Лекция 11: Численное решение краевых задач для систем обыкновенных дифференциальных уравнений
Теперь, после того как описан прогоночный алгоритм, исследуем его на устойчивость.
Для этого рассмотрим вычисление прогоночного коэффициента pn (т.е. этап прямого хода прогонки). В идеальной арифметике этот коэффициент равен
в конечноразрядной арифметике — где — погрешность, связанная с округлениями на всех предшествующих этапах вычислений. Полагая малой, исследуем изменение этой погрешности с ростом n. Для этого запишем соотношение между и в видегде — погрешность вычислений правой части и машинного представления коэффициентов an, bn, cn. Следовательно, складывается из двух составляющих — локальной погрешности и наследственной
Полагая при и опуская члены порядка получим оценку
Отсюда, учитывая, что
получим требуемую оценку для эволюции погрешности( 10.2) |
Докажем следующую теорему.
Теорема. Если выполнены условия диагонального преобладания и хотя бы для одной строки матрицы системы имеет место строгое диагональное преобладание Пусть, кроме того, 0 < p1 < 1. Тогда алгоритм прогонки устойчив.
Доказательство.
Докажем утверждение теоремы для случая, когда во всех строках матрицы выполнено условие строгого диагонального преобладания. На случай нестрогих неравенств обобщение доказательства очевидно.
- Пусть выполнено условие диагонального преобладания и 0 < p1 < 1. Для определенности положим an > 0, bn > 0, cn > 0.
Тогда
Кроме того,
откуда следует 0 < pn + 1 < 1. - Покажем, что
Для этого вспомним выражения для коэффициентов линейной системы, полученной при разностной аппроксимации исходного уравнения второго порядка.
Вернемся к выражению для эволюции погрешности (10.2). С учетом полученных оценок имеем
Так как то где c — константа Липшица для функции g(t). Считаем, что на каждом шаге ошибка округления не превосходит предельного значения, т.е.Из цепочки неравенств
будет следовать оценка
Используя известные из математического анализа неравенства, последнюю оценку можно записать в видеПри погрешности не накапливаются (для краевых задач это реальное условие), поскольку в расчетах где — машинный эпсилон (подробнее в "Предмет вычислительной математики. Обусловленность задачи, устойчивость алгоритма, погрешности вычислений. Задача численного дифференцирования" ).
Аналогичное утверждение доказывается и для второго прогоночного коэффициента
алгоритм устойчив при выполнении тех же условий.Покажем устойчивость обратного хода прогонки.
При обратном ходе вычисления проводятся по формулам un = pn + 1un + 1 + qn + 1, откуда, учитывая, что и получим где — наследственная погрешность, — погрешность округления на n шаге. Очевидно, что обратный ход прогонки устойчив при выполнении условия 0 < pn < 1, или 0 < p1 < 1.