信号处理——时频分析

经典傅里叶变换的限制:

1、只能反映信号的整体特性;(完全是时域或频域)

2、要求信号满足平稳条件;

3、必须获得时域中的全部信息。

所以引入时频分析,同时使用时间和频率的联合函数来表示信号。

1 时频分析

1.1 短时Fourier变换

具体理论可以参看参考资料[1]的103~105页。

短时傅里叶变换的实现:

[tfr,t,f]=tfrstft(x)

tfr为短时傅里叶变换的变换系数,t为系数tfr对应的时刻,f为归一化频率向量。

例1:构建一个有256个点的正弦信号x,在[30,80]区间的频率为32Hz,在[140,190]区间的频率为64Hz。fs=256Hz.用tfrstft对x进行时频分析。

clc;
clear;
fs=256;
ts=1/fs;
N=256;
pt=0*ts:ts:(N-1)*ts;
t1=zeros(N,1);
t2=zeros(N,1);
t1(30:80)=pt(30:80);
t2(140:190)=pt(140:190);
f1=32;
f2=64;
x=sin(2*pi*f1*t1)+sin(2*pi*f2*t2);
figure(1);
subplot(311)
plot(pt,x);
xlabel('time/s');
ylabel('幅值');
title('时域图')
subplot(312)
[tfr,t,f]=tfrstft(x);
pcolor(t,f(1:N/2,1),abs(tfr([1:N/2],:)));
colorbar;
xlabel('采样点');
ylabel('归一化频率')
title('时频分布')
subplot(313)
t=(t-1)/fs;
f=f*fs;
pcolor(t,f(1:N/2,1),abs(tfr([1:N/2],:)));
xlabel('time/s');
ylabel('频率/Hz');
colorbar;

1.2 Gabor变换

理论部分在参考资料[1]中110~111.

Gabor变换以高斯函数为窗函数。

选择高斯函数的原因:1、高斯函数的傅里叶变换仍为高斯函数;2、Gabor变换是最优的窗口Fourier变换。

Gabor变换才是真正意义上的时间-频率分析。

Gabor变换的局限性:时间频率的宽度对所有频率是固定不变的。

matlab实现:

[tfr,dgr,gam]=tfrgabor(x)

[tfr,dgr,gam]=tfrgabor(x,N)  N为Gabor系数的个数

[tfr,dgr,gam]=tfrgabor(x,N,Q)  Q为过采样度。

例2 对信号进行gabor变换

