VTK  9.6.20260626
vtkHDFReader.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
50
51#ifndef vtkHDFReader_h
52#define vtkHDFReader_h
53
54#include "vtkDataAssembly.h" // For vtkDataAssembly
56#include "vtkDeprecation.h" // For VTK_DEPRECATED_IN_9_7_0 VTK_DEPRECATED_IN_9_6_0
57#include "vtkIOHDFModule.h" // For export macro
58#include "vtkSmartPointer.h" // For vtkSmartPointer
59
60#include <array> // For storing the time range
61#include <memory> // For std::unique_ptr
62#include <vector> // For storing list of values
63
64VTK_ABI_NAMESPACE_BEGIN
67class vtkCellData;
68class vtkCommand;
70class vtkDataSet;
73class vtkImageData;
74class vtkInformation;
80class vtkPointData;
81class vtkPolyData;
86
92
93class VTKIOHDF_EXPORT vtkHDFReader : public vtkDataObjectAlgorithm
94{
95public:
96 static vtkHDFReader* New();
98 void PrintSelf(ostream& os, vtkIndent indent) override;
99
101
107
109
118
119 enum
120 {
123 };
124
126
138 vtkSetClampMacro(PieceDistribution, int, Block, Interleave);
139 vtkGetMacro(PieceDistribution, int);
141
151 virtual vtkTypeBool CanReadFile(VTK_FILEPATH const char* name);
152 static bool CanReadFile(vtkResourceStream* stream);
154
156
162
164
172
174
180
182
186 const char* GetPointArrayName(int index);
187 const char* GetCellArrayName(int index);
189
191
201 vtkGetMacro(Step, vtkIdType);
202 vtkSetMacro(Step, vtkIdType);
203 vtkGetMacro(TimeValue, double);
204 const std::array<double, 2>& GetTimeRange() const { return this->TimeRange; }
206
208
211 VTK_DEPRECATED_IN_9_7_0("Do not use, cache is on by default and should not be disabled.")
212 virtual bool GetUseCache();
213 VTK_DEPRECATED_IN_9_7_0("Do not use, cache is on by default and should not be disabled.")
214 virtual void SetUseCache(bool use);
215 VTK_DEPRECATED_IN_9_7_0("Do not use, cache is on by default and should not be disabled.")
216 virtual void UseCacheOn();
217 VTK_DEPRECATED_IN_9_7_0("Do not use, cache is on by default and should not be disabled.")
218 virtual void UseCacheOff();
220
222
228 vtkSetMacro(MaximumLevelsToReadByDefaultForAMR, unsigned int);
229 vtkGetMacro(MaximumLevelsToReadByDefaultForAMR, unsigned int);
231
233
236 VTK_DEPRECATED_IN_9_7_0("Do not use, will be removed.")
238 VTK_DEPRECATED_IN_9_7_0("Do not use, will be removed.")
239 void SetAttributeOriginalIdName(vtkIdType attribute, const std::string& name);
241
246
247protected:
249 ~vtkHDFReader() override;
250
254 int CanReadFileVersion(int major, int minor);
255
257
262 int Read(vtkInformation* outInfo, vtkImageData* data);
271 int ReadRecursively(vtkInformation* outInfo, vtkMultiBlockDataSet* data, const std::string& path);
273
274 VTK_DEPRECATED_IN_9_6_0("This method is deprecated, do not use")
275 int Read(const std::vector<vtkIdType>& numberOfPoints,
276 const std::vector<vtkIdType>& numberOfCells,
277 const std::vector<vtkIdType>& numberOfConnectivityIds, vtkIdType partOffset,
278 vtkIdType startingPointOffset, vtkIdType startingCellOffset,
279 vtkIdType startingConnectctivityIdOffset, int filePiece, vtkUnstructuredGrid* pieceData);
280
284 VTK_DEPRECATED_IN_9_7_0("This method is deprecated, do not use")
286
291 vtkObject* caller, unsigned long eid, void* clientdata, void* calldata);
292
294
299 vtkInformationVector* outputVector) override;
301 vtkInformationVector* outputVector) override;
303 vtkInformationVector* outputVector) override;
305
310
315
319 char* FileName;
320
325
331
338
343
345
350 double TimeValue = 0.0;
351 std::array<double, 2> TimeRange;
353
355
356 bool UseCache = true;
357 struct DataCache;
358 std::shared_ptr<DataCache> Cache;
359
360private:
361 vtkHDFReader(const vtkHDFReader&) = delete;
362 void operator=(const vtkHDFReader&) = delete;
363
364 class Implementation;
365 Implementation* Impl;
366
371 bool ReadData(vtkInformation* outInfo, vtkDataObject* data);
372
378 bool ReadStructuredData(
379 vtkDataSet* data, const int* WholeExtent, const std::vector<int>& updateExtent);
380
385 bool ReadAMRData(vtkOverlappingAMR* data, unsigned int maxLevel,
386 vtkDataArraySelection* dataArraySelection[3], bool isTemporalData);
387
393 int Read(const std::vector<vtkIdType>& numberOfPoints,
394 const std::vector<vtkIdType>& numberOfCells,
395 const std::vector<vtkIdType>& numberOfConnectivityIds,
396 const std::vector<vtkIdType>& numberOfFaces,
397 const std::vector<vtkIdType>& numberOfPolyhedronToFaceIds,
398 const std::vector<vtkIdType>& numberOfFaceConnectivityIds,
399 vtkHDFUtilities::TemporalGeometryOffsets& geoOffsets, int filePiece,
400 vtkUnstructuredGrid* pieceData);
401
407 int Read(const std::vector<vtkIdType>& numberOfTrees, const std::vector<vtkIdType>& numberOfCells,
408 const std::vector<vtkIdType>& numberOfDepths, const std::vector<vtkIdType>& descriptorSizes,
409 const vtkHDFUtilities::TemporalHyperTreeGridOffsets& htgTemporalOffsets, int filePiece,
410 vtkHyperTreeGrid* pieceData);
411
415 void SetHasTemporalData(bool useTemporalData);
416
423 std::vector<int> GetPieceAssignmentForDistribution(
424 int pieceIdx, int numDatasets, int numPieces) const;
425
430 void GenerateAssembly();
431
436 bool RetrieveStepsFromAssembly();
437
442 bool RetrieveDataArraysFromAssembly();
443
447 bool ReadFieldArrays(vtkDataObject* data);
448
449 vtkSmartPointer<vtkDataObject> OutputCache;
450
451 std::map<vtkIdType, std::string> AttributesOriginalIdName{
452 { vtkDataObject::POINT, "__pointsOriginalIds__" },
453 { vtkDataObject::CELL, "__cellOriginalIds__" }, { vtkDataObject::FIELD, "__fieldOriginalIds__" }
454 };
455
456 bool HasTemporalData = false;
457 std::string CompositeCachePath; // Identifier for the current composite piece
458 int PieceDistribution = Interleave;
459};
460
461VTK_ABI_NAMESPACE_END
462#endif
Abstract superclass for all arrays.
supports function callbacks
represent and manipulate cell attribute data
superclass for callback/observer methods
Definition vtkCommand.h:385
Store on/off settings for data arrays, etc.
hierarchical representation to use with vtkPartitionedDataSetCollection
general representation of visualization data
represent and manipulate attribute data in a dataset
abstract class to specify dataset behavior
Definition vtkDataSet.h:166
Implementation for the vtkHDFReader.
int GetNumberOfPointArrays()
Get the number of point or cell arrays available in the input.
int GetNumberOfCellArrays()
Get the number of point or cell arrays available in the input.
static bool CanReadFile(vtkResourceStream *stream)
const char * GetCellArrayName(int index)
Get the name of the point or cell array with the given index in the input.
vtkIdType Step
Temporal data properties.
vtkSmartPointer< vtkResourceStream > Stream
The input stream.
virtual vtkDataArraySelection * GetFieldDataArraySelection()
Get the data array selection tables used to configure which data arrays are loaded by the reader.
vtkDataSet * GetOutputAsDataSet(int index)
Get the output as a vtkDataSet pointer.
std::shared_ptr< DataCache > Cache
virtual vtkDataArraySelection * GetCellDataArraySelection()
Get the data array selection tables used to configure which data arrays are loaded by the reader.
virtual bool GetUseCache()
Boolean property determining whether to use the internal cache or not (default is true).
virtual vtkTypeBool CanReadFile(const char *name)
Return true if, after a quick check of file header, it looks like the provided file or stream can be ...
int CanReadFileVersion(int major, int minor)
Test if the reader can read a file with the given version number.
int Read(vtkInformation *outInfo, vtkImageData *data)
Reads the 'data' requested in 'outInfo' (through extents or pieces) for a specialized data type.
virtual void SetUseCache(bool use)
Boolean property determining whether to use the internal cache or not (default is true).
const std::array< double, 2 > & GetTimeRange() const
Getters and setters for temporal data.
vtkSetFilePathMacro(FileName)
Get/Set the name of the input file.
int RequestInformation(vtkInformation *request, vtkInformationVector **inputVector, vtkInformationVector *outputVector) override
Standard functions to specify the type, information and read the data from the file.
int RequestDataObject(vtkInformation *request, vtkInformationVector **inputVector, vtkInformationVector *outputVector) override
Standard functions to specify the type, information and read the data from the file.
vtkMTimeType GetMTime() override
Overridden to take into account mtime from the internal vtkResourceStream.
int RequestData(vtkInformation *request, vtkInformationVector **inputVector, vtkInformationVector *outputVector) override
Standard functions to specify the type, information and read the data from the file.
static vtkHDFReader * New()
virtual void UseCacheOff()
Boolean property determining whether to use the internal cache or not (default is true).
vtkGetFilePathMacro(FileName)
Get/Set the name of the input file.
static void SelectionModifiedCallback(vtkObject *caller, unsigned long eid, void *clientdata, void *calldata)
Modify this object when an array selection is changed.
int AddFieldArrays(vtkDataObject *data)
Read the field arrays from the file and add them to the dataset.
std::array< double, 2 > TimeRange
Assembly used for PartitionedDataSetCollection.
vtkResourceStream * GetStream()
Specify stream to read from When both Stream and Filename are set, stream is used.
unsigned int MaximumLevelsToReadByDefaultForAMR
void SetAttributeOriginalIdName(vtkIdType attribute, const std::string &name)
Get or Set the Original id name of an attribute (POINT, CELL, FIELD...)
vtkIdType NumberOfSteps
Assembly used for PartitionedDataSetCollection.
double TimeValue
Assembly used for PartitionedDataSetCollection.
const char * GetPointArrayName(int index)
Get the name of the point or cell array with the given index in the input.
char * FileName
The input file's name.
int ReadRecursively(vtkInformation *outInfo, vtkMultiBlockDataSet *data, const std::string &path)
Reads the 'data' requested in 'outInfo' (through extents or pieces) for a specialized data type.
int SetupInformation(vtkInformation *outInfo)
Setup the information pass in parameter based on current vtkHDF file loaded.
virtual vtkDataArraySelection * GetPointDataArraySelection()
Get the data array selection tables used to configure which data arrays are loaded by the reader.
bool GetHasTemporalData()
Getters and setters for temporal data.
vtkDataArraySelection * DataArraySelection[3]
The array selections.
vtkCallbackCommand * SelectionObserver
The observer to modify this object when the array selections are modified.
std::string GetAttributeOriginalIdName(vtkIdType attribute)
Get or Set the Original id name of an attribute (POINT, CELL, FIELD...)
void SetStream(vtkResourceStream *stream)
Specify stream to read from When both Stream and Filename are set, stream is used.
vtkSmartPointer< vtkDataAssembly > Assembly
Assembly used for PartitionedDataSetCollection.
void PrintPieceInformation(vtkInformation *outInfo)
Print update number of pieces, piece number and ghost levels.
vtkDataSet * GetOutputAsDataSet()
Get the output as a vtkDataSet pointer.
virtual void UseCacheOn()
Boolean property determining whether to use the internal cache or not (default is true).
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
A dataset containing a grid of vtkHyperTree instances arranged as a rectilinear grid.
topologically and geometrically regular array of data
a simple class to control print indentation
Definition vtkIndent.h:108
Store zero or more vtkInformation instances.
Store vtkAlgorithm input/output information.
Composite dataset that organizes datasets into blocks.
a multi-resolution dataset based on vtkCartesianGrid allowing overlaps
Composite dataset that groups datasets as a collection.
composite dataset to encapsulates a dataset consisting of partitions.
represent and manipulate point attribute data
concrete dataset represents vertices, lines, polygons, and triangle strips
a dataset that is topologically regular with variable spacing in the three coordinate directions
Abstract class used for custom streams.
Hold a reference to a vtkObjectBase instance.
topologically regular array of data
dataset represents arbitrary combinations of all possible cell types
Common utility variables and functions for reader and writer of vtkHDF.
int vtkTypeBool
Definition vtkABI.h:64
#define VTK_DEPRECATED_IN_9_7_0(reason)
#define VTK_DEPRECATED_IN_9_6_0(reason)
int vtkIdType
Definition vtkType.h:363
vtkTypeUInt32 vtkMTimeType
Definition vtkType.h:318
#define VTK_FILEPATH