42 #ifndef TPETRA_FEMULTIVECTOR_DECL_HPP
43 #define TPETRA_FEMULTIVECTOR_DECL_HPP
59 template <
class Scalar,
64 public MultiVector<Scalar, LocalOrdinal, GlobalOrdinal, Node>
75 using scalar_type = Scalar;
79 using global_ordinal_type = GlobalOrdinal;
110 FEMultiVector () =
delete;
134 FEMultiVector (
const Teuchos::RCP<const map_type>& map,
135 const Teuchos::RCP<
const Import<local_ordinal_type, global_ordinal_type, node_type>>& importer,
136 const size_t numVecs,
137 const bool zeroOut =
true);
140 FEMultiVector (
const FEMultiVector<Scalar, LocalOrdinal, GlobalOrdinal, Node>&) =
delete;
143 FEMultiVector (FEMultiVector<Scalar, LocalOrdinal, GlobalOrdinal, Node>&&) =
delete;
147 operator= (
const FEMultiVector<Scalar, LocalOrdinal, GlobalOrdinal, Node>&) =
delete;
151 operator= (FEMultiVector<Scalar, LocalOrdinal, GlobalOrdinal, Node>&&) =
delete;
162 virtual ~FEMultiVector () =
default;
176 void globalAssemble ();
192 void switchActiveMultiVector();
199 void replaceMap (
const Teuchos::RCP<const map_type>& map);
204 FE_ACTIVE_OWNED_PLUS_SHARED,
209 Teuchos::RCP<base_type> inactiveMultiVector_;
216 Teuchos::RCP<FEWhichActive> activeMultiVector_;
219 Teuchos::RCP<const Import<local_ordinal_type, global_ordinal_type, node_type>> importer_;
224 #endif // TPETRA_FEMULTIVECTOR_DECL_HPP