Plotting system of differential equations

Hi,
does anybody know the code to plot a system of differential equations? For example say,
x1(dot) = -x2 + (x1)^2 -(x1*x2)
x2(dot) = x1 + (x1*x2)
Thanks in advance! :)
Sajith.

 Respuesta aceptada

Star Strider
Star Strider el 24 de Mzo. de 2015

1 voto

Yes.
Use ode45 to integrate your equations, then plot the solution.
Give it a go. It should be very easy for you to cast your system of equations as an Anonymous Function. If you have problems with your code, we can help you get it running.

5 comentarios

Sajith Dharmasena
Sajith Dharmasena el 24 de Mzo. de 2015
I'm not very familiar with MATLAB. Do you think you could show me how to use ode45 and then plot the functions?
Sajith
Since you already Accepted my Answer, here you go:
odesys = @(t,x) [(-x(2) + (x(1)).^2 -(x(1).*x(2))); (x(1) +
(x(1).*x(2)))];
x0 = [0; 1]; % Initial Conditions
tspan = [0 60]; % Time Of Integration
[t, x] = ode45(odesys, tspan, x0); % Integrate
figure(1)
plot(t, x)
grid
legend('x_1(t)', 'x_2(t)', 'Location', 'NE')
You didn’t specify time span (‘tspan’) or initial conditions (‘x0’), so you may want to revisit those, and specify different values.
Sajith Dharmasena
Sajith Dharmasena el 24 de Mzo. de 2015
Thank you so much for your help!
Sajith Dharmasena
Sajith Dharmasena el 24 de Mzo. de 2015
How do you plot x1 vs x2? (phase plane)
You plot just that:
plot(x(:,1), x(:,2))

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Mathematics en Centro de ayuda y File Exchange.

Preguntada:

el 24 de Mzo. de 2015

Comentada:

el 24 de Mzo. de 2015

Community Treasure Hunt

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

Start Hunting!

Translated by