EpetraExt
Development
Main Page
Related Pages
Modules
Namespaces
Classes
Files
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Groups
Pages
src
coloring
EpetraExt_MapColoring.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_MAPCOLORING_H
43
#define EpetraExt_CRSGRAPH_MAPCOLORING_H
44
45
#include <
EpetraExt_Transform.h
>
46
47
class
Epetra_CrsGraph
;
48
class
Epetra_MapColoring
;
49
50
namespace
EpetraExt {
51
53
59
class
CrsGraph_MapColoring
:
public
StructuralTransform
<Epetra_CrsGraph,Epetra_MapColoring>
60
{
61
62
public
:
63
64
enum
ColoringAlgorithm
{
GREEDY
,
LUBY
,
JONES_PLASSMAN
,
PSEUDO_PARALLEL
};
65
67
69
~CrsGraph_MapColoring
() {}
70
72
74
CrsGraph_MapColoring
(
ColoringAlgorithm
algo =
GREEDY
,
75
int
reordering = 0,
76
bool
distance1 =
false
,
77
int
verbosity = 0 )
78
: algo_(algo),
79
reordering_(reordering),
80
distance1_(distance1),
81
verbosity_(verbosity)
82
{}
83
85
87
CrsGraph_MapColoring::NewTypeRef
operator()
(
CrsGraph_MapColoring::OriginalTypeRef
orig );
88
89
private
:
90
91
92
const
ColoringAlgorithm
algo_;
93
94
const
int
reordering_;
95
const
bool
distance1_;
96
97
const
int
verbosity_;
98
99
template
<
typename
int
_type>
100
CrsGraph_MapColoring::NewTypeRef
Toperator(
CrsGraph_MapColoring::OriginalTypeRef
orig );
101
};
102
103
}
//namespace EpetraExt
104
105
#endif //EpetraExt_CRSGRAPH_MAPCOLORING_H
Epetra_MapColoring
EpetraExt::CrsGraph_MapColoring::JONES_PLASSMAN
Definition:
EpetraExt_MapColoring.h:64
EpetraExt::CrsGraph_MapColoring::CrsGraph_MapColoring
CrsGraph_MapColoring(ColoringAlgorithm algo=GREEDY, int reordering=0, bool distance1=false, int verbosity=0)
Constructor.
Definition:
EpetraExt_MapColoring.h:74
EpetraExt::CrsGraph_MapColoring::~CrsGraph_MapColoring
~CrsGraph_MapColoring()
Destructor.
Definition:
EpetraExt_MapColoring.h:69
EpetraExt::CrsGraph_MapColoring::operator()
CrsGraph_MapColoring::NewTypeRef operator()(CrsGraph_MapColoring::OriginalTypeRef orig)
Generates the Epetra_MapColoring object from an input Epetra_CrsGraph.
Definition:
EpetraExt_MapColoring.cpp:662
EpetraExt::CrsGraph_MapColoring::PSEUDO_PARALLEL
Definition:
EpetraExt_MapColoring.h:64
EpetraExt::Transform::OriginalTypeRef
T & OriginalTypeRef
Definition:
EpetraExt_Transform.h:74
EpetraExt::CrsGraph_MapColoring::LUBY
Definition:
EpetraExt_MapColoring.h:64
EpetraExt::StructuralTransform
Definition:
EpetraExt_Transform.h:260
EpetraExt::CrsGraph_MapColoring::GREEDY
Definition:
EpetraExt_MapColoring.h:64
EpetraExt::CrsGraph_MapColoring::ColoringAlgorithm
ColoringAlgorithm
Definition:
EpetraExt_MapColoring.h:64
EpetraExt::CrsGraph_MapColoring
Map Coloring of independent columns in a Graph.
Definition:
EpetraExt_MapColoring.h:59
EpetraExt_Transform.h
EpetraExt::Transform::NewTypeRef
U & NewTypeRef
Definition:
EpetraExt_Transform.h:79
Epetra_CrsGraph
Generated by
1.8.5