سیستم غیر خطی – راهنمای جامع


سیستم غیر خطی گستره وسیعی از سیستمهای موجود در طبیعت را در بر میگیرد. در اکثر موارد، سیستم را میتوان توسط یک مدل خطی سادهتر تقریب زد. در این موارد اثر غیر خطی بودن (Nonlinearity) کوچک است و میتوان از آن صرف نظر کرد. اما این ایده همیشه درست نیست. بسته به نوع غیر خطی بودن، حالتهای سیستم میتوانند رفتار همگرا (Convergent)، واگرا (Divergent) یا نوسانی (Cyclic) داشته باشند. در این مطلب قصد داریم تا سیستمهای غیر خطی را معرفی کنیم و به بیان روشهای آنالیز پایداری بپردازیم. همچنین این مفاهیم را با ذکر چند مثال ساده، واضحتر خواهیم ساخت.
یک مثال ساده از یک خودروی زیرآبی (Underwater Vehicle) را در نظر بگیرید که معادله آن به صورت زیر است:
عبارت نشاندهنده اصطکاک ناشی از آب است.
در این مورد، حالت خاصی را که در آن ورودی کنترل است بررسی میکنیم. پس معادله سیستم برابر است با:
این سیستم زمانی که ، دارای مشتق منفی و زمانی که ، دارای مشتق مثبت است. بنابراین نرخ رشد حالتهای سیستم همواره کاهشی است. در نتیجه میتوان گفت که سیستم همواره پایدار است. این نوع غیر خطی بودن را اتلافی (Dissipative) یا پایدارکننده (Stabilizing) مینامند.
اما همیشه به این صورت نیست و ممکن است غیر خطی بودن منجر به ناپایداری حالتهای سیستم شود. سیستم زیر را در نظر بگیرید:
در این سیستم اگر حالتهای سیستم با یک مقدار مثبت شروع شوند، گرادیان آنها منفی میشود و حالتهای سیستم به صفر کاهش مییابند. اما اگر مقدار اولیه منفی باشد، گرادیان عددی منفی میشود و حالت سیستم به میرود. در این حالت نوع غیر خطی بودن، غیراتلافی (Non-dissipative) یا ناپایدارکننده (Destabilizing) نامیده میشود.
بنابراین بسته به نوع غیر خطی بودن، یک سیستم میتواند پایدار یا ناپایدار شود. یک سیستم غیر خطی مشخصه جالب دیگری را نیز از خود نشان میدهد. حالتهای یک سیستم غیر خطی میتوانند حرکتی نوسانی را تجربه کنند که در آن هیچگاه به یک مقدار ثابت همگرا و یا به بینهایت واگرا نشوند.
نوسانساز وندر پل
یک سیستم غیر خطی مرتبه دوم که بسیار مورد بررسی قرار میگیرد، نوسانساز وندر پل (Van der Pol Oscillator) است. فرم این سیستم به صورت زیر است:
که در آن و میتوانند به عنوان چسبندگی (Viscosity) و سختی (Stiffness) در نظر گرفته شوند. حالت خاصی را در نظر بگیرید که:
معادله بالا در فرم فضای حالت به صورت زیر نشان داده میشود:
در معادله بالا پارامتر میرایی (Damping) است. یک راه متداول برای به تصویر کشیدن رفتار یک سیستم غیر خطی، رسم یک حالت بر حسب حالتهای دیگر است و معمولا یک متغیر بر حسب مشتق آن رسم میشود. به دیاگرام ترسیمشده پرتره فاز میگویند. قطعه کد زیر، نحوه رسم حالتهای سیستم بالا در MATLAB را نشان میدهد.
شکل زیر حالتهای سیستم را نشان میدهد.

حال کد زیر پرتره فاز سیستم را رسم میکند.
پرتره فاز سیستم به صورت زیر است.

