24小时热门版块排行榜    

Znn3bq.jpeg
查看: 548  |  回复: 5
当前主题已经存档。
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

zhaoshans

铁杆木虫 (小有名气)

[交流] 【求助】ode45问题【已完成】

2个M文件的时间范围和步长一样,在第2个M文件中参数u 是变化的,且u也是21*1的,u 的第一个值是10,从第二个开始都是第1个M文件中y(1) 的解,(通过输入y(:,1)可以得到所有21个解)。在第2个M文件中运行有问题,请高手指点,帮忙修改程序,而且能运行得了。谢谢

%第一个M文件
function dy=ivpode1(t,y)
dy=zeros(2,1);
dy(1)=y(2);
dy(2)=(1-y(1)^2)*y(2)-y(1);

%第二个M文件
function df=ivpode2(t,f)
global y
u=ones(length(t),1)*10;
for i=1:1:20
u(i<=t&t<(i+1))=y(i,1);
end
df=zeros(2,1);
df(1)=f(2);
df(2)=u*(1-f(1)^2)*f(2)-f(1);

t=0:1:20;
>> [t,y]=ode45(@ivpode1,t,[2,0]);
>> [t,f]=ode45(@ivpode2,t,[2,0]);
??? Attempted to access y(7,1); index out of bounds because size(y)=[6,1].

Error in ==> ivpode2 at 5
u(i<=t&t<(i+1))=y(i,1);

Error in ==> funfun\private\odearguments at 110
f0 = feval(ode,t0,y0,args{:});   % ODE15I sets args{1} to yp0.

Error in ==> ode45 at 173
[neq, tspan, ntspan, next, t0, tfinal, tdir, y0, f0, odeArgs, ...


[ Last edited by nono2009 on 2009-9-25 at 07:02 ]
回复此楼

» 猜你喜欢

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

zhaoshans

铁杆木虫 (小有名气)

Done! Thank you!
5楼2009-05-21 14:46:09
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 6 个回答

sitonyl

铁杆木虫 (文坛精英)

★ ★
woshilsh(金币+2,VIP+0):感谢帮助,期待大家点评 5-20 23:25
按照下述顺序调用即可解决问题:

global y
t=0:1:20;
[t,y]=ode45(@ivpode1,t,[2,0]);
[t,f]=ode45(@ivpode2,t,[2,0]);
zz
2楼2009-05-20 22:14:32
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zhaoshans

铁杆木虫 (小有名气)

还得麻烦你帮忙,谢谢

谢谢关注,但是我按照下面指令输入后,还是运行有问题
global y
t=0:1:20;
[t,y]=ode45(@ivpode1,t,[2,0]);
[t,f]=ode45(@ivpode2,t,[2,0]);


Warning: Failure at t=5.188906e+000.  Unable to meet integration tolerances without reducing the step size below the smallest value allowed (1.421085e-014) at time t.
> In ode45 at 355
3楼2009-05-21 11:44:16
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

sitonyl

铁杆木虫 (文坛精英)

★ ★ ★ ★ ★ ★ ★ ★
zhaoshans(金币+5,VIP+0):很耐心的帮忙 5-21 14:46
woshilsh(金币+3,VIP+0):问题得到楼主认可,嘉奖3金币! 5-21 15:19
woshilsh(金币+0,VIP+0):兄弟以后常来哈! 5-21 15:19
引用回帖:
Originally posted by zhaoshans at 2009-5-21 11:44:
谢谢关注,但是我按照下面指令输入后,还是运行有问题
global y
t=0:1:20;
[t,y]=ode45(@ivpode1,t,[2,0]);
[t,f]=ode45(@ivpode2,t,[2,0]);


Warning: Failure at t=5.188906e+000.  Unable to meet int ...

那是计算的精度不够,也就是积分计算中选择的步长太大的原因,可以试着更改一下积分步长,如
t=0:0.01:20;
应该就没问题了。
zz
4楼2009-05-21 12:05:14
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[基金申请] 国自然面上和省基金B类撒花 +15 花田半亩~白 2026-04-21 15/750 2026-04-23 00:09 by prepg
[考研] 有没有学校收留 +3 蒋昌鹏qtj 2026-04-20 3/150 2026-04-22 20:25 by 学员JpLReM
[考研] 312求调剂 +3 山河似你温柔 2026-04-22 3/150 2026-04-22 20:17 by 学员JpLReM
[考博] 华师大读博 +3 xq83 2026-04-22 5/250 2026-04-22 10:42 by xq83
[论文投稿] 急需审稿人!!! +3 陆小果画大饼 2026-04-21 3/150 2026-04-21 23:54 by jzy_123456
[考博] 申博/考博 +4 啃面包的小书虫 2026-04-17 8/400 2026-04-21 16:26 by 啃面包的小书虫
[考研] 295分求调剂 +6 ?要上岸? 2026-04-17 6/300 2026-04-21 08:18 by Equinoxhua
[考研] 085600材料与化工调剂 5+3 孜孜不倦2002 2026-04-19 6/300 2026-04-20 21:25 by babero
[论文投稿] 有没有接收比较快的sci期刊呀,最好在一个月之内的,研三孩子求毕业 20+4 之护着 2026-04-16 7/350 2026-04-20 15:45 by 豆豆7758
[考研] 337求调剂 +3 jyz04 2026-04-18 3/150 2026-04-20 12:24 by 研可安
[考博] 申博 +3 Xyyx. 2026-04-18 3/150 2026-04-20 10:44 by YuY66
[考研] 求计算机方向调剂 +3 Toffee2 2026-04-16 6/300 2026-04-19 22:37 by ll叶
[考研] 294求调剂 +8 淡然654321 2026-04-17 9/450 2026-04-19 19:51 by Equinoxhua
[考研] 304求调剂 +8 castLight 2026-04-16 8/400 2026-04-19 17:14 by 中豫男
[考研] 求调剂 +10 小聂爱学习 2026-04-16 12/600 2026-04-19 16:51 by 中豫男
[考研] 求调剂 +6 苦命人。。。 2026-04-18 7/350 2026-04-19 16:27 by 中豫男
[考研] 收到复试调剂但是去不了 +8 小蜗牛* 2026-04-16 8/400 2026-04-18 11:15 by zixin2025
[考研] 260求调剂 +4 Zyt1314520.. 2026-04-17 5/250 2026-04-18 08:28 by babysonlkd
[有机交流] 二苯甲酮酸类衍生物 50+3 小白爱主人 2026-04-17 6/300 2026-04-17 18:47 by kf2781974
[考研] 322求调剂 +6 tekuzu 2026-04-17 6/300 2026-04-17 13:48 by Espannnnnol
信息提示
请填处理意见