声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 912|回复: 1

[编程技巧] 跪问:为何计算结果发散

[复制链接]
发表于 2009-11-5 10:34 | 显示全部楼层 |阅读模式

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

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

x
小弟最近在做车桥系统响应计算,应用RungeKuta法,以下是主程序:
tspan=t0:h:te;
n=length(tspan);
z0=[0 0 0 0 0 0 0 0 0 0 0 0 0 0]';%任意设置初值为0
neq=length(z0);
z=zeros(neq,n);;
x=zeros(1,n);
P=zeros(neq,4);
z(:,1)=z0;
for i=2:n
    ti=tspan(i-1);
    zi=z(:,i-1);
    P(:,1)=feval(@fun,ti,zi);
    P(:,2)=feval(@fun,ti+0.5*h,zi+0.5*h*P(:,1));
    P(:,3)=feval(@fun,ti+0.5*h,zi+0.5*h*P(:,2));
    P(:,4)=feval(@fun,tspan(i),zi+h*P(:,3));
    z(:,i)=zi+(h/6)*(P(:,1)+2*P(:,2)+2*P(:,3)+P(:,4));
end这应该算是通用的简单RT四阶迭代公式了,可小弟计算结果疯狂飙升至1.0e+133,仅计算前五阶。但用ode45求解时却能得到相当满意的结果,不足处是其计算速度太慢,我不必取那么小的步长。
望大侠指点迷津啊,急求·····
回复
分享到:

使用道具 举报

 楼主| 发表于 2009-11-5 11:15 | 显示全部楼层
问题解决,步长选择问题
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

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

GMT+8, 2024-11-29 23:02 , Processed in 0.053863 second(s), 18 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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