使用具有多个输入的函数时出错

时间:2014-11-07 05:36:15

标签: matlab function ode function-handle

我正在尝试用多个输入来评估MATLAB中的duffing振荡器,我得到了一个奇怪的错误,我希望有人可以帮助我。

以下是代码:

% file duffing.m

function dy=duffing(t,y,a,b,d,g,w) 
    dy=[y(2); -a*y(1)^3-b*y(1)-d*y(2)+g*cos(w*t)];
end

调用duffing函数的文件:

t=0:0.01:100;

%duffing oscillator 

y0=[2,0];
a=1;
b=-1;
d=0.2;
w=1;
g=0.1;

% duffing oscillator
[t,y]=ode45('duffing',t,y0,a,b,d,g,w); 

当我运行它时,我收到以下错误:

  

使用odearguments时出错(第92行)   DUFFING返回长度为1的向量,但初始条件向量的长度为2. DUFFING返回的向量和初始条件向量必须具有相同数量的元素。

但是当我将函数duffing定义为

function dy=duffing(t,y) 

    a=1;
    b=-1;
    d=0.2;
    w=1;
    dy=[y(2); -a*y(1)^3-b*y(1)-d*y(2)+g*cos(w*t)];

end

并传入

[t y]=ode45('duffing',t,y0);

与上面的y0相同,运行正常,我可以绘制它。

我做错了什么?

2 个答案:

答案 0 :(得分:1)

ode45仅将两个变量的函数作为输入。如果你想传递更多的输入,你必须创建一个小的匿名函数,如下所示:

a=1;
b=-1;
d=0.2;
w=1;
g=0.1;

% duffing oscillator
[t,y]=ode45(@(t,y) duffing(t,y,a,b,d,g,w),t,y0); 

答案 1 :(得分:1)

ode45的语法是:

function varargout = ode45(ode,tspan,y0,options,varargin)

第四个参数options是使用odeset创建的选项结构。附加输入需要是第五个及以后,并且需要修改该功能。官方的方法是使用函数句柄或全局变量,但这里是如何使用ode45的参数来完成的。

options = odeset('RelTol',1e-4);
[t,y]=ode45('duffing',t,y0,options,a,b,d,g,w);

然后你必须使用伪参数修改duffing以与odearguments.m(f(t,y,'',p1,p2...))的调用约定兼容:

function dy=duffing(t,y,~,a,b,d,g,w) 
    dy=[y(2); -a*y(1)^3-b*y(1)-d*y(2)+g*cos(w*t)];
end

官方功能句柄解决方案如下所示:

myDuffing = @(t,y) duffing(t,y,a,b,d,g,w);

然后以与第二种方法相同的方式调用ode45,但使用myDuffing(请参阅David's solution了解此方法)。