همانطور که از شکل بالا مشخص است، علیرغم شرایط اولیه سیستم، حالتها به یک چرخه نوسانی همگرا میشوند. به این چرخه نوسانی، چرخه حدی (Limit Cycle) میگویند. بنابراین علاوه بر اینکه حالتها میتوانند به یک مقدار ثابت همگرا شوند و یا به بینهایت واگرا شوند، این امکان نیز وجود دارد که حالتها رفتاری دورهای از خود نشان دهند که به آن چرخه حدی میگویند. طبقه خاصی از سیستمهای غیر خطی که چنین رفتار نوسانی را از خود نشان میدهند، سیستمهای لینارد (Lienard) نامیده میشوند.
سیستمهای لینارد
معادله دیفرانسیل زیر را در نظر بگیرید:
اگر به ازای چند و داشته باشیم:
آنگاه چرخه حدی وجود نخواهد داشت. اگر عبارت سمت چپ برابر با صفر باشد، وجود یک چرخه حدی امکان نخواهد داشت. برای نوع خاصی از سیستمهای Lienard که میتوانند به صورت زیر بیان شوند، از تئوری Lienard برای بررسی وجود چرخه حدی استفاده میشود.
تئوری لینارد برای چرخه حدی
تئوری لینارد بیان میکند که اگر دو تابع نرم و فرد و داشته باشیم، به نحوی که برای ، و همچنین تابع دقیقا دارای سه صفر در و و باشد و و برای برقرار باشند و نیز اگر ، آنگاه سیستم Lienard متناظر با آن دقیقا دارای یک چرخه حدی است و این چرخه پایدار است.
توجه کنید که عبارت بالا بیان میکند که مشتق تابع اگر بزرگتر از صفر باشد، افزایش مییابد و اگر بزرگتر از باشد، کاهش مییابد. این شروط منجر به سیستمی میشوند که در آن حالتهای سیستم از صفر دور شده و به جای همگرایی به یک مقدار ثابت، به یک مسیر دورانی (Orbit) نوسانی همگرا میشوند. اگر و به صورت زیر انتخاب شوند:
آنگاه سیستم به صورت زیر نوشته خواهد شد:
معادله بالا معادله یک نوسانساز وندر پل است. بنابراین بر اساس نوع غیر خطی بودن و مقدار اولیه، حالتهای یک سیستم ممکن است به یک نقطه ثابت همگرا شوند یا یک حرکت نوسانی داشته باشند و یا واگرا شوند. تکنیکهای خاصی برای مطالعه مشخصههای سیستم غیر خطی گسترش یافتهاند که در ادامه به بیان آنها میپردازیم.
تکنیکهای آنالیز پایداری سیستم غیر خطی
سیستم غیر خطی در دو مد، رفتار پایداری از خود نشان میدهند. این سیستمها ممکن است یا یک نقطه تعادل (Equilibirum) داشته باشند که حالتهای سیستم به آن همگرا شوند و یا یک چرخه حدی داشته باشند که حالتها رفتاری نوسانی را تجربه کنند.
نقطه تعادل
سیستمی را که توسط معادله زیر توصیف میشود در نظر بگیرید:
یک نقطه نقطه تعادل نامیده میشود اگر شرط زیر برقرار باشد:
این نقطه تعادل باید پایدار باشد. اگر در همسایگی ، جهت مشتق از آن دور شود، حالتها حرکت خواهند کرد.
چرخه حدی
همانطور که در بالا بررسی کردیم، چرخه حدی مسیر دورانی نوسانی است که حالتهای یک سیستم غیر خطی در آن مسیر مستقر میشوند. برای کاربردهایی که در آنها هدف ایجاد حرکت نوسانی است، چرخه حدی یک مشخصه بسیار مفید است. یافتن یک چرخه معمولا بسیار دشوار است. چرخههای حدی میتوانند پایدار، ناپایدار و یا نیمهپایدار (Half Stable) باشند. چرخههای حدی نیمهپایدار چرخههایی هستند که برای مقادیر اولیه که داخل ناحیه محاصره شده توسط چرخه حدی باشند، پایدار بوده و برای سایر نواحی ناپایدار هستند. مثال زیر را در نظر بگیرید:
در این سیستم حالتهای سیستم تا همگرا میشوند، اما برای ، حالتها به بینهایت میروند.
بنابراین برخلاف سیستمهای خطی، پایداری سیستمهای غیر خطی به طبیعت غیر خطی بودن و حالتهای سیستم بستگی دارد. پس روشهای آنالیز مقادیر ویژه که برای سیستمهای خطی بسط یافته بودند، دیگر مستقیما قابل استعمال نیستند. سه تکنیک برای تعیین پایداری سیستم به صورت زیر هستند:
- حل معادلات دیفرانسیل به روش عددی (شبیهسازی) یا به روش تحلیلی و مطالعه رفتار جواب.
- خطیسازی سیستم غیر خطی در تعدادی از نقاط و مطالعه رفتار آنها. این روش مستعد خطای خطیسازی است.
- تعریف یک تابع لیاپانوف و مطالعه رفتار خود تابع.
از بین تمام این روشها، استفاده از تابع لیاپانوف دارای بیشترین دقت و کاربرد است و در برای آنالیز رفتار یک سیستم غیر خطی بیشتر از این روش استفاده میشود.
روش لیاپانوف برای آنالیز پایداری سیستم غیر خطی
در روش لیاپانوف، یک تابع مثبت معین (Positive-Definite) را تعریف میکنیم. از این تابع نسبت به زمان مشتق میگیریم و رفتار آن را بررسی خواهیم کرد. توجه کنید که این تابع را به نحوی تعریف میکنیم که در نقطه پایداری مورد تحقیق دارای مقدار صفر باشد. روش لیاپانوف میتواند به صورت زیر تعریف شود:
- ابتدا تابع را به نحوی تعریف میکنیم که در تمام نقاط فضا به غیر از نقطه تعادل مثبت معین باشد.
- مشتق این تابع را نسبت به زمان محاسبه میکنیم و کنترل میکنیم که تابع دارای کدامیک از مشخصههای زیر است:
- اگر مشتق این تابع همواره منفی باشد، آنگاه حالتها به صورت مجانبی (Asymptotically) به نقطه تعادل میل خواهند کرد.
- اگر مشتق این تابع برای تمام به ازای یک معین منفی شود، آنگاه نشاندهنده مرز پایداری است. به عبارتی دیگر، بعد از زمان بینهایت حالتهای سیستم توسط برای همیشه محدود میشوند.
روش لیاپانوف برای سیستمهای پیوسته در زمان
حال از روش لیاپانوف برای مطالعه رفتار یک سیستم گسسته در زمان مانند یک نوسانساز وندر پل استفاده میکنیم. سیستم زیر را در نظر بگیرید:
تابع لیاپانوفی را به صورت زیر در نظر می گیریم:
حال از این معادله نسبت به زمان مشتق میگیریم:
با جایگذاری معادلات حالت در مشتق لیاپانوف داریم:
توجه کنید که یک حالت خاص است که در آن تابع لیاپانوف تغییری نمیکند و سیستم یک حرکت تناوبی ثابت را از خود نشان میدهد. بنابراین بر روی دو حالت دیگر یعنی و تمرکز میکنیم:
حالت
در این حالت به سادگی را با قدر مطلق آن جایگزین میکنیم. زیرا باعث هیچ تغییری در رفتار سیستم نخواهد شد:
بنابراین اگر ، تابع لیاپانوف کاهش خواهد یافت. پس متغیرهای حالت همیشه محدود خواهند ماند و اگر ، حالتهای سیستم به سمت خواهند رفت.
حالت
در این حالت را با منفی قدر مطلق آن جایگزین خواهیم کرد. زیرا منجر به تغییر رفتار سیستم نخواهد شد. تابع لیاپانوف به صورت زیر در خواهد آمد:
بنابراین اگر باشد، حالتهای سیستم به صفر همگرا خواهند شد و اگر حالتهای سیستم به بینهایت خواهند رفت.
بنابراین با استفاده از روش لیاپانوف توانستیم رفتار سیستم را برای مقادیر پارامترها و حالتهای مختلف توصیف کنیم.
نکته: برای سیستمهای گسسته در زمان، تابع لیاپانوف مشابه با سیستمهای پیوسته تعریف میشود، اما پایداری به وسیله تفاضل بین مقدار تابع لیاپانوف در لحظه حال و لحظه قبل به دست میآید.
کدهای زیر نوسانساز وندر پل را به ازای رسم میکند:
شکل زیر پرتره فاز سیستم را نشان میدهد.

