声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 1162|回复: 2

[转子动力学] 为什么用ode45求解时位移ss和速度vv是零?

[复制链接]
发表于 2008-3-21 10:21 | 显示全部楼层 |阅读模式

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

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

x
为什么用ode45求解时位移ss和速度vv是零?是不是计算精度问题?请赐教;
方程
[localimg=640,278]1[/localimg]
程序:

function dy=even(t,y,q)
    dy=zeros(2,1);
    cca=0.5;ch=81.2;kca=25392;tao6=1e+5;m=3.24;beta=0.4488;w=157.1;
   
dy(1)=y(2);  dy(2)=(-(ch*((cos(w*t-q*beta)).^2+(cos(w*t-q*beta+2*beta)).^2+(cos(w*t-q*beta+4*beta)).^2+(cos(w*t-q*beta+6*beta)).^2)+cca)*y(2)-(tao6*((cos(w*t-q*beta)).^2+(cos(w*t-q*beta+2*beta)).^2+(cos(w*t-q*beta+4*beta)).^2+(cos(w*t-q*beta+6*beta)).^2)+kca)*y(1))/m;
   
   
   
   function dy=odd(t,y,q)
    dy=zeros(2,1);
    cca=0.5;ch=81.2;kca=25392;tao6=1e+5;m=3.24;beta=0.4488;w=157.1;
   
dy(1)=y(2);   dy(2)=(-(ch*((cos(w*t-(q-1)*beta)).^2+(cos(w*t-(q-1)*beta+2*beta)).^2+(cos(w*t-(q-1)*beta+4*beta)).^2)+cca)*y(2)-(tao6*((cos(w*t-(q-1)*beta)).^2+(cos(w*t-(q-1)*beta+2*beta)).^2+(cos(w*t-(q-1)*beta+4*beta)).^2)+kca)*y(1))/m;



y(1,1)=0;y(1,2)=0;beta=0.4488;w=157.1;
N=ceil(20*pi/beta);   
dim(1)=1;
for n=0:1:N
    q(n+1)=n;
    if mod(n,2)==0;                                                                    %判断奇数偶数
        tspan=[n*beta/w,(n+1)*beta/w];
        initial=[y(dim(1),1);y(dim(1),2)];
       options = odeset('RelTol',1e-6,'AbsTol',1e-14);
             [t,y]=ode45(@evens,tspan,initial,options,q(n+1));
    else
        tspan=[n*beta/w,(n+1)*beta/w];
        initial=[y(dim(1),1);y(dim(1),2)];                               %本次计算的初值是上一次计算的末值
       options = odeset('RelTol',1e-6,'AbsTol',1e-14);
             [t,y]=ode45(@odds,tspan,initial,options,q(n+1));
    end
    tt(:,n+1)=t;                                                                         %取出时间
    dim=size(y);
     ss(:,n+1)=y(:,1);                                                                %取出位移
     vv(:,n+1)=y(:,2);                                                                %取出速度
end
方程.jpg

程序.txt

1.57 KB, 下载次数: 6

回复
分享到:

使用道具 举报

发表于 2008-3-21 11:10 | 显示全部楼层

回复 楼主 的帖子

简单看了一下,你没有定义odds函数吧?
 楼主| 发表于 2008-3-21 14:06 | 显示全部楼层

回复 2楼 的帖子

抱歉,odds和evens函数就是程序中的odd和even函数,我发程序时漏掉一个s了,不过把补上后结果仍然是零。
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

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

GMT+8, 2024-9-22 10:03 , Processed in 0.057146 second(s), 21 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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