24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 2296  |  回复: 10
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

brucexmc

新虫 (正式写手)

[求助] 求教ode45计算流程问题 已有2人参与

大家好,本人最近利用Matlab的ODE45函数求解微分方程[t,y]=ode45(@fun,tspan,t0),在fun函数中用写文件命令fsprint()记录了一些需要使用的参数,最后发现ODE45计算过程中时间项t不是单调增加,而是有时候会往回走一段儿,比如[0, 0.1, 0.2, 0.3, 0.25, 0.28, 0.3, 0.35, 0.4],但是最后输出的[t,y]中的t确实单调增大的。
所以想问一问各位有没有谁比较懂这个,ode45的计算流程是什么样的呢?
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   关注TA 给TA发消息 送TA红花 TA的回帖

shikang999

新虫 (小有名气)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
brucexmc: 金币+30, ★★★很有帮助 2014-11-29 19:17:09
1、ode45计算流程数值算法书上已经有,这里不详细叙述
2、你函数里记录的t和你外面输出的那个t不存在线性相关性(特别是一些算法做了技巧性处理,比如加入自适应或者复化分段自控误差等等),所以不影响你外面t按大小输出
3、看你这个数据记录情况,很可能t在1附近时,内部计算误差比较大,为了控制误差技巧性地自适应了一个区间(区间前后扩移了一下),进而得到相应点的值
4、当然,我并不了解ode45内部技巧性处理算法,仅是凭自己写的经验来判断!
5、希望能帮到你!

» 本帖已获得的红花(最新10朵)

我还是那个我,过去如此,未来亦如此!
9楼2014-11-29 13:51:10
已阅   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 11 个回答

brucexmc

新虫 (正式写手)

求大神指教啊,给自己顶一下下吧!
2楼2014-11-27 20:11:20
已阅   关注TA 给TA发消息 送TA红花 TA的回帖

月只蓝

主管区长 (职业作家)

【答案】应助回帖

感谢参与,应助指数 +1
你说的这种情况比较少见。
麻烦给出完整代码。
MATLAB、MS小问题、普通问题请发帖求助!时间精力有限,恕不接受无偿私信求助。
3楼2014-11-27 20:29:38
已阅   关注TA 给TA发消息 送TA红花 TA的回帖

brucexmc

新虫 (正式写手)

引用回帖:
3楼: Originally posted by 月只蓝 at 2014-11-27 20:29:38
你说的这种情况比较少见。
麻烦给出完整代码。

非常感谢您的回复,我的调用函数代码为:
clear all;
clc;
options=odeset('reltol',1e-5);
[t,y]=ode45(@fun,[0 2],[1 -1],options);
plot(t,y(:,1),t,y(:,2));

函数fun的定义为
function dx=fun(t,x)

if t<1
    a=0.1;
else
    a=0.2;
end

%数据写入文件
fdata=fopen('data.txt','a');
fprintf(fdata,'%f\n',t);
fclose(fdata);

dx=[x(2);1+a*x(2)];

经过计算之后,在t=1左右就会出现t值先变小,之后又变大的现象,下图所示为记录得到的t的变化情况。
求教ode45计算流程问题
方程时间序列.jpg

4楼2014-11-27 21:20:06
已阅   关注TA 给TA发消息 送TA红花 TA的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 求调剂 +3 图鉴212 2026-03-30 3/150 2026-03-31 00:31 by jp9609
[考研] 085701环境工程求调剂 +11 多久上课 2026-03-27 12/600 2026-03-30 21:21 by 研究僧导导
[考研] 材料工程专硕求调剂 +8 hyl3153942 2026-03-29 8/400 2026-03-30 20:45 by dophin1985
[考研] 0703一志愿9,初试成绩:338,四六级已过,有科研经历,求调剂! +7 Zuhui0306 2026-03-25 7/350 2026-03-30 19:01 by 源_2020
[考研] 287求调剂 +14 land xuxu 2026-03-26 14/700 2026-03-30 18:38 by 544594351
[考研] 342求调剂 +4 加油a李zs 2026-03-26 4/200 2026-03-30 16:39 by 晶体之美
[考研] 298求调剂 +3 什么是胖头鱼 2026-03-30 5/250 2026-03-30 14:41 by 青海小西牛
[考研] 284求调剂 +14 junqihahaha 2026-03-26 15/750 2026-03-30 14:12 by 探123
[考研] 282求调剂 +4 wcq131415 2026-03-24 4/200 2026-03-30 10:39 by Delta2012
[考研] 0856材料化工调剂 总分330 +14 zhubinhao 2026-03-27 14/700 2026-03-29 10:01 by Sjndkwm
[考研] 298求调剂 +4 种圣赐 2026-03-28 4/200 2026-03-29 08:42 by q1092522407
[考研] 调剂求院校招收 +6 鹤鲸鸽 2026-03-28 6/300 2026-03-29 08:15 by fmesaito
[考研] 070300求调剂306分 +4 26要上岸 2026-03-27 4/200 2026-03-28 13:06 by 唐沐儿
[考研] 药学105500求调剂 +3 Ssun。。 2026-03-28 3/150 2026-03-28 11:24 by lxf170613
[考研] 086000调剂 +3 7901117076 2026-03-26 3/150 2026-03-27 21:34 by Jianing_Mi
[考研] 调剂 +3 李嘉图·S·路 2026-03-27 3/150 2026-03-27 11:19 by wangjy2002
[考研] 324求调剂 +5 hanamiko 2026-03-26 5/250 2026-03-27 10:33 by wangjy2002
[考研] 求调剂 一志愿 本科 北科大 化学 343 +6 13831862839 2026-03-24 7/350 2026-03-26 22:57 by 不吃魚的貓
[考研] 0854人工智能方向招收调剂 +4 章小鱼567 2026-03-24 4/200 2026-03-25 13:29 by 2177681040
[考研] 调剂 +4 13853210211 2026-03-24 4/200 2026-03-24 19:44 by ms629
信息提示
请填处理意见