Попытка согласовать распределение вероятностей Pearson3 с помощью scipy - PullRequest
0 голосов
/ 05 июня 2018

Я пытаюсь понять, как приспособить функцию распределения вероятностей, такую ​​как тип Пирсона 3, к набору данных (в частности, среднегодовое количество осадков в области). Я прочитал несколько вопросов об этом , но я все еще что-то упускаю, и примерка не подходит.На данный момент мой код таков (конкретный файл данных можно загрузить с здесь ):

import numpy as np
import matplotlib.pyplot as plt
from scipy.stats import pearson3
year,mm = np.loadtxt('yearly_mm_sde_boker_month_1960_2016.csv',delimiter=',').T
fig,ax=plt.subplots(1,2,figsize=(2*1.62*3,3))
ax[0].plot(year,mm)
dump=ax[1].hist(mm)

enter image description here

size = len(year)
param = pearson3.fit(mm)
pdf_fitted = pearson3.pdf(year, *param[:-2], loc=param[-2], scale=param[-1]) * size
plt.plot(pdf_fitted, label=dist_name)
plt.xlim(0,len(year))
plt.legend(loc='upper right')
plt.show()

enter image description here

Чего мне не хватает?

1 Ответ

0 голосов
/ 05 июня 2018

Ну, это работает:

param = pearson3.fit(mm) # distribution fitting

# now, param[0] and param[1] are the mean and 
# the standard deviation of the fitted distribution
x = np.linspace(0,200,100)
# fitted distribution
pdf_fitted = pearson3.pdf(x,*param[:-2], loc=param[-2], scale=param[-1])
# original distribution
#pdf = norm.pdf(x)

plt.title('Pearson 3 distribution')
plt.plot(x,pdf_fitted,'r-')#,x,pdf,'b--')
dump=plt.hist(mm,normed=1,alpha=.3)

enter image description here

...