Описание программного модуля быстрого преобразования Фурье
Объяснение работы быстрого преобразования Фурье и исследование специфики реализации на программируемых логических интегральных схемах. Особенности и принципы его реализации реализуется в основном с помощью цифровой программной обработки сигналов.
Рубрика | Математика |
Вид | статья |
Язык | русский |
Дата добавления | 10.08.2018 |
Размер файла | 231,8 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru/
Размещено на http://www.allbest.ru/
Описание программного модуля быстрого преобразования Фурье
Быстрое преобразование Фурье (БПФ) является ключевым алгоритмом в современной цифровой обработке сигналов (ЦОС) - это общее имя любого метода для уменьшения вычислительной сложности дискретного преобразования Фурье (ДПФ). Первая теоретическая работа над БПФ принадлежит немецкому математику К.Ф. Гаусу. Широкое использование БПФ началось после публикации в 1965 году статьи Д. Кули и Дж. Туки с оригинальным описанием алгоритма (Cooley-Tukey FFT Algorithm). Компьютеры того времени уже справлялись с задачей практической реализации БПФ, но метод Кули-Туки позволил ускорить расчеты в 5-6 раз. Поскольку схема компьютеров значительно изменилась, появились новые алгоритмы для вычисления БПФ, но алгоритм Кули-Тьюки остается популярным.
В настоящее время БПФ реализуется в основном с помощью ЦПОС и ПЛИС. Значительное увеличение емкости и производительности микросхем программируемой логики облегчает реализацию алгоритмов БПФ. Статья содержит описание модуля быстрого преобразования Фурье, предназначенного для семейства ПЛИС Xilinx. Как упоминалось выше, БПФ является алгоритмом для вычисления ДПФ, который является методом разложения дискретного периодического сигнала в ряд тригонометрических функций. Теоретический метод был разработан французским физиком и математиком Ж.Б. Фурье, который доказал, что любой дискретный периодический сигнал может быть представлен комбинацией простых тригонометрических функций (синус и косинус).
Существует два типа преобразований Фурье - действительный ДПФ и комплексный ДПФ. Для реализации БПФ необходимо использовать комплексный ДПФ. Предположим, что введен дискретный сигнал X (k), состоящий из N выборок. ДПФ будет выглядеть следующим образом:
сигнал фурье преобразование программный
Комплексные уравнения компонентов WN в английской литературе часто называют фактором twiddle factor (поворачивающий коэффициент), и также могут быть выражены комбинацией синусов и косинусов:
Количество входных выборок N обычно равно степени 2, хотя доступны методы для расчета БПФ для произвольного количества входных выборок. При малом значении N время вычисления ДПФ прямым методом и методом БПФ сопоставимы. Однако с увеличением размерности входного сигнала преимущества БПФ в скорости вычислений могут достигать сотен раз. Рассмотрим более подробно реализацию метода БПФ, Кули-Туки для входного сигнала с размером 128 выборок.
Суть БПФ заключается в том, что входной сигнал имеет большую размерность N, в этом случае 128 делится на N сигналов одного измерения. Затем для каждого отдельного сигнала рассчитывают спектр, то есть происходит переход от временной области к частотной области. На последнем этапе N отдельных спектров объединяются в один спектр. Первый этап разделения входного сигнала называется декомпозицией. Он применяет так называемую бит-реверсную адресацию. Например, отсчеты входного сигнала нумеруются в порядке 0, 1, 2, 3 и т.д.
Для формирования бит-реверсной последовательности необходимо единицы адреса отсчёта в двоичной форме переставить в обратном порядке, как показано в таблице. Для адресации 128 выборок требуется семь битов адреса. В таблице показаны первые девять отсчетов, все остальные счетчики бит-реверсального адреса вычисляются аналогичным образом. После бит-реверной сортировки входные отсчеты должны выполняться в порядке 0, 64, 32, 96, 16, 80 и т.д. А затем для каждого отдельного сигнала рассчитывается спектр. На данном этапе, не требуется каких-либо действий программного обеспечения, так как спектр одного сигнала равен соответствующиму ДПФ базисного сигнала. Последний шаг БПФ состоит в объединении отдельных спектров. Этот шаг является самым сложным и требует нескольких этапов. Основная операция объединения спектров, показанных на рисунке 1, называется «бабочкой» (butterfly).
Рисунок 1. Базовая операция БПФ
Алгоритм, в котором операция «бабочка» выполняется одновременно для двух входных сигналов, называемых БПФ с основанием 2. Этот алгоритм рассматривается в этой статье. Другим распространненым основанием БПФ является 4. Операция «бабочка», в свою очередь, состоит из нескольких этапов. Сначала второй входной сигнал IN2 умножается на коэффициент WN (коэффициент поворота). Затем первый выходной сигнал OUT1 получается путем суммирования результата умножения первого входного сигнала IN1. Второй выходной сигнал представляет собой разность между первым входным сигналом IN1 и результатом умножения. Для полной унификации размерности спектра N выборок требуется log2N циклов операций «бабочка». Когда размеры 128 требуют 7 циклов, и каждый цикл состоит из 64 операций, так как при основании 2 одна базовая операция БПФ включает в себя два входных отсчета.
Полная схема БПФ для 128 выборок довольно громоздка, поэтому на рисунке 2 в качестве примера показана схема БПФ для 8 выборок, которая состоит из трех циклов (log28). В зависимости от процедуры использования коэффициентов поворота и операций «бабочка» различают БПФ с прореживанием во времени и БПФ прореживанием по частоте. На рисунке 2 показан алгоритм с прореживанием во времени, тот же алгоритм реализован в модуле для ПЛИС; видно, что входные выборки сортируются в соответствии с обращением бит-реверсного адреса. Во время первого цикла для всех «бабочек», используюется тот же самый коэффициент поворота W0. Пары отсчетов для второго цикла формируются согласно рисунку 2, поэтому поворачивающие коэффициенты начинают чередоваться: для первой «бабочки» коэффициент W0, а для второй - W2, третьего и четвертого - коэффициенты W0 и W2 соответственно.
Рисунок 2. БПФ для 8-ми разрядного входного сигнала
сигнал фурье преобразование программный
В течение третьего цикла используются все коэффициенты поворота W0 - W3. Обратите внимание, что общее количество коэффициентов twiddle равно половине размерности входного сигнала, то есть для ввода размерности 128 выборок потребуется 64 коэффициента. Пары сигналов в этом случае будут сформированы аналогично БПФ для 8 образцов. В течение первого цикла умножение будет выполняться с коэффициентом поворота W0, тогда как второй цикл будет чередовать коэффициенты W0 и W32, в течение третьего цикла будут чередовать коэффициенты W0-W16-W32-W48, в течение четвертого цикла W0-W8 - W16-W24-W32-W40-W48-W56.
Таким образом, количество задействованных коэффициентов будет увеличиваться, и в течение последнего седьмого цикла будет задействован весь 64 поворачивающих коэффициента.
В настоящее время существует большое количество алгоритмов БПФ с разной производительностью, размерами, вычислительными ресурсами и другими параметрами. Важной характеристикой реализации алгоритма БПФ является арифметика, используемая для расчетов (плавающая или фиксированная точка). Реализация алгоритма с плавающей точкой имеет высокую точность, но является сложным и дорогостоящим вычислительным ресурсом. В приложениях, которые не требуют высокой точности, более простая реализация алгоритма БПФ с фиксированной точкой оправдана, так как для этого требуется меньшее количество ресурсов, что важно для ПЛИС. Модуль БПФ, описанный в статье, показал удовлетворительные результаты в тестировании и подходит для приложений, которые не требуют высокой точности.
Размещено на Allbest.ru
...Подобные документы
Свойства дискретного преобразования Фурье, представленные в виде математических формул, которые наиболее адекватно соответствуют цифровой технике обработки информации. Алгоритм быстрого преобразования Фурье (БПФ), его значение для программирования.
учебное пособие [223,6 K], добавлен 11.02.2014Преобразования Фурье, представление периодической функции суммой отдельных гармонических составляющих. Использование преобразований как для непрерывных функций времени, так и для дискретных. Программа и примеры реализации алгоритмов с прореживанием.
реферат [1,6 M], добавлен 25.05.2010Элементарные многоэкстремальные функции, направления их исследования и вычисление основных параметров. Сравнительный анализ ЭМЭФ-преобразования и преобразования Фурье. Механизм и значение обнаружения слабого сигнала на фоне сильной низкочастотной помехи.
статья [126,0 K], добавлен 03.07.2014Векторные пространства, скалярное произведение и норма функций, ортогональные системы функций, равенства и тригонометрический ряд Фурье. Сходимость интеграла Фурье, основные сведения теории преобразования. Операционное исчисление, преобразование Лапласа.
учебное пособие [1,2 M], добавлен 23.12.2009Алгоритм вычисления преобразования Фурье для дискретного случая. Дискретное преобразование Фурье. Спектральное представление и спектральные характеристики периодического сигнала, четной непериодической функции и произвольного непериодического сигнала.
курсовая работа [932,9 K], добавлен 23.01.2022Главные особенности вычисления преобразования Фурье, приложения и методы использования их на практике. Решение сложных уравнений физики, описывающих динамические процессы, которые возникают под воздействием электрической, тепловой или световой энергии.
контрольная работа [151,0 K], добавлен 14.12.2013Интеграл Фурье в комплексной форме. Формулировка теоремы о сходимости интеграла для кусочно-гладких и абсолютно интегрируемых на числовой прямой функции. Примеры нахождения преобразования Фурье, сверстка и преобразование, спектр, некоторые приложения.
курсовая работа [231,5 K], добавлен 27.08.2012Изучение способов работы с файлами с помощью автоматического преобразования данных. Решение иррациональных уравнений методами хорд и половинного деления. Вычисление определенного интеграла. Решение систем линейных алгебраических уравнений. Ряды Фурье.
курсовая работа [759,3 K], добавлен 16.08.2012Задача о малых колебаниях. Вычисление коэффициентов с помощью быстрого преобразования Фурье. Дискретный подход к вычислению коэффициентов. Вычисление методом Лежандра-Гаусса. Расчет узлов и весовых коэффициентов. Массивно-параллельный расчёт амплитуд.
курсовая работа [2,1 M], добавлен 20.07.2015Образование множеством функций системы ортонормированных функций, условия ортогональности для заданной системы. Разложение в тригонометрический и комплексный ряды Фурье пилообразного сигнала. Генерирование программного произвольного дискретного сигнала.
контрольная работа [378,6 K], добавлен 14.01.2016Разложение в ряд Фурье. Определение функции и нахождение коэффициентов разложения. Проведение замены в интеграле. Условия теоремы о разложении функции в ряд Фурье. Примеры взятия интеграла по частям. Разложение в ряд Фурье четных и нечетных функций.
презентация [73,1 K], добавлен 18.09.2013Условия разложения функций для тригонометрического ряда. Определение коэффициентов разложения с помощью ортогональности систем тригонометрических функций. Понятие периодического продолжения функции, заданной на отрезке. Ряд Фурье функции у=f(x).
презентация [30,4 K], добавлен 18.09.2013Пространство обобщенных функций. Дифференциальные уравнения в обобщенных функциях. Преобразования Лапласа и Фурье. Обобщенные функции, отвечающие квадратичным формам с комплексными коэффициентами. Нахождение решения в математическом пакете Maple.
курсовая работа [516,1 K], добавлен 25.06.2013Рассмотрение задач с двойными и тройными интегралами, применение к ним геометрического и симплекс методов решения; описание теоретической и практической части. Разложение функции в ряд Фурье по синусам и определение наибольшего и наименьшего значения.
курсовая работа [185,1 K], добавлен 28.04.2011Дискретный периодический сигнал, представленный рядом Фурье. Прямое и обратное дискретное преобразование. Его свойства: линейность и симметрия. Алгоритм вычисления круговой свертки сигналов. Равенство Парсеваля для них. Связь ДПФ с Z-преобразованием.
презентация [72,0 K], добавлен 19.08.2013Определение числа гармоник разложения функций в ряд Фурье, содержащих в сумме не менее 90% энергии. Построение амплитудного и фазового спектров функции, графика суммы ряда. Расчет среднеквадратичной ошибки между исходной функцией и частичной суммой Фурье.
контрольная работа [348,5 K], добавлен 13.12.2011Общее определение коэффициентов по методу Эйлера-Фурье. Ортогональные системы функций. Интеграл Дирихле, принцип локализации. Случай непериодической функции, произвольного промежутка, четных и нечетных функций. Примеры разложения функций в ряд Фурье.
курсовая работа [296,3 K], добавлен 12.12.2010Алгоритм введения понятия ряда Фурье, опирающийся на моделирование физических задач в теоретическом курсе высшей математики для студентов физико-математических и инженерно-технических специальностей вузов. Функции и свойства рядов, их физический смысл.
курсовая работа [1,8 M], добавлен 20.05.2015Плоскость частота-время для анализа и сравнения частотно-временных локализационных свойств различных базисов. Понятие базисных функций. Прямое и обратное преобразование Фурье. Сущность дискретного вейвлет-преобразования и примеры функции вейвлет.
курсовая работа [486,0 K], добавлен 21.11.2010Законы алгебры Буля и их применение для преобразования логических выражений. Расчет информационной емкости документов предметной области. Построение инфологической, реляционной и даталогической моделей. Применение методов поиска и сортировки данных.
курсовая работа [261,7 K], добавлен 05.01.2013