Differential Equation
ODE45
Lsim-State Space Model
Step
ode45 - 1st order
data:image/s3,"s3://crabby-images/f5b5a/f5b5a690fb15ecdee043589c24c58fe65467a943" alt=""
Ex)
Input
|
f = inline('-2*y','t','y');
odeopt = odeset ('RelTol', 0.00001, 'AbsTol', 0.00001,'InitialStep',0.5,'MaxStep',0.5);
[t,y] = ode45(f,[0 5],2,odeopt);
plot(t,y)
|
Output
|
data:image/s3,"s3://crabby-images/03315/033155dafe39b5d404adb69a1899f99dacef0508" alt=""
|
ode45 - Undamped Pendulum
data:image/s3,"s3://crabby-images/a6c39/a6c391502c0ab2f532360cb3ce0c1c1011a88f68" alt=""
data:image/s3,"s3://crabby-images/e8b95/e8b9589b12c76318084dcaf43ce9063bba12b3ea" alt=""
Ex 1)
Input
|
%Save the following contents in a .m file and run the .m file
omega = 1;
dy_dt = @(t,y) [y(2);...
-omega.^2*sin(y(1))];
odeopt = odeset ('RelTol', 0.00001, 'AbsTol', 0.00001,'InitialStep',0.5,'MaxStep',0.5);
[t,y] = ode45(dy_dt,[0 25], [0.0 1.0],odeopt);
subplot(1,2,1);plot(t,y(:,1),'r-',t,y(:,2),'b-');xlabel('time'); legend('y1(t)','y2(t)');
subplot(1,2,2);plot(y(:,1),y(:,2),'b-'); axis([-2.5 2.5 -2.5 2.5]); xlabel('y(2)');ylabel('y(1)');
|
Output
|
data:image/s3,"s3://crabby-images/0842c/0842cfecae00a1609fdc546cb9e8872bcf79b879" alt=""
|
Ex 2) If you change the initial condition, you would get different result (a little bit distorted circle)
Input
|
%Save the following contents in a .m file and run the .m file
omega = 1;
dy_dt = @(t,y) [y(2);...
-omega.^2*sin(y(1))];
odeopt = odeset ('RelTol', 0.00001, 'AbsTol', 0.00001,'InitialStep',0.5,'MaxStep',0.5);
[t,y] = ode45(dy_dt,[0 25], [0.0 1.7],odeopt);
subplot(1,2,1);plot(t,y(:,1),'r-',t,y(:,2),'b-'); xlabel('time'); legend('y1(t)','y2(t)');
subplot(1,2,2);plot(y(:,1),y(:,2),'b-'); xlabel('y(2)');ylabel('y(1)');axis([-2.5 2.5 -2.5 2.5]);
|
Output
|
data:image/s3,"s3://crabby-images/606a6/606a63f90c000bbe07ff982e1fd0d6222633b033" alt=""
|
ode45 - Single Spring Mass- Undamped
data:image/s3,"s3://crabby-images/03cbb/03cbb8decf64b0539ac0207134f67ba41ddf74a3" alt=""
data:image/s3,"s3://crabby-images/228db/228db682aba38103feffe4a615cab6ee3fe70989" alt=""
Ex)
Input
|
%Save the following contents in a .m file and run the .m file
m = 1;
k = 1;
dy_dt = @(t,y) [y(2);...
-(k/m) * y(1) ];
odeopt = odeset ('RelTol', 0.00001, 'AbsTol', 0.00001,'InitialStep',0.5,'MaxStep',0.5);
[t,y] = ode45(dy_dt,[0 25], [0.0 1.0],odeopt);
subplot(1,2,1);plot(t,y(:,1),'r-',t,y(:,2),'b-'); xlabel('time'); ylim([-1.2 1.2]); legend('y1(t)','y2(t)');
subplot(1,2,2);plot(y(:,1),y(:,2),'b-'); xlabel('y(2)');ylabel('y(1)'); xlim([-1.2 1.2]); ylim([-1.2 1.2]);
|
Output
|
data:image/s3,"s3://crabby-images/8c7cd/8c7cdf9ef52104b41d12bd5e226bc9dba43266e4" alt=""
|
ode45 - Single Spring Mass- Damped
data:image/s3,"s3://crabby-images/3b212/3b2127ebc223771e5a651e4ab36ffba067a77119" alt=""
data:image/s3,"s3://crabby-images/228db/228db682aba38103feffe4a615cab6ee3fe70989" alt=""
Ex)
Input
|
%Save the following contents in a .m file and run the .m file
m = 1;
k = 1;
c = 0.3;
dy_dt = @(t,y) [y(2);...
-(c/m) * y(2) - (k/m) * y(1) ];
odeopt = odeset ('RelTol', 0.00001, 'AbsTol', 0.00001,'InitialStep',0.5,'MaxStep',0.5);
[t,y] = ode45(dy_dt,[0 25], [0.0 1.0],odeopt);
subplot(1,2,1);plot(t,y(:,1),'r-',t,y(:,2),'b-'); xlabel('time'); ylim([-1.2 1.2]); legend('y1(t)','y2(t)');
subplot(1,2,2);plot(y(:,1),y(:,2),'b-'); xlabel('y(2)');ylabel('y(1)'); xlim([-1.2 1.2]); ylim([-1.2 1.2]);
|
Output
|
data:image/s3,"s3://crabby-images/f7b52/f7b523187a9eed530e3a3c610246c0c6fcd448fa" alt=""
|
ode45 - Single Spring Mass- Damped and External Force
data:image/s3,"s3://crabby-images/ea2e5/ea2e5821a579f7cbf4beba2b1431b8c9fb1c59d9" alt=""
data:image/s3,"s3://crabby-images/6517a/6517a027378cec08820a2016c110c45cf73fc320" alt=""
Ex)
Input
|
%Save the following contents in a .m file and run the .m file
m = 1;
k = 1;
c = 0.3;
F0 = 0.5;
w = 2.5;
dy_dt = @(t,y) [y(2);...
-(c/m) * y(2) - (k/m) * y(1) + (F0/m) * cos(w*t)];
odeopt = odeset ('RelTol', 0.00001, 'AbsTol', 0.00001,'InitialStep',0.5,'MaxStep',0.5);
[t,y] = ode45(dy_dt,[0 50], [0.0 1.0],odeopt);
subplot(1,2,1);plot(t,y(:,1),'r-',t,y(:,2),'b-'); xlabel('time'); ylim([-1.2 1.2]); legend('y1(t)','y2(t)');
subplot(1,2,2);plot(y(:,1),y(:,2),'b-'); xlabel('y(2)');ylabel('y(1)'); xlim([-1.2 1.2]); ylim([-1.2 1.2]);
|
Output
|
data:image/s3,"s3://crabby-images/cdf0c/cdf0ca49fadc54c8bc5d61ae7bbb5b2d750c014e" alt=""
|
ode45 - Single Spring Mass- Damped and External Force with Frequency Sweep
Ex)
Input
|
%Save the following contents in a .m file and run the .m file
m = 1.0;
k = 0.7;
c = 0.3;
F0 = 0.5;
tmax = 100;
yinit = 0.0;
for i = 1:10
w = 0.2 * i;
dy_dt = @(t,y) [y(2);...
-(c/m) * y(2) - (k/m) * y(1) + (F0/m) * cos(w*t)];
odeopt = odeset ('RelTol', 0.00001, 'AbsTol', 0.00001,'InitialStep',0.5,'MaxStep',0.5);
[t,y] = ode45(dy_dt,[0 tmax], [0.0 yinit],odeopt);
subplot(10,7,[(i*7-6) (i*7-1)] );plot(t,y(:,1),'r-',t,y(:,2),'b-');
ylim([-2 2]); set(gca,'xticklabel',[]);set(gca,'yticklabel',[]);
subplot(10,7,i*7);plot(y(:,1),y(:,2),'b-');
xlim([-2 2]); ylim([-2 2]); set(gca,'xticklabel',[]);set(gca,'yticklabel',[]);
end;
|
Output
|
data:image/s3,"s3://crabby-images/734f7/734f793739fe74fe227adcd46206e0e82e4a87d0" alt=""
|
ode45 - 1s Order System Equation- Lorenz Attractor
data:image/s3,"s3://crabby-images/95fca/95fca508676c6e424f55c86dbc35e49e54218bd3" alt=""
data:image/s3,"s3://crabby-images/0b601/0b601eba88003724459c594c20a2e276e7beb1ec" alt=""
Ex)
Input
|
%Save the following contents in a .m file and run the .m file
P = 10;
r = 28;
b = 8/3;
dy_dt = @(t,y) [-P*y(1)+P*y(2);...
r.*y(1)-y(2)-y(1)*y(3);...
y(1)*y(2)-b.*y(3)];
odeopt = odeset ('RelTol', 0.00001, 'AbsTol', 0.00001,'InitialStep',0.5,'MaxStep',0.5);
[t,y] = ode45(dy_dt,[0 250], [1.0 1.0 1.0],odeopt);
subplot(1,3,1);plot(y(:,1),y(:,2),'r-'); xlabel('y(1)'); ylabel('y(2)');
subplot(1,3,2);plot(y(:,2),y(:,3),'g-'); xlabel('y(2)'); ylabel('y(3)');
subplot(1,3,3);plot(y(:,1),y(:,3),'b-'); xlabel('y(1)'); ylabel('y(3)');
|
Output
|
data:image/s3,"s3://crabby-images/43e3c/43e3c053c86e3792beb27fd7b194067821a8759a" alt=""
|
ode45 - Chemical Reaction
data:image/s3,"s3://crabby-images/6a9dc/6a9dcf5f1852aa876344e175c2197a5b02f32ac7" alt=""
data:image/s3,"s3://crabby-images/b76c8/b76c8ad6b3502a1465a177eca8635597bbe64a0b" alt=""
Ex)
Input
|
%Save the following contents in a .m file and run the .m file
k1 = 5;
k2 = 2;
k3 = 1;
dy_dt = @(t,y) [-k1*y(1) + k2*y(2);
k1*y(1) - (k2+k3)*y(2);
k3*y(2)];
odeopt = odeset ('RelTol', 0.00001, 'AbsTol', 0.00001,'InitialStep',0.5,'MaxStep',0.5);
[t,y] = ode45(dy_dt,[0 4], [1.0 0.0 0.0],odeopt);
plot(t,y(:,1),'r-',t,y(:,2),'g-',t,y(:,3),'b-'); xlabel('time'); legend('y(1)','y(2)','y(3)');
|
Output
|
data:image/s3,"s3://crabby-images/8c9a7/8c9a7d21b6f0262a6f1b330c7db090f4da2dd29f" alt=""
|
Ode45 - Vander Pol Oscillator
data:image/s3,"s3://crabby-images/f037b/f037b6356f9b0be2873dc5625f5d83c5b4b5c1b3" alt=""
data:image/s3,"s3://crabby-images/58de0/58de0f06a86686aa0c2fb3625a3fe6d38d083258" alt=""
Ex)
Input
|
%Save the following contents in a .m file and run the .m file
mu = 1;
k = 1;
dy_dt = @(t,y) [y(2);...
mu*(1-y(1)^2)*y(2)-k*y(1)];
odeopt = odeset ('RelTol', 0.00001, 'AbsTol', 0.00001,'InitialStep',0.5,'MaxStep',0.5);
[t,y] = ode45(dy_dt,[0 40], [1.0 2.0],odeopt);
subplot(1,3,[1 2]);plot(t,y(:,1),'r-',t,y(:,2),'g-'); xlabel('time'); legend('y(1)','y(2)');
subplot(1,3,3);plot(y(:,1),y(:,2)); xlabel('y(1)'); ylabel('y(2)');
|
Output
|
data:image/s3,"s3://crabby-images/4fb1a/4fb1aa8810c6312a1fdafc42fada0c65980c501d" alt=""
|
Ode45 - Vander Pol Oscillator with External Force
data:image/s3,"s3://crabby-images/b5d79/b5d7942fd8641a06cd4fe00d53fd44bfea089b35" alt=""
data:image/s3,"s3://crabby-images/58de0/58de0f06a86686aa0c2fb3625a3fe6d38d083258" alt=""
Ex)
Input
|
%Save the following contents in a .m file and run the .m file
mu = 1;
k = 1;
A = 2.0;
w = 10;
dy_dt = @(t,y) [y(2);...
mu*(1-y(1)^2)*y(2)-k*y(1) + A*sin(w*t)];
odeopt = odeset ('RelTol', 0.00001, 'AbsTol', 0.00001,'InitialStep',0.5,'MaxStep',0.5);
[t,y] = ode45(dy_dt,[0 40], [1.0 2.0],odeopt);
subplot(1,3,[1 2]);plot(t,y(:,1),'r-',t,y(:,2),'g-'); xlabel('time'); legend('y(1)','y(2)');
subplot(1,3,3);plot(y(:,1),y(:,2)); xlabel('y(1)'); ylabel('y(2)');
|
Output
|
data:image/s3,"s3://crabby-images/f9392/f93927450157b82fa74c6c3380c630c4b8ed0f80" alt=""
|
Ode45 - Duffing Oscillator
data:image/s3,"s3://crabby-images/cfdce/cfdce24e3aac1c4c34f1e5cc74f1aa861b737df1" alt=""
data:image/s3,"s3://crabby-images/a0ace/a0aced7d8a3c3b06e2e8aa3c78f1dee5433b4831" alt=""
Ex)
Input
|
%Save the following contents in a .m file and run the .m file
delta = 0.06;
beta = 1.0;
w0 = 1.0;
w = 1.0;
gamma = 6.0;
phi = 0;
dy_dt = @(t,y) [y(2);...
-delta*y(2)-(beta*y(1)^3 + w0^2*y(1))+gamma*cos(w*t+phi)];
odeopt = odeset ('RelTol', 0.00001, 'AbsTol', 0.00001,'InitialStep',0.5,'MaxStep',0.5);
[t,y] = ode45(dy_dt,[0 100], [3.0 4.1],odeopt);
subplot(1,3,[1 2]);plot(t,y(:,1),'r-',t,y(:,2),'g-'); xlabel('time'); legend('y(1)','y(2)');
subplot(1,3,3);plot(y(:,1),y(:,2)); xlabel('y(1)'); ylabel('y(2)');
|
Output
|
data:image/s3,"s3://crabby-images/34815/3481542d278f200c2f5c65be3ede3be2e1adfbfa" alt=""
|
Ode45 - Matrix Equation - 2 x 2
data:image/s3,"s3://crabby-images/4f107/4f107627fca677243eeb808e4b3515ecb8f3c5f5" alt=""
data:image/s3,"s3://crabby-images/743cc/743cc362d0df52118ec09076f00418794d0b1f61" alt=""
Ex)
Input
|
%Save the following contents in a .m file and run the .m file
M = [-1,-1;...
1,-2];
yinit = [1.0,1.0];
dy_dt = @(t,y) [M*y];
odeopt = odeset ('RelTol', 0.00001, 'AbsTol', 0.00001,'InitialStep',0.5,'MaxStep',0.5);
[t,y] = ode45(dy_dt,[0 4], yinit,odeopt);
plot(t,y(:,1),'r-',t,y(:,2),'g-'); xlabel('time'); legend('y(1)','y(2)');
|
Output
|
data:image/s3,"s3://crabby-images/db978/db97871e89d8150490b15788d0d6699c2476467b" alt=""
|
Lsim - Damped Spring
Ex) See Damped Spring Example in Differential Equation page for the description of the model.
data:image/s3,"s3://crabby-images/61a0a/61a0ac3e12be470123f833d9266425dd5ca1d037" alt=""
Input
|
% This is tested on Octave. It would not work on Matlab (tested on Matlab 2014).
m = 1;
c = 0.2;
k = 1;
A = [0 1;-k/m -c/m];
B = [0 ; 1/m];
C = [0 1];
D = [0];
t = 0:0.1:50;
u = zeros(length(t),1);
x0 = [1 0];
sys = ss(A,B,C,0);
[y,t,x] = lsim(sys,u,t,x0);
plot(t,y);xlabel('time');ylabel('velocity');
|
Output
|
data:image/s3,"s3://crabby-images/daeef/daeefd482f668e337178364b8c992f7c9bcaa6a5" alt=""
|
Ex)
data:image/s3,"s3://crabby-images/cd1b0/cd1b06847329f5e8b7dd73605883f62c22caada5" alt=""
Input
|
% This is tested on Octave. It would not work on Matlab (tested on Matlab 2014).
m = 1;
c = 0.2;
k = 1;
A = [0 1;-k/m -c/m];
B = [0 ; 1/m];
C = [1 0];
D = [0];
t = 0:0.1:50;
u = zeros(length(t),1);
x0 = [1 0];
sys = ss(A,B,C,0);
[y,t,x] = lsim(sys,u,t,x0);
plot(t,y);xlabel('time');ylabel('velocity');
|
Output
|
data:image/s3,"s3://crabby-images/ca490/ca490af69b7e744a9a927ec1a46cb732f16e2f8c" alt=""
|
Lsim - RLC Circuit
Ex) See RLC Circuit Example in Differential Equation page for the description of the model.
data:image/s3,"s3://crabby-images/682b0/682b0bf5d2807ea460c50c64305058989d2774a7" alt=""
Input
|
% This is tested on Octave. It would not work on Matlab (tested on Matlab 2014).
R = 1;
L = 0.1;
C = 0.01;
A = [0 1;-1/(L*C) -R/L];
B = [0 ; 1/(L*C)];
C = [1 0];
D = [0];
t = 0:0.01:10;
u = ones(length(t),1);
u(200:400) = 0;
x0 = [1 0];
sys = ss(A,B,C,D);
[y,t,x] = lsim(sys,u,t,x0);
plot(t,y,'r-',t,u,'b--');xlabel('time');ylabel('voltage');legend('v2(t)','u(t)');
|
Output
|
data:image/s3,"s3://crabby-images/eb18a/eb18aa725fdc59d8b528557a770726920b68fabf" alt=""
|
Step - 1/s
Ex)
Input
|
sys = tf([1],[1 0]) % Create a transfer function based on numerator and denominator
step(sys);
|
Output
|
Transfer function 'sys' from input 'u1' to output ...
1
y1: -
s
Continuous-time model.
data:image/s3,"s3://crabby-images/80d11/80d113ea64b994524bc25a6ae75f42a2b3ac3d1d" alt=""
|
Step - 1/(a*s+1)
Ex)
Input
|
tau = 0.5;
sys = tf([1],[tau 1])
step(sys,5.0);
|
Output
|
Transfer function 'sys' from input 'u1' to output ...
1
y1: ---------
0.5 s + 1
Continuous-time model.
data:image/s3,"s3://crabby-images/db2ac/db2ac7d701318e40e9e19b2ae4d0f8f378066ece" alt=""
|
Step - 1/(a*s^2+b*s+1)
Ex)
Input
|
a = 1.5;
b = 0.7;
sys = tf([1],[a b 1])
step(sys,20.0);
|
Output
|
Transfer function 'sys' from input 'u1' to output ...
1
y1: -------------------
1.5 s^2 + 0.7 s + 1
Continuous-time model.
data:image/s3,"s3://crabby-images/8221a/8221ae4da36b5feb9f621fd9b85490e84bb43dac" alt=""
|
|
|