- 在线时间
- 31 小时
- 最后登录
- 2017-7-6
- 注册时间
- 2014-7-7
- 听众数
- 12
- 收听数
- 0
- 能力
- 0 分
- 体力
- 316 点
- 威望
- 0 点
- 阅读权限
- 30
- 积分
- 150
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 111
- 主题
- 3
- 精华
- 0
- 分享
- 0
- 好友
- 5
升级   25% TA的每日心情 | 开心 2015-9-11 00:19 |
|---|
签到天数: 54 天 [LV.5]常住居民I
- 自我介绍
- 无,新手,最近才接触建模,求指点。
 |
问题是这样的(见附图)
+ C7 x( x6 r: k7 \: u5 Z& L! d
% q. j2 _8 y4 b- ~ k$ G然后我的程序如下- function Untitled
* g1 K6 Q# z1 F* X8 W8 g - clear all;clc;$ T/ ` i. G d4 D0 p
- f=@(t)(2*sin(t)*(t<(4*pi)) + 0);
& v' r1 n& Q# d - g=@(t)(0+cos(t).*(t>=((7*pi)/2)));
+ m7 v7 T& f# I' Z - function dy = rigid(t,y)
. ]2 J. c! E- {/ q. `# I* ]6 P - dy = zeros(2,1);
9 V: k2 S6 _4 l - dy(1) = y(2)-f(t);6 ?+ U' K; a& s8 ?
- dy(2) = y(1)*g(t)-y(2);
5 d; K3 _) {) C ? - end
+ g$ _ B$ m% q& a& Z' b4 Q: u - options = odeset('RelTol',1e-4,'AbsTol',[1e-5 1e-5]);$ y5 h# ^/ Y4 ?+ k) b4 D O
- %[T, y] = ode45(@rigid, [0 20], [1 2],options)- L* k% {4 y. F$ u- C
- sol = ode45(@rigid, [0 20], [1 2],options);( O9 b8 ^% q$ S7 E; [7 N% g
- x=linspace(0,20,200000);+ B/ ?2 H+ g2 `
- y=deval(sol,x);
8 o# v3 `3 f3 W. y7 e - res=y(1,:)+y(2,:);+ @ E\" t/ Q8 Z( U' l' R
- idx=find(abs(res-0)<1e-4) %相加,当和小于误差运行范围的时候可以认为它就为0% h. R! r+ X6 k# j0 @2 M; O
- xx=x(idx) %算出在x中的下标
( r6 ] Q6 U X1 B$ q$ L1 i - F=@(t)(f(t)+g(t));
* ?! I; G% E& f9 w% @* x - r=[]; %得出的解反代入方程求值,得到的值保存在r中。如果解正确,r中的值应该非常接近0
4 K* w6 B# v- g - for i=1:size(xx,2)! g* p! e3 t$ G6 b: z4 M. N4 V8 j5 V
- r = [r F(xx(i))]; %将解的值依次带入。当前问题在于r中的值都和0差的很远
\" Z1 b* M; D! r1 P# r+ E0 v - end: |8 b% V% ~5 d% }5 M, [2 Y* u- l8 U
- r/ m6 [/ m- g6 w/ R0 A: T0 g- g( Z: [
- end
复制代码 问题就是最后算出来的解再带入方程进行检验得出的结果和0差的好远,都到了1.73几。8 w. t9 m9 U( |' ]
我也不知道哪里用错了,但猜测可能是由于微分方程里出现了f(t),g(t)的缘故2 ?- [ T- U t( C6 r3 d. a/ h5 s
4 ^; [/ k9 n6 X' {# h; q. \' @
求教大家我的程序是哪里出现了问题,该如何改呢?
# N$ n* p1 B1 |8 k% D8 H谢谢; ]: G q' R3 l A: q
2 w5 E+ U# N3 O6 Y0 K) X( u2 m) Y0 m6 p# X
|
zan
|