Model Markov tersembunyi: Perbedaan antara revisi

Konten dihapus Konten ditambahkan
Loveless (bicara | kontrib)
Rangerbiru II (bicara | kontrib)
Fitur saranan suntingan: 3 pranala ditambahkan.
Tag: VisualEditor Suntingan perangkat seluler Suntingan peramban seluler Tugas pengguna baru Disarankan: tambahkan pranala
 
(17 revisi perantara oleh 13 pengguna tidak ditampilkan)
Baris 1:
{{rapikan}}
'''Model Markov Tersembunyi''' atau lebih dikenal sebagai '''Hidden Markov Model''' ('''HMM''') adalah sebuah model statistik dari sebuah sistem yang diasumsikan sebuah Markov[[Proses ProcessMarkov]] dengan parameter yang tak diketahui, dan tantangannya adalah menentukan parameter-parameter tersembunyi (hiddenstate) dari parameter-parameter yang dapat diamati (observer). Parameter-parameter yang ditentukan kemudian dapat digunakan untuk analisis yang lebih jauh, misalnya untuk aplikasi Pattern Recognition. Sebuah HMM dapat dianggap sebagai4, sebuah Bayesian Network dinamis yang paling sederhana.
 
Pada model Markov umum (Vanilla/Visible Markov Model), state-nya langsung dapat diamati, oleh karena itu probabilitas transisi state menjadi satu-satunya parameter. Di dalam Model Markov yang Hidden (tersembunyi) , state-nya tidak dapat diamati secara langsung, akan tetapi yang dapat diamati adalah variabel-variabel yangyatng terpengaruh oleh state. Setiap state memiliki distribusi probabilitas atas token-token output yang mungkin muncul. Oleh karena itu rangkaian token yang dihasilkan oleh HMM memberikan sebagian informasi tentang sekuens state-state.
 
