10 #ifndef TPETRA_LINEARPROBLEM_DEF_HPP
11 #define TPETRA_LINEARPROBLEM_DEF_HPP
21 #include "Teuchos_DataAccess.hpp"
22 #include "Teuchos_TestForException.hpp"
24 #include "Tpetra_MultiVector.hpp"
29 template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
38 template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
41 const Teuchos::RCP<multivector_type>& X,
42 const Teuchos::RCP<multivector_type>& B)
49 template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
58 template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
60 leftScale(
const Teuchos::RCP<const vector_type>& D, Teuchos::ETransp mode) {
61 const Scalar ST0 = Teuchos::ScalarTraits<Scalar>::zero();
62 const Scalar ST1 = Teuchos::ScalarTraits<Scalar>::one();
63 if (mode == Teuchos::NO_TRANS) {
65 B_->elementWiseMultiply(ST1, *D, *B_, ST0);
70 X_->elementWiseMultiply(ST1, R, *X_, ST0);
76 template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
78 rightScale(
const Teuchos::RCP<const vector_type>& D, Teuchos::ETransp mode) {
79 const Scalar ST0 = Teuchos::ScalarTraits<Scalar>::zero();
80 const Scalar ST1 = Teuchos::ScalarTraits<Scalar>::one();
81 if (mode == Teuchos::NO_TRANS) {
85 X_->elementWiseMultiply(ST1, R, *X_, ST0);
88 B_->elementWiseMultiply(ST1, *D, *B_, ST0);
93 template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
96 const char tfecfFuncName[] =
"checkInput: ";
98 TEUCHOS_TEST_FOR_EXCEPTION_CLASS_FUNC(A_ == Teuchos::null, std::runtime_error,
99 "Linear problem does not have a matrix (A_).");
101 TEUCHOS_TEST_FOR_EXCEPTION_CLASS_FUNC(X_ == Teuchos::null,
102 std::logic_error,
"Solution vector (X_) is unset.");
104 TEUCHOS_TEST_FOR_EXCEPTION_CLASS_FUNC(B_ == Teuchos::null,
105 std::logic_error,
"RHS vector (B_) is unset.");
107 TEUCHOS_TEST_FOR_EXCEPTION_CLASS_FUNC(!A_->getRowMap()->isSameAs(*(X_->getMap())),
108 std::logic_error,
"Domain map of matrix is not the 'same as' the solution map.");
110 TEUCHOS_TEST_FOR_EXCEPTION_CLASS_FUNC(!A_->getRowMap()->isSameAs(*(B_->getMap())),
111 std::logic_error,
"Range map of matrix is not the 'same as' the RHS map.");
116 template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
122 const LP* src =
dynamic_cast<const LP*
>(&sourceObj);
123 if (src ==
nullptr) {
129 return ((this->A_->getDomainMap() == src->getMatrix()->getDomainMap()) and
130 (this->A_->getRangeMap() == src->getMatrix()->getRangeMap()));
142 #define TPETRA_LINEARPROBLEM_INSTANT(SCALAR, LO, GO, NODE) \
143 template class LinearProblem<SCALAR, LO, GO, NODE>;
145 #endif // TPETRA_LINEARPROBLEM_DEF_HPP
Class that encapulates linear problem (Ax = b).
void checkInput() const
Check input parameters for existence and size consistency.
void rightScale(const Teuchos::RCP< const vector_type > &D, Teuchos::ETransp mode=Teuchos::NO_TRANS)
Perform right scaling of a linear problem.
Declaration of the Tpetra::MultiVector class.
LinearProblem()
Default Constructor.
virtual bool checkSizes(const SrcDistObject &source) override
Compare the source and target (this) objects for compatibility.
Abstract base class for objects that can be the source of an Import or Export operation.
A parallel distribution of indices over processes.
A distributed dense vector.
void leftScale(const Teuchos::RCP< const vector_type > &D, Teuchos::ETransp mode=Teuchos::NO_TRANS)
Perform left scaling of a linear problem.
void reciprocal(const MultiVector< Scalar, LocalOrdinal, GlobalOrdinal, Node > &A)
Put element-wise reciprocal values of input Multi-vector in target, this(i,j) = 1/A(i,j).
Declaration of Tpetra::Details::Behavior, a class that describes Tpetra's behavior.