24小时热门版块排行榜    

Znn3bq.jpeg
查看: 1705  |  回复: 6

monixia

木虫 (小有名气)

[求助] 求解决matlab解非线性方程组出现的问题 已有1人参与

各位matlab大神,我计算的方程组如下,
>> m=0.00040;
f=@(x)([3.14159*m^3+1.9635e-7*x(1)-0.002*3.14159*0.0005^2;
6*(m+x(2))*1.9635e-7-3.14159*m^3+1.9635e-7*x(3)+1.9635e-7*x(6)*(m+x(2))/x(4)-0.002*3.14159*0.0005^2;
3.14159*m^3*x(4)/(m+x(2))+1.9635e-7*x(1)*x(5)/(x(1)+x(3))-1/6*1e-6;
(6*1.9635e-7*(m+x(2))-3.14159*m^3)*x(4)/(m+x(2))+1.9635e-7*x(3)*x(5)/(x(1)+x(3))+1.9635e-7*x(6)-1/6*1e-6;
fix(0.05/(x(1)+x(3)))*(32*0.0010087*x(5)/0.0005^2*x(3)+7.16*0.07275*(3*(1.0087*x(5)/72.75)^(2/3)/0.0005/(1+3.34*(1.0087*x(5)/72.75)^(2/3))))-6455.68*x(6)
0.05/(m+x(2))*(32*0.0010087*x(4)/0.0005^2*x(2)+7.16*0.07275*(3*(1.0087*x(4)/72.75)^(2/3)/0.0005/(1+3.34*(1.0087*x(4)/72.75)^(2/3))))-6455.68*x(6)]);
options = optimset('MaxIter',1e30,'MaxFunEvals',1e50,'TolFun',1e-50);
x=fsolve(f,[0.005 0.0005 0.001 0.15 0.9 0.3],options)

No solution found.

fsolve stopped because the relative size of the current step is less than the
default value of the step size tolerance squared, but the vector of function values
is not near zero as measured by the selected value of the function tolerance.

<stopping criteria details>


x =

    0.0070   -0.0001    0.0030    0.0344    1.0563    0.4352


fsolve stopped because the relative norm of the current step, 2.848645e-15, is less than
max(options.TolX^2,eps) = 1.000000e-12. However, the sum of squared function values,
r = 3.833839e-15, exceeds sqrt(options.TolFun) = 1.000000e-25.

Optimization Metric                                               Options
relative norm(step) =   2.85e-15                max(TolX^2,eps) =   1e-12 (default)
r =   3.83e-15                                    sqrt(TolFun) =  1.0e-25 (selected)

如上,初值已经取的很接近实验值了,还是没有满意的结果。将matlab算的带入六个方程,
ans =
   4.7168e-12
ans =
  -8.4160e-11
ans =
   1.5716e-09
ans =
  -1.5222e-09
ans =
   15.7955
ans =
  232.7567
后两项收敛不是很好。我已经尝试把optimset调到很小了,可是还是没有满意的结果。
求助各位大牛,这个该怎么解?还是方程需要修改?

如果圆满解决,可以加金币~
回复此楼

» 猜你喜欢

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

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

月只蓝

主管区长 (职业作家)

【答案】应助回帖

感谢参与,应助指数 +1
1stOpt代码(注意不是MATLAB软件代码):
CODE:
Constant m=0.00040;
Parameters x(1:6);
Function 3.14159*m^3+1.9635e-7*x1-0.002*3.14159*0.0005^2;
6*(m+x2)*1.9635e-7-3.14159*m^3+1.9635e-7*x3+1.9635e-7*x6*(m+x2)/x4-0.002*3.14159*0.0005^2;
3.14159*m^3*x4/(m+x2)+1.9635e-7*x1*x5/(x1+x3)-1/6*1e-6;
(6*1.9635e-7*(m+x2)-3.14159*m^3)*x4/(m+x2)+1.9635e-7*x3*x5/(x1+x3)+1.9635e-7*x6-1/6*1e-6;
(0.05/(x1+x3))*(32*0.0010087*x5/0.0005^2*x3+7.16*0.07275*(3*(1.0087*x5/72.75)^(2/3)/0.0005/(1+3.34*(1.0087*x5/72.75)^(2/3))))-6455.68*x6;
0.05/(m+x2)*(32*0.0010087*x4/0.0005^2*x2+7.16*0.07275*(3*(1.0087*x4/72.75)^(2/3)/0.0005/(1+3.34*(1.0087*x4/72.75)^(2/3))))-6455.68*x6;

