VTK  9.6.20260325
vtkmDataArray.h
Go to the documentation of this file.
1// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
2// SPDX-FileCopyrightText: Copyright (c) Kitware, Inc.
3// SPDX-FileCopyrightText: Copyright 2019 Sandia Corporation.
4// SPDX-FileCopyrightText: Copyright 2019 UT-Battelle, LLC.
5// SPDX-FileCopyrightText: Copyright 2019 Los Alamos National Security.
6// SPDX-License-Identifier: LicenseRef-BSD-3-Clause-Sandia-LANL-USGov
27
28#ifndef vtkmDataArray_h
29#define vtkmDataArray_h
30
31#include "vtkAcceleratorsVTKmCoreModule.h" // For export macro
32#include "vtkGenericDataArray.h"
33#include "vtkmConfigCore.h" // For template export
34
35#include <viskores/VecTraits.h> // For viskores::VecTraits
36#include <viskores/cont/ArrayHandle.h> // For viskores::cont::ArrayHandle
37#include <viskores/cont/UnknownArrayHandle.h> // For viskores::cont::UnknownArrayHandle
38
39#include <memory> // For std::unique_ptr<>
40#include <mutex> // For std::mutex
41
42namespace fromvtkm
43{
44VTK_ABI_NAMESPACE_BEGIN
45
46template <typename T>
48
49template <typename T>
51
52template <typename ArrayHandleType>
54
55template <typename ArrayHandleType>
57
58VTK_ABI_NAMESPACE_END
59} // fromvtkm
60
61VTK_ABI_NAMESPACE_BEGIN
62template <typename T>
64 : public vtkGenericDataArray<vtkmDataArray<T>, T, vtkArrayTypes::VTKM_DATA_ARRAY>
65{
66 static_assert(std::is_arithmetic<T>::value, "T must be an integral or floating-point type");
67
68 using GenericDataArrayType =
70
71public:
73 vtkTemplateTypeMacro(SelfType, GenericDataArrayType);
74 using typename Superclass::ArrayTypeTag;
75 using typename Superclass::DataTypeTag;
76 using typename Superclass::ValueType;
77
78 static vtkmDataArray* New();
79
82 void SetVtkmArrayHandle(const viskores::cont::UnknownArrayHandle& ah);
83
86 viskores::cont::UnknownArrayHandle GetVtkmUnknownArrayHandle() const;
87
91 void* GetVoidPointer(vtkIdType valueIdx) override;
92 VTK_DEPRECATED_IN_9_7_0("Use vtkmDataArray::WritePointer(valueIdx, numValues) or "
93 "vtkAbstractArray::SetNumberOf[Values/Tuples]() instead")
94 void* WriteVoidPointer(vtkIdType valueIdx, vtkIdType numValues) override;
95 T* GetPointer(vtkIdType valueIdx);
96 T* WritePointer(vtkIdType valueIdx, vtkIdType numValues);
100
102 ValueType GetValue(vtkIdType valueIdx) const;
103 void SetValue(vtkIdType valueIdx, ValueType value);
104 void GetTypedTuple(vtkIdType tupleIdx, ValueType* tuple) const;
105 void SetTypedTuple(vtkIdType tupleIdx, const ValueType* tuple);
106 ValueType GetTypedComponent(vtkIdType tupleIdx, int compIdx) const;
107 void SetTypedComponent(vtkIdType tupleIdx, int compIdx, ValueType value);
108
109protected:
112
117 double* ranges, const unsigned char* ghosts, unsigned char ghostsToSkip = 0xff) override;
120 double range[2], const unsigned char* ghosts, unsigned char ghostsToSkip = 0xff) override;
123 double* ranges, const unsigned char* ghosts, unsigned char ghostsToSkip = 0xff) override;
126 double range[2], const unsigned char* ghosts, unsigned char ghostsToSkip = 0xff) override;
127
129 bool AllocateTuples(vtkIdType numberOfTuples);
130 bool ReallocateTuples(vtkIdType numberOfTuples);
131
132private:
133 // To access concept methods
134 friend class vtkGenericDataArray<SelfType, ValueType, ArrayTypeTag::value>;
135 friend fromvtkm::ArrayHandleHelperBase<T>;
136 friend fromvtkm::ArrayHandleHelperUnknown<T>;
137 template <typename ArrayHandleType>
139 template <typename ArrayHandleType>
141
142 mutable std::unique_ptr<fromvtkm::ArrayHandleHelperBase<T>> Helper;
143
144 mutable std::mutex Mutex;
145
146 vtkmDataArray(const vtkmDataArray&) = delete;
147 void operator=(const vtkmDataArray&) = delete;
148};
149
150// Declare vtkArrayDownCast implementations for vtkmDataArray:
152
153//=============================================================================
154template <typename T, typename S>
155inline vtkmDataArray<typename viskores::VecTraits<T>::BaseComponentType>* make_vtkmDataArray(
156 const viskores::cont::ArrayHandle<T, S>& ah)
157{
159 ret->SetVtkmArrayHandle(ah);
160 return ret;
161}
162
163//=============================================================================
164template <typename TCast, typename TReal, typename S>
166 const viskores::cont::ArrayHandle<TCast, viskores::cont::StorageTagCast<TReal, S>>& ah)
167{
169 ret->SetVtkmArrayHandle(ah);
170 return ret;
171}
172
173//=============================================================================
174#ifndef vtkmDataArray_cxx
175extern template class VTKACCELERATORSVTKMCORE_TEMPLATE_EXPORT vtkmDataArray<char>;
176extern template class VTKACCELERATORSVTKMCORE_TEMPLATE_EXPORT vtkmDataArray<double>;
177extern template class VTKACCELERATORSVTKMCORE_TEMPLATE_EXPORT vtkmDataArray<float>;
178extern template class VTKACCELERATORSVTKMCORE_TEMPLATE_EXPORT vtkmDataArray<int>;
179extern template class VTKACCELERATORSVTKMCORE_TEMPLATE_EXPORT vtkmDataArray<long>;
180extern template class VTKACCELERATORSVTKMCORE_TEMPLATE_EXPORT vtkmDataArray<long long>;
181extern template class VTKACCELERATORSVTKMCORE_TEMPLATE_EXPORT vtkmDataArray<short>;
182extern template class VTKACCELERATORSVTKMCORE_TEMPLATE_EXPORT vtkmDataArray<signed char>;
183extern template class VTKACCELERATORSVTKMCORE_TEMPLATE_EXPORT vtkmDataArray<unsigned char>;
184extern template class VTKACCELERATORSVTKMCORE_TEMPLATE_EXPORT vtkmDataArray<unsigned int>;
185extern template class VTKACCELERATORSVTKMCORE_TEMPLATE_EXPORT vtkmDataArray<unsigned long>;
186extern template class VTKACCELERATORSVTKMCORE_TEMPLATE_EXPORT vtkmDataArray<unsigned long long>;
187extern template class VTKACCELERATORSVTKMCORE_TEMPLATE_EXPORT vtkmDataArray<unsigned short>;
188#endif // vtkmDataArray_cxx
189
190VTK_ABI_NAMESPACE_END
191#endif // vtkmDataArray_h
192
193#include "vtkmlib/vtkmDataArray.hxx"
194
195// VTK-HeaderTest-Exclude: vtkmDataArray.h
std::integral_constant< int, VTK_OPAQUE > DataTypeTag
std::integral_constant< int, vtkArrayTypes::VTK_ABSTRACT_ARRAY > ArrayTypeTag
vtkAbstractArray Superclass
void * WriteVoidPointer(vtkIdType valueIdx, vtkIdType numValues) override
Wraps a Viskores ArrayHandle inside a sub-class of vtkGenericDataArray.
bool ComputeVectorRange(double range[2], const unsigned char *ghosts, unsigned char ghostsToSkip=0xff) override
Returns true if the range was computed.
void * GetVoidPointer(vtkIdType valueIdx) override
T * GetPointer(vtkIdType valueIdx)
friend class fromvtkm::ArrayHandleHelperRead
ValueType GetValue(vtkIdType valueIdx) const
Support methods for vtkGenericDataArray.
friend class fromvtkm::ArrayHandleHelperWrite
bool ComputeFiniteVectorRange(double range[2], const unsigned char *ghosts, unsigned char ghostsToSkip=0xff) override
Returns true if the range was computed.
void SetValue(vtkIdType valueIdx, ValueType value)
void SetTypedTuple(vtkIdType tupleIdx, const ValueType *tuple)
vtkDataArray::MemorySpace GetMemorySpace() override
void SetTypedComponent(vtkIdType tupleIdx, int compIdx, ValueType value)
T * WritePointer(vtkIdType valueIdx, vtkIdType numValues)
vtkmDataArray< T > SelfType
bool ComputeFiniteScalarRange(double *ranges, const unsigned char *ghosts, unsigned char ghostsToSkip=0xff) override
Computes the range for each component of an array, the length of ranges must be two times the number ...
static vtkmDataArray * New()
VTK_DEPRECATED_IN_9_7_0("Use vtkmDataArray::WritePointer(valueIdx, numValues) or " "vtkAbstractArray::SetNumberOf[Values/Tuples]() instead") void *WriteVoidPointer(vtkIdType valueIdx
void * GetDeviceVoidPointer(vtkIdType valueIdx) override
bool AllocateTuples(vtkIdType numberOfTuples)
concept methods for vtkGenericDataArray
std::integral_constant< int, vtkArrayTypes::VTK_ABSTRACT_ARRAY > ArrayTypeTag
void GetTypedTuple(vtkIdType tupleIdx, ValueType *tuple) const
ValueType GetTypedComponent(vtkIdType tupleIdx, int compIdx) const
viskores::cont::UnknownArrayHandle GetVtkmUnknownArrayHandle() const
Get the underlying ArrayHandle.
vtkTemplateTypeMacro(SelfType, GenericDataArrayType)
bool ComputeScalarRange(double *ranges, const unsigned char *ghosts, unsigned char ghostsToSkip=0xff) override
Computes the range for each component of an array, the length of ranges must be two times the number ...
vtkIdType numValues override
bool ReallocateTuples(vtkIdType numberOfTuples)
void SetVtkmArrayHandle(const viskores::cont::UnknownArrayHandle &ah)
Set the Viskores ArrayHandle to be wrapped.
#define vtkArrayDownCast_TemplateFastCastMacro(ArrayT)
Same as vtkArrayDownCast_FastCastMacro, but treats ArrayT as a single-parameter template (the paramet...
int vtkIdType
Definition vtkType.h:363
@ VTKM_DATA_ARRAY
Definition vtkType.h:86
vtkmDataArray< typename viskores::VecTraits< T >::BaseComponentType > * make_vtkmDataArray(const viskores::cont::ArrayHandle< T, S > &ah)