WikiDer > Метод Аберта
В Метод Аберта, или же Метод Аберта – Эрлиха, названный в честь Оливера Аберта[1] и Луи У. Эрлих,[2] это алгоритм поиска корней разработан в 1967 г. для одновременной аппроксимации всех корней одномерный многочлен.
Этот метод сходится кубически, что является улучшением по сравнению с Метод Дюрана – Кернера, еще один алгоритм для аппроксимации всех корней сразу, который сходится квадратично.[1][2] (Однако оба алгоритма линейно сходятся при несколько нулей.[3])
Этот метод используется в MPSolve, которое является эталонным программным обеспечением для аппроксимации всех корней многочлена с произвольной точностью.
Описание
Позволять быть одномерный многочлен степени с действительными или комплексными коэффициентами. Тогда существуют комплексные числа , корни , что дает факторизация:
Хотя эти цифры неизвестны, верхняя и нижняя границы поскольку их абсолютные значения вычисляются из коэффициентов полинома. Теперь можно выбрать различные числа в комплексной плоскости - случайно или равномерно распределенные, так что их абсолютные значения находятся в одних и тех же границах. (Кроме того, если нули симметричны, начальные точки не должны быть точно симметричными по одной и той же оси, так как это может помешать схождению.)[1] Набор таких чисел называется начальным приближением набора корней . Это приближение можно итеративно улучшить, используя следующую процедуру.
Позволять быть текущими приближениями нулей . Затем сместите числа вычисляются как
куда - полиномиальная производная от оценивается в точке .
Следующий набор приближений корней затем . Качество текущего приближения можно измерить по значениям полинома или по размеру смещений.
Концептуально этот метод использует электростатический аналогия, моделируя приближенные нули как подвижные отрицательные точечные сборы, которые сходятся к истинным нулям, представленным фиксированными положительными точечными зарядами.[1] Прямое применение метода Ньютона к каждому приближенному нулю часто приводит к неправильному схождению нескольких начальных точек к одному корню. Метод Аберта позволяет избежать этого, также моделируя отталкивающий эффект, который подвижные заряды оказывают друг на друга. Таким образом, когда подвижный заряд сходится к нулю, их заряды нейтрализуются, так что другие подвижные заряды больше не притягиваются к этому месту, побуждая их сходиться к другим «незанятым» нулям. (Стилтьес также моделировали положения нулей многочленов как решения электростатических проблем.)
Внутри формулы метода Аберта можно найти элементы Метод Ньютона и Метод Дюрана – Кернера. Детали для эффективной реализации, особенно. о выборе хороших начальных приближений можно найти в Bini (1996).[3]
Обновления корней могут выполняться одновременно. Якоби-подобная итерация, где сначала все новые приближения вычисляются из старых приближений или как последовательные Гаусс-Зейдель-подобная итерация, которая использует каждое новое приближение с момента его вычисления.
Очень похожий метод - метод Ньютона-Мэли. Он вычисляет нули один за другим, но вместо явного дефлятирования на лету делит на уже полученные линейные множители. Метод Аберта подобен методу Ньютона-Мейли для вычисления последнего корня, делая вид, что вы уже нашли другие корни.[4]
Вывод из метода Ньютона
Формула итерации - это одномерная итерация Ньютона для функции
Если значения уже близки к корням , то рациональная функция почти линейна с доминантным корнем, близким к и полюса на которые направляют итерацию Ньютона от корней р (х) близкие к ним. То есть соответствующие бассейны притяжения становятся довольно маленькими, а корень, близкий к имеет широкую область притяжения.
Шаг Ньютона в одномерном случае - величина, обратная логарифмической производной
Таким образом, новое приближение вычисляется как
которая является обновленной формулой метода Аберта – Эрлиха.
Литература
- ^ а б c d Аберт, Оливер (1973). «Итерационные методы поиска всех нулей полинома одновременно». Математика. Comp. Математика вычислений, Vol. 27, № 122. 27 (122): 339–344. Дои:10.2307/2005621. JSTOR 2005621.
Из-за очевидной аналогии с электростатикой это поле можно назвать полем единицы плюс заряд ... Чтобы избежать этого, мы назначаем единицу минус заряда в каждой точке выборки. Идея здесь заключается в том, что когда точка выборки z близка к простому нулю, поле от отрицательного заряда в z должно противодействовать полю от положительного заряда в нуле, предотвращая схождение второй точки выборки к этому нулю.
- ^ а б Эрлих, Луис В. (1967). «Модифицированный метод Ньютона для многочленов». Comm. ACM. 10 (2): 107–108. Дои:10.1145/363067.363115.
- ^ а б Бини, Дарио Андреа (1996). «Численное вычисление полиномиальных нулей методом Аберта». Численные алгоритмы. 13 (2): 179–200. Bibcode:1996НуАлг..13..179Б. Дои:10.1007 / BF02207694.
- ^ Bauer, F.L .; Стоер, Дж. (1962). «Алгоритм 105: Ньютон Мэли». Comm. ACM. 5 (7): 387–388. Дои:10.1145/368273.368423.
Смотрите также
- MPSolve Пакет для численного вычисления корней полиномов. Бесплатное использование в научных целях.