Быстрое преобразование Фурье — различия между версиями
(→Описание задачи) |
|||
| Строка 1: | Строка 1: | ||
{{Определение | {{Определение | ||
|definition= | |definition= | ||
| − | '''Быстрое преобразование Фурье''' (англ. ''Fast Fourier Transform | + | '''Быстрое преобразование Фурье''' (англ. ''Fast Fourier Transform, FFT'') {{---}} метод, позволяющий вычислять [[Дискретное преобразование Фурье | дискретное преобразование Фурье]] за время <tex>O(n \log n)</tex>. |
}} | }} | ||
| Строка 33: | Строка 33: | ||
| − | Мы разбили исходный многочлен на два многочлена, имеющих вдвое меньшую степень. Нам необходимо по вычисленным <tex>DFT(A_0)</tex> и <tex>DFT(A_1)</tex> за линейное время вычислить <tex>DFT(A)</tex>. Так как здесь используется идея "разделяй и властвуй", то асимптотическая оценка будет <tex>O( | + | Мы разбили исходный многочлен на два многочлена, имеющих вдвое меньшую степень. Нам необходимо по вычисленным <tex>DFT(A_0)</tex> и <tex>DFT(A_1)</tex> за линейное время вычислить <tex>DFT(A)</tex>. Так как здесь используется идея "разделяй и властвуй", то асимптотическая оценка будет <tex>O(n \log n)</tex>. |
| − | Пусть <tex>DFT(A_0) = \{y_k^0\}^{\frac{n}{2}-1}_{k=0}</tex> и <tex>DFT(A_1) = \{y_k^1\}^{\frac{n}{2} - 1}_{k=0}</tex>. Найдем вектор значений <tex>DFT(A) = \{y_k\}^{n-1}_{k=0}</tex>. | + | Пусть <tex>DFT(A_0) = \{y_k^0\}^{\frac{n}{2}-1}_{k=0}</tex> и <tex>\mathrm{DFT}(A_1) = \{y_k^1\}^{\frac{n}{2} - 1}_{k=0}</tex>. Найдем вектор значений <tex>\mathrm{DFT}(A) = \{y_k\}^{n-1}_{k=0}</tex>. |
* Из <tex>(1)</tex> получаем значения для первой половины коэффициентов: | * Из <tex>(1)</tex> получаем значения для первой половины коэффициентов: | ||
<center><tex>y_k = y_k^0 + \omega^k_n y_k^1, \ \ k = 0 \ldots \dfrac{n}{2} - 1 </tex></center> | <center><tex>y_k = y_k^0 + \omega^k_n y_k^1, \ \ k = 0 \ldots \dfrac{n}{2} - 1 </tex></center> | ||
Версия 23:33, 14 декабря 2016
| Определение: |
| Быстрое преобразование Фурье (англ. Fast Fourier Transform, FFT) — метод, позволяющий вычислять дискретное преобразование Фурье за время . |
Содержание
Описание задачи
| Задача: |
| Необходимо научиться вычислять прямое и обратное дискретное преобразование Фурье многочлена степени за время . |
Метод основывается на том, что степени одних комплексных корней единицы в степени дают другие.
Идея заключается в том, что сначала мы разделяем вектор коэффициентов на два вектора, рекурсивно вычисляем значение ДПФ для них, и объединяем их в одно ДПФ.
Алгоритм построения БПФ
Пусть имеется многочлен степени , где . Если не является степенью двойки, добавим недостающие члены и положим коэффициенты равными нулю.
Разделим на два многочлена, где один будет с четными, а другой с нечетными коэффициентами:
Многочлен получается из и следующим образом:
Мы разбили исходный многочлен на два многочлена, имеющих вдвое меньшую степень. Нам необходимо по вычисленным и за линейное время вычислить . Так как здесь используется идея "разделяй и властвуй", то асимптотическая оценка будет .
Пусть и . Найдем вектор значений .
- Из получаем значения для первой половины коэффициентов:
- Для второй половины получаем:
Заметим, что , тогда:
Таким образом, мы получили:
Алгоритм построения обратного БПФ
Пусть вектор — значения многочлена степени в точках . Необходимо, по данному вектору восстановить коэффициенты многочлена.
Рассмотрим ДПФ в матричном виде:
Отсюда можно найти вектор , умножив вектор на матрицу обратную матрице Вандермонда (матрица слева).
Непосредственной проверкой можно убедиться, что обратная матрица имеет вид:
Получаем формулу для :
Аналогично прямому ДПФ, по принципу разделяй и властвуй посчитаем .