Алгоритм решения задач симплексным методом

Автор работы: Пользователь скрыл имя, 19 Июня 2014 в 14:45, курсовая работа

Описание работы

В данной курсовой работе будет рассмотрен алгоритм решения задач с применением симплексного метода.
Перед нами стоит несколько задач: введение понятия «симплексный метод», обозначение условий применения данного метода на практике, особенности решения, а также алгоритм решения задач различными способами (графический, алгоритмический, матричный) и предоставление практического решения реальной производственной задачи.

Содержание работы

Введение………………………………………………………………………………..3
1 Описание симплексного метода..…………...……………………………...……….4
2 Алгоритм решения задач симплексным методом……………………...…………..9
2.1 Графический метод……………………………………………………………….16
2.2 Табличный симплекс – метод……………………………………………….…...21
2.3 Алгоритм метода искусственного базиса………………...…………….……….25
2.4 Двойственный симплекс-метод………………..………………………………...26
3 Решение реальной производственной задачи…………………………………….28
3.1 Постановка задачи………………………………………………………………..28
3.2 Решение задачи…………………………………………………………………...28
Заключение……………………………………………………………………………38
Список используемой литературы…………………………………………………..40

Файлы: 1 файл

Курсовой по методам оптимизации.doc

— 629.00 Кб (Скачать файл)

Содержание

 

Введение………………………………………………………………………………..3                                                                                                                                                                                                                                                                                                                                                  

1 Описание симплексного метода..…………...……………………………...……….4

2 Алгоритм решения задач симплексным методом……………………...…………..9

2.1 Графический метод……………………………………………………………….16

2.2 Табличный симплекс – метод……………………………………………….…...21

2.3 Алгоритм метода искусственного базиса………………...…………….……….25

2.4 Двойственный симплекс-метод………………..………………………………...26

3 Решение реальной производственной задачи…………………………………….28

3.1 Постановка задачи………………………………………………………………..28

3.2 Решение задачи…………………………………………………………………...28

Заключение……………………………………………………………………………38

Список используемой литературы…………………………………………………..40

 

Введение

Многие задачи, с которыми приходится иметь дело в повседневной практике, являются многовариантными. В условиях рыночных отношений среди множества возможных вариантов приходится отыскивать наилучшие - с учетом ограничений, налагаемых на природные, экономические и технологические возможности. В связи с этим возникла необходимость применять для анализа и синтеза экономических ситуаций и систем математические методы и современную вычислительную технику.

Методы и модели линейного программирования широко применяются при оптимизации процессов во всех отраслях народного хозяйства: при разработке производственной программы предприятия, распределении ее по исполнителям, при размещении заказов между исполнителями и по временным интервалам, при определении наилучшего ассортимента выпускаемой продукции, в задачах перспективного, текущего и оперативного планирования и управления, при планировании грузопотоков, определении плана товарооборота и его распределении, в задачах развития и размещения производительных сил, баз и складов систем обращения материальных ресурсов и т. д. Особенно широкое применение методы и модели линейного программирования получили при решении задач экономии ресурсов (выбор ресурсосберегающих технологий, составление смесей, раскрой материалов), производственно-транспортных и других задач.

В данной курсовой работе будет рассмотрен алгоритм решения задач с применением симплексного метода.

Перед нами стоит несколько задач: введение понятия «симплексный метод», обозначение условий применения данного метода на практике, особенности решения, а также алгоритм решения задач различными способами (графический, алгоритмический, матричный) и предоставление практического решения реальной производственной задачи.

 

1 Описание симплексного метода

 

Симплекс - выпуклый многоугольник в n-мерном пространстве с n + 1 вершинами, не лежащими в одной гиперплоскости. Симплексы выделены в отдельный класс потому, что в n-мерном пространстве n точек всегда лежат в одной гиперплоскости(гиперплоскость делит пространство на два полупространства). Так что симплекс - это простейший многоугольник, содержащий некоторый объем n-мерного пространства.

