找回密码
 注册
关于网站域名变更的通知
查看: 475|回复: 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 编辑 5 M1 G. y1 ?7 U$ K

    8 ]4 f$ j% T2 W$ O1 c原程序为
    • 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);
      7 ?! X, r- W1 P9 z
    在调用时会报错截图如下:
    % y) E$ g3 A& [% Z; \" K, i7 ~& l- V
    / R+ A& |& ?5 Z! r6 k5 y
    原方程比较复杂,如图:
    4 _( s* r2 h( _4 t$ f+ e& a7 g

    8 r$ O3 h- R6 @2 M  T, R
    是调用的方式出现了问题吗?
    / s+ S3 t  E' z7 x1 w

      V& m' N: [6 M
    ; w/ L( r# J* {8 U" p8 l/ z
  • TA的每日心情
    开心
    2022-1-29 15:04
  • 签到天数: 1 天

    [LV.1]初来乍到

    3#
     楼主| 发表于 2023-2-7 16:45 | 只看该作者
    aid4her 发表于 2023-2-7 16:37
    , G4 S2 W% Q4 @4 y# q你这样写不符合 fsolve函数(超链接,自己点进去看) 的语法要求。( W# B( `0 B9 ]( \  u0 I
    仔细看帮助文档里的示例,以 x = fsolv ...
    0 U  G, `5 c1 [
    是的,我的函数搞错了,是我打的时候想多了。按照您的两个方式我都尝试了一下,程序可以正常运行了,但是我没明白是在哪一步修改初值,最后得到的结果数字都是没输入过的
    ( t& c# `, _0 c" {5 Y! l

    该用户从未签到

    2#
    发表于 2023-2-7 16:37 | 只看该作者
    你这样写不符合 fsolve函数(超链接,自己点进去看) 的语法要求。6 K/ @' d6 U0 e
    仔细看帮助文档里的示例,以 x = fsolve(@myfun,x0) 这种语法调用时,要求输入函数形为 function F = myfun(x) 这样的“单输入”函数,你有两个输入,当然不行了。要么改写为5 F8 f/ y; j9 k& `! z0 m: y+ D3 N* }
    function F = myeqn( Input ): Y2 G( m) @+ ^
    alpha = Input( 1 );
    ! l& w8 \. L; g3 `+ \1 kL = Input( 2 );& @2 ^  f. x5 @
    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));
    & e' b8 \  s1 A: u! r3 i  uend4 ^8 N) @0 X4 C- I0 U+ o
    这样的“单输入”,然后用 x0 = [ alpha0, L0 ]; x = fsolve( @myeqn, x0 ) 来求“满足方程的数值向量”(另外还得注意你这初值取得不合适,导致分母出现了零,新手要避免直接取全零或全1这种简单值作为初值,很容易导致各种无穷或零出现在分母之类位置上,导致迭代运算无法继续); r8 W5 l8 S4 Z6 z5 Q  D
    要么不改动自定义函数,但需要另行指定一个输入的值,求另一个,需要改写为: Q/ W3 C9 Z' ]  W4 F8 P1 X4 d4 w6 V
    x0 = [ alpha0 ] + eps; % 避免初值无效& q/ |0 m& n$ b3 _
    x = fsolve( @( t ) myeqn( t, L0 ), x0 ). ^. h" c! O: `; q% Y
    disp( myeqn( x, L0 ) )
    5 K, R! F* R4 I最后,你得好好检查检查你的函数,你为什么要多此一举地把 0.9*tan(alpha) 扔到分母上去。原方程是
    6 _& C% h) y; i0 == 0.9*tan(alpha) + Others
    7 P- ?, M0 P% [& s7 P9 {怎么你改写就成了 0 == Others / ( 0.9*tan(alpha) ) 了?

    点评

    是的,我的函数搞错了,是我打的时候想多了。按照您的两个方式我都尝试了一下,程序可以正常运行了,但是我没明白是在哪一步修改初值,最后得到的结果数字都是没输入过的  详情 回复 发表于 2023-2-7 16:45
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

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

    EDA365公众号

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

    GMT+8, 2025-11-23 17:26 , Processed in 0.156250 second(s), 28 queries , Gzip On.

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

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

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