当前位置: 首页 > news >正文

(38)MATLAB分析带噪信号的频谱

文章目录

  • 前言
  • 一、MATLAB仿真代码
  • 二、仿真结果画图
  • 总结


前言

本文给出带噪信号的时域和频域分析,指出频域分析在处理带噪信号时的优势。

首先使用MATLAB生成一段信号,并在信号上叠加高斯白噪声得到带噪信号,然后对带噪信号对其进行FFT变换,得出其频谱,并对其频谱进行分析,阐述加性高斯白噪声对信号频谱的影响。


一、MATLAB仿真代码

代码如下:

f1 = 50;                       % 余弦波1的频率
f2 = 100;                      % 余弦波2的频率
A1 = 0.7;                      % 余弦波的振幅
A2 = 1;                        % 余弦波的振幅
fs = 1000;                     % 采样率                   
Ts = 1/fs;                     % 采样时间间隔    
L = 1500;                      % 信号长度,单位sample
t = (0:L-1)*Ts;                % 时间向量% 合成信号包含两个正弦波,幅值为0.750Hz正弦波和幅值为1100Hz正弦波
s = A1*sin(2*pi*f1*t) + A2*sin(2*pi*f2*t);% 信号加白噪声
x = s + 2*randn(size(t));      % 白噪声均值为零、方差为4% 绘制带噪信号的时域波形。通过时域波形,难以辨认出有用信号。
figure()
plot(1000*t(1:100),x(1:100),'LineWidth',1.5)
grid on
title('被零均值随机噪声污染的信号')
xlabel('t/ms')
ylabel('x(t)')% 将信号变换到频域
Y = fft(x);% 计算信号的单边幅度频谱
P2 = abs(Y/L);                 % 计算双边幅度频谱P2
P1 = P2(1:L/2+1);
P1(2:end-1) = 2*P1(2:end-1);   % 基于双边幅度谱P2计算单边幅度频谱P1% 绘制单边幅度频谱
f = fs*(0:(L/2))/L;            % 频域的频率刻度,单位Hz
figure()
plot(f,P1,'LineWidth',1.5)
grid on
title('带噪信号x(t)的单边幅度谱')
xlabel('频率(Hz)')
ylabel('频谱幅度|P1(f)|')

二、仿真结果画图

时域波形图:

在这里插入图片描述

带噪信号的频谱(单边谱):

在这里插入图片描述

(1)时域分析
从时域波形几乎看不出原始信号,也就是说信号被严重干扰了。

(2)频域分析
观察带噪信号的频谱,可以发现:(1)带噪信号频率与预期相符,即与原始信号一致,因为加性高斯白噪声并不带来信号频移;(2)噪声导致幅值并不精确等于0.7和1。

总结

对于被噪声污染的信号,干扰严重时,我们几乎难以从时域波形看到期待的信号,此时,就需要借助频域分析,从频谱上将很容易发现信号的特征,这对我们做信号分析和提取都非常有帮助。


http://www.lryc.cn/news/461239.html

相关文章:

  • 多级缓存-案例导入说明
  • 基于Python的自然语言处理系列(31):SpaCy + Training Neural Network
  • 在 cPanel 中管理区域编辑权限
  • web前端网页用户注册页面
  • 问题记录-- 在 Vue2 中动态更新 Select 组件的选项
  • Opencv形态学的膨胀操作、开运算与闭运算、梯度运算、礼帽与黑帽操作
  • keil 中添加gcc编译 stmf207
  • BEV相关
  • nodepad++带时间段的关键字搜索筛选
  • 【理论笔记】网工基础知识 1 —— 计算机网络基础知识
  • Z 字形变换
  • 在JasperReports中自动生成序列号
  • SpringBoot3 + MyBatisPlus 快速整合
  • 单片机(学习)2024.10.9
  • 操作符详解(C 语言)
  • 自动化测试数据:如何正确地选择不同格式文件「详细介绍」?
  • OceanBase中扩容OCP节点step by step
  • 国家人工智能创新应用先导区数据及城市人工智能先导区准自然实验数据(2006-2023年)
  • 搜维尔科技:感受、握持、推动、连接和挤压虚拟物体,SenseGlove触觉反馈手套拥有先进的触觉技术、一流的可用性和功能
  • C++中的引用详解
  • 软考中级 - 软件设计师学习笔记 - 1.3 计算机安全
  • Unity3D相关知识点总结
  • 牛顿迭代多维+原理推导
  • [自然语言处理]RNN
  • MySQL(B站CodeWithMosh)——2024.10.11(14)
  • Transformer的预训练模型
  • 手撕单例模式
  • UE4 材质学习笔记06(布料着色器/体积冰着色器)
  • 人工智能学习框架
  • GEE 教程:Landsat TOA数据计算地表温度(LST)