亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? fwdback_twoslice.m

?? 貝葉斯網(wǎng)絡(luò)的matlab實(shí)現(xiàn)。可以創(chuàng)建貝葉斯網(wǎng)絡(luò)、訓(xùn)練模型
?? M
字號(hào):
function [alpha, beta, gamma, loglik, xi, gamma2] = fwdback_twoslice(engine, init_state_distrib, transmat, obslik, varargin)
% FWDBACK Compute the posterior probs. in an HMM using the forwards backwards algo.
%
% [alpha, beta, gamma, loglik, xi, gamma2] = fwdback(init_state_distrib, transmat, obslik, ...)
%
% Notation:
% Y(t) = observation, Q(t) = hidden state, M(t) = mixture variable (for MOG outputs)
% A(t) = discrete input (action) (for POMDP models)
%
% INPUT:
% init_state_distrib(i) = Pr(Q(1) = i)
% transmat(i,j) = Pr(Q(t) = j | Q(t-1)=i)
%  or transmat{a}(i,j) = Pr(Q(t) = j | Q(t-1)=i, A(t-1)=a) if there are discrete inputs
% obslik(i,t) = Pr(Y(t)| Q(t)=i)
%   (Compute obslik using eval_pdf_xxx on your data sequence first.)
%
% Optional parameters may be passed as 'param_name', param_value pairs.
% Parameter names are shown below; default values in [] - if none, argument is mandatory.
%
% For HMMs with MOG outputs: if you want to compute gamma2, you must specify
% 'obslik2' - obslik(i,j,t) = Pr(Y(t)| Q(t)=i,M(t)=j)  []
% 'mixmat' - mixmat(i,j) = Pr(M(t) = j | Q(t)=i)  []
%
% For HMMs with discrete inputs:
% 'act' - act(t) = action performed at step t
%
% Optional arguments:
% 'fwd_only' - if 1, only do a forwards pass and set beta=[], gamma2=[]  [0]
% 'scaled' - if 1,  normalize alphas and betas to prevent underflow [1]
% 'maximize' - if 1, use max-product instead of sum-product [0]
%
% OUTPUTS:
% alpha(i,t) = p(Q(t)=i | y(1:t)) (or p(Q(t)=i, y(1:t)) if scaled=0)
% beta(i,t) = p(y(t+1:T) | Q(t)=i)*p(y(t+1:T)|y(1:t)) (or p(y(t+1:T) | Q(t)=i) if scaled=0)
% gamma(i,t) = p(Q(t)=i | y(1:T))
% loglik = log p(y(1:T))
% xi(i,j,t-1)  = p(Q(t-1)=i, Q(t)=j | y(1:T))
% gamma2(j,k,t) = p(Q(t)=j, M(t)=k | y(1:T)) (only for MOG  outputs)
%
% If fwd_only = 1, these become
% alpha(i,t) = p(Q(t)=i | y(1:t))
% beta = []
% gamma(i,t) = p(Q(t)=i | y(1:t))
% xi(i,j,t-1)  = p(Q(t-1)=i, Q(t)=j | y(1:t))
% gamma2 = []
%
% Note: we only compute xi if it is requested as a return argument, since it can be very large.
% Similarly, we only compute gamma2 on request (and if using MOG outputs).
%
% Examples:
%
% [alpha, beta, gamma, loglik] = fwdback(pi, A, multinomial_prob(sequence, B));
%
% [B, B2] = mixgauss_prob(data, mu, Sigma, mixmat);
% [alpha, beta, gamma, loglik, xi, gamma2] = fwdback(pi, A, B, 'obslik2', B2, 'mixmat', mixmat);


if nargout >= 5, compute_xi = 1; else compute_xi = 0; end
if nargout >= 6, compute_gamma2 = 1; else compute_gamma2 = 0; end

[obslik2, mixmat, fwd_only, scaled, act, maximize, compute_xi, compute_gamma2] = process_options(varargin, 'obslik2', [], 'mixmat', [], 'fwd_only', 0, 'scaled', 1, 'act', [], 'maximize', 0, 'compute_xi', compute_xi, 'compute_gamma2', compute_gamma2);


