> ratio([SL1=10-3*x-2*y, SL2=8-2*x-4*y], x);
Функция setup может иметь три формы:
setup(С)
setup(С, NONNEGATIVE)
setup(С, NONNEGATIVE, 't')
Она обеспечивает конструирование множества уравнений с переменными в левой части:
> setup({2*х+3*y<=5,3*х+5*y=15));
Последняя функция — standartize(C) — конвертирует список уравнений (неравенств) в неравенства типа «меньше или равно»:
> standardize({2*х+3*у<=5,3*х+5*у=15});
6.6. Новый пакет оптимизации Optimization в Maple 9.5
В систему Maple 9.5 был добавлен новый пакет оптимизации Optimization, основанный на новейших существенно улучшенных алгоритмах оптимизации. С его помощью можно решать не только задачи линейного, но и квадратичного и нелинейного программирований с повышенной степенью визуализации.
6.6.1. Доступ к пакету Optimization и его назначение
Пакет оптимизации Optimization вызывается как обычно:
> with(Optimization);
Warning, the name changecoords has been redefined
Для получения справки по пакету надо исполнить команду:
> help(Optimization);
Пакет использует при вычислениях алгоритмы группы NAG, которые считаются наиболее эффективными при реализации численных методов вычислений, в частности реализующих алгоритмы оптимизации. Пакет вводит 8 функций. Две из них это переопределенные функции вычисления максимума Maximize и минимума Minimize. Кроме того, пакет имеет 4 решателя уравнений с заданными ограничениями, реализующих следующие методы:
• LPSolve — линейное программирование;
• LSSolve — улучшенная реализация метода наименьших квадратов;
• QPSolve — квадратичное программирование;
• NLPSolve — нелинейное программирование.
Функция ImportMPC обеспечивает ввод данных для оптимизации из файла, а функций Interactive позволяет работать с интерактивным Maplet-окном для оптимизации.
С пакетом Optimization можно познакомиться по его справке. В ее разделе Examples есть довольно обширный документ с примерами применения пакета — дополнительными к тем, которые даются к функциям пакета в справке. Начало этого документа представлено на рис. 6.3. В нем представлены основные задачи, решаемые пакетом Optimization — линейное, квадратичное и нелинейное программирование, а также приближение данных и функциональных зависимостей методом наименьших квадратов (нелинейная регрессия).
Рис. 6.3. Начало документа с примерами применения пакета Optimization
6.6.2. Работа с функциями Minimize и Maximize
Функции Minimize и Maximize служат для поиска минимумов и максимумов математических выражений с учетом ограничений самыми современными численными методами. Функции записываются в виде:
Minimize(obj [, constr, bd, opts])
Minimize(opfobj [, ineqcon, eqcon, opfbd, opts])
Maximize(obj [, constr, bd, opts])
Maximize(opfobj [, ineqcon, eqcon, opfbd, opts])
Параметры функций следующие:
• obj — алгебраический объект, целевая функция;
• constr — список с ограничивающими условиями;
• bd — последовательность вида name=range, задающая границы для одной или более переменных;
• opts — равенство или равенства вида option=value, где option одна из опции feasibilitytolerance, infinitebound, initialpoint, iterationlimit или optimalitytolerance, специфицированных в команде Minimize или Maximize.
• opfobj — процедура, целевая функция;
• ineqcon — множество или список процедур с ограничениями типа неравенств;
• eqcon — множество или список процедур с ограничениями типа равенств;
• opfbd — последовательность пределов; границы для всех переменных; Примеры применения этих функций представлены ниже:
> Maximize(sin(х)/х);
> Minimize(х^2+у^2);
> Minimize(sin(х)/х, initialpoint={x=5});
> Maximize(sin(x*y*z));
> Minimize(2*х+3*y, {3*х-y<=9, х+y>=2}, assume=nonnegative);
Из этих примеров видно, что результаты вычислений представляются в виде чисел с плавающей точкой с так называемой двойной точностью (правильнее было бы сказать с двойной длиной или разрядностью). При вычислениях используются алгоритмы группы NAG и решатели, описанные ниже.
6.6.3. Линейное программирование — LPSolve
Для решения задач линейного программирования в пакете Optimization введена функция: