Using ODE45 to solve a system of 2nd order ODEs equation

4 Ansichten (letzte 30 Tage)
I am trying to solve
This is what I have written as my finction script. everytime I try to solve it once I type the initial condiitions to the Command Windown, I get "Show complete stack trace." How can I solve my problem?
function theta_dot = pendulum(t,x)
theta_dot = [x(2);
-8.8*x(1)-1.8*x(3);
x(4);
1.8*x(1)+8.8*x(3)];
end

Akzeptierte Antwort

Bjorn Gustavsson
Bjorn Gustavsson am 6 Mai 2020
After fixing the sign-errors in your ODE-function this:
thetathetadot0 = [0 0 0 -1];
[t,theta] = ode45(@(t,y) pendulum(t,y),0:0.1:10,thetathetadot0);
plot(t,theta)
works just fine.
HTH
  2 Kommentare
Missael Hernandez
Missael Hernandez am 6 Mai 2020
I get:
Error in odearguments (line 90)
f0 = feval(ode,t0,y0,args{:}); % ODE15I sets args{1} to yp0.
Error in ode45 (line 115)
odearguments(FcnHandlesUsed, solver_name, ode, tspan, y0, options, varargin);
Error in rg5y (line 2)
[t,theta] = ode45(@(t,y) pendulum(t,y),0:0.1:10,thetathetadot0); - Show complete stack trace

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (0)

Tags

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by