الگوریتم ویتربی
الگوریتم ویتربی (به انگلیسی: Viterbi algorithm) الگوریتمی پویا برای پیدا کردن محتملترین مسیر از حالتهای پنهان، با داشتن یک توالی از مشاهدات است.
این الگوریتم اغلب در مواردی بکار میرود که با داشتن یک مدل پنهان مارکف و توالیای از مشاهدات، میخواهیم بدانیم چه توالیای از حالتها (مسیر) این مشاهدات را تولید کردهاند. به عبارت دیگر ما دنبال محتملترین مسیر بهوجودآورندهٔ مشاهدات در یک مدل پنهان مارکف هستیم.
پیدایش و کاربردها
در بسیاری از کاربردهای مدلهای پنهان مارکف، متغیرهای پنهان تفسیر معناداری دارند و در نتیجه یکی از مهمترین مسائل در این حیطه، پیدا کردن محتملترین توالی از متغیرهای پنهان با داشتن یک توالی از مشاهدات است. بهعنوان مثال، در حوزهٔ بازشناسی گفتار، میخواهیم یک توالی از واجها با استفاده از توالیای از آواها داشته باشیم.
این مسئله نباید با مسئلهٔ پیدا کردن محتملترین مجموعه از حالتهای پنهان اشتباه گرفته شود. مسئلهٔ دوم میتواند با استفاده از الگوریتم پسرو-پیشرو حل شود. بدین صورت که ابتدا توزیع حاشیهای برای هر متغیر نهان را بهدست آورده و سپس جداگانه آنها را بیشینه میکنیم.[1] اما در حالت کلی، مسئلهٔ پیدا کردن محتملترین توالی پراهمیتتر بوده و الگوریتم بهینهٔ ارائهشده برای آن، الگوریتم جمع-بیشینه که در حیطهٔ مدلهای پنهان مارکف، به آن الگوریتم ویتربی گفته میشود استفاده کرد.[2]
در مسائل طبیعی مانند در، همیشه واقعیت منطبق بر محتملترین مسیر نیست. اما بسیاری اوقات محتملترین مسیر نیز اطلاعات خوبی در اختیار میگذارد.
مدلهای پنهان مارکف برای جزایز سیپیجی
در این بخش، به بررسی یکی از کاربردهای این مسئله در بیوانفورماتیک میپردازیم. مسئله جزایر سیپیجی (CpG islands) -پیدا کردن ناحیهای از ژنوم که فرکانس بالایی از مکانهای CG در آن وجود دارد- است. این مسئله را میتوان با استفاده از دو مدل مخفی مارکف مدل کرد. کافی است حالتهای مخفی را دو حالتِ و در نظر گیریم بهطوری که زمانی که در ناحیهٔ سیجیپی قرار داریم یا زمانی که در این ناحیه قرار نداریم؛ و حالتهایمان نیز حروف A, C، G و T که در واقع نوکلئوتیدهای روی رشتهاند در نظر گیریم. پس مجموعاً ۸ حالت مخفی که در شکل زیر نمایش داده شدهاند را داریم.[3]
جستجوی کامل فضای مسئله
میتوانیم تمامی مسیرهای ممکن را که مشاهده ما را تولید میکنند را پیدا کنیم، سپس با محاسبه احتمال آنها، محتملترین مسیر را بدست آوریم. به عنوان نمونه در مسئله آب و هوا (میتوانید در مثالهایی برای مدل پنهان مارکف ببینید) مشاهدی ما به صورت خشک، نمدار، مرطوب است. برای بهدست آوردن محتملترین مسیر باید احتمال زیر بیشینه شود:
برای جستجوی تمامی فضای جواب باید این احتمال را برای تمامی مسیرها بدست بیاوریم:
پیچیدگی زمانی این راهحل از اندازهٔ نمایی () بوده و بهینه نیست. برای سرعت بخشیدن به الگوریتم میتوان از تکنیک شاخه و حد استفاده کرد اما یک راه حل در زمان چندجملهای برای این مسئله وجود دارد که الگوریتم ویتربی است.
الگوریتم ویتربی
همانطور که در بخش قبل توضیح دادهشد، تعداد حالتهای ممکن برای متغیرهای پنهان یا معادلاً تعداد مسیرها نسبت به طول توالی از اندازهٔ نمایی است. شکل زیر، حالتهای متغیرهای نهان یک مدل پنهان مارکف را بهصورت یک شبکه نشان دادهاست که در آن، حالتهای مختلف برای هر متغیر نهان با رنگهای متفاوت مشخص شدهاند و متغیرهای نهان بهصورت افقی از چپ به راست نمایش داده شدهاند. با استفاده از الگوریتم ویتربی، میخواهیم محتملترین مسیر را در این شبکه بیابیم بهطوری که هزینهٔ محاسباتی بهصورت خطی با طول توالی افزایش یابد.
تعریف مسئله
با توجه به توضیحات دادهشده، میدانیم میتوان مسئله را بهصورت زیر بازنویسی کرد:
میخواهیم مسیر بهینهای مانند پیدا کنیم بهگونهای که داشته باشیم: . که در آن یک توالی از مشاهدات و یک توالی از متغیرهای پنهان باشد.
میدانیم برای محاسبهٔ احتمال بالا داریم: . که در آن مقادیر احتمالهای انتقال و احتمال انتشار را نشان میدهد. برای اطلاعات بیشتر به صفحهٔ مدل پنهان مارکف مراجعه کنید.
ایدهٔ الگوریتم[5]
اگر گرههای گراف روبرو را با استفاده از دوتاییهایی که بهترتیب از شمارهٔ متغیر نهان و شمارهٔ حالتهای ممکن برای آنها تشکیلشده باشند، نمایش دهیم، میتوان وزن بین دو گرهٔ و را برابر با مقدار تعریف کرد. حال میتوان احتمال برای یک مسیر مانند بهطوری که با یال به گرهٔ ختم شود را بهصورت زیر محاسبه کرد:
حال کافی است متغیر را بهطوری تعریف کنیم که احتمال بهترین مسیر تا مکان باشد، بهطوری که توالی مشاهدات به ختم شدهباشد و متغیر نهان برابر با باشد؛ بنابراین طبق نتایج بالا داریم:
شبهکد الگوریتم[5]
ورودی:
مدل که:
- : الفبای مشاهدات
- Q: مجموعه حالات
- P: ماتریس احتمال انتقال بین حالات
- e: ماتریس احتمال تولید الفبا در هر حالت
و توالی
خروجی: محتملترین مسیر بهگونهای که
محاسبات آغازین: (i=۰) قرار بده و برای تمام kهای بزرگتر از صفر قرار بده
- برای i از ۱ تا L و تمامی lها عضو Q
- قرار بده
- قرار بده
خاتمه:
و محتملترین مسیر
بازگشت:
- برای i از L تا ۱:
- قرار بده
منابع
- Pattern Classification, Duda et al. , 2001.
- Forney, G.D. (1973). "The viterbi algorithm". Proceedings of the IEEE. 61 (3): 268–278. doi:10.1109/proc.1973.9030. ISSN 0018-9219.
- Durbin, Richard, Sean R. Eddy, Anders Krogh, and Graeme Mitchison. Biological sequence analysis: probabilistic models of proteins and nucleic acids. Cambridge university press, 1998.
- Bishop, Christopher M. Pattern recognition and machine learning. springer, 2006.
- Algorithms in Bioinformatics I, WS’06, ZBIT, C. Dieterich, February 6, 2007