nag_ode_ivp_rk_interp_setup (d02phc) is a reverse communication function that computes the interpolant for evaluation by
nag_ode_ivp_rk_interp_eval (d02pjc) anywhere on an integration step taken by
nag_ode_ivp_rk_step_revcomm (d02pgc). The direct communication version of the
nag_ode_ivp_rk_interp_setup (d02phc) and
nag_ode_ivp_rk_interp_eval (d02pjc) pair is
nag_ode_ivp_rkts_interp (d02psc). A significant difference in functionality between the forward and reverse communication versions is that
nag_ode_ivp_rk_interp_setup (d02phc) and
nag_ode_ivp_rk_interp_eval (d02pjc) can interpolate for the highorder Runge–Kutta method.
nag_ode_ivp_rk_interp_setup (d02phc) and its associated functions (
nag_ode_ivp_rk_step_revcomm (d02pgc),
nag_ode_ivp_rk_interp_eval (d02pjc),
nag_ode_ivp_rkts_setup (d02pqc),
nag_ode_ivp_rkts_reset_tend (d02prc),
nag_ode_ivp_rkts_diag (d02ptc) and
nag_ode_ivp_rkts_errass (d02puc)) solve the initial value problem for a firstorder system of ordinary differential equations. The functions, based on Runge–Kutta methods and derived from RKSUITE (see
Brankin et al. (1991)), integrate
where
$y$ is the vector of
$\mathit{n}$ solution components and
$t$ is the independent variable.
nag_ode_ivp_rk_step_revcomm (d02pgc) computes the solution at the end of an integration step. Using the information computed on that step
nag_ode_ivp_rk_interp_setup (d02phc) computes the interpolant which can be evaluated at any point on that step by
nag_ode_ivp_rk_interp_eval (d02pjc). If
${\mathbf{method}}=\mathrm{Nag\_RK\_2\_3}$ then there is enough information available from the stages of the last step to provide an interpolant of sufficient order of accuracy; no further derivative evaluations will therefore be requested. If
${\mathbf{method}}=\mathrm{Nag\_RK\_4\_5}$ then the interpolant is an order
$8$ continuous Runge–Kutta process that requires a further
$3$ stages of derivative evaluations that will be requested in turn before a final exit. If
${\mathbf{method}}=\mathrm{Nag\_RK\_7\_8}$ was specified in the call to setup function
nag_ode_ivp_rkts_setup (d02pqc) then the interpolant is a continuous Runge–Kutta process requiring a further
$7$ stages of derivative evaluations that will be requested in turn.
Brankin R W, Gladwell I and Shampine L F (1991) RKSUITE: A suite of Runge–Kutta codes for the initial value problems for ODEs SoftReport 91S1 Southern Methodist University
Note: this function uses
reverse communication. Its use involves an initial entry, intermediate exits and reentries, and a final exit, as indicated by the argument
irevcm. Between intermediate exits and reentries,
all arguments other than those specified by the value of irevcm must remain unchanged.
 NE_ALLOC_FAIL

Dynamic memory allocation failed.
See
Section 2.3.1.2 in How to Use the NAG Library and its Documentation for further information.
 NE_BAD_PARAM

On entry, argument $\u2329\mathit{\text{value}}\u232a$ had an illegal value.
 NE_INT

On entry, ${\mathbf{lwcomm}}=\u2329\mathit{\text{value}}\u232a$.
Constraint: for ${\mathbf{method}}=\mathrm{Nag\_RK\_2\_3}$, ${\mathbf{lwcomm}}\ge 1$.
 NE_INT_2

On entry, ${\mathbf{lwcomm}}=\u2329\mathit{\text{value}}\u232a$ and ${\mathbf{nwant}}=\u2329\mathit{\text{value}}\u232a$.
Constraint: for ${\mathbf{method}}=\mathrm{Nag\_RK\_7\_8}$, ${\mathbf{lwcomm}}\ge 8\times {\mathbf{nwant}}$.
On entry, ${\mathbf{nwant}}=\u2329\mathit{\text{value}}\u232a$ and ${\mathbf{n}}=\u2329\mathit{\text{value}}\u232a$.
Constraint: $1\le {\mathbf{nwant}}\le {\mathbf{n}}$.
 NE_INT_3

On entry, ${\mathbf{lwcomm}}=\u2329\mathit{\text{value}}\u232a$, ${\mathbf{n}}=\u2329\mathit{\text{value}}\u232a$ and ${\mathbf{nwant}}=\u2329\mathit{\text{value}}\u232a$.
Constraint: for ${\mathbf{method}}=\mathrm{Nag\_RK\_4\_5}$, ${\mathbf{lwcomm}}\ge {\mathbf{n}}+\mathrm{max}\phantom{\rule{0.125em}{0ex}}\left({\mathbf{n}},5\times {\mathbf{nwant}}\right)$.
 NE_INT_CHANGED

On entry, ${\mathbf{n}}=\u2329\mathit{\text{value}}\u232a$, but the value passed to the setup function was ${\mathbf{n}}=\u2329\mathit{\text{value}}\u232a$.
 NE_INTERNAL_ERROR

An internal error has occurred in this function. Check the function call and any array sizes. If the call is correct then please contact
NAG for assistance.
See
Section 2.7.6 in How to Use the NAG Library and its Documentation for further information.
 NE_MISSING_CALL

On entry, a previous call to the setup function has not been made or the communication arrays have become corrupted, or a catastrophic error has already been detected elsewhere.
You cannot continue integrating the problem.
You cannot call this function before you have called the step integrator.
 NE_NO_LICENCE

Your licence key may have expired or may not have been installed correctly.
See
Section 2.7.5 in How to Use the NAG Library and its Documentation for further information.
 NE_PREV_CALL_INI

You cannot call this function after the integrator has returned an error.
 NE_RK_INVALID_CALL

You cannot call this function after the range integrator has been called.
The computed values will be of a similar accuracy to that computed by
nag_ode_ivp_rk_step_revcomm (d02pgc).
Please consult the
x06 Chapter Introduction for information on how to control and interrogate the OpenMP environment used within this function. Please also consult the
Users' Note for your implementation for any additional implementationspecific information.
None.