MueLu
Version of the Day
Main Page
Related Pages
Namespaces
Classes
Files
File List
File Members
MueLu_AggregationAlgorithmBase.hpp
Go to the documentation of this file.
1
// @HEADER
2
//
3
// ***********************************************************************
4
//
5
// MueLu: A package for multigrid based preconditioning
6
// Copyright 2012 Sandia Corporation
7
//
8
// Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
9
// the U.S. Government retains certain rights in this software.
10
//
11
// Redistribution and use in source and binary forms, with or without
12
// modification, are permitted provided that the following conditions are
13
// met:
14
//
15
// 1. Redistributions of source code must retain the above copyright
16
// notice, this list of conditions and the following disclaimer.
17
//
18
// 2. Redistributions in binary form must reproduce the above copyright
19
// notice, this list of conditions and the following disclaimer in the
20
// documentation and/or other materials provided with the distribution.
21
//
22
// 3. Neither the name of the Corporation nor the names of the
23
// contributors may be used to endorse or promote products derived from
24
// this software without specific prior written permission.
25
//
26
// THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY
27
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
28
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
29
// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE
30
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
31
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
32
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
33
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
34
// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
35
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
36
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
37
//
38
// Questions? Contact
39
// Jonathan Hu (jhu@sandia.gov)
40
// Andrey Prokopenko (aprokop@sandia.gov)
41
// Ray Tuminaro (rstumin@sandia.gov)
42
//
43
// ***********************************************************************
44
//
45
// @HEADER
46
#ifndef MUELU_AGGREGATIONALGORITHMBASE_HPP_
47
#define MUELU_AGGREGATIONALGORITHMBASE_HPP_
48
49
#include "
MueLu_ConfigDefs.hpp
"
50
#include "
MueLu_BaseClass.hpp
"
51
52
#include "
MueLu_Aggregates_fwd.hpp
"
53
54
#include "MueLu_Aggregates.hpp"
55
#include "
MueLu_GraphBase.hpp
"
56
57
namespace
MueLu
{
58
59
// In the algorithm, aggStat[] = READY/NOTSEL/SELECTED indicates whether a node has been aggregated
60
enum
NodeState
{
61
READY
= 1,
// indicates that a node is available to be
62
// selected as a root node of an aggregate
63
64
NOTSEL
= 2,
// indicates that a node has been rejected as a root node.
65
// This could perhaps be because if this node had been
66
// selected a small aggregate would have resulted
67
// This is Phase 1 specific
68
69
AGGREGATED
= 3,
// indicates that a node has been assigned
70
// to an aggregate
71
72
ONEPT
= 4,
// indicates that a node shall be preserved over
73
// all multigrid levels as 1 point aggregate
74
75
IGNORED
= 5,
// indicates that the node is removed from consideration,
76
// and is not aggregated
77
78
BOUNDARY
= 6
// node is a Dirichlet node
79
// During aggregation, it is transformed either to AGGREGATED
80
// or to IGNORED
81
};
82
83
84
85
class
Aggregate
{
86
public
:
87
int
index
;
// local aggregate id
88
std::vector<int>
list
;
// list of node ids in aggregate
89
};
90
97
template
<
class
LocalOrdinal = int,
98
class
GlobalOrdinal = LocalOrdinal,
99
class
Node = KokkosClassic::DefaultNode::DefaultNodeType>
100
class
AggregationAlgorithmBase
:
public
BaseClass
{
101
#undef MUELU_AGGREGATIONALGORITHMBASE_SHORT
102
#include "
MueLu_UseShortNamesOrdinal.hpp
"
103
public
:
104
106
107
109
virtual
~AggregationAlgorithmBase
() {}
110
112
114
115
117
virtual
void
BuildAggregates(
const
Teuchos::ParameterList& params,
const
GraphBase
& graph,
Aggregates
& aggregates, std::vector<unsigned>& aggStat, LO& numNonAggregatedNodes)
const
= 0;
119
120
};
121
122
}
// namespace MueLu
123
124
#define MUELU_AGGREGATIONALGORITHMBASE_SHORT
125
#endif
/* MUELU_AGGREGATIONALGORITHMBASE_HPP_ */
MueLu::Aggregate::list
std::vector< int > list
Definition:
MueLu_AggregationAlgorithmBase.hpp:88
MueLu::Aggregates
Container class for aggregation information.
Definition:
MueLu_Aggregates_decl.hpp:98
MueLu::Aggregate::index
int index
Definition:
MueLu_AggregationAlgorithmBase.hpp:87
MueLu::AggregationAlgorithmBase
Pure virtual base class for all MueLu aggregation algorithms.
Definition:
MueLu_AggregationAlgorithmBase.hpp:100
MueLu_BaseClass.hpp
MueLu::NodeState
NodeState
Definition:
MueLu_AggregationAlgorithmBase.hpp:60
MueLu
Namespace for MueLu classes and methods.
Definition:
MueLu_BrickAggregationFactory_decl.hpp:76
MueLu_ConfigDefs.hpp
MueLu_GraphBase.hpp
MueLu::AggregationAlgorithmBase::~AggregationAlgorithmBase
virtual ~AggregationAlgorithmBase()
Destructor.
Definition:
MueLu_AggregationAlgorithmBase.hpp:109
MueLu::AGGREGATED
Definition:
MueLu_AggregationAlgorithmBase.hpp:69
MueLu::NOTSEL
Definition:
MueLu_AggregationAlgorithmBase.hpp:64
MueLu_Aggregates_fwd.hpp
MueLu::GraphBase
MueLu representation of a graph.
Definition:
MueLu_GraphBase.hpp:67
MueLu::BaseClass
Base class for MueLu classes.
Definition:
MueLu_BaseClass.hpp:61
MueLu::Aggregate
Definition:
MueLu_AggregationAlgorithmBase.hpp:85
MueLu::READY
Definition:
MueLu_AggregationAlgorithmBase.hpp:61
MueLu::ONEPT
Definition:
MueLu_AggregationAlgorithmBase.hpp:72
MueLu::BOUNDARY
Definition:
MueLu_AggregationAlgorithmBase.hpp:78
MueLu_UseShortNamesOrdinal.hpp
MueLu::IGNORED
Definition:
MueLu_AggregationAlgorithmBase.hpp:75
src
Graph
UncoupledAggregation
MueLu_AggregationAlgorithmBase.hpp
Generated on Tue Mar 1 2016 10:39:54 for MueLu by
1.8.11