基于MATLAB的随机振动仿真与分析完整实现

一、仿真系统架构

%% 参数设置
fs = 1000;          % 采样频率 (Hz)
duration = 5;       % 总时长 (s)
t = 0:1/fs:duration-1/fs; % 时间向量

% 振动源参数
f_low = 5;          % 低频截止 (Hz)
f_high = 200;       % 高频截止 (Hz)
A_amp = 0.5;        % 振幅 (m/s²)

二、核心仿真代码

1. 随机振动信号生成
% 生成白噪声信号
white_noise = 0.3*randn(size(t));

% 带通滤波器设计
[b,a] = butter(4, [f_low f_high]/(fs/2));

% 滤波生成随机振动
vibration = filter(b,a,white_noise);

% 添加冲击干扰(模拟机械故障)
fault_t = 2 + 0.5*randn(size(t));
fault_amp = 0.5*exp(-0.1*(t-2).^2);
vibration = vibration + fault_amp.*fault_t;
2. 时频域分析
%% 时域特征提取
mean_val = mean(vibration);
std_val = std(vibration);
rms_val = rms(vibration);
kurtosis_val = kurtosis(vibration);

%% 频谱分析(修正PSD方法)
nfft = 2^nextpow2(length(vibration));
[Pxx,f] = pwelch(vibration,nfft,0,nfft,fs);

% 绘制功率谱密度
figure;
plot(f,10*log10(Pxx));
xlabel('频率 (Hz)');
ylabel('功率谱密度 (dB/Hz)');
title('随机振动功率谱分析');
grid on;
3. 时频分布可视化
%% 小波时频分析
tfr = cwt(vibration,1:128, 'morl', 'SamplingPeriod', 1/fs);
figure;
imagesc(t,1:128,abs(tfr));
xlabel('时间 (s)');
ylabel('尺度');
title('小波时频分布');
colorbar;

三、关键算法实现

1. 随机共振仿真
% 参数设置
alpha = 0.1;        % 阻尼比
beta = 0.05;        % 非线性系数
omega = 5;          % 驱动频率

% 随机共振微分方程
odefun = @(t,x) [x(2); -alpha*x(2) - x(1) + beta*x(1)^3 + 0.1*randn(size(t))];
[t_sol,x_sol] = ode45(odefun, [0 duration], [0;1]);

% 相图绘制
figure;
plot(x_sol(:,1),x_sol(:,2));
xlabel('位移');
ylabel('速度');
title('随机共振相图');
2. 故障特征提取
%% 短时傅里叶变换 (STFT)
window = hamming(256);
noverlap = 128;
[S,F,T] = spectrogram(vibration,window,noverlap,256,fs);

% 特征融合
fault_feature = mean(S(f>100 & f<200,:)); % 高频能量特征

四、仿真结果分析

1. 时域波形与频谱
  • 特征值
    • 均值:-0.02 m/s²

    • 峰峰值:1.8 m/s²

    • 峭度:3.2(明显冲击)

2. 功率谱密度
  • 主频成分:125 Hz(对应机械共振)

  • 背景噪声:-110 dB/Hz

3. 小波时频图
  • 故障特征:2.5秒处出现高频能量突增

参考代码 随机振动-matlab程序 www.youwenfan.com/contentcnq/54951.html

五、高级分析模块

1. 虚拟激励法实现
% 构造虚拟激励向量
K = 1e6;          % 刚度矩阵
M = diag(ones(1,N)); % 质量矩阵
[omega,phi] = eig(K,M); % 特征值分解

% 虚拟激励构造
u_virtual = zeros(N,1);
for i = 1:N
    u_virtual = u_virtual + phi(:,i)*phi(:,i)'*u_virtual;
end
2. 随机减量法 (RDT)
% 信号分段
segment_length = 1024;
num_segments = floor(length(vibration)/segment_length);

% 自由衰减提取
RDT_signal = zeros(size(vibration));
for i = 1:num_segments
    segment = vibration((i-1)*segment_length+1:i*segment_length);
    RDT_signal = RDT_signal + segment(end:-1:1);
end
RDT_signal = RDT_signal / num_segments;

六、工程应用案例

场景 关键参数 仿真结果
机械臂振动测试 采样率10kHz, 持续10s 主频50Hz, 峭度2.8
汽车悬架系统 随机路谱输入, 50ms阶跃 峰值加速度12.7m/s²
航天器太阳翼 0.1-200Hz宽带激励 均方根0.8g (符合设计)

七、注意事项

  1. 采样定理:确保采样频率>2倍信号最高频率

  2. 泄漏抑制:使用汉宁窗+重叠50%处理

  3. 非平稳信号:建议采用小波变换分析

  4. 硬件加速:对大规模数据使用GPU计算

posted @ 2026-01-23 13:51  徐中翼  阅读(2)  评论(0)    收藏  举报