module Quadrature:sig
..end
Support for backward quadrature equations that may or may not depend on forward sensitivities.
type 'd
bquadrhsfn_args = {
|
t : |
(* | The value of the independent variable. | *) |
|
y : |
(* | The vector of dependent-variable values $y(t)$. | *) |
|
y' : |
(* | The vector of dependent-variable derivatives $\dot{y}(t)$ . | *) |
|
yb : |
(* | The vector of backward dependent-variable values $y_B(t)$. | *) |
|
yb' : |
(* | The vector of backward dependent-variable derivatives $\dot{y}_B(t)$ . | *) |
}
Arguments common to Idas.Adjoint.Quadrature.bquadrhsfn_no_sens
and
Idas.Adjoint.Quadrature.bquadrhsfn_with_sens
.
type'd
bquadrhsfn_no_sens ='d bquadrhsfn_args -> 'd -> unit
Functions defining backward quadrature variables without forward sensitivities. They are passed the arguments:
args
, the current values of forward and backward state
variables, and,qb'
, a vector for storing the computed value of
$\dot{y}_\mathit{BQ} =
f_\mathit{BQ}(t, y, \dot{y}, y_B, \dot{y}_B)$.Within the function, raising a Sundials.RecoverableFailure
exception indicates a recoverable error. Any other exception is
treated as an unrecoverable error.
type'd
bquadrhsfn_with_sens ='d bquadrhsfn_args ->
'd array -> 'd array -> 'd -> unit
Functions defining backward quadrature variables that depend on forward sensitivities. They are passed the arguments:
args
, current values of forward and backward state variables,s
, the array of forward sensitivity vectors,s'
, the array of forward sensitivity derivative vectors, and,qb'
, a vector for storing the computed value of
$\dot{y}_\mathit{BQ} =
f_\mathit{BQ}(t, y, \dot{y}, s, \dot{s}, y_B, \dot{y}_B)$.Within the function, raising a Sundials.RecoverableFailure
exception indicates a recoverable error. Any other exception is
treated as an unrecoverable error.
type 'd
bquadrhsfn =
| |
NoSens of |
(* | Does not depend on forward sensitivities. | *) |
| |
WithSens of |
(* | Depends on forward sensitivities. | *) |
These functions compute the quadrature equation right-hand side for the backward problem.
val init : ('d, 'k) Idas.Adjoint.bsession ->
'd bquadrhsfn -> ('d, 'k) Nvector.t -> unit
This function activates the integration of quadrature equations.
The arguments are the function that computes the right-hand side of
the backward quadrature equations, and a vector giving the values
of the quadrature variables at tB0
.
val reinit : ('d, 'k) Idas.Adjoint.bsession -> ('d, 'k) Nvector.t -> unit
This function reinitializes the integration of quadrature equations during the backward phase.
type ('d, 'k)
tolerance =
| |
NoStepSizeControl |
(* | Quadrature variables are not used for step-size control (the default). | *) |
| |
SStolerances of |
(* |
| *) |
| |
SVtolerances of |
(* |
| *) |
Tolerances for calculating backward quadrature variables.
val set_tolerances : ('d, 'k) Idas.Adjoint.bsession ->
('d, 'k) tolerance -> unit
Specify how to use quadrature variables in step size control.
val get : ('d, 'k) Idas.Adjoint.bsession -> ('d, 'k) Nvector.t -> float
Returns the backward quadrature solutions and time reached
after a successful solver step. The given vectors are filled with
values calculated during either Idas.Adjoint.backward_normal
or
Idas.Adjoint.backward_one_step
and the value of the independent variable
is returned.
val get_num_rhs_evals : ('d, 'k) Idas.Adjoint.bsession -> int
Returns the number of calls to the backward quadrature right-hand side function.
val get_num_err_test_fails : ('d, 'k) Idas.Adjoint.bsession -> int
Returns the number of local error test failures due to quadrature variables.
val get_err_weights : ('d, 'k) Idas.Adjoint.bsession -> ('d, 'k) Nvector.t -> unit
Returns the quadrature error weights at the current time.
val get_stats : ('d, 'k) Idas.Adjoint.bsession -> int * int
Returns quadrature-related statistics. These are the
number of calls to the quadrature function (nfqevals
) and the
number of error test failures due to quadrature variables
(nqetfails
).
nfqevals
, nqetfails
)