声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 7851|回复: 21

[编程技巧] 求助 裂纹转子系统故障信号matlab仿真

  [复制链接]
发表于 2010-12-3 14:53 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?我要加入

x
本帖最后由 mjtjiang 于 2010-12-3 15:15 编辑

请大家帮我看看这段程序吧,原方程和降阶后的一阶方程我都贴出来了,程序也在下面,方程中的参数都是按书上给的输入的,可仿真结果跟书上差很多啊,不知道是我的方程编写错误还是求频谱的傅里叶变换程序部分出错了,希望大家指点啊!

无量纲参数:
无量纲化的参数2.bmp

裂纹转子系统运动微分方程的无量纲形式:
裂纹转子系统运动微分方程的无量纲形式1.bmp
裂纹转子系统运动微分方程的无量纲形式2.bmp

因为是要用ode45求解方程,所以将方程降阶:
Z.bmp
降阶后的方程1.bmp
降阶后的方程2.bmp
降.bmp
为编程方便,又把系数简化了一下:
系数.bmp
矩阵1.bmp
矩阵2.bmp
程序贴在楼下

回复
分享到:

使用道具 举报

 楼主| 发表于 2010-12-3 15:11 | 显示全部楼层
回复 1 # mjtjiang 的帖子

方程在楼上贴出了,以下是程序,就算是截取后半段稳定值作分析,运行结果也还是与书上的不相符,请大家帮忙指点
function out=liewenfun(t,z,flag)

omega=2000;           % 轴的转速
a=0.0135;                % 裂纹深度
r=0.015;                  % r转轴半径
L1=0.57;                 % L1转轴长度
R=0.025;                 % R轴承半径
L=0.012;                 % L轴承长度
b=0.05*10^(-3);    % b圆盘偏心率
m1=4.0;                 % m1轴承处的等效集中质
m2=32.1;               % m2转轴中央圆盘质量
c=0.11*10^(-3);    % c轴承间隙
mu=0.018;             % mu润滑油粘度
c1=1050.0;             % c1转子在轴承处的结构阻尼
c2=2100.0;             % c2转子在圆盘处的结构阻尼
k=2.5*10^7;           % k转轴刚度
g=9.81;
epsilon=3.3064e-007;
delta=3.0244e+006;     % epsilon与delta为仅与裂纹深度a有关的相关刚度参数
P=0.5*m2;             % P转子圆盘重量的一半

beta=0;        % beta裂纹方向与偏心之间的夹角
phi=0;          % phi转轴初始相位角
theta=omega*t+phi+beta; % theta裂纹截面转角
F=(1+cos(theta))/2;     % F裂纹开闭规律,描述的是裂纹转角对实际裂纹轴刚度的影响规律(裂纹开闭规律模型有好几种,我用的是比较简单的余弦波模型)

s=(mu*omega*R*L*((R/c)^2)*(L/(2*R))^2)/P; % s为Sommerfeld修正系数,c平均油膜厚度
xi1=c1/(m1*omega);
xi2=c2/(m2*omega);
eta1=k/(m1*omega^2);
eta2=2*k/(m2*omega^2);
G=g/(c*omega^2);
M1=(c*m1*omega^2)/(s*P);
b1=b/c;
tau=omega*t;
w=1-epsilon*delta*0.5*F;
u=epsilon*0.5*F.*cos(2*tau);
l=epsilon*0.5*F.*sin(2*tau); %时变系数

out=[z(5);...
z(6);...
z(7);...
z(8);...
(-eta1*w-eta1*u)*z(1)-eta1*l*z(2)+(eta1*w+eta1*u)*z(3)+eta1*l*z(4)-xi1*z(5)+fx(z(1),z(2),z(5),z(6))/M1;...
-eta1*l*z(1)+(-eta1*w+eta1*u)*z(2)+eta1*l*z(3)+(eta1*w-eta1*u)*z(4)-xi1*z(6)+fy(z(1),z(2),z(5),z(6))/M1-G;...
(eta2*w+eta2*u)*z(1)+eta2*l*z(2)+(-eta2*w-eta2*u)*z(3)-eta2*l*z(4)-xi2*z(7)+b1*cos(tau);...
eta2*l*z(1)+(eta2*w-eta2*u)*z(2)-eta2*l*z(3)+(-eta2*w+eta2*u)*z(4)-xi2*z(8)+b1*sin(tau)-G];

fx、fy是无量纲非线性油膜力
function fxout=fx(x,y,Dx,Dy)
if x-2*Dy~=0
alpha=atan((y+2*Dx)./(x-2*Dy))-0.5*pi*sign((y+2*Dx)./(x-2*Dy))-0.5*pi*sign(y+2*Dx);
else
alpha=atan2((y+2*Dx),(x-2*Dy))-0.5*pi*sign(y+2*Dx)-0.5*pi*sign(y+2*Dx);
end
G=(2.0/sqrt(abs(1.0-abs(x.^2)-abs(y.^2)))).*(pi/2+atan((y.*cos(alpha)-x.*sin(alpha))./sqrt(abs(1.0-abs(x.^2)-abs(y.^2)))));
V=(2.0+(y.*cos(alpha)-x.*sin(alpha)).*G)./(1.0-abs(x.^2)-abs(y.^2));
S=(x.*cos(alpha)+y.*sin(alpha))./(1.0-abs((x.*cos(alpha)+y.*sin(alpha)).^2));
fxout=-1.0*(sqrt(abs(abs((x-2*Dy).^2)+abs((y+2*Dx).^2)))./(1.0-abs(x.^2)-abs(y.^2))).*(3.0.*x.*V-sin(alpha).*G-2.0.*cos(alpha).*S);
function fyout=fy(x,y,Dx,Dy)
if x-2*Dy~=0
alpha=atan((y+2*Dx)./(x-2*Dy))-0.5*pi*sign((y+2*Dx)./(x-2*Dy))-0.5*pi*sign(y+2*Dx);
else
alpha=atan2((y+2*Dx),(x-2*Dy))-0.5*pi*sign(y+2*Dx)-0.5*pi*sign(y+2*Dx);
end
G=(2.0/sqrt(abs(1.0-abs(x.^2)-abs(y.^2)))).*(pi/2+atan((y.*cos(alpha)-x.*sin(alpha))./sqrt(abs(1.0-abs(x.^2)-abs(y.^2)))));
V=(2.0+(y.*cos(alpha)-x.*sin(alpha)).*G)./(1.0-abs(x.^2)-abs(y.^2));
S=(x.*cos(alpha)+y.*sin(alpha))./(1.0-abs((x.*cos(alpha)+y.*sin(alpha)).^2));
fyout=-1.0*(sqrt(abs(abs((x-2*Dy).^2)+abs((y+2*Dx).^2)))./(1.0-abs(x.^2)-abs(y.^2))).*(3.0.*y.*V+cos(alpha).*G-2.0.*sin(alpha).*S);
% 主程序
clear all

