/usr/include/arkode/arkode_bbdpre.h is in libsundials-dev 2.7.0+dfsg-2build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 | /*---------------------------------------------------------------
* Programmer(s): Daniel R. Reynolds @ SMU
*---------------------------------------------------------------
* LLNS/SMU Copyright Start
* Copyright (c) 2015, Southern Methodist University and
* Lawrence Livermore National Security
*
* This work was performed under the auspices of the U.S. Department
* of Energy by Southern Methodist University and Lawrence Livermore
* National Laboratory under Contract DE-AC52-07NA27344.
* Produced at Southern Methodist University and the Lawrence
* Livermore National Laboratory.
*
* All rights reserved.
* For details, see the LICENSE file.
* LLNS/SMU Copyright End
*---------------------------------------------------------------
* This is the header file for the ARKBBDPRE module, for a
* band-block-diagonal preconditioner, i.e. a block-diagonal
* matrix with banded blocks, for use with ARKSPGMR, ARKSPBCG,
* ARKSPTFQMR, ARKSPFGMR or ARKPCG, and the parallel implementation
* of the NVECTOR module.
*
* Summary:
*
* These routines provide a preconditioner matrix that is
* block-diagonal with banded blocks. The blocking corresponds
* to the distribution of the dependent variable vector y among
* the processors. Each preconditioner block is generated from
* the Jacobian of the local part (on the current processor) of a
* given function g(t,y) approximating f(t,y). The blocks are
* generated by a difference quotient scheme on each processor
* independently. This scheme utilizes an assumed banded
* structure with given half-bandwidths, mudq and mldq.
* However, the banded Jacobian block kept by the scheme has
* half-bandwiths mukeep and mlkeep, which may be smaller.
*
* The user's calling program should have the following form:
*
* #include <nvector_parallel.h>
* #include <arkode/arkode_bbdpre.h>
* ...
* void *arkode_mem;
* ...
* Set y0
* ...
* arkode_mem = ARKodeCreate();
* ier = ARKodeInit(...);
* ...
* flag = ARKSpgmr(arkode_mem, pretype, maxl);
* -or-
* flag = ARKSpbcg(arkode_mem, pretype, maxl);
* -or-
* flag = ARKSptfqmr(arkode_mem, pretype, maxl);
* -or-
* flag = ARKSpfgmr(arkode_mem, pretype, maxl);
* -or-
* flag = ARKPcg(arkode_mem, pretype, maxl);
* ...
* flag = ARKBBDPrecInit(arkode_mem, Nlocal, mudq ,mldq,
* mukeep, mlkeep, dqrely, gloc, cfn);
* ...
* ier = ARKode(...);
* ...
* ARKodeFree(&arkode_mem);
*
* Free y0
*
* The user-supplied routines required are:
*
* f = function defining the ODE right-hand side f(t,y).
*
* gloc = function defining the approximation g(t,y).
*
* cfn = function to perform communication need for gloc.
*
* Notes:
*
* 1) This header file is included by the user for the definition
* of the ARKBBDData type and for needed function prototypes.
*
* 2) The ARKBBDPrecInit call includes half-bandwiths mudq and mldq
* to be used in the difference quotient calculation of the
* approximate Jacobian. They need not be the true
* half-bandwidths of the Jacobian of the local block of g,
* when smaller values may provide a greater efficiency.
* Also, the half-bandwidths mukeep and mlkeep of the retained
* banded approximate Jacobian block may be even smaller,
* to reduce storage and computation costs further.
* For all four half-bandwidths, the values need not be the
* same on every processor.
*
* 3) The actual name of the user's f function is passed to
* ARKodeInit, and the names of the user's gloc and cfn
* functions are passed to ARKBBDPrecInit.
*
* 4) The pointer to the user-defined data block user_data, which is
* set through ARKodeSetUserData is also available to the user in
* gloc and cfn.
*
* 5) Optional outputs specific to this module are available by
* way of routines listed below. These include work space sizes
* and the cumulative number of gloc calls. The costs
* associated with this module also include nsetups banded LU
* factorizations, nlinsetups cfn calls, and npsolves banded
* backsolve calls, where nlinsetups and npsolves are
* integrator/ARKSPGMR/ARKSPBCG/ARKSPTFQMR/ARKSPFGMR/ARKPCG
* optional outputs.
*--------------------------------------------------------------*/
#ifndef _ARKBBDPRE_H
#define _ARKBBDPRE_H
#include <sundials/sundials_nvector.h>
#ifdef __cplusplus /* wrapper to enable C++ usage */
extern "C" {
#endif
/*---------------------------------------------------------------
Type: ARKLocalFn
The user must supply a function g(t,y) which approximates the
right-hand side function f for the system y'=f(t,y), and which
is computed locally (without interprocess communication).
(The case where g is mathematically identical to f is allowed.)
The implementation of this function must have type ARKLocalFn.
This function takes as input the local vector size Nlocal, the
independent variable value t, the local real dependent
variable vector y, and a pointer to the user-defined data
block user_data. It is to compute the local part of g(t,y) and
store this in the vector g.
(Allocation of memory for y and g is handled within the
preconditioner module.)
The user_data parameter is the same as that specified by the user
through the ARKodeSetFdata routine.
A ARKLocalFn should return 0 if successful, a positive value if
a recoverable error occurred, and a negative value if an
unrecoverable error occurred.
---------------------------------------------------------------*/
typedef int (*ARKLocalFn)(long int Nlocal, realtype t, N_Vector y,
N_Vector g, void *user_data);
/*---------------------------------------------------------------
Type: ARKCommFn
The user may supply a function of type ARKCommFn which performs
all interprocess communication necessary to evaluate the
approximate right-hand side function described above.
This function takes as input the local vector size Nlocal,
the independent variable value t, the dependent variable
vector y, and a pointer to the user-defined data block user_data.
The user_data parameter is the same as that specified by the user
through the ARKodeSetUserData routine. The ARKCommFn cfn is
expected to save communicated data in space defined within the
structure user_data. Note: A ARKCommFn cfn does not have a return value.
Each call to the ARKCommFn cfn is preceded by a call to the
ARKRhsFn f with the same (t,y) arguments. Thus cfn can omit any
communications done by f if relevant to the evaluation of g.
If all necessary communication was done by f, the user can
pass NULL for cfn in ARKBBDPrecInit (see below).
A ARKCommFn should return 0 if successful, a positive value if
a recoverable error occurred, and a negative value if an
unrecoverable error occurred.
---------------------------------------------------------------*/
typedef int (*ARKCommFn)(long int Nlocal, realtype t,
N_Vector y, void *user_data);
/*---------------------------------------------------------------
ARKBBDPrecInit:
ARKBBDPrecInit allocates and initializes the BBD preconditioner.
The parameters of ARKBBDPrecInit are as follows:
arkode_mem is the pointer to the integrator memory.
Nlocal is the length of the local block of the vectors y etc.
on the current processor.
mudq, mldq are the upper and lower half-bandwidths to be used
in the difference quotient computation of the local
Jacobian block.
mukeep, mlkeep are the upper and lower half-bandwidths of the
retained banded approximation to the local Jacobian
block.
dqrely is an optional input. It is the relative increment
in components of y used in the difference quotient
approximations. To specify the default, pass 0.
The default is dqrely = sqrt(unit roundoff).
gloc is the name of the user-supplied function g(t,y) that
approximates f and whose local Jacobian blocks are
to form the preconditioner.
cfn is the name of the user-defined function that performs
necessary interprocess communication for the
execution of gloc.
The return value of ARKBBDPrecInit is one of:
ARKSPILS_SUCCESS if no errors occurred
ARKSPILS_MEM_NULL if the integrator memory is NULL
ARKSPILS_LMEM_NULL if the linear solver memory is NULL
ARKSPILS_ILL_INPUT if an input has an illegal value
ARKSPILS_MEM_FAIL if a memory allocation request failed
---------------------------------------------------------------*/
SUNDIALS_EXPORT int ARKBBDPrecInit(void *arkode_mem, long int Nlocal,
long int mudq, long int mldq,
long int mukeep, long int mlkeep,
realtype dqrely,
ARKLocalFn gloc, ARKCommFn cfn);
/*---------------------------------------------------------------
ARKBBDPrecReInit:
ARKBBDPrecReInit re-initializes the BBDPRE module when solving a
sequence of problems of the same size with ARKSPGMR/ARKBBDPRE or
ARKSPBCG/ARKBBDPRE or ARKSPTFQMR/ARKBBDPRE or ARKSPFGMR/ARKBBDPRE
or ARKPCG/ARKBBDPRE provided there is no change in Nlocal,
mukeep, or mlkeep. After solving one problem, and after calling
ARKodeReInit to re-initialize the integrator for a subsequent
problem, call ARKBBDPrecReInit.
All arguments have the same names and meanings as those
of ARKBBDPrecInit.
The return value of ARKBBDPrecReInit is one of:
ARKSPILS_SUCCESS if no errors occurred
ARKSPILS_MEM_NULL if the integrator memory is NULL
ARKSPILS_LMEM_NULL if the linear solver memory is NULL
ARKSPILS_PMEM_NULL if the preconditioner memory is NULL
---------------------------------------------------------------*/
SUNDIALS_EXPORT int ARKBBDPrecReInit(void *arkode_mem, long int mudq,
long int mldq, realtype dqrely);
/*---------------------------------------------------------------
BBDPRE optional output extraction routines:
ARKBBDPrecGetWorkSpace returns the BBDPRE real and integer work
space sizes.
ARKBBDPrecGetNumGfnEvals returns the number of calls to gfn.
The return value of ARKBBDPrecGet* is one of:
ARKSPILS_SUCCESS if no errors occurred
ARKSPILS_MEM_NULL if the integrator memory is NULL
ARKSPILS_LMEM_NULL if the linear solver memory is NULL
ARKSPILS_PMEM_NULL if the preconditioner memory is NULL
---------------------------------------------------------------*/
SUNDIALS_EXPORT int ARKBBDPrecGetWorkSpace(void *arkode_mem,
long int *lenrwLS,
long int *leniwLS);
SUNDIALS_EXPORT int ARKBBDPrecGetNumGfnEvals(void *arkode_mem,
long int *ngevalsBBDP);
#ifdef __cplusplus
}
#endif
#endif
|