کد زیر نیز پرتره فاز را برای رسم خواهد کرد.
شکل زیر پرتره فاز در این حالت را نشان میدهد.

اگر این مطلب برای شما مفید بوده است، آموزشهای زیر نیز به شما پیشنهاد میشوند:
- مجموعه آموزشهای مهندسی کنترل
- آموزش طراحی سیستم های کنترل غیر خطی
- مجموعه آموزش مهندسی برق
- آموزش کنترل صنعتی – حل مساله
- خطی سازی سیستم های غیر خطی — از صفر تا صد
- کنترل کننده PID — مفاهیم و ساختارها
^^
سلام آیا یک سیستم غیرخطی را میتوان در سرتاسر نقاط اش خطی کرد؟ چه راهی هست یک سیستم خطی با تقریب خوب بدست بیاریم
سلام . ممنون از آموزش کاربردی شما.
برای کدنویسی دینامیک غیرخطی در متلب پیشنهاد منبع میدید؟!
با سلام
وقتتون بخیر
برای خطی سازی سیستم های غیر خطی گسسته که متغیر با زمان هستند و پارامتر متغیر نیز دارند. فیلم یا مطلب اموزشی به من معرفی میکنید؟ ممنونم.
سلام بسیار مفید و قابل استفاده بود. در صورت امکان منبع مطالب بیان شده برای استفاده و مطالعه بیشتر را ذکر کنید.
بسیار ممنون
سلام خانم مهندس وقت بخیر
سوالی داشتم خدوتون : بنده دارم روی یک سیستم کار می کنم که در حالت پیوسته پایدار(قطب ها منفی) و در حالت گسسته نیز پایدار(قطب ها داخل دایره واحد) هستند و گسسته سازیمو به دو روش انجام دادم 1- اویلر 2 – رانگ کوتای مرتبه4 ولی متاسفانه سکل موج های خروجیم ناپایداره و سیگنال منترلیم ندسانات زیادی داره و دامنه آن نیز زیاد هستش تقریبا 500 یا شایدم بیشتر…. . به نظرتون برای پایداریش باید چیکار کنم؟؟
ممنونتون میشم راهنماییم کنید از طریق ایمیل .
با سلام
ممکن است گام زمانی شبیهسازی نزدیک به گام زمانی روش گسسته سازی انتخاب شده باشد. گام شبیه سازی را باید حداقل ۱۰ برابر کوچکتر از گام گسستهسازی انتخاب کرده و حتی مقدار ۱۰۰ برابر کوچکتر را نیز امتحان کنید.
سلام
خیلی مفید، مختصر و آموزنده بود.
تشکر