计算结果:
CODE:
函数表达式 1: 3.14159*0.0004^3+1.9635e-7*x1-0.002*3.14159*0.0005^2
         2: 6*(0.0004+x2)*1.9635e-7-3.14159*0.0004^3+1.9635e-7*x3+1.9635e-7*x6*(0.0004+x2)/x4-0.002*3.14159*0.0005^
            2
         3: 3.14159*0.0004^3*x4/(0.0004+x2)+1.9635e-7*x1*x5/(x1+x3)-1/6*1e-6
         4: (6*1.9635e-7*(0.0004+x2)-3.14159*0.0004^3)*x4/(0.0004+x2)+1.9635e-7*x3*x5/(x1+x3)+1.9635e-7*x6-1/6*1e
            -6
         5: (0.05/(x1+x3))*(32*0.0010087*x5/0.0005^2*x3+7.16*0.07275*(3*(1.0087*x5/72.75)^(2/3)/0.0005/(1+3.34*(1.0087
            *x5/72.75)^(2/3))))-6455.68*x6
         6: 0.05/(0.0004+x2)*(32*0.0010087*x4/0.0005^2*x2+7.16*0.07275*(3*(1.0087*x4/72.75)^(2/3)/0.0005/(1+3.34
            *(1.0087*x4/72.75)^(2/3))))-6455.68*x6
目标函数值: 8.44256812628831E-7
x1: 1.38116851215046
x2: 0.213584946434081
x3: 0.106474657467166
x4: 0.0176943028978422
x5: 0.2480594437683
x6: 0.0180988189842738
6个方程目标函数值:
ans =

  2.6982e-007


ans =

  3.1421e-007


ans =

-1.2143e-007


ans =

-1.3880e-007


ans =

  1.4211e-013


ans =

-8.5265e-014

1.5版本计算结果不唯一,以下再例举6组解:
CODE:
目标函数值: 8.81354127610376E-9
x1: 0.0270233957846693
x2: -4.08878886642551E-5
x3: 0.0126231922603729
x4: 0.0323838969507018
x5: 1.10773562695781
x6: 0.383966561657027


目标函数值: 5.88138553710961E-7
x1: 2.08840573452721
x2: -0.0811262956407749
x3: 0.416992754705403
x4: 0.19145905588163
x5: 1.1205806122223
x6: 0.187004870338678


目标函数值: 6.80817986394196E-7
x1: 2.10149925984767
x2: -0.218796314718131
x3: 0.718745532551135
x4: 0.109052962294469
x5: 0.42221573528721
x6: 0.10785410685195

目标函数值: 1.10547660307994E-6
x1: 2.53429273796369
x2: -0.218841716843157
x3: 1.13544861896696
x4: 0.431086688290742
x5: 1.38395310620881
x6: 0.42858810590596

目标函数值: 1.32464424554872E-6
x1: 4.35394653830248
x2: -0.286471171270745
x3: 2.04705166768062
x4: 0.401695771492555
x5: 1.24966197787108
x6: 0.39985126552927

目标函数值: 7.67093610988707E-7
x1: 1.6997802237498
x2: -0.00709436222448859
x3: -0.505554887761384
x4: 0.00623112985186669
x5: 0.00101373791179563
x6: -0.000417366283335469

MATLAB、MS小问题、普通问题请发帖求助!时间精力有限,恕不接受无偿私信求助。
2楼2014-11-05 13:40:03
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

