# Lorenz system

(Redirected from Lorenz attractor)
https://en.wikipedia.org/wiki/Lorenz_attractor
A sample solution in the Lorenz attractor when ρ = 28, σ = 10, and β = 8/3

The Lorenz system is a system of ordinary differential equations first studied by Edward Lorenz. It is notable for having chaotic solutions for certain parameter values and initial conditions. In particular, the Lorenz attractor is a set of chaotic solutions of the Lorenz system. In popular media the ' butterfly effect' stems from the real-world implications of the Lorenz attractor, i.e. that in any physical system, in the absence of perfect knowledge of the initial conditions (even the minuscule disturbance of the air due to a butterfly flapping its wings), our ability to predict its future course will always fail. This underscores that physical systems can be completely deterministic and yet still be inherently unpredictable even in the absence of quantum effects. The shape of the Lorenz attractor itself, when plotted graphically, may also be seen to resemble a butterfly.

## Overview

In 1963, Edward Lorenz, with the help of Ellen Fetter, developed a simplified mathematical model for atmospheric convection. [1] The model is a system of three ordinary differential equations now known as the Lorenz equations:

{\displaystyle {\begin{aligned}{\frac {\mathrm {d} x}{\mathrm {d} t}}&=\sigma (y-x),\\[6pt]{\frac {\mathrm {d} y}{\mathrm {d} t}}&=x(\rho -z)-y,\\[6pt]{\frac {\mathrm {d} z}{\mathrm {d} t}}&=xy-\beta z.\end{aligned}}}

The equations relate the properties of a two-dimensional fluid layer uniformly warmed from below and cooled from above. In particular, the equations describe the rate of change of three quantities with respect to time: ${\displaystyle x}$ is proportional to the rate of convection, ${\displaystyle y}$ to the horizontal temperature variation, and ${\displaystyle z}$ to the vertical temperature variation. [2] The constants ${\displaystyle \sigma }$, ${\displaystyle \rho }$, and ${\displaystyle \beta }$ are system parameters proportional to the Prandtl number, Rayleigh number, and certain physical dimensions of the layer itself. [2]

The Lorenz equations also arise in simplified models for lasers, [3] dynamos, [4] thermosyphons, [5] brushless DC motors, [6] electric circuits, [7] chemical reactions [8] and forward osmosis. [9] The Lorenz equations are also the governing equations in Fourier space for the Malkus waterwheel. [10] [11] The Malkus waterwheel exhibits chaotic motion where instead of spinning in one direction at a constant speed, its rotation will speed up, slow down, stop, change directions, and oscillate back and forth between combinations of such behaviors in an unpredictable manner.

From a technical standpoint, the Lorenz system is nonlinear, non-periodic, three-dimensional and deterministic. The Lorenz equations have been the subject of hundreds of research articles, and at least one book-length study. [2]

## Analysis

One normally assumes that the parameters ${\displaystyle \sigma }$, ${\displaystyle \rho }$, and ${\displaystyle \beta }$ are positive. Lorenz used the values ${\displaystyle \sigma =10}$, ${\displaystyle \beta =8/3}$ and ${\displaystyle \rho =28}$. The system exhibits chaotic behavior for these (and nearby) values. [12]

If ${\displaystyle \rho <1}$ then there is only one equilibrium point, which is at the origin. This point corresponds to no convection. All orbits converge to the origin, which is a global attractor, when ${\displaystyle \rho <1}$. [13]

A pitchfork bifurcation occurs at ${\displaystyle \rho =1}$, and for ${\displaystyle \rho >1}$ two additional critical points appear at: ${\displaystyle \left({\sqrt {\beta (\rho -1)}},{\sqrt {\beta (\rho -1)}},\rho -1\right)}$ and ${\displaystyle \left(-{\sqrt {\beta (\rho -1)}},-{\sqrt {\beta (\rho -1)}},\rho -1\right).}$ These correspond to steady convection. This pair of equilibrium points is stable only if

${\displaystyle \rho <\sigma {\frac {\sigma +\beta +3}{\sigma -\beta -1}},}$

which can hold only for positive ${\displaystyle \rho }$ if ${\displaystyle \sigma >\beta +1}$. At the critical value, both equilibrium points lose stability through a subcritical Hopf bifurcation. [14]

