简体   繁体   English

Matlab函数中输入参数不足

[英]Not enough input arguments in function Matlab

I'm having a problem developing my GUI to solve a differential equation and I can not find the error. 我在开发GUI来解决微分方程时遇到问题,但找不到错误。

The equation I'm trying to solve is defined by: 我要求解的方程式定义为:

T*x'+x = kSigma*heaviside(t-t0) + kSin*sin(Omega*t+alpha*pi/180).

The approach I have tried is: 我尝试过的方法是:

function lsg = DGLvar(t,T,Omega)
   x = 1;
   kSin = 1;
   kSigma = 5;
   t0 = 0;
   alpha = 0;
   lsg = 1/T * (-x + kSigma*heaviside(t-t0) + kSin*sin(Omega*t+alpha*pi/180) );

In the GUI the code looks like this: 在GUI中,代码如下所示:

function pushbutton1_Callback(hObject, ~, handles)
   t=[0 100];
   periode=get(handles.sliderT,'value');
   Omega=get(handles.slideromega,'value');
   [x,t]=ode45(@DGLvar,t,periode,Omega);
   plot(handles.axes2,x,t,'g')

I'm getting the following error: 我收到以下错误:

Error using DGLvar (line 8)
Not enough input arguments.

Error in odearguments (line 87)
f0 = feval(ode,t0,y0,args{:});   % ODE15I sets args{1} to yp0.

Error in ode45 (line 113)
[neq, tspan, ntspan, next, t0, tfinal, tdir, y0, f0, odeArgs, odeFcn, ...

Error in PT1>pushbutton1_Callback (line 218)
   [x,t]=ode45(@DGLvar,t,periode,Omega);

Error in gui_mainfcn (line 95)
    feval(varargin{:});

Error in PT1 (line 42)
gui_mainfcn(gui_State, varargin{:});

Error in @(hObject,eventdata)PT1('pushbutton1_Callback',hObject,eventdata,guidata(hObject))


Error while evaluating uicontrol Callback

How can I resolve this error? 如何解决此错误?

The solver ode45 expects as input a function f(t,x) and uses this to solve the equation x'=f(t,x) . 求解器ode45期望输入f(t,x)作为函数f(t,x)并使用它来求解方程x'=f(t,x)

You need to use x as a parameter for your function DGLvar . 您需要将x用作函数DGLvar的参数。 I would also recommend renaming it to xprime , as this is more descriptive. 我还建议将其重命名为xprime ,因为这更具描述性。

function xp = xprime(t,x,T,Omega)
   kSin = 1;
   kSigma = 5;
   t0 = 0;
   alpha = 0;
   xp = 1/T * (-x + kSigma*heaviside(t-t0) + kSin*sin(Omega*t+alpha*pi/180) );

The GUI code would look like this: GUI代码如下所示:

%% Get the GUI values:
tspan = [0 100];
x0 = 0;
T = get(handles.sliderT, 'value');
Omega = get(handles.slideromega, 'value');
%% Define a function with two parameters @(t,x) for ode45.
xprimefixedTandOmega = @(t,x) xprime(t, x, T, Omega);
%% Solve the equation: x' = xprimefixedTandOmega(t,x), x(0)=0 for t=0...100.
[t,x] = ode45(xprimefixedTandOmega, tspan, x0);
%% Plot the result of solver
plot(handles.axes2, t, x, 'g');

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM