- 在线时间
- 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
- 自我介绍
- 无,新手,最近才接触建模,求指点。
 |
问题是这样的(见附图)
- y& D( W0 u0 M/ d" z6 W, p2 D
! h+ p" z. t8 d- p) I6 `' _然后我的程序如下- function Untitled
3 n. f! Q& e; N: \ - clear all;clc;; i7 M, x% ^\" `' q# _& x
- f=@(t)(2*sin(t)*(t<(4*pi)) + 0);
, d3 d! I* _& F% t: F Y. T; ?! Q - g=@(t)(0+cos(t).*(t>=((7*pi)/2)));
, K( q: U- d# } - function dy = rigid(t,y)
7 F! p: a+ X \2 u - dy = zeros(2,1);4 D% Y; h, k: w5 X
- dy(1) = y(2)-f(t);
9 O8 K% ~0 F3 ~# v, j\" y - dy(2) = y(1)*g(t)-y(2);
& n4 Y4 G& f# Z - end5 q. P0 J* ]* v9 Z
- options = odeset('RelTol',1e-4,'AbsTol',[1e-5 1e-5]);( B! S, ^- X9 [: \
- %[T, y] = ode45(@rigid, [0 20], [1 2],options)6 {( l0 _8 ?) z
- sol = ode45(@rigid, [0 20], [1 2],options);: J, t\" p! O D7 P$ B
- x=linspace(0,20,200000);
( F+ \) p9 u5 m+ g - y=deval(sol,x);
7 L9 Z# O2 X- c\" X\" U5 m. F: b - res=y(1,:)+y(2,:);/ h' S, C3 ]/ Z. I; |
- idx=find(abs(res-0)<1e-4) %相加,当和小于误差运行范围的时候可以认为它就为0; r6 u/ @# @2 V( H/ `1 _% z7 X @
- xx=x(idx) %算出在x中的下标) u. D# w% H5 _( w
- F=@(t)(f(t)+g(t));
* Y2 o: B3 n1 p5 u& T - r=[]; %得出的解反代入方程求值,得到的值保存在r中。如果解正确,r中的值应该非常接近05 G0 B4 s0 p! \0 ?4 r: s
- for i=1:size(xx,2); Y# ?) \, r* u
- r = [r F(xx(i))]; %将解的值依次带入。当前问题在于r中的值都和0差的很远
* F2 `& k; N/ j+ o g+ N. V, P - end; ]- O$ E, p! B9 @
- r
; J9 ]8 ?\" g: z+ d4 x1 h - end
复制代码 问题就是最后算出来的解再带入方程进行检验得出的结果和0差的好远,都到了1.73几。
; Y" V! F1 h- z9 Z* ~( d) t我也不知道哪里用错了,但猜测可能是由于微分方程里出现了f(t),g(t)的缘故
8 h' y# t4 M7 A5 D3 b1 F: j; m8 U8 r4 @4 e+ @
求教大家我的程序是哪里出现了问题,该如何改呢?+ u. s1 W# y" N [1 O
谢谢
" N% G9 z5 T: p- F) o# ^" z3 s. N7 D. I* T( a% {, P
3 h+ I1 B- \! m% m! j- S
|
zan
|