cpd_to_pi.m
来自「基于matlab的bayes net toolbox,希望对大家能有些帮助」· M 代码 · 共 23 行
M
23 行
function pi = CPD_to_pi(CPD, msg_type, n, ps, msg, evidence)
% CPD_TO_PI Compute the pi vector (gaussian)
% function pi = CPD_to_pi(CPD, msg_type, n, ps, msg, evidence)
switch msg_type
case 'd',
error('gaussian_CPD can''t create discrete msgs')
case 'g',
[m, Q, W] = gaussian_CPD_params_given_dps(CPD, [ps n], evidence);
cps = ps(CPD.cps);
cpsizes = CPD.sizes(CPD.cps);
pi.mu = m;
pi.Sigma = Q;
for k=1:length(cps) % only get pi msgs from cts parents
%bk = block(k, cpsizes);
bk = CPD.cps_block_ndx{k};
Bk = W(:, bk);
m = msg{n}.pi_from_parent{k};
pi.Sigma = pi.Sigma + Bk * m.Sigma * Bk';
pi.mu = pi.mu + Bk * m.mu; % m.mu = u(k)
end
end
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?