我试着用STAN估计多元正态分布的均值和协方差矩阵。我首先导入pystan并生成数据。我基本上是尝试遵循Python的官方YouTube tutorial。
import pystan as ps
import numpy as np
data = np.random.multivariate_normal(mean=[0.7, 0], cov=[[1,1], [1,2]], size=200)然后指定我的模型。我的数据具有形状(200,2)。因为我有一个多元分布,所以均值必须是一个向量,协方差必须是一个矩阵。
model =
"""
data
{
int N; // Number of data points.
vector[2] X[N]; // Values.
}
parameters
{
vector[2] mu; // Mean
matrix[2,2] sigma; // Covariance matrix.
}
model
{
X ~ multi_normal(mu, sigma);
}
"""然后,我将数据放入字典中,如YouTube上的STAN教程所示
my_data = {"N": 200, "X": data}
sm = ps.StanModel(model_code = model)模型编译时没有问题。然而,当我尝试拟合模型时,我得到了一个运行时错误。
fit = sm.sampling(data=my_data, iter=1000, chains=4)通向
/usr/lib/python3.6/multiprocessing/pool.py in get(self, timeout)
642 return self._value
643 else:
--> 644 raise self._value
645
646 def _set(self, i, obj):
RuntimeError: Initialization failed.我不确定是什么导致了这个错误,因为我的代码只是对教程中的代码进行了轻微的抽象。
发布于 2020-11-12 17:39:54
我自己找到了答案。在第二段代码中,我们需要用cov_matrix[2]替换matrix[2,2]。
matrix[2,2] sigma; // Covariance matrix.然后变成
cov_matrix[2] sigma; // Covariance matrix.显然,对于正定的对称矩阵,例如协方差矩阵,STAN有一种特殊的数据类型。这个简单的替换使代码运行时不会抛出错误。
https://stackoverflow.com/questions/64785056
复制相似问题