Пред.
След.
Макеты страниц
Распознанный текст, спецсимволы и формулы могут содержать ошибки, поэтому с корректным вариантом рекомендуем ознакомиться на отсканированных изображениях учебника выше Также, советуем воспользоваться поиском по сайту, мы уверены, что вы сможете найти больше информации по нужной Вам тематике ДЛЯ СТУДЕНТОВ И ШКОЛЬНИКОВ ЕСТЬ
ZADANIA.TO
12.5. СИМПЛЕКС-МЕТОД РЕШЕНИЯ ЗАДАЧИ ЛИНЕЙНОГО ПРОГРАММИРОВАНИЯ С МНОЖЕСТВОМ ПЕРЕМЕННЫХЕсли задача линейного программирования содержит более двух переменных, то ее решение требует применения некоторого алгебраического метода. Принцип, лежащий в основе решения задачи с множеством переменных, достаточно прост. Предполагается, что оптимальному решению соответствует одна из крайних точек допустимого множества. Следовательно, необходимо провести оценку значений целевой функции во всех крайних точках допустимого множества и выбрать ту из них, в которой достигается оптимальное значение целевой функции. Нами используются методы матричной алгебры и такой алгоритм перехода от одной крайней точки допустимого множества к другой, при котором переход осуществляется только в случае, когда значение целевой функции улучшается. Если оказывается, что некоторое базисное решение улучшить уже нельзя, то оно является оптимальным планом задачи. Этот алгоритм получил название симплекс-метода. Нет необходимости вдаваться в детали алгоритма симплекс-метода, поскольку для решения задач линейного программирования с множеством переменных используется, как правило, один из компьютерных пакетов прикладных программ, которые общедоступны и широко применяются для этих целей. Однако для более полной интерпретации и всесторонней оценки решения задачи линейного программирования, полученного с использованием пакета прикладных программ, с основными принципами этого метода полезно ознакомиться. В обычном симплекс-методе принимается предпосылка о максимизации целевой функции задачи линейного программирования в условиях системы ограничений со знаком Это означает, что при реализации данного алгоритма в качестве начальной крайней точки может быть выбрано начало координат. Поиск оптимального решения всегда начинается со значения целевой функции, равного нулю. Симплекс-метод можно применять также и в решении задач минимизации, и в решении задач, система ограничений которых содержит ограничения со знаком или уравнения. Эта процедура предусматривает введение в задачу искусственных, а также избыточных и остаточных переменных. Мы не будем подробно останавливаться на подобных усложнениях, поскольку обычно задачи линейного программирования решаются с помощью пакетов прикладных программ, в которых указанные переменные вводятся в модель автоматически. Базовую модель, с которой мы будем работать в дальнейшем, формально можно представить следующим образом: Максимизировать Здесь С - константы. Данная функция максимизируется в условиях системы
Данная система содержит Пример 12.8. Некоторая фирма производит два вида продуктов X и Y в условиях ограничений на три вида сырья: 1. Выпускается х единиц продукта X в неделю и у единиц продукта Y в неделю. 2. Максимизируется еженедельная прибыль Р (ф. ст.), где 3. Максимизация осуществляется в условиях ограничений:
4. Найти оптимальный ассортиментный набор и максимальную прибыль за неделю. Определить свободный запас каждого ресурса. Решение Графический метод. В каждое ограничение модели вводятся остаточные переменные
при ограничениях:
Изобразим систему ограничений графически (см. рис. 12.23) Точка с координатами
В качестве типичной линии уровня прибыли выберем прямую
Рис. 12.23. Задача линейного программирования для объемов выпуска продуктов X и Y в неделю Точка с координатами
Подставив это значение во второе уравнение системы, получим:
Оптимальным ассортиментным набором является производство 9 единиц продукта X и 11 единиц продукта Y в неделю. Таким образом, максимальная прибыль, получаемая за неделю, составит:
Сырье типа 1 и 3 используется полностью, однако существует свободный запас сырья типа 2, т.е.
следовательно, Решение Симплекс-метод. Представим коэффициенты, стоящие в левой части системы ограничений, в матричной форме. За обозначения столбцов примем переменные которым они соответствуют. Значения правой части ограничений запишем в отдельном столбце матрицы справа. За обозначения строк примем обозначения соответствующих переменных, которые являются базисными (имеющими ненулевые значения) переменными в начальной крайней точке (начале координат). Наконец введем в таблицу дополнительную строку, соответствующую коэффициентам целевой функции у. Существует несколько немного отличных друг от друга вариантов решения задачи симплекс-методом. В том из них, который излагается ниже требуется вводить коэффициенты целевой функции с отрицательным знаком. Полученная в результате применения данной процедуры матрица называется снмплекс-таблицей, а сама эта процедура представляет собой Шаг 1 в алгоритме симплекс-метода. Таблица 12.2. Первая симплекс-таблица (см. скан) Шаг 2. В строке коэффициентов целевой функции найдем наибольшее отрицательное значение Таблица 12.3. Первая симплекс-таблица с учетом отношений (см. скан) Шаг 3. Выберем среди полученных отношений наименьшее положительное отношение. В нашем случае оно равно 9. Соответствующая ему строка ведущей. Пересечение ведущего столбца и ведущей строки дает ведущий элемент 3, в приведенной выше табл. 12.3 он отмечен знаком Шаг 4. Разделим все элементы ведущей строки на ведущий элемент 3. Заменим все элементы ведущей строки на полученные новые значения (табл. 12.4). Обозначение ведущей строки Таблица 12 4. Вторая симплекс-таблица (см. скан) Шаг 5. Применив к строкам матрицы арифметические операции (строчные операции в матричной алгебре), приведем все остальные элементы ведущего столбца х к нулю. В качестве базиса в этих арифметических операциях должна использоваться только ведущая строка. Обозначим через Шаг 6. Шаги 2-5 повторяются до тех пор, пока не будет достигнута неотрицательность всех элементов в строке целевой функции. Таблица 12.5. Вторая симплекс-таблица с отношениями (см. скан) Таблица 12.6. Третья, итоговая, симплекс-таблица (см. скан) Теперь все элементы в строке целевой функции либо положительны, либо равны нулю, следовательно, представленное в данной таблице решение является оптимальным. Чтобы дать интерпретацию итоговой симплекс-таблице, обратим сначала внимание на значения ее крайних элементов. Таблица 12.7. Интерпретация итоговой симплекс-таблицы (см. скан) Базисными называются переменные, которые имеют ненулевые значения в крайней точке допустимого множества. Значения базисных переменных находятся в соответствующих строках столбца
а значение остаточной переменной для сырья 2 составило 8 кг в неделю. Все остальные переменные имеют нулевые значения, т.е. остаточные переменные ограничений 1 и найденным ранее. Элементы, стоящие на пересечении строки целевой функции и столбцов остаточных переменных, соответствуют, как показано в табл. 12.7, теневым ценам ресурсов. Теневая цена для ограничения 1, т.е. цена ресурса Ограничение 1, соответствующее сырью 1, имеет вид:
а соотношение
приводит к тому, что
Новое максимальное значение прибыли за неделю составит:
Увеличение прибыли на 33 пенса произошло в результате использования 1 кг ресурса Оставшиеся крайние значения итоговой таблицы — это элементы, лежащие на пересечении строки "целевая функция" и столбцов переменных задачи. В нашем примере значения, соответствующие столбцам х и у, равны нулю. Эти элементы были бы ненулевыми, если бы соответствующие переменные в оптимальном решении не являлись базисными. Например, если бы в оптимальном решении утверждалось, что следует производить только продукт X, переменная у была бы небазисной, т.е. выполнялось бы соотношение Предположим, что в результате решения данной задачи мы получили итоговую таблицу следующего вида: Таблица 12.8. Модификация итоговой таблицы
Оптимальный ассортиментный набор для этого решения — это выпуск только продукта X в количестве 9 единиц. Если по тем или иным причинам некоторое количество продукта У все же необходимо произвести, значение целевой функции уменьшится на 0,5 ф. ст., приходящихся на каждую производимую единицу продукта У.
|
1 |
Оглавление
|