24小时热门版块排行榜    

查看: 1242  |  回复: 9

wyjjf

新虫 (正式写手)

[交流] MATLAB求助 已有1人参与

【m.file】ODE45_fun:

function dx=ODE45_fun(t,x)
a1=1;a2=1;e1=9;e2=7;f1=56;f2=98;g1=76;g2=665;
a=a1+a2;
e=e1+e2;
f=f1+f2;
g=g1+g2;
dx(1)=x(3)+x(2)-x(4)*x(2)+2*x(5)*x(2)+x(2)*x(2)+x(5)+e+f+g;
dx(2)=x(1)+x(3)-x(4)*x(2)+x(2)*x(2)+x(5)*x(5)+x(5)*x(2)+e*f+g;
dx(3)=x(2)+x(1)-x(5)*x(1)+x(4)*x(3)-x(3)-x(4)-e*g-f;
x(6)=x(4)*x(5)+x(2)*x(3)+e*f+e*g;        % 就是x(6)  而非dx(6)
dx(4)=x(5)*a-x(3)*x(1)-x(3)-e*f*g*x(6)
dx(5)=x(4)*a-x(2)*x(1)+e*f*x(1)+x(2)*x(2)*x(5)+x(2)*x(5)*x(5)+e*f+f*g
dx=[dx(1);dx(2);dx(3);dx(4);dx(5);dx(6)];
【m.file】DE45_main:

tspan=[0,10];
x0=[0;0.1;2;0;0.1;2];
[t,x]=ode45('ODE45_fun',tspan,x0);
data=[t,x];
save ODE45_data.txt data -ascii
subplot(2,3,1),plot(t,x(1))
subplot(2,3,2),plot(t,x(2))
subplot(2,3,3),plot(t,x(3))
subplot(2,3,4),plot(t,x(4))
subplot(2,3,5),plot(t,x(5))
subplot(2,3,6),plot(t,x(6))

>> ODE45_main

dx =

  1.0e+010 *

    0.0000    0.0000   -0.0000   -2.6146


dx =

  1.0e+010 *

    0.0000    0.0000   -0.0000   -2.6146    0.0000

??? Attempted to access dx(6); index out of bounds because numel(dx)=5.

Error in ==> ODE45_fun at 14
dx=[dx(1);dx(2);dx(3);dx(4);dx(5);dx(6)];
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, ...

Error in ==> ODE45_main at 3
[t,x]=ode45('ODE45_fun',tspan,x0);

MATLAB求助
六元方程组怎么用MATLAB编辑程序?.jpg
MATLAB求助-1
六元方程组怎么用MATLAB编辑程序?.jpg
回复此楼

» 猜你喜欢

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

wyjjf

新虫 (正式写手)

一个老外给的回答
What is

x0=[0:0.1:2:0:0.1:2];     原来写的是x0=[0:0.1:2:0:0.1:2];
supposed to mean? On my version of matlab (2015a) it does not give me any warning but it creates an empty vector.

I suspect it's the cause of the warning and ultimately the cause of the error since you're passing empty for the initial condition.

希望论坛的大神多多帮忙!
2楼2015-03-14 17:24:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wyjjf

新虫 (正式写手)

empty vector.是什么意思? 还有
passing empty for the initial condition.
3楼2015-03-14 17:25:43
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

信彼南山

木虫 (著名写手)


小木虫: 金币+0.5, 给个红包,谢谢回帖
你这程序编的,符号跟方程还不一致,看起来好累的
你这里面Y只出现在方程4和方程5里面,可以考虑吧Y消去吧,变成5个方程5个变量的是不是能容易点
4楼2015-03-15 01:16:14
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

信彼南山

木虫 (著名写手)


小木虫: 金币+0.5, 给个红包,谢谢回帖
你这程序肯定有问题,跟你图上的方程完全不一样么。
而且方程咋还有那么多dx = 。。。 = 0

5楼2015-03-15 02:11:05
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wyjjf

新虫 (正式写手)

引用回帖:
5楼: Originally posted by 信彼南山 at 2015-03-15 02:11:05
你这程序肯定有问题,跟你图上的方程完全不一样么。
而且方程咋还有那么多dx = 。。。 = 0


抱歉,图片当时忘记删除了
都是dx = 。。。
6楼2015-03-15 07:20:43
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wyjjf

新虫 (正式写手)

第二幅图为准
7楼2015-03-15 07:53:24
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

信彼南山

木虫 (著名写手)


小木虫: 金币+0.5, 给个红包,谢谢回帖
按照你的变量定义,应该是:
CODE:
x(1) = x
x(2) = y
x(3) = z
x(4) = b
x(5) = c

