SoAutoThresholdingProcessing engine
More...
#include <ImageViz/Engines/ImageSegmentation/Binarization/SoAutoThresholdingProcessing.h>
Classes | |
class | SbAutoThresholdingDetail |
Results details of threshold by automatic segmentation. More... | |
Public Types | |
enum | ObjectLightness { BRIGHT_OBJECTS = 0 , DARK_OBJECTS = 1 } |
enum | ThresholdCriterion { ENTROPY = 0 , FACTORISATION = 1 , MOMENTS = 2 } |
enum | RangeMode { MIN_MAX = 0 , OTHER = 1 } |
![]() | |
enum | ComputeMode { MODE_2D = 0 , MODE_3D = 1 , MODE_AUTO = 2 } |
Compute Mode This enum specifies whether the main input will be interpreted as a 3D volume or a stack of 2D images for processing. More... | |
enum | Neighborhood3d { CONNECTIVITY_6 = 0 , CONNECTIVITY_18 = 1 , CONNECTIVITY_26 = 2 } |
Neighborhood Connectivity 3D. More... | |
Public Member Functions | |
SoAutoThresholdingProcessing () | |
Constructor. | |
![]() | |
virtual SoType | getTypeId () const |
Returns the type identifier for this specific instance. | |
virtual void | startEvaluate () |
Evaluate engine and dependencies in another thread without blocking the current one. | |
virtual void | waitEvaluate () |
Wait for the end of engine evaluation. | |
virtual void | abortEvaluate () |
Abort current processing as soon as possible. | |
virtual bool | isEvaluating () |
Returns true if the engine evaluation is in progress. | |
![]() | |
virtual int | getOutputs (SoEngineOutputList &list) const |
Returns a list of outputs in this engine. | |
SoEngineOutput * | getOutput (const SbName &outputName) const |
Returns a reference to the engine output with the given name. | |
SbBool | getOutputName (const SoEngineOutput *output, SbName &outputName) const |
Returns (in outputName) the name of the engine output (output). | |
SoEngine * | copy () const |
Creates and returns an exact copy of the engine. | |
![]() | |
void | setToDefaults () |
Sets all fields in this object to their default values. | |
SbBool | hasDefaultValues () const |
Returns TRUE if all of the object's fields have their default values. | |
SbBool | fieldsAreEqual (const SoFieldContainer *fc) const |
Returns TRUE if this object's fields are exactly equal to fc's fields. | |
void | copyFieldValues (const SoFieldContainer *fc, SbBool copyConnections=FALSE) |
Copies the contents of fc's fields into this object's fields. | |
SoNONUNICODE SbBool | set (const char *fieldDataString) |
Sets one or more fields in this object to the values specified in the given string, which should be a string in the Open Inventor file format. | |
SbBool | set (const SbString &fieldDataString) |
Sets one or more fields in this object to the values specified in the given string, which should be a string in the Open Inventor file format. | |
void | get (SbString &fieldDataString) |
Returns the values of the fields of this object in the Open Inventor ASCII file format in the given string. | |
virtual int | getFields (SoFieldList &list) const |
Appends references to all of this object's fields to resultList, and returns the number of fields appended. | |
virtual int | getAllFields (SoFieldList &list) const |
Returns a list of fields, including the eventIn's and eventOut's. | |
virtual SoField * | getField (const SbName &fieldName) const |
Returns a the field of this object whose name is fieldName. | |
virtual SoField * | getEventIn (const SbName &fieldName) const |
Returns a the eventIn with the given name. | |
virtual SoField * | getEventOut (const SbName &fieldName) const |
Returns the eventOut with the given name. | |
SbBool | getFieldName (const SoField *field, SbName &fieldName) const |
Returns the name of the given field in the fieldName argument. | |
SbBool | enableNotify (SbBool flag) |
Notification at this Field Container is enabled (if flag == TRUE) or disabled (if flag == FALSE). | |
SbBool | isNotifyEnabled () const |
Notification is the process of telling interested objects that this object has changed. | |
virtual void | setUserData (void *data) |
Sets application data. | |
void * | getUserData (void) const |
Gets user application data. | |
![]() | |
virtual void | touch () |
Marks an instance as modified, simulating a change to it. | |
virtual SbName | getName () const |
Returns the name of an instance. | |
virtual void | setName (const SbName &name) |
Sets the name of an instance. | |
void | setSynchronizable (const bool b) |
Sets this to be a ScaleViz synchronizable object. | |
bool | isSynchronizable () const |
Gets the ScaleViz synchronizable state of this object. | |
![]() | |
void | ref () const |
Adds a reference to an instance. | |
void | unref () const |
Removes a reference from an instance. | |
void | unrefNoDelete () const |
unrefNoDelete() should be called when it is desired to decrement the reference count, but not delete the instance if this brings the reference count to zero. | |
int | getRefCount () const |
Returns current reference count. | |
void | lock () const |
lock this instance. | |
void | unlock () const |
unlock this instance. | |
![]() | |
SbBool | isOfType (const SoType &type) const |
Returns TRUE if this object is of the type specified in type or is derived from that type. | |
template<typename TypedObjectClass > | |
SbBool | isOfType () const |
Returns TRUE if this object is of the type of class TypedObjectClass or is derived from that class. | |
Public Attributes | |
SoSFEnum | computeMode |
Select the compute Mode (2D or 3D or AUTO) Use enum ComputeMode. | |
SoSFEnum | objectLightness |
Select the lightness mode for object to detect. | |
SoSFImageDataAdapter | inGrayImage |
The input grayscale image. | |
SoSFVec2f | intensityRangeInput |
The input intensity range. | |
SoSFEnum | thresholdCriterion |
The criterion to detect thresholds on histogram. | |
SoSFEnum | rangeMode |
Select the input intensity range mode. | |
SoImageVizEngineOutput< SoSFImageDataAdapter, SoImageDataAdapter * > | outBinaryImage |
The output binary image. | |
SoImageVizEngineAnalysisOutput< SbAutoThresholdingDetail > | outResult |
The thresholding results. | |
![]() | |
SbEventHandler< EventArg & > | onBegin |
Event raised when the processing begins. | |
SbEventHandler< EventArg & > | onEnd |
Event raised when processing ends and the result is available. | |
SbEventHandler< EventArg & > | onProgress |
Event raised while processing is running. | |
Additional Inherited Members | |
![]() | |
static SoType | getClassTypeId () |
Returns the type identifier for this class. | |
![]() | |
static SoType | getClassTypeId () |
Returns the type identifier for the SoEngine class. | |
static SoEngine * | getByName (const SbName &name) |
Looks up engine(s) by name. | |
static int | getByName (const SbName &name, SoEngineList &list) |
Looks up engine(s) by name. | |
![]() | |
static SoType | getClassTypeId () |
Returns the type of this class. | |
![]() | |
static SoType | getClassTypeId () |
Returns type identifier for this class. | |
![]() | |
static SoType | getClassTypeId () |
Returns the type identifier for this class. | |
SoAutoThresholdingProcessing engine
The SoAutoThresholdingProcessing engine computes an automatic threshold on a gray level image.
This engine computes an automatic threshold on a grayscale image i.e. separate the image in 2 classes of pixels. Three methods of classification are available: Entropy, Factorisation or Moments. The computed threshold is provided in the SbAutoThresholdingDetail object.
Entropy
The entropy principle defines 2 classes in the image histogram by minimizing the total classes' entropy, for more theory the reader can refers to references [1] and [2]. Considering the first-order probability histogram of an image and assuming that all symbols in the flowing equation are statistically independent, its entropy (in the Shannon sense) is defined as:
Where
Let us denote
Where
![]() | ![]() |
Factorization
The factorization method is based on the Otsu criterion (see [3] for details), i.e. minimizing the within-class variance:
Where
A faster and equivalent approach is to maximize the between-class variance:
The within-class variance calculation is based on the second-order statistics (variances) while the between-class variance calculation is based on the first order statistics (means). It is therefore simplest and faster to use this last optimization criterion. We then search the value
![]() | ![]() |
Moments
The moment SoAutoThresholdingProcessing uses the moment-preserving bi-level thresholding described by W.H.Tsai in [4]. Moments of an image can be computed from its histogram in the following way:
Where
And preserving the first three moments in
To find the desired threshold value
![]() | ![]() |
[1] T.Pun, Entropic thresholding: A new approach, comput. Graphics Image Process. 16, 1981, 210-239
[2] J. N. Kapur, P. K. Sahoo, and A. K. C. Wong, "A New Method for Gray-Level Picture Thresholding Using the Entropy of the Histogram" Computer Vision, Graphics and Image Processing 29, pp. 273-285, Mar. 1985
[3] Otsu, N. 1979. A thresholding selection method from grayscale histogram. IEEE Transactions on Systems, Man, and Cybernetics9(1): 62-66
[4] Tsai, W. H. 1985. Moment-preserving thresholding: A New Approach. Computer Vision, Graphics, and Image Processing 29: 377-393
SoAdaptiveThresholdingProcessing.
computeMode | MODE_AUTO |
objectLightness | BRIGHT_OBJECTS |
inGrayImage | NULL |
intensityRangeInput | 0.0f 255.0f |
thresholdCriterion | ENTROPY |
rangeMode | MIN_MAX |
Definition at line 178 of file SoAutoThresholdingProcessing.h.
Enumerator | |
---|---|
BRIGHT_OBJECTS | The algorithm thresholds bright objects (graylevels between T and Max(I)) |
DARK_OBJECTS | The algorithm thresholds dark objects (between Min(I) and T ) |
Definition at line 215 of file SoAutoThresholdingProcessing.h.
Enumerator | |
---|---|
MIN_MAX | With this option the histogram is computed between the minimum and the maximum of the image. |
OTHER | With this option the histogram is computed between user-defined bounds [a,b]. |
Definition at line 263 of file SoAutoThresholdingProcessing.h.
Definition at line 240 of file SoAutoThresholdingProcessing.h.
SoAutoThresholdingProcessing::SoAutoThresholdingProcessing | ( | ) |
Constructor.
SoSFEnum SoAutoThresholdingProcessing::computeMode |
Select the compute Mode (2D or 3D or AUTO) Use enum ComputeMode.
Default is MODE_AUTO
Definition at line 190 of file SoAutoThresholdingProcessing.h.
SoSFImageDataAdapter SoAutoThresholdingProcessing::inGrayImage |
The input grayscale image.
Default value is NULL. Supported types include: grayscale image.
Definition at line 232 of file SoAutoThresholdingProcessing.h.
SoSFVec2f SoAutoThresholdingProcessing::intensityRangeInput |
The input intensity range.
Default value is SbVec2f(0.0f,255.0f).
Definition at line 235 of file SoAutoThresholdingProcessing.h.
SoSFEnum SoAutoThresholdingProcessing::objectLightness |
Select the lightness mode for object to detect.
Use enum ObjectLightness. Default is BRIGHT_OBJECTS
Definition at line 229 of file SoAutoThresholdingProcessing.h.
SoImageVizEngineOutput<SoSFImageDataAdapter,SoImageDataAdapter*> SoAutoThresholdingProcessing::outBinaryImage |
The output binary image.
Default value is NULL. Supported types include: binary image.
Definition at line 280 of file SoAutoThresholdingProcessing.h.
SoImageVizEngineAnalysisOutput<SbAutoThresholdingDetail> SoAutoThresholdingProcessing::outResult |
The thresholding results.
Default value is NULL.
Definition at line 283 of file SoAutoThresholdingProcessing.h.
SoSFEnum SoAutoThresholdingProcessing::rangeMode |
Select the input intensity range mode.
Use enum RangeMode. Default is MIN_MAX
Definition at line 277 of file SoAutoThresholdingProcessing.h.
SoSFEnum SoAutoThresholdingProcessing::thresholdCriterion |
The criterion to detect thresholds on histogram.
Use enum ThresholdCriterion. Default is ENTROPY
Definition at line 258 of file SoAutoThresholdingProcessing.h.