で定義されているようにガウス混合モデルを移植しようとしています: PyMC で 3 つの法線の混合をモデル化する方法は? pymc3に
コード
import numpy as np
from pymc import Model, Gamma, Normal, Dirichlet
from pymc import Multinomial
from pymc import sample, Metropolis
k = 3
ndata = 500
v = np.random.randint(0, k, ndata)
data = ((v == 0)*(50 + np.random.randn(ndata))
+ (v == 1)*(-50 + np.random.randn(ndata))
+ (v == 2)*np.random.randn(ndata))
model = Model()
with model:
dd = Dirichlet('dd', k=k, a=1, shape=k)
precs = Gamma('precs', alpha=0.1, beta=0.1, shape=k)
means = Normal('means', 0, 0.001, shape=k)
category = Multinomial('category',
n=1,
p=dd,
shape=ndata)
points = Normal('obs',
means[category],
precs[category],
observed=data)
tr = sample(3000, step=Metropolis())
次のコード エラーが発生します。
AttributeError: <pymc.quickclass.Multinomial object at 0x4804210> has no default value to use, checked for: ['mode'] pass testval argument or provide one of these.
私は何を間違っていますか?