Симплексный метод решения задач линейного программирования (симплекс-метод)1 - вычислительная процедура, основанная на принципе последовательного улучшения решений - перехода от одной базисной точки к другой, для которой значение целевой функции больше (эти операции фиксируются в симплексной таблице).

Задача линейного программирования (далее ЛП) состоит в необходимости максимизировать или минимизировать некоторый линейный функционал на многомерном пространстве при заданных линейных ограничениях.

Исходя из этого, симплекс-метод можно представить как алгоритм решения оптимизационной задачи линейного программирования путём перебора вершин выпуклого многогранника в многомерном пространстве. Также симплексным методом является вычислительная процедура, основанная на принципе последовательного улучшения решений при переходе от одной базисной точки (базисного решения) к другой. При этом значение целевой функции улучшается.

Базисным решением является одно из допустимых решений, находящихся в вершинах области допустимых значений. Проверяя на оптимальность вершину за вершиной симплекса, можно прийти к искомому оптимуму. Именно на этом принципе основан симплекс-метод.

В графической интерпретации симплекс-метода выбирается одна из вершин многогранника, после чего начинается движение по его ребрам от вершины к вершине в сторону увеличения значения функционала. Когда переход по ребру из текущей вершины в другую вершину с более высоким значением функционала невозможен, считается, что оптимальное значение найдено.

Данный метод является методом целенаправленного перебора опорных решений задачи линейного программирования. Он позволяет за конечное число шагов либо найти оптимальное решение, либо установить, что оптимальное решение отсутствует.

При решении задач линейного программирования все ограничения, имеющие вид неравенств, преобразуют в равенство путем:

1) Добавления неотрицательной остаточной переменной в левую часть неравенства вида « ≤ ».

2) Вычитания неотрицательной избыточной переменной из левой части неравенств вида « ≤ ».

Избыточные и достаточные переменные называют свободными.

Кроме того, все элементы правой части bi делают неотрицательными, либо умножая для этого i-ое уравнение на -1, если bi < 0, либо используя эквивалентность следующих отношений:

                                           (1.1)

Запишем целевую функцию:

F(X) =c1x1+c2x2+...+cnxn => max,                                                                       (1.2)

Где F(X) – целевая функция.

        ci – коэффициенты при переменных.

        xn – базисные переменные.

Система ограничений и условие неотрицательности будут выглядеть следующим образом:

 

a11x1 + a12x2 + . . . + a1nxn ≤ b1


a21x1 + a22x2 + . . . + a2nxn ≤ b2

. . . . . . . . . . . . . . . . . . . . . . . . .                                                                            (1.3)

am1x1 + am2x2 + . . . + amnxn ≤ bm                                                                           

 

xj ≥ 0, (j = 1, 2, . . . n)                                                                                         (1.4)                                                     

 

 

 

Запишем представленную систему ограничений в канонической форме:


a11 x 1+a12 x 2+...+a1n x n = b1

a21 x 1+a22 x 2+...+a2n x n = b2                                                                         (1.5)

. . . . . . . . . . . . . . . . . . . . .

am1 x 1+am2 x 2+...+amn x n = bm

 

Пусть A = (Аij) — матрица m*n, B = (b1, … , bm)T — вектор-стоблец,                  C = (c1, … , cn) — вектор-строка. Если A = (a1, … , am) и A = (b1, … , bm), то под неравенством A ≥ B будем понимать m неравенств ai ≥ bi (i = 1, … , m).

Используя матричные операции, запишем стандартную и каноническую задачу ЛП в матричном виде:

C∙X→max         Целевая функция                                                               

A∙X≤B               Система ограничений                                                           (1.6)

X≥0                  Условие неотрицательности

 

Матрица A = (aij) (i = 1, … , m; j = 1, 2, . . . n), составленная из коэффициентов системы (1.5), называется симплекс-таблицей.

Таблица 1.1.  Начальная симплекс-таблица.

Базисные Переменные

Свободные Переменные

X1

.......

Xi

.......

Xm

X1

b1

