Dynamical Systems 1 Introduction Ing. Jaroslav Jíra, CSc. Definition Dynamical system is a system that changes over time according to a set of fixed rules that determine how one state of the system moves to another state. Dynamical system is a phase space together with a transformation of that space A dynamical system has two parts a) a state vector, which describes exactly the state of some real or hypothetical system b) a function, which tells us, given the current state, what the state of the system will be in the next instant of time A state vector can be described by x ( t ) [ x1 ( t ), x 2 ( t ),......, x n ( t )] A function can be described by a single function or by a set of functions f 1 ( x1 , x 2 ,...., x n ), f 2 ( x1 , x 2 ,...., x n ),...., f n ( x1 , x 2 ,...., x n ) Entire system can be then described by a set of differential equations – equations of motion dx 1 dt dx 2 dt x1 f 1 ( x1 , x 2 ,...., x n ) x 2 f 2 ( x1 , x 2 ,...., x n ) . . dx n dt x n f n ( x1 , x 2 ,...., x n ) Classification of Dynamical Systems Linear Nonlinear Autonomous Nonautonomous Conservative Nonconservative Discrete Continous One-dimensional Multidimensional Linear system – a function describing the system behavior must satisfy two basic properties • additivity f ( x y) f ( x) f ( y) f ( x ) f ( x ) • homogeneity For example f(x) = 3x; f(y) = 3y; • additivity f(x+y) = 3(x+y) = 3x + 3y = f(x) + f(y) • homogeneity 5 * f(x) = 5* 3x = 15x = f(5x) Nonlinear system is described by a nonlinear function. It does not satisfy previous basic properties For example f(x) = x2; f(y) = y2; f ( x y ) ( x y ) x 2 xy y f ( x ) f ( y ) x y 2 2 2 f ( 5 x ) ( 5 x ) 25 x 5 f ( x ) 5 x 2 2 2 2 2 Autonomous system is a system of ordinary differential equations, which do not depend on the independent variable. If the independent variable is time, we call it time-invariant system. Condition: If the input signal x(t) produces an output y(t) then any time shifted input, x(t + δ), results in a time-shifted output y(t + δ) Example: we have two systems System A: System B: y ( t ) 10 x ( t ) System A: Start with a delay of the input Now we delay the output by δ Clearly , therefore the system is not time-invariant or is nonautonomous. System B: Start with a delay of the input Now delay the output by δ Clearly therefore the system is time-invariant or autonomous. Conservative system - the total mechanical energy remains constant, there are no dissipations present, e.g. simple harmonic oscillator Nonconservative (dissipative) system – the total mechanical energy changes due to dissipations like friction or damping, e.g. damped harmonic oscillator Discrete system – is described be a difference equation or set of equations. In case of a single equation we are also talking about one-dimensional map. We denote time by k, and the system is typically specified by the equations x (0) x 0 x ( k 1) f ( x ( k )) x(k ) f ( x0 ) k The system can be solved by iteration calculation. Typical example is annual progress of a bank account. If the initial deposit is 100000 crowns and annual interest is 3%, then we can describe the system by x ( 0 ) 100000 x ( k 1) 1 . 03 x ( k ) x ( k ) 1 . 03 * 100000 k Continous system – is described by a differential equation or a set of equations. x (0) x 0 x´ f ( x ) For example, vertical throw is described by initial conditions h(0), v(0) and equations h ( t )´ v ( t ) v ( t )´ g where h is height and v is velocity of a body. Definition from the Mathematica: When the reals are acting, the system is called a continuous dynamical system, and when the integers are acting, the system is called a discrete dynamical system. One-dimensional system is described by a single function like x ( k 1) ax ( k ) b x´( t ) ax ( t ) b where a,b are constants. Multidimensional system is described by a vector of functions like x ( k 1) A x ( k ) B x ´( t ) A x ( t ) B where x is a vector with n components, A is n x n matrix and B is a constant vector Repetition From the Matrix Algebra Matrix A a 11 A a 21 a 31 a 12 a 22 a 32 a 13 a 23 a 33 a 11 b11 a 12 b 21 a 13 b 31 A.B a 21 b11 a 22 b 21 a 23 b 31 a 31 b11 a 32 b 21 a 33 b 31 a c a 12 c 2 a13 c 3 11 1 A. C a 21 c1 a 22 c 2 a 23 c 3 a 31 c1 a 32 c 2 a 33 c 3 Matrix B b11 B b 21 b 31 b12 b 22 b 32 b13 b 23 b 33 a 11 b12 a 12 b 22 a 13 b 32 a 21 b12 a 22 b 22 a 23 b 32 a 31 b12 a 32 b 22 a 33 b 32 Vector C c 1 C c2 c 3 a 11 b13 a 12 b 23 a 13 b 33 a 21 b13 a 22 b 23 a 23 b 33 a 31 b13 a 32 b 23 a 33 b 33 Identity matrix (unit matrix), we use symbol E or I Determinant 1 E 0 0 d 11 D d 12 0 1 0 0 0 1 d 21 d 22 det( D ) d 11 d 22 d 21 d 12 a 11 A a 21 a 31 a 12 a 22 a 32 a 13 a 11 a 23 a 21 a 33 a 31 a 12 a 22 a 32 det( A ) a11 a 22 a 33 a12 a 23 a 31 a13 a 21 a 32 a11 a 23 a 32 a12 a 21 a 33 a13 a 22 a 31 Inversion matrix – 2x2 a A c A 1 a c b d b d 1 a det( A ) c Inversion matrix – 3x3 1 b a 1 d ad cb c b d Eigenvalues and Eigenvectors The eigenvectors of a square matrix are the non-zero vectors which, after being multiplied by the matrix, remain proportional to the original vector (i.e. change only in magnitude, not in direction). For each eigenvector, the corresponding eigenvalue λ is the factor by which the eigenvector changes when multiplied by the matrix. Au u For the eigenvalue calculation we use the formula det( A E ) 0 For the eigenvector calculation we use the formula: a 11 a 21 Two-dimensional example: ( A E )u 0 u1 0 u 2 a 12 a 22 If we are successful in finding eigenvalues, we can say, that we found a diagonal matrix, which is similar to the original matrix. The diagonal matrix has the same properties like the original one for the purpose of solving dynamical system stability. We write the diagonal matrix in the form: 1 0 0 0 0 0 2 0 0 ... 0 0 0 0 0 n What are advantages of diagonal matrix? 1. Multidimensional discrete system. The typical formula is: x ( k 1) A x ( k ) To obtain k-th element: k x ( k ) A x (0) Raising matrices to the power is quite difficult, but in case of diagonal matrix we simply have: 1 k 0 k A 0 0 0 2 0 k 0 0 ... 0 0 0 0 0 k n 2. Multidimensional continous system. The typical differential equation: dx Solution of the equation: x ( t ) x 0 exp( A t ) A x (t ) dt Using matrices as an argument for the exponential function is much more difficult than raising them to the power, but in case of diagonal matrix we can write: e 1 t 0 exp( A t ) 0 0 0 e 2 0 t 0 0 ... 0 0 0 0 0 nt e Example for eigenvalue and eigenvector calculation Initial matrix 4 A 1 2 5 Characteristic equation 4 det( A E ) det 1 2 0 5 ( 4 )( 5 ) 2 9 18 0 2 1 6 ; 2 3 Eigenvalues Eigenvector calculation 4 1 1 u1 2 5 1 u 2 1 2 2 u1 0 1 u 2 4 2 1 u 1 1 5 2 u 2 1 2 u1 2 u 2 0 u1 2 u 2 0 u1 u 2 0 u1 2 u 2 0 1 u1 1 2 u2 1 2 2 u1 0 2 u 2 Any vector that satisfies condition u1=u2 is an eigenvector for the λ=6 Any vector that satisfies condition u1=-2u2 is an eigenvector for the λ=3 Automatic eigenvalue and eigenvector calculation in the Mathematica Trace of a matrix is a sum of the elements on the main diagonal Tr ( A ) a11 a 22 .... a nn Jacobian matrix is the matrix of all first-order partial derivatives of a vectoror scalar-valued function with respect to another vector. This matrix is frequently being marked as J, Df or A. dx 1 dt dx 2 dt x1 f 1 ( x1 , x 2 ,...., x n ) x 2 f 2 ( x1 , x 2 ,...., x n ) . . dx n dt x n f n ( x1 , x 2 ,...., x n ) f1 x 1 f 2 J x1 ... f n x1 f1 x2 f 2 x2 ... f n x2 ... ... ... f1 xn f 2 xn ... f n x n Phase Portraits A phase space is a space in which all possible states of a system are represented, with each possible state of the system corresponding to one unique point in the phase space. The phase space of a two-dimensional system is called a phase plane, which occurs in classical mechanics for a single particle moving in one dimension, and where the two variables are position and velocity. For mechanical systems, the phase space usually consists of all possible values of position and velocity variables. A plot of position and velocity variables as a function of time is sometimes called a phase diagram. A phase portrait is a plot of single phase curve or multiple phase curves corresponding to different initial conditions in the same phase plane. A phase portrait of a simple harmonic oscillator x 2 x 0 Differential equation where x is displacement, v is velocity, A is amplitude and ω is angular frequency. x A cos( t ) Solution of the equation v A sin( t ) Now we separate sine and cosine functions, raise both equations to the power of two and finally we add them. x 2 cos( t ) A v A sin( t ) x 2 cos ( t ) A 2 v 2 sin ( t ) A 2 2 x v 2 2 cos ( t ) sin ( t ) 1 A A 2 Final equation describes an ellipse 2 x v 1 A A The following figure shows a phase portrait of a simple harmonic oscillator with ω=10 s-1 and initial conditions x(0)=1 m; v(0)=0 m/s 2 2 x v 1 A A 2 2 x v 1 1 10 Creating a phase portrait of a damped oscillator in Matlab y 2 y 2 y 0 y 2 y 2 y y1 y function [t,y] = oscil(delta) tspan=[0,7]; init=[1;0]; omega=10; [t,y]=ode45(@f,tspan,init); plot(y(:,1),y(:,2)); y 2 y y 1 y 2 y 2 y 2 y y y 1 y 2 y 2 2 y 2 y1 2 y1 ( 0 ) y ( 0 ) 1 y 2 ( 0 ) y ( 0 ) 0 %Creation of graph description. xlabel('displacement [m]') ylabel('velocity [m/s]') title('A damped harmonic oscillator'); axis([-1 1 -10 10]); function yprime=f(t,y) yprime=zeros(2,1); yprime(1)=y(2); yprime(2)=-2*delta*y(2)-omega^2*y(1); end clc end Oscillator with critical damping ω= 10s-1; δ= 10s-1 x(0)=1m; v(0)=0 m/s Overdamped oscillator ω= 10s-1; δ= 20s-1 x(0)=1m; v(0)=0 m/s Underdamped oscillator ω= 10s-1; δ= 1s-1 x(0)=1m; v(0)=0 m/s Simple harmonic oscillator initial amplitudes are 1,2, …,10 m Creating a phase portrait of an oscillator in Mathematica Stability and Fixed Points A fixed point is a special point of the dynamical system which does not change in time. It is also called an equilibrium, steady-state, or singular point of the system. If a system is defined by an equation dx/dt = f(x), then the fixed point x~ can be found by examining of condition f(x~)=0. We need not know analytic solution of x(t). For discrete time systems we examine condition x~ = f(x~) An attractor is a set towards which a dynamical system evolves over time. It can be a point, a curve or more complicated structure A stable fixed point: for all starting values x0 near the x~ the system converges to the x~ as t→∞. A marginally stable (neutral) fixed point: for all starting values x0 near x~, the system stays near x~ but does not converge to x~ . An unstable fixed point: for starting values x0 very near x~ the system moves far away from x~ A perturbation is a small change in a physical system, most often in a physical system at equilibrium that is disturbed from the outside. Phase portraits of basic three types of fixed points STABLE MARGINALLY STABLE UNSTABLE Example 1– bacteria in a jar A jar is filled with a nutritive solution and some bacteria. Let b (for birth) be relative rate at which the bacteria reproduce and p (for perish) be relative rate at which they die. Then the population is growing at the rate r = b−p. If there are x bacteria in the jar, then the rate at which the number of bacteria is increasing is (b − p)x, that is, dx/dt = rx. Solution of this equation fox x(0)=x0 is x (t ) x 0 e rt This model is not realistic, because bacteria population goes to the ∞ for r>0. Actually, as the number of bacteria rises, they crowd each other, produce more toxic waste products etc. Instead of constant relative perish rate p we will assume relative perish rate dependent on their number px. Now the number of bacteria increases by bx and their number decreases by px2. New differential equation will be dx dt bx px 2 Differential equation, dx initial number of bacteria x(0)=x0 dt bx px 2 Analytic solution provided by Mathematica To be able to find a fixed point, we have to set the right-hand side of the differential equation to zero. 2 b~ x p~ x 0 ~ x (b p~ x) 0 There are two possible solutions, ~ x1 0 i.e. we have two fixed points: b ~ x2 p First fixed point x~1= 0; There are no bacteria, so none can be born, none can die, but after small contamination of the jar (perturbation), but smaller than b/p, we can see, that the number of bacteria will increase by dx/dt = bx-px2>0 and will never return to the zero state. Conclusion: this fixed point is unstable. Second point x~2= b/p; At this population level, bacteria are being born at a rate bx~=b(b/p) = b2/p and are dying at a rate px~2 = p(b/p)2 = b2/p, so birth and death rates are exactly in balance. If the number of bacteria would be slightly increased, then dx/dt = bx-px2<0 and would return to equilibrium. If the number of bacteria would be slightly decreased, then dx/dt = bx-px2>0 and would return to equilibrium. Small perturbations away from x~ = b/p will self-correct back to b/p. Conclusion: this fixed point is stable and is also an attractor of this system. Graphic solution from Mathematica Input parameters: b=0.2, p=0.5 Initial conditions: x0= 0.9 for blue lines x0= 0.01 for red lines Phase portrait Number of bacteria in time dx dt 0.10 x 1.0 0.8 0.05 b/p 0.6 0.4 0.00 0.2 0.0 0 10 20 30 40 t 0.05 0.10 0.2 0.4 0.6 0.8 1.0 x Example 2 – predator and prey Now we have a biological system containing two species – predators (wolves) and prey (rabbits). Population of rabbits in time is r(t) and population of wolves is w(t). Rabbits, left on their own, will reproduce with velocity dr/dt= ar, where a>0 Wolves, without rabbits, will starve and their population will decline with velocity dw/dt= -bw, where b>0 When brought into the same environment, wolves will catch and eat rabbits. Loss to the rabbit population will be proportional to number of wolves w and number of rabbits r by a constant g (aggressivity of predators). Gain to the wolf population will be also proportional to r and w, this time by a constant h (effectivity of transformation of prey meat into the predator biomass). dr Here are differential equations describing the closed system ar grw dt dw dt bw hrw Here is time dependence and phase diagram for both populations a=0.3; b=0.1; g=0.002; h=0.001, initial number of rabbits r0=100, wolves w0=25 Number of populations over time Phase portrait An attractor of this system drawn on the phase diagram is a limit cycle. With higher rabbit natality and higher wolf mortality together with higher wolf aggressivity the changes are quicker a=0.75; b=0.2; g=0.03; h=0.01 Number of populations over time Phase portrait With extremely low rabbit natality and low wolf mortality togehter with high wolf aggressivity both civilizations will vanish a=0.01; b=0.05; g=0.05; h=0.05 Number of populations over time Phase portrait Source codes from Matlab for both types of graphs function [t, x, y] = predator function [t, x, y] = predatorparam a=0.2; b=0.1; g=0.002; h=0.001; tend=200; a=0.2; b=0.1; g=0.002; h=0.001; tend=200; x0 = [100; 25]; [t, xvec] = ode45(@f, [0, tend], x0); x0 = [100; 25]; [t, xvec] = ode45(@f, [0, tend], x0); x = xvec(:, 1); y = xvec(:, 2); x = xvec(:, 1); y = xvec(:, 2); % Plot of the solution p=plot(t,x,t,y); xlabel('time'); ylabel('number'); hleg = legend('Rabbits','Wolves'); % Plot of the solution p=plot(x,y); xlabel('Rabbits'); ylabel('Wolves'); function xdot = f(t, x) xdot= [ a*x(1) - g*x(1)*x(2); ... -b*x(2) + h*x(1)*x(2)]; end end function xdot = f(t, x) xdot= [ a*x(1) - g*x(1)*x(2); ... -b*x(2) + h*x(1)*x(2)]; end end