EpetraExt Package Browser (Single Doxygen Collection)
Development
src
transform
EpetraExt_SymmRCM_CrsGraph.h
Go to the documentation of this file.
1
//@HEADER
2
// ***********************************************************************
3
//
4
// EpetraExt: Epetra Extended - Linear Algebra Services Package
5
// Copyright (2011) Sandia Corporation
6
//
7
// Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
8
// the U.S. Government retains certain rights in this software.
9
//
10
// Redistribution and use in source and binary forms, with or without
11
// modification, are permitted provided that the following conditions are
12
// met:
13
//
14
// 1. Redistributions of source code must retain the above copyright
15
// notice, this list of conditions and the following disclaimer.
16
//
17
// 2. Redistributions in binary form must reproduce the above copyright
18
// notice, this list of conditions and the following disclaimer in the
19
// documentation and/or other materials provided with the distribution.
20
//
21
// 3. Neither the name of the Corporation nor the names of the
22
// contributors may be used to endorse or promote products derived from
23
// this software without specific prior written permission.
24
//
25
// THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY
26
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
27
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
28
// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE
29
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
30
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
31
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
32
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
33
// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
34
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
35
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36
//
37
// Questions? Contact Michael A. Heroux (maherou@sandia.gov)
38
//
39
// ***********************************************************************
40
//@HEADER
41
42
#ifndef EpetraExt_CRSGRAPH_SYMMRCM_H
43
#define EpetraExt_CRSGRAPH_SYMMRCM_H
44
45
#include <vector>
46
47
#include <
EpetraExt_Transform.h
>
48
49
class
Epetra_Map
;
50
class
Epetra_CrsGraph
;
51
52
namespace
EpetraExt
{
53
55
struct
CrsGraph_SymmRCM
:
public
StructuralSameTypeTransform
<Epetra_CrsGraph> {
56
57
public
:
58
60
~CrsGraph_SymmRCM
();
61
63
CrsGraph_SymmRCM
(
bool
BruteForce =
false
,
int
testLeafWidth = 5 )
64
:
bruteForce_
(BruteForce),
65
testLeafWidth_
(testLeafWidth),
66
RCMMap_
(0),
67
RCMColMap_
(0)
68
{}
69
71
NewTypeRef
operator()
(
OriginalTypeRef
orig );
72
73
private
:
74
75
Epetra_Map
*
RCMMap_
;
76
Epetra_Map
*
RCMColMap_
;
77
const
int
testLeafWidth_
;
78
const
bool
bruteForce_
;
79
80
class
BFT
{
81
82
public
:
83
84
BFT
(
const
std::vector< std::vector<int> > & adjlist,
85
int
root,
86
int
max_width,
87
bool
& failed );
88
89
int
Width
() {
return
width_
; }
90
int
Depth
() {
return
depth_
; }
91
92
void
NonNeighborLeaves
( std::vector<int> & leaves,
93
const
std::vector< std::vector<int> > & adjlist,
94
int
count );
95
void
ReverseVector
( std::vector<int> & ordered );
96
97
private
:
98
99
bool
failed_
;
100
int
width_
;
101
int
depth_
;
102
int
nodes_
;
103
104
std::vector< std::vector<int> >
levelSets_
;
105
};
106
107
};
108
109
}
//namespace EpetraExt
110
111
#endif //EpetraExt_CRSGRAPH_SYMMRCM_H
EpetraExt::Transform< Epetra_CrsGraph, Epetra_CrsGraph >::NewTypeRef
Epetra_CrsGraph & NewTypeRef
Definition:
EpetraExt_Transform.h:79
EpetraExt::CrsGraph_SymmRCM::BFT::width_
int width_
Definition:
EpetraExt_SymmRCM_CrsGraph.h:100
EpetraExt::CrsGraph_SymmRCM::BFT::ReverseVector
void ReverseVector(std::vector< int > &ordered)
EpetraExt::CrsGraph_SymmRCM::BFT::Width
int Width()
Definition:
EpetraExt_SymmRCM_CrsGraph.h:89
EpetraExt::CrsGraph_SymmRCM::BFT::Depth
int Depth()
Definition:
EpetraExt_SymmRCM_CrsGraph.h:90
EpetraExt::CrsGraph_SymmRCM::BFT::nodes_
int nodes_
Definition:
EpetraExt_SymmRCM_CrsGraph.h:102
EpetraExt::CrsGraph_SymmRCM::CrsGraph_SymmRCM
CrsGraph_SymmRCM(bool BruteForce=false, int testLeafWidth=5)
Constructor.
Definition:
EpetraExt_SymmRCM_CrsGraph.h:63
EpetraExt::CrsGraph_SymmRCM::BFT::BFT
BFT(const std::vector< std::vector< int > > &adjlist, int root, int max_width, bool &failed)
EpetraExt::Transform< Epetra_CrsGraph, Epetra_CrsGraph >::OriginalTypeRef
Epetra_CrsGraph & OriginalTypeRef
Definition:
EpetraExt_Transform.h:74
EpetraExt::CrsGraph_SymmRCM::RCMColMap_
Epetra_Map * RCMColMap_
Definition:
EpetraExt_SymmRCM_CrsGraph.h:76
EpetraExt::CrsGraph_SymmRCM
Generates the symmetric RCM reordered version of a Epetra_CrsGraph.
Definition:
EpetraExt_SymmRCM_CrsGraph.h:55
EpetraExt::CrsGraph_SymmRCM::BFT
Definition:
EpetraExt_SymmRCM_CrsGraph.h:80
EpetraExt::CrsGraph_SymmRCM::~CrsGraph_SymmRCM
~CrsGraph_SymmRCM()
Destructor.
EpetraExt::CrsGraph_SymmRCM::testLeafWidth_
const int testLeafWidth_
Definition:
EpetraExt_SymmRCM_CrsGraph.h:77
EpetraExt::CrsGraph_SymmRCM::BFT::levelSets_
std::vector< std::vector< int > > levelSets_
Definition:
EpetraExt_SymmRCM_CrsGraph.h:104
EpetraExt::CrsGraph_SymmRCM::BFT::NonNeighborLeaves
void NonNeighborLeaves(std::vector< int > &leaves, const std::vector< std::vector< int > > &adjlist, int count)
EpetraExt_Transform.h
Epetra_CrsGraph
EpetraExt::CrsGraph_SymmRCM::RCMMap_
Epetra_Map * RCMMap_
Definition:
EpetraExt_SymmRCM_CrsGraph.h:75
EpetraExt::CrsGraph_SymmRCM::bruteForce_
const bool bruteForce_
Definition:
EpetraExt_SymmRCM_CrsGraph.h:78
EpetraExt::CrsGraph_SymmRCM::BFT::depth_
int depth_
Definition:
EpetraExt_SymmRCM_CrsGraph.h:101
EpetraExt::CrsGraph_SymmRCM::operator()
NewTypeRef operator()(OriginalTypeRef orig)
Transformation Operator.
EpetraExt
EpetraExt::BlockCrsMatrix: A class for constructing a distributed block matrix.
Definition:
EpetraExt_BlockCrsMatrix.cpp:46
Epetra_Map
EpetraExt::CrsGraph_SymmRCM::BFT::failed_
bool failed_
Definition:
EpetraExt_SymmRCM_CrsGraph.h:99
EpetraExt::StructuralSameTypeTransform
Definition:
EpetraExt_Transform.h:281
Generated by
1.8.16