Тригонометрическая интерполяция
Материал из MachineLearning.
(→Дискретное преобразование Фурье) |
(→Список литературы) |
||
(33 промежуточные версии не показаны) | |||
Строка 1: | Строка 1: | ||
+ | ==Постановка задачи== | ||
+ | Интерполяция - приблежение одной функции с помощью другой. Это может понадобиться в случае, когда вычислительно сложную функцию нужно заменить более легкой. Есть много видов метода интерполяции и способов их применения. Здесть мы рассмотрим особый вид интерполяции - тригонометрическую. На класс функций, при которых ее удобно использовать накладывается сильное ограничение - они должны быть периодическими, но более подробно об этом ниже. | ||
+ | |||
+ | Для использования математических формул для тригонометрической интерполяцией необходимо ознакомиться с теорией дискретного преобразования Фурье. | ||
+ | |||
==Дискретное преобразование Фурье== | ==Дискретное преобразование Фурье== | ||
- | В прикладных задачах часто используются различные преобразования Фурье функций непрерывного | + | В прикладных задачах часто используются различные преобразования Фурье функций непрерывного аргумента, а также представлений функций с помощью сходящихся тригонометрических рядов. |
- | Всякую непрерывно дифференцируемую | + | Всякую непрерывно дифференцируемую функцию <tex>f</tex> можно разложить в ряд Фурье: |
<tex>f(x)=\sum_{k=-\infty}^{\infty} \alpha_k exp{2\pi i k x}</tex> | <tex>f(x)=\sum_{k=-\infty}^{\infty} \alpha_k exp{2\pi i k x}</tex> | ||
- | коэффициенты <tex>\alpha_k</tex> находятся по | + | коэффициенты <tex>\alpha_k</tex> находятся по следующим формулам |
<tex>\alpha_k=\int \limits_{0}^{1} f(x) exp {-2 \pi i k x} dx</tex> | <tex>\alpha_k=\int \limits_{0}^{1} f(x) exp {-2 \pi i k x} dx</tex> | ||
- | Но как правила функция задана только в некоторых точках или у нас есть возможность узнать | + | Но как правила функция задана только в некоторых точках или у нас есть возможность узнать её значения только в некотором конечном числе точек. Допустим, <tex> x_j=j/N, j=0,1,\dots,N-1 </tex>.В этом случае аналогом функции непрерывной интерполяции функции будет дискретный вариант: |
<tex> f(x_j)=\sum_{k=0}^{N-1} \alpha_k exp{2\pi ikx_j}, 0\le j<N </tex> | <tex> f(x_j)=\sum_{k=0}^{N-1} \alpha_k exp{2\pi ikx_j}, 0\le j<N </tex> | ||
- | Разложение имеет место когда функцию можно приблизить тригонометрическим многочленом | + | Разложение имеет место когда функцию можно приблизить тригонометрическим многочленом следующего вида в заданных нам точках |
- | <tex>S_N(x)=\sum_{k=0}^{N-1}a_k exp{2 \pi ikx}</tex> | + | <tex>S_N(x)=\sum_{k=0}^{N-1}a_k exp{2 \pi ikx} </tex> |
Система функций <tex>\phi (x)=2\pi kx, 0\le k <N</tex> является ортогональной, на множестве точек <tex>x_j=j/N, 0\le j<N </tex> при том что <tex>(\phi_k,\phi_k)=N</tex>, таким образом разложение имеет место и коэффициенты <tex>a_k</tex> представляются в виде: | Система функций <tex>\phi (x)=2\pi kx, 0\le k <N</tex> является ортогональной, на множестве точек <tex>x_j=j/N, 0\le j<N </tex> при том что <tex>(\phi_k,\phi_k)=N</tex>, таким образом разложение имеет место и коэффициенты <tex>a_k</tex> представляются в виде: | ||
Строка 21: | Строка 26: | ||
<tex>a_k=\frac{1}{N} \sum_{l=0}^{N-1} f(x_l)exp{-2\pi ikx_l}, 0\le k<N</tex> | <tex>a_k=\frac{1}{N} \sum_{l=0}^{N-1} f(x_l)exp{-2\pi ikx_l}, 0\le k<N</tex> | ||
- | = | + | Далее для удобства записи будем использовать <tex>\omega=exp{2\pi i/N}</tex> |
- | + | ||
- | + | ||
- | + | Часто используется следующий вид формул: | |
- | + | <tex> f(x_j)=\sum_{-N/2<k\le N/2} a_k exp{2\pi ikx_j}, </tex> и это соответствует интерполяции тригонометрическим многочленом | |
- | + | <tex>S_N=\sum_{-N/2<k\le N/2}a_k exp{2\pi i kx}</tex>, | |
- | = | + | где коэффициенты <tex>a_k</tex> считаются по тем же формулам. |
+ | |||
+ | Если вычисления проводить по вышеприведённым формулам, то на выполнения каждого из преобразований потребуется <tex>N^2</tex> арифметических операций (считаем, что <tex>\omega=exp{2\pi i/N}</tex> уже вычислены). Если N не является простым числом, то количество операций можно значительно сократить, используя [[быстрое преобразование Фурье]]. | ||
==Пример использования== | ==Пример использования== | ||
+ | Рассмотрим применение тригонометрической интерполяции. | ||
+ | Будем использовать для приближения следующий тригонометрический полином: | ||
+ | |||
+ | <tex>\begin{matrix} F_n(x)=a_0 & + & a_1 \cos x + a_2 \cos 2x+\dots + a_n \cos nx + \\ \ &+&b_1 \sin x + b_2 \sin 2x+\dots + b_n \sin nx . \end{matrix}</tex> | ||
+ | |||
+ | Будем искать приближение функции f(x). Пусть известно значения <tex>f(\frac{2\pi j}{2n+1})=y_i</tex> при <tex>j\in \{-n,-n+1,\dots,0,1,\dots n\}</tex> | ||
+ | |||
+ | Тогда по формулам изложенным выше можно получить | ||
+ | <tex> | ||
+ | a_m= \frac{2}{2n+1} \sum_{j=-n}^n y_j \cos \left( \frac{2\pi jm}{2n+1} \right),\quad b_m= \frac{2}{2n+1} \sum_{j=-n}^n y_j \sin \left(\frac{2\pi jm}{2n+1} \right) </tex> | ||
+ | |||
+ | Если интерполировать тригонометические функции и выбирать правильное число узлов, то погрешность приближается к нулю. Интересно рассмотреть функции, не являющиеся тригонометрическими, но обладающие периодом. Рассмотрим ряд вычислений приближенных функций с помощью программы, использующей выше изложенный алгоритм апроксимации. | ||
+ | На вход подается функция и количество точек на промежутке <tex>[-\pi;\pi]</tex>, точки по умолчанию расположены равномерно на промежутке. Как будет показано ниже, это соответсвует наилучшей аппроксимации. | ||
+ | |||
+ | Тригонометрическая функция с шумом | ||
+ | |||
+ | На вход подавалась функция <tex>sin(5*x)+cos(x)+rand()</tex>, (пусть под 'rand()' понимается некоторая шумовая функция). | ||
+ | Вычислияем значение функции в 5 точках. По графику ('Рис.1')видно, что аппроксимация произвендена достаточно точно. | ||
+ | |||
+ | [[Изображение:Slide1.gif|||Рис.1]] | ||
+ | |||
+ | Выход : коэффициенты <tex>a_n, b_n</tex>, чтоб можно было восстановить многочлен с помощью других вычислительных инструментов. | ||
+ | Также ряд значений функции на промежутке <tex>[-\pi,\pi]</tex>. Количество точек запрашивается у пользователя. | ||
+ | |||
+ | Не тригонометрическая кусочно-заданная функция | ||
+ | |||
+ | Попробуем приблизить кусочно-заданную функцию с помощью тригонометрической интерполяций, зная ее значения в конечном числе точек. (Такую функцию можно разложить точно, используя обычное преобразование Фурье). При тригонометрической интерполяции строится многочлен, число тригонометрических функций которого определяется числом узлов интерполяции. Таким образом, чем больше мы возьмем точек интерполяции мы возьмем, тем лучще мы приблизимся к виду разложения Фурье. | ||
+ | |||
+ | [[Изображение:kusochnozadannaya.png|||Рис.2]] | ||
+ | |||
+ | На вход программе подавалась кусочно-заданная функция <tex> \pi<x<-1.5 y=1, -1.5<x<1.6 y=0, 1.6<x<\pi </tex>, функция подразумевается периодической с периодом <tex>\pi</tex>. Для вычисления полинома бралось 25 точек. На Рис.2 приведен график функциии и график интерполирующего полинома. На Рис.4 приведен график ошибки интерполяции. | ||
+ | |||
+ | [[Изображение:Error1.png|||Рис.3]] | ||
+ | |||
+ | Как видно из графика функции ошибки она максимальна на а районе концлв промежутка. | ||
+ | |||
+ | ==Погрешность вычислений== | ||
+ | Для минимизации погрешность вычислений в методе тригонометрической интерполяции лучше всего использовать узлы Чебышева. | ||
+ | |||
+ | ==Программная реализация== | ||
+ | В данной программной реализации функция занесена в код программы, по этому в исполняемом файле не может быть изменена. Но при необходимости можно править код С++ и реализовывать необходимые функции. | ||
+ | |||
+ | [[Media:Trigonometric interpolation.zip|Реализация программы на языке С++]] | ||
+ | |||
+ | [[Media:Text_trig.zip|Код программы на языке С++]] | ||
==Список литературы== | ==Список литературы== | ||
+ | |||
+ | * ''А.А.Самарский, А.В.Гулин.'' Численные методы М.: Наука, 1989. | ||
+ | * ''А.А.Самарский.'' Введение в численные методы М.: Наука, 1982. | ||
+ | |||
+ | == См. также == | ||
+ | * [[Интерполяция каноническим полиномом]] | ||
+ | * [[Рациональная интерполяция]] | ||
+ | * [[Интерполяция функций двух переменных, проблема выбора узлов | Проблема выбора узлов для интерполяции]] | ||
+ | * [[Практикум ММП ВМК, 4й курс, осень 2008]] | ||
+ | |||
+ | |||
+ | {{Заготовка}} | ||
+ | [[Категория:Учебные задачи]] |
Текущая версия
Содержание[убрать] |
Постановка задачи
Интерполяция - приблежение одной функции с помощью другой. Это может понадобиться в случае, когда вычислительно сложную функцию нужно заменить более легкой. Есть много видов метода интерполяции и способов их применения. Здесть мы рассмотрим особый вид интерполяции - тригонометрическую. На класс функций, при которых ее удобно использовать накладывается сильное ограничение - они должны быть периодическими, но более подробно об этом ниже.
Для использования математических формул для тригонометрической интерполяцией необходимо ознакомиться с теорией дискретного преобразования Фурье.
Дискретное преобразование Фурье
В прикладных задачах часто используются различные преобразования Фурье функций непрерывного аргумента, а также представлений функций с помощью сходящихся тригонометрических рядов. Всякую непрерывно дифференцируемую функцию можно разложить в ряд Фурье:
коэффициенты находятся по следующим формулам
Но как правила функция задана только в некоторых точках или у нас есть возможность узнать её значения только в некотором конечном числе точек. Допустим, .В этом случае аналогом функции непрерывной интерполяции функции будет дискретный вариант:
Разложение имеет место когда функцию можно приблизить тригонометрическим многочленом следующего вида в заданных нам точках
Система функций является ортогональной, на множестве точек при том что , таким образом разложение имеет место и коэффициенты представляются в виде:
Далее для удобства записи будем использовать
Часто используется следующий вид формул:
и это соответствует интерполяции тригонометрическим многочленом
,
где коэффициенты считаются по тем же формулам.
Если вычисления проводить по вышеприведённым формулам, то на выполнения каждого из преобразований потребуется арифметических операций (считаем, что уже вычислены). Если N не является простым числом, то количество операций можно значительно сократить, используя быстрое преобразование Фурье.
Пример использования
Рассмотрим применение тригонометрической интерполяции. Будем использовать для приближения следующий тригонометрический полином:
Будем искать приближение функции f(x). Пусть известно значения при
Тогда по формулам изложенным выше можно получить
Если интерполировать тригонометические функции и выбирать правильное число узлов, то погрешность приближается к нулю. Интересно рассмотреть функции, не являющиеся тригонометрическими, но обладающие периодом. Рассмотрим ряд вычислений приближенных функций с помощью программы, использующей выше изложенный алгоритм апроксимации. На вход подается функция и количество точек на промежутке , точки по умолчанию расположены равномерно на промежутке. Как будет показано ниже, это соответсвует наилучшей аппроксимации.
Тригонометрическая функция с шумом
На вход подавалась функция , (пусть под 'rand()' понимается некоторая шумовая функция). Вычислияем значение функции в 5 точках. По графику ('Рис.1')видно, что аппроксимация произвендена достаточно точно.
Выход : коэффициенты , чтоб можно было восстановить многочлен с помощью других вычислительных инструментов. Также ряд значений функции на промежутке . Количество точек запрашивается у пользователя.
Не тригонометрическая кусочно-заданная функция
Попробуем приблизить кусочно-заданную функцию с помощью тригонометрической интерполяций, зная ее значения в конечном числе точек. (Такую функцию можно разложить точно, используя обычное преобразование Фурье). При тригонометрической интерполяции строится многочлен, число тригонометрических функций которого определяется числом узлов интерполяции. Таким образом, чем больше мы возьмем точек интерполяции мы возьмем, тем лучще мы приблизимся к виду разложения Фурье.
На вход программе подавалась кусочно-заданная функция , функция подразумевается периодической с периодом . Для вычисления полинома бралось 25 точек. На Рис.2 приведен график функциии и график интерполирующего полинома. На Рис.4 приведен график ошибки интерполяции.
Как видно из графика функции ошибки она максимальна на а районе концлв промежутка.
Погрешность вычислений
Для минимизации погрешность вычислений в методе тригонометрической интерполяции лучше всего использовать узлы Чебышева.
Программная реализация
В данной программной реализации функция занесена в код программы, по этому в исполняемом файле не может быть изменена. Но при необходимости можно править код С++ и реализовывать необходимые функции.
Реализация программы на языке С++
Список литературы
- А.А.Самарский, А.В.Гулин. Численные методы М.: Наука, 1989.
- А.А.Самарский. Введение в численные методы М.: Наука, 1982.
См. также
- Интерполяция каноническим полиномом
- Рациональная интерполяция
- Проблема выбора узлов для интерполяции
- Практикум ММП ВМК, 4й курс, осень 2008