首页/文章/ 详情

一文搞懂Matlab时频傅里叶转换

10天前浏览755

众所周知,振动中会用到响应谱,响应谱分析的主要用途是代替瞬态动力学的时程分析,如下图,将一个复杂的复杂的时域信号使用拟合的方法,分离成众多的谐波信号,即正弦或余弦信号,由于频谱图省略了各谐波的相位信息,只记录它们的频率与幅值,所以是近似且快速的计算手段。这个内容在教主的动力学课程中说得很详细了。

严格意义上,响应谱分析中的边界条件是一种响应,因为输出的反应谱是位移(速度、加速度或力)与频率之间的关系,这种关系称为频谱。

1 时频转换的必要性

很多教程说响应谱不需要工程师自己生成,可以直接查询相关标准。在一些标准试验中的确是这样,比如舰船的海浪冲击可以直接查询GJB150相应文件、地震对建筑物的冲击可以查询国标或欧标的建筑规范标准。    

但是大多数时候,我们要计算的频谱并不是标准手册上有的,而是根据我们自身产品在冲击或振动试验中测得的。一般使用传感器测试产品某处的时间历程响应,即时间与位移(或速度、加速度)的时域信号。如果是在固定约束处,也可直接使用振动台的时域信号,而无需传感器。将这个时域信号转换为频域信号,导入有限元软件中对产品进行仿真计算。如果振动台控制器自带频谱输出,那么都不需要时频转换了。

工作中,甲方也不会给你配一个人专门进行信号处理,往往甲方自己也不清楚边界或加载情况,更有甚者试验都让仿真者参与设计,所以不要想着有人给你个频谱,你拿进ansys/abaqus中咔咔一顿操作交差完事,这么轻松为啥甲方自己不搞呢。

在有限元教材中不会讲Matlab的时频转换,在Matlab的教材中又不会讲振动,这个最重要的环节似乎被各位大佬故意遗忘了,我们本文中要探讨的正是这个中间被忽略的部分。

2 Matlab快速傅里叶变换

在Matlab中,时频转换是通过快速傅里叶变换FFT完成了,我们不需要详细研究FFT内部转换过程,只需要直接调用就行了,以下结合实例介绍如何转换。

本文使用的是16版本的Matlab,按照Matlab桀骜不驯的性格,每年升级都会悄悄咪 咪地改动几个命令,所以不能保证适用于其他版本的Matlab。

Step1 数据分析    

如图,打开ZXS.csv文件,可以看到这个信号共1s,每个采样数据间隔0.01s,即采样率100。这里一共有100个数据,注意数据的数量必须是偶数个,数据最上方不能有表头,否则需要修改后文的代码。

Step2 Matlab转换。

首先将工作目录设置到ZXS.csv所在的文件夹。

输入如下代码,%之后的文字为注释。

需要注意的是,需要核对输入文件名称ZXS.csv是否与我们保存的数据文件名相同,核对采样率是否正确。

clc;clear all;close all %清理屏幕与缓存

data = xlsread('ZXS.csv'); %19版本读取命令为data = readmatrix('ZXS.csv')    

t = data(:,1);      %对应第一列

y1 = data(:,2);     %对应第二列

figure

y=y1;         % 读取时域数据

Fs=100;     % 采集频率,1秒采集了多少个点(需要自行根据数据更改)

T=1/Fs;       % 采集时间间隔

N=length(y);  % 采集信号的长度

t=(0:1:N-1)*T;   % 定义整个采集时间点

t=t';            % 转置成列向量

% fft变换

Y=fft(y);          % Y为fft变换结果,复数向量

Y=Y(1:N/2+1);      % 只看变换结果的一半即可

A=abs(Y);          % 复数的幅值(模)

f=(0:1:N/2)*Fs/N;  % 生成频率范围

f=f';              % 转置成列向量

% 幅值修正

A_adj=zeros(N/2+1,1);

A_adj(1)=A(1)/N;      % 频率为0的位置

A_adj(end)=A(end)/N;   % 频率为Fs/2的位置

A_adj(2:end-1)=2*A(2:end-1)/N;

%写出数据    

dataa(:,1)=f;               %频率

dataa(:,2)=A_adj;           %幅值

str = ['DXS.csv'];     %写出文件名称

xlswrite(str,dataa);    %19版本为  writematrix(str,dataa)

% 绘制频率幅值图和频谱图

subplot(2,1,1)

plot(t,y,'LineWidth',1)

xlabel('时间')

ylabel('信号值')

title('时域信号')

subplot(2,1,2)

plot(f,A_adj,'LineWidth',3)

xlabel('频率(Hz)')

ylabel('幅值(修正后)')

title('FFT变换幅值图')

输入后,点击上方运行工具,将自动导出转换的频域信号DXS.csv,并生成图像,上面显示的是输入的时域图,下面显示的是输出的频域图。可以看到,这个型号是由三个信号组成,分别是频率=1幅值=5的信号1,频率=8幅值=1的信号2,频率=10幅值=0.5的信号3。    

到输出的DXS.csv文件中,插入散点图能更清晰看到组成。

本文先写到这里,这篇文章写作中我也感觉有一些疑惑,比如输出的信号为啥是三角形,如何调整,也请大佬们不吝赐教。    

来源:CAE中学生
Abaqus瞬态动力学振动建筑MATLAB控制试验ANSYS
著作权归作者所有,欢迎分享,未经许可,不得转载
首次发布时间:2024-05-10
最近编辑:10天前
CAE无剑
硕士 | 仿真工程师 CAE中学生
获赞 625粉丝 1362文章 232课程 0
点赞
收藏

作者推荐

未登录
还没有评论

课程
培训
服务
行家

VIP会员 学习 福利任务 兑换礼品
下载APP
联系我们
帮助与反馈