Рассмотрим решение задачи интерполяции на классе сплайнов - функций, которые широко используются в вопросах численного анализа, в машинной графике и в других областях.
1.1. Линейный интерполяционный сплайн
Пусть - разбиение отрезка .
, - заданные значения.
Сплайном первой степени называется :непрерывная на отрезке , линейная на каждом частичном промежутке функция. Его обозначение . Интерполяционным для данной функции называется сплайн, удовлетворяющий условиям , .
График линейного интерполяционного сплайна - это ломаная, проходящая через заданные точки.
Пусть , . Выражение для сплайна на этом промежутке:
Остаточный член : .
Оценка остаточного члена зависит от дифференцируемых свойств функции .
Пусть . Обозначение
- колебание функции на
Справедлива следующая лемма:
Лемма (вариант теоремы о среднем):
Пусть . Если величины одинакового знака, то существует такое, что
С помощью этой леммы доказывается следующая теорема об оценке остаточного члена линейного интерполяционного сплайна.
Теорема
Если , то .
Действительно,
, где .
По приведенной
выше лемме
, где
С улучшением гладкости функции оценка погрешности ее интерполяции линейными сплайнами также улучшается. А именно,
если , то , где
Для можно получить оценку .
Дальнейшее увеличение гладкости функции не дает повышения порядка аппроксимации. Происходит насыщение алгоритма.
Пусть на задана
последовательность сеток : , , которая
удовлетворяют условию при . Для строится
интерполяционный сплайн . Интерполяционный
процесс сходится, если
при для любой функции из некоторого
класса . Отсюда вытекает возможность интерполяции с наперед заданной
точностью:
.
Преимущество по сравнению с интерполяционными многочленами: из оценки погрешности следует сходимость.
Пусть . По доказанной теореме .
По определению при , поэтому процесс интерполяции линейными сплайнами сходится на множестве непрерывных функций по произвольной последовательности сеток .
Если , , то . Сходимость порядка .
Пусть на задана сетка , в узлах которой известны значения функции . Сплайн третьей степени , интерполирующий заданную функцию , определяется как функция, удовлетворяющая условиям:
1)
2) Для любого частичного промежутка -многочлен третьей степени
3)
Для задания надо определить 4 коэффициента для каждого промежутка , т.е. параметров.
Условия 1) требуют чтобы во внутренних узлах сплайн и его производные до 2-го порядка были непрерывны.
Это дает условия для определения параметров, еще условие содержится в 3).
Итого имеем условия. Еще 2 условия, необходимые для однозначного определения сплайна, обычно задаются в виде граничных условий, т.е. условий в точках и .
Возьмем в качестве граничных условия
4)
Для построения кубического интерполяционного сплайна могут быть использованы различные подходы. Проведем построение сплайна, исходя из условий 1) - 4). Из 1) и 2) следует, что непрерывная функция, линейная на каждом т.е. линейный сплайн.
Обозначив , получаем
(33)
для .
Интегрируя (5), получаем
(34)
(35)
и - постоянные интегрирования.
Условия 3) дают:
(36)
Из (36) получаем:
Подставляя и в (7), получаем:
(37)
После преобразования
из (37) получаем
(38)
Из (34) получаем
(39)
Из (39) находим односторонние пределы производной для узла ,
(40)
(41)
Подставляя (40) и (41) в условие непрерывности в узле получаем :
(42)
Дополняя (42) равенствами из условия 4) : , получаем систему уравнений относительно вида :
(43)
с квадратной матрицей .
и квадратной матрицей
Координатами вектора являются значения .
Для матрицы ненулевые элементы расположены на главной диагонали и двух соседних с ней. Такие матрицы называются трехдиагональными. Для выполнено условие диагонального преобладания .
Матрица с диагональным преобладанием невырождена. Следовательно, система (42) однозначно разрешима, т.е. существует единственный кубический интерполяционный сплайн. Кроме условий 4) - условий "свободного провисания" интерполяционной кривой в точках и , могут быть известны наклоны интерполяционной кривой в граничных точках. Тогда условия на границах имеют вид:
(44)
Могут быть использованы и другие
варианты.
Вид граничных условий меняет некоторые элементы матрицы , но в любом случае она остается матрицей с диагональным преобладанием.
Решение системы (43) с трехдиагональной матрицей может быть найдено посредством специального варианта метода последовательного исключения неизвестных, который называется методом прогонки.
Относительно оценки погрешности и сходимости интерполяций кубическими сплайнами имеют место следующие результаты:
если , то , где , ,
если , , то
оценка имеет вид для .
Из этих оценок
следует сходимость интерполяционного процесса на последовательности сеток .
Метод прогонки - реализация метода Гаусса исключения неизвестных для систем линейных уравнений с трехдиагональными матрицами. При этом в случае матриц с трехдиагональным преобладанием автоматически используется главный элемент, что обеспечивает устойчивость вычислений, т.е. гарантирует от накопления ошибок округления результатов арифметических действий.
Пусть требуется найти решение следующей системы линейных алгебраических уравнений
(45)
причем для всех .
Матрица этой системы является трехдиагональной и имеет следующий вид:
Это квадратная матрица размера .
Предположим, что имеет место рекуррентное соотношение
(46)
с неопределенными коэффициентами .
Из соотношений (46) и соотношений (45) находим:
Сравнивая получаемое отсюда выражение для с формулами (46), получим рекуррентные формулы для прогоночных коэффициентов:
, , .
Начальные значения получим, сравнивая и (46) при .
Для нахождения граничного значения запишем систему уравнений:
Исключая из системы , получим
.
Итак, формально получен следующий алгоритм решения системы (45), который называется методом прогонки.
Сначала осуществляется прямая прогонка, т.е. находятся прогоночные коэффициенты
(47)
Затем осуществляется обратная прогонка по формулам
, , (48)