/usr/include/sundials/sundials_dense.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 | /*
* -----------------------------------------------------------------
* $Revision: 4780 $
* $Date: 2016-06-22 17:28:19 -0700 (Wed, 22 Jun 2016) $
* -----------------------------------------------------------------
* Programmer: Radu Serban @ LLNL
* -----------------------------------------------------------------
* LLNS Copyright Start
* Copyright (c) 2014, Lawrence Livermore National Security
* This work was performed under the auspices of the U.S. Department
* of Energy by Lawrence Livermore National Laboratory in part under
* Contract W-7405-Eng-48 and in part under Contract DE-AC52-07NA27344.
* Produced at the Lawrence Livermore National Laboratory.
* All rights reserved.
* For details, see the LICENSE file.
* LLNS Copyright End
* -----------------------------------------------------------------
* This is the header file for a generic package of DENSE matrix
* operations, based on the DlsMat type defined in sundials_direct.h.
*
* There are two sets of dense solver routines listed in
* this file: one set uses type DlsMat defined below and the
* other set uses the type realtype ** for dense matrix arguments.
* Routines that work with the type DlsMat begin with "Dense".
* Routines that work with realtype** begin with "dense".
* -----------------------------------------------------------------
*/
#ifndef _SUNDIALS_DENSE_H
#define _SUNDIALS_DENSE_H
#include <sundials/sundials_direct.h>
#ifdef __cplusplus /* wrapper to enable C++ usage */
extern "C" {
#endif
/*
* -----------------------------------------------------------------
* Functions: DenseGETRF and DenseGETRS
* -----------------------------------------------------------------
* DenseGETRF performs the LU factorization of the M by N dense
* matrix A. This is done using standard Gaussian elimination
* with partial (row) pivoting. Note that this applies only
* to matrices with M >= N and full column rank.
*
* A successful LU factorization leaves the matrix A and the
* pivot array p with the following information:
*
* (1) p[k] contains the row number of the pivot element chosen
* at the beginning of elimination step k, k=0, 1, ..., N-1.
*
* (2) If the unique LU factorization of A is given by PA = LU,
* where P is a permutation matrix, L is a lower trapezoidal
* matrix with all 1's on the diagonal, and U is an upper
* triangular matrix, then the upper triangular part of A
* (including its diagonal) contains U and the strictly lower
* trapezoidal part of A contains the multipliers, I-L.
*
* For square matrices (M = N), L is unit lower triangular.
*
* DenseGETRF returns 0 if successful. Otherwise it encountered
* a zero diagonal element during the factorization. In this case
* it returns the column index (numbered from one) at which
* it encountered the zero.
*
* DenseGETRS solves the N-dimensional system A x = b using
* the LU factorization in A and the pivot information in p
* computed in DenseGETRF. The solution x is returned in b. This
* routine cannot fail if the corresponding call to DenseGETRF
* did not fail.
* DenseGETRS does NOT check for a square matrix!
*
* -----------------------------------------------------------------
* DenseGETRF and DenseGETRS are simply wrappers around denseGETRF
* and denseGETRS, respectively, which perform all the work by
* directly accessing the data in the DlsMat A (i.e. in A->cols).
* -----------------------------------------------------------------
*/
SUNDIALS_EXPORT long int DenseGETRF(DlsMat A, long int *p);
SUNDIALS_EXPORT void DenseGETRS(DlsMat A, long int *p, realtype *b);
SUNDIALS_EXPORT long int denseGETRF(realtype **a, long int m, long int n, long int *p);
SUNDIALS_EXPORT void denseGETRS(realtype **a, long int n, long int *p, realtype *b);
/*
* -----------------------------------------------------------------
* Functions : DensePOTRF and DensePOTRS
* -----------------------------------------------------------------
* DensePOTRF computes the Cholesky factorization of a real symmetric
* positive definite matrix A.
* -----------------------------------------------------------------
* DensePOTRS solves a system of linear equations A*X = B with a
* symmetric positive definite matrix A using the Cholesky factorization
* A = L*L**T computed by DensePOTRF.
*
* -----------------------------------------------------------------
* DensePOTRF and DensePOTRS are simply wrappers around densePOTRF
* and densePOTRS, respectively, which perform all the work by
* directly accessing the data in the DlsMat A (i.e. the field cols)
* -----------------------------------------------------------------
*/
SUNDIALS_EXPORT long int DensePOTRF(DlsMat A);
SUNDIALS_EXPORT void DensePOTRS(DlsMat A, realtype *b);
SUNDIALS_EXPORT long int densePOTRF(realtype **a, long int m);
SUNDIALS_EXPORT void densePOTRS(realtype **a, long int m, realtype *b);
/*
* -----------------------------------------------------------------
* Functions : DenseGEQRF and DenseORMQR
* -----------------------------------------------------------------
* DenseGEQRF computes a QR factorization of a real M-by-N matrix A:
* A = Q * R (with M>= N).
*
* DenseGEQRF requires a temporary work vector wrk of length M.
* -----------------------------------------------------------------
* DenseORMQR computes the product w = Q * v where Q is a real
* orthogonal matrix defined as the product of k elementary reflectors
*
* Q = H(1) H(2) . . . H(k)
*
* as returned by DenseGEQRF. Q is an M-by-N matrix, v is a vector
* of length N and w is a vector of length M (with M >= N).
*
* DenseORMQR requires a temporary work vector wrk of length M.
*
* -----------------------------------------------------------------
* DenseGEQRF and DenseORMQR are simply wrappers around denseGEQRF
* and denseORMQR, respectively, which perform all the work by
* directly accessing the data in the DlsMat A (i.e. the field cols)
* -----------------------------------------------------------------
*/
SUNDIALS_EXPORT int DenseGEQRF(DlsMat A, realtype *beta, realtype *wrk);
SUNDIALS_EXPORT int DenseORMQR(DlsMat A, realtype *beta, realtype *vn, realtype *vm,
realtype *wrk);
SUNDIALS_EXPORT int denseGEQRF(realtype **a, long int m, long int n, realtype *beta,
realtype *wrk);
SUNDIALS_EXPORT int denseORMQR(realtype **a, long int m, long int n, realtype *beta,
realtype *v, realtype *w, realtype *wrk);
/*
* -----------------------------------------------------------------
* Function : DenseCopy
* -----------------------------------------------------------------
* DenseCopy copies the contents of the M-by-N matrix A into the
* M-by-N matrix B.
*
* DenseCopy is a wrapper around denseCopy which accesses the data
* in the DlsMat A and DlsMat B (i.e. the fields cols)
* -----------------------------------------------------------------
*/
SUNDIALS_EXPORT void DenseCopy(DlsMat A, DlsMat B);
SUNDIALS_EXPORT void denseCopy(realtype **a, realtype **b, long int m, long int n);
/*
* -----------------------------------------------------------------
* Function: DenseScale
* -----------------------------------------------------------------
* DenseScale scales the elements of the M-by-N matrix A by the
* constant c and stores the result back in A.
*
* DenseScale is a wrapper around denseScale which performs the actual
* scaling by accessing the data in the DlsMat A (i.e. in A->cols).
* -----------------------------------------------------------------
*/
SUNDIALS_EXPORT void DenseScale(realtype c, DlsMat A);
SUNDIALS_EXPORT void denseScale(realtype c, realtype **a, long int m, long int n);
/*
* -----------------------------------------------------------------
* Function: denseAddIdentity
* -----------------------------------------------------------------
* denseAddIdentity adds the identity matrix to the n-by-n matrix
* stored in a realtype** array.
* -----------------------------------------------------------------
*/
SUNDIALS_EXPORT void denseAddIdentity(realtype **a, long int n);
/*
* -----------------------------------------------------------------
* Function: DenseMatvec
* -----------------------------------------------------------------
* DenseMatvec computes the matrix-vector product y = A*x, where A
* is an M-by-N matrix, x is a vector of length N, and y is a vector
* of length M. No error checking is performed on the length of the
* arrays x and y. Only y is modified in this routine.
*
* DenseMatvec is a wrapper around denseMatvec which performs the
* actual product by accessing the data in the DlsMat A.
* -----------------------------------------------------------------
*/
SUNDIALS_EXPORT void DenseMatvec(DlsMat A, realtype *x, realtype *y);
SUNDIALS_EXPORT void denseMatvec(realtype **a, realtype *x, realtype *y, long int m, long int n);
#ifdef __cplusplus
}
#endif
#endif
|