找回密码
 注册
关于网站域名变更的通知
查看: 476|回复: 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 编辑
    : S  H( e" t4 P) r: z% `7 I2 t+ ?* Y9 _9 P
    原程序为
    • 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);
      % z$ Y' z. j' G! q% f7 r$ _" b* `
    在调用时会报错截图如下:0 n$ |0 s9 G2 ~: s

    9 Z$ f4 A. \) W' Q7 |5 O原方程比较复杂,如图:$ o" N$ W5 o; ~9 r& @" d+ S
    - D9 n4 t) g- {1 D1 b3 ]
    是调用的方式出现了问题吗?
    5 t1 t2 M$ p  M5 a$ L* O

    ! K! n4 F) B* L/ Q$ d8 z' W) X" I4 M4 d

    该用户从未签到

    2#
    发表于 2023-2-7 16:37 | 只看该作者
    你这样写不符合 fsolve函数(超链接,自己点进去看) 的语法要求。0 [8 u$ M% l. i
    仔细看帮助文档里的示例,以 x = fsolve(@myfun,x0) 这种语法调用时,要求输入函数形为 function F = myfun(x) 这样的“单输入”函数,你有两个输入,当然不行了。要么改写为" [( e* p; J- R
    function F = myeqn( Input )5 j) o! H6 v  W& o
    alpha = Input( 1 );) j% D, I2 L3 X- k) K) B: d; r) D
    L = Input( 2 );9 ~1 u0 ^4 T/ e5 V- G+ D& y
    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));* c  B+ x9 O( o; Q
    end9 |" o. `0 o! j- L# c; I0 X1 E
    这样的“单输入”,然后用 x0 = [ alpha0, L0 ]; x = fsolve( @myeqn, x0 ) 来求“满足方程的数值向量”(另外还得注意你这初值取得不合适,导致分母出现了零,新手要避免直接取全零或全1这种简单值作为初值,很容易导致各种无穷或零出现在分母之类位置上,导致迭代运算无法继续)0 w) o; e. y: N9 C0 ~2 K
    要么不改动自定义函数,但需要另行指定一个输入的值,求另一个,需要改写为$ ?" `0 ^/ V- g) Z* g& N2 h% z
    x0 = [ alpha0 ] + eps; % 避免初值无效
    * j3 Q  [! U" ^6 s0 ^9 @$ Qx = fsolve( @( t ) myeqn( t, L0 ), x0 )2 L) ^' D5 z0 i5 P6 e; O
    disp( myeqn( x, L0 ) )
    : J7 \2 q7 s& ~7 M$ N  w  [最后,你得好好检查检查你的函数,你为什么要多此一举地把 0.9*tan(alpha) 扔到分母上去。原方程是6 y% r* f+ `' r8 Y, D0 H
    0 == 0.9*tan(alpha) + Others  x0 V, u. n8 W# E2 S* j
    怎么你改写就成了 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:37
    : A+ H- `! U6 P  v( Z你这样写不符合 fsolve函数(超链接,自己点进去看) 的语法要求。  @- l7 N" g# f( _0 K& V6 C
    仔细看帮助文档里的示例,以 x = fsolv ...
    6 ?; j+ V0 y- o2 Z6 s
    是的,我的函数搞错了,是我打的时候想多了。按照您的两个方式我都尝试了一下,程序可以正常运行了,但是我没明白是在哪一步修改初值,最后得到的结果数字都是没输入过的
    3 P: v) [$ G' Y4 r% ?
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

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

    EDA365公众号

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

    GMT+8, 2025-11-23 19:52 , Processed in 0.171875 second(s), 27 queries , Gzip On.

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

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

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