Skip to content

dq.solver.Kvaerno3

Kvaerno3(
    rtol: float = 1e-06,
    atol: float = 1e-06,
    safety_factor: float = 0.9,
    min_factor: float = 0.2,
    max_factor: float = 5.0,
    max_steps: int = 100000,
)

Kvaerno's method of order 3 (adaptive step size and implicit ODE solver).

This method is suitable for stiff problems, typically those with Hamiltonians or Liouvillians that have eigenvalues spanning different orders of magnitudes. This is for instance the case with problems involving high-order polynomials of the bosonic annihilation and creation operators, in large dimensions.

This solver is implemented by the Diffrax library, see diffrax.Kvaerno3.

Warning

If you find that your simulation is slow or that the progress bar gets stuck, consider switching to double-precision with dq.set_precision('double'). See more details in The sharp bits 🔪 tutorial.

Parameters

  • rtol –

    Relative tolerance.

  • atol –

    Absolute tolerance.

  • safety_factor –

    Safety factor for adaptive step sizing.

  • min_factor –

    Minimum factor for adaptive step sizing.

  • max_factor –

    Maximum factor for adaptive step sizing.

  • max_steps –

    Maximum number of steps.

Supported gradients

This solver supports differentiation with dq.gradient.Autograd and dq.gradient.CheckpointAutograd (default).