کنترل فازی — از صفر تا صد

۵۷۷۶ بازدید
آخرین به‌روزرسانی: ۱۶ اردیبهشت ۱۴۰۲
زمان مطالعه: ۱۴ دقیقه
دانلود PDF مقاله
کنترل فازی — از صفر تا صدکنترل فازی — از صفر تا صد

در آموزش‌های قبلی مجله فرادرس، با برخی از رویکردهای طراحی سیستم‌های کنترل از قبیل کنترل پیش‌بین مدل آشنا شدیم. در این آموزش، با یک روش کنترلی دیگر، به نام کنترل فازی آشنا می‌شویم.

997696

امروزه کاربرد مجموعه‌های فازی در کنترل خودکار توجه زیادی را به خود جلب کرده است. در سال ۱۹۷۴، اولین کاربرد موفق منطق فازی در مهندسی کنترل، در یک فرایند آزمایشگاهی گزارش شد. کنترل کوره پخت سیمان یکی از اولین موارد کاربرد صنعنتی کنترل فازی بود. پس از ارائه اولین محصول تجاری در سال ۱۹۸۷ به بازار، که در تولید آن از منطق فازی استفاده شده بود، کاربرد کنترل فازی (Fuzzy Control) افزایش قابل توجهی یافت. امروزه تعدادی از محیط‌های طراحی به کمک رایانه (CAD) برای طراحی فازی با سخت‌افزار VLSI جهت اجرای سریع ادغام شده‌اند. تاکنون، کنترل فازی به سیستم‌های مختلفی از قبیل لوازم برقی، قطارها، ترافیک و... اعمال شده است.

کنترل‌کننده منطق فازی، یک پروتکل کنترلی را با قواعد «اگر-آنگاه» توصیف می‌کند؛ مثلاً «اگر دما پایین باشد، کمی شیر گرمایش را باز کن.» ابهام (عدم قطعیت) در تعریف عبارات زبانی (مثلاً دمای پایین)، با استفاده از مجموعه‌های فازی، که مجموعه‌هایی با مرزهای دارای هم‌پوشانی هستند، نمایش داده می‌شود (شکل ۱).

شکل ۱: سهم دامنه دما در سه مجموعه فازی
شکل ۱: سهم دامنه دما در سه مجموعه فازی

در چارچوب مجموعه فازی، یک عنصر خاص در دامنه می‌تواند همزمان به چند مجموعه متعلق باشد (با درجات عضویت متفاوت μ\mu). برای مثال، t=20t = 20^{\circ} به مجموعه دماهای بالا با عضویت 0.40.4 و مجموعه دماهای متوسط با عضویت 0.20.2 تعلق دارد. این انتقال تدریجی از عضویت به عدم عضویت، به تولید یک خروجی استدلالی هموار با قواعد اگر-آنگاه فازی کمک می‌کند.

تاریخچه کنترل فازی

کنترل فازی از یک رساله دکتری در زمینه هوش مصنوعی متولد شد. این رساله بین سال‌های ۱۹۷۲ تا ۱۹۷۴ به انجام رسید. هدف پژوهش، این بود که کامپیوترها با مشاهده کار یک انسان، یاد بگیرند آن را انجام دهند. آزمایشی که برای پژوهش مورد نظر انتخاب شد، کنترل یک نمونه موتور بخار بود. ورودی‌های کنترل در دسترس این سیستم، دو مورد بودند: «گرما» که فشار بخار در یک بویلر را تولید می‌کرد و «دریچه گاز» که بخار را به تک سیلندر موتور تزریق می‌کرد و روی سرعت آن تأثیر می‌گذاشت. هدف کنترل، ثابت نگه داشتن فشار بویلر و سرعت موتور بود. برای اینکه درک بهتری از چگونگی گسترش کنترل فازی از این پروژه پژوهشی داشته باشیم، باید با چند موضوع کلیدی آن آشنا شویم. در ادامه، این موارد را بیان می‌کنیم.

محیط محاسباتی

