Matlab信号处理3:FFT(快速傅里叶变换)标准使用方式

Fs = 1000;      % 采样频率
T = 1/Fs;       % 采样周期:0.001s
L = 1500;       % 信号长度
t = (0:L-1)*T;  % 时间向量.  时间向量从0开始递增,0s~1.499s

S = 0.7*sin(2*pi*50*t) + sin(2*pi*120*t);  % 模拟原信号
X = S + 2*randn(size(t));                  % 加入干扰信号

subplot(221);
plot(t,S);
xlabel("时间(s)");
ylabel("幅值");
title("原信号波形");

subplot(222);
plot(t,X);
xlabel("时间(s)");
ylabel("幅值");
title("加入干扰信号波形");

Y=fft(X);
len = length(Y);     % Len = L
P2=abs(Y/L);         % 计算幅值并进行能量还原

% 751个,P1提取P2中左半部分的第1~751个
P1 = P2(1:L/2+1);  
% 绘制单边谱,所以除了首尾元素,其余信号幅度翻倍
P1(2:end-1) = 2*P1(2:end-1);   
%根据奈奎斯特定理,此处采样频率Fs为1000,因此频域分析的信号频率最大为500
f = Fs*(0:(L/2))/L;  % 0 ~ 500Hz

subplot(223);
plot(f,P1);
xlabel("频率(Hz)");
ylabel("幅值");
title("含有干扰信号的傅里叶变换");

运行效果:

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

伟大的马师兄

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值