/usr/include/trilinos/BlockPCGSolver.h is in libtrilinos-anasazi-dev 12.4.2-2.
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 | //**************************************************************************
//
// NOTICE
//
// This software is a result of the research described in the report
//
// " A comparison of algorithms for modal analysis in the absence
// of a sparse direct method", P. Arbenz, R. Lehoucq, and U. Hetmaniuk,
// Sandia National Laboratories, Technical report SAND2003-1028J.
//
// It is based on the Epetra, AztecOO, and ML packages defined in the Trilinos
// framework ( http://software.sandia.gov/trilinos/ ).
//
// The distribution of this software follows also the rules defined in Trilinos.
// This notice shall be marked on any reproduction of this software, in whole or
// in part.
//
// Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive
// license for use of this work by or on behalf of the U.S. Government.
//
// This program is distributed in the hope that it will be useful, but
// WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
//
// Code Authors: U. Hetmaniuk (ulhetma@sandia.gov), R. Lehoucq (rblehou@sandia.gov)
//
//**************************************************************************
#ifndef ANASAZI_BLOCK_PCG_SOLVER_H
#define ANASAZI_BLOCK_PCG_SOLVER_H
#include "Epetra_ConfigDefs.h"
#include "Anasaziepetra_ModeLaplace_DLLExportMacro.h"
#include "Epetra_Comm.h"
#include "Epetra_Map.h"
#include "Epetra_MultiVector.h"
#include "Epetra_Vector.h"
#include "Epetra_Operator.h"
#include "Epetra_RowMatrix.h"
#include "Teuchos_BLAS.hpp"
#include "Teuchos_LAPACK.hpp"
class ANASAZIEPETRA_MODELAPLACE_LIB_DLL_EXPORT BlockPCGSolver : public virtual Epetra_Operator {
private:
const Epetra_Comm &MyComm;
#ifdef _MSC_VER
//use pragmas to disable some false-positive warnings for windows sharedlibs export
#pragma warning(push)
#pragma warning(disable:4251)
#endif // _MSC_VER
const Teuchos::BLAS<int,double> callBLAS;
const Teuchos::LAPACK<int,double> callLAPACK;
#ifdef _MSC_VER
#pragma warning(pop)
#endif // _MSC_VER
const Epetra_Operator *K;
Epetra_Operator *Prec;
double tolCG;
int iterMax;
int verbose;
mutable double *workSpace;
mutable int lWorkSpace;
mutable int numSolve;
mutable int maxIter;
mutable int sumIter;
mutable int minIter;
// Don't define these functions
BlockPCGSolver(const BlockPCGSolver &ref);
BlockPCGSolver& operator=(const BlockPCGSolver &ref);
public:
BlockPCGSolver(const Epetra_Comm& _Com, const Epetra_Operator *KK,
double _tol = 0.0, int _iMax = 0, int _verb = 0);
BlockPCGSolver(const Epetra_Comm& _Com, const Epetra_Operator *KK,
Epetra_Operator *PP,
double _tol = 0.0, int _iMax = 0, int _verb = 0);
~BlockPCGSolver();
const char* Label() const { return "Epetra_Operator for Block PCG solver"; };
bool UseTranspose() const { return (false); };
int SetUseTranspose(bool useTranspose) { return 0; };
bool HasNormInf() const { return (false); };
double NormInf() const { return (-1.0); };
int Apply(const Epetra_MultiVector &X, Epetra_MultiVector &Y) const;
int ApplyInverse(const Epetra_MultiVector &X, Epetra_MultiVector &Y) const;
const Epetra_Comm& Comm() const { return MyComm; };
const Epetra_Map& OperatorDomainMap() const { return K->OperatorDomainMap(); };
const Epetra_Map& OperatorRangeMap() const { return K->OperatorRangeMap(); };
int Solve(const Epetra_MultiVector &X, Epetra_MultiVector &Y) const;
int Solve(const Epetra_MultiVector &X, Epetra_MultiVector &Y, int blkSize) const;
const Epetra_Operator* getPreconditioner() const { return Prec; };
void setPreconditioner(Epetra_Operator *PP);
void setIterMax(int _iMax) { iterMax = (_iMax > 0) ? _iMax : 0; };
int getMaxIter() const { return maxIter; };
double getAvgIter() const { return sumIter/((double) numSolve); };
int getMinIter() const { return minIter; };
};
#endif
|