我试图使用 scipy.stats.rv_continuous 对给定概率密度函数(pdf)的随机变量进行采样:
class Distribution(stats.rv_continuous):
def _pdf(self,x, _a, _c):
return first_hitting_time(x, _a, _c)
其中函数第一次击球时间 is
#pdf of first hitting time of W_t + c*t on a.
def first_hitting_time(_t, _a, _c=0.0):
return _a/_t*np.exp(-0.5/_t*(_a-_c*_t)**2)/np.sqrt(2.0*np.pi*_t)
然后我继续
myrv= Distribution(name='hittingtime', a=0.002,b=30.0)
data3= myrv.rvs(size=10000, _a=1.0, _c=0.0)
翻译开始抱怨——
Traceback (most recent call last):
File "<ipython-input-246-71f67047462b>", line 1, in <module>
data3= myrv.rvs(size=10000, _a=1.0, _c=0.0)
File "C:\Users\ME\AppData\Local\Continuum\Anaconda2\lib\site-packages\scipy\stats\_distn_infrastructure.py", line 856, in rvs
raise ValueError("Domain error in arguments.")
ValueError: Domain error in arguments.
看来如果我设置_c
大于 0.0 的某个数字,它可以正常工作,但不适用于_c
小于0。
我对此有点困惑。任何帮助,将不胜感激。