multiply_by_pot.m

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

M
20
字号
function bigpot = multiply_by_pot(bigpot, smallpot, varargin)
% MULTIPLY_BY_POT bigpot *= smallpot for cgpot
% bigpot = multiply_by_pot(bigpot, smallpot)
%
% smallpot's domain must be a subset of bigpot's domain.

bigpot = cg_mom_to_can(bigpot);
smallpot = cg_mom_to_can(smallpot);

mask = find_equiv_posns(smallpot.ddom, bigpot.ddom);
for i=1:bigpot.dsize
  if isempty(smallpot.ddom)
    src = 1;
  else
    sub = ind2subv(bigpot.dsizes, i);
    src = subv2ind(smallpot.dsizes, sub(mask));
  end
  bigpot.can{i} = multiply_by_pot(bigpot.can{i}, smallpot.can{src});
end                   

⌨️ 快捷键说明

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