基于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 (符合设计) |
七、注意事项
-
采样定理:确保采样频率>2倍信号最高频率
-
泄漏抑制:使用汉宁窗+重叠50%处理
-
非平稳信号:建议采用小波变换分析
-
硬件加速:对大规模数据使用GPU计算

浙公网安备 33010602011771号