annotate toolboxes/FullBNT-1.0.7/bnt/examples/static/gibbs_test1.m @ 0:cc4b1211e677 tip

initial commit to HG from Changeset: 646 (e263d8a21543) added further path and more save "camirversion.m"
author Daniel Wolff
date Fri, 19 Aug 2016 13:07:06 +0200
parents
children
rev   line source
Daniel@0 1 function gibbs_test1()
Daniel@0 2
Daniel@0 3 disp('gibbs test 1')
Daniel@0 4
Daniel@0 5 rand('state', 0);
Daniel@0 6 randn('state', 0);
Daniel@0 7
Daniel@0 8 %[bnet onodes hnodes qnodes] = gibbs_ex_1;
Daniel@0 9 [bnet onodes hnodes qnodes] = gibbs_ex_2;
Daniel@0 10
Daniel@0 11 je = jtree_inf_engine(bnet);
Daniel@0 12 ge = gibbs_sampling_inf_engine (bnet, 'T', 50, 'burnin', 0, ...
Daniel@0 13 'order', [2 2 1 2 1]);
Daniel@0 14
Daniel@0 15 ev = sample_bnet(bnet);
Daniel@0 16
Daniel@0 17 evidence = cell(length(bnet.dag), 1);
Daniel@0 18 evidence(onodes) = ev(onodes);
Daniel@0 19 [je lj] = enter_evidence(je, evidence);
Daniel@0 20 [ge lg] = enter_evidence(ge, evidence);
Daniel@0 21
Daniel@0 22
Daniel@0 23 mj = marginal_nodes(je, qnodes);
Daniel@0 24
Daniel@0 25 [mg ge] = marginal_nodes (ge, qnodes);
Daniel@0 26 for t = 1:100
Daniel@0 27 [mg ge] = marginal_nodes (ge, qnodes, 'reset_counts', 0);
Daniel@0 28 diff = mj.T - mg.T;
Daniel@0 29 err(t) = norm (diff(:), 1);
Daniel@0 30 end
Daniel@0 31 clf
Daniel@0 32 plot(err);
Daniel@0 33 %title('error vs num. Gibbs samples')
Daniel@0 34
Daniel@0 35
Daniel@0 36 %%%%%%%
Daniel@0 37
Daniel@0 38 function [bnet, onodes, hnodes, qnodes] = gibbs_ex_1
Daniel@0 39 % bnet = gibbs_ex_1
Daniel@0 40 % a simple network to test the gibbs sampling engine
Daniel@0 41 % 1
Daniel@0 42 % / | \
Daniel@0 43 % 2 3 4
Daniel@0 44 % | | |
Daniel@0 45 % 5 6 7
Daniel@0 46 % \/ \/
Daniel@0 47 % 8 9
Daniel@0 48 % where all arcs point downwards
Daniel@0 49
Daniel@0 50 N = 9;
Daniel@0 51 dag = zeros(N,N);
Daniel@0 52 dag(1,2)=1; dag(1,3)=1; dag(1,4)=1;
Daniel@0 53 dag(2,5)=1; dag(3,6)=1; dag(4,7)=1;
Daniel@0 54 dag(5,8)=1; dag(6,8)=1; dag(6,9)=1; dag(7,9) = 1;
Daniel@0 55
Daniel@0 56 onodes = 8:9;
Daniel@0 57 hnodes = 1:7;
Daniel@0 58 qnodes = [1 2 6];
Daniel@0 59 ns = [2 3 4 3 5 2 4 3 2];
Daniel@0 60
Daniel@0 61 eclass = [1 2 3 2 4 5 6 7 8];
Daniel@0 62
Daniel@0 63 bnet = mk_bnet (dag, ns, 'equiv_class', eclass);
Daniel@0 64
Daniel@0 65 for i = 1:3
Daniel@0 66 bnet.CPD{i} = tabular_CPD(bnet, i);
Daniel@0 67 end
Daniel@0 68
Daniel@0 69 for i = 4:8
Daniel@0 70 bnet.CPD{i} = tabular_CPD(bnet, i+1);
Daniel@0 71 end
Daniel@0 72
Daniel@0 73
Daniel@0 74
Daniel@0 75 %%%%%%%
Daniel@0 76
Daniel@0 77 function [bnet, onodes, hnodes, qnodes] = gibbs_ex_2
Daniel@0 78 % bnet = gibbs_ex_2
Daniel@0 79 % a very simple network
Daniel@0 80 %
Daniel@0 81 % 1 2
Daniel@0 82 % \ /
Daniel@0 83 % 3
Daniel@0 84
Daniel@0 85 N = 3;
Daniel@0 86 dag = zeros(N,N);
Daniel@0 87 dag(1,3)=1; dag(2,3)=1;
Daniel@0 88
Daniel@0 89 onodes = 3;
Daniel@0 90 hnodes = 1:2;
Daniel@0 91 qnodes = 1:2;
Daniel@0 92 ns = [2 4 3];
Daniel@0 93
Daniel@0 94 eclass = [1 2 3];
Daniel@0 95
Daniel@0 96 bnet = mk_bnet (dag, ns, 'equiv_class', eclass);
Daniel@0 97
Daniel@0 98 for i = 1:3
Daniel@0 99 bnet.CPD{i} = tabular_CPD(bnet, i);
Daniel@0 100 end
Daniel@0 101
Daniel@0 102
Daniel@0 103
Daniel@0 104
Daniel@0 105
Daniel@0 106
Daniel@0 107