یک کامپیوتر هیبریدی تقریباً مانند مینی‌کامپیوتر PDP-8S با کلمات 8K (کلماتی ۱۲ بیتی) با رم هسته مغناطیسی برای انجام محاسبات ساخته شد. نوار کاغذی اصلی‌ترین بستر برای ذخیره و پشتیبانی اطلاعات بود. در آن زمان، ماوس هنوز اختراع نشده بود و ارتباط از طریق تله‌تایپ انجام می‌شد. ورودی‌ها و خروجی‌های موتور بخار با این کامپیوتر هیبریدی تنظیم و خوانده می‌شدند. اجرای یک بار آزمایش، مستلزم این بود که تله‌تایپ سرعت و فشار فعلی را چاپ کرده و منتظر بماند تا اپراتور با تایپ تنظیمات مقادیر گرما و دریچه گاز پاسخ دهد. با فشار دادن کلید بازگشت، کامپیوتر این تنظیمات را حمل کرده و با تایپ قرائت‌های جدید سرعت و فشار پاسخ می‌داد. این عملیات تا جایی ادامه پیدا می‌کرد که دیگ از آب خالی شده و آماده شروع یک اجرای دیگر قابل انجام می‌شد.

چارچوب نظری پژوهش

این مطالعه عاری از هرگونه فرمول‌بندی خاص ریاضی بود. با توجه به منابع محدود محیط محاسباتی، ساده‌ترین کار، شروع با استفاده از رویکرد یادگیری بیزی بود. ایده کار به‌روزرسانی احتمالات کنش اعمالی به موتور بخار بود. واضح است که این روش ساده بوده و احتمال می‌رفت همگرایی احتمالاتِ یادگیری شده با شکست مواجه شود. دلیل این شکست هم مشخص بود؛ اپراتور انسانی علاوه بر حالت فعلی، حالات گذشته سیستم را نیز در نظر می‌گرفت. الگوریتم باید به گونه‌ای بازبینی می‌شد تا حالات قبلی را نیز شامل شود. اما این نگرانی وجود داشت که الگوریتم پیچیده‌تر شود و به رم موجود آسیب بزند.

ورود نظریه مجموعه فازی

برای حفظ جایگاه پژوهش، یک رویکرد جایگزین مورد بررسی قرار گرفت. نظریه مجموعه‌های فازی، تقریباً از سال ۱۹۶۵ وجود داشت، اما در سال ۱۹۷۳، دکتر زاده مقاله‌ای در مجله IEEE SMC منتشر کرد که به جای شرح نظریه با عبارات نظری مجموعه‌های سنتی، راهی برای تشکیل الگوریتم‌ها بر اساس مجموعه‌های فازی ارائه داد. یک الگوریتم کنترل فازی به ماشین «می‌گوید» که چگونه موتور بخار را کنترل کند، به جای آنکه با مشاهده کنش‌های اپراتور انسانی یاد بگیرد که چه کاری را انجام دهد. ممدانی اولین الگوریتم کنترل فازی را در ۴ روز ساخت و آن را به سهولت برای مدل موتور بخار بررسی کرد. این الگوریتم شامل تعدادی قوانین فازی بود؛ از جمله: «اگر خطای فشار بسیار مثبت است و تغییر خطای فشار متوسط منفی نیست، آنگاه گرما را به اندازه خیلی مثبت تغییر بده.» در این قانون، متغیرهای اندازه‌گیری و کنترل با حروف پررنگ (بولد) و مقادیر فازی آن‌ها به صورت کج (ایتالیک) نمایش داده شده‌اند.

دلایل استفاده از کنترل فازی

نظریه کنترل رایج از مدل ریاضی (تحلیلی) صریح یک فرایند تحت کنترل و مشخصات رفتار مطلوب حلقه‌بسته برای طراحی یک کنترل‌کننده استفاده می‌‌کند. اگر به دست آوردن مدل دشوار باشد یا (بخشی از آن) ناشناخته یا بسیار غیرخطی باشد، این رویکرد با مشکل مواجه خواهد شد. طراحی کنترل‌کننده‌ برای کارهای روزمره به ظاهر ساده، مانند رانندگی یک خودرو یا محکم گرفتن یک جسم شکستنی، هنوز در رباتیک با چالش همراه است. این در حالی است که انسان این کارها را به آسانی انجام می‌دهد. تاکنون، بشر از مدل‌های ریاضی یا مسیرهای دقیق برای کنترل چنین فرایندهایی استفاده نکرده است.

