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>
39 template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
42 const Teuchos::RCP<multivector_type>&
X,
43 const Teuchos::RCP<multivector_type>&
B)
51 template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
61 template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
63 leftScale(
const Teuchos::RCP<const vector_type> &
D, Teuchos::ETransp
mode)
65 const Scalar ST0 = Teuchos::ScalarTraits<Scalar>::zero();
66 const Scalar ST1 = Teuchos::ScalarTraits<Scalar>::one();
67 if (
mode == Teuchos::NO_TRANS) {
69 B_->elementWiseMultiply(
ST1, *
D, *B_,
ST0);
75 X_->elementWiseMultiply(
ST1,
R, *X_,
ST0);
81 template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
83 rightScale(
const Teuchos::RCP<const vector_type> &
D, Teuchos::ETransp
mode)
85 const Scalar ST0 = Teuchos::ScalarTraits<Scalar>::zero();
86 const Scalar ST1 = Teuchos::ScalarTraits<Scalar>::one();
87 if (
mode == Teuchos::NO_TRANS) {
91 X_->elementWiseMultiply(
ST1,
R, *X_,
ST0);
95 B_->elementWiseMultiply(
ST1, *
D, *B_,
ST0);
100 template <
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
107 "Linear problem does not have a matrix (A_).");
110 std::logic_error,
"Solution vector (X_) is unset.");
113 std::logic_error,
"RHS vector (B_) is unset.");
116 std::logic_error,
"Domain map of matrix is not the 'same as' the solution map.");
119 std::logic_error,
"Range map of matrix is not the 'same as' the RHS map.");
124 template<
class Scalar,
class LocalOrdinal,
class GlobalOrdinal,
class Node>
132 if (src ==
nullptr) {
139 return ((this->A_->getDomainMap() == src->getMatrix()->getDomainMap())
and
140 (this->A_->getRangeMap() == src->getMatrix()->getRangeMap()));
152#define TPETRA_LINEARPROBLEM_INSTANT(SCALAR,LO,GO,NODE) \
153 template class LinearProblem< SCALAR , LO , GO , NODE >;
Declaration of Tpetra::Details::Behavior, a class that describes Tpetra's behavior.
Declaration of the Tpetra::MultiVector class.
Struct that holds views of the contents of a CrsMatrix.
virtual bool checkSizes(const SrcDistObject &source) override
Compare the source and target (this) objects for compatibility.
void rightScale(const Teuchos::RCP< const vector_type > &D, Teuchos::ETransp mode=Teuchos::NO_TRANS)
Perform right scaling of a linear problem.
LinearProblem()
Default Constructor.
void leftScale(const Teuchos::RCP< const vector_type > &D, Teuchos::ETransp mode=Teuchos::NO_TRANS)
Perform left scaling of a linear problem.
void checkInput() const
Check input parameters for existence and size consistency.
Abstract base class for objects that can be the source of an Import or Export operation.
A distributed dense vector.
Namespace Tpetra contains the class and methods constituting the Tpetra library.