信号基本分析方法——频域分析

 二、频域分析

随机信号的时域分析只能提供有限的时域故障特征信息,故障发生时往往会引起信号频率结构的变化,而故障频率可以计算和预知,通过检测频率的幅值变换规律,就可以监控故障的发展过程。

频谱分析的理论基础是傅里叶变换,傅里叶变换包括傅里叶级数和傅里叶积分。

2.1 傅里叶级数

满足Dirichlet条件的周期信号X(t)可以分解为很多谐波分量之和:

x(t)=\frac{a_{0}}{2}+\sum_{n=1 }^{\infty }(a_{n}cosn\omega _{0}t+b_{n}sinn\omega _{0}t)

其中

傅里叶级数的概念是任何一个周期函数都可以采用无限个三角函数去拟合和描述。

时域分析和频域分析只是从不同侧面反映信号。

2.2 傅里叶变换

傅里叶变换对

为了计算机上实现信号的频谱分析,需要时域信号是离散的,且是有限长。

离散傅里叶变换公式为:

傅里叶分析的不足

变换之后的信号完全失去了时间信息,无法反映频率随时间的变化

傅里叶变换命令

y=fft(x)

y=fft(x,n)  n表示执行n点fft

若x的长度是2的整数次幂,函数fft运行速度最佳

傅里叶逆变换命令

y=ifft(x)

y=ifft(x,n)

例3. 对信号y=2sin(2\pi *30t)+sin(2\pi *80t)分别64点,256点进行fourier变换,并画出幅频图,采样频率256Hz。

clc
clear
close all
fs=256;
f1=30;
f2=80;
t=0:1/fs:1-1/fs;
p=length(t);
y=2*sin(2*pi*f1.*t)+sin(2*pi*f2.*t);
nfft1=64;
nfft2=256;
rfft1=fft(y,nfft1);
ys1=abs(rfft1);
fz1=(1:nfft1/2)*fs/nfft1;
figure(1)
subplot(211)
plot(fz1,ys1(1:nfft1/2)*2/p)
xlabel('频率/Hz')
ylabel('幅值')
title('64点fft')
rfft2=fft(y,nfft2);
ys2=abs(rfft2);
fz2=(1:nfft2/2)*fs/nfft2;
subplot(212)
plot(fz2,ys2(1:nfft2/2)*2/p);
xlabel('频率/Hz')
ylabel('幅值')
title('256点fft')

从上图可以看出,采样频率越多,频谱图效果越好

例4.对例3的信号进行fft逆变换,与原信号对比。

clc
clear
close all
fs=256;
f1=30;
f2=80;
t=0:1/fs:1-1/fs;
p=length(t);
y=2*sin(2*pi*f1.*t)+sin(2*pi*f2.*t);
nfft=256;
rfft=fft(y,nfft);
ys=abs(rfft);
fz=(1:nfft/2)*fs/nfft;
xifft=ifft(rfft);
realx=real(xifft);
ti=[0:length(xifft)-1]/fs;
yfft=fft(xifft,nfft);
myfft=abs(yfft);
p1=length(xifft);
figure(1)
subplot(221)
plot(t,y)
xlabel('时间/s')
ylabel('幅值')
title('原始信号')
subplot(222)
plot(fz,ys(1:nfft/2)*2/p);
xlabel('频率/Hz')
ylabel('幅值')
title('原始信号的fft')
subplot(223)
plot(ti,realx);
xlabel('时间/s')
ylabel('幅值')
title('逆变换后的信号')
subplot(224)
plot(fz,myfft(1:nfft/2)*2/p1);
xlabel('频率/Hz')
ylabel('幅值')
title('逆变换后得到的信号的fft')

例5 对西储大学的数据进行傅里叶变换

clc,
clear,
close all;

