我正在使用主持人来分析一些与SN1a相关的数据。在处理真实数据之前,我从模拟数据开始。我所取得的结果似乎是好的:

现在,我要计算一些量的后验,例如
f(q,j) =j- q^2
用我为q和j得到的后验,有人能帮我吗?
发布于 2018-09-25 18:25:45
如果有j和q的原始后验样本,例如两个numpy数组j和q,那么对这些数组进行元素计算将得到所需变量的相应样本。在您的示例中,f = j - q**2。
我知道直接在采样器中捕获转换变量样本的选项存在于其他采样器中(斯坦,PyMC3)。也许知道主持人(不是我)的人知道怎么做。
发布于 2019-12-09 16:00:55
您可以使用参数的最终示例,然后获取转换的分位数,例如:
ndim=3 #number of parameters
chains= sampler.chain
samples = chains.reshape((-1, ndim))
q=samples[:,0]
j=samples[:,1]
H=samples[:,2]
f = j - q**2f现在可以表示为一个发行版:
import matplotlib.pyplot as plt
import numpy as np
plt.hist(f)
Q=np.quantile(f,q=[0.16,0.5,0.84])如果f达到高斯分布,则Q是1西格玛值‘q,Q1’的中值Q[1]
还可以使用标准错误传播方程(不确定):
f=Ej-Eq**2
df = np.sqrt(dj**2 - (2*Eq*dq)**2)这给了f = 0.9 +/- 0.25的dq = 0.03,dj = 0.25,Eq=-0.52,Ej=1.18 (从你的情节)。但是由于参数之间的高度相关性,这并不是最安全的方法。
https://stackoverflow.com/questions/52502029
复制相似问题