-
-
Notifications
You must be signed in to change notification settings - Fork 211
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
84ae858
commit 375a78d
Showing
1 changed file
with
64 additions
and
23 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,38 +1,79 @@ | ||
# Modeling with Stochasticity | ||
|
||
All models with `ODESystem` are deterministic. `SDESystem` adds another element | ||
to the model: randomness. This is a | ||
All previous differential equations tutorials deal with deterministic `ODESystem`s. | ||
In this tutorial, we add randomness. | ||
In particular, we show how to represent a | ||
[stochastic differential equation](https://en.wikipedia.org/wiki/Stochastic_differential_equation) | ||
which has a deterministic (drift) component and a stochastic (diffusion) | ||
component. Let's take the Lorenz equation from the first tutorial and extend | ||
it to have multiplicative noise by creating `@brownian` variables in the equations. | ||
as a `SDESystem`. | ||
|
||
!!! note | ||
|
||
The high level `@mtkmodel` macro used in the | ||
[getting started tutorial](@ref getting_started) | ||
is not yet compatible with `SDESystem`. | ||
We thus have to use a lower level interface to define stochastic differential equations. | ||
For an introduction to this interface, read the | ||
[programmatically generating ODESystems tutorial](@ref programmatically). | ||
|
||
Let's take the Lorenz equation and add noise to each of the states. | ||
To show the flexibility of ModelingToolkit, | ||
we do not use homogeneous noise, with constant variance, | ||
but instead use heterogeneous noise, | ||
where the magnitude of the noise scales with (0.1 times) the magnitude of each of the states: | ||
|
||
```math | ||
\begin{aligned} | ||
dx &= (\sigma (y-x))dt &+ 0.1xdB \\ | ||
dy &= (x(\rho-z) - y)dt &+ 0.1ydB \\ | ||
dz &= (xy - \beta z)dt &+ 0.1zdB \\ | ||
\end{aligned} | ||
``` | ||
|
||
Where $B$, is standard Brownian motion, also called the | ||
[Wiener process](https://en.wikipedia.org/wiki/Wiener_process). | ||
In ModelingToolkit this can be done by `@brownian` variables. | ||
|
||
```@example SDE | ||
using ModelingToolkit, StochasticDiffEq | ||
using ModelingToolkit: t_nounits as t, D_nounits as D | ||
using Plots | ||
# Define some variables | ||
@parameters σ ρ β | ||
@variables x(t) y(t) z(t) | ||
@brownian a | ||
eqs = [D(x) ~ σ * (y - x) + 0.1a * x, | ||
D(y) ~ x * (ρ - z) - y + 0.1a * y, | ||
D(z) ~ x * y - β * z + 0.1a * z] | ||
@parameters σ=10.0 ρ=2.33 β=26.0 | ||
@variables x(t)=5.0 y(t)=5.0 z(t)=1.0 | ||
@brownian B | ||
eqs = [D(x) ~ σ * (y - x) + 0.1B * x, | ||
D(y) ~ x * (ρ - z) - y + 0.1B * y, | ||
D(z) ~ x * y - β * z + 0.1B * z] | ||
@mtkbuild de = System(eqs, t) | ||
``` | ||
|
||
Even though we did not explicitly use `SDESystem`, ModelingToolkit can still infer this from the equations. | ||
|
||
u0map = [ | ||
x => 1.0, | ||
y => 0.0, | ||
z => 0.0 | ||
] | ||
```@example SDE | ||
typeof(de) | ||
``` | ||
|
||
parammap = [ | ||
σ => 10.0, | ||
β => 26.0, | ||
ρ => 2.33 | ||
] | ||
We continue by solving and plotting the SDE. | ||
|
||
prob = SDEProblem(de, u0map, (0.0, 100.0), parammap) | ||
```@example SDE | ||
prob = SDEProblem(de, [], (0.0, 100.0), []) | ||
sol = solve(prob, LambaEulerHeun()) | ||
plot(sol, idxs = [(1, 2, 3)]) | ||
``` | ||
|
||
The noise present in all 3 equations is correlated, as can be seen on the below figure. | ||
If you want uncorrelated noise for each equation, | ||
multiple `@brownian` variables have to be declared. | ||
|
||
```@example SDE | ||
@brownian Bx By Bz | ||
``` | ||
|
||
The figure also shows the multiplicative nature of the noise. | ||
Because states `x` and `y` generally take on larger values, | ||
the noise also takes on a more pronounced effect on these states compared to the state `z`. | ||
|
||
```@example SDE | ||
plot(sol) | ||
``` |