الگوریتم ویتربی

الگوریتم ویتربی (به انگلیسی: Viterbi algorithm) الگوریتمی پویا برای پیدا کردن محتمل‌ترین مسیر از حالت‌های پنهان، با داشتن یک توالی از مشاهدات است.

این الگوریتم اغلب در مواردی بکار می‌رود که با داشتن یک مدل پنهان مارکف و توالی‌ای از مشاهدات، می‌خواهیم بدانیم چه توالی‌ای از حالت‌ها (مسیر) این مشاهدات را تولید کرده‌اند. به عبارت دیگر ما دنبال محتمل‌ترین مسیر به‌وجودآورندهٔ مشاهدات در یک مدل پنهان مارکف هستیم.

پیدایش و کاربردها

در بسیاری از کاربردهای مدل‌های پنهان مارکف، متغیرهای پنهان تفسیر معناداری دارند و در نتیجه یکی از مهم‌ترین مسائل در این حیطه، پیدا کردن محتمل‌ترین توالی از متغیرهای پنهان با داشتن یک توالی از مشاهدات است. به‌عنوان مثال، در حوزهٔ بازشناسی گفتار، می‌خواهیم یک توالی از واج‌ها با استفاده از توالی‌ای از آواها داشته باشیم.

این مسئله نباید با مسئلهٔ پیدا کردن محتمل‌ترین مجموعه از حالت‌های پنهان اشتباه گرفته شود. مسئلهٔ دوم می‌تواند با استفاده از الگوریتم پس‌رو-پیش‌رو حل شود. بدین صورت که ابتدا توزیع حاشیه‌ای برای هر متغیر نهان را به‌دست آورده و سپس جداگانه آن‌ها را بیشینه می‌کنیم.[1] اما در حالت کلی، مسئلهٔ پیدا کردن محتمل‌ترین توالی پراهمیت‌تر بوده و الگوریتم بهینهٔ ارائه‌شده برای آن، الگوریتم جمع-بیشینه که در حیطهٔ مدل‌های پنهان مارکف، به آن الگوریتم ویتربی گفته می‌شود استفاده کرد.[2]

در مسائل طبیعی مانند در، همیشه واقعیت منطبق بر محتمل‌ترین مسیر نیست. اما بسیاری اوقات محتمل‌ترین مسیر نیز اطلاعات خوبی در اختیار می‌گذارد.

مدل‌های پنهان مارکف برای جزایز سی‌پی‌جی

در این بخش، به بررسی یکی از کاربردهای این مسئله در بیوانفورماتیک می‌پردازیم. مسئله جزایر سی‌پی‌جی (CpG islands) -پیدا کردن ناحیه‌ای از ژنوم که فرکانس بالایی از مکان‌های CG در آن وجود دارد- است. این مسئله را می‌توان با استفاده از دو مدل مخفی مارکف مدل کرد. کافی است حالت‌های مخفی را دو حالتِ و در نظر گیریم به‌طوری که زمانی که در ناحیهٔ سی‌جی‌پی قرار داریم یا زمانی که در این ناحیه قرار نداریم؛ و حالت‌هایمان نیز حروف A, C، G و T که در واقع نوکلئوتیدهای روی رشته‌اند در نظر گیریم. پس مجموعاً ۸ حالت مخفی که در شکل زیر نمایش داده شده‌اند را داریم.[3]

جستجوی کامل فضای مسئله

می‌توانیم تمامی مسیرهای ممکن را که مشاهده ما را تولید می‌کنند را پیدا کنیم، سپس با محاسبه احتمال آنها، محتمل‌ترین مسیر را بدست آوریم. به عنوان نمونه در مسئله آب و هوا (می‌توانید در مثال‌هایی برای مدل پنهان مارکف ببینید) مشاهدی ما به صورت خشک، نم‌دار، مرطوب است. برای به‌دست آوردن محتمل‌ترین مسیر باید احتمال زیر بیشینه شود:

Pr(توالی مشاهده شده | انتخابی از حالت‌های مخفی)

برای جستجوی تمامی فضای جواب باید این احتمال را برای تمامی مسیرها بدست بیاوریم:

Pr(خشک، نم‌دار، مرطوب | آفتابی، آفتابی، آفتابی)، Pr(خشک، نم‌دار، مرطوب | آفتابی، آفتابی، ابری)، Pr(خشک، نم‌دار، مرطوب | آفتابی، آفتابی، بارانی)، . . Pr(خشک، نم‌دار، مرطوب | بارانی، بارانی، بارانی)

