24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 533  |  回复: 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

铁杆木虫 (小有名气)

还得麻烦你帮忙,谢谢

谢谢关注,但是我按照下面指令输入后,还是运行有问题
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的回帖
查看全部 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的回帖

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的回帖

zhaoshans

铁杆木虫 (小有名气)

Done! Thank you!
5楼2009-05-21 14:46:09
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 400分求调剂 +3 尴尬且挠头 2026-04-04 3/150 2026-04-04 08:41 by jp9609
[考研] 求调剂:085600材料与化工,考材科基,总分319 +18 678lucky 2026-03-31 22/1100 2026-04-04 07:38 by oooqiao
[考研] 考研调剂 +3 zybz冲冲冲 2026-04-03 3/150 2026-04-04 07:17 by wxiongid
[考研] 材料调剂 +10 吴棂颖! 2026-04-03 10/500 2026-04-04 06:12 by xuxiang
[考研] 271分求调剂学校 +11 zph158488! 2026-04-02 11/550 2026-04-04 01:06 by userper
[考研] 085600,专业课化工原理,321分求调剂 +6 大馋小子 2026-03-28 6/300 2026-04-03 22:38 by JimmyQAQ
[考研] 一志愿郑州大学材料与化工085600,求调剂 +17 吃的不少 2026-04-02 17/850 2026-04-03 21:48 by qlm5820
[考研] 0854求调剂 +3 assdll 2026-04-03 3/150 2026-04-03 14:32 by fxue1114
[考研] 333求调剂 +9 wfh030413@ 2026-04-03 9/450 2026-04-03 14:20 by 啊俊!
[考研] 材料专硕 调剂 +11 CXN123456 2026-04-03 11/550 2026-04-03 14:09 by 1753564080
[考研] 一志愿中国科学院大学265求调剂 +9 恬淡ye 2026-03-31 10/500 2026-04-03 11:10 by txp1986
[考研] 326求调剂 +3 9ahye 2026-04-02 4/200 2026-04-03 08:43 by Jaylen.
[考研] 349求调剂 +10 zwjjjjjj 2026-03-31 10/500 2026-04-02 20:13 by dongzh2009
[考研] 调剂 +3 好好读书。 2026-04-01 6/300 2026-04-02 15:49 by liumengping
[考研] 一志愿北京科技大学085601材料工程英一数二初试总分335求调剂 +9 双马尾痞老板2 2026-04-01 9/450 2026-04-02 12:14 by oooqiao
[考研] 0710生物学求调剂 +9 manman511 2026-04-01 9/450 2026-04-02 10:00 by zxl830724
[考研] 一志愿346上海大学生物学 +3 上海大学346调剂 2026-04-01 3/150 2026-04-02 08:36 by w虫虫123
[考研] 环境工程调剂 +9 hyzzzzzzz. 2026-04-01 9/450 2026-04-01 14:20 by salamander`
[考研] 322求调剂 +8 三水sss 2026-04-01 8/400 2026-04-01 10:19 by 唐沐儿
[考研] 求收留 +8 1943443204 2026-03-28 8/400 2026-03-31 15:00 by -迷了路啊路
信息提示
请填处理意见