clc;
clear;
fs=256;
t=0:1/fs:1-1/fs;
y=cos(20*pi.*t.*t)+cos(2*pi.*cos(6*pi.*t)+120*pi.*t);
tfrgabor(y',64,32)

1.3 Wigner-Ville时频分析

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

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

提高数据融合效率和数据成果质量工作流的可行性分析

第一章 引言 本文基于对框架数据、地名地址数据以及变更调查数据为主体数据源的分析,结合数据融合中分层数据处理原则和内容,从数据管理者、数据应用的角度提出数据质量的定位、需求定位,归纳数据融合过程中存在的困难,提出了数据…

嵌入式linux面试题大全及参考答案(3万字长文)

目录 解释Linux内核的主要职责 什么是inode?它在文件系统中扮演什么角色? 常用的5个Linux文件权限标志 查看当前系统运行级别 查找包含特定字符串的文件 使用grep命令过滤特定模式的行 编写脚本检查指定目录下文件大小并排序输出 解释变量、环境变量和位置参数在Shel…

前端npm打包自动压缩

需要插件rollup-plugin-compression 在vite.config中使用 import compresssionBuild from rollup-plugin-compression import type { ICompressionOptions } from rollup-plugin-compression import dayjs from dayjs import packageInfo from ./package.json const option: I…

FANUC喷涂机器人P-350iA电机过热维修解决方案

发那科喷涂机器人作为自动化喷涂生产线的重要组成部分,其性能稳定性和可靠性对于生产效率和产品质量具有重要影响。然而,在实际使用过程中,FANUC喷涂机器人P-350iA电机过热故障问题往往成为影响其正常运行的主要因素之一。 FANUC机器人M-100…

产品经理进阶:供应链管理制度

目录 一、 目的 二、范围 三、意义 五、周期 一、 目的 根据公司战略规划和经营目标,建立和完善生产计划、物料控制体系、库存 管理体系。通过匹配需求和产能,确保在满足市场需求的同时降低整体库存 水平,提高存货周转率,以达成公司的成本管理目标。 二、范围 涉及供应…

vue2的双向绑定

vue是一个mvvm框架,即数据双向绑定,即当数据发生变化的时候,视图也就发生变化,当视图发生变化的时候,数据也会跟着同步变化。 Vue.js 2 中的双向绑定是通过 v-model 指令实现的。v-model 指令可以在表单输入元素上创建…

一款开源免费的现代化风格的Avalonia控件库

前言 Citrus.Avalonia是一款开源(MIT License)、免费的现代化风格的Avalonia控件库。 Avalonia介绍 Avalonia是一个强大的框架,使开发人员能够使用.NET创建跨平台应用程序。它使用自己的渲染引擎绘制UI控件,确保在Windows、mac…

推荐系统数据集——Amazon-Book

在推荐系统中,像Amazon-Book这样的数据集通常包含用户和物品的交互信息。为了训练模型,这些数据需要转换成适合模型输入的格式。在这种情况下,item_list和user_list需要转换成train.txt文件,通常包含用户ID和物品ID的交互记录。 …

你的生日是星期几?HTML+JavaScript帮你列出来

0 源起 上周末,大宝发现今年自己的生日不是周末,这样就不好约同学和好友一起开生日Party了,很是郁闷。一直嘀咕自己哪年的生日才是周末。 于是我用JavaScript写了一个小程序来帮她测算了未来100年中每年的生日分别是星期几。 1 设计交互界面…

torch创建2d卷积层报错

import torch import torch.nn as nn print(nn.Conv2d(3, 16, 3, padding1)) 编译器:pycharm2023.03.05 python:3.11 运行上述代码 页面报错:OSError: [WinError 126] 找不到指定的模块。 Error loading "D:\apploadpath\pythonPath\Lib\site-…

logback自定义规则脱敏

自定义规则conversionRule public class LogabckMessageConverter extends MessageConverter {Overridepublic String convert(ILoggingEvent event) {String msg event.getMessage();if ("INFO".equals(event.getLevel().toString())) {msg .....脱敏实现}return …

搭建大型分布式服务(四十一)SpringBoot 整合多个kafka数据源-支持亿级消息生产者

系列文章目录 文章目录 系列文章目录前言一、本文要点二、开发环境三、原项目四、修改项目五、测试一下五、小结 前言 本插件稳定运行上百个kafka项目&#xff0c;每天处理上亿级的数据的精简小插件&#xff0c;快速上手。 <dependency><groupId>io.github.vipjo…

【ARM】MCU和SOC的区别

【更多软件使用问题请点击亿道电子官方网站】 1、 文档目标 了解SOC芯片和MCU芯片的区别 2、 问题场景 用于了解SOC芯片和MCU芯片的区别&#xff0c;内部结构上的区别。 3、软硬件环境 1&#xff09;、软件版本&#xff1a;无 2&#xff09;、电脑环境&#xff1a;无 3&am…

【小学期】安装Navicat,可视化操作数据库

什么是Navicat&#xff0c;如何安装&#xff1f;如何操作&#xff1f; 1. 什么是Navicat&#xff1f; Navicat 是一款功能强大的数据库管理工具&#xff0c;支持多种数据库系统&#xff0c;包括 MySQL、PostgreSQL、SQLite、Oracle、MariaDB 和 SQL Server 等。Navicat 提供了…

Java——枚举

1. 概念 枚举是在JDK1.5之后引入的&#xff0c;主要用途是&#xff1a;将一组常量组织起来&#xff0c;在这之前表示一组常量通常使用定义常量的方式&#xff1a; public static final int RED 1; public static final int GREEN 2; public static final int BLACK 3;但是…

意识与通用人工智能:北京智源大会深度解读

在科技迅猛发展的今天&#xff0c;人工智能&#xff08;AI&#xff09;的意识问题成为了学术界和公众关注的焦点。北京智源大会汇聚了众多学者&#xff0c;围绕意识与通用人工智能&#xff08;AGI&#xff09;的关系进行了深入探讨。本文将对大会的精彩观点进行总结&#xff0c…

clickhouse join内存溢出

clickhouse join 内存溢出 前言排查步骤查看sql统计数据量统计大小优化索引优化字段增加内存最终优化 前言 在一个离线工作流中任务报错 Code: 241. DB::Exception: Received from XXXXXX:9000. DB::Exception: Memory limit (for query) exceeded: would use 20.49 GiB (att…

第 12 课:基于隐语的VisionTransformer框架

基于之前MPC的基础知识&#xff0c;本讲主要内容是MPCViT基于SecretFlow的VisionTransformer框架&#xff0c;主要从神经网络架构&#xff0c;隐私推理框架和实验结果三方面介绍。 一、MPCViT&#xff1a;安全且高效的MPC友好型 Vision Transformer架构 MPCViT隐私推理总体框架…

QT中子工程的创建,以及如何在含有库的子工程项目中引用主项目中的qt资源

1、背景 在qt中创建多项目类型,如下: CustomDll表示其中的一个动态库子项目; CustomLib表示其中的一个静态库子项目; MyWidget表示主项目窗口(main函数所在项目); 2、qrc资源的共享 如何在CustomDll和CustomLib等子项目中也同样使用 MyWidget项目中的qrc资源呢??? 直…

【AI应用探讨】—决策树应用场景

目录 1 命名实体识别&#xff08;NER&#xff09; 2 信用评估 3 医学诊断 4 垃圾邮件过滤 5 推荐系统 6 金融欺诈检测 7 医疗领域的其他应用 8 网络行为管理系统 1 命名实体识别&#xff08;NER&#xff09; 应用场景&#xff1a;在文本处理中&#xff0c;决策树可以用…