声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 2126|回复: 3

[共享资源] maker系列-有阻尼自由振动程序

[复制链接]
发表于 2005-7-28 17:46 | 显示全部楼层 |阅读模式

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

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

x
一个简单的例子,可以对照相关振动和动力学的书,非常容易理解,望对初学者有一定的帮助,针对临界阻尼,欠阻尼,过阻尼的情况

function maker1(m,c,k,x0,v0,time)
%maker1用来计算单自由度系统响应
%此程序针对两种输入形势(m,c,k,x0,v0,tf)和(zeta,wn,x0,v0,tf)
%m-为质量,c-阻尼,k-刚度,x0-初位移,v0-除速度;time-仿真时间
%zeta-阻尼系数,wn-固有频率
%chinamaker@dytrol.com
%2003.11.26
clc
%针对输入形势做出判断
if nargin==5 %输出参数的个数
z=m;
wn=c;
time=v0;
v0=x0;
x0=k;
m==1;
c=2*z*wn;
k=wn^2;
end

k=1;
wn=sqrt(k/m);%固有频率
z=c/2/m/wn;%相对阻尼系数
wd=wn*sqrt(1-z^2);%系统的实际振动频率
fprintf('固有频率%.3g.rad/s.\n',wn);
fprintf('阻尼系数%.3g.\n',z);
fprintf('振动频率%.3g.\n',wd);
t=0:time/1000:time;
if z<1 %欠阻尼情况
Ampli=sqrt(((v0+z*wn*x0)^2+(x0*wd)^2)/wd^2);%系统振幅
phi=atan2(x0*wd,v0+z*wn*x0);%系统相位角
x=Ampli*exp(-z*wn*t).*sin(wd*t+phi);%系统振动时程曲线
fprintf('Ampli=%.3g\n',Ampli);
fprintf('Ampli2=%,3g\n',phi);
elseif z==1 %临界阻尼
a1=x0;
a2=v0+wn*x0;
fprintf('a1=%.3g.\n',a1);
fprintf('a2=%.3g.\n',a2);
x=(a1+a2*t).*exp(-wn*t);
else %过阻尼
a1=(-v0+(-zsqrt(z^2-1))*wn*x0)*wn*x0/2/wn/sqrt(z^2-1);
a2=(v0+(z+sqrt(z^2-1))*wn*x0)/2/wn/sqrt(z^2-1);
fprintf('a1=%.3g.\n',a1);
fprintf('a2=%.3g.\n',a2);
x=exp(-wn*t).*(a1*exp(wn*sqrt(z^2-1)*t)+a2*exp(wn*sqrt(z^2-1)*t));
end
plot(t,x);
grid;
xlabel('Time(s)');
ylabel('Amplitude');

运行结果:
>>maker1(1,0.05,1,1,1,100)
固有频率1.rad/s.
阻尼系数0.025.
振动频率1.
Ampli=1.43
phi=0.773
tb9Dn4Cn.jpg
回复
分享到:

使用道具 举报

发表于 2006-12-7 20:40 | 显示全部楼层
输入形式是(zeta,wn,x0,v0,tf)是什莫含义?程序里对应法nargin==5的else在哪里?
发表于 2006-12-9 09:43 | 显示全部楼层
输入形式是(zeta,wn,x0,v0,tf)是什莫含义?


注释中不是有说明吗?
发表于 2006-12-9 09:45 | 显示全部楼层
程序里对应法nargin==5的else在哪里?


不需要else,如果输入参数不是5个,就不需要做特殊处理,直接跳过

  1. if nargin==5 %输出参数的个数
  2. z=m;
  3. wn=c;
  4. time=v0;
  5. v0=x0;
  6. x0=k;
  7. m==1;
  8. c=2*z*wn;
  9. k=wn^2;
  10. end
复制代码


这一段
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

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

GMT+8, 2024-9-24 23:25 , Processed in 0.060531 second(s), 21 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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