روش دوبخشی
روش دوبخشی (به انگلیسی: Bisection method) یا تصنیف، یکی از روشهای مهم مطرح شده در محاسبات عددی برای یافتن ریشه یک تابع پیوسته است که میدانیم در دو نقطه مقدار آن دارای علامت مختلف است. تکرار این روش بر روی تابعهایی با ویژگی ذکر شده در صورتی که در حدود بازه، هم علامت نباشند ما را به ریشه میرساند.[۱]
بهطور دقیقتر ابتدا مقدار تابع در میانه بازه داده شده محاسبه میشود، سپس از بین دو بازه ایجاد شده، بازه ای انتخاب میشود که مقدار تابع در ابتدا و انتهای بازهٔ جدید هم علامت نباشند.
در این صورت به علت پیوستگی تابع اطمینان داریم ریشه در این بازه خواهد بود. حال برای این بازهٔ منتخب دوباره الگوریتم را تکرار میکنیم و به ریشه نزدیکتر میشویم.
ویژگی
[ویرایش]این روش در محاسبات عددی از سادهترین روشهای پیدا کردن ریشه تابع است. محاسبات ساده ای دارد و نیاز به محاسبات دشوار مشتق و انتگرال ندارد. از طرفی در کنار سادگی، این روش کند است و نسبت به بقیه روشهای پیشنهادی برای پیدا کردن ریشه یک تابع، دیرتر به جواب میرسد.
روش دوبخشی که بعضاً روش تصنیف نیز خوانده میشود، شباهتهایی به الگوریتم جستجوی دودویی در علوم کامپیوتر دارد.
جزئیات الگوریتم
[ویرایش]دادههای مسئله عبارتند از (f(x به عنوان تابع ورودی و بازه [a,b] که در آن به دنبال ریشه تابع هستیم.
شروط استفاده
[ویرایش]دو محدودیت اصلی برای بهکارگیری از این روش وجود دارد:
- در بازه [a,b] داده شده، ریشه وجود داشته باشد.
- ریشه ذکر شده در بازه فوق یکتا باشد.
اگر بخواهیم محدودیتهای گفته شده را به زبان ریاضی بیان کنیم، اینگونه خواهد بود:
- مقدار تابع در x=a و x=b هم علامت نباشند، به عبارتی f(a).f(b) < 0.
- با توجه به قضیه مقدار میانی و شروط ۱ و ۲ حتماً X در بازه [a,b] وجود دارد که f(X) = ۰ باشد.
- در هیچیک از نقاط بازه [a,b] مشتق تابع (f(x برابر صفر نباشد.[۲]
مراحل الگوریتم
[ویرایش]- محاسبه مقدار c - نقطه وسط بازه [a,b] - یا به عبارتی a+b) = c)½.
- محاسبه مقدار تابع در f(c) ,c.
- اگر c به قدر کافی به ریشه نزدیک بود (مقدار |(f(c)| به اندازه کافی به صفر نزدیک بود)، محاسبات را متوقف میکنیم.
- در غیر این صورت اگر (f(c هم علامت (f(a بود c را جایگزین a میکنیم، در غیر این صورت (یعنی اگر(f(c هم علامت (f(b بود) c را جایگزین b میکنیم. در این حالت مطمئنیم ریشه در بازه جدید وجود خواهد داشت و دوباره به مرحله ۱ برمیگردیم.
پیادهسازی کامپیوتری الگوریتم
[ویرایش]پیادهسازی الگوریتم دوبخشی به صورت شبه کد قابل مشاهده است:[۳]
INPUT: Function f,
endpoint values a, b,
tolerance TOL,
maximum iterations NMAX
CONDITIONS: a < b,
either f(a) < 0 and f(b) > 0 or f(a) > 0 and f(b) < 0
OUTPUT: value which differs from a root of f(x) = 0 by less than TOL
N ← 1
While N ≤ NMAX # limit iterations to prevent infinite loop
c ← (a + b)/2 # new midpoint
If f(c) = 0 or (b – a)/2 < TOL then # solution found
Output(c)
Stop
EndIf
N ← N + 1 # increment step counter
If sign(f(c)) = sign(f(a)) then a ← c else b ← c # new interval
EndWhile
Output("Method failed.") # max number of steps exceeded
بررسی یک مثال: پیدا کردن ریشه یک چند جمله ای
[ویرایش]میخواهیم ریشه چندجمله ای روبرو را با استفاده از روش دوبخشی تقریب بزنیم:
ابتدا باید a و b را به عنوان بازه جوری معین کنیم تا (f(a و (f(b هم علامت نباشند. برای مثال بالا اعداد ۱ و ۲ مناسب خواهند بود چرا که:
در نظر داریم به علت پیوستگی تابع چند جمله ای شرط دوم استفاده از روش برقرار خواهد بود. برای بررسی شرط سوم باید از تابع مشتق بگیریم و اطمینان داشته باشیم در بازه مورد نظر مشتق تابع در هیچ نقطه ای صفر نیست.
نقاطی که در این تابع مشتق صفر دارند تقریبا برابر برابر 0.7 و 0.7- است که در بازه مورد نظر با نیستند. پس با اطمینان میتوانیم از روش دوبخشی در این مثال برای یافتن ریشه استفاده کنیم.
مرحله اول تقریب را با یافتن c انجام میدهیم: , , .
حال زمان محاسبه مقدار تابع در نقطه c است:
به دلیل منفی بودن مقدار تابع، c را جایگزین a میکنیم تا مقادیر تابع در حدود بازه جدید نیز هم علامت نباشند.
در نتیجه b همان مقدار قبلی را خواهد داشت ولی a مقدار جدید ۱٫۵ را خواهد گرفت.
با تکرار این روش خواهیم دید فاصله بازه a و b تدریج کم و کمتر میشود و به ریشه واقعی تابع نزدیک تر میشویم. این اتفاق در جدول زیر قابل مشاهده است.
شماره مرحله | ||||
---|---|---|---|---|
۱ | ۱ | ۲ | ۱٫۵ | ۰٫۱۲۵− |
۲ | ۱٫۵ | ۲ | ۱٫۷۵ | ۱٫۶۰۹۳۷۵۰ |
۳ | ۱٫۵ | ۱٫۷۵ | ۱٫۶۲۵ | ۰٫۶۶۶۰۱۵۶ |
۴ | ۱٫۵ | ۱٫۶۲۵ | ۱٫۵۶۲۵ | ۰٫۲۵۲۱۹۷۳ |
۵ | ۱٫۵ | ۱٫۵۶۲۵ | ۱٫۵۳۱۲۵۰۰ | ۰٫۰۵۹۱۱۲۵ |
۶ | ۱٫۵ | ۱٫۵۳۱۲۵۰۰ | ۱٫۵۱۵۶۲۵۰ | ۰٫۰۳۴۰۵۳۸− |
۷ | ۱٫۵۱۵۶۲۵۰ | ۱٫۵۳۱۲۵۰۰ | ۱٫۵۲۳۴۳۷۵ | ۰٫۰۱۲۲۵۰۴ |
۸ | ۱٫۵۱۵۶۲۵۰ | ۱٫۵۲۳۴۳۷۵ | ۱٫۵۱۹۵۳۱۳ | ۰٫۰۱۰۹۷۱۲− |
۹ | ۱٫۵۱۹۵۳۱۳ | ۱٫۵۲۳۴۳۷۵ | ۱٫۵۲۱۴۸۴۴ | ۰٫۰۰۰۶۲۲۲ |
۱۰ | ۱٫۵۱۹۵۳۱۳ | ۱٫۵۲۱۴۸۴۴ | ۱٫۵۲۰۵۰۷۸ | ۰٫۰۰۵۱۷۸۹− |
۱۱ | ۱٫۵۲۰۵۰۷۸ | ۱٫۵۲۱۴۸۴۴ | ۱٫۵۲۰۹۹۶۱ | ۰٫۰۰۲۲۷۹۴− |
۱۲ | ۱٫۵۲۰۹۹۶۱ | ۱٫۵۲۱۴۸۴۴ | ۱٫۵۲۱۲۴۰۲ | ۰٫۰۰۰۸۲۸۹− |
۱۳ | ۱٫۵۲۱۲۴۰۲ | ۱٫۵۲۱۴۸۴۴ | ۱٫۵۲۱۳۶۲۳ | ۰٫۰۰۰۱۰۳۴− |
۱۴ | ۱٫۵۲۱۳۶۲۳ | ۱٫۵۲۱۴۸۴۴ | ۱٫۵۲۱۴۲۳۳ | ۰٫۰۰۰۲۵۹۴ |
۱۵ | ۱٫۵۲۱۳۶۲۳ | ۱٫۵۲۱۴۲۳۳ | ۱٫۵۲۱۳۹۲۸ | ۰٫۰۰۰۰۷۸۰ |
مراحل تقریب میتواند تا زمان لازم ادامه پیدا کنند، در این مثال تا مرحله پانزدهم ادامه یافتهاست.
بررسی خطا
[ویرایش]با انجام هر مرحله از این تقریب، بازه اعداد، که مطمئن هستیم ریشه در این بازه قرار دارد، نصف میشود. به همین دلیل درجه همگرایی این روش خطی است.
در واقع اگر c را ریشه اصلی در نظر بگیریم و cn را تقریب بدست آمده از روش برای ریشه در مرحله n ام بدانیم، خواهیم داشت:
درجه همگرایی خطی باعث میشود که روش دوبخشی الگوریتم نسبتاً کندی در پیدا کردن ریشه باشد.[۴]
مزایا و معایب
[ویرایش]یکی از مهمترین مزایای این روش، همگرایی همیشگی است. در هر مرحله از پیمایش و اجرای الگوریتم حتما خطا کمتر خواهد شد و مسائلی مانند واگرایی یا گیرافتادن الگوریتم در حلقه برای این روش وجود ندارد.
از معایب روش دوبخشی میتوان به کند بودن روش و همچنین عدم توانایی الگوریتم در پیدا کردن بیش از یک ریشه در یک بازه معین اشاره کرد. در صورت وجود چنین مسئله ای باید از روش های دیگر پیدا کردن ریشه توابع استفاده کرد.
تاریخچه
[ویرایش]با وجود اینکه اطلاعات چندانی درباره تاریخچه دقیق پیدایش این روش در دست نیست، اما میتوان گفت که اندکی بعد از بیان قضیه مقدار میانی مطرح شده است. قضیه مقدار میانی برای اولین بار توسط بولزانو در سال 1817 طرح گردید. میتوان حدس زد یکی از ابزار های لازم برای اثبات کامل قضیه مقدار میانی، کارکرد روش دوبخشی بوده است.[۵]
جستارهای وابسته
[ویرایش]منابع
[ویرایش]- ↑ «Bisection Method». دریافتشده در ۱۷ مه ۲۰۱۹.
- ↑ کتاب محاسبات عددی تألیف نیکوکار و درویشی بخش 2.3.1
- ↑ (Burden و Faires 1985، ص. 29). This version recomputes the function values at each iteration rather than carrying them to the next iterations.
- ↑ Burden & Faires 1985, p. 31, Theorem 2.1
- ↑ «نسخه آرشیو شده». بایگانیشده از اصلی در ۱۱ اكتبر ۲۰۲۰. دریافتشده در ۳ ژوئن ۲۰۱۹. تاریخ وارد شده در
|archive-date=
را بررسی کنید (کمک)