www.pudn.com > HMM1.zip > dhmm_sample_endstate.m
function [obs, hidden] = dhmm_sample_endstate(startprob, transmat, obsmat, endprob, numex)
> SAMPLE_DHMM Generate random sequences from an HMM with discrete outputs.
> function [obs, hidden] = sample_dhmm_endstate(startprob, transmat, obsmat, endprob, numex)
>
> We sample until we have have entered the end state
> obs{m} and hidden{m} are the m'th sequence
hidden = cell(1,numex);
obs = cell(1,numex);
for m=1:numex
hidden{m} = mc_sample_endstate(startprob, transmat, endprob);
T = length(hidden{m});
obs{m} = zeros(1,T);
for t=1:T
h = hidden{m}(t);
obs{m}(t) = sample_discrete(obsmat(h,:));
end
end