When ${\displaystyle \rho =28}$, ${\displaystyle \sigma =10}$, and ${\displaystyle \beta =8/3}$, the Lorenz system has chaotic solutions (but not all solutions are chaotic). Almost all initial points will tend to an invariant set – the Lorenz attractor – a strange attractor, a fractal, and a self-excited attractor with respect to all three equilibria. Its Hausdorff dimension is estimated from above by the Lyapunov dimension (Kaplan-Yorke dimension) as 2.06 ± 0.01, [15] and the correlation dimension is estimated to be 2.05 ± 0.01. [16] The exact Lyapunov dimension formula of the global attractor can be found analytically under classical restrictions on the parameters: [17] [15] [18] ${\displaystyle 3-{\frac {2(\sigma +\beta +1)}{\sigma +1+{\sqrt {(\sigma -1)^{2}+4\sigma \rho }}}}.}$

The Lorenz attractor is difficult to analyze, but the action of the differential equation on the attractor is described by a fairly simple geometric model. [19] Proving that this is indeed the case is the fourteenth problem on the list of Smale's problems. This problem was the first one to be resolved, by Warwick Tucker in 2002. [20]

For other values of ${\displaystyle \rho }$, the system displays knotted periodic orbits. For example, with ${\displaystyle \rho =99.96}$ it becomes a T(3,2) torus knot.

Example solutions of the Lorenz system for different values of ρ
ρ = 14, σ = 10, β = 8/3 (Enlarge) ρ = 13, σ = 10, β = 8/3 (Enlarge)
ρ = 15, σ = 10, β = 8/3 (Enlarge) ρ = 28, σ = 10, β = 8/3 (Enlarge)
For small values of ρ, the system is stable and evolves to one of two fixed point attractors. When ρ is larger than 24.74, the fixed points become repulsors and the trajectory is repelled by them in a very complex way.
Sensitive dependence on the initial condition
Time t = 1 (Enlarge) Time t = 2 (Enlarge) Time t = 3 (Enlarge)
These figures — made using ρ = 28, σ = 10 and β = 8/3 — show three time segments of the 3-D evolution of two trajectories (one in blue, the other in yellow) in the Lorenz attractor starting at two initial points that differ only by 10−5 in the x-coordinate. Initially, the two trajectories seem coincident (only the yellow one can be seen, as it is drawn over the blue one) but, after some time, the divergence is obvious.

## Connection to tent map

A recreation of Lorenz's results created on Mathematica. Points above the red line correspond to the system switching lobes.

In Figure 4 of his paper, [1] Lorenz created a Poincaré plot by plotting the relative maximum value in the z direction achieved by the system, against the previous relative maximum in the z direction. The resulting plot has a shape very similar to the tent map. Lorenz also found that when the maximum z value is above a certain cut-off, the system will switch to the next lobe. Combining this with the chaos known to be exhibited by the tent map, he showed that the system switches between the two lobes chaotically.

## Simulations

### MATLAB simulation

% Solve over time interval [0,100] with initial conditions [1,1,1]
% ''f'' is set of differential equations
% ''a'' is array containing x, y, and z variables
% ''t'' is time variable

sigma = 10;
beta = 8/3;
rho = 28;
f = @(t,a) [-sigma*a(1) + sigma*a(2); rho*a(1) - a(2) - a(1)*a(3); -beta*a(3) + a(1)*a(2)];
[t,a] = ode45(f,[0 100],[1 1 1]);     % Runge-Kutta 4th/5th order ODE solver
plot3(a(:,1),a(:,2),a(:,3))


### Mathematica simulation

Standard way:

