VTK  9.5.20250804
vtkCompositeDataPipeline.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
38#ifndef vtkCompositeDataPipeline_h
39#define vtkCompositeDataPipeline_h
40
41#include "vtkCommonExecutionModelModule.h" // For export macro
43#include "vtkWrappingHints.h" // For VTK_MARSHALAUTO
44#include <vtkSmartPointer.h> // smart pointer
45
46#include <vector> // for vector in return type
47
48VTK_ABI_NAMESPACE_BEGIN
57
58class VTKCOMMONEXECUTIONMODEL_EXPORT VTK_MARSHALAUTO vtkCompositeDataPipeline
60{
61public:
64 void PrintSelf(ostream& os, vtkIndent indent) override;
65
71
76 vtkDataObject* GetCompositeInputData(int port, int index, vtkInformationVector** inInfoVec);
77
84
94
107
117
118protected:
121
122 int ForwardUpstream(vtkInformation* request) override;
123 virtual int ForwardUpstream(int i, int j, vtkInformation* request);
124
125 // Copy information for the given request.
126 void CopyDefaultInformation(vtkInformation* request, int direction,
127 vtkInformationVector** inInfoVec, vtkInformationVector* outInfoVec) override;
128
131
133 vtkInformation* request, vtkInformationVector** inInfo, vtkInformationVector* outInfo) override;
134
136 vtkInformationVector* outInfoVec) override;
137
139 vtkInformationVector* outInfoVec) override;
140
141 // Override this check to account for update extent.
143 int outputPort, vtkInformationVector** inInfoVec, vtkInformationVector* outInfoVec) override;
144
145 // Check whether the data object in the pipeline information exists
146 // and has a valid type.
148 vtkInformation* request, vtkInformationVector** inInfoVec, vtkInformationVector* outInfoVec);
149
150 // True when the pipeline is iterating over the current (simple) filter
151 // to produce composite output. In this case, ExecuteDataStart() should
152 // NOT Initialize() the composite output.
154
156 vtkInformationVector* outInfoVec, int compositePort);
157
159 vtkInformationVector* outInfoVec, int compositePort, int connection, vtkInformation* request,
160 std::vector<vtkSmartPointer<vtkCompositeDataSet>>& compositeOutput);
161
162 std::vector<vtkDataObject*> ExecuteSimpleAlgorithmForBlock(vtkInformationVector** inInfoVec,
163 vtkInformationVector* outInfoVec, vtkInformation* inInfo, vtkInformation* request,
164 vtkDataObject* dobj);
165
166 bool ShouldIterateOverInput(vtkInformationVector** inInfoVec, int& compositePort);
167
168 int InputTypeIsValid(int port, int index, vtkInformationVector** inInfoVec) override;
169
171
174
175 void ResetPipelineInformation(int port, vtkInformation*) override;
176
186 std::vector<vtkSmartPointer<vtkDataObject>> CreateOutputCompositeDataSet(
187 vtkCompositeDataSet* input, int compositePort, int numOutputPorts);
188
189 // Override this to handle UPDATE_COMPOSITE_INDICES().
191 vtkInformationVector* outInfoVec) override;
192
194
201
212
213private:
215 void operator=(const vtkCompositeDataPipeline&) = delete;
216};
217
218VTK_ABI_NAMESPACE_END
219#endif
superclass for composite data iterators
Executive supporting composite datasets.
std::vector< vtkSmartPointer< vtkDataObject > > CreateOutputCompositeDataSet(vtkCompositeDataSet *input, int compositePort, int numOutputPorts)
Tries to create the best possible composite data output for the given input and non-composite algorit...
int ForwardUpstream(vtkInformation *request) override
vtkDataObject * GetCompositeOutputData(int port)
Returns the data object stored with the DATA_OBJECT() in the output port.
int NeedToExecuteBasedOnCompositeIndices(vtkInformation *outInfo)
static vtkCompositeDataPipeline * New()
virtual void ExecuteSimpleAlgorithm(vtkInformation *request, vtkInformationVector **inInfoVec, vtkInformationVector *outInfoVec, int compositePort)
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
void CopyDefaultInformation(vtkInformation *request, int direction, vtkInformationVector **inInfoVec, vtkInformationVector *outInfoVec) override
void ResetPipelineInformation(int port, vtkInformation *) override
int ExecuteData(vtkInformation *request, vtkInformationVector **inInfoVec, vtkInformationVector *outInfoVec) override
vtkDataObject * GetCompositeInputData(int port, int index, vtkInformationVector **inInfoVec)
Returns the data object stored with the DATA_OBJECT() in the input port.
void MarkOutputsGenerated(vtkInformation *request, vtkInformationVector **inInfoVec, vtkInformationVector *outInfoVec) override
virtual int ForwardUpstream(int i, int j, vtkInformation *request)
virtual void PushInformation(vtkInformation *)
void ExecuteDataStart(vtkInformation *request, vtkInformationVector **inInfoVec, vtkInformationVector *outInfoVec) override
int NeedToExecuteData(int outputPort, vtkInformationVector **inInfoVec, vtkInformationVector *outInfoVec) override
int ExecuteDataObject(vtkInformation *request, vtkInformationVector **inInfo, vtkInformationVector *outInfo) override
bool ShouldIterateOverInput(vtkInformationVector **inInfoVec, int &compositePort)
virtual void ExecuteEach(vtkCompositeDataIterator *iter, vtkInformationVector **inInfoVec, vtkInformationVector *outInfoVec, int compositePort, int connection, vtkInformation *request, std::vector< vtkSmartPointer< vtkCompositeDataSet > > &compositeOutput)
virtual int CheckCompositeData(vtkInformation *request, vtkInformationVector **inInfoVec, vtkInformationVector *outInfoVec)
std::vector< vtkDataObject * > ExecuteSimpleAlgorithmForBlock(vtkInformationVector **inInfoVec, vtkInformationVector *outInfoVec, vtkInformation *inInfo, vtkInformation *request, vtkDataObject *dobj)
int InputTypeIsValid(int port, int index, vtkInformationVector **inInfoVec) override
~vtkCompositeDataPipeline() override
virtual void PopInformation(vtkInformation *)
abstract superclass for composite (multi-block or AMR) datasets
general representation of visualization data
a simple class to control print indentation
Definition vtkIndent.h:108
Key for vtkDataObject values.
Key for double values in vtkInformation.
Key for integer values in vtkInformation.
Key for vtkObjectBase values.
Key for string values in vtkInformation.
Store zero or more vtkInformation instances.
Store vtkAlgorithm input/output information.
Hold a reference to a vtkObjectBase instance.
Executive supporting partial updates.
static vtkInformationIntegerKey * LOAD_REQUESTED_BLOCKS()
An integer key that indicates to the source to load all requested blocks specified in UPDATE_COMPOSIT...
static vtkInformationIntegerVectorKey * UPDATE_COMPOSITE_INDICES()
UPDATE_COMPOSITE_INDICES is a key placed in the request to request a set of composite indices from a ...
static vtkInformationObjectBaseKey * COMPOSITE_DATA_META_DATA()
COMPOSITE_DATA_META_DATA is a key placed in the output-port information by readers/sources producing ...
static vtkInformationIntegerVectorKey * DATA_COMPOSITE_INDICES()
COMPOSITE_INDICES() is put in the output information by the executive if the request has UPDATE_COMPO...
static vtkInformationIntegerKey * SUPPRESS_RESET_PI()
Because we sometimes have to swap between "simple" data types and composite data types,...
static vtkInformationDoubleKey * BLOCK_AMOUNT_OF_DETAIL()
BLOCK_AMOUNT_OF_DETAIL is a key placed in the information about a multi-block dataset that indicates ...
#define VTK_MARSHALAUTO