VTK  9.6.20260404
vtkDataArray.h
Go to the documentation of this file.
1// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
2// SPDX-License-Identifier: BSD-3-Clause
137
138#ifndef vtkDataArray_h
139#define vtkDataArray_h
140
141#include "vtkAbstractArray.h"
142#include "vtkCommonCoreModule.h" // For export macro
143#include "vtkWrappingHints.h" // For VTK_MARSHALMANUAL
144
145VTK_ABI_NAMESPACE_BEGIN
146class vtkDoubleArray;
147class vtkIdList;
150class vtkLookupTable;
151class vtkPoints;
152
153class VTKCOMMONCORE_EXPORT VTK_MARSHALMANUAL vtkDataArray : public vtkAbstractArray
154{
155public:
157 void PrintSelf(ostream& os, vtkIndent indent) override;
158 using ArrayTypeTag = std::integral_constant<int, vtkArrayTypes::VTK_DATA_ARRAY>;
159 using typename vtkAbstractArray::DataTypeTag;
160
168
175 int IsNumeric() const override { return 1; }
176
182 int GetElementComponentSize() const override { return this->GetDataTypeSize(); }
183
184 // Reimplemented virtuals (doc strings are inherited from superclass):
186
191 void InsertTuple(vtkIdType dstTupleIdx, vtkIdType srcTupleIdx, vtkAbstractArray* source) override;
193 void InsertTuples(vtkIdList* dstIds, vtkIdList* srcIds, vtkAbstractArray* source) override;
195 vtkIdType dstStart, vtkIdType n, vtkIdType srcStart, vtkAbstractArray* source) override;
197 vtkIdType dstStart, vtkIdList* srcIds, vtkAbstractArray* source) override;
198 void SetTuple(vtkIdType dstTupleIdx, vtkIdType srcTupleIdx, vtkAbstractArray* source) override;
200 void GetTuples(vtkIdList* tupleIds, vtkAbstractArray* output) override;
201 void GetTuples(vtkIdType p1, vtkIdType p2, vtkAbstractArray* output) override;
203 double* weights) override;
204 void InterpolateTuple(vtkIdType dstTupleIdx, vtkIdType srcTupleIdx1, vtkAbstractArray* source1,
205 vtkIdType srcTupleIdx2, vtkAbstractArray* source2, double t) override;
206
212 virtual double* GetTuple(vtkIdType tupleIdx)
213 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples()) = 0;
214
220 virtual void GetTuple(vtkIdType tupleIdx, double* tuple)
221 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples()) = 0;
222
224
233 virtual void GetIntegerTuple(vtkIdType tupleIdx, vtkTypeInt64* tuple)
234 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
235 virtual void SetIntegerTuple(vtkIdType tupleIdx, vtkTypeInt64* tuple)
236 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
238
240
249 virtual void GetUnsignedTuple(vtkIdType tupleIdx, vtkTypeUInt64* tuple)
250 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
251 virtual void SetUnsignedTuple(vtkIdType tupleIdx, vtkTypeUInt64* tuple)
252 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
254
256
261 double GetTuple1(vtkIdType tupleIdx) VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
262 double* GetTuple2(vtkIdType tupleIdx) VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples())
263 VTK_SIZEHINT(2);
264 double* GetTuple3(vtkIdType tupleIdx) VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples())
265 VTK_SIZEHINT(3);
266 double* GetTuple4(vtkIdType tupleIdx) VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples())
267 VTK_SIZEHINT(4);
268 double* GetTuple6(vtkIdType tupleIdx) VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples())
269 VTK_SIZEHINT(6);
270 double* GetTuple9(vtkIdType tupleIdx) VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples())
271 VTK_SIZEHINT(9);
273
275
280 virtual void SetTuple(vtkIdType tupleIdx, const float* tuple)
281 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
282 virtual void SetTuple(vtkIdType tupleIdx, const double* tuple)
283 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
285
287
292 void SetTuple1(vtkIdType tupleIdx, double value)
293 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
294 void SetTuple2(vtkIdType tupleIdx, double val0, double val1)
295 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
296 void SetTuple3(vtkIdType tupleIdx, double val0, double val1, double val2)
297 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
298 void SetTuple4(vtkIdType tupleIdx, double val0, double val1, double val2, double val3)
299 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
300 void SetTuple6(vtkIdType tupleIdx, double val0, double val1, double val2, double val3,
301 double val4, double val5) VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
302 void SetTuple9(vtkIdType tupleIdx, double val0, double val1, double val2, double val3,
303 double val4, double val5, double val6, double val7, double val8)
304 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
306
308
312 virtual void InsertTuple(vtkIdType tupleIdx, const float* tuple) VTK_EXPECTS(0 <= tupleIdx) = 0;
313 virtual void InsertTuple(vtkIdType tupleIdx, const double* tuple) VTK_EXPECTS(0 <= tupleIdx) = 0;
315
317
322 void InsertTuple1(vtkIdType tupleIdx, double value) VTK_EXPECTS(0 <= tupleIdx);
323 void InsertTuple2(vtkIdType tupleIdx, double val0, double val1) VTK_EXPECTS(0 <= tupleIdx);
324 void InsertTuple3(vtkIdType tupleIdx, double val0, double val1, double val2)
325 VTK_EXPECTS(0 <= tupleIdx);
326 void InsertTuple4(vtkIdType tupleIdx, double val0, double val1, double val2, double val3)
327 VTK_EXPECTS(0 <= tupleIdx);
328 void InsertTuple6(vtkIdType tupleIdx, double val0, double val1, double val2, double val3,
329 double val4, double val5) VTK_EXPECTS(0 <= tupleIdx);
330 void InsertTuple9(vtkIdType tupleIdx, double val0, double val1, double val2, double val3,
331 double val4, double val5, double val6, double val7, double val8) VTK_EXPECTS(0 <= tupleIdx);
333
335
340 virtual vtkIdType InsertNextTuple(const float* tuple) = 0;
341 virtual vtkIdType InsertNextTuple(const double* tuple) = 0;
343
345
350 void InsertNextTuple1(double value);
351 void InsertNextTuple2(double val0, double val1);
352 void InsertNextTuple3(double val0, double val1, double val2);
353 void InsertNextTuple4(double val0, double val1, double val2, double val3);
355 double val0, double val1, double val2, double val3, double val4, double val5);
356 void InsertNextTuple9(double val0, double val1, double val2, double val3, double val4,
357 double val5, double val6, double val7, double val8);
359
361
366 virtual void RemoveTuple(vtkIdType tupleIdx)
367 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples()) = 0;
368 virtual void RemoveFirstTuple() { this->RemoveTuple(0); }
369 virtual void RemoveLastTuple();
371
376 virtual double GetComponent(vtkIdType tupleIdx, int compIdx)
377 VTK_EXPECTS(0 <= tupleIdx && GetNumberOfComponents() * tupleIdx + compIdx < GetNumberOfValues())
378 VTK_EXPECTS(0 <= compIdx && compIdx < GetNumberOfComponents());
379
387 virtual void SetComponent(vtkIdType tupleIdx, int compIdx, double value)
388 VTK_EXPECTS(0 <= tupleIdx && GetNumberOfComponents() * tupleIdx + compIdx < GetNumberOfValues())
389 VTK_EXPECTS(0 <= compIdx && compIdx < GetNumberOfComponents());
390
395 virtual void InsertComponent(vtkIdType tupleIdx, int compIdx, double value)
396 VTK_EXPECTS(0 <= tupleIdx) VTK_EXPECTS(0 <= compIdx && compIdx < GetNumberOfComponents());
397
406 virtual void GetData(
407 vtkIdType tupleMin, vtkIdType tupleMax, int compMin, int compMax, vtkDoubleArray* data);
408
410
414 void DeepCopy(vtkAbstractArray* aa) override;
415 virtual void DeepCopy(vtkDataArray* da);
417
419
427 virtual void ShallowCopy(vtkDataArray* other);
428 void ShallowCopy(vtkAbstractArray* other) override;
430
437 virtual void FillComponent(int compIdx, double value)
438 VTK_EXPECTS(0 <= compIdx && compIdx < GetNumberOfComponents());
439
443 virtual void Fill(double value);
444
446
457 bool CopyComponent(int dstComponent, vtkAbstractArray* src, int srcComponent) override;
458 virtual bool CopyComponent(int dstComponent, vtkDataArray* src, int srcComponent);
460
466 VTK_DEPRECATED_IN_9_7_0("Use vtkAOSDataArrayTemplate::WritePointer(valueIdx, numValues) or "
467 "vtkAbstractArray::SetNumberOf[Values/Tuples]() instead")
468 virtual void* WriteVoidPointer(vtkIdType valueIdx, vtkIdType numValues) = 0;
469
478 unsigned long GetActualMemorySize() const override;
479
485
487
491 vtkGetObjectMacro(LookupTable, vtkLookupTable);
493
495
512 void GetRange(double range[2], int comp) { this->ComputeRange(range, comp); }
513 void GetRange(double range[2], int comp, const unsigned char* ghosts, unsigned char ghostsToSkip)
514 {
515 this->ComputeRange(range, comp, ghosts, ghostsToSkip);
516 }
517
518
520
528 double* GetRange(int comp) VTK_SIZEHINT(2)
529 {
530 this->GetRange(this->Range, comp);
531 return this->Range;
532 }
533
534
542 double* GetRange() VTK_SIZEHINT(2) { return this->GetRange(0); }
543
552 void GetRange(double range[2]) { this->GetRange(range, 0); }
553
555
573 void GetFiniteRange(double range[2], int comp) { this->ComputeFiniteRange(range, comp); }
575 double range[2], int comp, const unsigned char* ghosts, unsigned char ghostsToSkip)
576 {
577 this->ComputeFiniteRange(range, comp, ghosts, ghostsToSkip);
578 }
579
580
582
590 double* GetFiniteRange(int comp) VTK_SIZEHINT(2)
591 {
592 this->GetFiniteRange(this->FiniteRange, comp);
593 return this->FiniteRange;
594 }
595
596
604 double* GetFiniteRange() VTK_SIZEHINT(2) { return this->GetFiniteRange(0); }
605
614 void GetFiniteRange(double range[2]) { this->GetFiniteRange(range, 0); }
615
617
622 void GetDataTypeRange(double range[2]);
625 static void GetDataTypeRange(int type, double range[2]);
626 static double GetDataTypeMin(int type);
627 static double GetDataTypeMax(int type);
629
634 virtual double GetMaxNorm();
635
645 static vtkDataArray* CreateDataArray(int dataType);
646
653
663
673
683
687 void Modified() override;
688
694
702 int CopyInformation(vtkInformation* infoFrom, vtkTypeBool deep = 1) override;
703
707 int GetArrayType() const override { return vtkDataArray::ArrayTypeTag::value; }
708
709 enum MemorySpace
710 {
711 HostMemory, // CPU memory
712 CudaDeviceMemory, // NVIDIA GPU via CUDA
713 HipDeviceMemory, // AMD GPU via HIP
714 };
715
719 virtual MemorySpace GetMemorySpace() { return MemorySpace::HostMemory; }
720
725 virtual void* GetDeviceVoidPointer(vtkIdType vtkNotUsed(valueIdx)) { return nullptr; }
726
727protected:
728 friend class vtkPoints;
729 friend class vtkFieldData;
730
732
748 virtual void ComputeRange(double range[2], int comp);
749 virtual void ComputeRange(
750 double range[2], int comp, const unsigned char* ghosts, unsigned char ghostsToSkip = 0xff);
752
754
770 virtual void ComputeFiniteRange(double range[2], int comp);
771 virtual void ComputeFiniteRange(
772 double range[2], int comp, const unsigned char* ghosts, unsigned char ghostsToSkip = 0xff);
774
776
791 virtual bool ComputeScalarRange(double* ranges);
792 virtual bool ComputeScalarRange(
793 double* ranges, const unsigned char* ghosts, unsigned char ghostsToSkip = 0xff);
795
797
809 virtual bool ComputeVectorRange(double range[2]);
810 virtual bool ComputeVectorRange(
811 double range[2], const unsigned char* ghosts, unsigned char ghostsToSkip = 0xff);
813
815
829 virtual bool ComputeFiniteScalarRange(double* ranges);
831 double* ranges, const unsigned char* ghosts, unsigned char ghostsToSkip = 0xff);
833
835
847 virtual bool ComputeFiniteVectorRange(double range[2]);
849 double range[2], const unsigned char* ghosts, unsigned char ghostsToSkip = 0xff);
851
852 // Construct object with default tuple dimension (number of components) of 1.
854 ~vtkDataArray() override;
855
857 double Range[2];
858 double FiniteRange[2];
859
860private:
861 double* GetTupleN(vtkIdType i, int n);
862
863 vtkDataArray(const vtkDataArray&) = delete;
864 void operator=(const vtkDataArray&) = delete;
865};
866
868VTK_ABI_NAMESPACE_END
869
870// These are used by vtkDataArrayPrivate.txx, but need to be available to
871// vtkGenericDataArray.h as well.
872namespace vtkDataArrayPrivate
873{
874VTK_ABI_NAMESPACE_BEGIN
876{
877};
879{
880};
881VTK_ABI_NAMESPACE_END
882}
883
884#endif
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 int GetDataTypeSize() const =0
Return the size of the underlying data type.
std::integral_constant< int, VTK_OPAQUE > DataTypeTag
vtkIdType GetNumberOfValues() const
Get the total number of values in the array.
virtual double * GetTuple(vtkIdType tupleIdx)=0
Get the data tuple at tupleIdx.
void InsertNextTuple1(double value)
These methods are included as convenience for the wrappers.
double * GetTuple4(vtkIdType tupleIdx)
These methods are included as convenience for the wrappers.
double * GetRange()
Return the range of the data array.
virtual void ComputeRange(double range[2], int comp, const unsigned char *ghosts, unsigned char ghostsToSkip=0xff)
Compute the range for a specific component.
static double GetDataTypeMin(int type)
These methods return the Min and Max possible range of the native data type.
virtual void FillComponent(int compIdx, double value)
Fill a component of a data array with a specified value.
double * GetTuple2(vtkIdType tupleIdx)
These methods are included as convenience for the wrappers.
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...
double Range[2]
virtual bool ComputeScalarRange(double *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 ...
virtual bool ComputeVectorRange(double range[2])
Returns true if the range was computed.
void InsertTuple9(vtkIdType tupleIdx, double val0, double val1, double val2, double val3, double val4, double val5, double val6, double val7, double val8)
These methods are included as convenience for the wrappers.
void SetTuple4(vtkIdType tupleIdx, double val0, double val1, double val2, double val3)
These methods are included as convenience for the wrappers.
int IsNumeric() const override
This method is here to make backward compatibility easier.
void CreateDefaultLookupTable()
Create default lookup table.
void DeepCopy(vtkAbstractArray *aa) override
Deep copy of data.
void SetTuple(vtkIdType dstTupleIdx, vtkIdType srcTupleIdx, vtkAbstractArray *source) override
See documentation from parent class.
void GetDataTypeRange(double range[2])
These methods return the Min and Max possible range of the native data type.
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,...
double * GetTuple9(vtkIdType tupleIdx)
These methods are included as convenience for the wrappers.
virtual void ComputeRange(double range[2], int comp)
Compute the range for a specific component.
double * GetFiniteRange()
Return the range of the data array.
virtual bool ComputeScalarRange(double *ranges)
Computes the range for each component of an array, the length of ranges must be two times the number ...
void SetTuple9(vtkIdType tupleIdx, double val0, double val1, double val2, double val3, double val4, double val5, double val6, double val7, double val8)
These methods are included as convenience for the wrappers.
unsigned long GetActualMemorySize() const override
Return the memory in kibibytes (1024 bytes) consumed by this data array.
void InsertTuples(vtkIdList *dstIds, vtkIdList *srcIds, vtkAbstractArray *source) override
See documentation from parent class.
virtual bool ComputeFiniteVectorRange(double range[2], const unsigned char *ghosts, unsigned char ghostsToSkip=0xff)
Returns true if the range was computed.
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
virtual void GetIntegerTuple(vtkIdType tupleIdx, vtkTypeInt64 *tuple)
Get/set the data at tupleIdx by filling in a user-provided array of integers.
virtual void SetIntegerTuple(vtkIdType tupleIdx, vtkTypeInt64 *tuple)
Get/set the data at tupleIdx by filling in a user-provided array of integers.
void InsertNextTuple3(double val0, double val1, double val2)
These methods are included as convenience for the wrappers.
void InsertTuple2(vtkIdType tupleIdx, double val0, double val1)
These methods are included as convenience for the wrappers.
void InsertNextTuple4(double val0, double val1, double val2, double val3)
These methods are included as convenience for the wrappers.
virtual bool ComputeVectorRange(double range[2], const unsigned char *ghosts, unsigned char ghostsToSkip=0xff)
Returns true if the range was computed.
double * GetTuple6(vtkIdType tupleIdx)
These methods are included as convenience for the wrappers.
~vtkDataArray() override
int GetArrayType() const override
Method for type-checking in FastDownCast implementations.
int GetElementComponentSize() const override
Return the size, in bytes, of the lowest-level element of an array.
virtual bool ComputeFiniteVectorRange(double range[2])
Returns true if the range was computed.
void SetTuple1(vtkIdType tupleIdx, double value)
These methods are included as convenience for the wrappers.
virtual void RemoveTuple(vtkIdType tupleIdx)=0
These methods remove tuples from the data array.
virtual void SetUnsignedTuple(vtkIdType tupleIdx, vtkTypeUInt64 *tuple)
Get/set the data at tupleIdx by filling in a user-provided array of unsigned integers.
virtual void GetUnsignedTuple(vtkIdType tupleIdx, vtkTypeUInt64 *tuple)
Get/set the data at tupleIdx by filling in a user-provided array of unsigned integers.
void GetRange(double range[2], int comp)
The range of the data array values for the given component will be returned in the provided range arr...
virtual void RemoveLastTuple()
These methods remove tuples from the data array.
double * GetRange(int comp)
Return the range of the data array values for the given component.
static vtkDataArray * FastDownCast(vtkAbstractArray *source)
Perform a fast, safe cast from a vtkAbstractArray to a vtkDataArray.
void GetFiniteRange(double range[2], int comp)
The range of the data array values for the given component will be returned in the provided range arr...
void InsertNextTuple6(double val0, double val1, double val2, double val3, double val4, double val5)
These methods are included as convenience for the wrappers.
void GetTuples(vtkIdType p1, vtkIdType p2, vtkAbstractArray *output) override
Get the tuples for the range of tuple ids specified (i.e., p1->p2 inclusive).
double GetDataTypeMin()
These methods return the Min and Max possible range of the native data type.
double FiniteRange[2]
void InsertTuple6(vtkIdType tupleIdx, double val0, double val1, double val2, double val3, double val4, double val5)
These methods are included as convenience for the wrappers.
friend class vtkPoints
vtkSmartPointer< vtkDataArray > ToAOSDataArray()
If the array is not already in AOS format, return a new array that is with the same data.
virtual void SetComponent(vtkIdType tupleIdx, int compIdx, double value)
Set the data component at the location specified by tupleIdx and compIdx to value.
void InsertTuplesStartingAt(vtkIdType dstStart, vtkIdList *srcIds, vtkAbstractArray *source) override
See documentation from parent class.
virtual void ShallowCopy(vtkDataArray *other)
Create a shallow copy of other into this, if possible.
virtual void InsertComponent(vtkIdType tupleIdx, int compIdx, double value)
Insert value at the location specified by tupleIdx and compIdx.
void GetTuples(vtkIdList *tupleIds, vtkAbstractArray *output) override
Given a list of tuple ids, return an array of tuples.
virtual void GetTuple(vtkIdType tupleIdx, double *tuple)=0
Get the data tuple at tupleIdx by filling in a user-provided array, Make sure that your array is larg...
double GetTuple1(vtkIdType tupleIdx)
These methods are included as convenience for the wrappers.
double GetDataTypeMax()
These methods return the Min and Max possible range of the native data type.
virtual void GetData(vtkIdType tupleMin, vtkIdType tupleMax, int compMin, int compMax, vtkDoubleArray *data)
Get the data as a double array in the range (tupleMin,tupleMax) and (compMin, compMax).
void SetLookupTable(vtkLookupTable *lut)
Set/get the lookup table associated with this scalar data, if any.
void GetRange(double range[2])
The range of the data array values will be returned in the provided range array argument.
void SetTuple6(vtkIdType tupleIdx, double val0, double val1, double val2, double val3, double val4, double val5)
These methods are included as convenience for the wrappers.
virtual double GetComponent(vtkIdType tupleIdx, int compIdx)
Return the data component at the location specified by tupleIdx and compIdx.
int CopyInformation(vtkInformation *infoFrom, vtkTypeBool deep=1) override
Copy information instance.
vtkIdType InsertNextTuple(vtkIdType srcTupleIdx, vtkAbstractArray *source) override
See documentation from parent class.
virtual void ComputeFiniteRange(double range[2], int comp)
Compute the range for a specific component.
void InsertNextTuple2(double val0, double val1)
These methods are included as convenience for the wrappers.
virtual void RemoveFirstTuple()
These methods remove tuples from the data array.
virtual void * GetDeviceVoidPointer(vtkIdType valueIdx)
Return a pointer to the data that live on a device (CUDA or HIP).
bool CopyComponent(int dstComponent, vtkAbstractArray *src, int srcComponent) override
Copy a component from one data array into a component on this data array.
virtual double GetMaxNorm()
Return the maximum norm for the tuples.
std::integral_constant< int, vtkArrayTypes::VTK_DATA_ARRAY > ArrayTypeTag
virtual MemorySpace GetMemorySpace()
Return the MemorySpace of where the data is stored.
void InsertTuple(vtkIdType dstTupleIdx, vtkIdType srcTupleIdx, vtkAbstractArray *source) override
See documentation from parent class.
void InsertTuple4(vtkIdType tupleIdx, double val0, double val1, double val2, double val3)
These methods are included as convenience for the wrappers.
void GetRange(double range[2], int comp, const unsigned char *ghosts, unsigned char ghostsToSkip)
The range of the data array values for the given component will be returned in the provided range arr...
static void GetDataTypeRange(int type, double range[2])
These methods return the Min and Max possible range of the native data type.
virtual void * WriteVoidPointer(vtkIdType valueIdx, vtkIdType numValues)=0
Get the address of a particular data index.
virtual bool ComputeFiniteScalarRange(double *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 ...
virtual void ComputeFiniteRange(double range[2], int comp, const unsigned char *ghosts, unsigned char ghostsToSkip=0xff)
Compute the range for a specific component.
static vtkDataArray * CreateDataArray(int dataType)
Creates an array for dataType where dataType is one of VTK_BIT, VTK_CHAR, VTK_SIGNED_CHAR,...
void GetFiniteRange(double range[2], int comp, const unsigned char *ghosts, unsigned char ghostsToSkip)
The range of the data array values for the given component will be returned in the provided range arr...
void InsertTuple3(vtkIdType tupleIdx, double val0, double val1, double val2)
These methods are included as convenience for the wrappers.
void InsertNextTuple9(double val0, double val1, double val2, double val3, double val4, double val5, double val6, double val7, double val8)
These methods are included as convenience for the wrappers.
void SetTuple3(vtkIdType tupleIdx, double val0, double val1, double val2)
These methods are included as convenience for the wrappers.
void GetFiniteRange(double range[2])
The range of the data array values will be returned in the provided range array argument.
friend class vtkFieldData
double * GetFiniteRange(int comp)
Return the range of the data array values for the given component.
double * GetTuple3(vtkIdType tupleIdx)
These methods are included as convenience for the wrappers.
void InsertTuples(vtkIdType dstStart, vtkIdType n, vtkIdType srcStart, vtkAbstractArray *source) override
See documentation from parent class.
void SetTuple2(vtkIdType tupleIdx, double val0, double val1)
These methods are included as convenience for the wrappers.
void InsertTuple1(vtkIdType tupleIdx, double value)
These methods are included as convenience for the wrappers.
virtual bool ComputeFiniteScalarRange(double *ranges)
Computes the range for each component of an array, the length of ranges must be two times the number ...
void Modified() override
Removes out-of-date L2_NORM_RANGE() and L2_NORM_FINITE_RANGE() values.
static double GetDataTypeMax(int type)
These methods return the Min and Max possible range of the native data type.
vtkLookupTable * LookupTable
dynamic, self-adjusting array of double
list of point or cell ids
Definition vtkIdList.h:135
a simple class to control print indentation
Definition vtkIndent.h:108
Key for string values in vtkInformation.
Store vtkAlgorithm input/output information.
map scalar values into colors via a lookup table
represent and manipulate 3D points
Definition vtkPoints.h:140
Hold a reference to a vtkObjectBase instance.
static vtkInformationDoubleVectorKey * COMPONENT_RANGE()
This key is used to hold tight bounds on the range of one component over all tuples of the array.
static vtkInformationDoubleVectorKey * L2_NORM_RANGE()
This key is used to hold tight bounds on the $L_2$ norm of tuples in the array.
static vtkInformationDoubleVectorKey * L2_NORM_FINITE_RANGE()
This key is used to hold tight bounds on the $L_2$ norm of tuples in the array.
static vtkInformationStringKey * UNITS_LABEL()
A human-readable string indicating the units for the array data.
int vtkTypeBool
Definition vtkABI.h:64
#define vtkArrayDownCast_FastCastMacro(ArrayT)
This macro is used to tell vtkArrayDownCast to use FastDownCast instead of SafeDownCast.
boost::graph_traits< vtkGraph * >::vertex_descriptor source(boost::graph_traits< vtkGraph * >::edge_descriptor e, vtkGraph *)
#define vtkDataArray
#define VTK_DEPRECATED_IN_9_7_0(reason)
int vtkIdType
Definition vtkType.h:363
#define VTK_SIZEHINT(...)
#define VTK_EXPECTS(x)
#define VTK_MARSHALMANUAL
#define VTK_NEWINSTANCE