| 查看: 987 | 回复: 3 | |||
| 当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖 | |||
[交流]
【求助】ode45数值求解常微分方程总是错,找不出原因
|
|||
|
程序如下:S1=0.4; S2=0.8; y=zeros(42,3); y(1,1)=6e10; y(2,1)=4e10; y(3,1)=0; for i=0:5; for j=1:7 if(j==6)|(j==7) [t,y]=ode45('tumor',[i*7+j i*7+j+1],[y(i*7+j,1) y(i*7+j,2) y(i*7+j,3)]); else a=y(i*7+j,1); y(i*7+j,1)=S1*a; b=y(i*7+j,2); y(i*7+j,2)=S2*b; y(i*7+j,3)=(1-S1)*a+(1-S2)*b; [t,y]=ode45('tumor',[i*7+j i*7+j+1],[y(i*7+j,1) y(i*7+j,2) y(i*7+j,3)]); end end end plot(t,y(1, ,'*',t,y(2, ,'.',t,y(3, ,'+');错误为:Index exceeds matrix dimensions. Error in ==> number1 at 12 [t,y]=ode45('tumor',[i*7+j i*7+j+1],[y(i*7+j,1) y(i*7+j,2) y(i*7+j,3)]); 我估计是向量传递出错了 发现ode45返回的是t和y(:,1) y(:,2) y(:,3)的列向量, 如果想得到向量的最后一个值应该怎么办? [ Last edited by liangbao on 2010-11-25 at 09:51 ] |
» 猜你喜欢
表哥与省会女结婚,父母去帮带孩子被省会女气回家生重病了
已经有12人回复
依托企业入选了国家启明计划青年人才。有无高校可以引进的。
已经有14人回复
江汉大学解明教授课题组招博士研究生/博士后
已经有3人回复
AI 太可怕了,写基金时,提出想法,直接生成的文字比自己想得深远,还有科学性
已经有11人回复
同年申请2项不同项目,第1个项目里不写第2个项目的信息,可以吗
已经有10人回复
依托企业入选了国家启明计划青年人才。有无高校可以引进的。
已经有11人回复
» 抢金币啦!回帖就可以得到:
西湖大学2026年秋季入学物理学、光学、电子信息方向博士生有名额速来!!!
+2/238
苏州国家实验室和中国科学技术大学联培博士招生
+1/182
华南师范大学(211)- 光电科学与工程学院 - 申请审核制(2026年4-5月份面试考核)
+2/106
澳洲西澳大学Dr Yiran Liu招全额奖学金和CSC奖学金博士生(3.8万澳币/年)
+1/104
陆军军医大学第二附属医院(新桥医院)冉茜课题组招聘科研人员
+1/87
江西理工大学联合中国科学院赣江创新研究院招收2026级博士研究生
+1/82
龙凤Tai——写给恋人的第100封情书
+1/81
北京-89175-事业单位-诚征女友
+1/67
2025难忘的时刻
+1/62
香港城市大学范俊教授招博士生 2名 机器学习和仿真设计新的电池材料 仅限C9高校学生
+1/15
【青岛大学】2026年生物与医药申请考核制博士生招生(含少数民族骨干人才)
+1/13
上海工程技术大学张培磊教授团队招收博士生
+1/7
澳科大招收2026年秋季药剂学/生物材料方向全奖博士研究生(春节不打烊)
+1/4
澳科大药学院诚招2026年秋季药剂学/生物材料硕士研究生(2026年3月5日报名截止)
+1/4
澳科大招收2026年秋季药物递送/生物材料方向全奖博士研究生(3月5日18:00截止)
+1/4
西交利物浦大学/GaN电力电子器件方向/张洁老师招博士研究生
+1/4
西交利物浦大学(苏州)/刘雯老师课题组/招博士研究生
+1/4
【科研助理招聘-北京理工大学-集成电路与电子学院-国家杰青团队】
+1/3
太原理工大学集成电路学院院长团队招收2026年博士研究生
+1/2
26储能博士申请自荐
+1/2
|
恩,谢谢 我这样改,运行通过了 您看看,没有什么对不? S1=0.4; S2=0.8; y=zeros(100,42); y(1,1)=6e10; y(1,2)=4e10; y(1,3)=0; for i=0:5; for j=1:7 if(j==6)|(j==7) tspan=i*7+j:0.05:i*7+j+1; [t,p]=ode45('tumor',tspan,[y(i*7+j,1) y(i*7+j,2) y(i*7+j,3)]); else y(i*7+j,1)=S1*y(i*7+j,1); y(i*7+j,2)=S2*y(i*7+j,2); y(i*7+j,3)=((1-S1)/S1)*y(i*7+j,1)+((1-S2)/S2)*y(i*7+j,2); tspan=i*7+j:0.05:i*7+j+1; [t,p]=ode45('tumor',tspan,[y(i*7+j,1) y(i*7+j,2) y(i*7+j,3)]); end plot(t,p(:,1),'*',t,p(:,2),'.',t,p(:,3)); hold on; y(i*7+j+1,1)=p(21,1); y(i*7+j+1,2)=p(21,2); y(i*7+j+1,3)=p(21,3); end end |
3楼2010-11-25 20:38:04
2楼2010-11-25 20:01:10
4楼2010-11-26 08:34:13













,'*',t,y(2,
回复此楼