monixia

木虫 (小有名气)

引用回帖:
2楼: Originally posted by 月只蓝 at 2014-11-05 13:40:03
1stOpt代码(注意不是MATLAB软件代码):
Constant m=0.00040;
Parameters x(1:6);
Function 3.14159*m^3+1.9635e-7*x1-0.002*3.14159*0.0005^2;
6*(m+x2)*1.9635e-7-3.14159*m^3+1.9635e-7*x3+1.9635e-7*x6*(m+ ...

非常感谢你的解答,1stOpt用起来真方便。不过,我有个问题就是,我希望找到初值附近的零点,但是几乎每次算出来的值都差很多(至少应该没有负数出现)。是不是不太容易实现在初值附近寻找呢?
3楼2014-11-05 19:09:09
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

月只蓝

主管区长 (职业作家)

【答案】应助回帖

引用回帖:
3楼: Originally posted by monixia at 2014-11-05 19:09:09
非常感谢你的解答,1stOpt用起来真方便。不过,我有个问题就是,我希望找到初值附近的零点,但是几乎每次算出来的值都差很多(至少应该没有负数出现)。是不是不太容易实现在初值附近寻找呢?...

可以设定x的取值范围
MATLAB、MS小问题、普通问题请发帖求助!时间精力有限,恕不接受无偿私信求助。
4楼2014-11-05 20:52:13
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

月只蓝

主管区长 (职业作家)

【答案】应助回帖

引用回帖:
3楼: Originally posted by monixia at 2014-11-05 19:09:09
非常感谢你的解答,1stOpt用起来真方便。不过,我有个问题就是,我希望找到初值附近的零点,但是几乎每次算出来的值都差很多(至少应该没有负数出现)。是不是不太容易实现在初值附近寻找呢?...

比如:
让所有x都大于0:
CODE:
Constant m=0.00040;
Parameters x(1:6)[0,];
Function 3.14159*m^3+1.9635e-7*x1-0.002*3.14159*0.0005^2;
6*(m+x2)*1.9635e-7-3.14159*m^3+1.9635e-7*x3+1.9635e-7*x6*(m+x2)/x4-0.002*3.14159*0.0005^2;
3.14159*m^3*x4/(m+x2)+1.9635e-7*x1*x5/(x1+x3)-1/6*1e-6;
(6*1.9635e-7*(m+x2)-3.14159*m^3)*x4/(m+x2)+1.9635e-7*x3*x5/(x1+x3)+1.9635e-7*x6-1/6*1e-6;
(0.05/(x1+x3))*(32*0.0010087*x5/0.0005^2*x3+7.16*0.07275*(3*(1.0087*x5/72.75)^(2/3)/0.0005/(1+3.34*(1.0087*x5/72.75)^(2/3))))-6455.68*x6;
0.05/(m+x2)*(32*0.0010087*x4/0.0005^2*x2+7.16*0.07275*(3*(1.0087*x4/72.75)^(2/3)/0.0005/(1+3.34*(1.0087*x4/72.75)^(2/3))))-6455.68*x6;

计算结果:
目标函数值: 2.37290707692599E-8
x1: 0.0105848644277172
x2: 0.0161346934843435
x3: 0.000420183576622565
x4: 0.115861612534128
x5: 0.876247555934376
x6: 0.132259599167984
MATLAB、MS小问题、普通问题请发帖求助!时间精力有限,恕不接受无偿私信求助。
5楼2014-11-05 20:57:57
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

monixia

木虫 (小有名气)

引用回帖:
5楼: Originally posted by 月只蓝 at 2014-11-05 20:57:57
比如:
让所有x都大于0:

Constant m=0.00040;
Parameters x(1:6);
Function 3.14159*m^3+1.9635e-7*x1-0.002*3.14159*0.0005^2;
6*(m+x2)*1.9635e-7-3.14159*m^3+1.9635e-7*x3+1.9635e-7*x6*(m+x2)/x4-0.0 ...

十分感谢您的回答!本打算用matlab解,现在就用1stopt吧。我有个小问题问一下,像这种多解的方程,我可以取接近实验值的一组解作为方程的解来验证方程的合理性吗?1stopt得到的解是否可靠呢?
6楼2014-11-08 10:42:38
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

月只蓝

主管区长 (职业作家)

引用回帖:
6楼: Originally posted by monixia at 2014-11-08 10:42:38
十分感谢您的回答!本打算用matlab解,现在就用1stopt吧。我有个小问题问一下,像这种多解的方程,我可以取接近实验值的一组解作为方程的解来验证方程的合理性吗?1stopt得到的解是否可靠呢?...

1stopt得到的解是否可靠,你把求出来的解代回原方程就知道能达到多少精度了。
多解取接近实验值有物理意义。
MATLAB、MS小问题、普通问题请发帖求助!时间精力有限,恕不接受无偿私信求助。
7楼2014-11-08 11:18:19
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 monixia 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 0856专硕求调剂 希望是a区院校 +11 好好休息好不好 2026-04-09 14/700 2026-04-10 07:45 by 314126402
[考研] 301求调剂 +5 静静想想 2026-04-05 5/250 2026-04-09 20:58 by 运气yunqi
[考研] 材料化工总分334求调剂 +16 Riot2025 2026-04-08 17/850 2026-04-09 20:19 by maddjdld
[考研] 296求调剂 +11 汪!?! 2026-04-08 11/550 2026-04-09 19:30 by 小小树2024
[考研] 296求调剂 +5 汪!?! 2026-04-08 5/250 2026-04-09 16:47 by Delta2012
[考研] 293求调剂 +3 勇远库爱314 2026-04-08 3/150 2026-04-09 15:51 by wp06
[考研] 086000生物与医药调剂 +7 awwwwwooooo 2026-04-09 7/350 2026-04-09 13:31 by 北极159263
[考研] 一志愿西南大学生物学学硕344 求生物学相关调剂/生物与医药 +7 超人不会飞@ 2026-04-08 7/350 2026-04-09 09:35 by gong120082
[考研] 353求调剂 +8 晴空万里air 2026-04-07 8/400 2026-04-09 00:18 by GouQ
[考研] 一志愿211,化学学硕,310分,本科重点双非,求调剂 +15 努力奋斗112 2026-04-06 17/850 2026-04-08 22:27 by 凯凯要变帅
[考研] 320分人工智能调剂 +9 振—TZ 2026-04-03 10/500 2026-04-08 19:56 by 振—TZ
[考研] 280求调剂 +9 李rien 2026-04-04 9/450 2026-04-08 13:20 by lijunpoly
[考研] 调剂 +3 电气300求调剂不 2026-04-08 6/300 2026-04-08 09:39 by 电气300求调剂不
[考研] 085100建筑学 寻求跨专业调剂 一志愿南大294分 校级省级国家级奖项若干 踏实肯干 +3 1021075758 2026-04-06 4/200 2026-04-07 09:23 by 蓝云思雨
[考研] 332求调剂 +17 小小孟... 2026-04-05 18/900 2026-04-06 09:51 by 蓝云思雨
[考研] 求调剂 +7 张.1 2026-04-05 7/350 2026-04-05 20:40 by 啵啵啵0119
[考研] 277求调剂 +5 考研调剂lxh 2026-04-05 5/250 2026-04-05 19:03 by chy09050039
[考研] 一志愿南农090401,268,求调剂 +5 一木鸟然 2026-04-04 5/250 2026-04-04 17:07 by babysonlkd
[考研] 357求调剂 +13 1050389037 2026-04-03 13/650 2026-04-03 22:27 by 无际的草原
[考研] 考研调剂 +3 Draa 2026-04-03 3/150 2026-04-03 17:37 by hgwz7468
信息提示
请填处理意见