10 #ifndef TPETRA_BLOCKVECTOR_DEF_HPP
11 #define TPETRA_BLOCKVECTOR_DEF_HPP
15 template <
class Scalar,
class LO,
class GO,
class Node>
20 template <
class Scalar,
class LO,
class GO,
class Node>
23 const Teuchos::DataAccess copyOrView)
26 template <
class Scalar,
class LO,
class GO,
class Node>
31 template <
class Scalar,
class LO,
class GO,
class Node>
36 :
base_type(meshMap, pointMap, blockSize, 1) {}
38 template <
class Scalar,
class LO,
class GO,
class Node>
44 TEUCHOS_TEST_FOR_EXCEPTION(
46 "Tpetra::BlockVector: Input MultiVector has "
50 template <
class Scalar,
class LO,
class GO,
class Node>
57 template <
class Scalar,
class LO,
class GO,
class Node>
63 :
base_type(X, newMeshMap, newPointMap, offset) {}
65 template <
class Scalar,
class LO,
class GO,
class Node>
72 template <
class Scalar,
class LO,
class GO,
class Node>
79 template <
class Scalar,
class LO,
class GO,
class Node>
82 return ((
base_type*)
this)->replaceLocalValues(localRowIndex, 0, vals);
85 template <
class Scalar,
class LO,
class GO,
class Node>
88 return ((
base_type*)
this)->replaceGlobalValues(globalRowIndex, 0, vals);
91 template <
class Scalar,
class LO,
class GO,
class Node>
94 return ((
base_type*)
this)->sumIntoLocalValues(localRowIndex, 0, vals);
97 template <
class Scalar,
class LO,
class GO,
class Node>
100 return ((
base_type*)
this)->sumIntoLocalValues(globalRowIndex, 0, vals);
103 template <
class Scalar,
class LO,
class GO,
class Node>
104 typename BlockVector<Scalar, LO, GO, Node>::const_little_host_vec_type
107 return ((
const base_type*)
this)->getLocalBlockHost(localRowIndex, 0, Access::ReadOnly);
110 template <
class Scalar,
class LO,
class GO,
class Node>
111 typename BlockVector<Scalar, LO, GO, Node>::little_host_vec_type
114 return ((base_type*)
this)->getLocalBlockHost(localRowIndex, 0, Access::ReadWrite);
117 template <
class Scalar,
class LO,
class GO,
class Node>
118 typename BlockVector<Scalar, LO, GO, Node>::little_host_vec_type
121 return ((base_type*)
this)->getLocalBlockHost(localRowIndex, 0, Access::OverwriteAll);
131 #define TPETRA_BLOCKVECTOR_INSTANT(S, LO, GO, NODE) \
132 template class BlockVector<S, LO, GO, NODE>;
134 #endif // TPETRA_BLOCKVECTOR_DEF_HPP
bool sumIntoGlobalValues(const GO globalRowIndex, const Scalar vals[])
Sum into all values at the given mesh point, using a global index.
size_t getNumVectors() const
Number of columns in the multivector.
bool sumIntoLocalValues(const LO localRowIndex, const Scalar vals[])
Sum into all values at the given mesh point, using a local index.
MultiVector for multiple degrees of freedom per mesh point.
vec_type getVectorView()
Get a Tpetra::Vector that views this BlockVector's data.
Teuchos::RCP< Vector< Scalar, LocalOrdinal, GlobalOrdinal, Node > > getVectorNonConst(const size_t j)
Return a Vector which is a nonconst view of column j.
const_little_host_vec_type getLocalBlockHost(const LO localRowIndex, Access::ReadOnlyStruct) const
Get a view of the degrees of freedom at the given mesh point, using a local index.
bool replaceLocalValues(const LO localRowIndex, const Scalar vals[])
Replace all values at the given mesh point, using a local index.
A distributed dense vector.
bool replaceGlobalValues(const GO globalRowIndex, const Scalar vals[])
Replace all values at the given mesh point, using a global index.
BlockVector()
Default constructor.
Vector for multiple degrees of freedom per mesh point.