24小时热门版块排行榜    

查看: 694  |  回复: 1

zhuang1017

铁虫 (小有名气)

[求助] matlab 编程求助 已有1人参与

各位前辈,matlab编程求助,关于碰撞振动的。
g(1)=0.02;
g(2)=0.02;
u=0.02;
odefunhdb = @(t,y)[y(2); (-2*g(1)*y(2)-y(1)+2*u*g(2)*(y(4)-y(2))+u*(y(3)-y(1))+cos(t));...
y(4); (-2*g(2)*(y(4)-y(2))-(y(3)-y(1)))];%把动力学方程中的二阶微分换成一阶
h = 0.05;  t = (0:h:100)'; y = zeros(length(t),4); y(1,: )=[0,0,0,0];%参数设置与初值
for n = 1:length(t)-1
       k1 = odefunhdb(t(n),y(n,: )');
       k2 = odefunhdb(t(n)+h/2,y(n,: )'+h/2*k1);
       k3 = odefunhdb(t(n)+h/2,y(n,: )'+h/2*k2);
       k4 = odefunhdb(t(n)+h,y(n,: )'+h*k3);
       y(n+1,: ) = y(n,: )+h/6*(k1+2*k2+2*k3+k4)';

end

plot(t,y(:,1))
这是没有发生碰撞时的动力学方程编程,现需要加入一个发生碰撞的条件,当在循环过程中满足y(3)-y(1)=0.8+1e-4时,有
y(2)+=0.9765*y(2)-+0.235*y(4)-
y(4)+=1.1765*y(2)--0.1765*y(4)-
其中+表示变化后的,-表示变化之前,然后用此刻的y(1),y(2)+,y(3),y(4)+作为初值继续在龙格库塔计算中循环,最后需要得到所有的y(1)
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

chendequan

铁虫 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
内容已删除
QQ:516477448,真心帮助解决MATLAB相关问题,提供详细资料,Word文档明确具体问题及要求,尽力而为!
2楼2017-06-17 15:09:36
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 zhuang1017 的主题更新
信息提示
请填处理意见