|  | 
| virtual int | IsA (const char *type) | 
|  | 
| vtkMultiThreshold * | NewInstance () const | 
|  | 
| virtual void | PrintSelf (ostream &os, vtkIndent indent) | 
|  | 
| int | AddBooleanSet (int operation, int numInputs, int *inputs) | 
|  | 
| int | OutputSet (int setId) | 
|  | 
| void | Reset () | 
|  | 
|  | 
| int | AddIntervalSet (double xmin, double xmax, int omin, int omax, int assoc, const char *arrayName, int component, int allScalars) | 
|  | 
| int | AddIntervalSet (double xmin, double xmax, int omin, int omax, int assoc, int attribType, int component, int allScalars) | 
|  | 
|  | 
| int | AddLowpassIntervalSet (double xmax, int assoc, const char *arrayName, int component, int allScalars) | 
|  | 
| int | AddHighpassIntervalSet (double xmin, int assoc, const char *arrayName, int component, int allScalars) | 
|  | 
| int | AddBandpassIntervalSet (double xmin, double xmax, int assoc, const char *arrayName, int component, int allScalars) | 
|  | 
| int | AddNotchIntervalSet (double xlo, double xhi, int assoc, const char *arrayName, int component, int allScalars) | 
|  | 
| vtkMultiBlockDataSetAlgorithm * | NewInstance () const | 
|  | 
| vtkMultiBlockDataSet * | GetOutput () | 
|  | 
| vtkMultiBlockDataSet * | GetOutput (int) | 
|  | 
| void | SetInputData (vtkDataObject *) | 
|  | 
| void | SetInputData (int, vtkDataObject *) | 
|  | 
| virtual int | ProcessRequest (vtkInformation *request, vtkInformationVector **inputVector, vtkInformationVector *outputVector) | 
|  | 
| vtkAlgorithm * | NewInstance () const | 
|  | 
| int | HasExecutive () | 
|  | 
| vtkExecutive * | GetExecutive () | 
|  | 
| virtual void | SetExecutive (vtkExecutive *executive) | 
|  | 
| virtual int | ModifyRequest (vtkInformation *request, int when) | 
|  | 
| vtkInformation * | GetInputPortInformation (int port) | 
|  | 
| vtkInformation * | GetOutputPortInformation (int port) | 
|  | 
| int | GetNumberOfInputPorts () | 
|  | 
| int | GetNumberOfOutputPorts () | 
|  | 
| void | UpdateProgress (double amount) | 
|  | 
| vtkInformation * | GetInputArrayInformation (int idx) | 
|  | 
| void | RemoveAllInputs () | 
|  | 
| vtkDataObject * | GetOutputDataObject (int port) | 
|  | 
| virtual void | RemoveInputConnection (int port, vtkAlgorithmOutput *input) | 
|  | 
| virtual void | RemoveInputConnection (int port, int idx) | 
|  | 
| virtual void | RemoveAllInputConnections (int port) | 
|  | 
| int | GetNumberOfInputConnections (int port) | 
|  | 
| int | GetTotalNumberOfInputConnections () | 
|  | 
| vtkAlgorithmOutput * | GetInputConnection (int port, int index) | 
|  | 
| vtkAlgorithm * | GetInputAlgorithm (int port, int index, int &algPort) | 
|  | 
| vtkAlgorithm * | GetInputAlgorithm (int port, int index) | 
|  | 
| vtkExecutive * | GetInputExecutive (int port, int index) | 
|  | 
| vtkInformation * | GetInputInformation (int port, int index) | 
|  | 
| vtkInformation * | GetOutputInformation (int port) | 
|  | 
| virtual void | UpdateInformation () | 
|  | 
| virtual void | UpdateDataObject () | 
|  | 
| virtual void | PropagateUpdateExtent () | 
|  | 
| virtual void | UpdateWholeExtent () | 
|  | 
| void | ConvertTotalInputToPortConnection (int ind, int &port, int &conn) | 
|  | 
| int | SetUpdateExtentToWholeExtent (int port) | 
|  | 
| int | SetUpdateExtentToWholeExtent () | 
|  | 
| void | SetUpdateExtent (int port, int extent[6]) | 
|  | 
| int | ProcessRequest (vtkInformation *request, vtkCollection *inInfo, vtkInformationVector *outInfo) | 
|  | 
| virtual int | ComputePipelineMTime (vtkInformation *request, vtkInformationVector **inInfoVec, vtkInformationVector *outInfoVec, int requestFromOutputPort, unsigned long *mtime) | 
|  | 
| virtual vtkInformation * | GetInformation () | 
|  | 
| virtual void | SetInformation (vtkInformation *) | 
|  | 
| virtual void | Register (vtkObjectBase *o) | 
|  | 
| virtual void | UnRegister (vtkObjectBase *o) | 
|  | 
| virtual void | SetAbortExecute (int) | 
|  | 
| virtual int | GetAbortExecute () | 
|  | 
| virtual void | AbortExecuteOn () | 
|  | 
| virtual void | AbortExecuteOff () | 
|  | 
| virtual void | SetProgress (double) | 
|  | 
| virtual double | GetProgress () | 
|  | 
| void | SetProgressText (const char *ptext) | 
|  | 
| virtual char * | GetProgressText () | 
|  | 
| virtual unsigned long | GetErrorCode () | 
|  | 
| virtual void | SetInputArrayToProcess (int idx, int port, int connection, int fieldAssociation, const char *name) | 
|  | 
| virtual void | SetInputArrayToProcess (int idx, int port, int connection, int fieldAssociation, int fieldAttributeType) | 
|  | 
| virtual void | SetInputArrayToProcess (int idx, vtkInformation *info) | 
|  | 
| virtual void | SetInputArrayToProcess (int idx, int port, int connection, const char *fieldAssociation, const char *attributeTypeorName) | 
|  | 
| vtkDataObject * | GetInputDataObject (int port, int connection) | 
|  | 
| virtual void | SetInputConnection (int port, vtkAlgorithmOutput *input) | 
|  | 
| virtual void | SetInputConnection (vtkAlgorithmOutput *input) | 
|  | 
| virtual void | AddInputConnection (int port, vtkAlgorithmOutput *input) | 
|  | 
| virtual void | AddInputConnection (vtkAlgorithmOutput *input) | 
|  | 
| virtual void | SetInputDataObject (int port, vtkDataObject *data) | 
|  | 
| virtual void | SetInputDataObject (vtkDataObject *data) | 
|  | 
| virtual void | AddInputDataObject (int port, vtkDataObject *data) | 
|  | 
| virtual void | AddInputDataObject (vtkDataObject *data) | 
|  | 
| vtkAlgorithmOutput * | GetOutputPort (int index) | 
|  | 
| vtkAlgorithmOutput * | GetOutputPort () | 
|  | 
| vtkAlgorithm * | GetInputAlgorithm () | 
|  | 
| vtkExecutive * | GetInputExecutive () | 
|  | 
| vtkInformation * | GetInputInformation () | 
|  | 
| virtual void | Update (int port) | 
|  | 
| virtual void | Update () | 
|  | 
| virtual void | SetReleaseDataFlag (int) | 
|  | 
| virtual int | GetReleaseDataFlag () | 
|  | 
| void | ReleaseDataFlagOn () | 
|  | 
| void | ReleaseDataFlagOff () | 
|  | 
| int | UpdateExtentIsEmpty (vtkInformation *pinfo, vtkDataObject *output) | 
|  | 
| int | UpdateExtentIsEmpty (vtkInformation *pinfo, int extentType) | 
|  | 
| void | SetUpdateExtent (int port, int piece, int numPieces, int ghostLevel) | 
|  | 
| void | SetUpdateExtent (int piece, int numPieces, int ghostLevel) | 
|  | 
| void | SetUpdateExtent (int extent[6]) | 
|  | 
| int * | GetUpdateExtent () | 
|  | 
| int * | GetUpdateExtent (int port) | 
|  | 
| void | GetUpdateExtent (int &x0, int &x1, int &y0, int &y1, int &z0, int &z1) | 
|  | 
| void | GetUpdateExtent (int port, int &x0, int &x1, int &y0, int &y1, int &z0, int &z1) | 
|  | 
| void | GetUpdateExtent (int extent[6]) | 
|  | 
| void | GetUpdateExtent (int port, int extent[6]) | 
|  | 
| int | GetUpdatePiece () | 
|  | 
| int | GetUpdatePiece (int port) | 
|  | 
| int | GetUpdateNumberOfPieces () | 
|  | 
| int | GetUpdateNumberOfPieces (int port) | 
|  | 
| int | GetUpdateGhostLevel () | 
|  | 
| int | GetUpdateGhostLevel (int port) | 
|  | 
| void | SetProgressObserver (vtkProgressObserver *) | 
|  | 
| virtual vtkProgressObserver * | GetProgressObserver () | 
|  | 
| vtkObject * | NewInstance () const | 
|  | 
| virtual void | DebugOn () | 
|  | 
| virtual void | DebugOff () | 
|  | 
| bool | GetDebug () | 
|  | 
| void | SetDebug (bool debugFlag) | 
|  | 
| virtual void | Modified () | 
|  | 
| virtual unsigned long | GetMTime () | 
|  | 
| unsigned long | AddObserver (unsigned long event, vtkCommand *, float priority=0.0f) | 
|  | 
| unsigned long | AddObserver (const char *event, vtkCommand *, float priority=0.0f) | 
|  | 
| vtkCommand * | GetCommand (unsigned long tag) | 
|  | 
| void | RemoveObserver (vtkCommand *) | 
|  | 
| void | RemoveObservers (unsigned long event, vtkCommand *) | 
|  | 
| void | RemoveObservers (const char *event, vtkCommand *) | 
|  | 
| int | HasObserver (unsigned long event, vtkCommand *) | 
|  | 
| int | HasObserver (const char *event, vtkCommand *) | 
|  | 
| void | RemoveObserver (unsigned long tag) | 
|  | 
| void | RemoveObservers (unsigned long event) | 
|  | 
| void | RemoveObservers (const char *event) | 
|  | 
| void | RemoveAllObservers () | 
|  | 
| int | HasObserver (unsigned long event) | 
|  | 
| int | HasObserver (const char *event) | 
|  | 
| template<class U , class T > | 
| unsigned long | AddObserver (unsigned long event, U observer, void(T::*callback)(), float priority=0.0f) | 
|  | 
| template<class U , class T > | 
| unsigned long | AddObserver (unsigned long event, U observer, void(T::*callback)(vtkObject *, unsigned long, void *), float priority=0.0f) | 
|  | 
| template<class U , class T > | 
| unsigned long | AddObserver (unsigned long event, U observer, bool(T::*callback)(vtkObject *, unsigned long, void *), float priority=0.0f) | 
|  | 
| int | InvokeEvent (unsigned long event, void *callData) | 
|  | 
| int | InvokeEvent (const char *event, void *callData) | 
|  | 
| int | InvokeEvent (unsigned long event) | 
|  | 
| int | InvokeEvent (const char *event) | 
|  | 
| const char * | GetClassName () const | 
|  | 
| virtual void | Delete () | 
|  | 
| virtual void | FastDelete () | 
|  | 
| void | Print (ostream &os) | 
|  | 
| void | SetReferenceCount (int) | 
|  | 
| void | PrintRevisions (ostream &) | 
|  | 
| virtual void | PrintHeader (ostream &os, vtkIndent indent) | 
|  | 
| virtual void | PrintTrailer (ostream &os, vtkIndent indent) | 
|  | 
| int | GetReferenceCount () | 
|  | 
|  | 
| virtual vtkObjectBase * | NewInstanceInternal () const | 
|  | 
|  | vtkMultiThreshold () | 
|  | 
| virtual | ~vtkMultiThreshold () | 
|  | 
| virtual int | RequestData (vtkInformation *, vtkInformationVector **, vtkInformationVector *) | 
|  | 
| virtual int | FillInputPortInformation (int port, vtkInformation *info) | 
|  | 
| int | AddIntervalSet (NormKey &nk, double xmin, double xmax, int omin, int omax) | 
|  | 
| void | PrintGraph (ostream &os) | 
|  | 
|  | vtkMultiThreshold (const vtkMultiThreshold &) | 
|  | 
| void | operator= (const vtkMultiThreshold &) | 
|  | 
|  | 
| void | UpdateDependents (int id, std::set< int > &unresolvedOutputs, TruthTreeValues &setStates, vtkCellData *inCellData, vtkIdType cellId, vtkGenericCell *cell, std::vector< vtkUnstructuredGrid * > &outv) | 
|  | 
|  | vtkMultiBlockDataSetAlgorithm () | 
|  | 
|  | ~vtkMultiBlockDataSetAlgorithm () | 
|  | 
| virtual vtkExecutive * | CreateDefaultExecutive () | 
|  | 
| virtual int | FillOutputPortInformation (int port, vtkInformation *info) | 
|  | 
| vtkDataObject * | GetInput (int port) | 
|  | 
| virtual int | RequestDataObject (vtkInformation *, vtkInformationVector **, vtkInformationVector *) | 
|  | 
| virtual int | RequestInformation (vtkInformation *, vtkInformationVector **, vtkInformationVector *) | 
|  | 
| virtual int | RequestUpdateExtent (vtkInformation *, vtkInformationVector **, vtkInformationVector *) | 
|  | 
|  | vtkAlgorithm () | 
|  | 
|  | ~vtkAlgorithm () | 
|  | 
| virtual void | SetNumberOfInputPorts (int n) | 
|  | 
| virtual void | SetNumberOfOutputPorts (int n) | 
|  | 
| int | InputPortIndexInRange (int index, const char *action) | 
|  | 
| int | OutputPortIndexInRange (int index, const char *action) | 
|  | 
| int | GetInputArrayAssociation (int idx, vtkInformationVector **inputVector) | 
|  | 
| virtual void | ReportReferences (vtkGarbageCollector *) | 
|  | 
| virtual void | SetNumberOfInputConnections (int port, int n) | 
|  | 
| int | GetInputArrayAssociation (int idx, int connection, vtkInformationVector **inputVector) | 
|  | 
| int | GetInputArrayAssociation (int idx, vtkDataObject *input) | 
|  | 
| vtkDataArray * | GetInputArrayToProcess (int idx, vtkInformationVector **inputVector) | 
|  | 
| vtkDataArray * | GetInputArrayToProcess (int idx, vtkInformationVector **inputVector, int &association) | 
|  | 
| vtkDataArray * | GetInputArrayToProcess (int idx, int connection, vtkInformationVector **inputVector) | 
|  | 
| vtkDataArray * | GetInputArrayToProcess (int idx, int connection, vtkInformationVector **inputVector, int &association) | 
|  | 
| vtkDataArray * | GetInputArrayToProcess (int idx, vtkDataObject *input) | 
|  | 
| vtkDataArray * | GetInputArrayToProcess (int idx, vtkDataObject *input, int &association) | 
|  | 
| vtkAbstractArray * | GetInputAbstractArrayToProcess (int idx, vtkInformationVector **inputVector) | 
|  | 
| vtkAbstractArray * | GetInputAbstractArrayToProcess (int idx, vtkInformationVector **inputVector, int &association) | 
|  | 
| vtkAbstractArray * | GetInputAbstractArrayToProcess (int idx, int connection, vtkInformationVector **inputVector) | 
|  | 
| vtkAbstractArray * | GetInputAbstractArrayToProcess (int idx, int connection, vtkInformationVector **inputVector, int &association) | 
|  | 
| vtkAbstractArray * | GetInputAbstractArrayToProcess (int idx, vtkDataObject *input) | 
|  | 
| vtkAbstractArray * | GetInputAbstractArrayToProcess (int idx, vtkDataObject *input, int &association) | 
|  | 
| vtkInformation * | GetInputArrayFieldInformation (int idx, vtkInformationVector **inputVector) | 
|  | 
| virtual void | SetNthInputConnection (int port, int index, vtkAlgorithmOutput *input) | 
|  | 
| void | SetInputDataInternal (int port, vtkDataObject *input) | 
|  | 
| void | AddInputDataInternal (int port, vtkDataObject *input) | 
|  | 
| virtual void | SetErrorCode (unsigned long) | 
|  | 
|  | vtkObject () | 
|  | 
| virtual | ~vtkObject () | 
|  | 
| virtual void | RegisterInternal (vtkObjectBase *, int check) | 
|  | 
| virtual void | UnRegisterInternal (vtkObjectBase *, int check) | 
|  | 
| void | InternalGrabFocus (vtkCommand *mouseEvents, vtkCommand *keypressEvents=NULL) | 
|  | 
| void | InternalReleaseFocus () | 
|  | 
|  | vtkObjectBase () | 
|  | 
| virtual | ~vtkObjectBase () | 
|  | 
| virtual void | CollectRevisions (ostream &) | 
|  | 
|  | vtkObjectBase (const vtkObjectBase &) | 
|  | 
| void | operator= (const vtkObjectBase &) | 
|  | 
Threshold cells within multiple intervals. 
This filter can be substituted for a chain of several vtkThreshold filters and can also perform more sophisticated subsetting operations. It generates a vtkMultiBlockDataSet as its output. This multiblock dataset contains a vtkUnstructuredGrid for each thresholded subset you request. A thresholded subset can be a set defined by an interval over a point or cell attribute of the mesh; these subsets are called IntervalSets. A thresholded subset can also be a boolean combination of one or more IntervalSets; these subsets are called BooleanSets. BooleanSets allow complex logic since their output can depend on multiple intervals over multiple variables defined on the input mesh. This is useful because it eliminates the need for thresholding several times and then appending the results, as can be required with vtkThreshold when one wants to remove some range of values (e.g., a notch filter). Cells are not repeated when they belong to more than one interval unless those intervals have different output grids.
Another advantage this filter provides over vtkThreshold is the ability to threshold on non-scalar (i.e., vector, tensor, etc.) attributes without first computing an array containing some norm of the desired attribute. vtkMultiThreshold provides  ,
,  , and
, and  norms.
 norms.
