欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > DOCX文档下载  

    动力学系统时域响应计算的六种方法Matlab源程序.docx

    • 资源ID:3333399       资源大小:37.26KB        全文页数:8页
    • 资源格式: DOCX        下载积分:6.99金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要6.99金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    动力学系统时域响应计算的六种方法Matlab源程序.docx

    动力学系统时域响应计算的六种方法Matlab源程序Newmark法Matlab源程序function acc,vel,dsp=Newmark_2(kk,cc,mm,fd,nt,dt,q0,dq0)%输入参数% kk-刚度矩阵% mm-质量矩阵% cc-阻尼矩阵% q0-初始位移% dq0-初始速度% dt-时间步长% nt-总的计算步数,等于结束时间除以dt%返回值% dsp-位移% vel-速度% acc-加速度sdof,n2=size(kk);dsp=zeros(sdof,nt); % displacement matrixvel=zeros(sdof,nt); % velocity matrixacc=zeros(sdof,nt); % acceleration matrixdsp(:,1)=q0; % initial displacementvel(:,1)=dq0; % initial velocityalpha=0.5; beta=0.5; % select the parametersacc(:,1)=inv(mm)*(fd(:,1)-kk*dsp(:,1)-cc*vel(:,1); % compute the initial acceleration (t=0)ekk=kk+mm/(alpha*dt2)+cc*beta/(alpha*dt);for it=1:nt % loop for each time stepcfm=dsp(:,it)/(alpha*dt2)+vel(:,it)/(alpha*dt)+acc(:,it)*(0.5/alpha-1);cfc=dsp(:,it)*beta/(alpha*dt)+vel(:,it)*(beta/alpha-1).+acc(:,it)*(0.5*beta/alpha-1)*dt;efd=fd(:,it)+mm*cfm+cc*cfc; % compute the effective force vectordsp(:,it+1)=inv(ekk)*efd; % find the displacement at time t+dtacc(:,it+1)=(dsp(:,it+1)-dsp(:,it)/(alpha*dt2)-vel(:,it)/(alpha*dt).-acc(:,it)*(0.5/alpha-1); % find the acceleration at time t+dtvel(:,it+1)=vel(:,it)+acc(:,it)*(1-beta)*dt+acc(:,it+1)*beta*dt;% find the velocity at time t+dtend中心差分法Matlab源程序function acc,vel,dsp=central_diff(kk,cc,mm,fd,nt,dt,q0,dq0)%输入参数% kk-刚度矩阵% mm-质量矩阵% cc-阻尼矩阵% q0-初始位移% dq0-初始速度% dt-时间步长% nt-总的计算步数,等于结束时间除以dt%返回值% dsp-位移% vel-速度% acc-加速度sdof,n2=size(kk);dsp=zeros(sdof,nt); % displacement matrixvel=zeros(sdof,nt); % velocity matrixacc=zeros(sdof,nt); % acceleration matrixdsp(:,1)=q0; % initial displacementvel(:,1)=dq0; % initial velocityacc(:,1)=inv(mm)*(fd(:,1)-kk*dsp(:,1)-cc*vel(:,1);dsp0=dsp(:,1)-vel(:,1)*dt+0.5*acc(:,1)*dt2;ekk=mm/dt2+cc/(2*dt);efd=fd(:,1)-(kk-2*mm/dt2)*dsp(:,1)-(mm/dt2-cc/(2*dt)*dsp0;dsp(:,1+1)=inv(ekk)*efd;for it=2:nt % loop for each time step after first stepefd=fd(:,it)-(kk-2*mm/dt2)*dsp(:,it)-(mm/dt2-cc/(2*dt)*dsp(:,it-1);% compute the effective force vectordsp(:,it+1)=inv(ekk)*efd; % find the dsp at t+dtacc(:,it)=(dsp(:,it+1)-2*dsp(:,it)+dsp(:,it-1)/dt2; % find the acc at tvel(:,it)=(dsp(:,it+1)-dsp(:,it-1)/(2*dt); % find the vel at tacc(:,it+1)=acc(:,it); vel(:,it+1)=vel(:,it);endHoubolt法Matlab源程序function acc,vel,dsp=Houbolt(kk,cc,mm,fd,nt,dt,q0,dq0)%输入参数% kk-刚度矩阵% mm-质量矩阵% cc-阻尼矩阵% q0-初始位移% dq0-初始速度% dt-时间步长% nt-总的计算步数,等于结束时间除以dt%返回值% dsp-位移% vel-速度% acc-加速度sdof,n2=size(kk);dsp=zeros(sdof,nt); % displacement matrixvel=zeros(sdof,nt); % velocity matrixacc=zeros(sdof,nt); % acceleration matrixdsp(:,1)=q0; % initial displacementvel(:,1)=dq0; % initial velocityacc(:,1)=inv(mm)*(fd(:,1)-kk*dsp(:,1)-cc*vel(:,1);dsp0=dsp(:,1)-vel(:,1)*dt+0.5*acc(:,1)*dt2;ekk=mm/dt2+cc/(2*dt); % compute the effective stiffness matrixit=1;efd=fd(:,it)-(kk-2*mm/dt2)*dsp(:,it)-(mm/dt2-cc/(2*dt)*dsp0;dsp(:,it+1)=inv(ekk)*efd; % find the dsp at t+dtfor it=2:3 % loop for two steps after first stepefd=fd(:,it)-(kk-2*mm/dt2)*dsp(:,it)-(mm/dt2-cc/(2*dt)*dsp(:,it-1);dsp(:,it+1)=inv(ekk)*efd; % find the dsp at t+dtacc(:,it)=(dsp(:,it+1)-2*dsp(:,it)+dsp(:,it-1)/dt2; % find the acc at tvel(:,it)=(dsp(:,it+1)-dsp(:,it-1)/(2*dt); % find the vel at tendekk=kk+cc*11/(6*dt)+mm*2/(dt*dt);for it=3:nt-1 % loop for each time step after initial stepcfm=dsp(:,it)*5/dt2-dsp(:,it-1)*4/dt2+dsp(:,it-2)*1/dt2;cfc=dsp(:,it)*3/dt-dsp(:,it-1)*3/(2*dt)+dsp(:,it-2)*1/(3*dt);efd=fd(:,it+1)+mm*cfm+cc*cfc;dsp(:,it+1)=inv(ekk)*efd; % find the dsp at t+dtacc(:,it)=(2*dsp(:,it+1)-5*dsp(:,it)+4*dsp(:,it-1)+dsp(:,it-2)/dt2;vel(:,it)=(11*dsp(:,it+1)-18*dsp(:,it)+9&dsp(:,it-1)-2*dsp(:,it-2)/(6*dt);acc(:,it+1)=acc(:,it); vel(:,it+1)=vel(:,it);end

    注意事项

    本文(动力学系统时域响应计算的六种方法Matlab源程序.docx)为本站会员(牧羊曲112)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开