(37)使用MATLAB画出余弦波的频谱

文章目录


前言

首先使用MATLAB生成一段余弦信号,然后对其进行FFT变换,画出其频谱。


一、MATLAB仿真代码

代码如下:

c 复制代码
f = [50, 100];                 % 两个余弦波的频率
fs = 1000;                     % 采样率
Ts = 1/fs;                     % 采样时间间隔
L = 1000;                      % 信号长度,单位sample
t = (0:L-1)*Ts;                % 时间向量

x1 = cos(2*pi*f(1)*t);         % 余弦波1
x2 = cos(2*pi*f(2)*t);         % 余弦波2
X = [x1; x2];                  % 余弦波1和2组成矩阵,每行一个余弦波

% 时域波形画图
figure()
for i = 1:2
    subplot(2,1,i)
    plot(t(1:100),X(i,1:100),'LineWidth',1.5)
    title(['余弦波',num2str(i),'的时域波形(f=',num2str(f(i)),'Hz)'])
    grid on
    xlabel('t/s')
    ylabel('cos(2*pi*f*t)')
end

% 时域序列的长度不是2的次幂值,将其扩展为比当前长度大的下一个最小的2的次幂值。扩展的值为补零。
n = 2^nextpow2(L);

% 指定dim参数沿X的行(即对每个余弦信号)进行fft运算
dim = 2;
Y = fft(X,n,dim);

% 计算每个信号的双边幅度频谱和单边幅度频谱
P2 = abs(Y/L);
P1 = P2(:,1:n/2+1);
P1(:,2:end-1) = 2*P1(:,2:end-1);

% 在频域内,为单个图窗中的每一行绘制单边幅度频谱
figure()
for i=1:2
    subplot(2,1,i)
    plot(0:(fs/n):(fs/2-fs/n),P1(i,1:n/2),'LineWidth',1.5)
    grid on
    title(['余弦波',num2str(i),'的幅度谱(f=',num2str(f(i)),'Hz)'])
    xlabel('频率(Hz)')
    ylabel('频谱幅度|Y|')
end

二、仿真结果画图

时域波形图:

余弦波的频谱(单边谱):


相关推荐
宇木灵4 小时前
C语言基础学习-二、运算符
c语言·开发语言·学习
yangSimaticTech4 小时前
沿触发的4个问题
开发语言·制造
舟舟亢亢4 小时前
算法总结——二叉树【hot100】(上)
java·开发语言·算法
百锦再5 小时前
Java中的char、String、StringBuilder与StringBuffer 深度详解
java·开发语言·python·struts·kafka·tomcat·maven
weixin_477271695 小时前
根象:树根。基石。基于马王堆帛书《周易》原文及甲骨文还原周朝生活活动现象(《函谷门》原创)
算法·图搜索算法
普通网友6 小时前
多协议网络库设计
开发语言·c++·算法
努力努力再努力wz6 小时前
【Linux网络系列】:TCP 的秩序与策略:揭秘传输层如何从不可靠的网络中构建绝对可靠的通信信道
java·linux·开发语言·数据结构·c++·python·算法
daxi1506 小时前
C语言从入门到进阶——第9讲:函数递归
c语言·开发语言·c++·算法·蓝桥杯
勇气要爆发7 小时前
LangGraph 实战:10分钟打造带“人工审批”的智能体流水线 (Python + LangChain)
开发语言·python·langchain
yy.y--7 小时前
Java数组逆序读写文件实战
java·开发语言