QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2553|回复: 1
打印 上一主题 下一主题

matlab求解微分方程结果不对

[复制链接]
字体大小: 正常 放大
yzh07137        

3

主题

12

听众

150

积分

升级  25%

  • TA的每日心情
    开心
    2015-9-11 00:19
  • 签到天数: 54 天

    [LV.5]常住居民I

    自我介绍
    无,新手,最近才接触建模,求指点。
    跳转到指定楼层
    1#
    发表于 2015-7-30 20:35 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    问题是这样的(见附图)) N+ I" J9 L# E" {8 J& O4 p" I
    * u- P& N& s5 ]* n
    然后我的程序如下
    1. function Untitled5 n' O0 ]; H& i2 e! T
    2.         clear all;clc;, R5 Y* H& \- W  s8 a, h\" c+ v
    3.         f=@(t)(2*sin(t)*(t<(4*pi)) + 0);
      : m6 ^# o& Q' A0 u! K9 J
    4.         g=@(t)(0+cos(t).*(t>=((7*pi)/2)));
      $ x- c7 {; C. E% i  }. b
    5.             function dy = rigid(t,y)0 i* j3 y& b8 W. ]. m! k
    6.                         dy = zeros(2,1);4 x  K5 b* V+ X+ V0 U- O
    7.                         dy(1) = y(2)-f(t);5 [: k! e\" G2 n) t9 K) N: S( h
    8.                         dy(2) = y(1)*g(t)-y(2);
      & d& C. M) R; Z- u4 \3 Q! o6 |* p
    9.             end
      , W% }; k, l, {6 g3 N/ S
    10.             options = odeset('RelTol',1e-4,'AbsTol',[1e-5 1e-5]);
      0 U! ?& _' G; F& j' A4 g4 K
    11.             %[T, y] = ode45(@rigid, [0 20], [1 2],options)\" X& y6 _( R( r  |
    12.             sol = ode45(@rigid, [0 20], [1 2],options);
      / M* J0 o0 l0 Q/ f/ E
    13.             x=linspace(0,20,200000);
      0 t1 Z0 \  O) v+ p1 n
    14.             y=deval(sol,x);
      ; X% H5 h9 y5 A
    15.             res=y(1,:)+y(2,:);
      ! \% d+ [& {! i4 @  M
    16.             idx=find(abs(res-0)<1e-4) %相加,当和小于误差运行范围的时候可以认为它就为0
      $ T0 E' g3 [9 M. j2 |+ S4 K4 k
    17.             xx=x(idx) %算出在x中的下标
      5 C2 z3 S  c& I# |; x
    18.             F=@(t)(f(t)+g(t));$ P& i/ `- {6 M, J\" R; i; G6 p
    19.             r=[]; %得出的解反代入方程求值,得到的值保存在r中。如果解正确,r中的值应该非常接近0
      ! m\" R- W. I0 H! r6 ?$ L/ E
    20.             for i=1:size(xx,2)) D& n( b; `$ x7 d  c9 m3 c
    21.                     r = [r F(xx(i))]; %将解的值依次带入。当前问题在于r中的值都和0差的很远
      2 j3 }9 t5 U* z, C\" L/ }) _
    22.             end$ r0 O3 P! L' b# U+ _2 T  E* w
    23.             r. Q8 D/ e2 w0 P
    24. end
    复制代码
    问题就是最后算出来的解再带入方程进行检验得出的结果和0差的好远,都到了1.73几。
    2 c1 {; Q+ |6 q$ |9 @% Y  p1 o& {我也不知道哪里用错了,但猜测可能是由于微分方程里出现了f(t),g(t)的缘故
    1 t. q/ y4 h! ]: ^9 r! C$ t1 m/ Y: H8 p# M6 b; ?: c- M# ~
    求教大家我的程序是哪里出现了问题,该如何改呢?" f3 n- K+ _& B$ W* W
    谢谢6 e: K9 f. c% U( T4 w8 H
    ) p7 e1 j! k, X

    $ ~8 b6 B  p& b0 Z/ y8 S

    matlab.png (12.23 KB, 下载次数: 530)

    问题

    问题

    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    yzh07137        

    3

    主题

    12

    听众

    150

    积分

    升级  25%

  • TA的每日心情
    开心
    2015-9-11 00:19
  • 签到天数: 54 天

    [LV.5]常住居民I

    自我介绍
    无,新手,最近才接触建模,求指点。
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-6-12 16:00 , Processed in 0.484464 second(s), 61 queries .

    回顶部