load 130.mat
x = X130_DE_time;
fs = 12000;
N=length(x);   %采样频率和数据点数
t = 0:1/fs:(N-1)/fs;
y = fft(x,N);
y1 = abs(y);
ayy = y1/(N/2);
ayy(1) = ayy(1)/2;
f = ((1:N)-1)*fs/N;
subplot(211)
tt=1000:1500;
plot(tt,x(tt),'color',[0/255,0/255,255/255],'LineWidth',0.8);
title('时域分析')
xlabel('时间(t)')
ylabel('m/s^2')
subplot(212)
plot(f(1:(N-1)/2),ayy(1:(N-1)/2),'color',[0/255,0/255,255/255],'LineWidth',0.8);
grid on
%xlim([0 500])
xlabel('频率[f]');
ylabel('Amplitude(m/s^2)')
title('频域分析')

参考资料:

[1] 时献江 《机械故障诊断及典型案例解析》

[2]张玲玲 《基于matlab的机械故障诊断技术案例教程》

[3]傅里叶分析之掐死教程(完整版)更新于2014.06.06 - 知乎 (zhihu.com)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/733701.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

支持 MKV、MP4、AVI、MPG 等格式视频转码器

一、简介 1、一款开源的视频转码器,适用于 Linux、Mac 和 Windows。它是一个免费的工具,由志愿者们开发,可以将几乎所有格式的视频转换为现代、广泛支持的编码格式。你可以在官网上下载该应用或源代码。该软件支持 MKV、MP4、AVI、MPG 等格式…

Graphviz——实现动态更新协议状态机

1、描述 为了实现动态更新协议状态机,首先需要定义类来表示协议状态机。初始化该类后,保存状态机对象。在后续更新过程中,就可以加载保存的状态机对象,添加新的状态或事件。Graphviz的安装过程参考:Graphviz——安装、…

PCL 三次样条插值(二维点)

一、简介 在插值计算中,最简单的分段多项式近似应该是分段线性插值,它由连接一组数据点组成,仅仅只需要将这些点一一用直线进行顺序相连即可。不过线性函数插值的缺点也很明显,就是在两个子区间变化的比较突兀,也就是没有可微性(不够光滑)。因此我们需要更为符合物理情况…

海外云手机自动化管理,高效省力解决方案

不论是企业还是个人,对于海外社媒的营销都是需要自动化管理的,因为自动化管理不仅省时省力,而且还节约成本; 海外云手机的自动化管理意味着什么?那就是企业无需再投入大量的人力和时间去逐一操作和监控每一台设备。 通…

波兰出局奥地利无限可能,荷法无谓争小组第一,谁能小组第一?

波兰出局奥地利无限可能,荷法无谓争小组第一,谁能小组第一? 2024欧洲杯D组结束小组赛第2轮争夺,积分榜形式如下:荷兰与法国均1胜1平积4分,两队之间直接对话战平,净胜球也均为1,荷兰凭借总进球数多1个暂列榜…

Python星载气溶胶数据处理与反演分析

在当前全球气候变化和环境污染问题日益突出的背景下,气溶胶研究显得尤为重要。气溶胶在大气中由直径范围在0.01微米至10微米固体和液体颗粒构成,直接或间接影响地球辐射平衡、气候变化和空气质量。尤其在“碳中和”目标的驱动下,研究气溶胶对…

韩顺平0基础学java——第29天

p592-599 线程 用户线程和守护线程 1.用户线程:也叫工作线程,当线程的任务执行完或通知方式结束 2守护线程:一般是为工作线程服务的,当所有的用户线选束,守护线程自动结束 3.常见的守护线程:垃圾回收机制 当我们希望当main线程结束后&…

高性能、高可靠性!Kafka的技术优势与应用场景全解析

我是小米,一个喜欢分享技术的29岁程序员。如果你喜欢我的文章,欢迎关注我的微信公众号“软件求生”,获取更多技术干货!​​​​​​​ 大家好,我是你们的小米,今天要和大家聊聊一个超级强大的消息系统——Kafka。很多同学可能对它还不太熟悉,不过没关系,今天我就带你们…

从一到无穷大 #29 ByteGraph的计算,内存,存储三级分离方案是否可以通用化为多模数据库

本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。 本作品 (李兆龙 博文, 由 李兆龙 创作),由 李兆龙 确认,转载请注明版权。 文章目录 引言ByteGraph现有架构阿里云Lindorm腾讯YottaDB多模型化修改点ByteGraph论文中的优化…

