これはPyMC のフォローアップです: マルコフ システムでのパラメーター推定
各タイムステップでの位置と速度によって定義されるシステムがあります。システムの動作は次のように定義されます。
vel = vel + damping * dt
pos = pos + vel * dt
これが私の PyMC モデルです。見積もりvel
、pos
そして最も重要なことdamping
。
# PRIORS
damping = pm.Normal("damping", mu=-4, tau=(1 / .5**2))
# we assume some system noise
tau_system_noise = (1 / 0.1**2)
# the state consist of (pos, vel); save in lists
# vel: we can't judge the initial velocity --> assume it's 0 with big std
vel_states = [pm.Normal("v0", mu=-4, tau=(1 / 2**2))]
# pos: the first pos is just the observation
pos_states = [pm.Normal("p0", mu=observations[0], tau=tau_system_noise)]
for i in range(1, len(observations)):
new_vel = pm.Normal("v" + str(i),
mu=vel_states[-1] + damping * dt,
tau=tau_system_noise)
vel_states.append(new_vel)
pos_states.append(
pm.Normal("s" + str(i),
mu=pos_states[-1] + new_vel * dt,
tau=tau_system_noise)
)
# we assume some observation noise
tau_observation_noise = (1 / 0.5**2)
obs = pm.Normal("obs", mu=pos_states, tau=tau_observation_noise, value=observations, observed=True)
これは私がサンプリングを実行する方法です:
mcmc = pm.MCMC([damping, obs, vel_states, pos_states])
mcmc.sample(50000, 25000)
pm.Matplot.plot(mcmc.get_node("damping"))
damping_samples = mcmc.trace("damping")[:]
print "damping -- mean:%f; std:%f" % (mean(damping_samples), std(damping_samples))
print "real damping -- %f" % true_damping
の値damping
は事前確率によって支配されます。ユニフォームなどの前を変えてもそのままです。
私は何を間違っていますか?別のレイヤーがあるだけで、前の例とほとんど同じです。
この問題の完全な IPython ノートブックは、http: //nbviewer.ipython.org/github/sotte/random_stuff/blob/master/PyMC%20-%20HMM%20Dynamic%20System.ipynbで入手できます。
[編集: いくつかの説明とサンプリングのためのコード。]
[EDIT2: @Chris の回答は役に立ちませんでした。AdaptiveMetropolis
*_states はモデルの一部ではないため、使用できませんでした。]