tend = 50;
eq = {x'[t] == σ (y[t] - x[t]),
y'[t] == x[t] (ρ - z[t]) - y[t],
z'[t] == x[t] y[t] - β z[t]};
init = {x[0] == 10, y[0] == 10, z[0] == 10};
pars = {σ->10, ρ->28, β->8/3};
{xs, ys, zs} =
NDSolveValue[{eq /. pars, init}, {x, y, z}, {t, 0, tend}];
ParametricPlot3D[{xs[t], ys[t], zs[t]}, {t, 0, tend}]


Less verbose:

lorenz = NonlinearStateSpaceModel[{{σ (y - x), x (ρ - z) - y, x y - β z}, {}}, {x, y, z}, {σ, ρ, β}];
soln[t_] = StateResponse[{lorenz, {10, 10, 10}}, {10, 28, 8/3}, {t, 0, 50}];
ParametricPlot3D[soln[t], {t, 0, 50}]


Dynamically interactive solution:

eqs = {
x'[t] == σ (y[t] - x[t]), y'[t] == x[t] (ρ - z[t]) - y[t], z'[t] == x[t] y[t] - β z[t],
x[0] == 10, y[0] == 10, z[0] == 10
};
tmax = 50;
sol = ParametricNDSolveValue[eqs, Function[t, {x[t], y[t], z[t]}], {t, 0, tmax}, {σ, ρ, β}];
Manipulate[
fun = sol[σ, ρ, β];
plot = ParametricPlot3D[fun[t], {t, 0, tmax}, PlotRange -> All, PerformanceGoal -> "Quality"];
Animate[
Show[plot, Graphics3D[{PointSize[0.05], Red, Point[fun[t]]}]],
{t, 0, tmax}, AnimationRunning -> True, AnimationRate -> 1
],
{{σ, 10}, 0, 100}, {{ρ, 28}, 0, 100}, {{β, 8/3}, 0, 100},
TrackedSymbols :> {σ, ρ, β}
]


### Python simulation

import numpy as np
import matplotlib.pyplot as plt
from scipy.integrate import odeint
from mpl_toolkits.mplot3d import Axes3D

rho = 28.0
sigma = 10.0
beta = 8.0 / 3.0

def f(state, t):
x, y, z = state  # Unpack the state vector
return sigma * (y - x), x * (rho - z) - y, x * y - beta * z  # Derivatives

state0 = [1.0, 1.0, 1.0]
t = np.arange(0.0, 40.0, 0.01)

states = odeint(f, state0, t)

fig = plt.figure()
ax = fig.gca(projection="3d")
ax.plot(states[:, 0], states[:, 1], states[:, 2])
plt.draw()
plt.show()


### Modelica simulation

model LorenzSystem

parameter Real sigma = 10;
parameter Real rho = 28;
parameter Real beta = 8/3;

parameter Real x_start = 1 "Initial x-coordinate";
parameter Real y_start = 1 "Initial y-coordinate";
parameter Real z_start = 1 "Initial z-coordinate";

Real x "x-coordinate";
Real y "y-coordinate";
Real z "z-coordinate";

initial equation
x = x_start;
y = y_start;
z = z_start;

equation

der(x) = sigma*(y-x);
der(y) = rho*x - y - x*z;
der(z) = x*y - beta*z;

end LorenzSystem;


### Julia simulation

using DifferentialEquations, ParameterizedFunctions, Plots

lorenz = @ode_def begin                  # define the system
dx = σ * (y - x)
dy = x * (ρ - z) - y
dz = x * y - β*z
end σ ρ β

u₀ = [1.0,0.0,0.0]                       # initial conditions
tspan = (0.0,100.0)                      # timespan
p = [10.0,28.0,8/3]                      # parameters
prob = ODEProblem(lorenz, u₀, tspan, p)  # define the problem
sol = solve(prob)                        # solve it
plot(sol, vars = (1, 2, 3))              # plot solution in phase space - variables ordered with 1 based indexing


### Maxima simulation

load(dynamics)$load(draw)$

/* System parameters */
a: 10; b: 8/3; r: 28;

lorenzSystem: [a*(y-x), -x*z+r*x-y, x*y-b*z];
dependentVariables: [x, y, z]$initialValues: [1, 1, 1]$
timeRange: [t, 0, 50, 0.01]$/* solution via 4th order Runge-Kutta method */ systemSolution: rk(lorenzSystem, dependentVariables, initialValues, timeRange)$
solutionPoints: map(lambda([x], rest(x)), systemSolution)\$

draw3d(point_type=none, points_joined=true, color=blue,
xlabel="x(t)", ylabel="y(t)", zlabel="z(t)",
points(solutionPoints));


## Derivation of the Lorenz equations as a model for atmospheric convection

The Lorenz equations are derived from the Oberbeck–Boussinesq approximation to the equations describing fluid circulation in a shallow layer of fluid, heated uniformly from below and cooled uniformly from above. [1] This fluid circulation is known as Rayleigh–Bénard convection. The fluid is assumed to circulate in two dimensions (vertical and horizontal) with periodic rectangular boundary conditions.

The partial differential equations modeling the system's stream function and temperature are subjected to a spectral Galerkin approximation: the hydrodynamic fields are expanded in Fourier series, which are then severely truncated to a single term for the stream function and two terms for the temperature. This reduces the model equations to a set of three coupled, nonlinear ordinary differential equations. A detailed derivation may be found, for example, in nonlinear dynamics texts. [21] The Lorenz system is a reduced version of a larger system studied earlier by Barry Saltzman. [22]

## Resolution of Smale's 14th problem

Smale's 14th problem says 'Do the properties of the Lorenz attractor exhibit that of a strange attractor?', it was answered affirmatively by Warwick Tucker in 2002. [20] To prove this result, Tucker used rigorous numerics methods like interval arithmetic and normal forms. First, Tucker defined a cross section ${\displaystyle \Sigma \subset \{x_{3}=r-1\}}$ that is cut transversely by the flow trajectories. From this, one can define the first-return map ${\displaystyle P}$, which assigns to each ${\displaystyle x\in \Sigma }$ the point ${\displaystyle P(x)}$ where the trajectory of ${\displaystyle x}$ first intersects ${\displaystyle \Sigma }$.

Then the proof is split in three main points that are proved and imply the existence of a strange attractor. [23] The three points are:

• There exists a region ${\displaystyle N\subset \Sigma }$ invariant under the first-return map, meaning ${\displaystyle P(N)\subset N}$
• The return map admits a forward invariant cone field
• Vectors inside this invariant cone field are uniformly expanded by the derivative ${\displaystyle DP}$ of the return map.

To prove the first point, we notice that the cross section ${\displaystyle \Sigma }$ is cut by two arcs formed by ${\displaystyle P(\Sigma )}$ (see [23]). Tucker covers the location of these two arcs by small rectangles ${\displaystyle R_{i}}$, the union of these rectangles gives ${\displaystyle N}$. Now, the goal is to prove that for all points in ${\displaystyle N}$, the flow will bring back the points in ${\displaystyle \Sigma }$, in ${\displaystyle N}$. To do that, we take a plan ${\displaystyle \Sigma '}$ below ${\displaystyle \Sigma }$ at a distance ${\displaystyle h}$ small, then by taking the center ${\displaystyle c_{i}}$ of ${\displaystyle R_{i}}$ and using Euler integration method, one can estimate where the flow will bring ${\displaystyle c_{i}}$ in ${\displaystyle \Sigma '}$ which gives us a new point ${\displaystyle c_{i}'}$. Then, one can estimate where the points in ${\displaystyle \Sigma }$ will be mapped in ${\displaystyle \Sigma '}$ using Taylor expansion, this gives us a new rectangle ${\displaystyle R_{i}'}$ centered on ${\displaystyle c_{i}}$. Thus we know that all points in ${\displaystyle R_{i}}$ will be mapped in ${\displaystyle R_{i}'}$. The goal is to do this method recursively until the flow comes back to ${\displaystyle \Sigma }$ and we obtain a rectangle ${\displaystyle Rf_{i}}$ in ${\displaystyle \Sigma }$ such that we know that ${\displaystyle P(R_{i})\subset Rf_{i}}$. The problem is that our estimation may become imprecise after several iterations, thus what Tucker does is to split ${\displaystyle R_{i}'}$ into smaller rectangles ${\displaystyle R_{i,j}}$ and then apply the process recursively. Another problem is that as we are applying this algorithm, the flow becomes more 'horizontal' (see [23]), leading to a dramatic increase in imprecision. To prevent this, the algorithm changes the orientation of the cross sections, becoming either horizontal or vertical.

## Contributions

Lorenz acknowledges the contributions from Ellen Fetter in his paper, who is responsible for the numerical simulations and figures. [1] Also, Margaret Hamilton helped in the initial, numerical computations leading up to the findings of the Lorenz model. [24]

## Notes

1. ^ a b c d
2. ^ a b c
3. ^
4. ^
5. ^
6. ^
7. ^
8. ^
9. ^
10. ^
11. ^
12. ^ Hirsch, Smale & Devaney (2003), pp. 303–305
13. ^ Hirsch, Smale & Devaney (2003), pp. 306+307
14. ^ Hirsch, Smale & Devaney (2003), pp. 307+308
15. ^ a b Kuznetsov, N.V.; Mokaev, T.N.; Kuznetsova, O.A.; Kudryashova, E.V. (2020). "The Lorenz system: hidden boundary of practical stability and the Lyapunov dimension". Nonlinear Dynamics. doi:.
16. ^
17. ^
18. ^ Kuznetsov, Nikolay; Reitmann, Volker (2020). Attractor Dimension Estimates for Dynamical Systems: Theory and Computation. Cham: Springer.
19. ^ Guckenheimer, John; Williams, R. F. (1979-12-01). "Structural stability of Lorenz attractors". Publications Mathématiques de l'Institut des Hautes Études Scientifiques. 50 (1): 59–72. doi: 10.1007/BF02684769. ISSN  0073-8301.
20. ^ a b
21. ^ Hilborn (2000), Appendix C; Bergé, Pomeau & Vidal (1984), Appendix D
22. ^
23. ^ a b c
24. ^