bic_score_cpd.m
来自「贝叶斯网络的matlab实现。可以创建贝叶斯网络、训练模型」· M 代码 · 共 27 行
M
27 行
function score = BIC_score_CPD(CPD, fam, data, ns, cnodes)
% BIC_score_CPD Compute the BIC score of a generic CPD
% score = BIC_score_CPD(CPD, fam, data, ns, cnodes)
%
% We assume this node has a maximize_params method
ncases = size(data, 2);
CPD = reset_ess(CPD);
% make a fully observed joint distribution over the family
fmarginal.domain = fam;
fmarginal.T = 1;
fmarginal.mu = [];
fmarginal.Sigma = [];
if ~iscell(data)
cases = num2cell(data);
else
cases = data;
end
for m=1:ncases
CPD = update_ess(CPD, fmarginal, cases(:,m), ns, cnodes);
end
CPD = maximize_params(CPD);
self = fam(end);
ps = fam(1:end-1);
L = log_prob_node(CPD, cases(self,:), cases(ps,:));
score = L - 0.5*CPD.nparams*log(ncases);
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?