Содержание
-
Численные методы безусловной оптимизации. Метода параллельных касательных (метод Пауэлла)
-
Метод Пауэла
Метод ориентирован на решение задач с квадратичными целевыми функциями, т.е. функциями вида: f(x) = a + bTx + 1/2xTCx, где Q(x) = xTCx – квадратичная форма. Т.к. в окрестности точки оптимума любую нелинейную функцию можно аппроксимировать квадратичной функцией (поскольку линейный член разложения Тейлора обращается в нуль), то метод может быть применен и для нелинейной целевой функции общего вида. Метод Пауэлла использует свойство квадратичной функции, заключающееся в том, что любая прямая, которая проходит через точку минимума функции х*, пересекает под равными углами касательные к поверхностям равного уровня функции в точках пересечения.
-
Суть метода заключается в следующем (Рассмотрим случай двух переменных). Выбирается некоторая точка х(0) и выполняется одномерный поиск вдоль произвольного направления, приводящий в точку х(1) (х(1) – точка минимума функции на выбранном направлении). Затем выбирается точка х(2), не лежащая на прямой х(0) – х(1), и осуществляется одномерный поиск вдоль прямой, параллельной х(0) – х(1). Находят точку х(3) – точку минимума функции на данном направлении. Точка х(3) вместе с точкой х(1) определяют направление х(1) – х(3) одномерного поиска, дающего точку минимума х*. Направления х(0) – х(2) и х(1) – х(3) являются сопряженными направлениями относительно матрицы С квадратичной формы Q(x) (C – сопряженные направления). Точно также сопряженными являются направления х(2)-х(3) и х(1)-х(3). В рассмотренных построениях для того, чтобы определить сопряженное направление, требовалось задать две точки и некоторое направление. Это не слишком удобно для проведения расчетов, поэтому предпочтительнее строить систему сопряженных направлений, исходя из одной начальной точки. Это легко осуществить при помощи единичных координатных векторов е(1), е(2), …, е(n). e(1) = (1, 0, …, 0)T; e(2) = (0, 1, …, 0)T; …; e(n) = (0, 0, …, 1)T. Проиллюстрируем процедуру построения сопряженных направлений для случая двух переменных (ее можно обобщить и для n-мерного пространства).
-
Пусть е(1) = (1, 0)Т; е(2) =(0, 1)Т. Зададим начальную точку х(00). Произведем одномерный поиск минимума функции f вдоль направления e(n) – e(2) (n=2), начиная из начальной точки х(00). Точки прямой, исходящей из х(00) в направлении е(2), задаются формулой x = x(00) + he(2). Вычислим значение h=h0, которому соответствует минимум f(x(00) + h0e(2)). f(x(00) + h0e(2)) = minh f(x(00) + he(2)). Положим x(0) = x(00) + h0e(2). Из точки х(0) выполняем одномерный поиск вдоль направления е(1). Вычислим значение h1, которому соответствует минимум f(x(0)+h1e(1)). Положим x(1) = x(0) + h1e(1). Из точки х(1) выполняем одномерный поиск в направлении е(2). Вычисляем значение h2, которому соответствует минимум f(x(1)+h2e(2)). Положим x(2) = x(1) + h2e(2). Направления (х(2) – х(0)) и е(2) оказываются сопряженными. Это видно из следующего рисунка.
-
Можно рассуждать так: мы выбрали две точки х(00) и х(1) и из этих точек выполнили одномерный поиск в направлении е(2). Соответствующие этим поискам точки минимума – х(0) и х(2). Поэтому направление х(0) – х(2) является сопряженным с направлением е(2). Одномерный поиск в направлении е(2) дает точку минимума х*. Поэтому на следующей итерации проводится одномерный поиск в направлении х(0) – х(2) и будет получена точка минимума х*. В случае квадратичной функции n переменных оптимальное значение находится за n итераций при этом требуется провести n2 одномерных поисков.
-
Алгоритм метода Пауэлла
1. Задают начальную точку х(00). Выполняют одномерный поиск минимума функции f вдоль направления p(n) = e(n) = (0, …, 0, 1)T. Величина шага h0 находится из условия f(x(00) +h0p(n)) = minh f(x(00) +hp(n)). Полученный шаг определяет точку x(0) = x(00) + h0p(n); k:=1(номер итерации). 2. За начальные направления поиска р(1), р(2), …, р(n) принимают направления осей координат, т.е. p(i) = e(i) (i = 1, …, n), где е(1) = (1, 0, …, 0)Т, е(2) = (0, 1, …, 0)Т, …, е(n) = (0, …, 0, 1)Т. 3. Из точки х(0) выполняют n одномерных поисков вдоль направлений p(i) (i = 1, …, n). При этом каждый следующий поиск производится из точки минимума, полученной на предыдущем шаге. Величина шага hiнаходится из условия f(x(i-1) + hip(i)) = minh f(x(i-1) + hp(i)). Полученный шаг определяет точку x(i) = x(i-1) +hip(i). 4. Выбираем новое направление p = x(n) – x(0) и заменяем направления p(1), …, p(n) соответственно на p(2), …, p(n), p. 5. Из точки x(n) осуществляют одномерный поиск вдоль направления p = p(n) = x(n) – x(0). Величина шага hn+1 находится из f(x(n) + hn+1p) = minh f(x(n) + hp). Полученный шаг определяет точку x(n+1) = x(n) + hn+1p; k:=k+1(номер итерации).
-
6. Проверяют выполнение условия k n. Если условие выполняется перейти к п.7, в противном случае перейти к п.8. 7. а) если целевая функция квадратичная, то поиск прекращается; х* полагается равным x(n+1) (x* := x(n+1)). б)если целевая функция не является квадратичной, то проверяют выполнение условия ||x(n) – x(0)|| ( - заданная точность) (т.е. изменение по каждой независимой переменной должно быть меньше, чем заданная точность). Если условие выполняется, то поиск прекратить; х* полагается равным x(n+1). В противном случае перейти к п.8. 8. Заменяют x(0) на x(n+1) (x(0) := x(n+1)) и принимают эту точку за начальную точку х(0) для следующей итерации. Переходят к п.3. Таким образом, в результате выполнения рассмотренной процедуры осуществляется поочередная замена принятых вначале направлений поиска. В итоге после n итераций они окажутся взаимно сопряженными.
-
Пример
-
-
Нет комментариев для данной презентации
Помогите другим пользователям — будьте первым, кто поделится своим мнением об этой презентации.