Векторный алгоритм БПФ - Vector-radix FFT algorithm

В векторный алгоритм БПФ, является многомерным быстрое преобразование Фурье (БПФ), который является обобщением обычного Алгоритм Кули – Тьюки БПФ который делит размеры преобразования на произвольные корни. Он ломает многомерное (МД) дискретное преобразование Фурье (DFT) вниз на последовательно меньшие MD DFT, пока, в конечном итоге, не потребуется оценивать только тривиальные MD DFT.[1]

Наиболее распространенные многомерные БПФ Алгоритм - это алгоритм строка-столбец, что означает преобразование массива сначала в один индекс, а затем в другой, подробнее см. БПФ. Затем было разработано прямое двумерное БПФ с основанием 2,[2] и он может исключить 25% умножений по сравнению с традиционным методом «строка-столбец». И этот алгоритм был расширен на прямоугольные массивы и произвольные корни,[3] который является общим алгоритмом векторной системы счисления.

Алгоритм вектор-основание БПФ может значительно уменьшить количество сложных умножений по сравнению с алгоритмом вектор-строка. Например, для элементной матрицы (размерности M и размер N в каждом измерении), количество комплексных кратных векторно-основному алгоритму БПФ для системы счисления-2 равно между тем, для алгоритма строка-столбец это . И, как правило, еще большая экономия на умножениях достигается, когда этот алгоритм работает с большими корнями и с массивами более высокой размерности.[3]

В целом алгоритм векторной системы счисления значительно снижает структурную сложность традиционного DFT, имеющего лучшую схему индексации, за счет небольшого увеличения арифметических операций. Таким образом, этот алгоритм широко используется во многих приложениях в области инженерии, науки и математики, например, для реализации в обработке изображений,[4] и проектирование высокоскоростного процессора БПФ.[5]

Случай 2-D DIT

Как и с Алгоритм Кули – Тьюки БПФ, двумерное векторно-основанное БПФ получается путем разложения обычного двумерного ДПФ на суммы меньших ДПФ, умноженных на множитель "твидла".

Прореживание во времени (DIT) означает, что разложение основано на временной области , см. больше в Алгоритм Кули – Тьюки БПФ.

Мы предполагаем, что 2-DFT

где , и это матрица и .

Для простоты предположим, что , и основание-( целые числа).

Используя замену переменных:

  • , где
  • , где

где или , то двумерное ДПФ можно записать как:[6]

Одноступенчатая "бабочка" для DIT вектор-основание 2x2 FFT

Приведенное выше уравнение определяет базовую структуру системы счисления 2-D DIT - «бабочка». (См. 1-D «бабочка» в Алгоритм Кули – Тьюки БПФ )

Когда , уравнение можно разбить на четыре суммирования: одно по тем выборкам x, для которых оба и четные, для которых даже и нечетный, один из которых это странно и четный, и тот, для которого оба и странные,[1] и это приводит к:

где

2-DIF корпус

Точно так же децимация по частоте (DIF, также называемый алгоритмом Санде – Тьюки) означает, что разложение основано на частотной области , см. больше в Алгоритм Кули – Тьюки БПФ.

Используя замену переменных:

  • , где
  • , где

где или , а уравнение ДПФ можно записать как:[6]

Другие подходы

В алгоритм БПФ с разделенным основанием оказался полезным методом для 1-DFT. И этот метод был применен к БПФ с векторной системой счисления, чтобы получить БПФ с разделенной векторной системой счисления.[6][7]

В обычном двумерном векторно-системном алгоритме мы разлагаем индексы на 4 группы:

С помощью алгоритма разделения вектор-основание системы первые три группы остаются неизменными, четвертая нечетно-нечетная группа далее разлагается на еще четыре подгруппы и всего семь групп:

Это означает, что четвертый член в системе счисления 2-D DIT - уравнение, становится:[8]

где

Затем 2-мерное N на N DFT получается путем последовательного использования вышеупомянутого разложения вплоть до последнего этапа.

Было показано, что алгоритм системы счисления разбиения вектора сэкономил около 30% сложных умножений и примерно такое же количество сложных сложений для типичных массив по сравнению с алгоритмом векторной системы счисления.[7]

использованная литература

  1. ^ а б Даджен, Дэн; Рассел, Мерсеро (сентябрь 1983 г.). Многомерная цифровая обработка сигналов. Прентис Холл. п. 76. ISBN  0136049591.
  2. ^ Ривард, Г. (1977). «Прямое быстрое преобразование Фурье двумерных функций». Транзакции IEEE по акустике, речи и обработке сигналов. 25 (3): 250–252. Дои:10.1109 / ТАССП.1977.1162951.
  3. ^ а б Harris, D .; McClellan, J .; Chan, D .; Шуесслер, Х. (1977). «Быстрое преобразование Фурье с векторной системой счисления». Международная конференция IEEE по акустике, речи и обработке сигналов, ICASSP '77. 2: 548–551. Дои:10.1109 / ICASSP.1977.1170349.
  4. ^ Buijs, H .; Pomerleau, A .; Fournier, M .; Там, В. (декабрь 1974 г.). «Реализация быстрого преобразования Фурье (БПФ) для приложений обработки изображений». Транзакции IEEE по акустике, речи и обработке сигналов. 22 (6): 420–424. Дои:10.1109 / ТАССП.1974.1162620.
  5. ^ Бадар, С .; Дандекар, Д. (2015). «Разработка высокоскоростного процессора БПФ с использованием конвейерной архитектуры radix −4». 2015 Международная конференция по промышленным контрольно-измерительным приборам (ICIC), Пуна, 2015 г.: 1050–1055. Дои:10.1109 / IIC.2015.7150901. ISBN  978-1-4799-7165-7.
  6. ^ а б c Chan, S.C .; Хо, К. Л. (1992). «Быстрое преобразование Фурье с разделением вектора на основание». Транзакции IEEE при обработке сигналов. 40 (8): 2029–2039. Bibcode:1992ITSP ... 40.2029C. Дои:10.1109/78.150004.
  7. ^ а б Пей, Су-Чанг; Ву, Джа-Линь (апрель 1987 г.). «Расщепление векторной системы счисления 2D быстрое преобразование Фурье». Международная конференция IEEE по акустике, речи и обработке сигналов, ICASSP '87. 12: 1987–1990. Дои:10.1109 / ICASSP.1987.1169345.
  8. ^ Wu, H .; Паолони, Ф. (август 1989 г.). «О двумерном векторном алгоритме БПФ с разделенным основанием». Транзакции IEEE по акустике, речи и обработке сигналов. 37 (8): 1302–1304. Дои:10.1109/29.31283.