Линейное программирвание

Автор: Пользователь скрыл имя, 24 Января 2012 в 20:58, контрольная работа

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

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

Содержание

ВВЕДЕНИЕ

1. Геометрический метод решения задач ЛП

2. Симплекс-метод

2.1 Идея симплекс-метода

2.2 Реализация симплекс-метода на примере

2.3 Табличная реализация простого симплекс-метода

ЗАКЛЮЧЕНИЕ

СПИСОК ИСПОЛЬЗОВАННОЙ ЛИТЕРАТУРЫ

Работа содержит 1 файл

Документ Microsoft Office Word (4).docx

— 171.05 Кб (Скачать)

  = < сБ, A> – c= 1∙(-1) + 0∙5 + 2∙1 – 4= -3,

  = < сБ, A> – c= 1∙0 + 0∙0 + 2∙1 – 2= 0.

  Так как оценка < 0, то базисный план xне оптимален. Заметим, что симплексные оценки, соответствующие базисным переменным, всегда равны нулю, так что достаточно проверять только небазисные оценки.  

2.2 Реализация симплекс-метода  на примере

  Продемонстрируем  применение симплекс-метода на примере. Рассмотрим каноническую задачу ЛП

      f(x) x12x+xx4 max (2.2)
      x12x2+ x4, (2.3)
      x+2x+ x12, (2.4)
      x≥ 0, j = 1,2,3,4. (2.5)

  Матрица условий = (A1A2A3A4), где

        

  Целевой вектор =(c1, c2, c3, c4) = (1, 2, 0, 0); вектор правых частей b=(b1, b2) = (4, 12).

  Шаг 0. Нахождение начальной угловой точки (базисного плана).

  Задача  имеет предпочтительный вид, так  как правые части уравнений положительны, а столбцы матрицы условий A3Aобразуют единичную подматрицу. Значит начальная базисная матрица  (A3A4); xи x– базисные переменные, xи xнебазисные переменные, cБ = (c3, c4= = (00).

  Начальный базисный план имеет вид x(0, 0, x3x4) = (0, 0, 4, 12); f(xo) = 0.

  Шаг 1. Проверка базисного плана на оптимальность.

  Подсчитаем  симплексные оценки для небазисных переменных по формуле (5.1)  

  D= < cБ, A> – c0 ·(–1) 0 ·3 – 1 = –1.

  D= < cБ, A> – c0 ·2 + 0 · 2 – 2 = –2.

  Так как оценки отрицательны, то план x – не оптимален. Будем искать новый базисный план (смежную угловую точку) с большим значением целевой функции.

  Шаг 2. Нахождение переменной вводимой в базис.

  Целевую функцию можно увеличить, если ввести в состав базисных переменных (сделать  положительной) одну из небазисных переменных xили x2, поскольку обе оценки D< 0. Обычно в состав базисных вводят небазисную переменную с наибольшей по модулю отрицательной оценкой, поэтому будем вводить в базис переменную x2.

  Шаг 3. Определение переменной выводимой из базиса.

  После ввода в базис переменной xновый план будет иметь вид   

  x' = (0, x2, x3x4).

  Этот  план не является базисным, так как  он содержит только одну нулевую координату, значит надо сделать нулевой (исключить  из базиса) одну из переменных xили x4. Подставим координаты плана x' = (0, x2, x3x4) в ограничения задачи. Получим

 

  2x2+ x4,

  2xx= 12.

  Выразим отсюда базисные переменные xи xчерез переменную x2вводимую в базис.

  x= 4 – 2x2, (2.6)
  x= 12 – 2x2. (2.7)

  Так переменные xи xдолжны быть неотрицательны, получим систему неравенств

  4 – 2x≥ 0, (2.8)
  12 – 2x≥ 0. (2.9)

  Чем больше значение x2тем больше возрастает целевая функция. Найдем максимальное значение новой базисной переменной, не нарушающее ограничения задачи, то есть удовлетворяющее условиям (2.8), (2.9).

  Перепишем последние неравенства в виде

  2x≤ 4,

  2x≤ 12,

  откуда  максимальное значение x= min { 4/2, 12/2 } = 2. Подставляя это значение в выражения (2.6), (2.7) для xи x4, получаем x= 0. Следовательно xвыводится из базиса

  Шаг 4. Определение координат нового базисного плана.

  Новый базисный план (смежная угловая точка) имеет вид

  x' = (0, x2, 0, x4)

  Базис этой точки состоит из столбцов Aи A4так что  = (A2, A4). Этот базис не является единичным, так как вектор A= (2,2), и следовательно задача (2.2)–(2.5) не имеет предпочтительного вида относительно нового базиса. Преобразуем условия задачи (2.3), (2.4) таким образом, чтобы она приняла предпочтительный вид относительно новых базисных переменных x2, x4то есть чтобы переменная xвходила в первое уравнение с коэффициентом, равным единице, и не присутствовала во втором уравнении. Перепишем уравнения задачи

  – x1+ 2 x2x= 4, (p1)

  3x+2 xx= 12. (p2)

  Поделим первое уравнение на коэффициент  при x2. Получим новое уравнение  = p/ 2, эквивалентное исходному 

  – 1/2 x1x2+ 1/2 x= 2. ( )

  Используем  это уравнение, которое назовем  разрешающим, для исключения переменной x2из второго уравнения. Для этого надо уравнение   умножить на 2 и вычесть из p2.Получим   = p–   = p– p1:

  x– xx= 8. ( )

  В итоге получили новое "предпочтительное" представление исходной задачи относительно новых базисных переменных x2x4:   

  f(x) = x+ 2 x+ 0 x+ 0 x4 max®

  – 1/2 x1+ x2+ 1/2 x= 2 ( )

  x– xx= 8 ( )

  x³ 0, j = 1,2,3,4

 

  Подставляя  сюда представление нового базисного  плана x(0, x2, 0, x4), сразу найдем его координаты, так как значения базисных переменных равны правым частям уравнений   

  x' = (0, 2, 0, 8); f(x1)=4.

  На  этом завершается первая итерация простого симплекс-метода. Далее процесс решения  задачи продолжается с шага 1, состоящем  в проверке найденного плана на оптимальность. Решение заканчивается тогда, когда  все симплексные оценки текущего базисного плана окажутся неотрицательными.

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

2.3 Табличная реализация  простого симплекс-метода

  Табличную реализацию продемонстрируем на том  же примере (2.2)–(2.5).

  Шаг 0. Решение начинается с построения начальной симплекс-таблицы. Сначала заполняется правая часть таблицы с третьей колонки. В двух верхних строках записываются имена переменных задачи (x1,...,x4) и коэффициенты целевой функции при этих переменных. Ниже записываются коэффициенты уравнений – элементы матрицы условийА, так что под переменной xрасполагается столбец A1, под переменной x– столбец Aи т.д. В правый столбец заносятся правые части ограничений (числа b> 0).

  Затем находим столбцы матрицы условий, образующие единичный базис –  в нашем примере это Aи A– и соответствующие им базисные переменные x3xзаписываем во вторую колонку. Наконец, в первом столбце записываем коэффициенты целевой функции при базисных переменных.

 

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

  СБ Базисные  переменные   с1=1   с2=2   с3=0   с4=0   Значения  базисных перем. (xБ=b)
  x1   x2   x3   4
  c3=0   x3   a11=-1   a12=2   a13=1   a14=0   b1=4
  c4=0   x4   a21=3   a22=2   a23=0   a24=1   b2=12
  Строка  оценок Dj   D1= -1   D2= -2   D3= 0   D4= 0   f(x)= 0

  Так как задача имеет предпочтительный вид, то значения базисных переменных равны правым частям уравнений, расположенным  в последнем столбце. Поскольку  небазисные переменные равны нулю, то начальный базисный план равен   

  x= (0, 0, x3x4) = (0, 0, 4, 12).  

  Шаг 1. Для проверки плана xна оптимальность подсчитаем симплексные оценки для небазисных переменных xи xпо формуле    

  Dj=< cБ, A> – cj.

  D= < cБ, A> – c0 ·(–1) 0 ·3 – 1 = –1.

  При табличной реализации для подсчета оценки Dнадо найти сумму произведений элементов первого столбца (cБ) на соответствующие элементы столбца Aпри небазисной переменной x1. Аналогично подсчитывается оценка D2как скалярное произведение первого столбца (cБ) на столбец при переменной x2.   

  D= < cБ, A> – c0 ·2 + 0 · 2 – 2 = –2.

  Симплексные оценки записываются в последней  строке симплекс-таблицы, которая называется дельта-строкой. При этом заполняются  не только клетки при небазисных переменных, но и базисные клетки. Легко проверить, что для базисных единичных столбцов матрицы условий симплексные  оценки равны нулю. В последней  клетке строки оценок записываем значение целевой функции в точке xoЗаметим, что, так как небазисные координаты базисного плана равны нулю, то подсчет целевой функции удобно производить по формуле   

  f(x)= < cБxБ >,

  перемножая  скалярно первый и последний столбцы  таблицы. 

  Так как среди оценок Dесть отрицательныето план x– не оптимальный, и надо найти новый базисный план, заменив одну из базисных переменных на новую из числа небазисных.

  Шаг 2. Поскольку обе оценки Dи D< 0, то в базис можно включить любую из переменных x1, x2. Введем в базис переменную с наибольшей по модулю отрицательной оценкой, то есть x2.

Информация о работе Линейное программирвание