MueLu
Version of the Day
Toggle main menu visibility
Loading...
Searching...
No Matches
MueLu_AlgebraicPermutationStrategy_decl.hpp
Go to the documentation of this file.
1
/*
2
* MueLu_AlgebraicPermutationStrategy_decl.hpp
3
*
4
* Created on: Feb 20, 2013
5
* Author: tobias
6
*/
7
8
#ifndef MUELU_ALGEBRAICPERMUTATIONSTRATEGY_DECL_HPP_
9
#define MUELU_ALGEBRAICPERMUTATIONSTRATEGY_DECL_HPP_
10
11
#include <Xpetra_Matrix_fwd.hpp>
12
#include <Xpetra_Vector_fwd.hpp>
13
#include <Xpetra_VectorFactory_fwd.hpp>
14
#include <Xpetra_CrsMatrixWrap_fwd.hpp>
15
#include <Xpetra_Export_fwd.hpp>
16
#include <Xpetra_ExportFactory_fwd.hpp>
17
#include <Xpetra_Import_fwd.hpp>
18
19
#include "
MueLu_ConfigDefs.hpp
"
20
#include "
MueLu_Level.hpp
"
21
#include "
MueLu_BaseClass.hpp
"
22
23
namespace
MueLu
{
24
25
// template struct for comparing pairs
26
template
<
class
Scalar = DefaultScalar,
class
LocalOrdinal = DefaultGlobalOrdinal>
27
struct
CompPairs
{
28
CompPairs
(
const
std::vector<Scalar> & v) :
vinternal_
(v) {}
29
std::vector<Scalar>
vinternal_
;
30
bool
operator()
(
LocalOrdinal
a,
LocalOrdinal
b) {
31
//return vinternal_[a] < vinternal_[b];
32
return
Teuchos::ScalarTraits<Scalar>::magnitude(
vinternal_
[a]) > Teuchos::ScalarTraits<Scalar>::magnitude(
vinternal_
[b]);
33
}
34
};
35
36
// template function for comparison
37
template
<
class
Scalar,
class
LocalOrdinal>
38
CompPairs<Scalar,LocalOrdinal>
CreateCmpPairs
(
const
std::vector<Scalar> & v) {
39
return
CompPairs<Scalar,LocalOrdinal>
(v);
40
}
41
42
// template function for sorting permutations
43
template
<
class
Scalar,
class
LocalOrdinal>
44
void
sortingPermutation
(
const
std::vector<Scalar> & values, std::vector<LocalOrdinal> & v) {
45
size_t
size = values.size();
46
v.clear(); v.reserve(size);
47
for
(
size_t
i=0; i<size; ++i)
48
v.push_back(i);
49
50
std::sort(v.begin(),v.end(),
MueLu::CreateCmpPairs<Scalar,LocalOrdinal>
(values));
51
}
52
54
59
60
template
<
class
Scalar
=
DefaultScalar
,
61
class
LocalOrdinal
=
DefaultLocalOrdinal
,
62
class
GlobalOrdinal
=
DefaultGlobalOrdinal
,
63
class
Node
=
DefaultNode
>
64
class
AlgebraicPermutationStrategy
:
public
BaseClass
{
65
#undef MUELU_ALGEBRAICPERMUTATIONSTRATEGY_SHORT
66
#include "
MueLu_UseShortNames.hpp
"
67
public
:
68
73
75
76
78
93
void
BuildPermutation
(
const
Teuchos::RCP<Matrix> & A,
const
Teuchos::RCP<const Map>& permRowMap,
94
Level
& currentLevel,
const
FactoryBase
* genFactory)
const
;
95
97
98
99
private
:
100
};
101
102
}
// namespace MueLu
103
104
#define MUELU_ALGEBRAICPERMUTATIONSTRATEGY_SHORT
105
106
107
#endif
/* MUELU_ALGEBRAICPERMUTATIONSTRATEGY_DECL_HPP_ */
MueLu_BaseClass.hpp
MueLu_ConfigDefs.hpp
MueLu_Level.hpp
LocalOrdinal
MueLu::DefaultLocalOrdinal LocalOrdinal
Definition
MueLu_UseDefaultTypes.hpp:50
Scalar
MueLu::DefaultScalar Scalar
Definition
MueLu_UseDefaultTypes.hpp:49
GlobalOrdinal
MueLu::DefaultGlobalOrdinal GlobalOrdinal
Definition
MueLu_UseDefaultTypes.hpp:51
Node
MueLu::DefaultNode Node
Definition
MueLu_UseDefaultTypes.hpp:52
MueLu_UseShortNames.hpp
MueLu::AlgebraicPermutationStrategy
Algebraic permutation strategy.
Definition
MueLu_AlgebraicPermutationStrategy_decl.hpp:64
MueLu::AlgebraicPermutationStrategy::BuildPermutation
void BuildPermutation(const Teuchos::RCP< Matrix > &A, const Teuchos::RCP< const Map > &permRowMap, Level ¤tLevel, const FactoryBase *genFactory) const
build permutation operators
Definition
MueLu_AlgebraicPermutationStrategy_def.hpp:35
MueLu::BaseClass
Base class for MueLu classes.
Definition
MueLu_BaseClass.hpp:63
MueLu::FactoryBase
Base class for factories (e.g., R, P, and A_coarse).
Definition
MueLu_FactoryBase.hpp:60
MueLu::Level
Class that holds all level-specific information.
Definition
MueLu_Level.hpp:99
MueLu
Namespace for MueLu classes and methods.
Definition
MueLu_BrickAggregationFactory_decl.hpp:78
MueLu::sortingPermutation
void sortingPermutation(const std::vector< Scalar > &values, std::vector< LocalOrdinal > &v)
Definition
MueLu_AlgebraicPermutationStrategy_decl.hpp:44
MueLu::DefaultNode
Tpetra::KokkosClassic::DefaultNode::DefaultNodeType DefaultNode
Definition
MueLu_Details_DefaultTypes.hpp:70
MueLu::DefaultGlobalOrdinal
int DefaultGlobalOrdinal
Definition
MueLu_Details_DefaultTypes.hpp:67
MueLu::DefaultLocalOrdinal
int DefaultLocalOrdinal
Definition
MueLu_Details_DefaultTypes.hpp:60
MueLu::DefaultScalar
Tpetra::Details::DefaultTypes::scalar_type DefaultScalar
Definition
MueLu_Details_DefaultTypes.hpp:58
MueLu::CreateCmpPairs
CompPairs< Scalar, LocalOrdinal > CreateCmpPairs(const std::vector< Scalar > &v)
Definition
MueLu_AlgebraicPermutationStrategy_decl.hpp:38
MueLu::CompPairs
Definition
MueLu_AlgebraicPermutationStrategy_decl.hpp:27
MueLu::CompPairs::CompPairs
CompPairs(const std::vector< Scalar > &v)
Definition
MueLu_AlgebraicPermutationStrategy_decl.hpp:28
MueLu::CompPairs::vinternal_
std::vector< Scalar > vinternal_
Definition
MueLu_AlgebraicPermutationStrategy_decl.hpp:29
MueLu::CompPairs::operator()
bool operator()(LocalOrdinal a, LocalOrdinal b)
Definition
MueLu_AlgebraicPermutationStrategy_decl.hpp:30
src
Utils
MueLu_AlgebraicPermutationStrategy_decl.hpp
Generated by
1.17.0