بسیاری از فرایندهای صنعتی که با اپراتورهای انسانی کنترل می‌شوند، نمی‌توانند از روش‌های کنترل رایج برای خودکار شدن بهره ببرند، زیرا عملکرد این کنترل‌کننده‌ها اغلب نسبت به اپراتورها مناسب نیست. یکی از دلایل این امر، آن است که کنترل‌کننده‌های خطی که اغلب در کنترل سنتی مورد استفاده قرار می‌گیرند، برای سیستم‌های غیرخطی مناسب نیستند. دلیل دیگر این است که انسان اطلاعات مختلفی را جمع‌آوری، و استراتژی‌های کنترل را با یکدیگر ترکیب می‌کند که نمی‌توان آن‌ها را در یک قانون کنترل تحلیلیِ تنها تجمیع کرد.

اصل اساسی کنترل دانش‌بنیان (خبره)، ثبت و پیاده‌سازی تجربه و دانش موجود خبره‌ها (یعنی اپراتورهای فرایند) است. یک نوع خاص کنترل دانش‌بنیان کنترل قاعده‌محور فازی است که در آن، کنش‌های کنترلی متناظر با شرایط خاص سیستم‌اند و بر اساس قوانین اگر-آنگاه فازی توصیف شده‌اند.

در این کنترل‌کننده‌ها، از مجموعه‌های فازی برای تعریف مفهوم مقادیر کیفی ورودی‌ها و خروجی‌های کنترل‌کننده استفاده می‌شود؛ مثلاً خطای «کوچک» و عمل یا کنش کنترلی «بزرگ». منطق فازی می‌تواند ماهیت پیوسته فرایندهای تصمیم‌گیری انسانی را ضبط کند و به همین ترتیب، بهبود قطعی نسبت به روش‌های مبتنی بر منطق دودویی یا باینری (که به طور گسترده در کنترل‌کننده‌های صنعتی مورد استفاده قرار می‌گیرند) دارد.

کار اولیه در کنترل فازی، با اهداف زیر انجام شد:

  • تقلید از کنش‌های کنترلی یک اپراتور انسانی باتجربه و متخصص (بخش دانش‌بنیان)
  • یافتن یک درون‌یابی هموار بین خروجی‌های مجزا که معمولاً به صورت رایج به دست می‌آیند (بخش منطق فازی).

پس از کارهای اولیه، کاربرد کنترل فازی وسعت پیدا کرد. با این حال، دو انگیزه اصلی آن همچنان پابرجاست: ماهیت زبانی کنترل فازی آن را برای توضیح دانش فرایندی که باید کنترل شود یا رفتار کند ممکن می‌سازد. جنبه درون‌یابی کنترل فازی نیز منجر به دیدگاهی می‌شود که در آن، سیستم‌های فازی به عنوان تقریب تابعی هموار دیده می‌شوند.

در اغلب موارد، از کنترل‌کننده فازی برای کنترل فیدبک استفاده می‌شود. هرچند، از آن می‌توان در سطح نظارتی، مانند یک دستگاه خودتنظیم در یک کنترل‌کننده PID رایج نیز استفاده کرد. همچنین، کنترل فازی را می‌توان از یک مدل فازی به دست آورد که از شناسایی سیستم به دست آمده است. اغلب کنترل‌کننده‌های فازی به صورت زیر هستند:

  • کنترل‌کننده ممدانی‌ (زبانی) با نتایج فازی یا تک عنصری. این نوع کنترل‌کننده معمولاً به عنوان کنترل‌کننده حلقه‌بسته استفاده می‌شود.
  • کنترل‌کننده تاکاگی-سوگنو (TS) که معمولاً به عنوان یک کنترل‌کننده نظارتی مورد استفاده قرار می‌گیرد.

