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 + -
显示快捷键?