DynamicalSystemsBase.DynamicalSystemsBase
— ModuleDynamicalSystemsBase.jl
A Julia package that defines the DynamicalSystem
interface and many concrete implementations used in the DynamicalSystems.jl ecosystem.
To install it, run import Pkg; Pkg.add("DynamicalSystemsBase")
. Typically, you do not want to use DynamicalSystemsBase
directly, as downstream analysis packages re-export it.
All further information is provided in the documentation, which you can either find online or build locally by running the docs/make.jl
file.
DynamicalSystemsBase.CoreDynamicalSystem
— TypeCoreDynamicalSystem
Union type meaning either DeterministicIteratedMap
or CoupledODEs
, which are the core systems whose dynamic rule f
is known analytically.
This type is used for deciding whether a creation of a TangentDynamicalSystem
is possible or not.
DynamicalSystemsBase.ArbitrarySteppable
— TypeArbitrarySteppable <: DiscreteTimeDynamicalSystem
ArbitrarySteppable(
model, step!, extract_state, extract_parameters, reset_model!;
isdeterministic = true, set_state = reinit!,
)
A dynamical system generated by an arbitrary "model" that can be stepped in-place with some function step!(model)
for 1 step. The state of the model is extracted by the extract_state(model) -> u
function The parameters of the model are extracted by the extract_parameters(model) -> p
function. The system may be re-initialized, via reinit!
, with the reset_model!
user-provided function that must have the call signature
reset_model!(model, u, p)
given a (potentially new) state u
and parameter container p
, both of which will default to the initial ones in the reinit!
call.
ArbitrarySteppable
exists to provide the DynamicalSystems.jl interface to models from other packages that could be used within the DynamicalSystems.jl library. ArbitrarySteppable
follows the DynamicalSystem
interface with the following adjustments:
initial_time
is always 0, as time counts the steps the model has taken since creation or lastreinit!
call.set_state!
is the same asreinit!
by default. If not, the keyword argumentset_state
is a functionset_state(model, u)
that sets the state of the model tou
.- The keyword
isdeterministic
should be set properly, as it decides whether downstream algorithms should error or not.
DynamicalSystemsBase.ContinuousDynamicalSystem
— TypeContinuousDynamicalSystem
An alias to CoupledODEs
. This was the name these systems had before DynamicalSystems.jl v3.0.
DynamicalSystemsBase.ContinuousTimeDynamicalSystem
— TypeContinuousTimeDynamicalSystem <: DynamicalSystem
Abstract subtype of DynamicalSystem
encompassing all continuous time systems.
DynamicalSystemsBase.CoupledODEs
— TypeCoupledODEs <: ContinuousTimeDynamicalSystem
CoupledODEs(f, u0 [, p]; diffeq, t0 = 0.0)
A deterministic continuous time dynamical system defined by a set of coupled ordinary differential equations as follows:
\[\frac{d\vec{u}}{dt} = \vec{f}(\vec{u}, p, t)\]
An alias for CoupledODE
is ContinuousDynamicalSystem
.
Optionally provide the parameter container p
and initial time as keyword t0
.
For construction instructions regarding f, u0
see the DynamicalSystems.jl tutorial.
DifferentialEquations.jl interfacing
The ODEs are evolved via the solvers of DifferentialEquations.jl. When initializing a CoupledODEs
, you can specify the solver that will integrate f
in time, along with any other integration options, using the diffeq
keyword. For example you could use diffeq = (abstol = 1e-9, reltol = 1e-9)
. If you want to specify a solver, do so by using the keyword alg
, e.g.: diffeq = (alg = Tsit5(), reltol = 1e-6)
. This requires you to have been first using OrdinaryDiffEq
to access the solvers. The default diffeq
is:
(alg = Tsit5(; stagelimiter! = triviallimiter!, steplimiter! = triviallimiter!, thread = static(false),), abstol = 1.0e-6, reltol = 1.0e-6)
diffeq
keywords can also include callback
for event handling .
The convenience constructors CoupledODEs(prob::ODEProblem [, diffeq])
and CoupledODEs(ds::CoupledODEs [, diffeq])
are also available. To integrate with ModelingToolkit.jl, the dynamical system must be created via the ODEProblem
(which itself is created via ModelingToolkit.jl), see the Tutorial for an example.
Dev note: CoupledODEs
is a light wrapper of ODEIntegrator
from DifferentialEquations.jl. The integrator is available as the field integ
, and the ODEProblem
is integ.sol.prob
. The convenience syntax ODEProblem(ds::CoupledODEs, tspan = (t0, Inf))
is available to extract the problem.
DynamicalSystemsBase.DeterministicIteratedMap
— TypeDeterministicIteratedMap <: DiscreteTimeDynamicalSystem
DeterministicIteratedMap(f, u0, p = nothing; t0 = 0)
A deterministic discrete time dynamical system defined by an iterated map as follows:
\[\vec{u}_{n+1} = \vec{f}(\vec{u}_n, p, n)\]
An alias for DeterministicIteratedMap
is DiscreteDynamicalSystem
.
Optionally configure the parameter container p
and initial time t0
.
For construction instructions regarding f, u0
see the DynamicalSystems.jl tutorial.
DynamicalSystemsBase.DiscreteDynamicalSystem
— TypeDiscreteDynamicalSystem
An alias to DeterministicIteratedMap
. This was the name these systems had before DynamicalSystems.jl v3.0.
DynamicalSystemsBase.DiscreteTimeDynamicalSystem
— TypeDiscreteTimeDynamicalSystem <: DynamicalSystem
Abstract subtype of DynamicalSystem
encompassing all discrete time systems.
DynamicalSystemsBase.DynamicalSystem
— TypeDynamicalSystem
DynamicalSystem
is an abstract supertype encompassing all concrete implementations of what counts as a "dynamical system" in the DynamicalSystems.jl library.
All concrete implementations of DynamicalSystem
can be iteratively evolved in time via the step!
function. Hence, most library functions that evolve the system will mutate its current state and/or parameters. See the documentation online for implications this has for parallelization.
DynamicalSystem
is further separated into two abstract types: ContinuousTimeDynamicalSystem, DiscreteTimeDynamicalSystem
. The simplest and most common concrete implementations of a DynamicalSystem
are DeterministicIteratedMap
or CoupledODEs
.
Description
A DynamicalSystem
represents the time evolution of a state in a state space. It mainly encapsulates three things:
- A state, typically referred to as
u
, with initial valueu0
. The space thatu
occupies is the state space ofds
and the length ofu
is the dimension ofds
(and of the state space). - A dynamic rule, typically referred to as
f
, that dictates how the state evolves/changes with time when calling thestep!
function.f
is typically a standard Julia function, see the online documentation for examples. - A parameter container
p
that parameterizesf
.p
can be anything, but in general it is recommended to be a type-stable mutable container.
In sort, any set of quantities that change in time can be considered a dynamical system, however the concrete subtypes of DynamicalSystem
are much more specific in their scope. Concrete subtypes typically also contain more information than the above 3 items.
In this scope dynamical systems have a known dynamic rule f
. Finite measured or sampled data from a dynamical system are represented using StateSpaceSet
. Such data are obtained from the trajectory
function or from an experimental measurement of a dynamical system with an unknown dynamic rule.
See also the DynamicalSystems.jl tutorial online for examples making dynamical systems.
Integration with ModelingToolkit.jl
Dynamical systems that have been constructed from DEProblem
s that themselves have been constructed from ModelingToolkit.jl keep a reference to the symbolic model and all symbolic variables. Accessing a DynamicalSystem
using symbolic variables is possible via the functions observe_state
, set_state!
, current_parameter
and set_parameter!
. The referenced MTK model corresponding to the dynamical system can be obtained with model = referrenced_sciml_model(ds::DynamicalSystem)
.
See also the DynamicalSystems.jl tutorial online for an example.
In ModelingToolkit.jl v9 the default split
behavior of the parameter container is true
. This means that the parameter container is no longer a Vector{Float64}
by default, which means that you cannot use integers to access parameters. It is recommended to keep split = true
(default) and only access parameters via their symbolic parameter binding. Use structural_simplify(sys; split = false)
to allow accessing parameters with integers again.
API
The API that DynamicalSystem
employs is composed of the functions listed below. Once a concrete instance of a subtype of DynamicalSystem
is obtained, it can queried or altered with the following functions.
The main use of a concrete dynamical system instance is to provide it to downstream functions such as lyapunovspectrum
from ChaosTools.jl or basins_of_attraction
from Attractors.jl. A typical user will likely not utilize directly the following API, unless when developing new algorithm implementations that use dynamical systems.
API - obtain information
ds(t)
withds
an instance ofDynamicalSystem
: return the state ofds
at timet
. For continuous time systems this interpolates and extrapolates, while for discrete time systems it only works ift
is the current time.current_state
initial_state
observe_state
current_parameters
current_parameter
initial_parameters
isdeterministic
isdiscretetime
dynamic_rule
current_time
initial_time
isinplace
successful_step
referrenced_sciml_model
API - alter status
DynamicalSystemsBase.ParallelDynamicalSystem
— TypeParallelDynamicalSystem <: DynamicalSystem
ParallelDynamicalSystem(ds::DynamicalSystem, states::Vector{<:AbstractArray})
A struct that evolves several states
of a given dynamical system in parallel at exactly the same times. Useful when wanting to evolve several different trajectories of the same system while ensuring that they share parameters and time vector.
This struct follows the DynamicalSystem
interface with the following adjustments:
- The function
current_state
is called ascurrent_state(pds, i::Int = 1)
which returns thei
th state. Same forinitial_state
. - Similarly,
set_state!
obtains a third argumenti::Int = 1
to set thei
-th state. current_states
andinitial_states
can be used to get all parallel states.reinit!
takes in a vector of states (likestates
) foru
.
ParallelDynamicalSystem(ds::DynamicalSystem, states::Vector{<:Dict})
For a dynamical system referring a MTK model, one can specify states as a vector of dictionaries to alter the current state of ds
as in set_state!
.
DynamicalSystemsBase.PlaneCrossing
— TypePlaneCrossing(plane, dir) → pc
Create a struct that can be called as a function pc(u)
that returns the signed distance of state u
from the hyperplane plane
(positive means in front of the hyperplane). See PoincareMap
for what plane
can be (tuple or vector).
DynamicalSystemsBase.PoincareMap
— TypePoincareMap <: DiscreteTimeDynamicalSystem
PoincareMap(ds::CoupledODEs, plane; kwargs...) → pmap
A discrete time dynamical system that produces iterations over the Poincaré map[DatserisParlitz2022] of the given continuous time ds
. This map is defined as the sequence of points on the Poincaré surface of section, which is defined by the plane
argument.
See also StroboscopicMap
, poincaresos
.
Keyword arguments
direction = -1
: Only crossings withsign(direction)
are considered to belong to the surface of section. Negative direction means going from less than $b$ to greater than $b$.u0 = nothing
: Specify an initial state.rootkw = (xrtol = 1e-6, atol = 1e-8)
: ANamedTuple
of keyword arguments passed tofind_zero
from Roots.jl.Tmax = 1e3
: The argumentTmax
exists so that the integrator can terminate instead of being evolved for infinite time, to avoid cases where iteration would continue forever for ill-defined hyperplanes or for convergence to fixed points, where the trajectory would never cross again the hyperplane. If during onestep!
the system has been evolved for more thanTmax
, thenstep!(pmap)
will terminate and error.
Description
The Poincaré surface of section is defined as sequential transversal crossings a trajectory has with any arbitrary manifold, but here the manifold must be a hyperplane. PoincareMap
iterates over the crossings of the section.
If the state of ds
is $\mathbf{u} = (u_1, \ldots, u_D)$ then the equation defining a hyperplane is
\[a_1u_1 + \dots + a_Du_D = \mathbf{a}\cdot\mathbf{u}=b\]
where $\mathbf{a}, b$ are the parameters of the hyperplane.
In code, plane
can be either:
- A
Tuple{Int, <: Real}
, like(j, r)
: the plane is defined as when thej
th variable of the system equals the valuer
. - A vector of length
D+1
. The firstD
elements of the vector correspond to $\mathbf{a}$ while the last element is $b$.
PoincareMap
uses ds
, higher order interpolation from DifferentialEquations.jl, and root finding from Roots.jl, to create a high accuracy estimate of the section.
PoincareMap
follows the DynamicalSystem
interface with the following adjustments:
dimension(pmap) == dimension(ds)
, even though the Poincaré map is effectively 1 dimension less.- Like
StroboscopicMap
time is discrete and counts the iterations on the surface of section.initial_time
is always0
andcurrent_time
is current iteration number. - A new function
current_crossing_time
returns the real time corresponding to the latest crossing of the hyperplane, which is what thecurrent_state(ds)
corresponds to as well. - For the special case of
plane
being aTuple{Int, <:Real}
, a specialreinit!
method is allowed with input state of lengthD-1
instead ofD
, i.e., a reduced state already on the hyperplane that is then converted into theD
dimensional state.
Example
using DynamicalSystemsBase
ds = Systems.rikitake(zeros(3); μ = 0.47, α = 1.0)
pmap = poincaremap(ds, (3, 0.0))
step!(pmap)
next_state_on_psos = current_state(pmap)
DynamicalSystemsBase.ProjectedDynamicalSystem
— TypeProjectedDynamicalSystem <: DynamicalSystem
ProjectedDynamicalSystem(ds::DynamicalSystem, projection, complete_state)
A dynamical system that represents a projection of an existing ds
on a (projected) space.
The projection
defines the projected space. If projection isa AbstractVector{Int}
, then the projected space is simply the variable indices that projection
contains. Otherwise, projection
can be an arbitrary function that given the state of the original system ds
, returns the state in the projected space. In this case the projected space can be equal, or even higher-dimensional, than the original.
complete_state
produces the state for the original system from the projected state. complete_state
can always be a function that given the projected state returns a state in the original space. However, if projection isa AbstractVector{Int}
, then complete_state
can also be a vector that contains the values of the remaining variables of the system, i.e., those not contained in the projected space. In this case the projected space needs to be lower-dimensional than the original.
Notice that ProjectedDynamicalSystem
does not require an invertible projection, complete_state
is only used during reinit!
. ProjectedDynamicalSystem
is in fact a rather trivial wrapper of ds
which steps it as normal in the original state space and only projects as a last step, e.g., during current_state
.
Examples
Case 1: project 5-dimensional system to its last two dimensions.
ds = Systems.lorenz96(5)
projection = [4, 5]
complete_state = [0.0, 0.0, 0.0] # completed state just in the plane of last two dimensions
prods = ProjectedDynamicalSystem(ds, projection, complete_state)
reinit!(prods, [0.2, 0.4])
step!(prods)
current_state(prods)
Case 2: custom projection to general functions of state.
ds = Systems.lorenz96(5)
projection(u) = [sum(u), sqrt(u[1]^2 + u[2]^2)]
complete_state(y) = repeat([y[1]/5], 5)
prods = # same as in above example...
DynamicalSystemsBase.StroboscopicMap
— TypeStroboscopicMap <: DiscreteTimeDynamicalSystem
StroboscopicMap(ds::CoupledODEs, period::Real) → smap
StroboscopicMap(period::Real, f, u0, p = nothing; kwargs...)
A discrete time dynamical system that produces iterations of a time-dependent (non-autonomous) CoupledODEs
system exactly over a given period
. The second signature first creates a CoupledODEs
and then calls the first.
StroboscopicMap
follows the DynamicalSystem
interface. In addition, the function set_period!(smap, period)
is provided, that sets the period of the system to a new value (as if it was a parameter). As this system is in discrete time, current_time
and initial_time
are integers. The initial time is always 0, because current_time
counts elapsed periods. Call these functions on the parent
of StroboscopicMap
to obtain the corresponding continuous time. In contrast, reinit!
expects t0
in continuous time.
The convenience constructor
StroboscopicMap(T::Real, f, u0, p = nothing; diffeq, t0 = 0) → smap
is also provided.
See also PoincareMap
.
DynamicalSystemsBase.TangentDynamicalSystem
— TypeTangentDynamicalSystem <: DynamicalSystem
TangentDynamicalSystem(ds::CoreDynamicalSystem; kwargs...)
A dynamical system that bundles the evolution of ds
(which must be an CoreDynamicalSystem
) and k
deviation vectors that are evolved according to the dynamics in the tangent space (also called linearized dynamics or the tangent dynamics).
The state of ds
must be an AbstractVector
for TangentDynamicalSystem
.
TangentDynamicalSystem
follows the DynamicalSystem
interface with the following adjustments:
reinit!
takes an additional keywordQ0
(with same default as below)- The additional functions
current_deviations
andset_deviations!
are provided for the deviation vectors.
Keyword arguments
k
orQ0
:Q0
represents the initial deviation vectors (each column = 1 vector). Ifk::Int
is given, a matrixQ0
is created with the firstk
columns of the identity matrix. OtherwiseQ0
can be given directly as a matrix. It must hold thatsize(Q, 1) == dimension(ds)
. You can useorthonormal
for random orthonormal vectors. By defaultk = dimension(ds)
is used.u0 = current_state(ds)
: Starting state.J
andJ0
: See section "Jacobian" below.
Description
Let $u$ be the state of ds
, and $y$ a deviation (or perturbation) vector. These two are evolved in parallel according to
\[\begin{array}{rcl} \frac{d\vec{x}}{dt} &=& f(\vec{x}) \\ \frac{dY}{dt} &=& J_f(\vec{x}) \cdot Y \end{array} \quad \mathrm{or}\quad \begin{array}{rcl} \vec{x}_{n+1} &=& f(\vec{x}_n) \\ Y_{n+1} &=& J_f(\vec{x}_n) \cdot Y_n. \end{array}\]
for continuous or discrete time respectively. Here $f$ is the dynamic_rule
(ds)
and $J_f$ is the Jacobian of $f$.
Jacobian
The keyword J
provides the Jacobian function. It must be a Julia function in the same form as f
, the dynamic_rule
. Specifically, J(u, p, n) -> M::SMatrix
for the out-of-place version or J(M, u, p, n)
for the in-place version acting in-place on M
. In both cases M
is the Jacobian matrix used for the evolution of the deviation vectors.
By default J = nothing
. In this case J
is constructed automatically using the module ForwardDiff
, hence its limitations also apply here. Even though ForwardDiff
is very fast, depending on your exact system you might gain significant speed-up by providing a hand-coded Jacobian and so it is recommended. Additionally, automatic and in-place Jacobians cannot be time dependent.
The keyword J0
allows you to pass an initialized Jacobian matrix J0
. This is useful for large in-place systems where only a few components of the Jacobian change during the time evolution. J0
can be a sparse or any other matrix type. If not given, a matrix of zeros is used. J0
is ignored for out of place systems.
CommonSolve.step!
— Methodstep!(ds::DiscreteTimeDynamicalSystem [, n::Integer]) → ds
Evolve the discrete time dynamical system for 1 or n
steps.
step!(ds::ContinuousTimeDynamicalSystem, [, dt::Real [, stop_at_tdt]]) → ds
Evolve the continuous time dynamical system for one integration step.
Alternatively, if a dt
is given, then progress the integration until there is a temporal difference ≥ dt
(so, step at least for dt
time).
When true
is passed to the optional third argument, the integration advances for exactly dt
time.
DynamicalSystemsBase.check_hyperplane_match
— MethodEnsure hyperplane is matching with dimension D
.
DynamicalSystemsBase.current_crossing_time
— Methodcurrent_crossing_time(pmap::PoincareMap) → tcross
Return the time of the latest crossing of the Poincare section.
DynamicalSystemsBase.current_deviations
— Methodcurrent_deviations(tands::TangentDynamicalSystem)
Return the deviation vectors of tands
as a matrix with each column a vector.
DynamicalSystemsBase.current_parameter
— Functioncurrent_parameter(ds::DynamicalSystem, index [,p])
Return the specific parameter of ds
corresponding to index
, which can be anything given to set_parameter!
. p
defaults to current_parameters
and is the parameter container to extract the parameter from, which must match layout with its default value.
Use parameter_name
for an accompanying name.
DynamicalSystemsBase.current_parameters
— Methodcurrent_parameters(ds::DynamicalSystem) → p
Return the current parameter container of ds
. This is mutated in functions that need to evolve ds
across a parameter range.
See also initial_parameters
, current_parameter
, set_parameter!
.
DynamicalSystemsBase.current_state
— Methodcurrent_state(ds::DynamicalSystem) → u::AbstractArray
Return the current state of ds
. This state is mutated when ds
is mutated. See also initial_state
, observe_state
.
DynamicalSystemsBase.current_states
— Methodcurrent_states(pds::ParallelDynamicalSystem)
Return an iterator over the parallel states of pds
.
DynamicalSystemsBase.current_time
— Methodcurrent_time(ds::DynamicalSystem) → t
Return the current time that ds
is at. This is mutated when ds
is evolved.
DynamicalSystemsBase.dynamic_rule
— Methoddynamic_rule(ds::DynamicalSystem) → f
Return the dynamic rule of ds
. This is never mutated and is set when initializing ds
.
DynamicalSystemsBase.initial_parameters
— Methodinitial_parameters(ds::DynamicalSystem) → p0
Return the initial parameter container of ds
. This is never mutated and is set when initializing ds
.
DynamicalSystemsBase.initial_state
— Methodinitial_state(ds::DynamicalSystem) → u0
Return the initial state of ds
. This state is never mutated and is set when initializing ds
.
DynamicalSystemsBase.initial_states
— Methodinitial_states(pds::ParallelDynamicalSystem)
Return an iterator over the initial parallel states of pds
.
DynamicalSystemsBase.initial_time
— Methodinitial_time(ds::DynamicalSystem) → t0
Return the initial time defined for ds
. This is never mutated and is set when initializing ds
.
DynamicalSystemsBase.isdeterministic
— Methodisdeterministic(ds::DynamicalSystem) → true/false
Return true
if ds
is deterministic, i.e., the dynamic rule contains no randomness. This is information deduced from the type of ds
.
DynamicalSystemsBase.isdiscretetime
— Methodisdiscretetime(ds::DynamicalSystem) → true/false
Return true
if ds
operates in discrete time, or false
if it is in continuous time. This is information deduced from the type of ds
.
DynamicalSystemsBase.jacobian
— Methodjacobian(ds::CoreDynamicalSystem)
Construct the Jacobian rule for the dynamical system ds
. This is done via automatic differentiation using module ForwardDiff
.
Description
For out-of-place systems, jacobian
returns the Jacobian rule as a function Jf(u, p, t) -> J0::SMatrix
. Calling Jf(u, p, t)
will compute the Jacobian at the state u
, parameters p
and time t
and return the result as J0
. For in-place systems, jacobian
returns the Jacobian rule as a function Jf!(J0, u, p, t)
. Calling Jf!(J0, u, p, t)
will compute the Jacobian at the state u
, parameters p
and time t
and save the result in J0
.
DynamicalSystemsBase.observe_state
— Functionobserve_state(ds::DynamicalSystem, i, u = current_state(ds)) → x::Real
Return the state u
of ds
observed at "index" i
. Possibilities are:
i::Int
returns thei
-th dynamic variable.i::Function
returnsf(current_state(ds))
.i::SymbolLike
returns the value of the corresponding symbolic variable. This is valid only for dynamical systems referrencing a ModelingToolkit.jl model which also hasi
as one of its listed variables (either uknowns or observed). Herei
can be anything can be anything that could index the solution objectsol = ModelingToolkit.solve(...)
, such as aNum
orSymbol
instance with the name of the symbolic variable. In this case, a last fourth optional positional argumentt
defaults tocurrent_time(ds)
and is the time to observe the state at.- Any symbolic expression involving variables present in the symbolic variables tracked by the system, e.g.,
i = x^2 - y
withx, y
symbolic variables.
For ProjectedDynamicalSystem
, this function assumes that the state of the system is the full state space state, not the projected one (this makes the most sense for allowing MTK-based indexing).
Use state_name
for an accompanying name.
DynamicalSystemsBase.parameter_name
— Methodparameter_name(index)::String
Return a name that matches the outcome of current_parameter
with index
.
DynamicalSystemsBase.poincare_step!
— Methodpoincare_step!(integ, plane_distance, planecrossing, Tmax, rootkw)
Low level function that actually performs the algorithm of finding the next crossing of the Poincaré surface of section. Return the state and time at the section or nothing
if evolved for more than Tmax
without any crossing.
DynamicalSystemsBase.poincaresos
— Functionpoincaresos(ds::CoupledODEs, plane, T = 1000.0; kwargs...) → P::StateSpaceSet
Return the iterations of ds
on the Poincaré surface of section with the plane
, by evolving ds
up to a total of T
. Return a StateSpaceSet
of the points that are on the surface of section.
This function initializes a PoincareMap
and steps it until its current_crossing_time
exceeds T
. You can also use trajectory
with PoincareMap
to get a sequence of N::Int
points instead.
The keywords Ttr, save_idxs
act as in trajectory
. See PoincareMap
for plane
and all other keywords.
DynamicalSystemsBase.poincaresos
— Methodpoincaresos(A::AbstractStateSpaceSet, plane; kwargs...) → P::StateSpaceSet
Calculate the Poincaré surface of section of the given dataset with the given plane
by performing linear interpolation betweeen points that sandwich the hyperplane.
Argument plane
and keywords direction, warning, save_idxs
are the same as in PoincareMap
.
DynamicalSystemsBase.referrenced_sciml_model
— Methodreferrenced_sciml_model(ds::DynamicalSystem)
Return the ModelingToolkit.jl structurally-simplified model referrenced by ds
. Return nothing
if there is no referrenced model.
DynamicalSystemsBase.set_deviations!
— Methodset_deviations!(tands::TangentDynamicalSystem, Q)
Set the deviation vectors of tands
to be Q
, a matrix with each column a vector.
DynamicalSystemsBase.set_parameter!
— Functionset_parameter!(ds::DynamicalSystem, index, value [, p])
Change a parameter of ds
given the index
it has in the parameter container and the value
to set it to. This function works for any type of parameter container (array/dictionary/composite types) provided the index
is appropriate type.
The index
can be a traditional Julia index (integer for arrays, key for dictionaries, or symbol for composite types). It can also be a symbolic variable or Symbol
instance. This is valid only for dynamical systems referring a ModelingToolkit.jl model which also has index
as one of its parameters.
The last optional argument p
defaults to current_parameters
and is the parameter container whose value is changed at the given index. It must match layout with its default value.
DynamicalSystemsBase.set_parameters!
— Functionset_parameters!(ds::DynamicalSystem, p = initial_parameters(ds))
Set the parameter values in the current_parameters
(ds)
to match those in p
. This is done as an in-place overwrite by looping over the keys of p
hence p
can be an arbitrary container mapping parameter indices to values (such as a Vector{Real}
, Vector{Pair}
, or AbstractDict
).
The keys of p
must be valid keys that can be given to set_parameter!
.
DynamicalSystemsBase.set_state!
— Methodset_state!(ds::DynamicalSystem, u::AbstractArray{Real})
Set the state of ds
to u
, which must match dimensionality with that of ds
. Also ensure that the change is notified to whatever integration protocol is used.
DynamicalSystemsBase.set_state!
— Methodset_state!(ds::DynamicalSystem, mapping::AbstractDict)
Convenience version of set_state!
that iteratively calls set_state!(ds, val, i)
for all index-value pairs (i, val)
in mapping
. This allows you to partially set only some state variables.
DynamicalSystemsBase.set_state!
— Methodset_state!(ds::DynamicalSystem, value::Real, i) → u
Set the i
th variable of ds
to value
. The index i
can be an integer or a symbolic-like index for systems that reference a ModelingToolkit.jl model. For example:
i = :x # or `1` or `only(@variables(x))`
set_state!(ds, 0.5, i)
Warning: this function should not be used with derivative dynamical systems such as Poincare/stroboscopic/projected dynamical systems. Use the method below to manipulate an array and give that to set_state!
.
set_state!(u::AbstractArray, value, index, ds::DynamicalSystem)
Modify the given state u
and leave ds
untouched.
DynamicalSystemsBase.state_name
— Methodstate_name(index)::String
Return a name that matches the outcome of observe_state
with index
.
DynamicalSystemsBase.subscript
— Methodsubscript(i::Int)
Transform i
to a string that has i
as a subscript.
DynamicalSystemsBase.successful_step
— Methodsuccessful_step(ds::DynamicalSystem) -> true/false
Return true
if the last step!
call to ds
was successful, false
otherwise. For continuous time systems this uses DifferentialEquations.jl error checking, for discrete time it checks if any variable is Inf
or NaN
.
DynamicalSystemsBase.trajectory
— Functiontrajectory(ds::DynamicalSystem, T [, u0]; kwargs...) → X, t
Evolve ds
for a total time of T
and return its trajectory X
, sampled at equal time intervals, and corresponding time vector. Optionally provide a starting state u0
which is current_state(ds)
by default.
The returned time vector is t = (t0+Ttr):Δt:(t0+Ttr+T)
.
If time evolution diverged before T
, the remaining of the trajectory is set to the last valid point.
trajectory
is a very simple function provided for convenience. For continuous time systems, it doesn't play well with callbacks, use DifferentialEquations.solve
if you want a trajectory/timeseries that works with callbacks.
Keyword arguments
Δt
: Time step of value output. For discrete time systems it must be an integer. Defaults to0.1
for continuous and1
for discrete time systems. If you don't have access to unicode, the keywordDt
can be used instead.Ttr = 0
: Transient time to evolve the initial state before starting saving states.t0 = initial_time(ds)
: Starting time.save_idxs::AbstractVector
: Which variables to output inX
. It can be any type of index that can be given toobserve_state
. Defaults to1:dimension(ds)
(all dynamic variables). Note: if you mix integer and symbolic indexing be sure to initialize the array asAny
so that integers1, 2, ...
are not converted to symbolic expressions.
SciMLBase.isinplace
— Methodisinplace(ds::DynamicalSystem) → true/false
Return true
if the dynamic rule of ds
is in-place, i.e., a function mutating the state in place. If true
, the state is typically Array
, if false
, the state is typically SVector
. A front-end user will most likely not care about this information, but a developer may care.
SciMLBase.reinit!
— Methodreinit!(ds::DynamicalSystem, u = initial_state(ds); kwargs...) → ds
Reset the status of ds
, so that it is as if it has be just initialized with initial state u
. Practically every function of the ecosystem that evolves ds
first calls this function on it. Besides the new state u
, you can also configure the keywords t0 = initial_time(ds)
and p = current_parameters(ds)
.
reinit!(ds::DynamicalSystem, u::AbstractDict; kwargs...) → ds
If u
is a AbstractDict
(for partially setting specific state variables in set_state!
), then the alterations are done in the state given by the keyword reference_state = copy(initial_state(ds))
.
reinit!(ds, ::Nothing; kwargs...)
This method does nothing and leaves the system as is. This is so that downstream functions that call reinit!
can still be used without resetting the system but rather continuing from its exact current state.
- DatserisParlitz2022Datseris & Parlitz 2022, Nonlinear Dynamics: A Concise Introduction Interlaced with Code, Springer Nature, Undergrad. Lect. Notes In Physics