【发布时间】:2015-07-28 05:16:03
【问题描述】:
我对 MATLAB 中的 ode 求解器 有疑问。我使用了 所有 ode 求解器,例如 ode23s、ode23、ode15s、ode45 等。由于错误警告,我的代码无法计算:
警告:在 t=8.190397e+01 失败。无法满足整合 公差而不将步长减小到最小值以下 在时间 t 允许 (2.273737e-13)。
我想计算一下,请直接在我的代码中帮助我。谢谢。
第一个脚本:
% 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;
谢谢。
【问题讨论】:
标签: matlab integration ode