Hidden Markov Model sangat populer diaplikasikan di bidang speech recognition dan bioinformatics.
 
 
== Arsitektur ==
[[Berkas:http://upload.wikimedia.org/wikipedia/en/a/ab/Hmm_temporal_bayesian_net.png]]
 
Diagram di bawahatas menggambarkan arsitektur umum tentang HMM. Masing-masing bentuk oval menggambarkan sebuah variabel acak (random variable) yang berisikan nilai. Variabel Acak x(t) berisikan nilai sebuah variabel tersembunyi pada saat t. variabel acak y(t) berisikan nilai sebuah variabel yang dapat diamati (tidak tersembunyi) pada saat t. Anak panah menunjukkan ketergantungan kondisional. Dari diagram, jelas kiranya bahwa nilai x(t) hanya bergantung pada nilai x(t-1). Selain itu, nilai y(t) hanya bergantung pada x(t).
 
Diagram di bawah menggambarkan arsitektur umum tentang HMM. Masing-masing bentuk oval menggambarkan sebuah variabel acak (random variable) yang berisikan nilai. Variabel Acak x(t) berisikan nilai sebuah variabel tersembunyi pada saat t. variabel acak y(t) berisikan nilai sebuah variabel yang dapat diamati (tidak tersembunyi) pada saat t. Anak panah menunjukkan ketergantungan kondisional. Dari diagram, jelas kiranya bahwa nilai x(t) hanya bergantung pada nilai x(t-1). Selain itu, nilai y(t) hanya bergantung pada x(t).
 
[[Berkas:http://upload.wikimedia.org/wikipedia/en/a/ab/Hmm_temporal_bayesian_net.png]]
 
== Probabilitas Barisan (Sequence) yang Teramati ==
 
Probabilitas mengamati barisan Y = y(0), y(1), ... , y(L-1), dengan panjang barisan L diberikan oleh persamaan:
 
Di mana penjumlahannya meliputi seluruh node tersembunyi (hidden) pada barisan X = x(0), x(1), ... , x(L-1). Perhitungan kasar (brute force) P(Y) termasuk intractable untuk masalah-masalah di dunia nyata, karena jumlah hidden node yang sangat besar (pada umumnya). Akan tetapi, perhitungan nya dapat sangat dipercepat menggunakan algoritma[[Algoritma|algoritme]] dynamic programming yang dinamai forward algorithm.
 
== Penggunaan Hidden Markov Model ==
Ada tiga permasalahan utama yang dapat diselesaikan HMM<{{br />}}
 
* Diberikan parameter dari model, hitunglah probabilitas output berupa suatu barisan tertentu. {{br}}Masalah ini diselesaikan oleh forward algorithm.{{br}}
Ada tiga permasalahan utama yang dapat diselesaikan HMM<br />
: * Diberikan parameter dari model, hitunglahcarilah probabilitasbarisan outputstate berupatersembunyi suatuyang paling mungkin {{br}}menghasilkan output barisan tertentu. <br(yang diberikan). />Masalah ini diselesaikan oleh forwardalgoritme algorithm{{br}}Viterbi.<{{br />}}
* Diberikan sebuah barisan *output Diberikanatau parameterhimpunan daribarisan modelsepertinya, carilahmaka barisantemukan statehimpunan tersembunyitransisi {{br}}state yang paling mungkin <brbeserta />menghasilkanprobabilitas outputoutputnya. barisanDengan tertentukata (yanglain, latihlah parameter HMM {{br}}jika diberikan) dataset barisan-barisan tertentu. Masalah ini diselesaikan oleh algoritmaalgoritme <Baum-Welch{{br />Viterbi.<br />}}
* Diberikan sebuah barisan output atau himpunan barisan sepertinya, maka temukan himpunan transisi <br />state yang paling mungkin beserta probabilitas outputnya. Dengan kata lain, latihlah parameter HMM <br />jika diberikan dataset barisan-barisan tertentu. Masalah ini diselesaikan oleh algoritma Baum-Welch<br />
 
== Sebuah Contoh Konkret ==
Baris 31 ⟶ 26:
Misalkan Anda memiliki seorang kawan yang tinggal di tempat yang jauh, dan Anda selalu berbicara dengannya setiap hari lewat telepon, tentang apa yang dia lakukan pada hari tersebut. Kawan Anda hanya tertarik pada tiga macam aktivitas: berjalan di taman, berbelanja, dan membersihkan apartemen. Pilihan atas apa yang hendak dia lakukan hanya ditentukan berdasarkan cuaca pada hari tersebut. Anda tidak memiliki informasi yang sahih tentang cuaca di tempat kawan Anda, tapi Anda tahu kecenderungannya secara umum. Berdasarkan apa yang dia ungkapkan setiap hari, Anda mencoba menebak seperti apa cuaca di sana.
 
Anda mengasumsikan bahwa [[cuaca]] bergerak sebagai sebuah Rantai Markov diskret. Ada dua macam state: "Hujan" dan "Cerah", namun Anda tidak dapat mengamatinya secara langsung (dengan kata lain, state ini tersembunyi dari Anda). Pada setiap harinya, ada peluang tertentu bahwa kawan Anda melakukan satu dari tiga aktivitas ini (bergantung dari cuaca di tempatnya) : "jalan-jalan"/'walk', "berbelanja"/'shop', atau "membersihkan"/'clean'. Pengamatan di sini adalah penyampaian informasi aktivitas yang dilakukan kawan Anda. Keseluruhan sistem dapat dianggap sebagai sebuah Hidden Markov Model (HMM).
 
Anggaplah Anda tahu kecenderungan cuaca di daerah kawan tersebut, dan kecenderungan apa yang kawan Anda lakukan (secara rata-rata). Dengan kata lain, parameter-parameter dari HMM sudah diketahui. Anda bisa menuliskannya di dalam [[bahasa pemrograman]] Python:
 
states = ('Rainy', 'Sunny')
Baris 42 ⟶ 37:
transition_probability = {
'Rainy' : {'Rainy': 0.7, 'Sunny': 0.3},
'Sunny' : {'Rainy': 0.4, 'Sunny': 0.6},
}
emission_probability = {
'Rainy' : {'walk': 0.1, 'shop': 0.4, 'clean': 0.5},
'Sunny' : {'walk': 0.6, 'shop': 0.3, 'clean': 0.1},
}
 
Dalam penggalan kode di atas, start_probability mewakili ketidakpastian tentang state mana HMM berada ketika kawan Anda menelfon untuk pertamakali. (Yang Anda ketahui hanyalah kecenderungan untuk hujan). Distribusi Peluang yang digunakan di sini bukanlah yang setimbang, yang (merujuk pada peluang transisi) kira-kira {'Rainy':0.571, 'Sunny':0.429}. transition_probability menggambarkan perubahan cuaca di [[rantai Markov]] yang dipakai. Dalam contoh ini, hanya 30% peluang bahwa besok akan cerah jika hari ini hujan. emmision_probability menggambarkan seberapa mungkin kawan Anda melakukan aktivitas tertentu pada satu harinya. Jika hari hujan, maka ada 50% peluang bahwa dia sedang membersihkan apartemennya; jika hari cerah, ada 60% peluang bahwa dia ada di luar untuk berjalan-jalan.
 
== Aplikasi dari Hidden Markov Model ==
Baris 63 ⟶ 58:
[[Kategori:Bioinformatika]]
[[Kategori:Statistika]]
 
[[af:Verborge Markovmodel]]
[[bg:Скрит модел на Марков]]
[[ca:Model ocult de Markov]]
[[de:Hidden Markov Model]]
[[en:Hidden Markov model]]
[[es:Modelo oculto de Márkov]]
[[fi:Markovin piilomalli]]
[[fr:Modèle de Markov caché]]
[[it:Modello nascosto di Markov]]
[[ja:隠れマルコフモデル]]
[[nl:Hidden Markov Model]]
[[ru:Скрытая марковская модель]]
[[sl:Skriti model Markova]]
[[sv:Dold Markovmodell]]
[[vi:Mô hình Markov ẩn]]
[[zh:隐马尔可夫模型]]