کنترل‌کننده ممدانی

کنترل‌کننده ممدانی (Mamdani Controller) معمولاً به عنوان یک کنترل‌کننده فیدبک مورد استفاده قرار می‌گیرد.

از آنجایی که قاعده‌محوری یک نگاشت استاتیکی بین متغیرهای قبلی و بعدی است، باید از فیلترهای دینامیکی خارجی برای به دست آوردن رفتار دینامیکی مطلوب کنترل‌کننده استفاده کرد (شکل ۲).

شکل ۲: کنترل‌کننده فازی در یک پیکربندی حلقه‌بسته (بخش بالایی) که از فیلتر‌های دینامیکی و یک تصویر استاتیکی تشکیل شده است (شکل وسط). تصویر استاتیکی بر بنیان دانش، ساز و کار استنتاج و استنتاج‌های فازی‌ساز و و غیرفازی‌ساز تشکیل شده است.
شکل ۲: کنترل‌کننده فازی در یک پیکربندی حلقه‌بسته (بخش بالایی) که از فیلتر‌های دینامیکی و یک نگاشت استاتیکی (شکل وسط) تشکیل شده است. نگاشت استاتیکی بر بنیان دانش، ساز و کار استنتاج و استنتاج‌های فازی‌ساز و و غیرفازی‌ساز تشکیل شده است.

پروتکل کنترل به فرم قواعد اگر-آنگاه در پایگاه قواعد ذخیره می‌شود که بخشی از پایگاه دانش است. در حالی که قوانین مبتنی بر دانش کیفی هستند، توابع عضویتی که عبارات زبانی را تعریف می‌کنند، یک استنتاج هموار را برای متغیرهای فرایند عددی و نقاط تنظیم ارائه می‌دهند. فازی‌ساز (Fuzzifier) درجات عضویت متغیرهای ورودی کنترل‌کننده را در مجموعه‌های فازی مرجع تعیین می‌کند. ساز و کار استنتاج یا همان موتور استنتاج این اطلاعات را با دانشِ ذخیره شده در قواعد ترکیب کرده و خروجی سیستم مبتنی بر قواعد را تعیین می‌کند. برای اهداف کنترل، یک سیگنال کنترل قطعی یا دقیق لازم است. غیرفازی‌ساز (Defuzzifier) مقدار این سیگنال قطعی را از خروجی‌های کنترل‌کننده فازی محاسبه می‌کند.

در شکل ۲، می‌توان دید که نگاشت فازی تنها بخشی از کنترل‌کننده فازی است. پردازش سیگنال قبل و بعد از نگاشت فازی ضروری است. پیش‌فیلترها و پس‌فیلترها ورودی‌ها و خروجی‌های کنترل‌کننده را پردازش می‌کنند. این فیلترهای دینامیکی معمولاً مقیاس‌بندی سیگنال و فیلترسازی دینامیکی را انجام می‌دهند، مثلاً مشتق و انتگرال خطای کنترل یا سیگنال کنترل را محاسبه می‌کنند.

این تفکیک کنترل‌کننده به یک نگاشت استاتیکی (ایستا) و فیلتر‌های دینامیکی (پویا) را می‌توان برای اغلب ساختارهای کنترل کلاسیک انجام داد. برای درک بهتر، یک کنترل‌کننده PID را در نظر بگیرید که معادله آن به صورت زیر است:

u(t)=Pe(t)+I0te(τ)dτ+Dde(t)dt          (1) \large u ( t ) =P e ( t ) + I \int _ 0 ^ t e ( \tau ) d \tau + D \frac { d e ( t ) } { d t} \;\;\;\;\; (1)

که در آن، u(t)u(t) سیگنال کنترلی است که به فرایند تحت کنترل اعمال می‌شود و e(t)=r(t)y(t)e(t) = r(t) - y(t) سیگنال خطا، یعنی اختلاف بین خروجی مطلوب و خروجی اندازه‌گیری شده فرایند است. معادله (۱) یک تابع خطی (از نظر هندسی، یک ابرصفحه) است:

