Геометричне програмування Геометричне програмування — розділ математичного програмування, що вивчає підхід до розв'язування нелінійних задач оптимізації спеціальної структури. Термін вперше ввели 1967 року Р. Даффін[en], Е. Пітерсон і К. Зенер. Назва дисципліни пов'язана з тим, що однією з основних у викладаній теорії є нерівність між середнім геометричним і середнім арифметичним і її узагальнення. Передумовою до розвитку геометричного програмування стали деякі геометричні задачі і методи їх розв'язування. Базовим поняттям геометричного програмування є позіном.
Формулювання задачі геометричного програмування
Знайти найменше значення функції за обмежень:

і
.
Тут
,
де
![{\displaystyle J[k]=(m_{k},m_{k}+1,m_{k}+2,...,n_{k})k=0,1,...,p}](https://wikimedia.org/api/rest_v1/media/math/render/svg/f1f20d3794cfbf57d7358c0c93811f37741edb6c)
і
.
Функції — позіноми.
Приклади задач геометричного програмування
Приклад 1
Знайти довжини сторін прямокутника заданого периметра, що має найбільшу площу. Те саме для трикутника.
Приклад 2

за обмежень

де
Розв'язком задачі є вектор з компонентами
де
Програмні засоби
Існує декілька пакунків програм, які допомагають формулювати та розв'язувати задачі геометричного програмування.
- MOSEK [Архівовано 28 жовтня 2020 у Wayback Machine.] — це комерційний розв'язувач, здатний розв'язувати задачі геометричного програмування, а також інші задачі нелінійної оптимізації.
- CVXOPT [Архівовано 28 жовтня 2020 у Wayback Machine.] — це розв'язувач із відкритим кодом для опуклих задач оптимізації.
- GPkit [Архівовано 4 жовтня 2020 у Wayback Machine.] — це пакунок Python для чіткого визначення та маніпулювання моделями геометричними програмування. Містить низку прикладів моделей геометричного програмування, написаних разом із цим пакетом.
- GGPLAB [Архівовано 26 вересня 2020 у Wayback Machine.] — це набір інструментів MATLAB для постановки та вирішення задач геометричного програмування (ГП) та узагальнених задач геометричного програмування (УГП).
- CVXPY [Архівовано 28 жовтня 2020 у Wayback Machine.] — це вбудована в Python мова моделювання для визначення та розв'язування опуклих задач оптимізації, включано з ГП, УГП та LLCP[1].
Див. також
Примітки
Література
- Richard J. Duffin, Elmor L. Peterson, Clarence Zener. Geometric Programming. — John Wiley and Sons, 1967. — P. 278. — ISBN 0-471-22370-0.
- Р. Даффин, Э. Питерсон, К. Зенер. Геометрическое программирование. — М. : Мир, 1972. — 311 с.
|