72#undef MUELU_UTILITIESBASE_SHORT
75 typedef typename Teuchos::ScalarTraits<Scalar>::magnitudeType
Magnitude;
77 static RCP<Matrix>
Crs2Op(RCP<CrsMatrix> Op);
118 static RCP<Vector>
GetMatrixDiagonalInverse(
const Matrix& A,
Magnitude tol = Teuchos::ScalarTraits<Scalar>::eps() * 100,
Scalar valReplacement = Teuchos::ScalarTraits<Scalar>::zero(),
const bool doLumped =
false);
127 Magnitude tol = Teuchos::ScalarTraits<Scalar>::magnitude(Teuchos::ScalarTraits<Scalar>::zero()),
128 Scalar valReplacement = Teuchos::ScalarTraits<Scalar>::zero(),
129 const bool replaceSingleEntryRowWithZero =
false,
130 const bool useAverageAbsDiagVal =
false);
140 static Teuchos::RCP<Vector>
GetMatrixMaxMinusOffDiagonal(
const Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>& A,
const Xpetra::Vector<LocalOrdinal, LocalOrdinal, GlobalOrdinal, Node>& BlockNumber);
149 static Teuchos::RCP<Vector>
GetInverse(Teuchos::RCP<const Vector> v,
Magnitude tol = Teuchos::ScalarTraits<Scalar>::eps() * 100,
Scalar valReplacement = Teuchos::ScalarTraits<Scalar>::zero());
170 static RCP<Xpetra::Vector<Magnitude, LocalOrdinal, GlobalOrdinal, Node>>
186 static Teuchos::Array<Magnitude>
ResidualNorm(
const Xpetra::Operator<Scalar, LocalOrdinal, GlobalOrdinal, Node>& Op,
const MultiVector& X,
const MultiVector& RHS);
188 static Teuchos::Array<Magnitude>
ResidualNorm(
const Xpetra::Operator<Scalar, LocalOrdinal, GlobalOrdinal, Node>& Op,
const MultiVector& X,
const MultiVector& RHS, MultiVector& Resid);
190 static RCP<MultiVector>
Residual(
const Xpetra::Operator<Scalar, LocalOrdinal, GlobalOrdinal, Node>& Op,
const MultiVector& X,
const MultiVector& RHS);
192 static void Residual(
const Xpetra::Operator<Scalar, LocalOrdinal, GlobalOrdinal, Node>& Op,
const MultiVector& X,
const MultiVector& RHS, MultiVector& Resid);
207 LocalOrdinal niters = 10,
Magnitude tolerance = 1e-2,
Magnitude diagonalReplacementTol = Teuchos::ScalarTraits<Scalar>::eps() * 100,
bool verbose =
false,
unsigned int seed = 123);
221 LocalOrdinal niters = 10,
Magnitude tolerance = 1e-2,
bool verbose =
false,
unsigned int seed = 123);
223 static RCP<Teuchos::FancyOStream>
MakeFancy(std::ostream& os);
229 static typename Teuchos::ScalarTraits<Scalar>::magnitudeType
Distance2(
const Teuchos::Array<Teuchos::ArrayRCP<const Scalar>>& v,
LocalOrdinal i0,
LocalOrdinal i1);
235 static typename Teuchos::ScalarTraits<Scalar>::magnitudeType
Distance2(
const Teuchos::ArrayView<double>& weight,
const Teuchos::Array<Teuchos::ArrayRCP<const Scalar>>& v,
LocalOrdinal i0,
LocalOrdinal i1);
249 static Teuchos::ArrayRCP<const bool>
DetectDirichletRows(
const Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>& A,
const Magnitude& tol = Teuchos::ScalarTraits<Magnitude>::zero(),
bool count_twos_as_dirichlet =
false);
258 static Kokkos::View<bool*, typename NO::device_type::memory_space>
DetectDirichletRows_kokkos(
const Matrix& A,
const Magnitude& tol = Teuchos::ScalarTraits<
typename Teuchos::ScalarTraits<SC>::magnitudeType>::zero(),
const bool count_twos_as_dirichlet =
false);
259 static Kokkos::View<bool*, typename Kokkos::HostSpace>
DetectDirichletRows_kokkos_host(
const Matrix& A,
const Magnitude& tol = Teuchos::ScalarTraits<
typename Teuchos::ScalarTraits<SC>::magnitudeType>::zero(),
const bool count_twos_as_dirichlet =
false);
273 static Teuchos::ArrayRCP<const bool>
DetectDirichletRowsExt(
const Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>& A,
bool& bHasZeroDiagonal,
const Magnitude& tol = Teuchos::ScalarTraits<Scalar>::zero());
280 static void EnforceInitialCondition(
const Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>& A,
const Xpetra::MultiVector<Scalar, LocalOrdinal, GlobalOrdinal, Node>& RHS, Xpetra::MultiVector<Scalar, LocalOrdinal, GlobalOrdinal, Node>& InitialGuess,
const Magnitude& tol = Teuchos::ScalarTraits<Magnitude>::zero(),
const bool count_twos_as_dirichlet =
false);
289 static void FindNonZeros(
const Teuchos::ArrayRCP<const Scalar> vals,
290 Teuchos::ArrayRCP<bool> nonzeros);
298 static void FindNonZeros(
const typename Xpetra::MultiVector<Scalar, LocalOrdinal, GlobalOrdinal, Node>::dual_view_type::t_dev_const_um vals,
299 Kokkos::View<bool*, typename Node::device_type> nonzeros);
310 const Teuchos::ArrayRCP<bool>& dirichletRows,
311 Teuchos::ArrayRCP<bool> dirichletCols,
312 Teuchos::ArrayRCP<bool> dirichletDomain);
322 const Kokkos::View<bool*, typename Node::device_type>& dirichletRows,
323 Kokkos::View<bool*, typename Node::device_type> dirichletCols,
324 Kokkos::View<bool*, typename Node::device_type> dirichletDomain);
337 static void ApplyRowSumCriterion(
const Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>& A,
const Magnitude rowSumTol, Teuchos::ArrayRCP<bool>& dirichletRows);
339 static void ApplyRowSumCriterion(
const Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>& A,
const Xpetra::Vector<LocalOrdinal, LocalOrdinal, GlobalOrdinal, Node>& BlockNumber,
const Magnitude rowSumTol, Teuchos::ArrayRCP<bool>& dirichletRows);
342 const typename Teuchos::ScalarTraits<Scalar>::magnitudeType rowSumTol,
343 Kokkos::View<bool*, typename NO::device_type::memory_space>& dirichletRows);
346 const typename Teuchos::ScalarTraits<Scalar>::magnitudeType rowSumTol,
347 Kokkos::View<bool*, Kokkos::HostSpace>& dirichletRows);
350 const Xpetra::Vector<LocalOrdinal, LocalOrdinal, GlobalOrdinal, Node>& BlockNumber,
351 const typename Teuchos::ScalarTraits<Scalar>::magnitudeType rowSumTol,
352 Kokkos::View<bool*, typename NO::device_type::memory_space>& dirichletRows);
355 const Xpetra::Vector<LocalOrdinal, LocalOrdinal, GlobalOrdinal, Node>& BlockNumber,
356 const typename Teuchos::ScalarTraits<Scalar>::magnitudeType rowSumTol,
357 Kokkos::View<bool*, Kokkos::HostSpace>& dirichletRows);
369 static Teuchos::ArrayRCP<const bool>
DetectDirichletCols(
const Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>& A,
370 const Teuchos::ArrayRCP<const bool>& dirichletRows);
382 static Kokkos::View<bool*, typename NO::device_type>
DetectDirichletCols(
const Matrix& A,
const Kokkos::View<const bool*, typename NO::device_type>& dirichletRows);
388 static Scalar Frobenius(
const Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>& A,
const Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>& B);
404 static void FindDirichletRows(Teuchos::RCP<Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>>& A,
405 std::vector<LocalOrdinal>& dirichletRows,
bool count_twos_as_dirichlet =
false);
409 static void ApplyOAZToMatrixRows(Teuchos::RCP<Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>>& A,
410 const std::vector<LocalOrdinal>& dirichletRows);
414 static void ApplyOAZToMatrixRows(Teuchos::RCP<Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>>& A,
415 const Teuchos::ArrayRCP<const bool>& dirichletRows);
417 static void ApplyOAZToMatrixRows(RCP<Matrix>& A,
const Kokkos::View<const bool*, typename Node::device_type>& dirichletRows);
421 static void ZeroDirichletRows(Teuchos::RCP<Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>>& A,
422 const std::vector<LocalOrdinal>& dirichletRows,
423 Scalar replaceWith = Teuchos::ScalarTraits<Scalar>::zero());
427 static void ZeroDirichletRows(Teuchos::RCP<Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>>& A,
428 const Teuchos::ArrayRCP<const bool>& dirichletRows,
429 Scalar replaceWith = Teuchos::ScalarTraits<Scalar>::zero());
433 static void ZeroDirichletRows(Teuchos::RCP<Xpetra::MultiVector<Scalar, LocalOrdinal, GlobalOrdinal, Node>>& X,
434 const Teuchos::ArrayRCP<const bool>& dirichletRows,
435 Scalar replaceWith = Teuchos::ScalarTraits<Scalar>::zero());
437 static void ZeroDirichletRows(RCP<Matrix>& A,
const Kokkos::View<const bool*, typename NO::device_type>& dirichletRows, SC replaceWith = Teuchos::ScalarTraits<SC>::zero());
439 static void ZeroDirichletRows(RCP<MultiVector>& X,
const Kokkos::View<const bool*, typename NO::device_type>& dirichletRows, SC replaceWith = Teuchos::ScalarTraits<SC>::zero());
444 const Teuchos::ArrayRCP<const bool>& dirichletCols,
445 Scalar replaceWith = Teuchos::ScalarTraits<Scalar>::zero());
447 static void ZeroDirichletCols(RCP<Matrix>& A,
const Kokkos::View<const bool*, typename NO::device_type>& dirichletCols, SC replaceWith = Teuchos::ScalarTraits<SC>::zero());
451 Teuchos::RCP<Xpetra::Vector<int, LocalOrdinal, GlobalOrdinal, Node>>&
isDirichletRow,
452 Teuchos::RCP<Xpetra::Vector<int, LocalOrdinal, GlobalOrdinal, Node>>& isDirichletCol);
456 static RCP<Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>>
ReplaceNonZerosWithOnes(
const RCP<Matrix>& original);
459 static RCP<Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>>
SPAI(
const RCP<Matrix>& original);
464 static RCP<const Xpetra::BlockedMap<LocalOrdinal, GlobalOrdinal, Node>>
GeneratedBlockedTargetMap(
const Xpetra::BlockedMap<LocalOrdinal, GlobalOrdinal, Node>& sourceBlockedMap,
465 const Xpetra::Import<LocalOrdinal, GlobalOrdinal, Node>& Importer);
469 static bool MapsAreNested(
const Xpetra::Map<LocalOrdinal, GlobalOrdinal, Node>& rowMap,
const Xpetra::Map<LocalOrdinal, GlobalOrdinal, Node>& colMap);
474 static RCP<Xpetra::Vector<LocalOrdinal, LocalOrdinal, GlobalOrdinal, Node>>
CuthillMcKee(
const Matrix& Op);
478 static RCP<Xpetra::Vector<LocalOrdinal, LocalOrdinal, GlobalOrdinal, Node>>
ReverseCuthillMcKee(
const Matrix& Op);
480 static void TripleMatrixProduct(
const Teuchos::RCP<Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>>& R,
481 const Teuchos::RCP<Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>>& A,
482 const Teuchos::RCP<Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>>& P,
483 Teuchos::RCP<Xpetra::Matrix<Scalar, LocalOrdinal, GlobalOrdinal, Node>>& Ac,
484 const Teuchos::ParameterList& pL,
486 Teuchos::RCP<Teuchos::ParameterList>& APparams,
487 Teuchos::RCP<Teuchos::ParameterList>& RAPparams,
488 Level* coarseLevel =
nullptr);