کدهای متلب محاسبات عددی | دانلود رایگان مجموعه کامل
در این مطلب روشها و کدهای متلب محاسبات عددی را معرفی میکنیم. محاسبات عددی روشها و ویژگیهای متفاوتی دارند. در این مبحث ضمن معرفی این روشها، کدها و حل دستی برخی از آنها را معرفی میکنیم. اگر شما نیز برای حل مسائل ریاضی، مهندسی یا فیزیکی خود به حل عددی نیازمند هستید خواندن این مطلب را از دست ندهید.
محاسبات عددی در متلب
محاسبات عددی روشی برای حل مسائل پیچیده ریاضی است که فقط با استفاده از عملگرهای ساده ریاضی انجام میشود. این روش شامل فرمولبندی فیزیکی مدلهای ریاضی و موقعیتهایی است که میتوان با عملگرهای ریاضی حل کرد. برای محاسبات عددی نیاز به توسعه، تجزیه و تحلیل و استفاده از الگوریتمها است.
این محاسبات شامل تعداد زیادی محاسبات ریاضی هستند و بنابراین به دستگاههای محاسباتی سریع و کارآمد احتیاج دارند. انقلاب میکروالکترونیک و متعاقب آن توسعه رایانههای شخصی ارزان و کم هزینه تأثیر به سزایی در استفاده از روشهای عددی برای حل مشکلات علمی داشته است. روشهای معادلات عددی برای حل حالتهای زیر اتفاق میافتد:
- معادلات غیر خطی تک متغیره که حل تحلیلی و بسته ندارند و برای آنها باید از حل عددی استفاده کرد.
- روش درونیابی و برازش برای پیدا کردن معادلاتی که دادههایی از آن را داریم.
- حل عددی مشتقها و انتگرالهایی که حل تحلیلی و دقیقی ندارند.
- حل عددی معادلات دیفرانسیل معمولی یا ODE
- حل عددی دستگاه معادلات خطی یا غیرخطی. البته حل تحلیلی دستگاه معادلات خطی غالباً امکانپذیر است اما در حالتی که تعداد متغیرها و معادلات زیاد باشند حل تحلیلی این معادلات زمان زیادی میگیرد و در این حالت بهتر است به حل عددی روی بیاوریم.
- حل عددی برای به دست آوردن ویژه مقادیر ماتریسها.
- الگوریتم حداقل مربعات که مجموعهای از دادهها را با یک تابع نمایی، هایپربولیک یا ... فیت میکند و به این ترتیب اطلاعات بیشتری از یک سیستم به دست میآوریم.
- بهینه سازی عددی نیز برای بهینه کردن یک پارامتر در یک سیستم به کار میرود.
نکتهای که در محاسبات عددی مهم است میزان خطا در این محاسبات است که باید آن را نیز مد نظر قرار داد. در این مطلب چند روش محاسبه عددی در متلب را معرفی میکنیم و چند مثال از این روشها را حل میکنیم.
حل عددی دستگاه معادلات خطی
در روش حل عددی دستگاه معادلات خطی میتوان به روشهای تکراری و غیرتکراری در نرم افزار متلب اشاره کرد که به گروههای زیر تقسیمبندی میشوند:
روشهای غیرتکراری
- کدهای متلب محاسبات عددی و روش گاوس ناقص
- کدهای متلب محاسبات عددی و روش گاوس یا پیووتینگ
- کدهای متلب محاسبات عددی و روش تجزیه LU
روشهای تکراری
- کدهای متلب محاسبات عددی و روش ژاکوبی
- کدهای متلب محاسبات عددی و روش گاوس-سیدال
در دستگاه معادلات خطی برای حل یک دستگاه باید تعداد ضرایب معلوم و مجهول با هم برابر باشند. برای حل این دستگاهها ابتدا آنها را به فرمت ماتریسی در میآوریم. در حقیقت دستگاه معادلات زیر را در نظر بگیرید:
فرم ماتریسی این دستگاه را میتوان به شکل خلاصه شده زیر نوشت:
که A، x و b به ترتیب ماتریسهای ، و هستند و به صورت زیر نمایش داده میشوند:
برای حل این دستگاه معادلات خطی همان طور که گفتیم میتوان از روشهای مستقیم و غیرمستقیم استفاده کرد. در روشهای مستقیم پاسخ اعداد ثابتی هستند که این اعداد شامل خطاهای حاصل از گردکردن میباشند و در روشهای غیرمستقیم اصل بر حدسهای پی در پی برای پاسخ به مسئله طرح ریزی شده است. در بین روشهای مستقیم یا غیرتکراری حل عددی دستگاه معادلات خطی میتوان به روشهای زیر اشاره کرد:
- کدهای متلب محاسبات عددی و روش معکوس ماتریس ضرایب
- کدهای متلب محاسبات عددی و روش کرامر
- کدهای متلب محاسبات عددی و روشهای حذفی که شامل روش ساده (ناقص) گاوس و روش گاوس است.
- کدهای متلب محاسبات عددی و روش تجزیه
نکته مهم در استفاده از این روشها که در بالا بیان شد غیرصفر بودن دترمینان ماتریس ضرایب یا ماتریس A که در بالا معرفی کردیم است. در اینجا به بررسی روش حذف ساده (ناقص) گاوس میپردازیم.
روش ساده (ناقص) گاوس
یکی از محدودیتهای این روش این است که تنها در صورت غیر صفر بودن قطر اصلی ماتریس ضرایب این روش کاربرد دارد. در این روش باید یک ماتریس افزوده تشکیل دهیم که مجموع ماتریس ضرایب و ماتریس معلومات مسئله است. در ماتریس افزوده یک ستون به ماتریس ضرایب اضافه میشود که همان ماتریس معلومات مسئله است. برای درک این روش یک مثال را با این روش حل میکنیم و سپس آن را در متلب نیز اجرا خواهیم کرد.
فرض کنید چهار مجهول داریم که فرم ماتریسی آن به صورت زیر است:
میخواهیم این دستگاه چهار معادله و چهار مجهول را با روش ساده گاوس حل کنیم. روش کار به این صورت است که اگر مخالف صفر باشد آن گاه این روش کاربرد دارد و ضرایب جدیدی تحت عنوان m برای اُمین سطر از ماتریس افزوده به صورت زیر تعریف میکنیم:
حال به ترتیب سطر اول عنصر را که برابر با 1 است در نظر میگیریم و را محاسبه میکنیم که برابر است با:
بدین ترتیب عناصر سطر دوم به صورت زیر تغییر میکنند:
همچنین برای سطر سوم برابر است با:
و عناصر سطر سوم به شکل زیر درمیآیند:
و در نهایت در این مرحله برای سطر آخر برابر است با:
و عناصر این سطر نیز به صورت زیر در میآیند:
بعد از انجام این مراحل ماتریس به شکل زیر در میآید و داریم:
حالا همین مراحل را برای عنصر در نظر میگیریم و به سمت سطرهای پایین یعنی سطرهای 3 و 4 حرکت میکنیم. در این حالت برابر است با:
بدین ترتیب عناصر سطر سوم به صورت زیر تغییر میکنند:
همچنین عنصر برابر است با:
و عناصر سطر چهارم به صورت زیر میشوند:
و بدین ترتیب ماتریس افزوده به صورت زیر در میآید:
در مرحله بعد را در نظر میگیریم و را محاسبه میکنیم که برابر است با:
حال عناصر سطر چهارم به شکل زیر تغییر میکنند و داریم:
و ماتریس در نهایت به شکل زیر در میآید:
اگر این معادلات را به شکل جبری بنویسیم داریم:
که به راحتی مقادیر ، ، و قابل محاسبه است. همین روش را در متلب میتوان به صورت زیر نوشت اگر ماتریس ضرایب و مقادیر را مانند مثال بالا به عنوان ورودی بدهیم هر دو حالت جوابهای یکسانی را نشان میدهند.
برای اجرای دستور گاوس در متلب کد بالا را در یک اسکریپت با نام تابع یعنی ngaussel ذخیره کنید و در صفحه کار متلب ماتریسهای A و b را تعریف کنید. با فراخوانی تابع این روش برای ماتریس ورودی شما اجرا شده و جواب نمایش داده میشود.
درونیابی و برازش
درونیابی و برازش برای پیدا کردن صورت کلی توابعی است که دادههایی از آن را داریم. این دادهها میتوانند از آزمایش یا مشاهده به دست آمده باشند. در حقیقت n زوج داده داریم که به صورت هستند و میخواهیم را تخمین بزنیم.
این روش در حل عددی بسیار متداول و رایج است و باید دقت کرد که این درونیابی با عبور از منحنی یا Curve fitting متفاوت است. در حقیقت در روش عبور از منحنی، منحنی که از بیشترین دادهها عبور میکند در نظر گرفته میشود اما در درون یابی باید تابع به دست آمده شامل تمام نقاط و دادهها باشد. انواع روشهای درون یابی و برازش را میتوان به صورت زیر دستهبندی کرد:
- کدهای متلب محاسبات عددی و روش لاگرانژ
- کدهای متلب محاسبات عددی و روش تفاضلهای تقسیم شونده پیشرونده نیوتن
- کدهای متلب محاسبات عددی و اسپلاینهای مرتبه دو و سه
- کدهای متلب محاسبات عددی و برازش یا عبور از منحنی
در ادامه این مطلب با حل یک مثال روش لاگرانژ را توضیح میدهیم.
درون یابی به روش لاگرانژ
با حل یک مثال روش لاگرانژ را توضیح میدهیم. در این مثال میخواهیم برای نقاط f(x)=\sum_{i=0}^{n} L_{k}(x) y_{k}L_{k}(x)L_{k}(x)=\frac{\left(x-x_{0}\right) \cdots\left(x-x_{k-1}\right)\left(x-x_{k+1}\right) \cdots\left(x-x_{n}\right)}{\left(x_{k}-x_{0}\right) \cdots\left(x_{k}-x_{k-1}\right)\left(x_{k}-x_{k+1}\right) \cdots\left(x_{k}-x_{n}\right)}=\prod_{j=0 \atop j=2}^{n} \frac{x-x_{i}}{x_{k}-x_{i}}, k=0,1, \cdots, nL_{k}(x)L_{0}(x)=\frac{(x-1)(x-2)}{(0-1)(0-2)}=\frac{x^{2}-3 x+2}{+2}$$
$$L_{1}(x)=\frac{(x-0)(x-2)}{(1-0)(1-2)}=\frac{x^{2}-2 x}{-1}$$
$$L_{2}(x)=\frac{(x-0)(x-1)}{(2-0)(2-1)}=\frac{x^{2}-x}{2}\left\{\begin{array}{l}
f(x)=\sum_{k=0}^{2} L_{k}(x) y_{k}=L_{2}(x) y_{0}+L_{1}(x) y_{1}+L_{2}(x) y_{2} \\
f(x)=\sum_{k=0}^{2} L_{k}(x) y_{k}=6 \times\left(\frac{x^{2}-3 x+2}{2}\right)+0 \times\left(\frac{x^{2}-2 x}{-1}\right)+2 \times\left(\frac{x^{2}-x}{2}\right) \\
f(x)=4 x^{2}-10 x+6
\end{array}\right.f(x+h)h=0\begin{array}{l}
f(x+h)=f(x)+h f^{\prime}(x)+\frac{1}{2 !} h^{2} f^{\prime \prime}(x)+\frac{1}{3 !} h^{3} f^{\prime \prime}(x)+\cdots \\
\Rightarrow \frac{f(x+h)-f(x)}{h}=f^{\prime}(x)+\left[\frac{1}{2 !} h f^{\prime \prime}(x)\right]+\frac{1}{3 !} h^{2} f^{\prime \prime}(x)+\cdots
\end{array}f(x-h)h=0\begin{array}{l}
f(x-h)=f(x)-h f^{\prime}(x)+\frac{1}{2 !} h^{2} f^{\prime \prime}(x)-\frac{1}{3 !} h^{3} f^{\prime \prime}(x)+\cdots \\
\Rightarrow \frac{f(x)-f(x-h)}{h}=f^{\prime}(x)-\left[\frac{1}{2 !} h f^{\prime \prime}(x)\right]+\frac{1}{3 !} h^{2} f^{\prime \prime}(x)-\cdots
\end{array}\frac{f(x+h)-f(x-h)}{2 h}=f^{\prime}(x)+\frac{1}{3 !} h^{2} f^{\prime \prime}(x)-\cdots$$\end{array}$$
بدین ترتیب میتوان فرمولهای تقریبی برای مشتق گیری مرتبه اول را به فرمهای زیر تعریف کرد:
- تقریب اختلاف پیشرونده که به صورت زیر تعریف میشود:
- همچنین تقریب اختلاف پسرو به شکل زیر است:
- و تقریب اختلاف مرکزی نیز شکل زیر را میگیرد:
با محاسبات میتوان دید که با توجه به این که همواره مقداری کوچکتر از یک دارد، خطای محاسباتی در روش مشتق گیری مرکزی از دو روش پیشرو و پسرو کمتر خواهد بود. همچنین مشتق دوم تابع با توجه به روش مشتق گیری مرکزی حول نقطه به شکل زیر خواهد بود:
این روش را با یک مثال توضیح داده و آن را در متلب اجرا میکنیم. برای تابع مقدار تخمینی مشتق دوم آن را به ازای مقدار و محاسبه کنید و خطای محاسبات را به دست آورید.
با استفاده از رابطه مشتق دوم از روش بسط تیلور مقدار تخمینی مشتق برابر با خواهد شد. این در حالی است که مقدار واقعی از روابط تحلیلی مقداری برابر با دارد. به این ترتیب مقدار خطا برابر با خواهد بود.
این مثال را در متلب به صورت زیر مینویسیم:
با اجرای این برنامه نمودارها به صورت زیر نمایش داده میشوند:
همچنین میزان ارور یا خطا نیز برابر با در خروجی چاپ میشود.
حل عددی معادلات دیفرانسیل معمولی
در این بخش حل عددی معادلات دیفرانسیل معمولی را بررسی و معرفی میکنیم. به صورت کلی روشهای حل عددی معادلات دیفرانسیل معمولی به صورت زیر معرفی میشوند:
- کدهای متلب محاسبات عددی و روش اویلر (بسط تیلور مرتبه اول)
- کدهای متلب محاسبات عددی و بسطهای تیلور مرتبههای بالاتر از 1
- کدهای متلب محاسبات عددی و روش نقطه میانی
- کدهای متلب محاسبات عددی و روش رانگ-کوتای مرتبه 2 و 4
- کدهای متلب محاسبات عددی و روش آدامز-باشفورث
- کدهای متلب محاسبات عددی و روش آدامز-مولتون
در ادامه روش اویلر را معرفی کرده و با استفاده از یک مثال و بررسی آن به صورت دستی و در متلب این روش را توضیح میدهیم.
روش اویلر
سادهترین شیوه تحلیلی از میان همه روشهای محاسباتی در حل معادلات دیفرانسیل معمولی روش اویلر است. معادلهای مانند زیر را در نظر بگیرید که مقدار اولیه آن برابر با است و در بازه تقریبی تعریف میشود و داریم:
برای شروع از روش اویلر ابتدا بازه را به زیر بازه مساوی تقسیم کرده و نقاط شبکهای به صورت به ازای تعریف میکنیم که یا گام حرکت برابر با است. به این ترتیب بسط تیلور تابع را حول مینویسیم و داریم:
که مقداری بین و دارد. با صرف نظر از جملات دوم به بعد داریم:
و با نمایش به صورت معادله به صورت زیر در میآید:
معادله فوق به نام روش اویلر مشهور است. برای درک بیشتر موضوع مثال زیر را حل میکنیم و داریم:
میدانیم که جواب این معادله دیفرانسیل برابر با است. بر اساس معادله اویلر داریم:
با نوشتن این تابع در متلب و برای گامهایی به طول و 10 گام و شرط اولیه داریم:
با اجرای این مثال نموداری به شکل زیر در خروجی ظاهر میشود:
با تغییر طول گام و تعداد گامها شکل نمودار به حالت منحنی یا curve نزدیکتر میشود و در این حالت خروجی به شکل زیر نمایش داده میشود:
حال اگر حل عددی اویلر را با مشتق مستقیم تابع در همان بازه رسم کنیم و با یکدیگر مقایسه کنیم نتایج به صورت زیر نمایش داده میشوند:
حل عددی معادلات دیفرانسیل غیرخطی
معادلات ديفرانسيل آهنگ تغييرات يک کميت را نمايش میدهند. در مطلب حل دستگاه معادلات ديفرانسيل غير خطي در متلب | گام به گام در مورد حل تحليلی اين معادلات در متلب صحبت کرديم در اين بخش از اين مبحث حل عددی معادلات ديفرانسيل غيرخطی در متلب را بررسی و معرفی ميکنيم.
به صورت کلی معادلات ديفرانسيل ترکيبی از توابع و مشتقات آنها هستند و بسياری از مسائل فيزيکی و مهندسی را مدلسازی میکنند. اين معادلات شامل شرايط اوليه يا شرايط مرزی هستند که با توجه با اين شرايط اين مسائل و معادلات مورد بررسی قرار میگيرند. انواع روشهای عددی معادلات ديفرانسيل غير خطی به سه دسته کلی تقسيم میشوند:
- روشهای ريشه يابی عددی دامنه محدود يا بسته
- روشهای ريشه يابی عددی دامنه نامحدود يا باز
- حل عددی دستگاه معادلات غيرخطی به روش نيوتن
روشهای ريشه يابی عددی دامنه محدود يا بسته را به دو روش نصف کردن يا Bisection و روش نابجايی يا موقعيت خطا میتوان انجام داد. همچنين روشهای ريشه يابی عددی دامنه نامحدود يا باز نيز به سه روش سکانت، نيوتون-رافسون و نقطه ثابت صورت میگيرد. در ادامه اين بخش روش نصف کردن يا Bisection را معرفی میکنيم و آن را با حل يک مثال و بررسی آن در متلب توضیح خواهیم داد.
روش نصف کردن يا Bisection
روش نصف کردن براي هر تابع پيوستهای مورد استفاده قرار میگيرد. برای استفاده از اين روش بايد تابع را در بازهای در نظر بگيريم که ضرب مقادير تابع در آن بازه کوچکتر از صفر و مشتق تابع مخالف صفر باشد. بدين ترتيب بازه تابع را نصف کرده و مقدار تابع را در آن نقطه به دست میآوريم و با توجه به شرايط آن را جايگزين مقدار اوليه يا نهايی بازه میکنيم يعنی داريم:
اين کار را تا جايي ادامه میدهيم تا مقدار به صفر نزديک شود. اين روش را برای پيدا کردن ريشه تابع در بازه استفاده میکنيم. بدين ترتيب داريم:
با تعريف تابع و بازه آن و دقت نزديک بودن جواب به صفر و اجرای این کد ريشه اين تابع در خروجی نمايش داده میشود.
جمع بندی
این مطلب به محاسبات عددی در متلب اختصاص داده شده است. در حقیقت روشها و کدهای متلب محاسبات عددی بسیار گسترده هستند و روشهای متفاوتی برای آنها وجود دارد. در این مطلب این روشها را به صورت فهرست وار معرفی کردیم و از هر کاربرد آن یک نمونه را با مثال و بررسی مثال در متلب توضیح دادیم.