39 class MultiVecAdapter<Kokkos::View<Scalar**, Kokkos::LayoutLeft, ExecutionSpace> >
43 typedef Tpetra::Map<>::node_type node_t;
44 typedef Kokkos::View<Scalar**,Kokkos::LayoutLeft, ExecutionSpace> multivec_t;
45 typedef int local_ordinal_t;
46 typedef Tpetra::Map<>::global_ordinal_type global_ordinal_t;
47 typedef size_t global_size_t;
48 typedef Scalar scalar_t;
50 typedef Kokkos::View<scalar_t**, Kokkos::LayoutLeft, ExecutionSpace> kokkos_view_t;
52 friend Teuchos::RCP<MultiVecAdapter<multivec_t> > createMultiVecAdapter<> (Teuchos::RCP<multivec_t>);
53 friend Teuchos::RCP<const MultiVecAdapter<multivec_t> > createConstMultiVecAdapter<> (Teuchos::RCP<const multivec_t>);
55 static const char* name;
81 if(getComm()->getSize() == 1){
87 bool isGloballyIndexed()
const;
89 Teuchos::RCP<
const Tpetra::Map<
99 Teuchos::RCP<const Teuchos::Comm<int> >
getComm()
const
101 return Tpetra::getDefaultComm();
107 return mv_->extent(0);
114 return mv_->extent(1);
121 return mv_->extent(0);
128 return mv_->extent(1);
135 return mv_->getStride();
142 return mv_->isConstantStride();
146 Scalar * getMVPointer_impl()
const;
149 Teuchos::RCP<multivec_t> clone()
const;
180 get1dCopy (
const Teuchos::ArrayView<scalar_t>& av,
183 const Tpetra::Map<local_ordinal_t,
185 node_t> > distribution_map,
188 template<
typename KV>
190 get1dCopy_kokkos_view (
191 bool bInitialize, KV& kokkos_view,
192 [[maybe_unused]]
size_t lda,
193 [[maybe_unused]] Teuchos::Ptr<
194 const Tpetra::Map<local_ordinal_t,
201 deep_copy_or_assign_view(bInitialize, kokkos_view, *mv_, bAssigned);
218 Teuchos::ArrayRCP<scalar_t> get1dViewNonConst (
bool local =
false);
230 put1dData (
const Teuchos::ArrayView<const scalar_t>& new_data,
233 const Tpetra::Map<local_ordinal_t,
235 node_t> > distribution_map,
236 EDistribution)
const;
238 template<
typename KV>
240 put1dData_kokkos_view (
242 [[maybe_unused]]
size_t lda,
243 [[maybe_unused]] Teuchos::Ptr<
244 const Tpetra::Map<local_ordinal_t,
250 deep_copy_or_assign_view(*mv_, kokkos_new_data);
253 template<
typename KV,
typename host_ordinal_type_array>
255 gather (KV& kokkos_new_view,
256 host_ordinal_type_array &perm_g2l,
257 host_ordinal_type_array &recvCountRows,
258 host_ordinal_type_array &recvDisplRows,
259 EDistribution distribution )
const;
261 template<
typename KV,
typename host_ordinal_type_array>
263 scatter (KV& kokkos_old_view,
264 host_ordinal_type_array &perm_g2l,
265 host_ordinal_type_array &recvCountRows,
266 host_ordinal_type_array &recvDisplRows,
267 EDistribution distribution )
const;
270 std::string description ()
const;
274 describe (Teuchos::FancyOStream& os,
275 const Teuchos::EVerbosityLevel verbLevel =
276 Teuchos::Describable::verbLevel_default)
const;
281 Teuchos::RCP<multivec_t>
mv_;
284 typedef Tpetra::Export<local_ordinal_t, global_ordinal_t, node_t>
export_type;
287 typedef Tpetra::Import<local_ordinal_t, global_ordinal_t, node_t>
import_type;