Автор работы: Пользователь скрыл имя, 25 Марта 2011 в 18:00, курсовая работа
Потенциальная возможность математического моделирования любых экономических объектов и процессов не означает, разумеется, ее успешной осуществимости при данном уровне экономических и математических знаний, имеющейся конкретной информации и вычислительной технике. И хотя нельзя указать абсолютные границы математической формализуемости экономических проблем, всегда будут существовать еще неформализованные проблемы, а также ситуации, где математическое моделирование недостаточно эффективно.
В основу модифицированного симплекс - метода положены такие особенности линейной алгебры, которые позволяют в ходе решения задачи работать с частью матрицы ограничений. Иногда метод называют методом обратной матрицы.
В процессе работы алгоритма происходит спонтанное обращение матрицы ограничений по частям, соответствующим текущим базисным векторам. Указанная способность делает весьма привлекательной машинную реализацию вычислений вследствие экономии памяти под промежуточные переменные и значительного сокращения времени счёта. Хорош для ситуаций, когда число переменных n значительно превышает число ограничений m.
В
целом, метод отражает традиционные
черты общего подхода к решению
задач линейного
Особенности заключаются в наличии двух таблиц - основной и вспомогательной, порядке их заполнения и некоторой специфичности расчётных формул.
Каждой задаче линейного программирования можно определенным образом сопоставить некоторую другую задачу, называемую двойственной или сопряженной по отношению к исходной или прямой задаче. Сопоставляя формы записи прямой и двойственной задач, можно установить между ними следующие взаимосвязи:
1. если прямая задача является задачей максимизации, то двойственная будет задачей минимизации, и наоборот;
2.
коэффициенты целевой функции
прямой задачи становятся
3.
свободные члены ограничений
прямой задачи становятся
4.
матрица ограничений
5.
знаки неравенств в
6.
число ограничений прямой
Отыскание решения задачи двойственным симплекс-методом включает в себя следующие этапы:
1. Находят псевдоплан задачи.
2. Проверяют этот псевдоплан на оптимальность. Если псевдоплан оптимален, то найдено решение задачи. В противном случае либо устанавливают неразрешимость задачи, либо переходят к новому псевдоплану.
3.
Выбирают разрешающую строку
с помощью определения
4. Находят новый псевдоплан и повторяют все действия начиная со второго этапа.
Двойственный
симплексный метод называют также
методом последовательного
Задача целочисленного программирования формулируется так же, как и задача линейного программирования, но включается дополнительное требование, состоящее в том, что значения переменных, составляющих оптимальное решение, должны быть целыми неотрицательными числами.
Метод решения таких задач, предложенный Гомори, основан на симплексном методе и состоит в следующем. Симплексным методом находится оптимальный план задачи без учета условия целочисленности. Если оптимальный план целочисленный, то вычисления заканчивают; если же оптимальный план содержит хотя бы одну дробную компоненту Xi, то накладывают дополнительное ограничение, учитывающее целочисленность компонент плана, и вычисления симплексным методом продолжают до тех пор, пока либо будет найден целочисленный оптимальный план, либо доказано, что задача не имеет целочисленных оптимальных планов.
Особенно
широкое распространение
Необходимым условием постановки задачи линейного программирования являются ограничения на наличие ресурсов, величину спроса, производственную мощность предприятия и другие производственные факторы.
Сущность линейного программирования состоит в нахождении точек наибольшего или наименьшего значения некоторой функции при определенном наборе ограничений, налагаемых на аргументы и образующих систему ограничений, которая имеет, как правило, бесконечное множество решений. Каждая совокупность значений переменных, которые удовлетворяют системе ограничений, называется допустимым планом задачи линейного программирования. Функция F, максимум или минимум которой определяется, называется целевой функцией задачи. Допустимый план, на котором достигается максимум или минимум функции, называется оптимальным планом задачи.
Методы, с помощью которых решаются задачи линейного программирования подразделяются на универсальные и специальные.
Линейное
программирование – наиболее разработанный
и широко применяемый раздел математического
программирования.
1.4
Алгоритм симплекс
метода
Симплексный метод решения задач линейного программирования – вычислительная процедура, основанная на принципе последовательного улучшения решений – перехода от одной базисной точки к другой, при котором на каждом шаге значение целевой функции улучшается до тех пор, пока не будет достигнут оптимум.
Симплекс-метод был разработан и впервые применен для решения задач в 1947 г. американским математиком Дж. Данцигом.
Симплекс-метод является основным в линейном программировании. Доказано, что если оптимальное решение существует, то оно обязательно будет найдено через конечное число шагов (за исключением т. н. вырожденной задачи, при которой возможно явление “зацикливания”, т. е. многократного возврата к одному и тому же положению). Название метод получил от термина “n-мерный симплекс”. Геометрическая интерпретация метода состоит в последовательном движении по вершинам симплекса.
Процесс применения симплексного метода предполагает реализацию трех его основных элементов:
1)
способ определения какого-
2) правило перехода к лучшему решению;
3)
критерий проверки
Симплексный
метод включает в себя ряд этапов
и может быть сформулирован в
виде четкого алгоритма. Это позволяет
успешно программировать и
Алгоритм симплекс-метода позволяет также установить, является ли задача линейного программирования разрешимой.
Алгоритм:
-
Исходная модель задачи
-
Заполняется симплексная
- Задача решается до тех пор пока:
а) все относительные оценки неотрицательны в этом случае задача уже решена;
б) среди относительных оценок соответствующих исходным переменным есть 0, задача имеет бесконечное множество решений;
в) среди относительных оценок нет отрицательных чисел, но в базисе есть искусственные переменные (задача не имеет решений);
г) среди относительных оценок есть отрицательные (задача еще не решена, переход к следующей операции).
- Переход к следующей итерации начинается с выбора главного столбца. Он соответствует наибольшему по модулю относительной оценки (выбираются только отрицательные оценки). Поиск главной строки выполняется следующим образом: числа столбца В делятся на числа главного столбца (0 и отрицательные числа в главном столбце пропускаются) результаты деления записываются в столбец Q. Главная строка соответствует минимальному Q. На пересечении главного столбца и главной строки находится главный элемент таблицы.
-
Пересчет таблицы. Переход к
новой итерации. Вместо переменной
главной строки и ее
- Вычисляется значение целевой функции и относительных оценок.
- Переход
к проверке оптимальности
Таблица 1 – Пример симплексной таблицы к математической модели
№ табл. | cj
ci |
Базис | B | c1 | c2 | 0 | 0 | 0 | Q |
x1 | x2 | x3 | x4 | x5 | |||||
0 | 0 | x3 | b1 | a11 | a12 | 1 | 0 | 0 | |
0 | x4 | b2 | a21 | a22 | 0 | 1 | 0 | ||
0 | x5 | b3 | a31 | a32 | 0 | 0 | 1 | ||
Z | 0 | - c1 | - c2 | 0 | 0 | 0 |
Информация о работе Задача линейного программирования: нахождение оптимального плана