This filter makes a distinction between intermediate subsets and subsets that will be output to a grid. Each intermediate subset you create with AddIntervalSet or AddBooleanSet is given a unique integer identifier (via the return values of these member functions). If you wish for a given set to be output, you must call OutputSet and pass it one of these identifiers. The return of OutputSet is the integer index of the output set in the multiblock dataset created by this filter.
For example, if an input mesh defined three attributes T, P, and s, one might wish to find cells that satisfy "T < 320 [K] && ( P > 101 [kPa] || s < 0.1 [kJ/kg/K] )". To accomplish this with a vtkMultiThreshold filter, 
vtkMultiThreshold* thr;
int intervalSets[3];
intervalSets[0] = thr->AddIntervalSet( vtkMath::NegInf(), 320., vtkMultiThreshold::CLOSED, vtkMultiThreshold::OPEN,
    vtkDataObject::FIELD_ASSOCIATION_POINTS, "T", 0, 1 );
intervalSets[1] = thr->AddIntervalSet( 101., vtkMath::Inf(), vtkMultiThreshold::OPEN, vtkMultiThreshold::CLOSED,
    vtkDataObject::FIELD_ASSOCIATION_CELLS, "P", 0, 1 );
intervalSets[2] = thr->AddIntervalSet( vtkMath::NegInf(), 0.1, vtkMultiThreshold::CLOSED, vtkMultiThreshold::OPEN,
    vtkDataObject::FIELD_ASSOCIATION_POINTS, "s", 0, 1 );int intermediate = thr->AddBooleanSet( vtkMultiThreshold::OR, 2, &intervalSets[1] );
int intersection[2];
intersection[0] = intervalSets[0];
intersection[1] = intermediate;
int outputSet = thr->AddBooleanSet( vtkMultiThreshold::AND, 2, intersection );
int outputGridIndex = thr->OutputSet( outputSet );
thr->Update();
 The result of this filter will be a multiblock dataset that contains a single child with the desired cells. If we had also called thr->OutputSet( intervalSets[0] );, there would be two child meshes and one would contain all cells with T < 320 [K]. In that case, the output can be represented by this graph 
 The filled rectangles represent sets that are output.
- Tests:
- vtkMultiThreshold (Tests) 
Definition at line 122 of file vtkMultiThreshold.h.