fwd.m

来自「贝叶斯网络的matlab实现。可以创建贝叶斯网络、训练模型」· M 代码 · 共 18 行

M
18
字号
function [f, logscale] = fwd(engine, fpast, ev, t)
% Forwards pass.

f.obslik = mk_hmm_obs_lik_vec(engine, ev);
transmat = engine.transprob;
f.past_alpha = fpast.alpha;
if engine.maximize
  Q = length(fpast.alpha);
  A = repmat(fpast.alpha, [1 Q]);
  m = max(transmat .* A, [], 1);
  [f.alpha, scale] = normalise(m(:) .* f.obslik);
else
  [f.alpha, scale] = normalise((transmat' * fpast.alpha) .* f.obslik);
end
logscale = log(scale);
%f.xi = normalise((fpast.alpha * obslik') .* transmat); % t-1,t
f.t = t;

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?