Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / PHP, Perl, Python [игнор отключен] [закрыт для гостей] / Аппроксимация функции / 2 сообщений из 2, страница 1 из 1
19.01.2015, 16:57
    #38857750
rs5630
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Аппроксимация функции
Дана функция y = x^2 + случайное значение от 0 до 0.3. Нужно построить среднюю кривую и среднеквадратичное отклонение. Желательно с помощью numpy. Подскажите, как правильно построить среднюю кривую и среднеквадратичное отклонение.

Код: python
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
import numpy as np
import matplotlib.pyplot as plt
x = np.linspace(0,3,20)
y = np.zeros(20)
a = np.random.normal(0,0.3,size=2E1)
for i in range(20):
    y[i] = x[i]**2 + a[i]
means = np.zeros(20)
stds = np.zeros(20)
for i in range(20):
    means[i] = np.mean(y[:i])
    stds[i] = np.std(y[:i])
plt.plot(x, y, 'bo-', lw = 1, label=u'Function')
plt.plot(x, means, lw = 1, label=u'Average')
plt.errorbar(x, means, stds, label=u'Std')
plt.legend(loc='best')
plt.title(u'Plots')
plt.xlabel('X')
plt.ylabel('Y')
plt.grid()
plt.show()
...
Рейтинг: 0 / 0
20.01.2015, 00:23
    #38857974
rs5630
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Аппроксимация функции
Нашел как построить среднее и СКО, но нужно, чтобы среднее было кривой как на графике ниже, а не прямой как у меня. Подскажите как изменить программу.

График: https://ru.wikipedia.org/wiki/?????_??????????_?????????#mediaviewer/File:Linear_least_squares(2).svg

Код: python
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
import numpy as np
import matplotlib.pyplot as plt
from math import *
x = np.linspace(0,3,20)
y = np.zeros(20)
a = np.random.normal(0,0.3,size=2E1)
for i in range(20):
    y[i] = x[i]**2 + a[i]
A = np.vstack([x, np.ones(len(x))]).T
m, c = np.linalg.lstsq(A, y)[0]
import matplotlib.pyplot as plt
plt.plot(x, y, 'bo-', lw = 1, label=u'Function')
plt.plot(x, m*x + c, 'r', label='Average')
std = np.zeros(20)
for i in range(20):
    std[i] = (sqrt((y[i] - (m*x[i] + c))**2))
plt.errorbar(x, y, std, label=u'Std')
plt.legend(loc='best')
plt.title(u'Plots')
plt.xlabel('X')
plt.ylabel('Y')
plt.grid()
plt.show()
...
Рейтинг: 0 / 0
Форумы / PHP, Perl, Python [игнор отключен] [закрыт для гостей] / Аппроксимация функции / 2 сообщений из 2, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]