49 #ifndef XPETRA_STRIDEDMAPFACTORY_DEF_HPP
50 #define XPETRA_STRIDEDMAPFACTORY_DEF_HPP
65 template<
class LocalOrdinal,
class GlobalOrdinal,
class Node>
72 #ifdef TPETRA_ENABLE_DEPRECATED_CODE
73 template<
class LocalOrdinal,
class GlobalOrdinal,
class Node>
79 GlobalOrdinal indexBase,
80 std::vector<size_t>& stridingInfo,
82 LocalOrdinal stridedBlockId,
87 return Build(lib, numGlobalElements, indexBase, stridingInfo, comm, stridedBlockId, offset, lg);
89 #endif // TPETRA_ENABLE_DEPRECATED_CODE
92 template<
class LocalOrdinal,
class GlobalOrdinal,
class Node>
93 RCP<Xpetra::StridedMap<LocalOrdinal, GlobalOrdinal, Node>>
97 GlobalOrdinal indexBase,
98 std::vector<size_t>& stridingInfo,
100 LocalOrdinal stridedBlockId,
101 GlobalOrdinal offset,
108 #ifdef TPETRA_ENABLE_DEPRECATED_CODE
109 template<
class LocalOrdinal,
class GlobalOrdinal,
class Node>
115 size_t numLocalElements,
116 GlobalOrdinal indexBase,
117 std::vector<size_t>& stridingInfo,
119 LocalOrdinal stridedBlockId,
120 GlobalOrdinal offset,
123 return Build(lib, numGlobalElements, numLocalElements, indexBase, stridingInfo, comm, stridedBlockId, offset);
125 #endif // TPETRA_ENABLE_DEPRECATED_CODE
128 template<
class LocalOrdinal,
class GlobalOrdinal,
class Node>
129 RCP<Xpetra::StridedMap<LocalOrdinal,GlobalOrdinal,Node>>
133 size_t numLocalElements,
134 GlobalOrdinal indexBase,
135 std::vector<size_t>& stridingInfo,
137 LocalOrdinal stridedBlockId,
138 GlobalOrdinal offset)
140 return rcp(
new StridedMap(lib, numGlobalElements, numLocalElements, indexBase, stridingInfo, comm, stridedBlockId, offset));
144 template<
class LocalOrdinal,
class GlobalOrdinal,
class Node>
148 std::vector<size_t>& stridingInfo,
149 LocalOrdinal stridedBlockId,
150 GlobalOrdinal offset)
156 template<
class LocalOrdinal,
class GlobalOrdinal,
class Node>
163 "Xpetra::StridedMapFactory::Build: constructor expects stridedBlockId > -1.");
167 "Xpetra::StridedMapFactory::Build: constructor expects a full map (stridedBlockId == -1).");
175 size_t nStridedOffset = 0;
178 nStridedOffset += stridingInfo[ j ];
183 std::vector<GlobalOrdinal> subBlockDofGids(numMyBlockDofs);
186 LocalOrdinal ind = 0;
191 subBlockDofGids[ ind++ ] = *it;
199 subBlockDofGids_view,
207 template<
class LocalOrdinal,
class GlobalOrdinal,
class Node>
218 for(LocalOrdinal i = 0; i < N; i++)
220 newElements[ i ] = oldElements[ i ];
230 #ifdef TPETRA_ENABLE_DEPRECATED_CODE
231 template<
class LocalOrdinal,
class GlobalOrdinal,
class Node>
238 GlobalOrdinal indexBase,
239 std::vector<size_t>& stridingInfo,
241 LocalOrdinal stridedBlockId,
242 GlobalOrdinal offset,
245 return Build(lib, numGlobalElements, elementList, indexBase, stridingInfo, comm, stridedBlockId, offset);
247 #endif // TPETRA_ENABLE_DEPRECATED_CODE
250 template<
class LocalOrdinal,
class GlobalOrdinal,
class Node>
251 RCP<Xpetra::StridedMap<LocalOrdinal,GlobalOrdinal,Node>>
256 GlobalOrdinal indexBase,
257 std::vector<size_t>& stridingInfo,
259 LocalOrdinal stridedBlockId,
262 return rcp(
new StridedMap(lib, numGlobalElements, elementList, indexBase, stridingInfo, comm, stridedBlockId));
271 #endif // __XPETRA_STRIDEDMAPFACTORY_DEF_HPP__
LocalOrdinal getStridedBlockId() const
size_t GID2StridingBlockId(GlobalOrdinal gid) const
#define TEUCHOS_TEST_FOR_EXCEPTION(throw_exception_test, Exception, msg)
Teuchos::ArrayView< const GlobalOrdinal > getNodeElementList() const
Return a list of the global indices owned by this node.
Exception throws to report errors in the internal logical of the program.
virtual GlobalOrdinal getIndexBase() const =0
The index base for this Map.
Teuchos::RCP< const Teuchos::Comm< int > > getComm() const
Get the Comm object for this Map.
TEUCHOS_DEPRECATED RCP< T > rcp(T *p, Dealloc_T dealloc, bool owns_mem)
size_t getFixedBlockSize() const
size_t getNodeNumElements() const
Returns the number of elements belonging to the calling node.
size_t global_size_t
Global size_t object.
GlobalOrdinal getIndexBase() const
Returns the index base for this Map.
global_size_t getGlobalNumElements() const
Returns the number of elements in this Map.
std::vector< size_t > getStridingData() const
UnderlyingLib lib() const
Get the library used by this object (Tpetra or Epetra?)
StridedMapFactory()
Private constructor. This is a static class.
#define XPETRA_MONITOR(funcName)
static RCP< Xpetra::StridedMap< LocalOrdinal, GlobalOrdinal, Node > > Build(UnderlyingLib lib, global_size_t numGlobalElements, GlobalOrdinal indexBase, std::vector< size_t > &stridingInfo, const Teuchos::RCP< const Teuchos::Comm< int >> &comm, LocalOrdinal stridedBlockId=-1, GlobalOrdinal offset=0, LocalGlobal lg=Xpetra::GloballyDistributed)
Map constructor with Xpetra-defined contiguous uniform distribution.
Class that stores a strided map.