Главная страница Случайная страница КАТЕГОРИИ: АвтомобилиАстрономияБиологияГеографияДом и садДругие языкиДругоеИнформатикаИсторияКультураЛитератураЛогикаМатематикаМедицинаМеталлургияМеханикаОбразованиеОхрана трудаПедагогикаПолитикаПравоПсихологияРелигияРиторикаСоциологияСпортСтроительствоТехнологияТуризмФизикаФилософияФинансыХимияЧерчениеЭкологияЭкономикаЭлектроника |
Общая постановка задачиСтр 1 из 2Следующая ⇒
Задача математического программирования (ЗМП). Общая постановка задачи В теории экстремума на независимые переменные x1, x2, …, хn не накладываются никакие дополнительные условия, т.е. не требуется, чтобы переменные удовлетворяли некоторым дополнительным ограничениям. Рассмотрим другую задачу. Найти максимум (минимум) функции y=f(x1, x2, …, хn), при условии, что независимые переменные x1, x2, …, хn удовлетворяют системе ограничений: g1(x1, x2, …, хn) ≤ b1, ………………………… gm(x1, x2, …, хn) ≤ bm, gm+1(x1, x2, …, хn) ≥ bm+1, ………………………… gk(x1, x2, …, хn) ≥ bk, (3.1) gk+1(x1, x2, …, хn) =bk+1, ………………………… gp(x1, x2, …, хn) =bp, x1, x2, …, хn ≥ 0. Функцию y=f(x1, x2, …, хn) принято называть целевой, т.к. её максимизация (минимизация) часто есть выражение какой-то цели, систему ограничений (3.1) – специальными ограничениями ЗМП, неравенства x1≥ 0, x≥ 02, …, хn≥ 0 – общими ограничениями ЗМП. Множество всех допустимых решений ЗМП (хj≥ 0, j= ) называется допустимым множеством этой задачи. Точка () называется оптимальным решением для функции двух переменных, если, во-первых, она есть допустимое решение этой ЗМП, а во-вторых, на этой точке целевая функция достигает максимума (минимума) среди всех точек, удовлетворяющих ограничениям (3.1), причём f ()≥ f(x1, x2) (в случае решения задачи на отыскание максимума), f () ≤ f(x1, x2) (в случае решения задачи на отыскание минимума). Если в ЗМП все функции f(x1, x2, …, хn), g i (x1, x2, …, хn) линейны, то имеем задачу линейного программирования (ЗЛП), если хотя бы одна из функций нелинейная, имеем задачу нелинейного программирования (ЗЛП). Рассмотрим ЗЛП. 2) ЗЛП и способы её решения. ЗЛП имеет вид F=c1x1+c2x2+…+cnxn+c0→ min(max). При этом переменные должны удовлетворять ограничениям: а11х1+ а12х2+…+а1nхn≤ b1 ………………………… аm1х1+ аm2х2+…+amnxn≤ bm аm+11х1+ аm+12х2+…+аm+1nхn≥ bm+1 ………………………… аk1х1+ аk2х2+…+аknхn≥ bk (3.2) аk1+1х1+ аk+12х2+…+аk+1nхn=bk+1 …………………………. аp1х1+аp2х2+…+аpnхn=bp x1, x2, …, хn ≥ 0. ЗЛП может быть записана в различных формах: Общий вид: найти минимум (максимум) целевой функции F при ограничениях (3.2) и условии неотрицательности переменных. Стандартный вид: найти минимум (максимум) целевой функции F и ограничениях, заданных в виде неравенств и добавлены условия о неотрицательности переменных. Канонический вид: вид, в котором нужно найти минимум (максимум) целевой функции F, где все ограничения заданы в виде равенств и есть условие неотрицательности переменных. Стандартную задачу можно привести к каноническому виду, путём введения дополнительных неотрицательных переменных. Т.е. свести к системе m линейных уравнений с n переменными. Любые m переменных системы m линейных уравнений с n переменными (m< n) называются основными (или базисными), если определитель матрицы коэффициентов при них отличен от нуля. Тогда остальные m-n переменных называются неосновными или (свободными). Базисным решением системы m линейных уравнений с n переменными называют решение, в котором все m-n неосновных переменных равны нулю. Для обоснования свойств ЗЛП и методов её решения, рассмотрим 2 вида записи канонической задачи. 1 вид – матричная форма записи: С=(c1, c2…cn, c0). Х= А= В= (3.3) F=CX→ min (max) AX=B, X≥ 0 2 вид – векторная форма записи: F=CX→ min (max) р1x1+р2x2+…+рnxn=р. Х≥ 0. р1= р2= … р n= . Для того чтобы рассмотреть теоретические основы метода линейного программирования, определим понятие выпуклого множества точек, дав ему определение в аналитической форме: Множество точек является выпуклым, если оно вместе с любыми своими двумя точками содержит их произвольную линейную комбинацию. Точка Х является выпуклой линейной комбинацией точек Х1, Х2, … Хn, если выполняются условия Х= α 1x1+α 2x2+…+α nxn, α j≥ 0, (j=1, …, n), . Теорема 1. Выпуклый линейный многогранник является выпуклой линейной комбинацией своих угловых точек. (Примем без доказательства). Теорема 2. Множество всех допустимых решений системы ограничений ЗЛП является выпуклым. □ Пусть Х1=(x , x , …, х ) и Х2=(x , x , …, х ) - два допустимых решения задачи (3.3), заданной в матричной форме. Тогда АХ1=В и АХ2=В. рассмотрим выпуклую линейную комбинацию решений Х1 и Х2, т.е. Х=α 1Х1+α 2Х2 при α 1 ≥ 0, α 2 ≥ 0 и α 1+α 2=1. Покажем, что она также является допустимым решением системы АХ=В. В самом деле, АХ=А(α 1Х1+α 2Х2) = α 1АХ1+(1-α 1)АХ2 = α 1В+(1-α 1)В=В, т.е. решение удовлетворяет системе ограничений. Но т.к. Х1≥ 0, Х2 ≥ 0, α 1 ≥ 0, α 2 ≥ 0, то и Х ≥ 0, т.е. решение Х удовлетворяет условию (3.3). ■ Итак, доказано, что множество всех допустимых решений ЗЛП является выпуклым, которое будем называть многогранником решений. Ответ на вопрос, в какой точке многогранника решений возможно оптимальное решение ЗЛП, даёт следующая теорема. Теорема 3. Если ЗЛП имеет оптимальное решение, то линейная функция F принимает максимальное (минимальное) значение в одной из угловых точек многогранника решений. Если линейная функция принимает максимальное значение более чем в одной угловой точке, то она принимает его в произвольной точке, являющейся выпуклой линейной комбинацией этих точек. □ Будем полагать, что многогранник решений является ограниченным. Обозначим его угловые точки через Х1, Х2, …, Хn, а оптимальное решение через Х*. Тогда F(Х*) ≥ F(X), для всех точек многогранника решений. Если Х* угловая, то первая часть теоремы доказана. Предположим, что Х* не является угловой точкой, тогда Х*, на основании теоремы 1, можно представить как выпуклую линейную комбинацию угловых точек многогранника решений, т.е. Х*=α 1x1+α 2x2+…+α рxр, α j≥ 0, (j=1, …, n), . Т.к. F(Х*)=F(α 1x1+α 2x2+…+α рxр)=α 1F(x1)+α 2F(x2)+…+α рF(xр). (3.4) В этом выражении среди значений F(Xj)(j=1, 2, …, p) выберем максимальное. Обозначим его через М, т.е. М=max F(Xj). Тогда α 1F(x1)+ α 2F(x2) +…+ α рF(xр)≤ α 1М+ α 2М +…+ α рМ = М(α 1+α 2+…+α р) =М. Значит F(Х*)≤ М. Пусть М=F(Xk), т.е. соответствует угловой точке Xk (1≤ к≤ р). Тогда F(Х*) ≤ F(Xk). Но по предположению Х* - оптимальное решение, поэтому F(Х*)≥ F(Xk)=М, следовательно, F(Х*)=М=F(Xk), где Xk - угловая точка. Итак, существует угловая точка Xk, в которой линейная функция принимает максимальное значение. Для доказательства второй части теоремы допустим, что F(Х) принимает максимальное значение более чем в одной угловой точке, например в точках Х1, Х2, … Хq, где 1≤ q ≤ р; тогда F(Х1)=F(Х2)=…=F(Хn)=M. Пусть Х выпуклая линейная комбинация этих угловых точек, т.е. Х= α 1Х1+α 2Х2+ …+α qХq, α j≥ 0, (j=1, …, q), . В этом случае, учитывая, что функция F(Х) – линейная, получим F(Х)=F(α 1Х1+α 2Х2+…+α qХq)=α 1F(Х1)+ +α 2F(Х2)+…+α qF(Хq)=α 1M+α 2M+…+α qM=M =M, т.е. линейная функция F принимает максимальное значение в произвольной точке Х, являющейся выпуклой линейной комбинацией угловых точек Х1, Х2, … Хq ■ Замечание. Требование ограниченности многогранника решений в теореме является существенным, т.к. в случае неограниченной многогранной области не каждую точку можно представить выпуклой линейной комбинацией её угловых точек. Доказанная теорема является фундаментальной, т.к. она указывает принципиальный путь решения ЗЛП. Рассмотрим геометрический метод решения ЗЛП в случае функции двух переменных. Было доказано, что оптимальное решение ЗЛП находится, по крайней мере, в одной из угловых точек многогранника решений. Рассмотрим задачу в стандартной форме с двумя переменными. F=c1x1+c2x2+с0 → min(max), При ограничениях а11х1+ а12х2 ≤ b1, а21х1+ а22х2 ≤ b2, ……………… an1х1+ аn2х2≤ bn, при условии, что x1 ≥ 0, x2 ≥ 0. Пусть геометрическим изображением системы ограничений является многоугольник ABCDE. Необходимо среди точек этого многоугольника найти такую точку, в которой линейная функция F=c1x1+c2x2+с0 принимает максимальное (или минимальное) значение. Рассмотрим линии уровня функции F или c1x1+c2x2=С (3.5). Это уравнение прямой. Линии уровня функции F параллельны, т.к. их угловые коэффициенты определяются только соотношением между коэффициентами c1 и c2 и, следовательно, равны. Т.о., линии уровня функции F – это своеобразные «параллели», расположенные обычно под углом к осям координат. Важное свойство линий уровня линейной функции состоит в том, что при параллельном смещении линии в одну сторону уровень только возрастает, а при смещении в другую сторону – только убывает. При фиксированном С рассмотрим линейную функцию. Чем больше значение С, тем больше значение линейной функции. Определив направление возрастания линейной функции, найдём точку, принадлежащую многоугольнику, в которой функция принимает максимальное или минимальное значение. Геометрическим изображением системы ограничений может служить и многоугольная область. Рассмотрим следующую задачу. 1.В суточный рацион включают два продукта питания П1 и П2, причём продукта П1 должно войти в дневной рацион не более 200 ед. Стоимость питательных веществ в 1 ед. продукта, минимальные нормы потребления указаны в таблице. Определить оптимальный рацион питания, стоимость которого будет наименьшей.
Решение. Обозначим х1 – количество продукта питания П1, х2 – количество продукта питания П2. F=2 х1 +4 х2 → min. (суммарная стоимость) При ограничениях х1 ≤ 200, 0, 2 х1 +0, 2 х2 ≥ 120, 0, 4 х1 +0, 2 х2 ≥ 160. Графическим решением системы ограничений является множество точек плоскости, называемое областью допустимых решений (ОДР). Линии уровня 2х1+4х2=0 х2=- х1 . Получаем, что минимальное значение, при заданных ограничениях на переменные, достигается в точке А(200; 400). F(A)=2000. Ответ: наименьшая стоимость 2000 будет при рационе 200 ед. продукта П1 и 400 ед. продукта П2. Не всегда бывает единственное оптимальное решение. Рассмотрим другую задачу. 2. F=4x1+4x2 → max. При ограничениях 2x1+x2 ≥ 7, x1-2x2 ≥ -5, x1+x2≤ 14, 2x1-x2 ≤ 18. Решив, систему ограничений найдём ОДР. Линия уровня будет иметь вид 4x1+4x2=0 x2=-x1. В данной задаче линия уровня с максимальным уровнем совпадает с граничной линией многоугольника решений. Найдём точку пересечения линии II с линией III:
х1= . Найдём точку пересечения линии III с линией IV: 14- х1=2 х1-18. Отсюда х1= . Следовательно, х1=c, x2=14-c, c [ ; ]. Пусть х1=9 [ ; ], х2=5. F=4·9+4·5=56. Ответ: Fmax=56 при множестве оптимальных решений х1=c, x2=14-c, где c [ ; ]. Рассмотренный геометрический метод решения ЗЛП обладает рядом достоинств. Он прост, нагляден, позволяет быстро и легко получить ответ. Однако есть и недостатки. Возникают «технические» погрешности, которые неизбежно возникают при приближенном построении графиков. Второй недостаток геометрического метода заключается в том, что многие величины, имеющие чёткий экономический смысл (например, такие, как остатки ресурсов производства), не выявляются при геометрическом решении задач. Его можно применять только в том случае, когда число переменных в стандартной задаче равно двум. Поэтому необходимы аналитические методы, позволяющие решать ЗЛП с любым числом переменных и выявить экономический смысл, входящих в них величин. Одним их таких методов является симплексный метод. В данном пункте была рассмотрена теорема, из которой следует, что если ЗЛП имеет оптимальное решение, то оно соответствует хотя бы одной угловой точке многогранника решений. Поэтому решение ЗЛП может быть следующим: перебрать конечное число всех угловых точек многогранника решений и выбрать среди них ту, на которой функция цели принимает оптимальное решение. Однако, практическое осуществление такого перебора связано с трудностями, т.к. число решений может быть чрезвычайно велико. Пусть ОДР изображается многоугольником ABCDEGH. Предположим, что его угловая точка соответствует исходному допустимому решению. При беспорядочном наборе пришлось бы перебирать все 7 угловых точек многогранника. Однако, из чертежа видно, что после вершины А выгодно перейти к соседней вершине В, а затем – к оптимальной точке С. Вместо семи перебрали 3 вершины, последовательно улучшая линейную функцию. Идея последовательного улучшения решения легла в основу универсального метода решения ЗЛП – симплексного метода. Для использования симплексного метода ЗЛП должна быть приведена к каноническому виду. Для реализации симплексного метода необходимо освоить 3 основных элемента: · способ определения какого – либо первоначального допустимого решения · правило перехода к лучшему решению · критерий проверки оптимальности найденного решения. Алгоритм конкретной реализации этих элементов рассмотрим на примере. Практические расчёты при решении реальных задач симплексным методом выполняются в настоящее время с помощью компьютера, однако, если расчёты выполняются без ЭВМ, то удобно использовать симплексные таблицы. Алгоритм составления симплексных таблиц: 1.Система ограничений приводится к каноническому виду. Для нахождения первоначального базисного решения переменные разбиваются на основные и неосновные. Т.к. определитель, составленный из коэффициентов при дополнительных переменных отличен от нуля, то эти переменные можно взять в качестве основных. При выборе основных переменных не обязательно составлять определитель, достаточно воспользоваться следующим правилом: в качестве основных переменных следует выбрать такие, каждая из которых входит только в одно из уравнений системы ограничений, при этом нет таких уравнений системы, в которые не входит ни одна из этих переменных. 2. Составляют таблицу, где в последней строке указываются коэффициенты функции с противоположным знаком. В левом столбце таблицы записывают основные переменные, в первой строке – все переменные, в последнем столбце свободные члены системы.
3. Проверяют выполнение критерия оптимальности – наличие в последней строке отрицательных коэффициентов. Если таких нет, то решение оптимально, достигнут, например, максимум функции (в правом нижнем углу таблицы), основные переменные при этом принимают значение bi, а неосновные переменные равны нулю, т.е. получается оптимальное базисное решение. 4. Если критерий оптимальности не выполнен, то наибольший по модулю отрицательный коэффициент в последней строке определяет разрешающий столбец S. Составляют оценочные ограничения по следующим правилам: · ∞, если bi и аis имеют разные знаки; · ∞, если bi=0 и аis< 0; · ∞, если аis=0; · 0, если bi=0 и аis> 0; · , если bi и аis имеют одинаковые знаки. Определяют min . Если конечного минимума нет, то задача не имеет конечного оптимума. Далее выбирают строку с номером q, на которой он достигается (любую, если их несколько), и называют её разрешающей строкой. На пересечении разрешающей строки и разрешающего столбца находится разрешающий элемент аqs. 5. Переходим к следующей таблице по правилам: а) в левом столбце записывают новый базис: вместо основной переменной хq - переменную хs, а геометрически произойдёт переход к соседней вершине многоугольника, где значение линейной функции «лучше». Значение линейной функции увеличится, т.к. переменная, входящая в выражение функции, станет основной, т.е. будет принимать не нулевое, а положительное значение; b) новую строку с номером q получают из старой делением на разрешающий элемент аqs; c) все остальные элементы вычисляют по правилу многоугольника: ; Далее переходим к пункту 3 алгоритма. Замечание: при отыскании минимума функции Z, полагаем, что F=-Z и учитываем, что Zmin=-Fmax. Решим задачу симплексным методом. Для производства трёх изделий А, В и С используются три вида ресурсов. Каждый из них используется в объёме, не превышающем 180, 210 и 236 кг. Нормы затрат каждого из видов ресурсов на одно изделие и цена единицы изделий приведены в таблице.
Определить план выпуска изделий, обеспечивающий получение оптимального дохода. Решение. х1 - количество выпускаемых изделий А х2 - количество выпускаемых изделий В х3 - количество выпускаемых изделий С. Тогда целевая функция будет иметь вид: F=10x1+14x2+12 х3 → max при ограничениях: 4x1+2x2+х3≤ 180 3x1+x2+3х3≤ 210 x1+2x2+5х3≤ 236 Приведём систему к каноническому виду: 4x1+2x2+х3+х4=180 3x1+x2+3х3+х5=210 x1+2x2+5х3+х6=236. Составляем таблицу
Определим ведущий элемент: min . Далее выполняем действия, следуя алгоритму.
min
Ответ: Чтобы получить оптимальный доход, нужно выпускать 83 ед. изделия В, 14 ед. изделия С, а изделие А не выпускать. Оптимальный доход составит 1330 у.е. По решению задачи видим, что у предприятия остаются свободными 85 кг. второго вида ресурсов, 1 и 3 вид полностью расходуются [5]
|