sig
val dense :
?context:Sundials.Context.t ->
([> Nvector_serial.kind ] as 'a) Nvector.serial ->
'a Sundials.Matrix.dense ->
(Sundials.Matrix.Dense.t, 'a, [ `Dls ]) Sundials_LinearSolver.serial_t
val lapack_dense :
?context:Sundials.Context.t ->
([> Nvector_serial.kind ] as 'a) Nvector.serial ->
'a Sundials.Matrix.dense ->
(Sundials.Matrix.Dense.t, 'a, [ `Dls ]) Sundials_LinearSolver.serial_t
val band :
?context:Sundials.Context.t ->
([> Nvector_serial.kind ] as 'a) Nvector.serial ->
'a Sundials.Matrix.band ->
(Sundials.Matrix.Band.t, 'a, [ `Dls ]) Sundials_LinearSolver.serial_t
val lapack_band :
?context:Sundials.Context.t ->
([> Nvector_serial.kind ] as 'a) Nvector.serial ->
'a Sundials.Matrix.band ->
(Sundials.Matrix.Band.t, 'a, [ `Dls ]) Sundials_LinearSolver.serial_t
module Klu :
sig
type ordering =
Sundials_LinearSolver_impl.Klu.ordering =
Amd
| ColAmd
| Natural
val make :
?context:Sundials.Context.t ->
?ordering:ordering ->
([> Nvector_serial.kind ] as 'a) Nvector.serial ->
('s, 'a) Sundials.Matrix.sparse ->
('s Sundials.Matrix.Sparse.t, 'a, [ `Dls | `Klu ])
Sundials_LinearSolver.serial_t
val reinit :
('s Sundials.Matrix.Sparse.t, [> Nvector_serial.kind ] as 'a,
[> `Klu ])
Sundials_LinearSolver.serial_t ->
('s, 'a) Sundials.Matrix.sparse -> ?nnz:int -> unit -> unit
val set_ordering :
('s Sundials.Matrix.Sparse.t, [> Nvector_serial.kind ], [> `Klu ])
Sundials_LinearSolver.serial_t -> ordering -> unit
end
val klu :
?context:Sundials.Context.t ->
?ordering:Klu.ordering ->
([> Nvector_serial.kind ] as 'a) Nvector.serial ->
('s, 'a) Sundials.Matrix.sparse ->
('s Sundials.Matrix.Sparse.t, 'a, [ `Dls | `Klu ])
Sundials_LinearSolver.serial_t
module Superlumt :
sig
type ordering =
Sundials_LinearSolver_impl.Superlumt.ordering =
Natural
| MinDegreeProd
| MinDegreeSum
| ColAmd
val make :
?context:Sundials.Context.t ->
?ordering:ordering ->
nthreads:int ->
([> Nvector_serial.kind ] as 'a) Nvector.serial ->
('s, 'a) Sundials.Matrix.sparse ->
('s Sundials.Matrix.Sparse.t, 'a, [ `Dls | `Slu ])
Sundials_LinearSolver.serial_t
val set_ordering :
('s Sundials.Matrix.Sparse.t, [> Nvector_serial.kind ], [> `Slu ])
Sundials_LinearSolver.serial_t -> ordering -> unit
end
val superlumt :
?context:Sundials.Context.t ->
?ordering:Superlumt.ordering ->
nthreads:int ->
([> Nvector_serial.kind ] as 'a) Nvector.serial ->
('s, 'a) Sundials.Matrix.sparse ->
('s Sundials.Matrix.Sparse.t, 'a, [> `Dls | `Slu ])
Sundials_LinearSolver.serial_t
type 'm jac_fn_no_sens =
(Sundials.RealArray.t Cvodes.Adjoint.triple, Sundials.RealArray.t)
Cvodes.Adjoint.jacobian_arg -> 'm -> unit
type 'm jac_fn_with_sens =
(Sundials.RealArray.t Cvodes.Adjoint.triple, Sundials.RealArray.t)
Cvodes.Adjoint.jacobian_arg -> Sundials.RealArray.t array -> 'm -> unit
type 'm jac_fn =
NoSens of 'm Cvodes.Adjoint.Dls.jac_fn_no_sens
| WithSens of 'm Cvodes.Adjoint.Dls.jac_fn_with_sens
type 'm linsys_fn_no_sens =
(Sundials.RealArray.t Cvodes.Adjoint.triple, Sundials.RealArray.t)
Cvodes.Adjoint.jacobian_arg -> 'm -> bool -> float -> bool
type 'm linsys_fn_with_sens =
(Sundials.RealArray.t Cvodes.Adjoint.triple, Sundials.RealArray.t)
Cvodes.Adjoint.jacobian_arg ->
Sundials.RealArray.t array -> 'm -> bool -> float -> bool
type 'm linsys_fn =
LNoSens of 'm Cvodes.Adjoint.Dls.linsys_fn_no_sens
| LWithSens of 'm Cvodes.Adjoint.Dls.linsys_fn_with_sens
val solver :
?jac:'m Cvodes.Adjoint.Dls.jac_fn ->
?linsys:'m Cvodes.Adjoint.Dls.linsys_fn ->
('m, Sundials.RealArray.t, [> Nvector_serial.kind ] as 'a, 't)
Sundials.LinearSolver.t -> 'a Cvodes.Adjoint.serial_linear_solver
val get_work_space :
[> Nvector_serial.kind ] Cvodes.Adjoint.serial_bsession -> int * int
val get_num_jac_evals :
[> Nvector_serial.kind ] Cvodes.Adjoint.serial_bsession -> int
val get_num_lin_rhs_evals :
[> Nvector_serial.kind ] Cvodes.Adjoint.serial_bsession -> int
end