template<typename TInputImage, typename TOutputImage = TInputImage>
class itk::ThresholdMaximumConnectedComponentsImageFilter< TInputImage, TOutputImage >
Finds the threshold value of an image based on maximizing the number of objects in the image that are larger than a given minimal size. 
- This method is based on Topological Stable State Thresholding to calculate the threshold set point. This method is particularly effective when there are a large number of objects in a microscopy image. Compiling in Debug mode and enable the debug flag for this filter to print debug information to see how the filter focuses in on a threshold value. Please see the Insight Journal's MICCAI 2005 workshop for a complete description. References are below.
- Parameters
- The MinimumObjectSizeInPixels parameter is controlled through the class Get/SetMinimumObjectSizeInPixels() method. Similar to the standard itk::BinaryThresholdImageFilter the Get/SetInside and Get/SetOutside values of the threshold can be set. The GetNumberOfObjects() and GetThresholdValue() methods return the number of objects above the minimum pixel size and the calculated threshold value.
- Automatic Thresholding in ITK
- There are multiple methods to automatically calculate the threshold intensity value of an image. As of version 4.0, ITK has a Thresholding ( ITKThresholding ) module which contains numerous automatic thresholding methods.implements two of these. Topological Stable State Thresholding works well on images with a large number of objects to be counted.
For algorithmic details see [142] and [97].
- Questions: email Ken Urish at ken.urish(at)gmail.com Please cc the itk list serve for archival purposes. 
Definition at line 68 of file itkThresholdMaximumConnectedComponentsImageFilter.h.
|  | 
| SizeValueType | ComputeConnectedComponents () | 
|  | 
| void | GenerateData () override | 
|  | 
| void | PrintSelf (std::ostream &os, Indent indent) const override | 
|  | 
|  | ThresholdMaximumConnectedComponentsImageFilter () | 
|  | 
|  | ~ThresholdMaximumConnectedComponentsImageFilter () override=default | 
|  | 
| virtual void | CallCopyInputRegionToOutputRegion (OutputImageRegionType &destRegion, const InputImageRegionType &srcRegion) | 
|  | 
| virtual void | CallCopyInputRegionToOutputRegion (OutputImageRegionType &destRegion, const InputImageRegionType &srcRegion) | 
|  | 
| virtual void | CallCopyOutputRegionToInputRegion (InputImageRegionType &destRegion, const OutputImageRegionType &srcRegion) | 
|  | 
| virtual void | CallCopyOutputRegionToInputRegion (InputImageRegionType &destRegion, const OutputImageRegionType &srcRegion) | 
|  | 
| void | GenerateInputRequestedRegion () override | 
|  | 
| void | GenerateInputRequestedRegion () override | 
|  | 
|  | ImageToImageFilter () | 
|  | 
|  | ImageToImageFilter () | 
|  | 
| void | VerifyInputInformation () const override | 
|  | 
| void | VerifyInputInformation () const override | 
|  | 
|  | ~ImageToImageFilter () override=default | 
|  | 
|  | ~ImageToImageFilter () override=default | 
|  | 
| virtual void | AfterThreadedGenerateData () | 
|  | 
| virtual void | AllocateOutputs () | 
|  | 
| virtual void | BeforeThreadedGenerateData () | 
|  | 
| void | ClassicMultiThread (ThreadFunctionType callbackFunction) | 
|  | 
| virtual const ImageRegionSplitterBase * | GetImageRegionSplitter () const | 
|  | 
|  | ImageSource () | 
|  | 
| virtual unsigned int | SplitRequestedRegion (unsigned int i, unsigned int pieces, OutputImageRegionType &splitRegion) | 
|  | 
|  | ~ImageSource () override=default | 
|  | 
| virtual void | ThreadedGenerateData (const OutputImageRegionType ®ion, ThreadIdType threadId) | 
|  | 
| virtual void | DynamicThreadedGenerateData (const OutputImageRegionType &outputRegionForThread) | 
|  | 
| virtual bool | GetDynamicMultiThreading () const | 
|  | 
| virtual void | SetDynamicMultiThreading (bool _arg) | 
|  | 
| virtual void | DynamicMultiThreadingOn () | 
|  | 
| virtual void | DynamicMultiThreadingOff () | 
|  | 
| virtual void | AddInput (DataObject *input) | 
|  | 
| void | AddOptionalInputName (const DataObjectIdentifierType &) | 
|  | 
| void | AddOptionalInputName (const DataObjectIdentifierType &, DataObjectPointerArraySizeType idx) | 
|  | 
| virtual void | AddOutput (DataObject *output) | 
|  | 
| bool | AddRequiredInputName (const DataObjectIdentifierType &) | 
|  | 
| bool | AddRequiredInputName (const DataObjectIdentifierType &, DataObjectPointerArraySizeType idx) | 
|  | 
| virtual void | CacheInputReleaseDataFlags () | 
|  | 
| virtual void | GenerateOutputInformation () | 
|  | 
| virtual void | GenerateOutputRequestedRegion (DataObject *output) | 
|  | 
| DataObject * | GetInput (const DataObjectIdentifierType &key) | 
|  | 
| const DataObject * | GetInput (const DataObjectIdentifierType &key) const | 
|  | 
| virtual const DataObjectPointerArraySizeType & | GetNumberOfRequiredInputs () const | 
|  | 
| virtual const DataObjectPointerArraySizeType & | GetNumberOfRequiredOutputs () const | 
|  | 
| bool | IsIndexedInputName (const DataObjectIdentifierType &) const | 
|  | 
| bool | IsIndexedOutputName (const DataObjectIdentifierType &) const | 
|  | 
| bool | IsRequiredInputName (const DataObjectIdentifierType &) const | 
|  | 
| DataObjectPointerArraySizeType | MakeIndexFromInputName (const DataObjectIdentifierType &name) const | 
|  | 
| DataObjectPointerArraySizeType | MakeIndexFromOutputName (const DataObjectIdentifierType &name) const | 
|  | 
| DataObjectIdentifierType | MakeNameFromInputIndex (DataObjectPointerArraySizeType idx) const | 
|  | 
| DataObjectIdentifierType | MakeNameFromOutputIndex (DataObjectPointerArraySizeType idx) const | 
|  | 
|  | ProcessObject () | 
|  | 
| virtual void | PropagateResetPipeline () | 
|  | 
| virtual void | PushBackInput (const DataObject *input) | 
|  | 
| virtual void | PushFrontInput (const DataObject *input) | 
|  | 
| virtual void | ReleaseInputs () | 
|  | 
| virtual void | RemoveInput (const DataObjectIdentifierType &key) | 
|  | 
| virtual void | RemoveInput (DataObjectPointerArraySizeType) | 
|  | 
| virtual void | RemoveOutput (const DataObjectIdentifierType &key) | 
|  | 
| virtual void | RemoveOutput (DataObjectPointerArraySizeType idx) | 
|  | 
| bool | RemoveRequiredInputName (const DataObjectIdentifierType &) | 
|  | 
| virtual void | RestoreInputReleaseDataFlags () | 
|  | 
| virtual void | SetInput (const DataObjectIdentifierType &key, DataObject *input) | 
|  | 
| virtual void | SetNthInput (DataObjectPointerArraySizeType idx, DataObject *input) | 
|  | 
| virtual void | SetNthOutput (DataObjectPointerArraySizeType idx, DataObject *output) | 
|  | 
| void | SetNumberOfIndexedInputs (DataObjectPointerArraySizeType num) | 
|  | 
| void | SetNumberOfIndexedOutputs (DataObjectPointerArraySizeType num) | 
|  | 
| virtual void | SetNumberOfRequiredInputs (DataObjectPointerArraySizeType) | 
|  | 
| virtual void | SetNumberOfRequiredOutputs (DataObjectPointerArraySizeType _arg) | 
|  | 
| virtual void | SetOutput (const DataObjectIdentifierType &name, DataObject *output) | 
|  | 
| virtual void | SetPrimaryInput (DataObject *object) | 
|  | 
| virtual void | SetPrimaryOutput (DataObject *object) | 
|  | 
| void | SetRequiredInputNames (const NameArray &) | 
|  | 
| virtual void | VerifyPreconditions () const | 
|  | 
|  | ~ProcessObject () override | 
|  | 
| DataObject * | GetInput (DataObjectPointerArraySizeType idx) | 
|  | 
| const DataObject * | GetInput (DataObjectPointerArraySizeType idx) const | 
|  | 
| DataObject * | GetPrimaryInput () | 
|  | 
| const DataObject * | GetPrimaryInput () const | 
|  | 
| virtual void | SetPrimaryInputName (const DataObjectIdentifierType &key) | 
|  | 
| virtual const char * | GetPrimaryInputName () const | 
|  | 
| DataObject * | GetOutput (const DataObjectIdentifierType &key) | 
|  | 
| const DataObject * | GetOutput (const DataObjectIdentifierType &key) const | 
|  | 
| virtual void | SetPrimaryOutputName (const DataObjectIdentifierType &key) | 
|  | 
| virtual const char * | GetPrimaryOutputName () const | 
|  | 
| DataObject * | GetOutput (DataObjectPointerArraySizeType i) | 
|  | 
| const DataObject * | GetOutput (DataObjectPointerArraySizeType i) const | 
|  | 
| DataObject * | GetPrimaryOutput () | 
|  | 
| const DataObject * | GetPrimaryOutput () const | 
|  | 
| virtual bool | GetThreaderUpdateProgress () const | 
|  | 
| virtual void | ThreaderUpdateProgressOn () | 
|  | 
| virtual void | ThreaderUpdateProgressOff () | 
|  | 
| virtual void | SetThreaderUpdateProgress (bool arg) | 
|  | 
|  | Object () | 
|  | 
| bool | PrintObservers (std::ostream &os, Indent indent) const | 
|  | 
| virtual void | SetTimeStamp (const TimeStamp &timeStamp) | 
|  | 
|  | ~Object () override | 
|  | 
| virtual LightObject::Pointer | InternalClone () const | 
|  | 
|  | LightObject () | 
|  | 
| virtual void | PrintHeader (std::ostream &os, Indent indent) const | 
|  | 
| virtual void | PrintTrailer (std::ostream &os, Indent indent) const | 
|  | 
| virtual | ~LightObject () | 
|  |