NAG CL Interface
d05bdc (abel2_​weak)

Settings help

CL Name Style:


1 Purpose

d05bdc computes the solution of a weakly singular nonlinear convolution Volterra–Abel integral equation of the second kind using a fractional Backward Differentiation Formulae (BDF) method.

2 Specification

#include <nag.h>
void  d05bdc (
double (*ck)(double t, Nag_Comm *comm),
double (*cf)(double t, Nag_Comm *comm),
double (*cg)(double s, double y, Nag_Comm *comm),
Nag_WeightMode wtmode, Integer iorder, double tlim, double tolnl, Integer nmesh, double yn[], double rwsav[], Integer lrwsav, Nag_Comm *comm, NagError *fail)
The function may be called by the names: d05bdc or nag_inteq_abel2_weak.

3 Description

d05bdc computes the numerical solution of the weakly singular convolution Volterra–Abel integral equation of the second kind
y(t) = f(t) + 1π 0t k(t-s) t-s g (s,y(s)) ds ,   0tT . (1)
Note the constant 1π in (1). It is assumed that the functions involved in (1) are sufficiently smooth.
The function uses a fractional BDF linear multi-step method to generate a family of quadrature rules (see d05byc). The BDF methods available in d05bdc are of orders 4, 5 and 6 (=p say). For a description of the theoretical and practical background to these methods we refer to Lubich (1985) and to Baker and Derakhshan (1987) and Hairer et al. (1988) respectively.
The algorithm is based on computing the solution y(t) in a step-by-step fashion on a mesh of equispaced points. The size of the mesh is given by T/(N-1), N being the number of points at which the solution is sought. These methods require 2p-1 (including y(0)) starting values which are evaluated internally. The computation of the lag term arising from the discretization of (1) is performed by fast Fourier transform (FFT) techniques when N>32+2p-1, and directly otherwise. The function does not provide an error estimate and you are advised to check the behaviour of the solution with a different value of N. An option is provided which avoids the re-evaluation of the fractional weights when d05bdc is to be called several times (with the same value of N) within the same program unit with different functions.

4 References

Baker C T H and Derakhshan M S (1987) FFT techniques in the numerical solution of convolution equations J. Comput. Appl. Math. 20 5–24
Hairer E, Lubich Ch and Schlichte M (1988) Fast numerical solution of weakly singular Volterra integral equations J. Comput. Appl. Math. 23 87–98
Lubich Ch (1985) Fractional linear multistep methods for Abel–Volterra integral equations of the second kind Math. Comput. 45 463–469

5 Arguments

1: ck function, supplied by the user External Function
ck must evaluate the kernel k(t) of the integral equation (1).
The specification of ck is:
double  ck (double t, Nag_Comm *comm)
1: t double Input
On entry: t, the value of the independent variable.
2: comm Nag_Comm *
Pointer to structure of type Nag_Comm; the following members are relevant to ck.
userdouble *
iuserInteger *
pPointer 
The type Pointer will be void *. Before calling d05bdc you may allocate memory and initialize these pointers with various quantities for use by ck when called from d05bdc (see Section 3.1.1 in the Introduction to the NAG Library CL Interface).
Note: ck should not return floating-point NaN (Not a Number) or infinity values, since these are not handled by d05bdc. If your code inadvertently does return any NaNs or infinities, d05bdc is likely to produce unexpected results.
2: cf function, supplied by the user External Function
cf must evaluate the function f(t) in (1).
The specification of cf is:
double  cf (double t, Nag_Comm *comm)
1: t double Input
On entry: t, the value of the independent variable.
2: comm Nag_Comm *
Pointer to structure of type Nag_Comm; the following members are relevant to cf.
userdouble *
iuserInteger *
pPointer 
The type Pointer will be void *. Before calling d05bdc you may allocate memory and initialize these pointers with various quantities for use by cf when called from d05bdc (see Section 3.1.1 in the Introduction to the NAG Library CL Interface).
Note: cf should not return floating-point NaN (Not a Number) or infinity values, since these are not handled by d05bdc. If your code inadvertently does return any NaNs or infinities, d05bdc is likely to produce unexpected results.
3: cg function, supplied by the user External Function
cg must evaluate the function g(s,y(s)) in (1).
The specification of cg is:
double  cg (double s, double y, Nag_Comm *comm)
1: s double Input
On entry: s, the value of the independent variable.
2: y double Input
On entry: the value of the solution y at the point s.
3: comm Nag_Comm *
Pointer to structure of type Nag_Comm; the following members are relevant to cg.
userdouble *
iuserInteger *
pPointer 
The type Pointer will be void *. Before calling d05bdc you may allocate memory and initialize these pointers with various quantities for use by cg when called from d05bdc (see Section 3.1.1 in the Introduction to the NAG Library CL Interface).
Note: cg should not return floating-point NaN (Not a Number) or infinity values, since these are not handled by d05bdc. If your code inadvertently does return any NaNs or infinities, d05bdc is likely to produce unexpected results.
4: wtmode Nag_WeightMode Input
On entry: if the fractional weights required by the method need to be calculated by the function then set wtmode=Nag_InitWeights.
If wtmode=Nag_ReuseWeights, the function assumes the fractional weights have been computed on a previous call and are stored in rwsav.
Constraint: wtmode=Nag_InitWeights or Nag_ReuseWeights.
Note: when d05bdc is re-entered with the value of wtmode=Nag_ReuseWeights, the values of nmesh, iorder and the contents of rwsav MUST NOT be changed.
5: iorder Integer Input
On entry: p, the order of the BDF method to be used.
Suggested value: iorder=4.
Constraint: 4iorder6.
6: tlim double Input
On entry: the final point of the integration interval, T.
Constraint: tlim>10×machine precision.
7: tolnl double Input
On entry: the accuracy required for the computation of the starting value and the solution of the nonlinear equation at each step of the computation (see Section 9).
Suggested value: tolnl=ε where ε is the machine precision.
Constraint: tolnl>10×machine precision.
8: nmesh Integer Input
On entry: N, the number of equispaced points at which the solution is sought.
Constraint: nmesh=2m+2×iorder-1, where m1.
9: yn[nmesh] double Output
On exit: yn[i-1] contains the approximate value of the true solution y(t) at the point t=(i-1)×h, for i=1,2,,nmesh, where h=tlim/(nmesh-1).
10: rwsav[lrwsav] double Communication Array
On entry: if wtmode=Nag_ReuseWeights, rwsav must contain fractional weights computed by a previous call of d05bdc (see description of wtmode).
On exit: contains fractional weights which may be used by a subsequent call of d05bdc.
11: lrwsav Integer Input
On entry: the dimension of the array rwsav.
Constraint: lrwsav(2×iorder+6)×nmesh+8×iorder2-16×iorder+1.
12: comm Nag_Comm *
The NAG communication argument (see Section 3.1.1 in the Introduction to the NAG Library CL Interface).
13: fail NagError * Input/Output
The NAG error argument (see Section 7 in the Introduction to the NAG Library CL Interface).

