log_prior.m
来自「用matlab实现贝叶斯网络的学习、推理。」· M 代码 · 共 19 行
M
19 行
function L = log_prior(CPD)
% LOG_PRIOR Return log P(theta) for a tabular CPD
% L = log_prior(CPD)
switch CPD.prior_type
case 'none',
L = 0;
case 'dirichlet',
D = CPD.dirichlet(:);
L = sum(log(D + (D==0)));
case 'entropic',
% log-prior = log exp(-H(theta)) = sum_i theta_i log (theta_i)
fam_sz = CPD.sizes;
psz = prod(fam_sz(1:end-1));
ssz = fam_sz(end);
C = reshape(CPD.CPT, psz, ssz);
L = sum(sum(C .* log(C + (C==0))));
end
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?