165#ifndef vtkGenericDataArray_h
166#define vtkGenericDataArray_h
179VTK_ABI_NAMESPACE_BEGIN
180template <
class DerivedT,
class ValueTypeT,
int ArrayType = vtkArrayTypes::VTK_DATA_ARRAY>
185 "ArrayType must be a valid vtkAbstractArray::ArrayType enum value");
191 using DataTypeTag = std::integral_constant<int, vtkTypeTraits<ValueTypeT>::VTK_TYPE_ID>;
217 return static_cast<const DerivedT*
>(
this)->
GetValue(valueIdx);
230 static_cast<DerivedT*
>(
this)->
SetValue(valueIdx, value);
244 static_cast<const DerivedT*
>(
this)->
GetTypedTuple(tupleIdx, tuple);
258 static_cast<DerivedT*
>(
this)->
SetTypedTuple(tupleIdx, tuple);
270 return static_cast<const DerivedT*
>(
this)->GetTypedComponent(tupleIdx, compIdx);
282 static_cast<DerivedT*
>(
this)->SetTypedComponent(tupleIdx, compIdx, value);
297 "vtkAbstractArray::SetNumberOf[Values/Tuples]() instead")
300 "vtkAbstractArray::SetNumberOf[Values/Tuples]() instead")
351 ValueType range[2],
int comp, const
unsigned char* ghosts,
unsigned char ghostsToSkip = 0xff);
369 ValueType range[2],
int comp,
const unsigned char* ghosts,
unsigned char ghostsToSkip = 0xff);
441 double* weights)
override;
470 return static_cast<DerivedT*
>(
this)->ReallocateTuples(numTuples);
485 ValueType range[2],
int comp,
const unsigned char* ghosts,
unsigned char ghostsToSkip = 0xff);
495 ValueType range[2],
int comp,
const unsigned char* ghosts,
unsigned char ghostsToSkip = 0xff);
504 ValueType* ranges,
const unsigned char* ghosts,
unsigned char ghostsToSkip = 0xff);
511 ValueType range[2],
const unsigned char* ghosts,
unsigned char ghostsToSkip = 0xff);
520 ValueType* ranges,
const unsigned char* ghosts,
unsigned char ghostsToSkip = 0xff);
527 ValueType range[2],
const unsigned char* ghosts,
unsigned char ghostsToSkip = 0xff);
540 std::unique_ptr<vtkInternals> Internals;
548#define vtkCreateGenericWrappedArrayReadInterface(T) \
549 int GetDataType() const override; \
550 T GetDataTypeValueMin() const; \
551 T GetDataTypeValueMax() const; \
552 T* GetValueRange(int comp) VTK_SIZEHINT(2); \
553 T* GetValueRange() VTK_SIZEHINT(2); \
554 void GetValueRange(T range[2], int comp); \
555 void GetValueRange(T range[2], int comp);
556#define vtkCreateGenericWrappedArrayWriteInterface(T) \
557 void InsertTypedTuple(vtkIdType i, const T* tuple) VTK_EXPECTS(0 <= i); \
558 vtkIdType InsertNextTypedTuple(const T* tuple); \
559 void InsertValue(vtkIdType id, T f) VTK_EXPECTS(0 <= id); \
560 vtkIdType InsertNextValue(T f);
561#define vtkCreateGenericWrappedArrayInterface(T) \
562 vtkCreateGenericWrappedArrayReadInterface(T); \
563 vtkCreateGenericWrappedArrayWriteInterface(T);
568#define vtkCreateWrappedArrayReadInterface(T) \
569 vtkCreateGenericWrappedArrayReadInterface(T); \
570 void GetTypedTuple(vtkIdType i, T* tuple) VTK_EXPECTS(0 <= i && i < GetNumberOfTuples()); \
571 T GetTypedComponent(vtkIdType i, int c) const VTK_EXPECTS(0 <= c && c < GetNumberOfComponents()) \
572 VTK_EXPECTS(0 <= i && GetNumberOfComponents() * i + c < GetNumberOfValues()); \
573 T GetValue(vtkIdType id) const VTK_EXPECTS(0 <= id && id < GetNumberOfValues());
574#define vtkCreateWrappedArrayWriteInterface(T) \
575 vtkCreateGenericWrappedArrayWriteInterface(T); \
576 void SetTypedTuple(vtkIdType i, const T* tuple) VTK_EXPECTS(0 <= i && i < GetNumberOfTuples()); \
577 void SetTypedComponent(vtkIdType i, int c, ValueType value); \
578 void SetValue(vtkIdType id, T value) VTK_EXPECTS(0 <= id && id < GetNumberOfValues()); \
579 bool SetNumberOfValues(vtkIdType number) override;
581#define VTK_INSTANTIATE_VALUERANGE_ARRAYTYPE(ArrayType, ValueType) \
582 template VTKCOMMONCORE_EXPORT bool DoComputeScalarRange( \
583 ArrayType*, ValueType*, vtkDataArrayPrivate::AllValues, const unsigned char*, unsigned char); \
584 template VTKCOMMONCORE_EXPORT bool DoComputeScalarRange(ArrayType*, ValueType*, \
585 vtkDataArrayPrivate::FiniteValues, const unsigned char*, unsigned char); \
586 template VTKCOMMONCORE_EXPORT bool DoComputeVectorRange(ArrayType*, ValueType[2], \
587 vtkDataArrayPrivate::AllValues, const unsigned char*, unsigned char); \
588 template VTKCOMMONCORE_EXPORT bool DoComputeVectorRange(ArrayType*, ValueType[2], \
589 vtkDataArrayPrivate::FiniteValues, const unsigned char*, unsigned char);
593VTK_ABI_NAMESPACE_BEGIN
594template <
typename A,
typename R,
typename T>
596 A*, R*, T,
const unsigned char* ghosts,
unsigned char ghostsToSkip);
597template <
typename A,
typename R>
599 A*, R[2],
AllValues,
const unsigned char* ghosts,
unsigned char ghostsToSkip);
600template <
typename A,
typename R>
602 A*, R[2],
FiniteValues,
const unsigned char* ghosts,
unsigned char ghostsToSkip);
606#define VTK_DECLARE_VALUERANGE_ARRAYTYPE(ArrayType, ValueType) \
607 extern template VTKCOMMONCORE_EXPORT bool DoComputeScalarRange( \
608 ArrayType*, ValueType*, vtkDataArrayPrivate::AllValues, const unsigned char*, unsigned char); \
609 extern template VTKCOMMONCORE_EXPORT bool DoComputeScalarRange(ArrayType*, ValueType*, \
610 vtkDataArrayPrivate::FiniteValues, const unsigned char*, unsigned char); \
611 extern template VTKCOMMONCORE_EXPORT bool DoComputeVectorRange(ArrayType*, ValueType[2], \
612 vtkDataArrayPrivate::AllValues, const unsigned char*, unsigned char); \
613 extern template VTKCOMMONCORE_EXPORT bool DoComputeVectorRange(ArrayType*, ValueType[2], \
614 vtkDataArrayPrivate::FiniteValues, const unsigned char*, unsigned char);
616#include "vtkGenericDataArray.txx"
624#define vtkAOSArrayNewInstanceMacro(thisClass) \
626 vtkObjectBase* NewInstanceInternal() const override \
628 if (vtkDataArray* da = vtkDataArray::CreateDataArray(thisClass::DataTypeTag::value)) \
632 return thisClass::New(); \
644#ifdef VTK_USE_EXTERN_TEMPLATE
646#ifndef VTK_GDA_TEMPLATE_EXTERN
647#define VTK_GDA_TEMPLATE_EXTERN
652#pragma warning(disable : 4910)
657VTK_ABI_NAMESPACE_BEGIN
Abstract superclass for all arrays.
int GetNumberOfComponents() const
Set/Get the dimension (n) of the components.
vtkIdType GetNumberOfTuples() const
Get the number of complete tuples (a component group) in the array.
virtual void SetTuple(vtkIdType dstTupleIdx, vtkIdType srcTupleIdx, vtkAbstractArray *source)=0
Set the tuple at dstTupleIdx in this array to the tuple at srcTupleIdx in the source array.
virtual void InsertTuples(vtkIdList *dstIds, vtkIdList *srcIds, vtkAbstractArray *source)=0
Copy the tuples indexed in srcIds from the source array to the tuple locations indexed by dstIds in t...
vtkIdType GetNumberOfValues() const
Get the total number of values in the array.
Abstract superclass to iterate over elements in an vtkAbstractArray.
internal class used by vtkGenericDataArray to support LookupValue.
void InterpolateTuple(vtkIdType dstTupleIdx, vtkIdType srcTupleIdx1, vtkAbstractArray *source1, vtkIdType srcTupleIdx2, vtkAbstractArray *source2, double t) override
Insert the tuple at dstTupleIdx in this array to the tuple interpolated from the two tuple indices,...
vtkIdType InsertNextValue(ValueType value)
ValueType * GetFiniteValueRange(int comp)
These methods are analogous to the GetValueRange methods, except that the only consider finite values...
void InsertValue(vtkIdType valueIdx, ValueType value)
void DataChanged() override
Tell the array explicitly that the data has changed.
virtual void LookupTypedValue(ValueType value, vtkIdList *valueIds)
void * GetVoidPointer(vtkIdType valueIdx) override
Default implementation raises a runtime error.
int GetDataTypeSize() const override
Return the size of the underlying data type.
void InsertComponent(vtkIdType tupleIdx, int compIdx, double value) override
Insert value at the location specified by tupleIdx and compIdx.
ValueType * GetValueRange()
Get the range of array values for the 0th component in the native data type.
void GetFiniteValueRange(ValueType range[2])
These methods are analogous to the GetValueRange methods, except that the only consider finite values...
void SetTuple(vtkIdType dstTupleIdx, vtkIdType srcTupleIdx, vtkAbstractArray *source) override
See documentation from parent class.
bool HasStandardMemoryLayout() const override
Returns true if this array uses the standard memory layout defined in the VTK user guide,...
void InsertTuple(vtkIdType dstTupleIdx, vtkIdType srcTupleIdx, vtkAbstractArray *source) override
See documentation from parent class.
void ComputeValueRange(ValueType range[2], int comp, const unsigned char *ghosts, unsigned char ghostsToSkip=0xff)
Compute the range for a specific component.
void GetFiniteValueRange(ValueType range[2], int comp, const unsigned char *ghosts, unsigned char ghostsToSkip=0xff)
These methods are analogous to the GetValueRange methods, except that the only consider finite values...
void InsertTuple(vtkIdType tupleIdx, const float *source) override
Insert the data tuple at tupleIdx.
double GetComponent(vtkIdType tupleIdx, int compIdx) override
Return the data component at the location specified by tupleIdx and compIdx.
void LookupValue(vtkVariant value, vtkIdList *valueIds) override
Return the value indices where a specific value appears.
void * WriteVoidPointer(vtkIdType valueIdx, vtkIdType numValues) override
int GetArrayType() const override
Method for type-checking in FastDownCast implementations.
bool ComputeVectorValueRange(ValueType range[2], const unsigned char *ghosts, unsigned char ghostsToSkip=0xff)
Returns true if the range was computed.
void SetComponent(vtkIdType tupleIdx, int compIdx, double value) override
Set the data component at the location specified by tupleIdx and compIdx to value.
bool ComputeFiniteScalarValueRange(ValueType *ranges, const unsigned char *ghosts, unsigned char ghostsToSkip=0xff)
Computes the range for each component of an array, the length of ranges must be two times the number ...
vtkTemplateTypeMacro(SelfType, vtkDataArray)
bool EnsureAccessToTuple(vtkIdType tupleIdx)
void ComputeFiniteValueRange(ValueType range[2], int comp, const unsigned char *ghosts, unsigned char ghostsToSkip=0xff)
Compute the range for a specific component.
vtkIdType InsertNextTypedTuple(const ValueType *t)
void GetValueRange(ValueType range[2], int comp, const unsigned char *ghosts, unsigned char ghostsToSkip=0xff)
vtkIdType LookupValue(vtkVariant value) override
Return the value indices where a specific value appears.
ValueType GetDataTypeValueMin() const
void GetTuples(vtkIdType p1, vtkIdType p2, vtkAbstractArray *output) override
Get the tuples for the range of tuple ids specified (i.e., p1->p2 inclusive).
void InsertTypedTuple(vtkIdType tupleIdx, const ValueType *t)
vtkGenericDataArrayLookupHelper< SelfType > Lookup
bool ComputeFiniteVectorValueRange(ValueType range[2], const unsigned char *ghosts, unsigned char ghostsToSkip=0xff)
Returns true if the range was computed.
void GetFiniteValueRange(ValueType range[2], int comp)
These methods are analogous to the GetValueRange methods, except that the only consider finite values...
void InsertVariantValue(vtkIdType valueIdx, vtkVariant value) override
Insert a value into the array from a variant.
std::vector< ValueType > LegacyValueRange
void RemoveTuple(vtkIdType tupleIdx) override
void InterpolateTuple(vtkIdType dstTupleIdx, vtkIdList *ptIndices, vtkAbstractArray *source, double *weights) override
Set the tuple at dstTupleIdx in this array to the interpolated tuple value, given the ptIndices in th...
void SetTuple(vtkIdType tupleIdx, const double *tuple) override
Set the data tuple at tupleIdx.
void SetVariantValue(vtkIdType valueIdx, vtkVariant value) override
Set a value in the array from a variant.
void SetNumberOfComponents(int num) override
Set/Get the dimension (n) of the components.
void SetTuple(vtkIdType tupleIdx, const float *tuple) override
Set the data tuple at tupleIdx.
void SetVoidArray(void *, vtkIdType, int) override
virtual vtkIdType LookupTypedValue(ValueType value)
bool ComputeScalarValueRange(ValueType *ranges, const unsigned char *ghosts, unsigned char ghostsToSkip=0xff)
Computes the range for each component of an array, the length of ranges must be two times the number ...
vtkIdType InsertNextTuple(const double *tuple) override
Insert the data tuple at the end of the array and return the tuple index at which the data was insert...
std::integral_constant< int, vtkTypeTraits< T >::VTK_TYPE_ID > DataTypeTag
void GetTuple(vtkIdType tupleIdx, double *tuple) override
Get the data tuple at tupleIdx by filling in a user-provided array, Make sure that your array is larg...
virtual void FillValue(ValueType value)
Set all the values in array to value.
vtkVariant GetVariantValue(vtkIdType valueIdx) override
Retrieve value from the array as a variant.
ValueType * WritePointer(vtkIdType valueIdx, vtkIdType numValues)
void InsertTuples(vtkIdType dstStart, vtkIdType n, vtkIdType srcStart, vtkAbstractArray *source) override
See documentation from parent class.
double * GetTuple(vtkIdType tupleIdx) override
Get the data tuple at tupleIdx.
void GetValueRange(ValueType range[2])
vtkIdType InsertNextTuple(const float *tuple) override
Insert the data tuple at the end of the array and return the tuple index at which the data was insert...
vtkTypeBool ReserveTuples(vtkIdType numTuples) override
Reserve the array to the requested number of tuples and preserve data.
virtual void FillTypedComponent(int compIdx, ValueType value)
Set component comp of all tuples to value.
void SetArrayFreeFunction(void(*callback)(void *)) override
void InsertTuplesStartingAt(vtkIdType dstStart, vtkIdList *srcIds, vtkAbstractArray *source) override
See documentation from parent class.
std::vector< double > LegacyTuple
void FillComponent(int compIdx, double value) override
Fill a component of a data array with a specified value.
void ClearLookup() override
Delete the associated fast lookup data structure on this array, if it exists.
void InsertTuples(vtkIdList *dstIds, vtkIdList *srcIds, vtkAbstractArray *source) override
See documentation from parent class.
vtkIdType InsertNextTuple(vtkIdType srcTupleIdx, vtkAbstractArray *source) override
See documentation from parent class.
void InsertTypedComponent(vtkIdType tupleIdx, int compIdx, ValueType val)
ValueType * GetPointer(vtkIdType valueIdx)
std::integral_constant< int, ArrayType > ArrayTypeTag
void Squeeze() override
Free any unnecessary memory.
static DerivedT * FastDownCast(vtkAbstractArray *source)
Perform a fast, safe cast from a vtkAbstractArray to a DerivedT.
int GetDataType() const override
Return the underlying data type.
ValueType GetDataTypeValueMax() const
void InsertTuple(vtkIdType tupleIdx, const double *source) override
Insert the data tuple at tupleIdx.
void GetTuples(vtkIdList *tupleIds, vtkAbstractArray *output) override
Given a list of tuple ids, return an array of tuples.
ValueType * GetFiniteValueRange()
These methods are analogous to the GetValueRange methods, except that the only consider finite values...
vtkArrayIterator * NewIterator() override
vtkGenericDataArray< vtkmDataArray< T >, T, ArrayType > SelfType
std::vector< ValueType > LegacyValueRangeFull
list of point or cell ids
A type representing the union of many types.
void SetTypedComponent(vtkIdType tupleIdx, int compIdx, ValueType value)
Set component compIdx of the tuple at tupleIdx to value.
ValueType GetTypedComponent(vtkIdType tupleIdx, int compIdx) const
Get component compIdx of the tuple at tupleIdx.
void GetTypedTuple(vtkIdType tupleIdx, ValueType *tuple) const
Copy the tuple at tupleIdx into tuple.
void SetTypedTuple(vtkIdType tupleIdx, const ValueType *tuple)
Set this array's tuple at tupleIdx to the values in tuple.
void SetValue(vtkIdType valueIdx, ValueType value)
Set the value at valueIdx to value.
bool ReallocateTuples(vtkIdType numTuples)
ValueType GetValue(vtkIdType valueIdx) const
Get the value at valueIdx.
VTKCOMMONCORE_EXPORT bool DoComputeScalarRange(A *, R *, T, const unsigned char *ghosts, unsigned char ghostsToSkip)
VTKCOMMONCORE_EXPORT bool DoComputeVectorRange(A *, R[2], AllValues, const unsigned char *ghosts, unsigned char ghostsToSkip)
Template defining traits of native types used by VTK.
boost::graph_traits< vtkGraph * >::vertex_descriptor source(boost::graph_traits< vtkGraph * >::edge_descriptor e, vtkGraph *)
#define VTK_DEPRECATED_IN_9_7_0(reason)
#define VTK_DEPRECATED_IN_9_6_0(reason)
#define VTK_DECLARE_VALUERANGE_ARRAYTYPE(ArrayType, ValueType)
#define VTK_SIZEHINT(...)