Mercurial > hg > camir-aes2014
view toolboxes/FullBNT-1.0.7/bnt/examples/dynamic/Old/online1.m @ 0:e9a9cd732c1e tip
first hg version after svn
author | wolffd |
---|---|
date | Tue, 10 Feb 2015 15:05:51 +0000 |
parents | |
children |
line wrap: on
line source
% Check that online inference gives same results as filtering for various algorithms N = 3; Q = 2; ss = N*2; rand('state', 0); randn('state', 0); obs_size = 1; discrete_obs = 0; bnet = mk_chmm(N, Q, obs_size, discrete_obs); ns = bnet.node_sizes_slice; engine = {}; engine{end+1} = hmm_inf_engine(bnet); E = length(engine); onodes = (1:N)+N; T = 4; ev = cell(ss,T); ev(onodes,:) = num2cell(randn(N, T)); filter = 1; loglik2 = zeros(1,E); for e=1:E [engine2{e}, loglik2(e)] = enter_evidence(engine{e}, ev, 'filter', filter); end loglik = zeros(1,E); marg1 = cell(E,N,T); for e=1:E ll = zeros(1,T); engine{e} = dbn_init_bel(engine{e}); for t=1:T [engine{e}, ll(t)] = dbn_update_bel(engine{e}, ev(:,t), t); for i=1:N marg1{e,i,t} = dbn_marginal_from_bel(engine{e}, i); end end loglik1(e) = sum(ll); end assert(approxeq(loglik1, loglik2)) a = zeros(E,N,T); for e=1:E for t=1:T for i=1:N marg2{e,i,t} = marginal_nodes(engine2{e}, i, t); a(e,i,t) = (approxeq(marg2{e,i,t}.T(:), marg1{e,i,t}.T(:))); end end end assert(all(a(:)==1))