Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Пособ_ЦОС_1.doc
Скачиваний:
50
Добавлен:
14.04.2019
Размер:
2.47 Mб
Скачать

3.2.1. Бпф по смешанному основанию

ДПФ последовательности , N = N1 N2 запишется в виде

.

Представим входные n и выходные k индексы в смешанной системе счисления с основаниями N1 N2:

; , где , .

Последовательности входных и выходных отсчетов преобразуются в двумерные массивы:

, , ;

, , .

После подстановки алгоритм ДПФ представляется в виде

(53)

Таким образом, исходное ДПФ оказалось сведенным к двум ДПФ, производимым над уменьшенными массивами. Алгоритм преобразования может быть представлен следующей трехэтапной схемой.

  1. Для всех строк матрицы вычисляются N2 точечные ДПФ.

  2. Каждый элемент полученной матрицы умножается на фазовый множитель .

  3. Для всех столбцов матрицы, полученной на втором этапе, вычисляются N1 точечные ДПФ.

Заметим, что алгоритм имеет инверсный порядок следования индексов в выходной последовательности. Это объясняется инверсией разрядов в позиционно-численном представлении индексов по смешанному основанию. Для сохранения естественного порядка следования отсчетов необходимо выполнить операцию обратной перестановки.

Вычислительные затраты при таком способе вычисления ДПФ равны: количество операций умножения равно ; сложений .

Если числа N1 и N2 являются составными, то алгоритм БПФ применяется рекурсивно. При этом на каждом шаге рекурсии БПФ сокращает число операций.

Пример. Пусть N = 6 = 23, N1 = 2, N2 = 3. Входная последовательность имеет вид

{x[n]; n = 0,..,5} = [1,1,1,-1,-1,-1]. Требуется вычислить ДПФ по смешанному основанию.

Элемент матрицы двумерного массива в этом случае равен

d[n1,n2] = x[2n2 +n1], n1=0,1; n2 = 0,1,2.

Сама матрица имеет вид

.

На первом этапе алгоритма вычислений, строки матрицы входных отсчетов преобразуются с помощью трехточечного ДПФ. В результате получаем матрицу

.

После умножения элементов этой матрицы на поворачивающие множители , k2 = 0,1,2, получаем матрицу

.

Применение двухточечного ДПФ к столбцам матрицы, полученной на втором этапе, приводит к следующему результату

Спектр ДПФ равен

.

Описанный алгоритм предпочтительнее непосредственного прямого вычисления ДПФ, поскольку при этом требуется меньше арифметических операций. Действительно, сложность алгоритма ДПФ по смешанному основанию определяется сложностью вычислений N1 ДПФ размера N2 , N2 ДПФ размера N1 и N1 N2 умножений на фазовые множители. Вычислительные затраты при таком способе вычисления ДПФ равны: количество операций умножения равно ; сложений . Прямое вычисление ДПФ потребовало бы N2 операций комплексного умножения и N(N-1 ) операций комплексного сложения.

Если числа N1 и N2 являются составными, то алгоритм БПФ применяется рекурсивно. При этом на каждом шаге рекурсии БПФ сокращает число операций.

3.2.2. Алгоритм Гуд-Томаса

Рассмотрим случай, когда необходимо вычислить N-точечное ДПФ, причем N=N1N2 и числа N1 и N2 являются взаимно простыми, т.е. НОД(N1N2)=1. В этом случае применим алгоритм Гуд-Томаса (ГТ) с использованием простых делителей. Используется отображение обрабатываемой последовательности в двумерную таблицу, позволяющая использовать двумерное преобразование Фурье.

Отобразим последовательности входных x[n] и выходных X(k) отсчетов в двумерные массивы

по следующим правилам:

- для индексов входного сигнала

; (54)

-для индексов выходного сигнала

. (55)

Обоснованность применения такого отображения доказывается следующим образом. Согласно китайской теоремы об остатках [ 1 ] существуют такие целые m1 и m2, что выполняется равенство , где . С другой стороны, для индексов выходного сигнала справедливо равенство

,

где Q1 целая часть, дополняющая k1 до k; Q2-целая часть, дополняющая k2 до k.

ДПФ двумерного массива данных запишется как

(56)

С учетом того, что и получаем

и

.

Теперь видно, что ДПФ двумерного массива входных данных можно вычислить с помощью двумерного ДПФ

. (57)

Элементы  и  являются простыми корнями из единицы степеней N1 и N2 , задающие соответственно N1 –точечное и N2-точечное преобразования Фурье.

Вычислительная сложность алгоритма оценивается как N(N1 + N2) операций умножений и сложений.

Пример. Необходимо вычислить ДПФ последовательности {x[n]; n=0,…,5} = (1,1,1,-1,-1,-1) с использованием алгоритма ГТ.

Длину обрабатываемых отсчетов N можно разложить на два взаимно простых множителя множителя

N = 23 = N1N2, N1 = 2, N2 = 3; НОД (N1,N2) = 1.

Алгоритм ГТ запишется как

,

n1 = 0,…,N1 , n2 = 0,…,N2 ; k1 = 0,…,N1 , k2 = 0,…,N2

Перестановка входных данных имеет вид:

n = n1 m2 N2 + n2 m1 N1 = n1 m2 3 + n2 m1 2,

где коэффициенты m1 и m2 определяются из решения диофантового уравнения

m2 N2 + m1N1 = 1  m2 3 + m12 = 1

Для решения диофантового уравнения применим алгоритм Евклида

3 = 21 + 1 или 1 = (1)3 + (-1)2,

откуда получаем, что m1= -1 и m2 = 1.

Матрица данных после перестановки имеет вид

Матрица внутреннего ДПФ равна

, k2 = 0,…,N2, n2 = 0,…,N2.

Вычисление внутреннего ДПФ приводит к результату

Матрица внешнего ДПФ равна

, k1 = 0,…,N1, n1 = 0,…,N1.

В результате вычисления внешнего ДПФ получаем

Связь выходных отсчетов преобразования ГТ {X(k1,k2)} и отсчетов прямого ДПФ {X(k)} определяется исходя из соотношения

k = k1 N2 + k2 N1 mod N

и имеет вид

.

Откуда получаем значения спектральных коэффициентов прямого ДПФ

.