声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 2370|回复: 6

[编程技巧] 怎样用MATLAB计算my''+cy'+ky+A*sgn(y')=B*sin(t)运动微分方程?

[复制链接]
发表于 2007-8-20 10:20 | 显示全部楼层 |阅读模式

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

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

x
怎样用MATLAB计算运动微分方程?


运动微分方程为:my''+cy'+ky+A*sgn(y')=B*sin(t)
其中y是t的函数,m为质量,,c阻尼系数,,k结构刚度,A,B是常数,他们都是已知量.
y''表示加速度,y'表示速度,y表示位移,sgn()表示符号函数;
怎样用MATLAB计算这个运动微分方程呀?
请各位高手帮帮忙呀!!!

[ 本帖最后由 sdpxzcz 于 2007-8-20 10:42 编辑 ]
回复
分享到:

使用道具 举报

发表于 2007-8-20 10:31 | 显示全部楼层
用ode45计算,具体你可以参考matlab帮助文件

评分

1

查看全部评分

 楼主| 发表于 2007-8-20 10:36 | 显示全部楼层
关键是里面有关于y'(速度)的符号函数呀!
不知道怎么用,
咕噜噜你可以帮帮我吗?
我的QQ:119452259
电子邮箱:sdpxzcz@163.com
发表于 2007-8-20 10:43 | 显示全部楼层

回复 #3 sdpxzcz 的帖子

直接加一个判断语句。

你可以参考分段线性的例子,原来的都是判断位移,你把它改成速度就可以了

评分

1

查看全部评分

 楼主| 发表于 2007-8-20 10:49 | 显示全部楼层
我是Matlab新手,可不可以把程序编给我看看呀!非常感谢!
发表于 2007-8-20 11:18 | 显示全部楼层

回复 #3 sdpxzcz 的帖子

速度也可以啊,在ode45里面
function doty=myff(t,y)
c=1;k=20;A=13;B=2;
doty=[y(2);-(c*y(2)+k*y(1)+A*sign(y(1))+B*sin(t))];
[t,y]=ode45('myff',[0,1],[0 0])
相应参数自己修改

评分

1

查看全部评分

 楼主| 发表于 2007-10-7 22:48 | 显示全部楼层
谢谢各位呀!!!
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

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

GMT+8, 2024-11-18 17:37 , Processed in 0.058237 second(s), 18 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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