声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 3790|回复: 7

[随机振动] newmark法求解非线性随机振动

[复制链接]
发表于 2017-1-11 19:23 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 大小不是白 于 2017-1-11 19:53 编辑

大牛的有非线性系统结果比线性系统小,但我的比线性系统大,并且加大激励后非线性系统出现NaN,而线性系统结果正常。
求各位大神指教,已经纠结很久了。
matlab程序如下
N=30;  %%%%% 模态数量
L=20;
t_max=940;  %%%%%%%%%%%!!!!!!!!!!!!!!!!!!!!!!!  < tstep*numtstep
dt=0.5*1e-2;    %步长
E1=244.27.*(10.^9);
E2=122.56.*(10.^9);
M1=4429;
M2=3000;
V=0.3;
n=0;
h=0.6;
b=1;
A11=(E2./E1+n)./(n+1).*E1.*h./(1-(V.^2));
B11=n.*(E2./E1-1)./2./(n+1)./(n+2).*(h.^2).*E1./(1-(V.^2));
D11=((n.^3)+3.*(n.^2)+8.*n+3.*E2./E1.*(n.^2+n+2))./12./(n+1)./(n+2)./(n+3).*(h.^3).*E1./(1-(V.^2));
i1=(M2./M1+n)./(n+1).*M1.*h;  %%%%%%%  I1
A=D11-(B11.^2)./A11; %%%%%  
c=500;   %%%%%%  damping



M=eye(N);
C=c/i1*eye(N);
B=zeros(N);
for i=1:N
B(i,i)=(i*pi)^4*A/(i1*L^4);   %%%%%%%%%%%%%%%%%%%%4  
end
K=B;

%%%%%%%%% 非线性项
KK=zeros(N);
for i=1:N   
        KK(i,i)=(i*pi/L)^2*L;
end
RR=zeros(N);
for i=1:N   
        RR(i,i)=-(i*pi/L)^2*L;
end


%%%%%%%% random excitation
disq=zeros(N,1);
for i=1:N   
    kkkk=2*i-1;
    if kkkk<=N
    aa=2*sqrt(2)/pi/kkkk/i1;
    disq(kkkk,1)=aa;
    end
end    %%%%%%%  加权载荷(特征函数)


f=wt11e5(1,2)*disq;    %%%%%%  初始载荷值 t=0



u=zeros(N,1);%%%%[0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]';
v=zeros(N,1);%%%[0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]';

t(1)=0;               %初始时间
x(:,1)=u;             %初始位移
x1(:,1)=v;            %初始速度
a=M\f;
x2(:,1)=a;            %初始加速度

%%%%%%%%%%%newmark参数
gama=0.5;
beta=0.25;
a0=1/(beta*dt^2);
a1=gama/(beta*dt);
a2=1/(beta*dt);
a3=1/(2*beta)-1;
a4=gama/beta-1;
a5=dt*(gama/(2*beta)-1);
a6=dt*(1-gama);
a7=gama*dt;
%%%%%%%%%%%newmark参数


K1=K+a0*M+a1*C;      
i=2;
ll=t_max/dt;
for i=2:ll
      if mod(i,1000)==0
          outputa=i*dt;
      end
      t(i)=(i-1)*dt;
      Q=wt11e5(i,2)*disq;
      coef=A11/2/L/L/i1;      
      temp=coef*(x(:,i-1))'*KK*x(:,i-1);
      norn=1;iterx1=x(:,1);
      while (norn>0.001)
           q(:,i)=Q+M*(a0*x(:,i-1)+a2*x1(:,i-1)+a3*x2(:,i-1))+C*(a1*x(:,i-1)+a4*x1(:,i-1)+a5*x2(:,i-1));     
           iterx2=(K1-temp*RR)\q(:,i);
           diff=abs(iterx2-iterx1);
           norn=max(diff./abs(iterx1));
           iterx1=iterx2;
      end      
      x(:,i)=iterx1;  
      x2(:,i)=a0*(x(:,i)-x(:,i-1))-a2*x1(:,i-1)-a3*x2(:,i-1);  
       x1(:,i)=x1(:,i-1)+a6*x2(:,i-1)+a7*x2(:,i);
end  
plot(t,x(1,:))

本帖被以下淘专辑推荐:

回复
分享到:

使用道具 举报

发表于 2017-1-12 08:10 | 显示全部楼层
没有文献信息,大家不了解背景,没法了解你的程序,所以注定你得不到想要的答复…
发表于 2017-1-12 08:40 | 显示全部楼层
??? Undefined function or method 'wt11e5' for input arguments of type 'double'.

Error in ==> newmak at 52
f=wt11e5(1,2)*disq;    %%%%%%  初始载荷值 t=0

运行报错了
 楼主| 发表于 2017-1-12 10:46 | 显示全部楼层
本帖最后由 大小不是白 于 2017-1-12 10:49 编辑

不好意思,是我忽略了。@心灯 @truleeee 这是参考含分数阶梁的非线性随机振动做的功能梯度梁的随机振动,具体文献如下,wt11e5是激励谱

Nonlinear Random Vibrations of Beams with Fractional Derivative Elements.pdf

400.72 KB, 下载次数: 50

wt11e5.txt

5.8 MB, 下载次数: 42

发表于 2017-1-13 09:00 | 显示全部楼层
你程序里也没调入txt文件啊
发表于 2017-9-1 16:11 | 显示全部楼层
有没有Newmark解其它非线性问题的程序?
untitled.jpg
发表于 2017-11-26 14:59 | 显示全部楼层
帮你出图了,那么久也没见来交流。
发表于 2018-1-11 22:49 | 显示全部楼层
dollfish000 发表于 2017-11-26 14:59
帮你出图了,那么久也没见来交流。

怎么运行成功的?能分享一下程序吗?
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

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

GMT+8, 2024-12-23 16:39 , Processed in 0.076001 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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