Решение задач линейного программирования с использованием Microsoft Excel
Ввод зависимостей из математической модели в экранную форму. Проверка правильности введения формул. Анализ граничных условий для допустимых значений переменных. Способы решения двухиндексного задания. Расчет примеров с целочисленными переменными.
Рубрика | Программирование, компьютеры и кибернетика |
Вид | лабораторная работа |
Язык | русский |
Дата добавления | 10.11.2015 |
Размер файла | 36,1 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru/
ЛАБОРАТОРНАЯ РАБОТА
1. “РЕШЕНИЕ ЗАДАЧ ЛИНЕЙНОГО ПРОГРАММИРОВАНИЯ С ИСПОЛЬЗОВАНИЕМ MICROSOFT EXCEL”
1.1 Цель работы
Приобретение навыков решения задач линейного программирования (ЛП) в табличном редакторе Microsoft Excel.
1.2 Порядок выполнения работы
Для модели ЛП, соответствующей номеру Вашего варианта, найдите оптимальное решение в табличном редакторе Microsoft Excel и продемонстрируйте его преподавателю.
1.3 Инструкция по использованию microsoft excel для решения задач лп
Для того чтобы решить задачу ЛП в табличном редакторе Microsoft Excel, необходимо выполнить следующие действия.
1. Ввести условие задачи:
a) создать экранную форму для ввода условия задачи: * переменных,
• целевой функции (ЦФ),
• ограничений,
• граничных условий;
b) ввести исходные данные в экранную форму:
• коэффициенты ЦФ,
• коэффициенты при переменных в ограничениях,
• правые части ограничений;
c) ввести зависимости из математической модели в экранную
форму:
• формулу для расчета ЦФ,
• формулы для расчета значений левых частей ограничений;
d) задать ЦФ (в окне "Поиск решения"):
• целевую ячейку,
• направление оптимизации ЦФ;
e) ввести ограничения и граничные условия (в окне "Поиск
решения"):
• ячейки со значениями переменных,
• граничные условия для допустимых значений переменных, * соотношения между правыми и левыми частями ограничений.
2. Решить задачу:
a) установить параметры решения задачи (в окне "Поиск решения");
b) запустить задачу на решение (в окне "Поиск решения");
c) выбрать формат вывода решения (в окне "Результаты поиска решения").
Одноиндексные задачи ЛП
Рассмотрим пример нахождения решения для следующей одноиндексной задачи ЛП:
L ( )X =130,5x1 + 20x2 + 56x3 + 87,8x4 > max;
??1,8x1 + 2x2 + x3 ? 4x4 = 756,
??? 6x1 + 2x2 + 4x3 ? x4 ? 450,
??4x 1?1,5x2 +10,4x3 +13x4 ? 89, ??x j ? 0; j =1,4.
Ввод исходных данных
Создание экранной формы и ввод в нее условия задачи
В экранной форме на рис. 1.1 каждой переменной и каждому коэффициенту задачи поставлена в соответствие конкретная ячейка в Excel. Имя ячейки состоит из буквы, обозначающей столбец, и цифры, обозначающей строку, на пересечении которых находится объект задачи ЛП. Так, например, переменным задачи (1.1) соответствуют ячейки B3 (x1), C3 (x2), D3 (x3), E3 (x4), коэффициентам ЦФ соответствуют ячейки B6 (c1 =130,5), C6 (c2 =20), D6 (c3 =56), E6 (c4 =87,8), правым частям ограничений соответствуют ячейки H10 (b1 =756), H11 (b2 =450), H12 (b3 = 89) и т.д.
Ввод зависимостей из математической модели в экранную форму
Зависимость для ЦФ
В ячейку F6, в которой будет отображаться значение ЦФ, необходимо ввести формулу, по которой это значение будет рассчитано. Согласно (1.1) значение ЦФ определяется выражением
130,5x1 + 20x2 + 56x3 +87,8x4 .
Используя обозначения соответствующих ячеек в Excel (см. рис. 1.1), формулу для расчета ЦФ (1.2) можно записать как сумму произведений каждой из ячеек, отведенных для значений переменных задачи (B3, C3, D3, E3), на соответствующую ячейку, отведенную для коэффициентов ЦФ (B6, C6, D6, E6), то есть
B6 ?B3+ C6 ?C3+ D6 ?D3+ E6 ?E3. (1.3) Чтобы задать формулу (1.3) необходимо в ячейку F6 ввести следующее выражение и нажать клавишу "Enter"=СУММПРОИЗВ(B$3:E$3;B6:E6),
где символ $ перед номером строки 3 означает, что при копировании этой формулы в другие места листа Excel номер строки 3 не изменится; символ : означает, что в формуле будут использованы все ячейки, расположенные между ячейками, указанными слева и справа от двоеточия (например, запись B6:E6 указывает на ячейки B6, C6, D6 и E6). После этого в целевой ячейке появится 0 (нулевое значение).
Примечание 1.1. Существует другой способ задания функций в Excel с помощью режима "Вставка функций", который можно вызвать из меню "Вставка" или при нажатии кнопки " fx " на стандартной панели инструментов. Так, например, формулу (1.4) можно задать следующим образом:
• курсор в поле F6;
• нажав кнопку " fx ", вызовите окно "Мастер функций - шаг 1 из 2";
• выберите в окне "Категория" категорию "Математические";
• в окне "Функция" выберите функцию СУММПРОИЗВ;
• в появившемся окне "СУММПРОИЗВ" в строку "Массив 1" введите выражение B$3:E$3, а в строку "Массив 2" - выражение B6:E6;
• после ввода ячеек в строки "Массив 1" и "Массив 2" в окне "СУММПРОИЗВ" появятся числовые значения введенных массивов, а в экранной форме в ячейке F6 появится текущее значение, вычисленное по введенной формуле, то есть 0 (так как в момент ввода формулы значения переменных задачи нулевые).
Зависимости для левых частей ограничений
Левые части ограничений задачи (1.1) представляют собой сумму произведений каждой из ячеек, отведенных для значений переменных задачи (B3, C3, D3, E3), на соответствующую ячейку, отведенную для коэффициентов конкретного ограничения (B10, C10, D10, E10 - 1-е ограничение; B11, C11, D11, E11 - 2-е ограничение и B12, C12, D12, E12 - 3-е ограничение). Формулы, соответствующие левым частям ограничений, представлены в табл. 1.1.
Таблица 1.1 Формулы, описывающие ограничения модели (1.1)
Левая часть ограничения |
Формула Excel |
|
?1,8x1 + 2x2 + x3 ? 4x4 илиB10? B3 + C10? C3 + D10? D3 + E10? E3 |
=СУММПРОИЗВ(B$3:E$3;B10:E10) |
|
?6x1 + 2x2 + 4x3 ? x4 илиB11? B3+ C11? C3 + D11? D3 + E11? E3 |
=СУММПРОИЗВ(B$3:E$3;B11:E11) |
|
4x1 ?1,5x2 +10,4x3 +13x4 илиB12? B3 + C12? C3 + D12? D3 + E12? E3 |
=СУММПРОИЗВ(B$3:E$3;B12:E12) |
Как видно из табл. 1.1, формулы, задающие левые части ограничений задачи (1.1), отличаются друг от друга и от формулы (1.4) в целевой ячейке F6 только номером строки во втором массиве. Этот номер определяется той строкой, в которой ограничение записано в экранной форме. Поэтому для задания зависимостей для левых частей ограничений достаточно скопировать формулу из целевой ячейки в ячейки левых частей ограничений. Для этого необходимо:
• поместить курсор в поле целевой ячейки F6 и скопировать в буфер содержимое ячейки F6 (клавишами "Ctrl-Insert");
• помещать курсор поочередно в поля левой части каждого из ограничений, то есть в F10, F11 и F12, и вставлять в эти поля содержимое буфера (клавишами "Shift-Insert") (при этом номер ячеек во втором массиве формулы будет меняться на номер той строки, в которую была произведена вставка из буфера);
• на экране в полях F10, F11 и F12 появится 0 (нулевое значение).
Проверка правильности введения формул
Для проверки правильности введенных формул производите поочередно двойное нажатие левой клавиши мыши на ячейки с формулами. При этом на экране рамкой будут выделяться ячейки, используемые в формуле.
Задание ЦФ
Дальнейшие действия производятся в окне "Поиск решения", которое вызывается из меню "Сервис":
• поставьте курсор в поле "Установить целевую ячейку";
• введите адрес целевой ячейки $F$6 или сделайте одно нажатие левой клавиши мыши на целевую ячейку в экранной форме ? это будет равносильно вводу адреса с клавиатуры;
• введите направление оптимизации ЦФ, щелкнув один раз левой клавишей мыши по селекторной кнопке "максимальному значению".
Ввод ограничений и граничных условий
Задание ячеек переменных
В окно "Поиск решения" в поле "Изменяя ячейки" впишите адреса $B$3:$E$3. Необходимые адреса можно вносить в поле "Изменяя ячейки" и автоматически путем выделения мышью соответствующих ячеек переменных непосредственно в экранной форме.
Задание граничных условий для допустимых значений переменных
В нашем случае на значения переменных накладывается только граничное условие неотрицательности, то есть их нижняя граница должна быть равна нулю.
• Нажмите кнопку "Добавить", после чего появится окно
"Добавление ограничения".
• В поле "Ссылка на ячейку" введите адреса ячеек переменных $B$3:$E$3. Это можно сделать как с клавиатуры, так и путем выделения мышью всех ячеек переменных непосредственно в экранной форме.
• В поле знака откройте список предлагаемых знаков и выберите ?.
• В поле "Ограничение" введите адреса ячеек нижней границы значений переменных, то есть $B$4:$E$4. Их также можно ввести путем выделения мышью непосредственно в экранной форме.
Задание знаков ограничений ?, ?, =
• Нажмите кнопку "Добавить" в окне "Добавление ограничения".
• В поле "Ссылка на ячейку" введите адрес ячейки левой части конкретного ограничения, например $F$10. Это можно сделать как с клавиатуры, так и путем выделения мышью нужной ячейки непосредственно в экранной форме.
• В соответствии с условием задачи (1.1) выбрать в поле знака необходимый знак, например =
• В поле "Ограничение" введите адрес ячейки правой части рассматриваемого ограничения, например $H$10.
• Аналогично введите ограничения: $F$11>=$H$11, $F$12<=$H$12.
• Подтвердите ввод всех перечисленных выше условий нажатием кнопки OK.
Окно "Поиск решения" после ввода всех необходимых данных задачи (1.1) представлено на рис. 1.6.
Если при вводе условия задачи возникает необходимость в изменении или удалении внесенных ограничений или граничных условий, то это делают, нажав кнопки "Изменить" или "Удалить" (см. рис. 1.6).
Решение задачи
Установка параметров решения задачи
Задача запускается на решение в окне "Поиск решения". Но предварительно для установления конкретных параметров решения задач оптимизации определенного класса необходимо нажать кнопку "Параметры" и заполнить некоторые поля окна "Параметры поиска решения". экранный переменная двухиндексный целочисленный
Параметр "Максимальное время" служит для назначения времени (в секундах), выделяемого на решение задачи. В поле можно ввести время, не превышающее 32 767 секунд (более 9 часов).
Параметр "Предельное число итераций" служит для управления временем решения задачи путем ограничения числа промежуточных вычислений. В поле можно ввести количество итераций, не превышающее 32 767.
Параметр "Относительная погрешность" служит для задания точности, с которой определяется соответствие ячейки целевому значению или приближение к указанным границам. Поле должно содержать число из интервала от 0 до 1. Чем меньше количество десятичных знаков во введенном числе, тем ниже точность. Высокая точность увеличит время, которое требуется для того, чтобы сошелся процесс оптимизации.
Параметр "Допустимое отклонение" служит для задания допуска на отклонение от оптимального решения в целочисленных задачах. При указании большего допуска поиск решения заканчивается быстрее.
Параметр "Сходимость" применяется только при решении нелинейных задач.
Установка флажка "Линейная модель" обеспечивает ускорение поиска решения линейной задачи за счет применение симплекс-метода.
Подтвердите установленные параметры нажатием кнопки "OK".
Запуск задачи на решение
Запуск задачи на решение производится из окна "Поиск решения" путем нажатия кнопки "Выполнить".
После запуска на решение задачи ЛП на экране появляется окно "Результаты поиска решения" с одним из сообщений, представленных.
Иногда сообщения, представленные на свидетельствуют не о характере оптимального решения задачи, а о том, что при вводе условий задачи в Excel были допущены ошибки, не позволяющие Excel найти оптимальное решение, которое в действительности существует (см. ниже подразд. 1.3.5).
Если при заполнении полей окна "Поиск решения" были допущены ошибки, не позволяющие Excel применить симплекс-метод для решения задачи или довести ее решение до конца, то после запуска задачи на решение на экран будет выдано соответствующее сообщение с указанием причины, по которой решение не найдено. Иногда слишком малое значение параметра "Относительная погрешность" не позволяет найти оптимальное решение. Для исправления этой ситуации увеличивайте погрешность поразрядно, например от 0,000001 до 0,00001 и т.д.
В окне "Результаты поиска решения" представлены названия трех типов отчетов: "Результаты", "Устойчивость", "Пределы". Они необходимы при анализе полученного решения на чувствительность (см. ниже подразд. 3.3). Для получения же ответа (значений переменных, ЦФ и левых частей ограничений) прямо в экранной форме просто нажмите кнопку "OK". После этого в экранной форме появляется оптимальное решение задачи
Целочисленное программирование
Допустим, что к условию задачи (1.1) добавилось требование целочисленности значений всех переменных. В этом случае описанный выше процесс ввода условия задачи необходимо дополнить следующими шагами.
• В экранной форме укажите, на какие переменные накладывается требование целочисленности (этот шаг делается для наглядности восприятия условия задачи) (рис. 1.13).
• В окне "Поиск решения" (меню "Сервис">"Поиск решения"), нажмите кнопку "Добавить" и в появившемся окне "Добавление ограничений" введите ограничения следующим образом (рис. 1.14):
? в поле "Ссылка на ячейку" введите адреса ячеек переменных задачи, то есть $B$3:$E$3;
? в поле ввода знака ограничения установите "целое";
? подтвердите ввод ограничения нажатием кнопки "OK".
Двухиндексные задачи ЛП
Двухиндексные задачи ЛП вводятся и решаются в Excel аналогично одноиндексным задачам. Специфика ввода условия двухиндексной задачи ЛП состоит лишь в удобстве матричного задания переменных задачи и коэффициентов ЦФ.
Рассмотрим решение двухиндексной задачи, суть которой заключается в оптимальной организации транспортных перевозок штучного товара со складов в магазины (табл. 1.2).
Таблица 1.2 Исходные данные транспортной задачи
Тарифы, руб./шт. |
1-й магазин |
2-й магазин |
3-й магазин |
Запасы, шт. |
|
1-й склад |
2 |
9 |
7 |
25 |
|
2-й склад |
1 |
0 |
5 |
50 |
|
3-й склад |
5 |
4 |
100 |
35 |
|
4-й склад |
2 |
3 |
6 |
75 |
|
Потребности, шт. |
45 |
90 |
50 |
Целевая функция и ограничения данной задачи имеют вид
L ( )X = 2x11 +9x12 +7x13 + x21 +5x23 +5x31 + 4x32 +100x33 + 2x41 +3x42 + 6x43 > min;
?x11 + x12 + x13 = 25,
??x21 + x22 + x23 = 50,
???x31 ++ xx3242 ++xx3343 ==3575,, (1.5) x41
??x11 + x21 + x31 = 45,
???xx1132 ++ xx2322 ++xx3332 ==5090,,
???xij ? 0,?xij ?целые (i =1,4; j =1,3) .
Экранные формы, задание переменных, целевой функции, ограничений и граничных условий двухиндексной задачи (1.5) и ее решение представлены (курсор в целевой ячейке F15)
Таблица 1.3 Формулы экранной формы задачи
Объект математической модели |
Выражение в Excel |
|
Переменные задачи |
C3:E6 |
|
Формула в целевой ячейке F15 |
=СУММПРОИЗВ(C3:E6;C12:E15) |
|
Ограничения по строкам в ячейках F3, F4, F5, F6 |
=СУММ(C3:E3)=СУММ(C4:E4)=СУММ(C5:E5)=СУММ(C6:E6) |
|
Ограничения по столбцам в ячейках С7, D7, E7 |
=СУММ(C3:C6)=СУММ(D3:D6) =СУММ(E3:E6) |
|
Суммарные запасы и потребности в ячейках H8, G9 |
=СУММ(H3:H6) =СУММ(C9:E9) |
Задачи с булевыми переменными
Частным случаем задач с целочисленными переменными являются задачи, в результате решения которых искомые переменные xj могут принимать только одно из двух значений: 0 или 1. Такие переменные в честь предложившего их английского математика Джорджа Буля называют булевыми. На представлена экранная форма с решением некоторой двухиндексной задачи с булевыми переменными.
Решение двухиндексной задачи с булевыми переменными
Помимо задания требования целочисленности (см. подразд. 1.3.2) при вводе условия задач с булевыми переменными необходимо:
• для наглядности восприятия ввести в экранную форму слово "булевы" в качестве характеристики переменных (см. рис.1.18);
• в окне "Поиск решения" добавить граничные условия, имеющие смысл ограничения значений переменных по их единичной верхней границе.
Добавление условия единичной верхней границы значений переменных двухиндексной задачи с булевыми переменными
Возможные ошибки при вводе условий задач ЛП
Если при решении задачи ЛП выдается сообщение о невозможности нахождения решения, то возможно, что причина заключается в ошибках ввода условия задачи в Excel. Поэтому, прежде чем делать вывод о принципиальной невозможности нахождения оптимального решения задачи, ответьте на вопросы из табл. 1.4.
1.4 Примерные вопросы на защите работы
1. Каковы основные этапы решения задач ЛП в MS Excel?
2. Каков вид и способы задания формул для целевой ячейки и ячеек левых частей ограничений?
3. В чем смысл использования символа $ в формулах MS Excel?
4. В чем различие использования в формулах MS Excel символов ";" и ":"?
5. Почему при вводе формул в ячейки ЦФ и левых частей ограничений в них отображаются нулевые значения?
6. Каким образом в MS Excel задается направление оптимизации ЦФ?
7. Какие ячейки экранной формы выполняют иллюстративную функцию, а какие необходимы для решения задачи?
8. Как наглядно отобразить в экранной форме ячейки, используемые в конкретной формуле, с целью проверки ее правильности?
9. Поясните общий порядок работы с окном "Поиск решения".
10. Каким образом можно изменять, добавлять, удалять ограничения в окне "Поиск решения"?
11. Какие сообщения выдаются в MS Excel в случаях: успешного решения задачи ЛП; несовместности системы ограничений задачи; неограниченности
1. Объясните смысл параметров, задаваемых в окне "Параметры поиска решения".
2. Каковы особенности решения в MS Excel целочисленных задач ЛП?
3. Каковы особенности решения в MS Excel двухиндексных задач ЛП?
4. Каковы особенности решения в MS Excel задач ЛП с булевыми переменными?
1.5 Варианты
Используя MS Excel, найти решение для модели ЛП, соответствующей заданному варианту (табл. 1.5).
Таблица 1.5 Варианты задач к лабораторной работе № 1
№ варианта |
Математическая модель |
|
1 |
L(X) = 5x1+ 7x2 ?6x3 +9x4 +8x5 > max; ?0,7x 1+ 0,9x2 +1,5x3 + 2,3x4 +1,8x5 ? 50000, ??0,4x 1+1,1x2 ?0,5x3 +1,3x4 ? 2,8x5 ? 32000,?0,5x 1+ 1,8x3 + 0,7x4 + 2x5 ? 40000, ??2,2x 1?1,4x2 ?0,8x3 + 0,9x4 =15000, ???xj ? 0 (j=1,5) . |
|
2 |
L(X) = x1+ 4x3 + 8x4 ?12x5 > min;?x 1+ 9x2 + 2x3 ? 4x4 = 250,??0,4x1+ x2 ? 5x3 + 3x4 + 8x5 ? 460,?0,5x1+ 10x2 - 8x3 + 6x4 + 2x5 ?190,?11x2 ? 8,5x3 + 3x4 + 2x5 = 210, ???x j ? 0 (j=1,5). |
|
3 |
L(X) =?45x1+ 65x2 + 2x4 ? 3x5 > max;?15x 1+18x2 + 34x4 ? 22x5 = 56,??2x1+ 7x3 ? 4x4 + 3x5 ? 91,?0,2x 1+ 0,8x2 +1,5x3 + 0,9x4 + 4x5 ? 26,??1,8x1? 42x2 + 6,4x3 + 3x5 =15, ???x j ? 0 (j =1,5) . |
Размещено на Allbest.ru
Подобные документы
Особенности решения задач линейного программирования (ЛП) в табличном редакторе Microsoft Excel. Создание экранной формы для ввода условия задачи. Ограничения и граничные условия, перенесение зависимостей из математической модели в экранную форму.
лабораторная работа [160,5 K], добавлен 26.05.2015Пакет Microsoft Office. Электронная таблица MS Excel. Создание экранной формы и ввод данных. Формулы и функции. Пояснение пользовательских функций MS Excel. Физическая постановка задач. Задание граничных условий для допустимых значений переменных.
курсовая работа [3,4 M], добавлен 07.06.2015Теоретическая основа линейного программирования. Задачи линейного программирования, методы решения. Анализ оптимального решения. Решение одноиндексной задачи линейного программирования. Постановка задачи и ввод данных. Построение модели и этапы решения.
курсовая работа [132,0 K], добавлен 09.12.2008Анализ метода линейного программирования для решения оптимизационных управленческих задач. Графический метод решения задачи линейного программирования. Проверка оптимального решения в среде MS Excel с использованием программной надстройки "Поиск решения".
курсовая работа [2,2 M], добавлен 29.05.2015Изучение и укрепление на практике всех моментов графического метода решения задач линейного программирования о производстве журналов "Автомеханик" и "Инструмент". Построение математической модели. Решение задачи с помощью электронной таблицы Excel.
курсовая работа [663,9 K], добавлен 10.06.2014Алгоритм решения задач линейного программирования симплекс-методом. Построение математической модели задачи линейного программирования. Решение задачи линейного программирования в Excel. Нахождение прибыли и оптимального плана выпуска продукции.
курсовая работа [1,1 M], добавлен 21.03.2012Краткие сведения об электронных таблицах MS Excel. Решение задачи линейного программирования. Решение с помощью средств Microsoft Excel экономической оптимизационной задачи, на примере "транспортной задачи". Особенности оформления документа MS Word.
курсовая работа [1,1 M], добавлен 27.08.2012Графическое решение задач. Составление математической модели. Определение максимального значения целевой функции. Решение симплексным методом с искусственным базисом канонической задачи линейного программирования. Проверка оптимальности решения.
контрольная работа [191,1 K], добавлен 05.04.2016Методы решения задач линейного программирования: планирования производства, составления рациона, задачи о раскрое материалов и транспортной. Разработка экономико-математической модели и решение задачи с использованием компьютерного моделирования.
курсовая работа [607,2 K], добавлен 13.03.2015Сущность задач оптимизации и методы их решения с ориентацией на современные средства компьютерной техники. Область допустимых решений. Структура оптимизационной модели. Проверка правильности нахождения точек координат методом половинного деления.
курсовая работа [2,4 M], добавлен 25.04.2015