VTK-m  2.1
ArrayHandleIndex.h
Go to the documentation of this file.
1 //============================================================================
2 // Copyright (c) Kitware, Inc.
3 // All rights reserved.
4 // See LICENSE.txt for details.
5 //
6 // This software is distributed WITHOUT ANY WARRANTY; without even
7 // the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
8 // PURPOSE. See the above copyright notice for more information.
9 //============================================================================
10 #ifndef vtk_m_cont_ArrayHandleIndex_h
11 #define vtk_m_cont_ArrayHandleIndex_h
12 
13 #include <vtkm/Range.h>
15 
16 namespace vtkm
17 {
18 
19 namespace internal
20 {
21 
22 struct VTKM_ALWAYS_EXPORT IndexFunctor
23 {
24  VTKM_EXEC_CONT vtkm::Id operator()(vtkm::Id index) const { return index; }
25 };
26 
27 } // namespace internal
28 
29 namespace cont
30 {
31 
33 {
34 };
35 
36 namespace internal
37 {
38 
39 using StorageTagIndexSuperclass =
41 
42 template <>
43 struct Storage<vtkm::Id, vtkm::cont::StorageTagIndex> : Storage<vtkm::Id, StorageTagIndexSuperclass>
44 {
45 };
46 
47 } // namespace internal
48 
55 class ArrayHandleIndex : public vtkm::cont::ArrayHandle<vtkm::Id, StorageTagIndex>
56 {
57 public:
60 
61  VTKM_CONT
63  : Superclass(
64  internal::FunctorToArrayHandleImplicitBuffers(vtkm::internal::IndexFunctor{}, length))
65  {
66  }
67 };
68 
72 {
73  return vtkm::cont::ArrayHandleIndex(length);
74 }
75 
76 namespace internal
77 {
78 
79 template <typename S>
80 struct ArrayRangeComputeImpl;
81 
82 template <>
83 struct VTKM_CONT_EXPORT ArrayRangeComputeImpl<vtkm::cont::StorageTagIndex>
84 {
87  const vtkm::cont::ArrayHandle<vtkm::UInt8>& maskArray,
88  bool computeFiniteRange,
89  vtkm::cont::DeviceAdapterId device) const;
90 };
91 
92 template <typename S>
93 struct ArrayRangeComputeMagnitudeImpl;
94 
95 template <>
96 struct VTKM_CONT_EXPORT ArrayRangeComputeMagnitudeImpl<vtkm::cont::StorageTagIndex>
97 {
98  VTKM_CONT vtkm::Range operator()(
100  const vtkm::cont::ArrayHandle<vtkm::UInt8>& maskArray,
101  bool computeFiniteRange,
102  vtkm::cont::DeviceAdapterId device) const
103  {
104  auto rangeAH = ArrayRangeComputeImpl<vtkm::cont::StorageTagIndex>{}(
105  input, maskArray, computeFiniteRange, device);
106  return rangeAH.ReadPortal().Get(0);
107  }
108 };
109 
110 } // namespace internal
111 
112 }
113 } // namespace vtkm::cont
114 
115 //=============================================================================
116 // Specializations of serialization related classes
118 
119 namespace vtkm
120 {
121 namespace cont
122 {
123 
124 template <>
125 struct SerializableTypeString<vtkm::cont::ArrayHandleIndex>
126 {
127  static VTKM_CONT std::string Get() { return "AH_Index"; }
128 };
129 
130 template <>
131 struct SerializableTypeString<vtkm::cont::ArrayHandle<vtkm::Id, vtkm::cont::StorageTagIndex>>
132  : SerializableTypeString<vtkm::cont::ArrayHandleIndex>
133 {
134 };
135 }
136 } // vtkm::cont
137 
138 namespace mangled_diy_namespace
139 {
140 
141 template <>
142 struct Serialization<vtkm::cont::ArrayHandleIndex>
143 {
144 private:
146 
147 public:
148  static VTKM_CONT void save(BinaryBuffer& bb, const BaseType& obj)
149  {
150  vtkmdiy::save(bb, obj.GetNumberOfValues());
151  }
152 
153  static VTKM_CONT void load(BinaryBuffer& bb, BaseType& obj)
154  {
155  vtkm::Id length = 0;
156  vtkmdiy::load(bb, length);
157 
158  obj = vtkm::cont::ArrayHandleIndex(length);
159  }
160 };
161 
162 template <>
163 struct Serialization<vtkm::cont::ArrayHandle<vtkm::Id, vtkm::cont::StorageTagIndex>>
164  : Serialization<vtkm::cont::ArrayHandleIndex>
165 {
166 };
167 } // diy
169 
170 #endif //vtk_m_cont_ArrayHandleIndex_h
vtkm::cont::ArrayHandle
Manages an array-worth of data.
Definition: ArrayHandle.h:300
vtkm::exec::arg::load
T load(const U &u, vtkm::Id v)
Definition: FetchTagArrayDirectIn.h:36
vtkm
Groups connected points that have the same field value.
Definition: Atomic.h:19
vtkm::Get
auto Get(const vtkm::Tuple< Ts... > &tuple)
Retrieve the object from a vtkm::Tuple at the given index.
Definition: Tuple.h:81
VTKM_ARRAY_HANDLE_SUBCLASS_NT
#define VTKM_ARRAY_HANDLE_SUBCLASS_NT(classname, superclass)
Macro to make default methods in ArrayHandle subclasses.
Definition: ArrayHandle.h:266
VTKM_EXEC_CONT
#define VTKM_EXEC_CONT
Definition: ExportMacros.h:52
vtkm::cont::ArrayHandleIndex::Superclass
vtkm::cont::detail::GetTypeInParentheses< void(vtkm::cont::ArrayHandle< vtkm::Id, StorageTagIndex >) >::type Superclass
Definition: ArrayHandleIndex.h:59
vtkm::cont::StorageTagIndex
Definition: ArrayHandleIndex.h:32
mangled_diy_namespace
Definition: Particle.h:351
VTKM_CONT_EXPORT
#define VTKM_CONT_EXPORT
Definition: vtkm_cont_export.h:44
Range.h
VTKM_CONT
#define VTKM_CONT
Definition: ExportMacros.h:57
vtkm::cont::ArrayHandleIndex::ArrayHandleIndex
ArrayHandleIndex(vtkm::Id length)
Definition: ArrayHandleIndex.h:62
vtkm::Id
vtkm::Int64 Id
Base type to use to index arrays.
Definition: Types.h:227
vtkm::cont::ArrayHandleImplicit::StorageTag
typename Superclass::StorageTag StorageTag
Definition: ArrayHandleImplicit.h:189
vtkm::cont::DeviceAdapterId
An object used to specify a device.
Definition: DeviceAdapterTag.h:58
vtkm::cont::make_ArrayHandleIndex
vtkm::cont::ArrayHandleIndex make_ArrayHandleIndex(vtkm::Id length)
A convenience function for creating an ArrayHandleIndex.
Definition: ArrayHandleIndex.h:71
VTKM_ALWAYS_EXPORT
#define VTKM_ALWAYS_EXPORT
Definition: ExportMacros.h:89
ArrayHandleImplicit.h
vtkm::cont::ArrayHandleIndex
An implicit array handle containing the its own indices.
Definition: ArrayHandleIndex.h:55
vtkm::Range
Represent a continuous scalar range of values.
Definition: Range.h:31