روش نقطه میانی در حل معادله دیفرانسیل – به زبان ساده
در آموزشهای پیشین مجله فرادرس، با روشهای عددی حل معادلات دیفرانسیل، مانند روش اویلر آشنا شدیم. در این آموزش، یکی دیگر از این روشها، به نام روش نقطه میانی (Midpoint Method) را معرفی میکنیم.
روش نقطه میانی
روش نقطه میانی، روشی برای حل عددی معادله دیفرانسیل زیر است:
روش نقطه میانی صریح با فرمول زیر بیان میشود:
فرمول روش نقطه میانی ضمنی نیز به صورت زیر است:
که در آنها است. در روابط بالا، اندازه گام (یک عدد کوچک مثبت)، و مقدار تقریب محاسبه شده است.
روش نقطه میانی صریح به عنوان «روش اویلر اصلاح شده» (Modified Euler Method) نیز شناخته میشود. روش نقطه میانی ضمنی سادهترین «روش جابهجایی» (Collocation Method) است و به «دینامیک همیلتونی» (Hamiltonian Dynamics) اعمال میشود که یک «انتگرالگیر سیمپلتیک» (Symplectic Integrator) است.
نام روش نقطه میانی، از این موضوع ناشی میشود که در فرمول بالا، تابع شیب جواب را در نتیجه میدهد. این نقطه، نقطه میانی بین و است که در مقدار را میدانیم و در میخواهیم مقدار را به دست آوریم.
تفسیر هندسی درک شهودی بهتری را از این روش ارائه خواهد داد. شکل ۱ را در نظر بگیرید. در روش اویلر پایه، شیب خط در با استفاده از محاسبه میشود. مقدار بعدی نیز در محل تقاطع خط مماس بر منحنی و خط عمودی به دست میآید. البته، اگر مشتق دوم بین و فقط مثبت یا فقط منفی باشد، منحنی به طور فزایندهای از خط مماس دور خواهد شد و با افزایش منجر به خطاهای بزرگتر میگردد. شکل ۱ نشان میدهد که خط مماس در نقطه میانی (سبز)، تقریب دقیقتری از منحنی در بازه ارائه میکند. البته، این شیب در نقطه میانی را نمیتوان به صورت دقیق محاسبه کرد، زیرا معادله منحنی را نمیدانیم و میخواهیم آن را محاسبه کنیم.
در واقع، شیب با استفاده از روش اویلر اصلی برای تخمین مقدار در نقطه میانی و در نتیجه، محاسبه شیب خط مماس با تقریب زده میشود. در نهایت، از خط مماس بهبودیافته برای محاسبه مقدار از استفاده میشود. این گام آخر با یک پارهخط قرمز در شکل نشان داده شده است. توجه کنید که پاره خط قرمز دقیقاً موازی خط سبز (مماس واقعی) نیست، زیرا در تخمین مقدار در نقطه میانی خطا وجود دارد.
مرتبه خطای محلی در هر گام از روش نقطه میانی است و منجر به خطای سراسری با درجه میشود. بنابراین، روش نقطه میانی با اینکه محاسبات بیشتری نسبت به روش اویلر دارد، با میل اندازه گام به صفر، خطای آن سریعتر کاهش پیدا میکند.
استخراج روش نقطه میانی
روش نقطه میانی اصلاحی از روش اویلر است و با روال مشابهی به دست میآید. کلید به دست آوردن روش اویلر تقریب زیر است:
که از فرمول شیب به دست آمده است:
توجه کنید که .
در روش نقطه میانی، به جای معادله (۳) فرمول دقیقتر زیر را قرار میدهیم:
در این صورت، به جای رابطه (۲)، خواهیم داشت:
نمیتوان از این معادله برای یافتن استفاده کرد، زیرا مقدار را در نمیدانیم. راه حل این است که از سری تیلور برای حل استفاده کنیم:
و اگر آن را در معادله (۴) قرار دهیم، خواهیم داشت:
که فرمول روش نقطه میانی صریح (1e) را نتیجه خواهد داد.
روش ضمنی (1i) با تقریب مقدار در نصف گام با نقطه میانی پارهخط بین تا به دست میآید:
و در نتیجه:
قرار دادن تقریب برای منجر به روش رانگ کوتای ضمنی خواهد شد:
که همان روش اویلر ضمنی با اندازه گام است.
پیادهسازی روش نقطه میانی در متلب
کد متلب روش نقطه میانی برای معادلات اسکالر را میتوانید از این لینک [+]، کد متلب روش نقطه میانی عمومی را از این لینک [+] و کد متلب روش نقطه میانی برای یک گام را این از این لینک [+] دانلود کنید.
پیادهسازی روش نقطه میانی در پایتون
کد پایتون روش نقطه میانی بدون استفاده از کتابخانه NumPy را از این لینک [+] و کد پایتون روش نقطه میانی را که در آن از NumPy استفاده شده است، میتوانید از این لینک [+] دانلود کنید.
اگر این مطلب برایتان مفید بوده است، آموزشهای زیر نیز به شما پیشنهاد میشوند:
- مجموعه آموزشهای محاسبات عددی
- آموزش محاسبات عددی با MATLAB
- مجموعه آموزشهای دروس ریاضیات
- آموزش ریاضی پایه دانشگاهی
- قاعده ذوزنقه ای — به زبان ساده
- روش حذفی گاوس — از صفر تا صد
- روش ژاکوبی — به زبان ساده
^^