1

.......

0

.......

0

X2

b2

0

.......

0

.......

0

.....

.....

.....

.....

.....

.....

.....

Xi

bi

0

.......

1

.......

0

.....

.....

.....

.....

.....

.....

.....

Xm

bm

0

.......

0

.......

1

F(X)

C0

0

.......

0

.......

0


 

Решение Х системы уравнений, в котором все небазисные переменные равны нулю, называется базисным решением. Если все компоненты базисного решения неотрицательны, то оно называется допустимым базисным решением, или опорным планом. При этом сама база также называется допустимой.

Переход от текущей базы к соседней называется итерацией.

Алгоритм симплекс-метода:

  1. Определить число и состав базисных и свободных переменных.
  2. Выразить базисные переменные через свободные переменные.
  3. Выразить целевую функцию через свободные переменные.
  4. Построить начальную симплекс-таблицу.
  5. Проверить решение на оптимальность: если в F-строке (кроме С0) все Сj=0, то получено оптимальное решение: X=(B1,...,Bm,0,...,0), F=C0. Если же существует Cj<0, то решение можно улучшить, но предварительно надо проверить факт существования решения.
  6. Проверить существование решения: рассмотрим все столбцы, у которых Сj<0, если существует хотя бы один столбец, у которого все коэффициенты Aij<0, то задача решения не имеет, т.к. множество допустимых решений D не ограничено и целевая функция неограниченно возрастает. Если таких столбцов нет, то переходим к следующему этапу. Выбрать свободную переменную, которую надо ввести в базис (выбор разрешающего столбца): это столбец с минимальным значением Сj (пусть это k-й столбец). Выбрать базисную переменную, которую надо вывести из базиса (выбор разрешающей строки). Рассмотрим k-й столбец и все его элементы, которые больше нуля, т.е. Aik>0. Для всех этих элементов находим отношение Bi/Aik и выбираем строку, которая соответствует минимальному значению этого отношения (пусть это i-я строка). Соответствующая i-я переменная Xi выводится из базиса, при нескольких одинаковых отношениях берем любую строку. Элемент Aik называется разрешающим элементом.
  7. Пересчитать симплекс-таблицу.
  • составляем новую симплекс-таблицу, заменив в составе базисных переменных Xi на Xk;
  • заполняем сначала новую k-ю строку, записывая в нее элементы старой     i-ой строки, поделенные на разрешающий элемент;
  • после заполнения k-ой строки заполняем оставшиеся строки. Для этого k-ю строку умножаем последовательно на такие числа, чтобы после сложения ее с каждой строкой старой таблицы в k-ом столбце получить везде ноль (кроме единицы в k-ой строке).
  1. После заполнения новой симплекс-таблицы алгоритм возвращается к 5-му пункту.

Конец работы алгоритма:

    • либо когда в F-строке все коэффициенты (кроме С0) будут больше нуля, тогда получаем оптимальное решение;
    • либо когда существует столбец, у которого Cj<<0 и все коэффициенты Aij<<0, в этом случае решения не существует.

 

 

2 Алгоритм решения задач симплексным методом

 

Формализованный алгоритм симплекс-метода состоит из двух основных этапов:

1) построение опорного плана;

2) построение оптимального плана.

Алгоритм симплекс-метода рассмотрим на примере реальной задачи.

Пусть предприятие может изготавливать изделия четырех видов: U1, U2, U3, U4. Для изготовления каждого изделия требуется определенный вид оборудования. Известно, сколько времени требуется на изготовление каждого изделия на каждом оборудовании и какая прибыль может быть получена при реализации каждого изделия. Требуется так распределить изделия по видам оборудования, чтобы предприятие имело максимальную прибыль.

Таблица 2.1. Распределение изделий по видам оборудования.

 

U 1

U2

U3

U4

bj

b1

3

5

2

7

15

b2

4

3

3

5

9

b3

5

6

4

8

8

сj

40

50

30

20

 

Информация о работе Алгоритм решения задач симплексным методом