الگوریتم اسمیت واترمن
| در متن این مقاله از هیچ منبع و مأخذی نام برده نشدهاست. شما میتوانید با افزودن منابع برطبق اصول اثباتپذیری و شیوهنامهٔ ارجاع به منابع، به ویکیپدیا کمک کنید. مطالب بیمنبع احتمالاً در آینده حذف خواهند شد.(ژوئن ۲۰۱۲) |
الگوریتم اسمیت واترمن (به انگلیسی: Smith–Waterman algorithm) برای انجام دادن یک همترازسازی توالی محلی به کار گرفته میشود و برای مشخص کردن مناطق مشابه بین دو توالی اسید نوکلئیک یا پروتین استفاده میشود. به جای در نظر گرفتن تمام توالی این الگوریتم سعی میکند که با در نظر گرفتن بخشهای مختلف با همهٔ طولهای ممکن میزان شباهت را بهینه کند.
محتویات |
پیشینه [ویرایش]
این الگوریتم برای اولین با توسط Temple F. Smith و Michael S. Waterman در سال ۱۹۸۱ ارائه شد. که مانندالگوریتم نیدلمن-وانچ با یک سری تفاوتها یک الگوریتم برنامهریزی پویا میباشد. این الگوریتم دارای این خصوصیت است که بر حسب سیستم امتیاز دهی (شامل ماتریس جایگزنی و جریمه پرش) که استفاده میشود تضمین میکند که به جواب بهینه برسد. تفاوتی که با الگوریتم نیدلمن-وانچ دارد این است که در ماتریس جایگذاری آن مقادیر منفی با صفر جابگزین میشوند. عمل برگشت به عقب در این الگوریتم از خانه ایی که مقدار بیشنه را دارد شروع شده و به خانه ایی که مقدار صفر دارد ختم میشود. که این مسیر بیشترن امتیاز همترازسازی محلی را دارد.
شرح الگوریتم [ویرایش]
مانند همه برنامه ریزیهای پویا یک ماتریس را باید پر کنیم. ماترییس
به اینصورت ساخته میشود.




که:
= رشتههایی روی الفبا 


- مقدار بیشینه امتیاز شباهت یک پسوند [a[1...i و یک پسوند [b[1...j
, که '-' نمایش جریمه پرش است
مثال [ویرایش]
- رشته 1 = ACACACTA
- رشته 2 = AGCACACA
- w(پرش) = -۱
- w(تطابق) = +۲


برای به دست آوردن بهترین همترازی محلی، از خانه ایی از ماتریس با بیشترین ارزش شروع میکنیم (خانه (i,j)) و به عقب بر میگردیم و به یکی از خانههای (i-1,j), (i,j-1) و (i-1,j-1) میرویم با توجه به مسیری که ماتریس ساخته شدهاست. این رویه را آنقدر تکرار میکنیم که یا به خانه ایی با مقدار صفر برسیم و یا در خانه (۰٬۰) باشیم. برای مثال خانه با بیشترین مقدار در جایگاه (۸،۸) است و با توجه به ماتریس مسیر (۸٬۸), (۷٬۷), (۷٬۶), (۶٬۵), (۵٬۴), (۴٬۳), (۳٬۲), (۲٬۱), (۱٬۱) و (۰٬۰) را به عقب بر میگردیم.
وقتی عمل برگشت تمام شد به این ترتیب همتراز سازی را نتیجه میگیریم:
- حرکت روی قطر نشاندهنده یک همتراز سازی است (تطابق یا عدم تطابق)
- یک حرکت بالا به پایین نشانده یک حذف است
- یک حرکت چپ به راست نشان دهنده یک درج است.
برای مثال خواهیم داشت:
رشته 1 = A-CACACTA رشته 2 = AGCACAC-A
منابع [ویرایش]
http://en.wikipedia.org/wiki/Smith%E2%80%93Waterman_algorithm
= رشتههایی روی الفبا 


- مقدار بیشینه امتیاز شباهت یک پسوند [a[1...i و یک پسوند [b[1...j
, که '-' نمایش 