Дискретное преобразование Фурье — различия между версиями
Shersh (обсуждение | вклад) м (→Применение ДПФ) |
|||
Строка 29: | Строка 29: | ||
Для того чтобы получить произведение двух многочленов за время, меньшее чем <tex>O(n^2)</tex>, необходимо сначала посчитать <tex>DFT</tex> обоих многочленов. Так как при умножении двух многочленов их значения просто перемножаются в каждой точке. Следовательно, если <tex>DFT</tex> {{---}} это вектор значений многочлена, то мы можем получить значение произведения двух многочленов, просто перемножив их ДПФ. Значит, чтобы получить коэффициенты полученного многочлена, применим обратное ДПФ. | Для того чтобы получить произведение двух многочленов за время, меньшее чем <tex>O(n^2)</tex>, необходимо сначала посчитать <tex>DFT</tex> обоих многочленов. Так как при умножении двух многочленов их значения просто перемножаются в каждой точке. Следовательно, если <tex>DFT</tex> {{---}} это вектор значений многочлена, то мы можем получить значение произведения двух многочленов, просто перемножив их ДПФ. Значит, чтобы получить коэффициенты полученного многочлена, применим обратное ДПФ. | ||
+ | <center> | ||
<tex> | <tex> | ||
A \times B = InvDFT(DFT(A) \times DTF(B)). | A \times B = InvDFT(DFT(A) \times DTF(B)). | ||
</tex> | </tex> | ||
+ | </center> | ||
Так как ДПФ многолчена {{---}} это вектор его значений, значит, перемножение двух ДПФ требует только <tex>O(n)</tex> операций. Осталось только вычислять ДПФ и обратное ДПФ за время <tex>O(n)</tex>. Для этого используем [[Быстрое преобразование Фурье| быстрое преобразование Фурье]]. | Так как ДПФ многолчена {{---}} это вектор его значений, значит, перемножение двух ДПФ требует только <tex>O(n)</tex> операций. Осталось только вычислять ДПФ и обратное ДПФ за время <tex>O(n)</tex>. Для этого используем [[Быстрое преобразование Фурье| быстрое преобразование Фурье]]. |
Версия 19:23, 4 декабря 2016
Определение: |
Дискретное преобразование Фурье (англ. Discrete Fourier Transform (DFT)) — многочлена где — ый из комплексных корней из единицы. называется главным значением корня -ой степени из единицы, а все остальные корни являются его степенями: . | называют вектор значений этого многочлена в точках :
Определение: |
Обратное дискретное преобразование Фурье (англ. Inverse DFT) для вектора значений многочлена
| — это вектор коэффициентов этого многочлена :
Применение ДПФ
Дискретное преобразование Фурье используют для быстрого перемножения двух полиномов
и .Для того чтобы получить произведение двух многочленов за время, меньшее чем
, необходимо сначала посчитать обоих многочленов. Так как при умножении двух многочленов их значения просто перемножаются в каждой точке. Следовательно, если — это вектор значений многочлена, то мы можем получить значение произведения двух многочленов, просто перемножив их ДПФ. Значит, чтобы получить коэффициенты полученного многочлена, применим обратное ДПФ.
Так как ДПФ многолчена — это вектор его значений, значит, перемножение двух ДПФ требует только быстрое преобразование Фурье.
операций. Осталось только вычислять ДПФ и обратное ДПФ за время . Для этого используемДПФ в модульной арифметике
В основе ДПФ используются комплексные числа, являющиеся корнями
-ой степени из единицы. Для эффективного вычисления использовались свойства комплексных корней, которые образуют группу, то есть степень одного корня всегда является другим корнем. Среди них есть корень, называемый примитивным.Однако, то же верно и в случае корней
-ой степени из единицы в модульной арифметике. Не для любого модуля найдется различных корней, но такие модули все же существуют. Необходимо найти примитивный корень, то есть:
Как и с комплексными корнями, остальные
корней -ой степени из единицы по модулю можно получить как степени примитивного корня