Проблема дієти

Метою дієтичної проблеми є відбір продуктів, які задовольняють добові харчові потреби з мінімальними витратами. Цю проблему можна сформулювати як лінійну програму, для якої обмеження обмежують кількість калорій та кількість вітамінів, мінералів, жирів, натрію та холестерину в раціоні. Данциг (1990) зазначає, що проблема дієти була мотивована бажанням армії США мінімізувати витрати на годування ГЛС в полі, зберігаючи при цьому здорове харчування.

Постановка проблеми

Дієтна задача може бути сформульована математично як задача лінійного програмування з використанням такої моделі в Pyomo:

Набори

Встановити дані, які використовуються для визначення екземпляра моделі.

Параметри (Param)

Дані параметрів, які використовуються для визначення екземпляра моделі.

Змінні (Var)

Змінні рішення в моделі.

Об’єктивна

Вирази, які у моделі зведено до мінімуму.

Обмеження

Вирази обмеження, які накладають обмеження на значення змінних у моделі.

Примітка: Усі пакети вже в Qusandbox, вам не потрібно встановлювати будь-які пакети, якщо ви запускаєте проект у Qusandbox. Якщо ви запускаєте проект у своєму локальному блокноті Jupyter, будь ласка, переконайтесь, що ви встановили всі пакунки вище.

Спочатку потрібно оголосити абстрактну модель, створивши об’єкт моделі. АнотаціяМодель клас забезпечує контекст для визначення та ініціалізації абстрактних моделей оптимізації в Pyomo, коли значення даних будуть надаватися в той час, коли потрібно отримати рішення.

Потім використовуйте Встановити компонент для оголошення наборів F і N абстрактно. Під час роботи з Pyomo зручно писати абстрактні моделі дещо абстрактніше, використовуючи набори індексів, що містять рядки, а не набори індексів, що передбачаються 1,. м або підсумовування від 1 до n.

Аналогічно параметри моделі визначаються абстрактно, використовуючи Парам компонент. в межах Параметр використовується в цих оголошеннях параметрів для визначення очікуваних властивостей параметрів. Ця інформація використовується для перевірки помилок даних, що використовуються для ініціалізації компонентів параметрів.

Наприклад, оголосіть параметр "вартість кожної їжі":

Використовувати Var компонент для визначення змінних прийняття рішення, який у цьому випадку є кількістю споживаних порцій кожної їжі. Внутрішня опція використовується для обмеження домену змінних рішення невід'ємними дійсними. Це позбавляє від необхідності явних обмежених обмежень для змінних.

Об’єктивна компонент використовується для визначення ціні витрат. Цей компонент використовує a правило функція для побудови цільового виразу

Аналогічно, функції правила використовуються для визначення виразів обмежень у Обмеження компонент.

Нарешті, складіть ці декларації разом, і ви отримаєте свою модель Pyomo.

Оскільки це абстрактна модель Pyomo, для встановлення моделі потрібно надати значення набору та параметрів. Ви можете поглянути на цей синтетичний набір даних:

визначення екземпляра

Дані набору визначаються за допомогою встановити команда, а дані параметрів визначаються за допомогою парам команди.

Цей набір даних розглядає проблему складання щоденного раціону лише з продуктів харчування з ланцюга швидкого харчування.

Pyomo включає команду pyomo, яка автоматизує побудову та оптимізацію моделей. Розв'язувач GLPK можна використати в цьому простому прикладі:

Це дає такий вивід на екран:

Цифри в квадратних дужках вказують, скільки часу потрібно для кожного кроку. Результати записуються у файл із назвою results.yml, який як спеціальна структура робить його корисним для подальшої обробки.

Це рішення показує, що приблизно за 15 доларів на день людина може обійтися 4 чизбургерами, 5 картоплею фрі, 1 сендвічем з рибою та 4 молоками.