24小时热门版块排行榜    

查看: 6703  |  回复: 2
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

容墨竹止

新虫 (初入文坛)

[求助] 【ode45】matlab 用积分出现关于积分公差的警告 已有1人参与

这个问题一直解决不了,又很急,希望有懂的朋友帮帮我。

代码如下:

M文件:
function dx=F_LTV_0(t,x)
dx=zeros(6,1);
global m n b_0 w_c

r0=10;
re=13;

r=r0+(1-exp(-t))*(re-r0);

dr=exp(-t)*(re-r0);
ddr=-exp(-t)*(re-r0);

rr=sqrt(x(1)^2+x(2)^2+x(3)^2);

x10 = sqrt(1/6)*r;
x20 = 0;
x30 = sqrt(5/6)*r;
x40 = sqrt(1/6)*dr;
x50 = 0;
x60 = sqrt(5/6)*dr;
x70 = sqrt(1/6)*ddr;
x80 = 0;
x90 = sqrt(5/6)*ddr;


DX=[x(1)-x10
    x(2)-x20
    x(3)-x30
    x(4)-x40
    x(5)-x50
    x(6)-x60];   



% % %

p1=(-x(1)^2-x(2)^2+2*x(3)^2)*x(5)-3*x(2)*x(3)*x(6)+w_c*x(1)*(x(1)^2+x(2)^2-2*x(3)^2);
p2=(x(1)^2+x(2)^2-2*x(3)^2)*x(4)+3*x(1)*x(3)*x(6)+w_c*x(2)*(x(1)^2+x(2)^2-2*x(3)^2);
p3=3*x(3)*(x(2)*x(4)-x(1)*x(5)+w_c*(x(1)^2+x(2)^2));

P=[ 0;
    0;
    0;
    p1;
    p2;
    p3]';



%
%
Q=[2*sign(x(1)-x10),2*sign(x(2)-x20),sign(x(3)-x30),2*n*x(5)+3*n^2*x(1)-x70,-2*n*x(4),-n^2*x30-x90];


AA=Q*DX;
BB=P*DX;

U=-m*rr^5/b_0*(AA/BB);


% % 状态方程------------------------------

dx(1)=x(4);
dx(2)=x(5);
dx(3)=x(6);
dx(4)=2*n*x(5)+3*n^2*x(1)+(U)*b_0/(m*rr^5)*p1;
dx(5)=-2*n*x(4)+(U)*b_0/(m*rr^5)*p2;
dx(6)=-n^2*x(3)+(U)*b_0/(m*rr^5)*p3;

%---------------------------------------------

dx=[dx(1);dx(2);dx(3);dx(4);dx(5);dx(6)];
end

主程序:
close all;
clear;
clc
  global  m n b_0 w_c


%% Constants
m=50;
n=2*pi/5400/2;
b_0=20;
w_c=500*pi;


r0 = 10;
x_1=sqrt(1/6)*r0;
x_2=0;
x_3=sqrt(5/6)*r0;
x_4=0;
x_5=0;
x_6=0;

%% Solve ODEs
xe= [x_1;x_2;x_3;x_4;x_5;x_6];
tspan = [0 10000];
options =odeset('RelTol',1e-9,'AbsTol',1e-9);
[t,x] = ode45(@F_LTV_0,tspan,xe,options);
y = x';


出现了如下警告并且ode不再继续运行。
警告: 在 t=1.596171e+00 处失败。在时间 t 处,若不将步长降至允许的最小值(3.552714e-15)以下,积分公差要求无法满足。

我把ode45换成其他的ode积分也不行。除非把绝对误差和相对误差调大到10^(-5)以上,但是这样出来的结果也不对。我怀疑是U的设计不对,但是反复检查后确实表达式是这样。
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

容墨竹止

新虫 (初入文坛)

仿真时间太短了,我也不确定结果是否正确。
正确积分后的结果应该是这样:x1=5.307, x2=0, x3=11.8673.

请问你是怎么改的?
3楼2017-04-14 20:53:34
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 3 个回答

chendequan

铁虫 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
未知是否正确
【ode45】matlab 用积分出现关于积分公差的警告
1.jpg


【ode45】matlab 用积分出现关于积分公差的警告-1
2.jpg


【ode45】matlab 用积分出现关于积分公差的警告-2
3.jpg

QQ:516477448,真心帮助解决MATLAB相关问题,提供详细资料,Word文档明确具体问题及要求,尽力而为!
2楼2017-04-14 10:46:35
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 一志愿深大,0703化学,总分302,求调剂 +4 七月-七七 2026-03-21 4/200 2026-03-21 18:20 by 学员8dgXkO
[考研] 材料学硕301分求调剂 +6 Liyouyumairs 2026-03-21 6/300 2026-03-21 17:42 by JourneyLucky
[考研] 一志愿重庆大学085700资源与环境总分308求调剂 +7 墨墨漠 2026-03-20 7/350 2026-03-21 16:36 by barlinike
[考研] 22 350 本科985求调剂,求老登收留 +3 李轶男003 2026-03-20 3/150 2026-03-21 13:28 by 搏击518
[考研] 306求调剂 +4 chuanzhu川烛 2026-03-18 4/200 2026-03-21 08:25 by laoshidan
[考研] 机械专硕299求调剂至材料 +3 kkcoco25 2026-03-16 4/200 2026-03-21 03:52 by JourneyLucky
[考研] 材料工程(专)一志愿985 初试335求调剂 +3 hiloiy 2026-03-17 4/200 2026-03-21 03:04 by JourneyLucky
[考研] 354求调剂 +5 Tyoumou 2026-03-18 8/400 2026-03-21 00:35 by JourneyLucky
[考研] 350求调剂 +5 weudhdk 2026-03-19 5/250 2026-03-20 22:04 by luoyongfeng
[考研] 一志愿西南交通 专硕 材料355 本科双非 求调剂 +5 西南交通专材355 2026-03-19 5/250 2026-03-20 21:10 by JourneyLucky
[考研] 295材料求调剂,一志愿武汉理工085601专硕 +5 Charlieyq 2026-03-19 5/250 2026-03-20 20:35 by JourneyLucky
[考研] 一志愿 南京航空航天大学大学 ,080500材料科学与工程学硕 +5 @taotao 2026-03-20 5/250 2026-03-20 20:16 by JourneyLucky
[考研] 319求调剂 +3 小力气珂珂 2026-03-20 3/150 2026-03-20 19:47 by JourneyLucky
[考博] 招收博士1-2人 +3 QGZDSYS 2026-03-18 3/150 2026-03-20 11:58 by 呱呱呱呱叫
[论文投稿] 申请回稿延期一个月,编辑同意了。但系统上的时间没变,给编辑又写邮件了,没回复 10+3 wangf9518 2026-03-17 4/200 2026-03-19 23:55 by babero
[考研] 一志愿中国海洋大学,生物学,301分,求调剂 +5 1孙悟空 2026-03-17 6/300 2026-03-19 23:46 by zcl123
[考研] 材料与化工求调剂 +7 为学666 2026-03-16 7/350 2026-03-19 14:48 by 尽舜尧1
[考研] 0703化学调剂 +5 pupcoco 2026-03-17 8/400 2026-03-19 13:58 by houyaoxu
[考研] 材料专硕306英一数二 +10 z1z2z3879 2026-03-16 13/650 2026-03-18 14:20 by 007_lilei
[考研] 一志愿211 0703方向310分求调剂 +3 努力奋斗112 2026-03-15 3/150 2026-03-16 16:44 by houyaoxu
信息提示
请填处理意见