那么:
CODE:
dx(1) = x(3)-x(2)+x(4)*x(3)-x(5)*x(2)-x(2)*x(2)-x(5)*x(2)-x(5)-e-f-g
合并同类项
dx(1) = x(3)-x(2)+x(4)*x(3)-2*x(5)*x(2)-x(2)*x(2)-x(5)-e-f-g

跟你程序里面的dx1不一样了
8楼2015-03-16 00:20:57
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wyjjf

新虫 (正式写手)

引用回帖:
8楼: Originally posted by 信彼南山 at 2015-03-16 00:20:57
按照你的变量定义,应该是:

x(1) = x
x(2) = y
x(3) = z
x(4) = b
x(5) = c


那么:

dx(1) = x(3)-x(2)+x(4)*x(3)-x(5)*x(2)-x(2)*x(2)-x(5)*x(2)-x(5)-e-f-g
合并同类项
dx(1) = x(3)-x(2)+x(4)* ...

谢谢回答
图片里的式子也是经过改动了,不好意思,忘记了
你是说式子不可能是引起整个程序错误的原因吧?
9楼2015-03-16 06:54:50
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

信彼南山

木虫 (著名写手)


小木虫: 金币+0.5, 给个红包,谢谢回帖
计算式不一样应该不会导致程序不可执行
程序不可执行一定是程序编写错误,而不是计算的公式不对

但是不同的计算式可能会导致不同的错误

另外,ODE算法是数值算法,它不是求解析解
这样的结果是:你的式子有错误的话,可能会导致方程异常的发散

因为那些实际的式子(也就是你的微分方程)应该是某种实际物理过程的数学模型,物理过程应该是最终趋于某一稳定状态的,与之对应其数学模型最后一定是收敛于某个结果的。

但如果式子有错误,那其数学模型计算的结果可能就不收敛了
10楼2015-03-16 11:18:05
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 wyjjf 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 326求调剂 +3 mlpqaz03 2026-03-15 3/150 2026-03-16 07:33 by Iveryant
[考研] 289求调剂 +5 步川酷紫123 2026-03-11 5/250 2026-03-15 00:45 by kruisytel
[考研] 080500,材料学硕302分求调剂学校 +4 初识可乐 2026-03-14 5/250 2026-03-14 21:08 by peike
[考研] 289求调剂 +4 这么名字咋样 2026-03-14 6/300 2026-03-14 18:58 by userper
[考研] 297求调剂 +4 学海漂泊 2026-03-13 4/200 2026-03-14 11:51 by 热情沙漠
[考研] 265求调剂 +9 小木虫085600 2026-03-09 12/600 2026-03-14 01:11 by JourneyLucky
[考研] 307求调剂 +7 超级伊昂大王 2026-03-10 7/350 2026-03-14 00:49 by JourneyLucky
[考研] 材料工程专硕,一志愿中国矿业大学,总分314,求调剂 +5 无懈可击的巨人 2026-03-10 5/250 2026-03-14 00:37 by JourneyLucky
[考研] 308求调剂 +3 是Lupa啊 2026-03-10 3/150 2026-03-14 00:30 by JourneyLucky
[考研] 311求调剂 +8 zchqwer 2026-03-10 8/400 2026-03-14 00:01 by JourneyLucky
[考研] 341求调剂 +4 番茄头--- 2026-03-10 4/200 2026-03-13 23:12 by JourneyLucky
[考研] 材料专硕288分求调剂 一志愿211 +4 在家想你 2026-03-11 4/200 2026-03-13 22:49 by JourneyLucky
[考研] 求材料调剂 085600英一数二总分302 前三科235 精通机器学习 一志愿哈工大 +4 林yaxin 2026-03-12 4/200 2026-03-13 22:04 by 星空星月
[考研] 329求调剂 +3 miaodesi 2026-03-12 4/200 2026-03-13 20:53 by 18595523086
[考研] 26调剂/材料科学与工程/总分295/求收留 +9 2026调剂侠 2026-03-12 9/450 2026-03-13 20:46 by 18595523086
[考研] 301求调剂 +6 Liyouyumairs 2026-03-11 6/300 2026-03-13 20:11 by JourneyLucky
[硕博家园] 085600 260分求调剂 +3 天空还下雨么 2026-03-13 5/250 2026-03-13 18:46 by 天空还下雨么
[考研] 289求调剂 +3 李政莹 2026-03-12 3/150 2026-03-13 11:02 by 求调剂zz
[考研] 296求调剂 +3 大口吃饭 身体健 2026-03-13 3/150 2026-03-13 10:31 by 学员8dgXkO
[考研] 工科0856专硕化学工程269能调剂吗 +10 我想读研11 2026-03-10 10/500 2026-03-13 10:14 by Yuyi.
信息提示
请填处理意见