下面的示例说明了如何使用 FFT 函数进行频谱分析。FFT 的一个常用场景是确定一个时域噪声信号的频率分量。

首先创建一些数据。假设是以 1000 Hz 的频率对数据进行的采样。首先为数据构造一条时间轴,时间范围从 t = 0 至 t = 0.25,步长为 1 毫秒。然后,创建一个包含 50 Hz 和 120 Hz 频率的正弦波信号 x。

t = 0:.001:.25;
x = sin(2*pi*50*t) + sin(2*pi*120*t);

添加一些标准差为 2 的随机噪声以产生噪声信号 y。然后,通过对该噪声信号 y 绘图来了解该信号。

y = x + 2*randn(size(t));
plot(y(1:50))
title('Noisy time domain signal')

很明显,通过观察该信号很难确定频率分量;这就是频谱分析为什么被广泛应用的原因。

得到带噪声信号 y 的离散傅里叶变换很容易;执行快速傅里叶变换 (FFT) 即可实现。

Y = fft(y,251);

使用复数共扼 (CONJ) 计算功率频谱密度,即测量不同频率下的能量。为前 127 个点构造一个频率轴,并使用该轴绘制结果图形。(其余的点是对称的。)

Pyy = Y.*conj(Y)/251;
f = 1000/251*(0:127);
plot(f,Pyy(1:128))
title('Power spectral density')
xlabel('Frequency (Hz)')

放大并仅绘制上限为 200 Hz 的图形。请注意 50 Hz 和 120 Hz 下的峰值。以下是原始信号的频率。

plot(f(1:50),Pyy(1:50))
title('Power spectral density')
xlabel('Frequency (Hz)')

关注公众号: MATLAB基于模型的设计 (ID:xaxymaker) ,每天推送MATLAB学习最常见的问题,每天进步一点点,业精于勤荒于嬉

打开微信扫一扫哦!

最新文章

  1. ThinkPHP3.2.3 自定义标签库的使用
  2. 【读书笔记《Android游戏编程之从零开始》】6.Android 游戏开发常用的系统控件(TabHost、ListView)
  3. 支持MVC的代码生成运行效果 C# ASP.NET
  4. Laravel教程 三:视图变量传递和Blade
  5. flume介绍以及环境的部署
  6. 【转】Git 少用 Pull 多用 Fetch 和 Merge
  7. 查看mysql当前表使用的存储引擎(转)
  8. Python的多线程编程
  9. 【个人笔记】《知了堂》mysql表连接
  10. 阿里开源分布式事务解决方案 Fescar
  11. Centos6.8实现SVN提交后自动更新目录
  12. linux 学习笔记 groupadd创建组
  13. Linux系统初始配置标准化
  14. Python—迭代器与生成器
  15. php 高效日志记录扩展seaslog 的使用
  16. [转]Angular 4 *ngIf/Else
  17. [daily] 像tcpdump一样监听unix domain socket
  18. Javaweb笔记—03(BS及分页的业务流程)
  19. 4.1.3 Euclid's Game (POJ 2348)
  20. delphi TOnFormVisibleChangeEvent 事件应用

热门文章

  1. UUID那些事
  2. RabbitMQ入门:认识并安装RabbitMQ(以Windows系统为例)
  3. TensorFlow 常用函数汇总
  4. Scrapy 1.4 文档 05 命令行工具
  5. Springboot+JPA+Thymeleaf 校园博客完整小网站
  6. scapyd部署出现的问题的解决方案
  7. selenium webdriver——设置元素等待
  8. python 写日志
  9. Python hashlib 无法打印
  10. go语言nsq源码解读七 lookup_protocol_v1.go