Gekko (نرم افزار بهینه سازی)

از testwiki
نسخهٔ تاریخ ۱۶ فوریهٔ ۲۰۲۵، ساعت ۱۶:۴۰ توسط imported>مبین خجسته برومند (growthexperiments-addlink-summary-summary:1|1|0)
(تفاوت) → نسخهٔ قدیمی‌تر | نمایش نسخهٔ فعلی (تفاوت) | نسخهٔ جدیدتر ← (تفاوت)
پرش به ناوبری پرش به جستجو

بسته پایتون GEKKO [۱] معادلات جبری اعداد صحیح مختلط و دیفرانسیل در مقیاس بزرگ را با حل کننده های برنامه نویسی غیرخطی ( IPOPT ، APOPT ، BPOPT، SNOPT ، MINOS ) حل می کند. حالت‌های عملیات شامل یادگیری ماشین، تطبیق داده‌ها، بهینه‌سازی بلادرنگ، شبیه‌سازی پویا و کنترل پیش‌بینی مدل غیرخطی است. علاوه بر این، این بسته برنامه‌نویسی خطی (LP)، برنامه‌ریزی درجه دوم (QP)، برنامه‌ریزی درجه دوم محدود (QCQP)، برنامه‌نویسی غیرخطی (NLP)، برنامه‌نویسی عدد صحیح مختلط (MIP) و برنامه‌ریزی خطی عدد صحیح مختلط (MILP) را حل می‌کند. GEKKO در پایتون موجود است و با pip از PyPI بنیاد نرم‌افزار پایتون نصب می‌شود.

pip install gekko

GEKKO روی همه پلتفرم ها و با پایتون 2.7 و 3+ کار می کند. به طور پیش فرض، مشکل به یک سرور عمومی ارسال می شود که در آنجا راه حل محاسبه می شود و به پایتون باز می گردد. گزینه های پردازنده Windows، MacOS، Linux و ARM (Raspberry Pi) بدون اتصال به اینترنت قابل حل هستند. GEKKO یک توسعه از مجموعه بهینه سازی APMonitor است اما مدل سازی و تجسم راه حل را مستقیماً در پایتون ادغام کرده است. یک مدل ریاضی بر حسب متغیرها و معادلات بیان می‌شود، مانند مسئله معیار Hock & Schittkowski #71 [۲] برای آزمایش عملکرد حل‌کننده‌های برنامه‌ریزی غیرخطی استفاده می‌شود. این مسئله بهینه سازی خاص یک تابع هدف دارد minxx1x4(x1+x2+x3)+x3 و مشروط به محدودیت نابرابری x1x2x3x425 و محدودیت برابری x12+x22+x32+x42=40 . چهار متغیر باید بین کران پایینی 1 و کران بالایی 5 باشند. مقادیر حدس اولیه هستند x1=1,x2=5,x3=5,x4=1 . این مشکل بهینه سازی با GEKKO مطابق شکل زیر حل می شود.

کاربرد های gekko

کاربردها عبارتند از تولید همزمان (قدرت و گرما) ، [۳] اتوماسیون حفاری ، [۴] کنترل فشار شدید، [۵] تولید انرژی حرارتی خورشیدی، [۶] سلول های سوختی اکسید جامد ، [۷] [۸] تضمین جریان، [۹] بازیافت نفت پیشرفته ، [۱۰] استخراج اسانس ، [۱۱] و وسایل نقلیه هوایی بدون سرنشین (UAVs) . [۱۲] ارجاعات زیادی به APMonitor و GEKKO به عنوان نمونه ای از انواع برنامه های کاربردی قابل حل وجود دارد. GEKKO از کمک مالی تحقیقاتی بنیاد ملی علوم (NSF) به شماره 1547110 [۱۳] [۱۴] [۱۵] [۱۶] توسعه یافته است و در مجموعه شماره ویژه برنامه ریزی و کنترل ترکیبی به تفصیل آمده است. [۱۷] سایر موارد قابل توجه GEKKO فهرستی در درخت تصمیم برای نرم افزار بهینه سازی، [۱۸] پشتیبانی اضافه شده برای حل کننده های APOPT و BPOPT، [۱۹] گزارش پروژه های دوره آنلاین بهینه سازی پویا از شرکت کنندگان بین المللی است. [۲۰] GEKKO موضوعی در انجمن های آنلاین است که در آن کاربران در حال حل مسائل بهینه سازی و کنترل بهینه هستند. [۲۱] [۲۲] GEKKO برای کنترل پیشرفته در آزمایشگاه کنترل دما (TCLab) [۲۳] برای آموزش کنترل فرآیند در 20 دانشگاه استفاده می شود. [۲۴] [۲۵] [۲۶] [۲۷]

from gekko import brain

import numpy as np

()b=brain.Brain

(1)b.input_layer

b.layer(linear=3)

b.layer(tanh=3)

b.layer(linear=3)

b.output_layer(1)

x=np.linespace(-np.pi,3*np.pi,20)

y=2-np.cos(x)

b.learn(x,y)

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

یادگیری ماشین

یکی از کاربردهای یادگیری ماشین ، انجام رگرسیون از داده های آموزشی برای ایجاد یک همبستگی است. در این مثال، یادگیری عمیق یک مدل از داده های آموزشی تولید می کند که با تابع تولید می شود 1cos(x) . برای این مثال از یک شبکه عصبی مصنوعی با سه لایه استفاده شده است. لایه اول خطی، لایه دوم تابع فعال سازی مماس هذلولی و لایه سوم خطی است. این برنامه وزن پارامترهایی را تولید می کند که مجموع مجذور خطاهای بین نقاط داده اندازه گیری شده و پیش بینی های شبکه عصبی در آن نقاط را به حداقل می رساند. GEKKO از بهینه‌سازهای مبتنی بر گرادیان برای تعیین مقادیر وزن بهینه به جای روش‌های استاندارد مانند انتشار پس‌انداز استفاده می‌کند. شیب ها با تمایز خودکار، مشابه سایر بسته های محبوب، تعیین می شوند. این مسئله به عنوان یک مسئله بهینه سازی محدود حل می شود و زمانی همگرا می شود که حل کننده شرایط کاروش–کون–تاکر را برآورده کند. استفاده از یک بهینه ساز مبتنی بر گرادیان، محدودیت های اضافی را امکان پذیر می کند که ممکن است با دانش دامنه از داده ها یا سیستم اعمال شود.

کنترل بهینه

کنترل بهینه استفاده از بهینه سازی ریاضی برای به دست آوردن یک خط مشی است که توسط دیفرانسیل محدود می شود (dx1dt=u) ، برابری (x1(0)=1) ، یا نابرابری (1u(t)1) معادله می کند و یک تابع هدف/پاداش را به حداقل می رساند (minu1202x12(t)dt) . کنترل بهینه اولیه با GEKKO با ادغام هدف و رونویسی معادله دیفرانسیل به شکل جبری با هم‌آمیزی متعامد بر روی عناصر محدود حل می‌شود.

منابع

الگو:پانویس