gpt4 book ai didi

pymc - 拟合具有可变速率的上限泊松过程

转载 作者:行者123 更新时间:2023-12-01 07:18:30 27 4
gpt4 key购买 nike

我正在尝试使用最大后验估计来估计泊松过程的速率,其中速率随时间变化。这是一个速率线性变化的简化示例 (λ = ax+b):

import numpy as np
import pymc

# Observation
a_actual = 1.3
b_actual = 2.0
t = np.arange(10)
obs = np.random.poisson(a_actual * t + b_actual)

# Model
a = pymc.Uniform(name='a', value=1., lower=0, upper=10)
b = pymc.Uniform(name='b', value=1., lower=0, upper=10)


@pymc.deterministic
def linear(a=a, b=b):
return a * t + b

r = pymc.Poisson(mu=linear, name='r', value=obs, observed=True)

model = pymc.Model([a, b, r])
map = pymc.MAP(model)
map.fit()
map.revert_to_max()

print "a :", a._value
print "b :", b._value

这工作正常。但是我的实际泊松过程受到确定性值的限制。由于我无法将观察到的值与确定性函数相关联,因此我为我的观察添加了一个具有小方差的正态随机函数:

import numpy as np
import pymc

# Observation
a_actual = 1.3
b_actual = 2.0
t = np.arange(10)
obs = np.random.poisson(a_actual * t + b_actual).clip(0, 10)

# Model
a = pymc.Uniform(name='a', value=1., lower=0, upper=10)
b = pymc.Uniform(name='b', value=1., lower=0, upper=10)


@pymc.deterministic
def linear(a=a, b=b):
return a * t + b

r = pymc.Poisson(mu=linear, name='r')


@pymc.deterministic
def clip(r=r):
return r.clip(0, 10)

rc = pymc.Normal(mu=r, tau=0.001, name='rc', value=obs, observed=True)

model = pymc.Model([a, b, r, rc])
map = pymc.MAP(model)
map.fit()
map.revert_to_max()

print "a :", a._value
print "b :", b._value

此代码产生以下错误:

Traceback (most recent call last):
File "pymc-bug-2.py", line 59, in <module>
map.revert_to_max()
File "pymc/NormalApproximation.py", line 486, in revert_to_max
self._set_stochastics([self.mu[s] for s in self.stochastics])
File "pymc/NormalApproximation.py", line 58, in __getitem__
tot_len += self.owner.stochastic_len[p]
KeyError: 0

知道我做错了什么吗?

最佳答案

“上限”是指它是截断的泊松吗?看来这就是你所说的。如果是左截断(更常见),则可以使用 TruncatedPoisson分布,但由于您正在执行正确的截断,因此您不能(我们应该使这更通用!)。您正在尝试的方法不起作用——泊松对象没有 clip()方法。您可以做的是使用因子潜力。它看起来像这样:

@pymc.potential
def clip(r=r):
if np.any(r>10):
return -np.inf
return 0

这将约束 r 的值小于 10。引用 pymc docs有关 Potential 的信息类(class)。

关于pymc - 拟合具有可变速率的上限泊松过程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22678052/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com