6 Error Indicators and Warnings

NE_ALLOC_FAIL
Dynamic memory allocation failed.
See Section 3.1.2 in the Introduction to the NAG Library CL Interface for further information.
NE_BAD_PARAM
On entry, argument value had an illegal value.
NE_FAILED_START
An error occurred when trying to compute the starting values.
Relaxing the value of tolnl and/or increasing the value of nmesh may overcome this problem (see Section 9 for further details).
NE_FAILED_STEP
An error occurred when trying to compute the solution at a specific step.
Relaxing the value of tolnl and/or increasing the value of nmesh may overcome this problem (see Section 9 for further details).
NE_INT
On entry, iorder=value.
Constraint: 4iorder6.
NE_INT_2
On entry, lrwsav=value.
Constraint: lrwsav(2×iorder+6)×nmesh+8×iorder2-16×iorder+1; that is, value.
On entry, nmesh=value and iorder=value.
Constraint: nmesh=2m+2×iorder-1, for some m.
On entry, nmesh=value and iorder=value.
Constraint: nmesh2×iorder+1.
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 7.5 in the Introduction to the NAG Library CL Interface for further information.
NE_NO_LICENCE
Your licence key may have expired or may not have been installed correctly.
See Section 8 in the Introduction to the NAG Library CL Interface for further information.
NE_REAL
On entry, tlim=value.
Constraints: tlim>10×machine precision.
On entry, tolnl=value.
Constraint: tolnl>10×machine precision.

7 Accuracy

The accuracy depends on nmesh and tolnl, the theoretical behaviour of the solution of the integral equation and the interval of integration. The value of tolnl controls the accuracy required for computing the starting values and the solution of (2) at each step of computation. This value can affect the accuracy of the solution. However, for most problems, the value of ε, where ε is the machine precision, should be sufficient.

8 Parallelism and Performance

Background information to multithreading can be found in the Multithreading documentation.
d05bdc is threaded by NAG for parallel execution in multithreaded implementations of the NAG Library.
d05bdc makes calls to BLAS and/or LAPACK routines, which may be threaded within the vendor library used by this implementation. Consult the documentation for the vendor library for further information.
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 implementation-specific information.

9 Further Comments

In solving (1), initially, d05bdc computes the solution of a system of nonlinear equations for obtaining the 2p-1 starting values. c05qdc is used for this purpose. When a failure with fail.code= NE_FAILED_START occurs (which corresponds to an error exit from c05qdc), you are advised to either relax the value of tolnl or choose a smaller step size by increasing the value of nmesh. Once the starting values are computed successfully, the solution of a nonlinear equation of the form
Yn-αg(tn,Yn)-Ψn=0, (2)
is required at each step of computation, where Ψn and α are constants. d05bdc calls c05axc to find the root of this equation.
If a failure with fail.code= NE_FAILED_STEP occurs (which corresponds to an error exit from c05axc), you are advised to relax the value of the tolnl or choose a smaller step size by increasing the value of nmesh.
If a failure with fail.code= NE_FAILED_START or NE_FAILED_STEP persists even after adjustments to tolnl and/or nmesh then you should consider whether there is a more fundamental difficulty. For example, the problem is ill-posed or the functions in (1) are not sufficiently smooth.

10 Example

In this example we solve the following integral equations
y(t) = t + 38 π t2 - 0t 1 t-s [y(s)] 3 ds ,   0t7 ,  
with the solution y(t)=t, and
y (t) = (3-t) t - 0t 1t-s exp(s (1-s) 2 - [y(s)] 2 ) d s ,   0t5 ,  
with the solution y(t)=(1-t)t. In the above examples, the fourth-order BDF is used, and nmesh is set to 26+7.

10.1 Program Text

Program Text (d05bdce.c)

10.2 Program Data

None.

10.3 Program Results

Program Results (d05bdce.r)