📅  最后修改于: 2023-12-03 14:50:02.001000             🧑  作者: Mango
傅里叶变换是一种信号处理中常用的技术,可以将一个函数表示为一系列正弦波的加权和。在 MATLAB 中,可以使用 fft()
函数进行傅里叶变换,使用 ifft()
函数进行傅里叶反变换。下面是一个简单的示例:
% 定义信号
t = 0:0.01:1;
f1 = sin(2*pi*10*t);
f2 = sin(2*pi*20*t);
signal = f1 + f2;
% 傅里叶变换
ft = fft(signal);
% 绘制频谱图
f = linspace(-50,50,length(signal));
plot(f, abs(fftshift(ft)))
这段代码定义了一个由两个正弦波组成的信号,并使用 fft()
函数进行了傅里叶变换。最后,使用 fftshift()
函数将频谱进行了平移,绘制了频谱图。
傅里叶变换的卷积定理是指,在频域中计算两个函数的卷积等价于在时域中计算这两个函数的乘积的傅里叶变换。即:
$$ \mathcal{F}^{-1} ( \mathcal{F} (f(t)) \cdot \mathcal{F} (g(t))) = f(t) * g(t) $$
其中,$\mathcal{F}$ 表示傅里叶变换,$\mathcal{F}^{-1}$ 表示傅里叶反变换,$*$ 表示卷积操作。
下面是一个简单的示例,演示了如何使用卷积定理计算两个信号的卷积:
% 定义信号
t = 0:0.01:1;
f1 = sin(2*pi*10*t);
f2 = exp(-100*(t-0.5).^2);
g1 = exp(-100*(t-0.7).^2);
g2 = sin(2*pi*20*t);
signal1 = f1 .* f2;
signal2 = g1 .* g2;
% 直接计算卷积
conv1 = conv(signal1, signal2, 'same');
% 使用卷积定理计算卷积
ft1 = fft(signal1);
ft2 = fft(signal2);
ft_conv = ifft(ft1 .* ft2);
% 绘制结果的对比图
plot(t, conv1)
hold on
plot(t, real(ft_conv), '--')
legend('直接计算卷积', '使用卷积定理计算卷积')
这段代码定义了两个信号 signal1
和 signal2
,分别由两个不同的正弦波和高斯函数组成。它同时演示了使用 conv()
函数直接计算卷积的方法,以及使用卷积定理计算卷积的方法。值得注意的是,在使用卷积定理计算卷积时,需要对 ft1
和 ft2
进行点乘,然后使用 ifft()
函数进行反变换得到卷积结果。最后,使用 plot()
函数绘制了两种方法计算的结果,可以发现它们是完全一致的。