SciPy - пакет FFT

Fourier Transformationвычисляется на сигнале временной области, чтобы проверить его поведение в частотной области. Преобразование Фурье находит свое применение в таких дисциплинах, как обработка сигналов и шумов, обработка изображений, обработка аудиосигналов и т. Д. SciPy предлагает модуль fftpack, который позволяет пользователю вычислять быстрые преобразования Фурье.

Ниже приведен пример синусоидальной функции, которая будет использоваться для вычисления преобразования Фурье с использованием модуля fftpack.

Быстрое преобразование Фурье

Давайте разберемся, что такое быстрое преобразование Фурье.

Одномерное дискретное преобразование Фурье

БПФ y [k] длины N последовательности x [n] длины N вычисляется с помощью fft (), а обратное преобразование вычисляется с помощью ifft (). Рассмотрим следующий пример

#Importing the fft and inverse fft functions from fftpackage
from scipy.fftpack import fft

#create an array with random n numbers
x = np.array([1.0, 2.0, 1.0, -1.0, 1.5])

#Applying the fft function
y = fft(x)
print y

Вышеупомянутая программа выдаст следующий результат.

[ 4.50000000+0.j           2.08155948-1.65109876j   -1.83155948+1.60822041j
 -1.83155948-1.60822041j   2.08155948+1.65109876j ]

Давайте посмотрим на другой пример

#FFT is already in the workspace, using the same workspace to for inverse transform

yinv = ifft(y)

print yinv

Вышеупомянутая программа выдаст следующий результат.

[ 1.0+0.j   2.0+0.j   1.0+0.j   -1.0+0.j   1.5+0.j ]

В scipy.fftpackмодуль позволяет вычислять быстрые преобразования Фурье. В качестве иллюстрации (зашумленный) входной сигнал может выглядеть следующим образом:

import numpy as np
time_step = 0.02
period = 5.
time_vec = np.arange(0, 20, time_step)
sig = np.sin(2 * np.pi / period * time_vec) + 0.5 *np.random.randn(time_vec.size)
print sig.size

Создаем сигнал с временным шагом 0,02 секунды. Последний оператор печатает размер сигнала. Результат будет следующим -

1000

Мы не знаем частоту сигнала; нам известен только временной шаг дискретизации сигнала sig. Предполагается, что сигнал исходит от реальной функции, поэтому преобразование Фурье будет симметричным. Вscipy.fftpack.fftfreq() функция будет генерировать частоты дискретизации и scipy.fftpack.fft() вычислит быстрое преобразование Фурье.

Разберемся в этом на примере.

from scipy import fftpack
sample_freq = fftpack.fftfreq(sig.size, d = time_step)
sig_fft = fftpack.fft(sig)
print sig_fft

Вышеупомянутая программа выдаст следующий результат.

array([ 
   25.45122234 +0.00000000e+00j,   6.29800973 +2.20269471e+00j,
   11.52137858 -2.00515732e+01j,   1.08111300 +1.35488579e+01j,
   …….])

Дискретное косинусное преобразование

А Discrete Cosine Transform (DCT)выражает конечную последовательность точек данных в виде суммы функций косинуса, колеблющихся на разных частотах. SciPy предоставляет DCT с функциейdct и соответствующий IDCT с функцией idct. Рассмотрим следующий пример.

from scipy.fftpack import dct
print dct(np.array([4., 3., 5., 10., 5., 3.]))

Вышеупомянутая программа выдаст следующий результат.

array([ 60.,  -3.48476592,  -13.85640646,  11.3137085,  6.,  -6.31319305])

Обратное дискретное косинусное преобразование восстанавливает последовательность из ее коэффициентов дискретного косинусного преобразования (DCT). Функция idct является обратной функцией dct. Давайте разберемся в этом на следующем примере.

from scipy.fftpack import dct
print idct(np.array([4., 3., 5., 10., 5., 3.]))

Вышеупомянутая программа выдаст следующий результат.

array([ 39.15085889, -20.14213562, -6.45392043, 7.13341236,
8.14213562, -3.83035081])