Метод Фибоначчи — различия между версиями
м (rollbackEdits.php mass rollback) |
|||
(не показаны 2 промежуточные версии 2 участников) | |||
Строка 36: | Строка 36: | ||
==Алгоритм== | ==Алгоритм== | ||
'''Предварительный этап.''' | '''Предварительный этап.''' | ||
− | Выбрать допустимую конечную длину интервала неопределенности <tex>l > 0</tex> и константу различимости <tex>{\epsilon}</tex>. Пусть задан начальный интервал неопределенности <tex>\left(b_1 - a_1\right)</tex>. Выбрать общее число вычислений функции <tex>n</tex> так, чтобы <tex>F_n > \dfrac{b_1 - a_1}{l}</tex>. Положить <tex>{\lambda}_1 = a_1 + \dfrac{F_{n-2}}{F_n}*\left(b_1 - a_1\right)</tex>, <tex>{\mu}_1 = a_1 + \dfrac{F_{n-1}}{F_n}*\left(b_1 - a_1\right)</tex>. | + | Выбрать допустимую конечную длину интервала неопределенности <tex>l > 0</tex> и константу различимости <tex>{\epsilon}</tex>. Пусть задан начальный интервал неопределенности <tex>\left(b_1 - a_1\right)</tex>. Выбрать общее число вычислений функции <tex>n</tex> так, чтобы <tex>F_n > \dfrac{b_1 - a_1}{l}</tex>. Положить <tex>{\lambda}_1 = a_1 + \dfrac{F_{n-2}}{F_n}*\left(b_1 - a_1\right)</tex>, <tex>{\mu}_1 = a_1 + \dfrac{F_{n-1}}{F_n}*\left(b_1 - a_1\right)</tex>.Вычислить <tex>f\left({\lambda}_1\right)</tex>, <tex>f\left({\mu}_1\right)</tex>, положить <tex>k = 1</tex> и перейти к основному этапу. |
+ | |||
+ | '''Основной этап.''' | ||
+ | |||
+ | ''Первый шаг.'' Если <tex>f\left({\lambda}_k\right) > f\left({\mu}_k\right)</tex>, то перейти ко второму шагу, в противном случае – к третьему шагу. | ||
+ | |||
+ | ''Второй шаг.''Положить <tex>a_{k+1} = {\lambda}_k, b_{k+1} = b_k</tex>. Затем положить <tex>{\lambda}_{k+1} = {\mu}_k</tex>, <tex>{\mu}_{k+1} = a_{k+1} + \dfrac{F_{n-k-1}}{F_{n-k}}*\left(b_{k+1} - a_{k+1}\right)</tex>. Если <tex>k = n - 2</tex>, то перейти к пятому шагу, в противном случае вычислить <tex>f\left({\mu}_{k+1}\right)</tex> и перейти к четвертому шагу. | ||
+ | |||
+ | ''Третий шаг.'' Положить <tex>a_{k+1} = a_k</tex>, <tex>b_{k+1} = {\mu}_k</tex>, <tex>{\mu}_{k+1} = {\lambda}_k</tex>, <tex>{\lambda}_{k+1} = a_{k+1} + \dfrac{F_{n-k-2}}{F_{n-k}}*\left(b_{k+1} - a_{k+1}\right)</tex>. Если <tex>k = n - 2</tex>, то перейти к пятому шагу, в противном случае <tex>f\left({\lambda}_{k+1}\right)</tex> и перейти к четвертому шагу. | ||
+ | |||
+ | ''Четвертый шаг.'' Заменить <tex>k</tex> на <tex>k + 1</tex> и перейти к первому шагу. | ||
+ | |||
+ | ''Пятый шаг.'' Положить <tex>{\lambda}_n = {\lambda}_{n-1}</tex>, <tex>{\mu}_n = {\lambda}_n + {\epsilon}</tex>. Если <tex>f\left({\lambda}_n\right) = f\left({\mu}_n\right)</tex>, то положить <tex>a_n = {\lambda}_n, b_n = b_{n-1}</tex>. В противном случае (если <tex>f\left({\lambda}_n\right) < f\left({\mu}_n\right)</tex>), положить <tex>a_n = a_{n-1}, b_n = {\mu}_n</tex>. | ||
+ | |||
+ | '''Конец''': оптимальное решение содержится в интервале <tex>[a_n, b_n]</tex>. |
Текущая версия на 19:29, 4 сентября 2022
Метод Фибоначчи
Метод Фибоначчи (англ. Fibonacci method) — это улучшение реализации поиска с помощью золотого сечения, служащего для нахождения минимума/максимума функции. Подобно методу золотого сечения, он требует двух вычислений функции на первой итерации, а на каждой последующей только по одному. Однако этот метод отличается от метода золотого сечения тем, что коэффициент сокращения интервала неопределенности меняется от итерации к итерации.
Описание
Метод основан на последовательности чисел Фибоначчи
, которая определяется следующим образом :
Таким образом, последовательность Фибоначчи имеет вид
Предположим, что на -й итерации интервал неопределенности равен . Рассмотрим две точки и , определяемые следующим образом:
,
где
и — заданное общее число вычислений функции.Новый интервал неопределенности
будет равен , если и , если . В первом случае, учитывая и полагая , получим.
Во втором случае, учитывая
, получаем.
Таким образом, в обоих случаях длина интервала неопределенности сжимается с коэффициентом
. Покажем, что на той итерации либо , либо , так что требуется только одно новое вычисление функции. Предположим, что . Тогда . Таким образом, используя и заменив на , получаем . Подставив выражение для и заменив на , получим ..
.
Если золотого сечения в методе Фибоначчи требуется, чтобы общее число вычислений (или коэффициент сокращения исходного интервала) было задано заранее. Это объясняется тем, что точки, в которых производятся вычисления, зависят от . Длина интервала неопределенности на -той итерации сжимается с коэффициентом . Следовательно, после итерации, где — заданное общее число вычислений функции , длина интервала неопределенности сократится от до .
, то выполнив аналогичные преобразования, получим . Таким образом, в обоих случаях на -й итерации требуется только одно вычисление функции. В отличие от методаАлгоритм
Предварительный этап. Выбрать допустимую конечную длину интервала неопределенности
и константу различимости . Пусть задан начальный интервал неопределенности . Выбрать общее число вычислений функции так, чтобы . Положить , .Вычислить , , положить и перейти к основному этапу.Основной этап.
Первый шаг. Если
, то перейти ко второму шагу, в противном случае – к третьему шагу.Второй шаг.Положить
. Затем положить , . Если , то перейти к пятому шагу, в противном случае вычислить и перейти к четвертому шагу.Третий шаг. Положить
, , , . Если , то перейти к пятому шагу, в противном случае и перейти к четвертому шагу.Четвертый шаг. Заменить
на и перейти к первому шагу.Пятый шаг. Положить
, . Если , то положить . В противном случае (если ), положить .Конец: оптимальное решение содержится в интервале
.