MATLAB- ode求解器:无法满足积分公差



我在MATLAB中使用代码求解器有问题。我使用了所有的代码求解器,如ode23s, ode23, ode15s, ode45等。我的代码无法计算,因为错误警告:

警告:t=8.190397e+01失败。无法满足集成不将步长减小到最小值以下的公差允许(2.273737e-13)在时间t.

我想计算一下,请直接在我的代码中帮助我。谢谢你。

第一个脚本:

% floq.m
global c_alpha c_beta c_gama om ms ks bs mii
 % Parameters            
   c_alpha=1;
   c_beta=1.1;
   c_gama=1.1;  
   ms=1;                             
   ks=1;                                                       
   D=0.01;
   OM=sqrt(ks/ms);                     
   bs=2*D*ms*OM;                       
 % Solver    
   sourad = 0.1:0.13:10;
   for pom = 1:length(sourad)
       eta= sqrt(1/sourad(pom));
       om=eta*OM;                          
       T=2*pi/(eta*OM);    
       for mii=-10*(eta^2):0.13:10*(eta^2)  
           tspan=0:0.01:T;
           [tt,x1]=ode23(@fun,tspan,[1; 0]);    
       end
   end       

第二个脚本=函数:

% fun.m
 function v=fun(tt,x1);
 global c_alpha c_beta c_gama om ms ks bs mii
 mt=ms*cos(om*tt);
 bt=bs*cos(2*om*tt);
 kt=ks*cos(2*om*tt);
 % Matrix A
 A=[(-bs+mii*c_beta*bt)/(ms-mii*c_gama*mt) (-ks+mii*c_alpha*kt)/(ms-mii*c_gama*mt); 1 0];
 % Method
 v=A*x1;

谢谢。

在ODE函数的极点上积分。在极点,每个解都结束了。极点左右的轨迹不能合并成一个更大的轨迹。

极点是1 = mii*c_gama*cos(om*t)的第一个正解t。如果mii*c_gama >= 1总有这样的解

最新更新