У меня есть доступ к scipy и я хочу создать БПФ о простой гауссовой функции, которая равна exp (-t ^ 2) .А также хорошо известно, что преобразование Фурье exp (−t ^ 2) равно √πexp (−π ^ 2 * k ^ 2) .Но БПФ exp (-t ^ 2) не было таким же, как √πexp (−π ^ 2 * k ^ 2) .
Я пробовал следующеекод:
import scipy.fftpack as fft
from scipy import integrate
import numpy as np
import matplotlib.pyplot as plt
#FFT
N=int(1e+3)
T=0.01 #sample period
t = np.linspace(0,N*T, N)
h=np.exp(-t**2)
H_shift=2*np.abs(fft.fftshift(np.fft.fft(h)/N))
freq=fft.fftshift(fft.fftfreq(h.shape[0],t[1]-t[0]))
#Comparing FFT with fourier transform
def f(x):
return np.exp(-x**2)
def F(k):
return (np.pi**0.5)*np.exp((-np.pi**2)*(k**2))
plt.figure(num=1)
plt.plot(freq,F(freq),label=("Fourier Transform"))
plt.legend()
plt.figure(num=2)
plt.plot(freq,H_shift,label=("FFT"))
plt.legend()
plt.show()
#Checking Parseval's Theorm
S_h=integrate.simps(h**2,t)
#0.62665690150683084
S_H_s=integrate.simps(H_shift**2,freq)
#0.025215875346935791
S_F=integrate.simps(F(freq)**2,freq)
#1.2533141373154999
График, который я построил, не совпадает, также значения FFT не следуют правилу Парсеваля..Это должно быть S_H_s = S_h * 2 , но мой результат не был.Я думаю, что S_H_s , который является результатом FFT, является неправильным значением из-за S_F = S_h * 2 .
Есть ли проблемы в моем коде ??Помощь очень ценится!Заранее спасибо.