Skip to content

Wrong lyapunov exponent of unstable systems when the solver works adaptively #309

@mapi1

Description

@mapi1

Describe the bug
I was testing the lyapunov() function for the simple exponential function dx/dt = ax as I know it has to be a in this case. Tough, just using the function gives some interesting results whenT > 1 is set:
Screenshot from 2023-06-16 13-31-01

Debugging a little I found that the problem might be related to the adaptiveness of the solver leading to large time steps and therefore wrong results after rescaling took place. Setting diffeq = (alg = Tsit5(), adaptive = false, dt = 1.0) gives correct results:
Screenshot from 2023-06-16 14-17-12

Maybe it is not so relevant for more complex problems, but would it be reasonable to reset the step size after rescaling took place?

Minimal Working Example

using DynamicalSystems
using ChaosTools
using OrdinaryDiffEq
using GLMakie

function sys(du, u, p, t)
    a = p[1]
    du[1] = a * u[1]
end

function simple(u0=[0.0]; a=0.0)
    # return CoupledODEs(sys, u0, [a]) # wrong
    return CoupledODEs(sys, u0, [a], diffeq = (alg = Tsit5(), adaptive = false, dt = 1.0)) # correct
end

ds = simple(; a = -1.0)

a_values = -1.0:0.025:1.0
λs = zeros(length(a_values), 4)

for i in eachindex(a_values)
    system = deepcopy(ds)
    set_parameter!(system, 1, a_values[i])
    λs[i, 1] = lyapunov(system, 1; Ttr = 0, u0 = 0.0)
    λs[i, 2] = lyapunov(system, 2; Ttr = 0, u0 = 0.0)
    λs[i, 3] = lyapunov(system, 50; Ttr = 0, u0 = 0.0)
    λs[i, 4] = lyapunov(system, 500; Ttr = 0, u0 = 0.0)
end

fig = Figure(fontsize = 25, dpi = 400)
ax = Axis(fig[1,1]; xlabel = L"a", ylabel = L"\lambda", title = L"\dot{x} = ax")
lins = [lines!(ax, a_values, λs[:, j], linewidth = 3) for j in 1:size(λs, 2)]
Legend(fig[1, 2], lins, ["T = $j" for j in [1,2,50,500]])
fig

Package versions

With Julia v1.9.0:

  [608a59af] ChaosTools v3.0.2
⌃ [61744808] DynamicalSystems v3.0.0
⌃ [e9467ef8] GLMakie v0.8.2
⌃ [1dea7af3] OrdinaryDiffEq v6.41.0

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions