Кубический сплайн: различия между версиями
[непроверенная версия] | [непроверенная версия] |
Vian96 (обсуждение | вклад) Исправлена формула системы для нахождения коэффициентов кубических сплайнов, с источником на книгу |
Ksvsvk (обсуждение | вклад) →Построение: изменены индексы интервалов |
||
(не показаны 3 промежуточные версии 3 участников) | |||
Строка 19: | Строка 19: | ||
== Построение == |
== Построение == |
||
На каждом отрезке <math>[x_{i |
На каждом отрезке <math>[x_{i},x_{i+1}],\ i=\overline{0,N-1}</math> функция <math>S(x)</math> есть полином третьей степени <math>S_i(x)</math>, коэффициенты которого надо определить. Запишем для удобства <math>S_i(x)</math> в виде: |
||
:<math>S_i(x) = a_i + b_i(x - x_i) + {c_i}(x-x_i)^2 + {d_i}(x - x_i)^3</math> |
:<math>S_i(x) = a_i + b_i(x - x_i) + {c_i}(x-x_i)^2 + {d_i}(x - x_i)^3</math> |
||
Строка 28: | Строка 28: | ||
S'''_i\left(x_i\right) = 6d_i \quad i=\overline{1,N}.</math> |
S'''_i\left(x_i\right) = 6d_i \quad i=\overline{1,N}.</math> |
||
Условия непрерывности всех производных до второго порядка включительно |
Условия непрерывности всех производных, до второго порядка включительно, записываются в виде <br /> |
||
записываются в виде <br /> |
|||
:<math>S_i\left(x_{i-1}\right) = S_{i-1}(x_{i-1}),</math><br /> |
:<math>S_i\left(x_{i-1}\right) = S_{i-1}(x_{i-1}),</math><br /> |
||
:<math>S'_i\left(x_{i-1}\right) = S'_{i-1}(x_{i-1}),</math><br /> |
:<math>S'_i\left(x_{i-1}\right) = S'_{i-1}(x_{i-1}),</math><br /> |
||
Строка 48: | Строка 47: | ||
== Литература == |
== Литература == |
||
# {{книга | автор = de Boor, Carl | заглавие = A Practical Guide to Splines | издательство=Springer-Verlag | место=New York | год = 1978 | ref = Boor}} |
# {{книга | автор = de Boor, Carl | заглавие = A Practical Guide to Splines | ссылка = https://archive.org/details/practicalguideto0027debo | издательство=Springer-Verlag | место=New York | год = 1978 | ref = Boor}} |
||
# {{книга|автор=Роджерс Д., Адамс Дж.|заглавие=Математические основы машинной графики|издательство=Мир|место=М.|Издание=2-е, перераб. и доп.|станиц=604|год=2001|isbn=5-03-002143-4}} |
# {{книга|автор=Роджерс Д., Адамс Дж.|заглавие=Математические основы машинной графики|издательство=Мир|место=М.|Издание=2-е, перераб. и доп.|станиц=604|год=2001|isbn=5-03-002143-4}} |
||
# {{книга|автор=[[Костомаров, Дмитрий Павлович|Костомаров Д. П.]], [[Фаворский, Антон Павлович|Фаворский А. П.]]|заглавие=Вводные лекции по численным методам}} |
# {{книга|автор=[[Костомаров, Дмитрий Павлович|Костомаров Д. П.]], [[Фаворский, Антон Павлович|Фаворский А. П.]]|заглавие=Вводные лекции по численным методам}} |
Текущая версия от 06:38, 15 октября 2024
Кубический сплайн — гладкая функция, область определения которой разбита на конечное число отрезков, на каждом из которых она совпадает с некоторым кубическим многочленом (полиномом).
Описание
[править | править код]Функция задана на отрезке , разбитом на части , . Кубическим сплайном дефекта 1 (разность между степенью многочлена и порядком его производной) называется функция , которая:
- на каждом отрезке является многочленом степени не выше третьей;
- имеет непрерывные первую и вторую производные на всём отрезке ;
- в точках выполняется равенство , т. е. сплайн интерполирует функцию в точках .
Для однозначного задания сплайна перечисленных условий недостаточно, для построения сплайна необходимо наложить дополнительные требования — граничные условия:
- "Естественный сплайн" — граничные условия вида: ;
- Непрерывность второй производной — граничные условия вида: ;
- Периодический сплайн — граничные условия вида: и .
Теорема: Для любой функции и любого разбиения отрезка на части существует ровно один естественный сплайн , удовлетворяющий перечисленным выше условиям.
Эта теорема является следствием более общей теоремы Шёнберга-Уитни об условиях существования интерполяционного сплайна.
Построение
[править | править код]На каждом отрезке функция есть полином третьей степени , коэффициенты которого надо определить. Запишем для удобства в виде:
тогда
Условия непрерывности всех производных, до второго порядка включительно, записываются в виде
где меняется от до а условия интерполяции в виде
Обозначим
Отсюда получаем формулы для вычисления коэффициентов "Естественного сплайна":
- ;
- ;
- ;
- ,
- причем и [1].
Если учесть, что , то вычисление можно провести с помощью метода прогонки для трёхдиагональной матрицы.
Литература
[править | править код]- de Boor, Carl. A Practical Guide to Splines. — New York: Springer-Verlag, 1978.
- Роджерс Д., Адамс Дж. Математические основы машинной графики. — М.: Мир, 2001. — ISBN 5-03-002143-4.
- Костомаров Д. П., Фаворский А. П. Вводные лекции по численным методам.
- Волков Е. А. Глава 1. Приближение функций многочленами. § 11. Сплайны // Численные методы. — Учеб. пособие для вузов. — 2-е изд., испр.. — М.: Наука, 1987. — С. 63-68. — 248 с.
Ссылки
[править | править код]Примечания
[править | править код]- ↑ Аристова Е. Н., Завьялова Н. А., Лобанов А. И. Практические занятия по вычислительной математике Часть 1ISBN 978-5-7417-0541-4. . — 2014. — С. 159-160. — 243 с. —
- ↑ Boor, 1978.
Для улучшения этой статьи желательно:
|