КАТЕГОРИИ: Архитектура-(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) |
Градиентные методы
Лекция № 8 Градиентные методы решения задач нелинейного программирования. Методы штрафных функций. Приложения нелинейного программирования к задачам исследования операций. Задачи без ограничений. Градиентным методом можно решать, вообще говоря, любую нелинейную задачу. Однако при этом находится лишь локальный экстремум. Поэтому целесообразнее применять этот метод при решении задач выпуклого программирования, в которых любой локальный экстремум, является одновременно и глобальным (см. теорему 7.6). Будем рассматривать задачу максимизации нелинейной дифференцируемой функции f (x). Суть градиентного поиска точки максимума х * весьма проста: надо взять произвольную точку х 0 и с помощью градиента
Рис. 7.4 а затем, сделав небольшой шаг в найденном направлении, перейти в новую точку xi. Потом снова определить наилучшее направление
Градиентные методы, как правило, позволяют получать точное решение за бесконечное число шагов и только в некоторых случаях — за конечное. В связи с этим градиентные методы относят к приближенным методам решения. Движение из точки хk в новую точку xk+1 осуществляется по прямой, проходящей через точку хk и имеющей уравнение
где λk — числовой параметр, от которого зависит величина шага. Как только значение параметра в уравнении (7.29) выбрано: λk=λk0, так становится определенной очередная точка Градиентные методы отличаются друг от друга способом выбора величины шага — значения λk0 параметра λk. Можно, например, двигаться из точки в точку с постоянным шагом λk= λ, т. е. при любом k
Если при этом окажется, что Иногда величина шага берется пропорциональной модулю градиента. Если ищется приближенное решение, то поиск можно прекратить, основываясь на следующих соображениях. После каждой серии из определенного числа шагов сравнивают достигнутые значения целевой функции f (x). Если после очередной серии изменение f (x) не превышает некоторого наперед заданного малого числа Если целевая функция f (x) вогнутая (выпуклая), то необходимым и достаточным условием оптимальности точки х * является равенство нулю градиента функции в этой точке. Распространенным является вариант градиентного поиска, называемый методом наискорейшего подъема. Суть его в следующем. После определения градиента Перемещение из точки хk в точку
Из выражения (7.30) видно, что приращение
Найдем выражение для производной, дифференцируя равенство (7.30) по
Это равенство имеет простое геометрическое истолкование: градиент в очередной точке хк+ 1, ортогонален градиенту в предыдущей точке хк.
Пример 7.4. Определить максимум функции , начав оптимизационный поиск с точки .
Решение. Будем сопровождать решение задачи графической иллюстрацией (рис. 7.6). По данному уравнению параболоида вращения
построены линии уровня этой поверхности. С этой целью уравнение приведено к виду (x 1-1)2+(x2-2)2=5-0,5 f, из которого ясно, что линиями пересечения параболоида с плоскостями, параллельными плоскости x 1О x 2 (линиями уровня), являются окружности радиусом . При f =-150, -100, -50 их радиусы равны соответственно , а общий центр находится в точке (1; 2). Находим градиент данной функции:
I шаг. Вычисляем:
На рис. 7.6 с началом в точке х 0=(5; 10) построен вектор Используя условие (7.32), получаем
или 1-4 II шаг. Начальная точка для второго шага x 1=(1; 2). Вычисляем Задача с линейными ограничениями. Сразу же отметим, что если целевая функция f (х) в задаче с ограничениями имеет единственный экстремум и он находится внутри допустимой области, то для поиска экстремальной точки х * применяется изложенная выше методика без каких-либо изменений. Рассмотрим задачу выпуклого программирования с линейными ограничениями:
где Предполагается, что f (х) является вогнутой функцией и имеет непрерывные частные производные в каждой точке допустимой области. Начнем с геометрической иллюстрации процесса решения задачи (рис. 7.7). Пусть начальная точка х 0 расположена внутри допустимой области. Из точки х 0 можно двигаться в направлении градиента
Таким образом, на следующем шаге двигаться надо по граничной прямой до тех пор, пока возрастает f (x); в нашем случае — до точки х 2. Из рисунка видно, что далее следует перемещаться в направлении вектора , который находится из условия максимизации скалярного произведения , т. е. по граничной прямой. Движение заканчивается в точке х 3, поскольку в этой точке завершается оптимизационный поиск, ибо в ней функция f (х) имеет локальный максимум. Ввиду вогнутости в этой точке f (х) достигает также глобального максимума в допустимой области. Градиент в точке максимума х 3= х * составляет тупой угол с любым вектором из допустимой области, проходящим через х3, поэтому скалярное произведение будет отрицательным для любого допустимого rk, кроме r 3, направленного по граничной прямой. Для него скалярное произведение =0, так как и взаимно перпендикулярны (граничная прямая касается линии уровня поверхности f (х), проходящей через точку максимума х *). Это равенство и служит аналитическим признаком того, что в точке х 3 функция f (x) достигла максимума.
Рассмотрим теперь аналитическое решение задачи (7.33) — (7.35). Если оптимизационный поиск начинается с точки, лежащей в допустимой области (все ограничения задачи выполняются как строгие неравенства), то перемещаться следует по направлению градиента так, как установлено выше. Однако теперь выбор λk в уравнении (7.29) усложняется требованием, чтобы очередная точка
Решая систему линейных неравенств (7.36), находим отрезок Значение λk*, определяемое в результате решения уравнения (7.32):
Если оптимизационный поиск начат с точки, лежащей на граничной гиперплоскости, или очередная точка поисковой траектории оказалась на граничной гиперплоскости, то для продолжения движения к точке максимума прежде всего необходимо найти наилучшее направление движения С этой целью следует решить вспомогательную задачу математического программирования, а именно- максимизировать функцию
при ограничениях
для тех t, при которых
где В результате решения задачи (7.37) — (7.40) будет найден вектор Условие (7.39) говорит о том, что точка После определения направления
Оптимизационный поиск прекращается, когда достигнута точка xk*, в которой Пример 7.5. Максимизировать функцию
Решение. Для наглядного представления процесса оптимизации будем сопровождать его графической иллюстрацией. На рис 7.8 изображено несколько линий уровня данной поверхности и допустимая область ОАВС, в которой следует найти точку х *, доставляющую максимум данной функции (см. пример 7 4). Начнем оптимизационный поиск, например с точки х 0=(4, 2,5), лежащей на граничной прямой АВ x 1+4 x 2=14. При этом f (х 0)=4,55. Найдем значение градиента
Поскольку точка х 0 располагается только на одной (первой) граничной прямой (i =1) x 1+4 x 2=14, то условие (7.38) записывается в форме равенства. Система ограничительных уравнений этой задачи имеет только два решения (-0,9700; 0,2425) и (0,9700;-0,2425) Непосредственной подстановкой их в функцию T 0 устанавливаем, что максимум Т 0 отличен от нуля и достигается при решении (-0,9700; 0,2425) Таким образом, перемещаться из х 0 нужно по направлению вектора r 0=(0,9700; 0,2425), т е по граничной прямой ВА. Для определения координат следующей точки x 1=(x 11; x 12)
необходимо найти значение параметра
Первое ограничение мы опустили, поскольку точка x 1 лежит на прямой АВ. Решая систему (7.43), устанавливаем, что
откуда Если продолжить оптимизационный поиск, то при решении очередной вспомогательной задачи (7.37)— (7.40) будет установлено, что Т1=
Задача с нелинейными ограничениями. Если в задачах с линейными ограничениями движение по граничным прямым оказывается возможным и даже целесообразным, то при нелинейных ограничениях, определяющих выпуклую область, любое как угодно малое перемещение из граничной точки может сразу вывести за пределы области допустимых решений, и возникнет необходимость в возвращении в допустимую область (рис. 7.9). Подобная ситуация характерна для задач, в которых экстремум функции f (x) достигается на границе области. В связи с этим применяются различные способы перемещения, обеспечивающие построение последовательности точек, расположенных вблизи границы и внутри допустимой области, или зигзагообразное движение вдоль границы с пересечением последней. Как видно из рисунка, возврат из точки x1 в допустимую область следует осуществлять вдоль градиента той граничной функции
Дата добавления: 2014-01-07; Просмотров: 1985; Нарушение авторских прав?; Мы поможем в написании вашей работы! |