[Q T] = size(obslik);

if isempty(obslik2)
  compute_gamma2 = 0;
end

if isempty(act)
  act = ones(1,T);
  transmat = { transmat } ;
end

scale = ones(1,T);

% scale(t) = Pr(O(t) | O(1:t-1)) = 1/c(t) as defined by Rabiner (1989).
% Hence prod_t scale(t) = Pr(O(1)) Pr(O(2)|O(1)) Pr(O(3) | O(1:2)) = Pr(O(1), ... ,O(T))
% or log P = sum_t log scale(t).
% Rabiner suggests multiplying beta(t) by scale(t), but we can instead
% normalise beta(t) - the constants will cancel when we compute gamma.

loglik = 0;

alpha = zeros(Q,T);
gamma = zeros(Q,T);
if compute_xi
  xi = zeros(Q,Q,T-1);
else
  xi = [];
end


%%%%%%%%% Forwards %%%%%%%%%%

t = 1;
alpha(:,1) = init_state_distrib(:) .* obslik(:,t);
if scaled
  %[alpha(:,t), scale(t)] = normaliseC(alpha(:,t));
  [alpha(:,t), scale(t)] = normalise(alpha(:,t));
end
if scaled, assert(approxeq(sum(alpha(:,t)),1)), end
for t=2:T
  %trans = transmat(:,:,act(t-1))';
  trans = transmat{act(t-1)};
  if maximize
    m = max_mult(trans', alpha(:,t-1));
    %A = repmat(alpha(:,t-1), [1 Q]);
    %m = max(trans .* A, [], 1);
  else
    m = trans' * alpha(:,t-1);
  end
  alpha(:,t) = m(:) .* obslik(:,t);
  if scaled
    %[alpha(:,t), scale(t)] = normaliseC(alpha(:,t));
    [alpha(:,t), scale(t)] = normalise(alpha(:,t));
  end
  if compute_xi & fwd_only  % useful for online EM
    %xi(:,:,t-1) = normaliseC((alpha(:,t-1) * obslik(:,t)') .* trans);
    xi(:,:,t-1) = normalise((alpha(:,t-1) * obslik(:,t)') .* trans);
  end
  if scaled, assert(approxeq(sum(alpha(:,t)),1)), end
end
if scaled
  if any(scale==0)
    loglik = -inf;
  else
    loglik = sum(log(scale));
  end
else
  loglik = log(sum(alpha(:,T)));
end

if fwd_only
  gamma = alpha;
  beta = [];
  gamma2 = [];
  return;
end


%%%%%%%%% Backwards %%%%%%%%%%

beta = zeros(Q,T);
if compute_gamma2
  M = size(mixmat, 2);
  gamma2 = zeros(Q,M,T);
else
  gamma2 = [];
end

beta(:,T) = ones(Q,1);
%gamma(:,T) = normaliseC(alpha(:,T) .* beta(:,T));
gamma(:,T) = normalise(alpha(:,T) .* beta(:,T));
t=T;
if compute_gamma2
  denom = obslik(:,t) + (obslik(:,t)==0); % replace 0s with 1s before dividing
  gamma2(:,:,t) = obslik2(:,:,t) .* mixmat .* repmat(gamma(:,t), [1 M]) ./ repmat(denom, [1 M]);
  %gamma2(:,:,t) = normaliseC(obslik2(:,:,t) .* mixmat .* repmat(gamma(:,t), [1 M])); % wrong!
end
for t=T-1:-1:1
  b = beta(:,t+1) .* obslik(:,t+1);
  %trans = transmat(:,:,act(t));
  trans = transmat{act(t)};
  if maximize
    B = repmat(b(:)', Q, 1);
    beta(:,t) = max(trans .* B, [], 2);
  else
    beta(:,t) = trans * b;
  end
  if scaled
    %beta(:,t) = normaliseC(beta(:,t));
    beta(:,t) = normalise(beta(:,t));
  end
  %gamma(:,t) = normaliseC(alpha(:,t) .* beta(:,t));
  gamma(:,t) = normalise(alpha(:,t) .* beta(:,t));
  if compute_xi
    %xi(:,:,t) = normaliseC((trans .* (alpha(:,t) * b')));
    xi(:,:,t) = normalise((trans .* (alpha(:,t) * b')));
    %xi(:,:,t) = (trans .* (alpha(:,t) * b'));
  end
  if compute_gamma2
    denom = obslik(:,t) + (obslik(:,t)==0); % replace 0s with 1s before dividing
    gamma2(:,:,t) = obslik2(:,:,t) .* mixmat .* repmat(gamma(:,t), [1 M]) ./ repmat(denom, [1 M]);
    %gamma2(:,:,t) = normaliseC(obslik2(:,:,t) .* mixmat .* repmat(gamma(:,t), [1 M]));
  end
end


% We now explain the equation for gamma2
% Let zt=y(1:t-1,t+1:T) be all observations except y(t)
% gamma2(Q,M,t) = P(Qt,Mt|yt,zt) = P(yt|Qt,Mt,zt) P(Qt,Mt|zt) / P(yt|zt)
%                = P(yt|Qt,Mt) P(Mt|Qt) P(Qt|zt) / P(yt|zt)
% Now gamma(Q,t) = P(Qt|yt,zt) = P(yt|Qt) P(Qt|zt) / P(yt|zt)
% hence
% P(Qt,Mt|yt,zt) = P(yt|Qt,Mt) P(Mt|Qt) [P(Qt|yt,zt) P(yt|zt) / P(yt|Qt)] / P(yt|zt)
%                = P(yt|Qt,Mt) P(Mt|Qt) P(Qt|yt,zt) / P(yt|Qt)
%

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
青青草精品视频| 成人精品一区二区三区中文字幕| 色婷婷综合久久久久中文| 国产精品夫妻自拍| 精品婷婷伊人一区三区三| 亚洲人亚洲人成电影网站色| 91视频一区二区| 蜜桃精品视频在线| 亚洲特黄一级片| 欧美一卡在线观看| 国产999精品久久| 国产麻豆成人传媒免费观看| 亚洲欧美日韩中文字幕一区二区三区| 一区二区三区四区av| 国内精品第一页| 日韩欧美在线1卡| 日韩专区一卡二卡| 国产精品久久久久久久久快鸭| 日本午夜精品一区二区三区电影 | 爽爽淫人综合网网站| 国产在线播精品第三| 精品奇米国产一区二区三区| 国产九色精品成人porny | 欧美色网一区二区| 美女任你摸久久| 亚洲成av人片www| 国产精品乱人伦| 亚洲精品在线网站| 91麻豆精品国产91久久久资源速度 | 国产精品亚洲专一区二区三区 | 99久久婷婷国产| 久久99精品久久久久久久久久久久| 亚洲欧洲成人精品av97| 久久久久亚洲蜜桃| 日韩欧美国产wwwww| 欧美色中文字幕| 在线看日韩精品电影| 不卡的电影网站| 国产精品一二一区| 成人小视频在线| 激情深爱一区二区| 久久国内精品视频| 国产成人av影院| 91麻豆精品在线观看| 色素色在线综合| 欧美亚日韩国产aⅴ精品中极品| 一本色道a无线码一区v| 欧美三级一区二区| 日韩一区二区三区在线视频| 91精品在线免费| 国产精品少妇自拍| 天天综合网 天天综合色| 久久精品国内一区二区三区| 国产成a人亚洲精品| 91国偷自产一区二区使用方法| 欧美成人一区二区三区在线观看| 国产精品毛片久久久久久久| 日韩精品免费专区| 成人精品电影在线观看| 欧美日韩的一区二区| 欧美mv日韩mv| 午夜精品久久久久久久久| 蜜臀av一区二区在线免费观看 | 国产精品天美传媒沈樵| 亚洲一区二区三区视频在线| 久久国产精品72免费观看| 91国内精品野花午夜精品| 久久精品视频免费| 欧美aaa在线| 欧美日韩精品三区| 亚洲精品日韩综合观看成人91| 亚洲成a人片在线不卡一二三区| 蜜桃91丨九色丨蝌蚪91桃色| 欧美吻胸吃奶大尺度电影| 国产三级精品三级| 国产高清亚洲一区| 日韩色在线观看| 美女国产一区二区三区| 日韩欧美国产小视频| 五月综合激情日本mⅴ| 色婷婷亚洲精品| 亚洲人成精品久久久久久| 成人免费高清视频| 国产精品视频第一区| 成人美女在线视频| 亚洲精品国产一区二区精华液| 91麻豆福利精品推荐| 爽好多水快深点欧美视频| 日韩欧美专区在线| 国产成人午夜高潮毛片| 中文字幕中文乱码欧美一区二区| 97超碰欧美中文字幕| 日本美女一区二区| 国产日产欧美一区二区三区| 成人a区在线观看| 婷婷开心激情综合| 中文字幕不卡的av| 日韩一区二区三区免费观看| 97精品国产露脸对白| 国产一区二区在线视频| 亚洲天堂久久久久久久| 欧美高清www午色夜在线视频| 日本成人在线网站| 亚洲视频一二三区| 精品成人a区在线观看| 不卡免费追剧大全电视剧网站| 视频一区免费在线观看| 中文一区在线播放| 欧美精品一区二区三| 97se亚洲国产综合自在线| 国产揄拍国内精品对白| 亚洲高清免费视频| 国产精品午夜电影| 久久一区二区视频| 26uuu欧美日本| 久久精品视频网| 久久日一线二线三线suv| 日韩一级欧美一级| 久久久久久一二三区| 精品捆绑美女sm三区| 26uuu国产电影一区二区| 欧美一区二区三区啪啪| 欧美精品久久久久久久久老牛影院| 99久久综合99久久综合网站| 国产成人精品综合在线观看 | 亚洲视频一二三| 日本vs亚洲vs韩国一区三区| 国产一区二区免费在线| 成人午夜视频免费看| 成人精品高清在线| 91国偷自产一区二区开放时间 | 国产精品免费久久久久| 中文字幕一区二区三区四区不卡 | 精品在线视频一区| 91亚洲午夜精品久久久久久| 色婷婷久久一区二区三区麻豆| 91福利在线播放| 日韩一区二区三区三四区视频在线观看 | 中文字幕一区二区不卡| 亚洲国产一区二区三区| 久久国产夜色精品鲁鲁99| av中文字幕一区| 日韩免费视频线观看| 一区二区在线观看免费| 成人激情小说网站| 日韩欧美国产综合一区| 亚洲国产另类av| www.亚洲色图| 国产精品美女视频| 国产一区二区伦理| 欧美老肥妇做.爰bbww| 国产精品国产三级国产| 麻豆精品久久久| 欧美精品成人一区二区三区四区| 国产精品久久久久一区| 免费不卡在线视频| 欧美一区国产二区| 天堂在线一区二区| 欧美卡1卡2卡| 日韩国产欧美一区二区三区| 欧美制服丝袜第一页| 亚洲女同一区二区| 91麻豆免费在线观看| 国产精品国产三级国产专播品爱网| 国产一区二区免费看| 欧美日韩亚洲综合一区| 亚洲欧美怡红院| 欧美亚洲一区二区在线| 亚洲一区二区三区在线| 欧美一区二区在线免费播放| 日本欧美韩国一区三区| 日韩视频中午一区| 国产精品综合二区| 中文字幕+乱码+中文字幕一区| 成人不卡免费av| 夜夜精品视频一区二区| 欧美电影在线免费观看| 国产美女主播视频一区| 国产亚洲欧美在线| 欧美日韩一区中文字幕| 男人的j进女人的j一区| 国产精品美女视频| 日韩欧美在线123| av网站一区二区三区| 欧美成人乱码一区二区三区| 色综合视频在线观看| 国产成人精品三级麻豆| 日韩极品在线观看| 亚洲摸摸操操av| 精品国产乱码久久久久久夜甘婷婷| 国v精品久久久网| 日本不卡一二三区黄网| 亚洲一本大道在线| 亚洲精品在线免费观看视频| 99视频精品在线| 国产精品一级片在线观看| 美女视频网站黄色亚洲| 亚洲午夜在线观看视频在线| 国产精品国产a| 国产午夜精品在线观看|