找回密码
 注册
关于网站域名变更的通知
查看: 470|回复: 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 编辑
    0 R9 d/ A- ~& I! {4 _& P' D
    " j9 s. k0 P8 M* n; n$ M原程序为
    • 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);/ F, y; I- @+ J1 N$ b3 Y$ H, j
    在调用时会报错截图如下:
    % N6 e: }0 B: P7 G$ Z! A

    1 d: h1 _' R$ J3 j" x- r原方程比较复杂,如图:
    ; _: l$ }- [/ Q1 {& u; o

    . I- z! I+ o! n
    是调用的方式出现了问题吗?
    7 q: A/ ~" }. X4 e' Z3 V1 x) Y
    2 K$ }% u+ \( `2 w: B8 q( Q
    ! L/ f0 o+ f+ u4 y2 T4 [

    该用户从未签到

    2#
    发表于 2023-2-7 16:37 | 只看该作者
    你这样写不符合 fsolve函数(超链接,自己点进去看) 的语法要求。+ m8 ^( W# g$ R2 F9 ^8 k; S
    仔细看帮助文档里的示例,以 x = fsolve(@myfun,x0) 这种语法调用时,要求输入函数形为 function F = myfun(x) 这样的“单输入”函数,你有两个输入,当然不行了。要么改写为+ Z3 `, s5 o, v0 Y; |
    function F = myeqn( Input )- m/ ]) ^, p( g, T( h/ u5 [
    alpha = Input( 1 );  o( p- P2 f. e# G/ V% u# a, O
    L = Input( 2 );  u$ @" c$ O' b0 L6 I2 n
    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));
    ( ]- @. A4 J. Z/ \/ i( K% eend
    . _  x  U! w5 w3 a$ r% E这样的“单输入”,然后用 x0 = [ alpha0, L0 ]; x = fsolve( @myeqn, x0 ) 来求“满足方程的数值向量”(另外还得注意你这初值取得不合适,导致分母出现了零,新手要避免直接取全零或全1这种简单值作为初值,很容易导致各种无穷或零出现在分母之类位置上,导致迭代运算无法继续)
    " x1 w& e' W* M- y" P4 T8 p要么不改动自定义函数,但需要另行指定一个输入的值,求另一个,需要改写为1 `" W7 ~; `! U, f$ f, ^. m1 y% R
    x0 = [ alpha0 ] + eps; % 避免初值无效
    , }  \7 w) p: z  v. p$ Zx = fsolve( @( t ) myeqn( t, L0 ), x0 )* e" [1 T* K6 X5 H9 }! I& w
    disp( myeqn( x, L0 ) )! ~1 \& R% Y4 o
    最后,你得好好检查检查你的函数,你为什么要多此一举地把 0.9*tan(alpha) 扔到分母上去。原方程是
    9 N7 |! V4 E; m! n' ]8 S0 == 0.9*tan(alpha) + Others
    2 x0 y5 b) _, k- a8 L7 W5 N怎么你改写就成了 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! r( q' n' a* Z) E/ w
    你这样写不符合 fsolve函数(超链接,自己点进去看) 的语法要求。0 C$ q# J$ X) O0 T' n+ D$ v  m
    仔细看帮助文档里的示例,以 x = fsolv ...
    ' N$ o' c2 e& |
    是的,我的函数搞错了,是我打的时候想多了。按照您的两个方式我都尝试了一下,程序可以正常运行了,但是我没明白是在哪一步修改初值,最后得到的结果数字都是没输入过的  T" D# E7 i, N# C
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

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

    EDA365公众号

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

    GMT+8, 2025-11-23 13:24 , Processed in 0.171875 second(s), 30 queries , Gzip On.

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

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

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