找回密码
 注册
关于网站域名变更的通知
查看: 383|回复: 2
打印 上一主题 下一主题

使用matlab中的fsolve求解非线性方程时报错

[复制链接]
  • TA的每日心情
    开心
    2022-1-29 15:04
  • 签到天数: 1 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2023-2-7 15:47 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

    EDA365欢迎您登录!

    您需要 登录 才可以下载或查看,没有帐号?注册

    x
    本帖最后由 peerless2021 于 2023-2-7 15:48 编辑 % K4 V5 V/ z+ c- B- |+ S
    1 K; Z& ^, ^- ^" F2 X. h: F9 r
    原程序为
    • function F = myeqn(alpha,L)
    • F = (0.3*((9.8)*L^1.83)/(2*cos(alpha)^2)+(1.96*L^3)/(3*cos(alpha)^3)-10)/(0.9*tan(alpha));
    • end
    • alpha0 = 0;
    • L0 = 0;
    • x0 = [alpha0,L0];
    • x = fsolve(@myeqn,x0);
      & `; A- Q  G8 C# |" c7 t
    在调用时会报错截图如下:( \7 o$ \% F+ X
    3 {  f- r  Q* \5 w% U+ a# C6 ]) ]
    原方程比较复杂,如图:
    + {! Y# q6 Q6 o5 J$ O( D( i

    3 E3 ], b# u  v
    是调用的方式出现了问题吗?
    1 E6 W" l' p) m$ Y& Z6 B0 ?3 A

    6 Y3 l+ @% z6 l2 l8 h1 r) H' t8 O8 x. t5 x4 i9 Z- z2 o3 q

    该用户从未签到

    2#
    发表于 2023-2-7 16:37 | 只看该作者
    你这样写不符合 fsolve函数(超链接,自己点进去看) 的语法要求。2 C/ |1 C6 A3 O2 |( `1 x
    仔细看帮助文档里的示例,以 x = fsolve(@myfun,x0) 这种语法调用时,要求输入函数形为 function F = myfun(x) 这样的“单输入”函数,你有两个输入,当然不行了。要么改写为
    ! |& j3 x- g, t" Mfunction F = myeqn( Input )6 t4 b- X$ @1 h5 L7 I' X
    alpha = Input( 1 );
    $ f8 v- N  F4 ^. A1 [; kL = Input( 2 );
    1 S9 F. I4 w/ v7 X* a2 _9 X* B' OF = (0.3*((9.8)*L^1.83)/(2*cos(alpha)^2)+(1.96*L^3)/(3*cos(alpha)^3)-10)/(0.9*tan(alpha));
    , {5 A7 c! o5 G% Zend7 A# S, y! W8 P5 Z, Y1 T
    这样的“单输入”,然后用 x0 = [ alpha0, L0 ]; x = fsolve( @myeqn, x0 ) 来求“满足方程的数值向量”(另外还得注意你这初值取得不合适,导致分母出现了零,新手要避免直接取全零或全1这种简单值作为初值,很容易导致各种无穷或零出现在分母之类位置上,导致迭代运算无法继续)6 x- `; _+ ~1 |
    要么不改动自定义函数,但需要另行指定一个输入的值,求另一个,需要改写为$ i! Q/ \9 X' Q) ^5 ]
    x0 = [ alpha0 ] + eps; % 避免初值无效
    ! k# h4 j, V6 Dx = fsolve( @( t ) myeqn( t, L0 ), x0 ); w9 _; L& D1 c; ?
    disp( myeqn( x, L0 ) )
    & f) @8 H8 z' x1 ]& {* \最后,你得好好检查检查你的函数,你为什么要多此一举地把 0.9*tan(alpha) 扔到分母上去。原方程是
    0 b% M7 U" a& q! `2 w0 == 0.9*tan(alpha) + Others
    / W, h6 p# @5 f3 H( e3 u+ o9 l怎么你改写就成了 0 == Others / ( 0.9*tan(alpha) ) 了?

    点评

    是的,我的函数搞错了,是我打的时候想多了。按照您的两个方式我都尝试了一下,程序可以正常运行了,但是我没明白是在哪一步修改初值,最后得到的结果数字都是没输入过的  详情 回复 发表于 2023-2-7 16:45
  • TA的每日心情
    开心
    2022-1-29 15:04
  • 签到天数: 1 天

    [LV.1]初来乍到

    3#
     楼主| 发表于 2023-2-7 16:45 | 只看该作者
    aid4her 发表于 2023-2-7 16:378 ~; ?, X: @% l& [/ a7 F
    你这样写不符合 fsolve函数(超链接,自己点进去看) 的语法要求。9 h' w! ^: Z0 G# j* Z# V
    仔细看帮助文档里的示例,以 x = fsolv ...
    ' Y9 A! Z( @% i4 f% B" ?. [
    是的,我的函数搞错了,是我打的时候想多了。按照您的两个方式我都尝试了一下,程序可以正常运行了,但是我没明白是在哪一步修改初值,最后得到的结果数字都是没输入过的
    , ]' j; \' I9 T4 ~) }
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-8-1 12:05 , Processed in 0.140625 second(s), 31 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表