/usr/include/trilinos/Ifpack_IlukGraph.h is in libtrilinos-dev 10.4.0.dfsg-1ubuntu2.
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 | /*@HEADER
// ***********************************************************************
//
// Ifpack: Object-Oriented Algebraic Preconditioner Package
// Copyright (2002) Sandia Corporation
//
// 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 library is free software; you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as
// published by the Free Software Foundation; either version 2.1 of the
// License, or (at your option) any later version.
//
// This library 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. See the GNU
// Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
// USA
// Questions? Contact Michael A. Heroux (maherou@sandia.gov)
//
// ***********************************************************************
//@HEADER
*/
#ifndef _IFPACK_ILUK_GRAPH_H_
#define _IFPACK_ILUK_GRAPH_H_
#include "Ifpack_ConfigDefs.h"
#include "Epetra_Object.h"
#include "Epetra_CrsGraph.h"
#include "Epetra_Import.h"
#include "Teuchos_RefCountPtr.hpp"
namespace Teuchos {
class ParameterList;
}
//! Ifpack_IlukGraph: A class for constructing level filled graphs for use with ILU(k) class preconditioners.
/*! The Ifpack_IlukGraph class enable the construction matrix graphs using level-fill algorithms. The only function
required for construction is an ExtractRowView capability, i.e., the matrix that is passed in to the constructor
must implement the Ifpack_CrsGraph interface defined in Ifpack_CrsMatrix.h
<b>Constructing Ifpack_IlukGraph objects</b>
Constructing Ifpack_IlukGraph objects is usually a two step process of passing in a Ifpack_CrsGraph object and
an integer indicating the desired level of fill and then calling the ConstructFilledGraph function to complete the
process. This allows warning error codes to be returned to the calling routine.
It is worth noting that an Ifpack_IlukGraph object has two
Epetra_CrsGraph objects containing L and U, the graphs for the lower and upper triangular parts of the ILU(k) graph.
Thus, it is possible to manually insert and delete graph entries in L and U via the Epetra_CrsGraph
InsertIndices and RemoveIndices functions. However, in this case FillComplete must be
called before the graph is used for subsequent operations.
*/
class Ifpack_IlukGraph {
// Give ostream << function some access to private and protected data/functions.
friend ostream& operator << (ostream& os, const Ifpack_IlukGraph& A);
public:
//! Ifpack_IlukGraph constuctor.
/*! Creates a Ifpack_IlukGraph object using the input graph and specified level of fill.
\param In
Graph_in - An existing Ifpack_CrsGraph. This object must implement the Ifpack_CrsGraph functions
that provide graph dimension and pattern information.
\param In
LevelFill_in - The level of fill to compute via ILU(k) algorithm.
\param In
LevelOverlap_in - The level of between subdomains.
\warning Actual construction occurs in ConstructFilledGraph. This allows error codes to
be passed back to the user.
*/
Ifpack_IlukGraph(const Epetra_CrsGraph & Graph_in, int LevelFill_in, int LevelOverlap_in);
//! Copy constructor.
Ifpack_IlukGraph(const Ifpack_IlukGraph & Graph_in);
//! Ifpack_IlukGraph Destructor
virtual ~Ifpack_IlukGraph();
//!Set parameters using Teuchos::ParameterList object.
/* This method is only available if the Teuchos package is enabled.
This method recogizes two parameter names: Level_fill and Level_overlap.
Both are case insensitive, and in both cases the ParameterEntry must
have type int.
*/
int SetParameters(const Teuchos::ParameterList& parameterlist,
bool cerr_warning_if_unused=false);
//! Does the actual construction of the graph.
/*
\return Integer error code, set to 0 if successful.
*/
virtual int ConstructFilledGraph();
//! Does the actual construction of the overlap matrix graph.
/*
\return Integer error code, set to 0 if successful.
*/
virtual int ConstructOverlapGraph();
//! Returns the level of fill used to construct this graph.
virtual int LevelFill() const {return(LevelFill_);};
//! Returns the level of overlap used to construct this graph.
virtual int LevelOverlap() const {return(LevelOverlap_);};
//! Returns the number of global matrix rows.
int NumGlobalBlockRows() const {return(NumGlobalBlockRows_);};
//! Returns the number of global matrix columns.
int NumGlobalBlockCols() const {return(NumGlobalBlockCols_);};
//! Returns the number of global matrix rows.
int NumGlobalRows() const {return(NumGlobalRows_);};
//! Returns the number of global matrix columns.
int NumGlobalCols() const {return(NumGlobalCols_);};
//! Returns the number of nonzero entries in the global graph.
int NumGlobalNonzeros() const {return(NumGlobalNonzeros_);};
//! Returns the number of diagonal entries found in the global input graph.
virtual int NumGlobalBlockDiagonals() const {return(NumGlobalBlockDiagonals_);};
//! Returns the number of local matrix rows.
int NumMyBlockRows() const {return(NumMyBlockRows_);};
//! Returns the number of local matrix columns.
int NumMyBlockCols() const {return(NumMyBlockCols_);};
//! Returns the number of local matrix rows.
int NumMyRows() const {return(NumMyRows_);};
//! Returns the number of local matrix columns.
int NumMyCols() const {return(NumMyCols_);};
//! Returns the number of nonzero entries in the local graph.
int NumMyNonzeros() const {return(NumMyNonzeros_);};
//! Returns the number of diagonal entries found in the local input graph.
virtual int NumMyBlockDiagonals() const {return(NumMyBlockDiagonals_);};
//! Returns the index base for row and column indices for this graph.
int IndexBase() const {return(IndexBase_);};
//! Returns the graph of lower triangle of the ILU(k) graph as a Epetra_CrsGraph.
virtual Epetra_CrsGraph & L_Graph() {return(*L_Graph_);};
//! Returns the graph of upper triangle of the ILU(k) graph as a Epetra_CrsGraph.
virtual Epetra_CrsGraph & U_Graph() {return(*U_Graph_);};
//! Returns the graph of lower triangle of the ILU(k) graph as a Epetra_CrsGraph.
virtual Epetra_CrsGraph & L_Graph() const {return(*L_Graph_);};
//! Returns the graph of upper triangle of the ILU(k) graph as a Epetra_CrsGraph.
virtual Epetra_CrsGraph & U_Graph() const {return(*U_Graph_);};
//! Returns the importer used to create the overlapped graph.
virtual Epetra_Import * OverlapImporter() const {return(&*OverlapImporter_);};
//! Returns the the overlapped graph.
virtual Epetra_CrsGraph * OverlapGraph() const {return(&*OverlapGraph_);};
//! Returns the Epetra_BlockMap object associated with the domain of this matrix operator.
virtual const Epetra_BlockMap & DomainMap() const {return(DomainMap_);};
//! Returns the Epetra_BlockMap object associated with the range of this matrix operator.
virtual const Epetra_BlockMap & RangeMap() const{return(RangeMap_);};
//! Returns the Epetra_BlockMap object associated with the range of this matrix operator.
virtual const Epetra_Comm & Comm() const{return(Comm_);};
private:
const Epetra_CrsGraph & Graph_;
const Epetra_BlockMap & DomainMap_;
const Epetra_BlockMap & RangeMap_;
const Epetra_Comm & Comm_;
Teuchos::RefCountPtr<Epetra_CrsGraph> OverlapGraph_;
Teuchos::RefCountPtr<Epetra_BlockMap> OverlapRowMap_;
Teuchos::RefCountPtr<Epetra_Import> OverlapImporter_;
int LevelFill_;
int LevelOverlap_;
Teuchos::RefCountPtr<Epetra_CrsGraph> L_Graph_;
Teuchos::RefCountPtr<Epetra_CrsGraph> U_Graph_;
int IndexBase_;
int NumGlobalRows_;
int NumGlobalCols_;
int NumGlobalBlockRows_;
int NumGlobalBlockCols_;
int NumGlobalBlockDiagonals_;
int NumGlobalNonzeros_;
int NumGlobalEntries_;
int NumMyBlockRows_;
int NumMyBlockCols_;
int NumMyRows_;
int NumMyCols_;
int NumMyBlockDiagonals_;
int NumMyNonzeros_;
int NumMyEntries_;
};
//! << operator will work for Ifpack_IlukGraph.
ostream& operator << (ostream& os, const Ifpack_IlukGraph& A);
#endif /* _IFPACK_ILUK_GRAPH_H_ */
|