qiskit_dynamics.solvers.solve_lmde#
- solve_lmde(generator, t_span, y0, method='DOP853', t_eval=None, **kwargs)[source]#
General interface for solving Linear Matrix Differential Equations (LMDEs) in standard form.
LMDEs in standard form are differential equations of the form:
\[\dot{y}(t) = G(t)y(t).\]where \(G(t)\) is a square matrix valued-function called the generator, and \(y(t)\) is an
Array
of appropriate shape.Thus function accepts \(G(t)\) as a
qiskit_dynamics
model class, or as an arbitrary callable.Note
Not all model classes are by-default in standard form. E.g.
LindbladModel
represents an LMDE which is not typically written in standard form. As such, using LMDE-specific methods with this generator requires setting a vectorized evaluation mode.The
method
argument exposes solvers specialized to both LMDEs, as well as general ODE solvers. If the method is not specific to LMDEs, the problem will be passed tosolve_ode()
by automatically setting up the RHS function \(f(t, y) = G(t)y\).Optional arguments for any of the solver routines can be passed via
kwargs
. Available LMDE-specific methods are:'scipy_expm'
: A fixed-step matrix-exponential solver usingscipy.linalg.expm
. Requires additional kwargmax_dt
indicating the maximum step size to take. This solver will break integration periods into even sub-intervals no larger thanmax_dt
and solve over each sub-interval. The optional kwargmagnus_order
controls the integration rule: ifmagnus_order==1
, the generator is sampled at the interval midpoint and exponentiated, and ifmagnus_order==2
ormagnus_order==3
, higher-order exponentiation rules are adopted from [1]. Themagnus_order
parameter defaults to1
.'lanczos_diag'
: A fixed-step matrix-exponential solver, similar to'scipy_expm'
but restricted to anti-Hermitian generators. The matrix exponential is performed by diagonalizing an approximate projection of the generator to a small subspace (the Krylov Subspace), obtained via the Lanczos algorithm, and then exponentiating the eigenvalues. Requires additional kwargsmax_dt
andk_dim
indicating the maximum step size to take and Krylov subspace dimension, respectively.k_dim
acts as an adjustable accuracy parameter and can be no larger than the dimension of the generator. The method is recommended for sparse systems with large dimension.'jax_lanczos_diag'
: JAX implementation of'lanczos_diag'
, with the same arguments and behaviour. Note that this method contains calls tojax.numpy.eigh
, which may have limited validity when automatically differentiated.'jax_expm'
: JAX-implemented version of'scipy_expm'
, with the same arguments and behaviour. Note that this method cannot be used for a model in sparse evaluation mode.'jax_expm_parallel'
: Same as'jax_expm'
, however all loops are implemented using parallel operations. I.e. all matrix-exponentials for taking a single step are computed in parallel usingjax.vmap
, and are subsequently multiplied together in parallel usingjax.lax.associative_scan
. This method is only recommended for use with GPU execution. Note that this method cannot be used for a model in sparse evaluation mode.'jax_RK4_parallel'
: 4th order Runge-Kutta fixed step solver. Under the assumption of the structure of an LMDE, utilizes the same parallelization approach as'jax_expm_parallel'
, however the single step rule is the standard 4th order Runge-Kutta rule, rather than matrix-exponentiation. Requires and utilizes themax_dt
kwarg in the same manner asmethod='scipy_expm'
. This method is only recommended for use with GPU execution.
Results are returned as a
OdeResult
object.- Parameters:
generator (
Union
[Callable
,BaseGeneratorModel
]) – Representation of generator function \(G(t)\).t_span (
Array
) –Tuple
or list of initial and final time.y0 (
Array
) – State at initial time.method (
Union
[str
,OdeSolver
,TypeVar
(AbstractSolver
),None
]) – Solving method to use.t_eval (
Union
[List
,Tuple
,Array
,None
]) – Times at which to return the solution. Must lie withint_span
. If unspecified, the solution will be returned at the points int_span
.**kwargs – Additional arguments to pass to the solver.
- Returns:
Results object.
- Return type:
OdeResult
- Raises:
QiskitError – If specified method does not exist, if dimension of
y0
is incompatible with generator dimension, or if an LMDE-specific method is passed with a LindbladModel.
- Additional Information:
While all
BaseGeneratorModel
subclasses represent LMDEs, they are not all in standard form by defualt. Using an LMDE-specific models likeLindbladModel
requires first setting a vectorized evaluation mode.