VTK  9.3.1
vtkPNrrdReader.h
Go to the documentation of this file.
1 // SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
2 // SPDX-FileCopyrightText: Copyright (c) Sandia Corporation
3 // SPDX-License-Identifier: BSD-3-Clause
4 
27 #ifndef vtkPNrrdReader_h
28 #define vtkPNrrdReader_h
29 
30 #include "vtkIOMPIImageModule.h" // For export macro
31 #include "vtkNrrdReader.h"
32 
33 VTK_ABI_NAMESPACE_BEGIN
34 class vtkCharArray;
36 class vtkMPIOpaqueFileHandle;
37 
38 class VTKIOMPIIMAGE_EXPORT vtkPNrrdReader : public vtkNrrdReader
39 {
40 public:
41  vtkTypeMacro(vtkPNrrdReader, vtkNrrdReader);
42  static vtkPNrrdReader* New();
43  void PrintSelf(ostream& os, vtkIndent indent) override;
44 
46 
50  vtkGetObjectMacro(Controller, vtkMultiProcessController);
51  virtual void SetController(vtkMultiProcessController*);
53 
54 protected:
56  ~vtkPNrrdReader() override;
57 
58  int ReadHeader() override;
59  int ReadHeader(vtkCharArray* headerBuffer) override;
60 
64  int GetDataScalarTypeSize();
65 
71  virtual void PartitionController(const int extent[6]);
72 
77  virtual unsigned long GetHeaderSize(vtkMPIOpaqueFileHandle& file);
78 
85  virtual void SetupFileView(vtkMPIOpaqueFileHandle& file, const int extent[6]);
86 
93  virtual void ReadSlice(int slice, const int extent[6], void* buffer);
94 
99  virtual void TransformData(vtkImageData* data);
100 
102 
106  void SetGroupedController(vtkMultiProcessController*);
109 
111 
113 
114 private:
115  vtkPNrrdReader(const vtkPNrrdReader&) = delete;
116  void operator=(const vtkPNrrdReader&) = delete;
117 };
118 
119 VTK_ABI_NAMESPACE_END
120 #endif // vtkPNrrdReader_h
Read nrrd files efficiently from parallel file systems (and reasonably well elsewhere).
Store vtkAlgorithm input/output information.
vtkMultiProcessController * GroupedController
A group of processes that are reading the same file (as determined by PartitionController.
unsigned long GetHeaderSize()
Get the size of the header computed by this object.
dynamic, self-adjusting array of char
Definition: vtkCharArray.h:40
a simple class to control print indentation
Definition: vtkIndent.h:28
topologically and geometrically regular array of data
Definition: vtkImageData.h:42
vtkMultiProcessController * Controller
Read nrrd files file system.
Definition: vtkNrrdReader.h:35
virtual int ReadHeader()
void ExecuteDataWithInformation(vtkDataObject *data, vtkInformation *outInfo) override
This is a convenience method that is implemented in many subclasses instead of RequestData.
static vtkNrrdReader * New()
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
general representation of visualization data
Definition: vtkDataObject.h:54
Multiprocessing communication superclass.