u=i=13aixi          (2) \large u = \sum _ { i = 1 } ^ 3 a _ i x _ i \; \; \; \; \; (2)

که در آن، x1=e(t) x _ 1 = e(t)، x2=0te(τ)dτx_2 = \int_0^te(\tau)d\tau، x3=de(t)dtx_3 = \frac{de(t)}{dt} و ai a _ i پارامترهای مربوط به بهره‌های P\text{P}، I\text{I} و D \text{D} هستند. فرم خطی (۲) را می‌توان به یک تابع غیرخطی تعمیم داد:

u=f(x).          (3) \large \mathbf { u } = f ( \mathbf { x } ) . \;\;\;\;\; (3)

در یک کنترل‌کننده منطق فازی، تابع غیرخطی ff با یک نگاشت فازی نمایش داده می‌شود. بدیهی است که کنترل‌کننده‌های فازی را می‌توان مشابه با کنترل‌کننده‌های P\text{P}، PI\text{PI}، PD\text{PD} یا PID\text{PID} خطی، با استفاده از فیلترهای دینامیکی مناسب، مانند مشتق‌گیرها و انتگرال‌گیرها طراحی کرد.

ماهیت سیستم‌های فازی ممدانی، بسیار نزدیک به ماهیت کنترل دستی است. این نوع کنترل‌کننده‌ها با مشخص کردن خروجی به ازای ترکیب‌هایی از سیگنال‌های ورودی مختلف تعریف می‌شوند. هر ترکیب سیگنال ورودی به صورت قاعده‌ای به فرم زیر است:‌

RiR_i: اگر x1x_1 به صورت Ai1A_{i1} باشد و ... و xnx_n به صورت AinA_{in} باشد، آنگاه uu به صورت Bi B _ {i} است (i=1,2,,Ki=1,2, \ldots, K).                   (4)\;\;\;\;\;(4)

در این کنترل‌کننده‌ها، ممکن است از بعضی رابط‌ها یا عملگرهای دیگر، مانند «یا» (OR) یا «نه» (NOT) نیز استفاده شود. در سیستم‌های فازی ممدانی، مجموعه‌های فازی مقدم (Antecedent) و مؤخر (Consequent) اغلب به صورت مثلثی یا گاوسی انتخاب می‌شوند. همچنین، رایج است که توابع عضویت ورودی، به گونه‌ای با یکدیگر همپوشانی داشته باشند که مقادیر عضویت قاعده مقدم همیشه به ۱ جمع شوند (مجموعشان ۱ شود). در این حالت، و اگر پایگاه قواعد به فرم عطفی باشد، می‌توان هر قاعده را به عنوان تعریف مقدار خروجی برای یک نقطه در فضای ورودی تفسیر کرد. این نقطه در فضای ورودی، با به دست آوردن مراکز مجموعه‌های فازی ورودی به دست می‌آید. در نتیجه، مقدار خروجی، مرکز مجموعه فازی خروجی است (روش مرکز مساحت).

همان‌طور که در شکل ۳ نشان داده شده است، استدلال فازی، منجر به یک درون‌یابی نرم (هموار) بین نقاط فضای ورودی می‌شود.

شکل ۳:‌ سهم توابع عضویت در فضای ورودی
شکل ۳:‌ سهم توابع عضویت در فضای ورودی
شکل ۴: هر قاعده مقدار خروجی را برای یک نقطه یا ناحیه در فضای ورودی تعریف می‌کند.
شکل ۴: هر قاعده مقدار خروجی را برای یک نقطه یا ناحیه در فضای ورودی تعریف می‌کند.
بر اساس رای ۲۶ نفر
آیا این مطلب برای شما مفید بود؟
اگر بازخوردی درباره این مطلب دارید یا پرسشی دارید که بدون پاسخ مانده است، آن را از طریق بخش نظرات مطرح کنید.
منابع:
Scholarpedia
نظر شما چیست؟

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *