1. 定義transition probability和 emis probability .
data:image/s3,"s3://crabby-images/bc0c2/bc0c2fc587b8407fbfc2104ea83ca7e3e3ee206d" alt=""
trans = [0.95,0.05 ;
0.10,0.90 ] ;
data:image/s3,"s3://crabby-images/15c5c/15c5c1123252c9a44634a7e2507827039c9b4a9b" alt=""
emis = [1/6 1/6 1/6 1/6 1/6 1/6;
1/10 1/10 1/10 1/10 1/10 1/2 ];
2. 用定義好的probability隨機產生一個sequence.
seq 存的是在第 i 步時的symbol,
states 存的是在第 i 步時所在的 state.
[seq,states] = hmmgenerate( 8,trans,emis);
result :
data:image/s3,"s3://crabby-images/add92/add9276d3a88ec53302b7d3e2a92a400cad5cf6a" alt=""
3. 可對symbols 及 states 另取名稱 .
[seq,states] = hmmgenerate( 8 ,trans,emis,...
'Symbols',{'one','two','three','four','five','six'},...
'Statenames',{'fair';'loaded'})
result :
data:image/s3,"s3://crabby-images/acf61/acf61b4f8231d361112655a4c237eadc06003dfd" alt=""
==用已知的sequence, states反推出 trans 和 emis 機率==
1. 用此matlab指令
[estimateTR,estimateE] = hmmestimate(seq,states);
result :
data:image/s3,"s3://crabby-images/d0233/d0233b09371850922a174f67ca56753dd8d443ad" alt=""
data:image/s3,"s3://crabby-images/eb9fa/eb9fa7b9822bac41485bf67f8e631593dbec8244" alt=""
=======pStates========
trans, emis, seq同上,輸入matlab指令.
PSTATES = hmmdecode(seq,TRANS,EMIS);
result :
data:image/s3,"s3://crabby-images/a4883/a4883b594690450c670f00ba39b63e5d0052426a" alt=""
沒有留言:
張貼留言