h=pi/256;
w=2000;
tf=100000*2*pi/w;
tspan=0:h:tf;
z0=[0 0 0 0 0 0 0 0]';
[t,z]=ode45('liewenfun',tspan,z0);

figure(1)
subplot(2,2,1);
plot(t,z(:,1))
title('裂纹转子左端轴心径向位移x');
xlabel('t');ylabel('x1');
subplot(2,2,2);
plot(t,z(:,2))
title('裂纹转子左端轴心径向位移y');
xlabel('t');ylabel('y1');
subplot(2,2,3);
plot(z(:,1),z(:,2))
title('裂纹转子左端轴心轨迹');xlabel('x1');ylabel('y1');
subplot(2,2,4);
plot(z(:,1),z(:,5))
title('裂纹转子左端轴心相轨迹');xlabel('x1');ylabel('Dx1');

N1=length(z(:,1));fs=1024;stepf=fs/N1;
n=0:stepf:(fs/2-stepf);
Z1=abs(fft(z(:,1)));
figure(2)
plot(n(1:end),abs(Z1(1:N1/2)));grid on;
axis([-1 10 0 10000]);
title('转子左端轴心位移幅值谱');xlabel('频率');ylabel('FFT幅值');


发表于 2010-12-3 16:30 | 显示全部楼层
估计别人帮你查程序的可能性比较小
把书上的结果和你计算的结果都贴出来看看,是否能从结果上出什么端倪

点评

赞成: 3.0
赞成: 3
  发表于 2010-12-4 00:40
 楼主| 发表于 2010-12-3 21:17 | 显示全部楼层
回复 3 # happy 的帖子

谢谢happy教授提醒

我查的一篇论文里给出的ω=1540 rad/sA=0.5时的响应形式,和ω=1800 rad/sA=0.9时的响应形式分别如下图
从上到下分别为时序波形,相轨迹和功率谱图:

时序图.bmp

相轨迹.bmp
功率谱图.bmp

而我做出的图形是这样的:
ω=1540 rad/sA=0.5时的响应形式:
时序波形和相轨迹:
4.bmp
5.bmp
频谱图截图:
6.bmp

ω=1800 rad/sA=0.9时的响应形式:
时序波形和相轨迹:
1.bmp
2.bmp
频谱图截图:
3.bmp

真的是弄不清楚是怎么回事了,在论坛里把所有关于转子的帖子都看过了,信号处理也看了不少,可就是弄不明白了,只有请大家帮助了!

发表于 2010-12-4 08:43 | 显示全部楼层
一个很明显的问题就是你的计算结果中瞬态量没有消除

个人感觉你对这类系统的仿真模拟还没有入门
建议一开始不要做这样复杂的模型

评分

1

查看全部评分

 楼主| 发表于 2010-12-4 09:56 | 显示全部楼层
回复 5 # happy 的帖子

请问happy教授,怎样才能入门啊?需要学什么呢?我现在是被老师赶鸭子上架做这个仿真,之前一点基础都没有的,请happy教授指点!
发表于 2010-12-5 23:07 | 显示全部楼层
发表于 2010-12-27 22:05 | 显示全部楼层
我想问一下图中的A=0.9是什么参数呢   在你的公式中也没看到这个参数
 楼主| 发表于 2011-4-12 15:34 | 显示全部楼层
回复 8 # woshiaq 的帖子

A是无量纲裂纹深度,是实际裂纹深度与转轴半径的比值

评分

1

查看全部评分

发表于 2011-11-15 13:39 | 显示全部楼层
我运行了楼主的程序 ,总是提示有错误,甚至连楼主的曲线都没得出,正学习中,研究两天了也没修正好程序
发表于 2011-11-15 13:58 | 显示全部楼层
回复 10 # 0810064 的帖子

:@)求助完整格式:出错代码和出错提示
发表于 2011-11-15 18:45 | 显示全部楼层
谢谢楼上的朋友。还是在学习中
发表于 2011-11-15 19:35 | 显示全部楼层
总算得出和楼主一样的仿真图了。尽管不理想,总算是对两天的工作有一个交待,昨天推了半天的大矩阵。谢谢Chaching前辈的鼓励。刚入学,正处在学习的初级阶段。
发表于 2012-3-12 08:34 | 显示全部楼层
学习学习,
发表于 2012-4-14 19:18 | 显示全部楼层
请问你最后做出来了吗?
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

QQ|小黑屋|Archiver|手机版|联系我们|声振论坛

GMT+8, 2024-12-26 01:12 , Processed in 0.082063 second(s), 22 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表