Linux中的全局环境变量和局部环境变量

Linux中的全局环境变量和局部环境变量 一、全局环境变量二、局部环境变量三、 设置全局环境变量 bash shell用一个叫作环境变量 (environment variable)的特性来存储有关shell会话和工作环境的信息(这也是它们被称作环境变量的原 因&#xff…

Qt利用Coin3D(OpenInventor)进行3d绘图

文章目录 1.安装1.1.下载coin3d1.2.下载quarter1.3.解压并合并 2.在Qt中使用3.画个网格4.加载wrl模型5.画个锤子并旋转6.加载自定义视口文件 1.安装 1.1.下载coin3d 首先,到官网下载[coin3d/coin] 我是Qt5.15.2vs2019的,因此我选择这个coin-4.0.2-msvc…

“脏读”、“幻读”、“不可重复读”

“脏读”、“幻读”、“不可重复读” 1.概念说明 “脏读”、“幻读”、“不可重复读”是数据库事务的概念。 “脏读”是指一个事务中访问到了另外一个事务未提交的数据。 “不可重复读”是指在一个事务内根据同一个条件对数据进行多次查询,但是结果却不一致&…

某程序员:30岁了,老婆管钱,背着我买了50万股票,亏了20w,强制她清仓后又买了36万

“辛辛苦苦攒了几年钱,本想买房买车,结果全被老婆炒股亏掉了!” 近日,一位30岁的程序员大哥在网上吐苦水,引发了网友们的热议。 这位程序员大哥和妻子结婚后,一直秉持着“男主外,女主内”的传统…

如何使用gprof对程序进行性能分析

如何使用gprof对程序进行性能分析 目录 1 gprof概述 2 gprof原理简述 3 gprof使用 3.1 gprof使用简述 3.2 gprof使用示例 4 小结 1 gprof概述 gprof 是 一个 GNU 的程序性能分析工具,可以用于分析C\C程序的执行性能。gprof工具可以统计出各个函数的调用次数、执…

修改docker中mongodb容器的时区

假设容器名称为mongodb,设置时区为伤害时区的命令为: docker exec -it mongodb bash -c "ln -snf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo Asia/Shanghai > /etc/timezone"验证时区更改: docker e…

【CT】LeetCode手撕—42. 接雨水

目录 题目1- 思路2- 实现⭐42. 接雨水——题解思路 3- ACM实现 题目 原题连接:42. 接雨水 1- 思路 模式识别:求雨水的面积 ——> 不仅是只求一个比当前元素大的元素,还要求面积 单调栈 应用场景,需要找到左边比当前元素大的…

如何用Spring使用Redis作为消息订阅?

目录 一、Spring 框架介绍二、Redis 框架介绍三、什么是消息订阅四、如何用Spring使用Redis作为消息订阅 一、Spring 框架介绍 Spring 框架是一个开源的 Java 平台,它提供了全面的基础设施支持,以便您可以更容易地开发 Java 应用程序。Spring 处理了基础…

【C++】优先队列的使用及模拟实现

💗个人主页💗 ⭐个人专栏——C学习⭐ 💫点击关注🤩一起学习C语言💯💫 目录 导读 一、什么是优先队列 二、优先队列的使用 1. 优先队列的构造 2. 优先队列的基本操作 3. 使用示例 三、优先队列模拟实…

[已解决]ImportError: DLL load failed while importing win32api: 找不到指定的程序。

使用pip install pywin32302安装后import找不到win32api 失败尝试 上网找别人的解决方案,大部分解决方案都是通过复制下面两个dll文件到 下面这个文件夹,并且复制到C:\Windows\System32,从而解决问题,但是我没能成功。 解决方…

web中间件漏洞-Redis漏洞未授权访问漏洞-写webshell、写ssh公钥

web中间件漏洞-Redis漏洞未授权访问漏洞 利用redis未授权访问漏洞写webshell 利用redis未授权访问、攻击机向服务器写入webshell 从服务器查看写入的webshell 菜刀连接 利用redis未授权访问漏洞写ssh公钥 kali生成rsa公私钥对 ssh-keygen -t rsa 将公钥id_rsa.pub写入文…