КАТЕГОРИИ: Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748) |
Представление задачи линейного программирования в канонической форме
Линейного программирования Линейного программирования Стандартной задачей линейного программирования называют задачу, в которой требуется найти такие значения Х1, Х2, …, Хn, при которых функция цели принимает максимальное значение f(x) = ® max (4.8) и которые удовлетворяют ограничениям £ bi; (i = ), (4.9) Хj ³ 0; (j = ). (4.10) Каноническая (основная) задача Канонической задачей называется задача, в которой требуется найти такой набор переменных Х1, Х2, …, Хn, который позволяет максимизировать функцию цели f(x) = ® max (4.11) и удовлетворяет системе ограничений = bi; (i = ), (4.12) Хj ³ 0; (j = ). (4.13)
Пусть требуется найти неотрицательные значения переменных Х1, Х2, …, Хn, для которых функция цели принимает максимальное значение f(x) = C1 Х1 + C2Х2 + …+ CnХn ® max при ограничениях а11Х1 + а12Х2 + …+ а1nХn £ b1, а21Х1 + а22Х2 + …+ а2nХn £ b2, ……………………………….. аm1Х1 + аm2Х2 + …+ аmnХn £ bm, Хj ³ 0, (j = ).
Поскольку в ограничениях левая часть меньше, чем правая (или равна ей), чтобы перейти к строгому равенству, необходимо к левой части каждого неравенства добавить соответствующую переменную. Найти максимум функции цели f(x) = C1 Х1 + C2Х2 + …+ CnХn + …+ 0×Хn+1 + …+ 0×Хn+m ® max при ограничениях
а11Х1 + а12Х2 + …+ а1nХn + Хn+1 = b1, а21Х1 + а22Х2 + …+ а2nХn + Хn+2 = b2, ………………………………………………. аm1Х1 + аm2Х2 + …+ аmnХn + Хn+m = bm, Хj ³ 0, (j = ). Пример. Записать следующую задачу в канонической форме: f(x) = –X1 + 2X2 – X3 + X4® min, 3X1 – X2 + 2X3 + 2X4 £ 10, X1 + 2X2 + X3 – X4 ³ 8, 2X1 – X2 – X3 + X4 £ 6, –X1 + 3X2 + 5X3 – 3X4 = 15, Xj ³ 0, (j = 1 ¸ 4). Для записи задачи в канонической форме поменяем знаки у всех коэффициентов функции цели на противоположные. Тогда задача будет заключаться в нахождении максимума целевой функции. Для приведения ограничений – неравенств к системе уравнений необходимо приравнять левые и правые части ограничений путем введения дополнительных переменных. Если левая часть ограничения меньше, чем правая, необходимо добавить дополнительную переменную, если же левая часть ограничения больше, из нее следует вычесть некоторое, пока неизвестное, значение.
f(x) = Х1 – 2Х2 + Х3 – Х4 + 0×Х5 + 0×Х6 + 0×Х7 ® max, 3X1 – X2 + 2X3 + 2X4 + X5 = 10, X1 + 2X2 + X3 – X4 – X6 = 8, 2X1 – X2 – X3 + X4 + X7 = 6, –X1 + 3X2 + 5X3 – 3X4 = 15, Xj ³ 0.
Свойства задачи линейного программирования: 1. Множество планов задачи линейного программирования, если оно не пусто, образует выпуклый многогранник. Любая точка внутри области, ограниченной этим многогранником, является допустимым решением задачи. 2. В одной из вершин многогранника решений целевая функция принимает максимальное значение (при условии, что функция ограничена сверху на множестве планов). 3. Если максимальное значение функция принимает более, чем в одной вершине, то это же значение она принимает в любой точке, являющейся выпуклой линейной комбинацией данных вершин.
Геометрическая интерпретация задачи линейного программирования Рассмотрим следующую задачу: найти такие значения переменных Х1 и Х2, которые максимизируют функцию цели f(x) = C1 × Х1 + C2 × Х2 ® max (4.14) при выполнении ограничений аi1 × Х1 + аi2 × Х2 £ bi; (i = ); (4.15) условие неотрицательности Х1 ³ 0, Х2 ³ 0. (4.16) Каждое неравенство 2 и 3 системы ограничений геометрически представляет собой полуплоскость с граничными прямыми: аi1 × Х1 + аi2 × Х2 = bi (i = ),
- оси координат (решение получаем в 1 квадранте).
В том случае, если система неравенств 2 и 3 совместна, то область ее решений есть множество точек, принадлежащих всем указанным полуплоскостям. А так как множество точек пересечения данных полуплоскостей – выпуклое, то область допустимых решений задачи 1 – 3 есть выпуклое множество, которое называется многоугольником решений. Стороны этого многоугольника лежат на прямых, уравнения которых получают из исходной системы ограничений заменой знаков неравенств на знаки точных равенств. Таким образом, исходная задача линейного программирования состоит в нахождении такой точки многоугольника решений, в которой функция цели f(x) принимает максимальное значение. Эта точка существует тогда, когда многоугольник решений не пуст и функция цели ограничена сверху. При указанных условиях в одной из вершин многоугольника функция цели принимает максимальное значение. Для определения данной вершины строится вектор-нормаль с координатами – коэффициентами функции цели . Перпендикулярно вектору-нормали построим линию уровня C1 × Х1 + C2 × Х2 = h (где h – некоторое число, которое подбирается таким, чтобы эта линия уровня проходила через многоугольник решений). Будем передвигать линию уровня в направлении вектора–нормали до тех пор, пока она не дойдет до последней общей точки с многоугольником решений. Координаты этой точки и определяют оптимальный план – решение задачи. Координаты этой точки А находятся следующим образом: решается система уравнений, которые соответствуют линиям-ограничениям, на пересечении которых эта точка находится. Подставляя значения координат этой точки в функцию цели, получаем максимальное значение целевой функции. Для нахождения минимума функции цели линия уровня передвигается не в направлении вектора-нормали, а в противоположном направлении.
При нахождении решения задачи 4.14 – 4.16 возможны следующие случаи:
1. Единственное оптимальное решение – в точке А функция цели принимает максимальное значение
Х2
- линия уровня (f(х) ® max) С2 f(х) = 0 - область вектор- допустимых значений нормаль 0 С1 Х1 - линия уровня (f(х) = 0)
2. Множество точек на отрезке DВ – оптимальное решение Х2 линия уровня (f(х) ® min)
A
D
В 0 Х1
3. Функция цели не ограничена сверху на множестве допустимых решений Х2
- линия уровня (f(х)max = + ¥)
0 Х1 4. Система ограничений задачи несовместна. Условия противоречивы. Многоугольник решений пуст. Решения нет. Х2
Х1
Пример. Найти решение задачи графическим и аналитическим методами:
f(x) = 2X1 + X2 ® max, –2X1 + X2 £ 2, X1 + X2 £ 4, X1 – X2 £ 1, X1 ³ 0, X2 ³ 0.
Решение.
Построим прямые, уравнения которых получаем в результате замены в системе ограничений знаков неравенств на знаки точных равенств. Получаем уравнения прямых линий на плоскости. Для того, чтобы провести прямую линию, достаточно знать координаты двух точек. Проведем линию (1), соответствующую первому ограничению. Для этого присвоим переменной Х2 некоторое значение, например ноль, и определим значение переменной Х1, найдем координаты первой точки (-1; 0). Приравняв нулю переменную Х1, найдем значение переменной Х2 – координаты второй точки (0; 2). Для того, чтобы определить, с какой стороны от проведенной линии находится область допустимых значений, необходимо подставить в неравенство координаты какой-нибудь точки пространства, например начала координат (Х1 = 0, Х2 = 0). Полученное значение – ноль, меньше чем два (правая часть ограничения), а значит, точка начала координат принадлежит искомой полуплоскости. Повторим построения для всех остальных ограничений задачи и получим многоугольник решений ОDАВЕ. Построим вектор-нормаль, выходящий из начала координат в направлении точки с координатами – коэффициентами функции цели (Х1 = 2, Х2 = 1) или пропорциональными этим координатам (Х1 = 1, Х2 = 0,5). Линия уровня (соответствующая функции цели) строится перпендикулярно вектору-нормали или же функция цели приравнивается какому-либо числу, например f(x) = 2X1 + X2 = 2 и проводится соответствующая линия. Передвинем линию уровня в направлении, указанном вектором. В результате находим точку А, в которой целевая функция принимает максимальное значение. Находим координаты этой точки. Для этого решим систему уравнений, которые соответствуют прямым, на пересечении которых находится точка А: X1 + X2 = 4, X1 - X2 = 1. Проведем сложение двух уравнений, получим 2X1 = 5, откуда X1 = 2,5. Вычтем из первого уравнения второе, получим 2X2 = 3, откуда X2 = 1,5. Вычислим значение функции цели в точке А(2,5; 1,5) f(x)max = 2 × 2,5 + 1,5 = 6,5.
Двойственность в задачах линейного
Дата добавления: 2014-12-27; Просмотров: 526; Нарушение авторских прав?; Мы поможем в написании вашей работы! Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет |