00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049 #ifndef XPETRA_STRIDEDMAPFACTORY_HPP
00050 #define XPETRA_STRIDEDMAPFACTORY_HPP
00051
00052 #include <Kokkos_DefaultNode.hpp>
00053
00054 #include "Xpetra_ConfigDefs.hpp"
00055 #include "Xpetra_Exceptions.hpp"
00056
00057 #include "Xpetra_StridedMap.hpp"
00058
00059
00060
00061 namespace Xpetra {
00062
00063 template <class LocalOrdinal = StridedMap<>::local_ordinal_type,
00064 class GlobalOrdinal =
00065 typename StridedMap<LocalOrdinal>::global_ordinal_type,
00066 class Node =
00067 typename StridedMap<LocalOrdinal, GlobalOrdinal>::node_type>
00068 class StridedMapFactory {
00069 #undef XPETRA_STRIDEDMAPFACTORY_SHORT
00070 #include "Xpetra_UseShortNamesOrdinal.hpp"
00071
00072 private:
00074 StridedMapFactory() {}
00075
00076 public:
00077
00078 static Teuchos::RCP<Node> defaultArgNode() {
00079
00080
00081
00082
00083
00084 return KokkosClassic::Details::getNode<Node>();
00085 }
00086
00088 static RCP<StridedMap> Build(UnderlyingLib lib, global_size_t numGlobalElements, GlobalOrdinal indexBase,
00089 std::vector<size_t>& stridingInfo, const Teuchos::RCP<const Teuchos::Comm<int> > &comm,
00090 LocalOrdinal stridedBlockId = -1, GlobalOrdinal offset = 0, LocalGlobal lg = Xpetra::GloballyDistributed,
00091 const Teuchos::RCP<Node> &node = defaultArgNode()) {
00092
00093 return rcp(new StridedMap(lib, numGlobalElements, indexBase, stridingInfo, comm, stridedBlockId, offset, lg, node));
00094 }
00095
00097 static RCP<StridedMap> Build(UnderlyingLib lib, global_size_t numGlobalElements, size_t numLocalElements, GlobalOrdinal indexBase,
00098 std::vector<size_t>& stridingInfo, const Teuchos::RCP<const Teuchos::Comm<int> > &comm,
00099 LocalOrdinal stridedBlockId = -1, GlobalOrdinal offset = 0,
00100 const Teuchos::RCP<Node> &node = defaultArgNode()) {
00101
00102 return rcp(new StridedMap(lib, numGlobalElements, numLocalElements, indexBase, stridingInfo, comm, stridedBlockId, offset, node));
00103 }
00104
00105 static RCP<StridedMap> Build(const RCP<const Map>& map, std::vector<size_t>& stridingInfo, LocalOrdinal stridedBlockId = -1, GlobalOrdinal offset = 0) {
00106 return rcp(new StridedMap(map, stridingInfo, map->getIndexBase(), stridedBlockId, offset));
00107 }
00108
00109
00110 static RCP<StridedMap> Build(const RCP<const StridedMap>& map, LocalOrdinal stridedBlockId) {
00111 TEUCHOS_TEST_FOR_EXCEPTION(stridedBlockId < 0, Exceptions::RuntimeError,
00112 "Xpetra::StridedMapFactory::Build: constructor expects stridedBlockId > -1.");
00113 TEUCHOS_TEST_FOR_EXCEPTION(map->getStridedBlockId() != -1, Exceptions::RuntimeError,
00114 "Xpetra::StridedMapFactory::Build: constructor expects a full map (stridedBlockId == -1).");
00115
00116 std::vector<size_t> stridingInfo = map->getStridingData();
00117
00118 Teuchos::ArrayView<const GlobalOrdinal> dofGids = map->getNodeElementList();
00119
00120
00121
00122 size_t nStridedOffset = 0;
00123 for (int j = 0; j < map->getStridedBlockId(); j++)
00124 nStridedOffset += stridingInfo[j];
00125
00126 size_t numMyBlockDofs = (stridingInfo[stridedBlockId] * map->getNodeNumElements()) / map->getFixedBlockSize();
00127 std::vector<GlobalOrdinal> subBlockDofGids(numMyBlockDofs);
00128
00129
00130 LocalOrdinal ind = 0;
00131 for (typename Teuchos::ArrayView< const GlobalOrdinal >::iterator it = dofGids.begin(); it!=dofGids.end(); ++it)
00132 if (map->GID2StridingBlockId(*it) == Teuchos::as<size_t>(stridedBlockId))
00133 subBlockDofGids[ind++] = *it;
00134
00135 const Teuchos::ArrayView<const GlobalOrdinal> subBlockDofGids_view(&subBlockDofGids[0],subBlockDofGids.size());
00136
00137 return rcp(new StridedMap(map->lib(), Teuchos::OrdinalTraits<global_size_t>::invalid(), subBlockDofGids_view, map->getIndexBase(), stridingInfo, map->getComm(), stridedBlockId, map->getNode()));
00138 }
00139
00141 static RCP<StridedMap> Build(const StridedMap& map) {
00142 XPETRA_MONITOR("MapFactory::Build");
00143
00144 LocalOrdinal N = map.getNodeNumElements();
00145 Teuchos::ArrayView<const GlobalOrdinal> oldElements = map.getNodeElementList();
00146 Teuchos::Array<GlobalOrdinal> newElements(map.getNodeNumElements());
00147 for (LocalOrdinal i = 0; i < N; i++)
00148 newElements[i] = oldElements[i];
00149
00150 std::vector<size_t> strData = map.getStridingData();
00151 return rcp(new StridedMap(map.lib(), map.getGlobalNumElements(), newElements, map.getIndexBase(), strData, map.getComm(), map.getStridedBlockId(), map.getNode()));
00152
00153
00154 }
00155
00157 static RCP<StridedMap>
00158 Build (UnderlyingLib lib,
00159 global_size_t numGlobalElements,
00160 const Teuchos::ArrayView<const GlobalOrdinal> &elementList,
00161 GlobalOrdinal indexBase,
00162 std::vector<size_t>& stridingInfo,
00163 const Teuchos::RCP<const Teuchos::Comm<int> > &comm,
00164 LocalOrdinal stridedBlockId = -1,
00165 GlobalOrdinal offset = 0,
00166 const Teuchos::RCP<Node> &node = defaultArgNode())
00167 {
00168 return rcp (new StridedMap (lib, numGlobalElements, elementList,
00169 indexBase, stridingInfo, comm,
00170 stridedBlockId, node));
00171 }
00172 };
00173 }
00174
00175 #define XPETRA_STRIDEDMAPFACTORY_SHORT
00176 #endif
00177