EpetraExt
Development
Toggle main menu visibility
Loading...
Searching...
No Matches
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.h
EpetraExt::StructuralSameTypeTransform
Definition
EpetraExt_Transform.h:282
EpetraExt::Transform< Epetra_CrsGraph, Epetra_CrsGraph >::OriginalTypeRef
Epetra_CrsGraph & OriginalTypeRef
Definition
EpetraExt_Transform.h:74
EpetraExt::Transform< Epetra_CrsGraph, Epetra_CrsGraph >::NewTypeRef
Epetra_CrsGraph & NewTypeRef
Definition
EpetraExt_Transform.h:79
Epetra_CrsGraph
Epetra_Map
EpetraExt
EpetraExt::BlockCrsMatrix: A class for constructing a distributed block matrix.
Definition
EpetraExt_BlockCrsMatrix.cpp:46
EpetraExt::CrsGraph_SymmRCM::~CrsGraph_SymmRCM
~CrsGraph_SymmRCM()
Destructor.
EpetraExt::CrsGraph_SymmRCM::operator()
NewTypeRef operator()(OriginalTypeRef orig)
Transformation Operator.
EpetraExt::CrsGraph_SymmRCM::CrsGraph_SymmRCM
CrsGraph_SymmRCM(bool BruteForce=false, int testLeafWidth=5)
Constructor.
Definition
EpetraExt_SymmRCM_CrsGraph.h:63
Generated by
1.17.0