پیچیدگی زمانی این راه‌حل از اندازهٔ نمایی () بوده و بهینه نیست. برای سرعت بخشیدن به الگوریتم می‌توان از تکنیک شاخه و حد استفاده کرد اما یک راه حل در زمان چندجمله‌ای برای این مسئله وجود دارد که الگوریتم ویتربی است.

الگوریتم ویتربی

همان‌طور که در بخش قبل توضیح داده‌شد، تعداد حالت‌های ممکن برای متغیرهای پنهان یا معادلاً تعداد مسیرها نسبت به طول توالی از اندازهٔ نمایی است. شکل زیر، حالت‌های متغیرهای نهان یک مدل پنهان مارکف را به‌صورت یک شبکه نشان داده‌است که در آن، حالت‌های مختلف برای هر متغیر نهان با رنگ‌های متفاوت مشخص شده‌اند و متغیرهای نهان به‌صورت افقی از چپ به راست نمایش داده شده‌اند. با استفاده از الگوریتم ویتربی، می‌خواهیم محتمل‌ترین مسیر را در این شبکه بیابیم به‌طوری که هزینهٔ محاسباتی به‌صورت خطی با طول توالی افزایش یابد.

تعداد مسیرهای مختلف یا به عبارت دیگر حالت‌های ممکن برای متغیرهای پنهان، از اندازهٔ نمایی است ولی با استفاده از الگوریتم ویتربی می‌توان محتمل‌ترین آن‌ها را با استفاده از الگوریتم چندجمله‌ای به‌دست‌آورد. برای هر مسیر داده‌شده، احتمال متناظر با استفاده از ضرب مقادیر ماتریس انتقال احتمال‌ها برای هر قسمت از مسیر با استفاده از احتمال‌های انتشار متناظر با هر گره در مسیر به‌دست می‌آید.[4]

تعریف مسئله

با توجه به توضیحات داده‌شده، می‌دانیم می‌توان مسئله را به‌صورت زیر بازنویسی کرد:

می‌خواهیم مسیر بهینه‌ای مانند پیدا کنیم به‌گونه‌ای که داشته باشیم: . که در آن یک توالی از مشاهدات و یک توالی از متغیرهای پنهان باشد.

می‌دانیم برای محاسبهٔ احتمال بالا داریم: . که در آن مقادیر احتمال‌های انتقال و احتمال انتشار را نشان می‌دهد. برای اطلاعات بیشتر به صفحهٔ مدل پنهان مارکف مراجعه کنید.

ایدهٔ الگوریتم[5]

اگر گره‌های گراف روبرو را با استفاده از دوتایی‌هایی که به‌ترتیب از شمارهٔ متغیر نهان و شمارهٔ حالت‌های ممکن برای آن‌ها تشکیل‌شده باشند، نمایش دهیم، می‌توان وزن بین دو گرهٔ و را برابر با مقدار تعریف کرد. حال می‌توان احتمال برای یک مسیر مانند به‌طوری که با یال به گرهٔ ختم شود را به‌صورت زیر محاسبه کرد:

حال کافی است متغیر را به‌طوری تعریف کنیم که احتمال بهترین مسیر تا مکان باشد، به‌طوری که توالی مشاهدات به ختم شده‌باشد و متغیر نهان برابر با باشد؛ بنابراین طبق نتایج بالا داریم:

شبه‌کد الگوریتم[5]

ورودی:

مدل که:

: الفبای مشاهدات
Q: مجموعه حالات
P: ماتریس احتمال انتقال بین حالات
e: ماتریس احتمال تولید الفبا در هر حالت

و توالی

خروجی: محتمل‌ترین مسیر به‌گونه‌ای که

محاسبات آغازین: (i=۰) قرار بده و برای تمام kهای بزرگتر از صفر قرار بده

برای i از ۱ تا L و تمامی lها عضو Q
قرار بده
قرار بده

خاتمه:

و محتمل‌ترین مسیر

بازگشت:

برای i از L تا ۱:
قرار بده

منابع

  1. Pattern Classification, Duda et al. , 2001.
  2. Forney, G.D. (1973). "The viterbi algorithm". Proceedings of the IEEE. 61 (3): 268–278. doi:10.1109/proc.1973.9030. ISSN 0018-9219.
  3. Durbin, Richard, Sean R. Eddy, Anders Krogh, and Graeme Mitchison. Biological sequence analysis: probabilistic models of proteins and nucleic acids. Cambridge university press, 1998.
  4. Bishop, Christopher M. Pattern recognition and machine learning. springer, 2006.
  5. Algorithms in Bioinformatics I, WS’06, ZBIT, C. Dieterich, February 6, 2007
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.