Xpetra Version of the Day
Loading...
Searching...
No Matches
Xpetra_EpetraIntMultiVector.cpp
Go to the documentation of this file.
1// @HEADER
2// *****************************************************************************
3// Xpetra: A linear algebra interface package
4//
5// Copyright 2012 NTESS and the Xpetra contributors.
6// SPDX-License-Identifier: BSD-3-Clause
7// *****************************************************************************
8// @HEADER
9
13
14namespace Xpetra {
15
16// TODO: move that elsewhere
17template <class GlobalOrdinal, class Node>
22
23template <class GlobalOrdinal, class Node>
26 return *tX.getEpetra_IntMultiVector();
27}
28//
29
30#ifndef XPETRA_EPETRA_NO_32BIT_GLOBAL_INDICES
31#ifdef HAVE_XPETRA_TPETRA
32#include "TpetraCore_config.h"
33#if ((defined(EPETRA_HAVE_OMP) && !defined(HAVE_TPETRA_INST_OPENMP)) || \
34 (!defined(EPETRA_HAVE_OMP) && !defined(HAVE_TPETRA_INST_SERIAL)))
35template class EpetraIntMultiVectorT<int, Xpetra::EpetraNode>;
38#endif
39#ifdef HAVE_TPETRA_INST_SERIAL
41template Epetra_IntMultiVector &toEpetra<int, Tpetra::KokkosCompat::KokkosSerialWrapperNode>(MultiVector<int, int, int, Tpetra::KokkosCompat::KokkosSerialWrapperNode> &);
42template const Epetra_IntMultiVector &toEpetra<int, Tpetra::KokkosCompat::KokkosSerialWrapperNode>(const MultiVector<int, int, int, Tpetra::KokkosCompat::KokkosSerialWrapperNode> &);
43#endif
44#ifdef HAVE_TPETRA_INST_PTHREAD
46template Epetra_IntMultiVector &toEpetra<int, Tpetra::KokkosCompat::KokkosThreadsWrapperNode>(MultiVector<int, int, int, Tpetra::KokkosCompat::KokkosThreadsWrapperNode> &);
47template const Epetra_IntMultiVector &toEpetra<int, Tpetra::KokkosCompat::KokkosThreadsWrapperNode>(const MultiVector<int, int, int, Tpetra::KokkosCompat::KokkosThreadsWrapperNode> &);
48#endif
49#ifdef HAVE_TPETRA_INST_OPENMP
51template Epetra_IntMultiVector &toEpetra<int, Tpetra::KokkosCompat::KokkosOpenMPWrapperNode>(MultiVector<int, int, int, Tpetra::KokkosCompat::KokkosOpenMPWrapperNode> &);
52template const Epetra_IntMultiVector &toEpetra<int, Tpetra::KokkosCompat::KokkosOpenMPWrapperNode>(const MultiVector<int, int, int, Tpetra::KokkosCompat::KokkosOpenMPWrapperNode> &);
53#endif
54#ifdef HAVE_TPETRA_INST_CUDA
55typedef Tpetra::KokkosCompat::KokkosCudaWrapperNode default_node_type;
57template Epetra_IntMultiVector &toEpetra<int, default_node_type>(MultiVector<int, int, int, default_node_type> &);
58template const Epetra_IntMultiVector &toEpetra<int, default_node_type>(const MultiVector<int, int, int, default_node_type> &);
59#endif
60#ifdef HAVE_TPETRA_INST_HIP
61typedef Tpetra::KokkosCompat::KokkosHIPWrapperNode default_node_type;
63template Epetra_IntMultiVector &toEpetra<int, default_node_type>(MultiVector<int, int, int, default_node_type> &);
64template const Epetra_IntMultiVector &toEpetra<int, default_node_type>(const MultiVector<int, int, int, default_node_type> &);
65#endif
66#else
67// Tpetra is disabled and Kokkos not available: use dummy node type
68typedef Xpetra::EpetraNode default_node_type;
70template Epetra_IntMultiVector &toEpetra<int, default_node_type>(MultiVector<int, int, int, default_node_type> &);
71template const Epetra_IntMultiVector &toEpetra<int, default_node_type>(const MultiVector<int, int, int, default_node_type> &);
72#endif // HAVE_XPETRA_TPETRA
73#endif
74
75#ifndef XPETRA_EPETRA_NO_64BIT_GLOBAL_INDICES
76#ifdef HAVE_XPETRA_TPETRA
77#include "TpetraCore_config.h"
78#if ((defined(EPETRA_HAVE_OMP) && !defined(HAVE_TPETRA_INST_OPENMP)) || \
79 (!defined(EPETRA_HAVE_OMP) && !defined(HAVE_TPETRA_INST_SERIAL)))
83#endif
84#ifdef HAVE_TPETRA_INST_SERIAL
86template Epetra_IntMultiVector &toEpetra<long long, Tpetra::KokkosCompat::KokkosSerialWrapperNode>(MultiVector<int, int, long long, Tpetra::KokkosCompat::KokkosSerialWrapperNode> &);
87template const Epetra_IntMultiVector &toEpetra<long long, Tpetra::KokkosCompat::KokkosSerialWrapperNode>(const MultiVector<int, int, long long, Tpetra::KokkosCompat::KokkosSerialWrapperNode> &);
88#endif
89#ifdef HAVE_TPETRA_INST_PTHREAD
91template Epetra_IntMultiVector &toEpetra<long long, Tpetra::KokkosCompat::KokkosThreadsWrapperNode>(MultiVector<int, int, long long, Tpetra::KokkosCompat::KokkosThreadsWrapperNode> &);
92template const Epetra_IntMultiVector &toEpetra<long long, Tpetra::KokkosCompat::KokkosThreadsWrapperNode>(const MultiVector<int, int, long long, Tpetra::KokkosCompat::KokkosThreadsWrapperNode> &);
93#endif
94#ifdef HAVE_TPETRA_INST_OPENMP
96template Epetra_IntMultiVector &toEpetra<long long, Tpetra::KokkosCompat::KokkosOpenMPWrapperNode>(MultiVector<int, int, long long, Tpetra::KokkosCompat::KokkosOpenMPWrapperNode> &);
97template const Epetra_IntMultiVector &toEpetra<long long, Tpetra::KokkosCompat::KokkosOpenMPWrapperNode>(const MultiVector<int, int, long long, Tpetra::KokkosCompat::KokkosOpenMPWrapperNode> &);
98#endif
99#ifdef HAVE_TPETRA_INST_CUDA
100typedef Tpetra::KokkosCompat::KokkosCudaWrapperNode default_node_type;
102template Epetra_IntMultiVector &toEpetra<long long, default_node_type>(MultiVector<int, int, long long, default_node_type> &);
103template const Epetra_IntMultiVector &toEpetra<long long, default_node_type>(const MultiVector<int, int, long long, default_node_type> &);
104#endif
105#ifdef HAVE_TPETRA_INST_HIP
106typedef Tpetra::KokkosCompat::KokkosHIPWrapperNode default_node_type;
108template Epetra_IntMultiVector &toEpetra<long long, default_node_type>(MultiVector<int, int, long long, default_node_type> &);
109template const Epetra_IntMultiVector &toEpetra<long long, default_node_type>(const MultiVector<int, int, long long, default_node_type> &);
110#endif
111#else
112// Tpetra is disabled and Kokkos not available: use dummy node type
113typedef Xpetra::EpetraNode default_node_type;
115template Epetra_IntMultiVector &toEpetra<long long, default_node_type>(MultiVector<int, int, long long, default_node_type> &);
116template const Epetra_IntMultiVector &toEpetra<long long, default_node_type>(const MultiVector<int, int, long long, default_node_type> &);
117#endif // HAVE_XPETRA_TPETRA
118#endif
119
120} // namespace Xpetra
#define XPETRA_DYNAMIC_CAST(type, obj, newObj, exceptionMsg)
Tpetra::KokkosCompat::KokkosSerialWrapperNode EpetraNode
const Epetra_CrsGraph & toEpetra(const RCP< const CrsGraph< int, GlobalOrdinal, Node > > &graph)
template const Epetra_CrsGraph & toEpetra< long long, Xpetra::EpetraNode >(const RCP< const CrsGraph< int, long long, Xpetra::EpetraNode > > &graph)
template const Epetra_CrsGraph & toEpetra< int, Xpetra::EpetraNode >(const RCP< const CrsGraph< int, int, Xpetra::EpetraNode > > &graph)