如何使用 pymc 参数化概率图形模型?
假设我有一个带有两个节点的 PGMX
和Y
. 可以说X->Y
是图表。
并X
取两个值{0,1}
,
Y
也取两个值{0,1}
。
我想使用 pymc 来学习分布的参数并用它填充图形模型以运行推理。
我能想到的方法如下:
X_p = pm.Uniform("X_p", 0, 1)
X = pm.Bernoulli("X", X_p, values=X_Vals, observed=True)
Y0_p = pm.Uniform("Y0_p", 0, 1)
Y0 = pm.Bernoulli("Y0", Y0_p, values=Y0Vals, observed=True)
Y1_p = pm.Uniform("Y1_p", 0, 1)
Y1 = pm.Bernoulli("Y1", Y1_p, values=Y1Vals, observed=True)
这里Y0Vals
是Y
对应于X
values = 0Y1Vals
的值并且是Y
对应于X
values = 1 的值。
计划是从中抽取 MCMC 样本,并使用Y0_p
和的方法Y1_p
填充离散贝叶斯网络的概率......所以概率表为P(X) = (X_p,1-X_p)
while 的P(Y/X)
:
Y 0 1
X
0 Y0_p 1-Y0_p
1 Y1_p 1-Y1_p
问题:
- 这是这样做的正确方法吗?
- 这不会变得笨拙,特别是如果我有
X
100 个离散值?或者如果一个变量有两个父级X
并且Y
每个有 10 个离散值? - 有什么更好的我可以做的吗?
- 有没有什么好书详细说明我们如何进行这种互连。