python - 在 Stan 模型中将概率乘以常数

标签 python bayesian mcmc stan

我在 PySTAN 工作。假设我的可能性是:p1 * p2

其中p1 ~ N(x, xerr)

p2 = 0.823 if t = 0 
       1   if t = 1

我的模型是:

model = """
data {
    int<lower=0> N; // number of points
    vector[N] x; 
    vector[N] xerr; 
    vector[N] cnd; // indicator: elements are 0 or 1
}

parameters {
    real alpha; // intercept
    real beta; // slope
}

model {
    vector[N] p2;

    // PRIORS
    alpha ~ normal(0,10);
    beta ~ normal(0,10);

    p1 ~ normal(x, xerr);

   for (i in 1:N) {
       if (cnd[i] == 1)
            p2[i] ~ 0.823;
       else if (cnd[i] == 0)
            p2[i] ~ 1;
    }
}
"""

但是,我遇到了错误!

我想做的就是在满足特定条件的情况下将可能性乘以常数。我怎样才能在 PySTAN 中做到这一点?

这是我得到的错误和回溯:

Traceback (most recent call last):
  File "/home/paula/Desktop/fakedata.py", line 91, in <module>
    fit = pystan.stan(model_code=fit_code, data=fit_data, iter=10, chains=1)
  File "/usr/local/lib/python2.7/dist-packages/pystan/api.py", line 373, in stan
    save_dso=save_dso, verbose=verbose)
  File "/usr/local/lib/python2.7/dist-packages/pystan/model.py", line 219, in __init__
obfuscate_model_name=obfuscate_model_name)
  File "/usr/local/lib/python2.7/dist-packages/pystan/api.py", line 129, in stanc
raise ValueError(error_msg)

ValueError: Failed to parse Stan model     'anon_model_04ef08903b48c28a7c3fee52b890cdaf'. Error message:
SYNTAX ERROR, MESSAGE(S) FROM PARSER:


ERROR at line 43

 41:        for (i in 1:N) {
 42:        if (cnd[i] == 1)
 43:            p2[i] ~ 0.823
                           ^
 44:        else if (cnd[i] == 0)

PARSER EXPECTED: <distribution and parameters>

最佳答案

您要查找的函数是 increment_log_prob(...)

查看 Stan 手册了解详细信息:http://mc-stan.org/manual.html

还值得注意的是,目前获得 Stan 帮助的最佳位置是 stan-users 邮件列表:http://mc-stan.org/groups.html

关于python - 在 Stan 模型中将概率乘以常数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30711689/

相关文章:

ruby - 贝叶斯分类器分数代表什么?

algorithm - 贝叶斯线性回归如何处理交通强度的非随机数据集?

python - pymc 如何表示先验分布和似然函数?

r - 如何修复 R2jags::jags 中的 'Node inconsistent with parents'

python - 在python中导入带参数的模块

python - Pyramid "select"表单输入引发KeyError

python - 两次分配变量?

python - 编译时全局应用 extern C

python - BUGS模型和PyMC的区别?

python - 在 django 上使用 folium 的最佳实践