Class SoAutoThresholdingProcessing
- java.lang.Object
- 
- com.openinventor.inventor.Inventor
- 
- com.openinventor.inventor.misc.SoBase
- 
- com.openinventor.inventor.fields.SoFieldContainer
- 
- com.openinventor.inventor.engines.SoEngine
- 
- com.openinventor.imageviz.engines.SoImageVizEngine
- 
- com.openinventor.imageviz.engines.imagesegmentation.binarization.SoAutoThresholdingProcessing
 
 
 
 
 
 
- 
- All Implemented Interfaces:
- SafeDisposable
 
 public class SoAutoThresholdingProcessing extends SoImageVizEngine SoAutoThresholdingProcessingengine. TheSoAutoThresholdingProcessingengine 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 SbAutoThresholdingDetailobject.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  is the number of grayscales, is the number of grayscales, the probability of occurrence of level and the probability of occurrence of level and is the log in base 2. is the log in base 2.Let us denote  the value of the threshold and the value of the threshold and the search interval. We can define two partial entropies: the search interval. We can define two partial entropies:    Where  defines the probability of occurrence of level in the range defines the probability of occurrence of level in the range and and defines the probability of occurrence of level defines the probability of occurrence of level in the range [t+1,I2]. We search the threshold value in the range [t+1,I2]. We search the threshold value which minimizes the sum which minimizes the sum : :    Figure 1: Example of thresholding using the entropy method Factorization 
 The factorization method is based on the Otsu criterion (see [3] for details), i.e. minimizing the within-class variance:  Where  and and are respectively the probabilities occurrence are respectively the probabilities occurrence and and , the variances of classes , the variances of classes and and . .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  which maximizes the between-class variance such as: which maximizes the between-class variance such as:    Figure 2: Example of thresholding using the factorization method Moments 
 The momentSoAutoThresholdingProcessinguses 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  is the probability of occurrence of grayscale is the probability of occurrence of grayscale . For the following we note . For the following we note the original grayscale image and the original grayscale image and the threshold image. Image the threshold image. Image can be considered as a blurred version of an ideal bi-level image which consists of pixels with only two gray values: can be considered as a blurred version of an ideal bi-level image which consists of pixels with only two gray values: and and . The moment-preserving thresholding principle is to select a threshold value such that if all below-threshold gray values of the original image are replaced by . The moment-preserving thresholding principle is to select a threshold value such that if all below-threshold gray values of the original image are replaced by and all above threshold gray values replaced by and all above threshold gray values replaced by , then the first three moments of the original image are preserved in the resulting bi-level image. Image , then the first three moments of the original image are preserved in the resulting bi-level image. Image so obtained may be regarded as an ideal unblurred version of so obtained may be regarded as an ideal unblurred version of . Let . Let and and denote the fractions of the below-threshold pixels and the above-threshold pixels in denote the fractions of the below-threshold pixels and the above-threshold pixels in , respectively, then the first three moments of , respectively, then the first three moments of are: are:  And preserving the first three moments in  , means the equalities: , means the equalities:  To find the desired threshold value  , we can first solve the four equations system to obtain , we can first solve the four equations system to obtain and and , and then choose , and then choose as the as the -tile of the histogram of -tile of the histogram of . Note that . Note that and and will also be obtained simultaneously as part of the solutions of system. will also be obtained simultaneously as part of the solutions of system.  Figure 3: Example of thresholding using the moment-preserving method [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
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classSoAutoThresholdingProcessing.ObjectLightnessTypestatic classSoAutoThresholdingProcessing.RangeModesstatic classSoAutoThresholdingProcessing.SbAutoThresholdingDetailResults details of threshold by automatic segmentation.static classSoAutoThresholdingProcessing.ThresholdCriterions- 
Nested classes/interfaces inherited from class com.openinventor.imageviz.engines.SoImageVizEngineSoImageVizEngine.ComputeModes, SoImageVizEngine.EventArg, SoImageVizEngine.Neighborhood3ds
 - 
Nested classes/interfaces inherited from class com.openinventor.inventor.InventorInventor.ConstructorCommand
 
- 
 - 
Field SummaryFields Modifier and Type Field Description SoSFEnum<SoImageVizEngine.ComputeModes>computeModeSelect the compute Mode (2D or 3D or AUTO) .SoSFImageDataAdapterinGrayImageThe input grayscale image.SoSFVec2fintensityRangeInputThe input intensity range.SoSFEnum<SoAutoThresholdingProcessing.ObjectLightnessType>objectLightnessSelect the lightness mode for object to detect.SoImageVizEngineOutput<SoSFImageDataAdapter,SoImageDataAdapter>outBinaryImageThe output binary image.SoImageVizEngineAnalysisOutput<SoAutoThresholdingProcessing.SbAutoThresholdingDetail>outResultThe thresholding results.SoSFEnum<SoAutoThresholdingProcessing.RangeModes>rangeModeSelect the input intensity range mode.SoSFEnum<SoAutoThresholdingProcessing.ThresholdCriterions>thresholdCriterionThe criterion to detect thresholds on histogram.- 
Fields inherited from class com.openinventor.imageviz.engines.SoImageVizEngineonBegin, onEnd, onProgress
 - 
Fields inherited from class com.openinventor.inventor.InventorVERBOSE_LEVEL, ZeroHandle
 
- 
 - 
Constructor SummaryConstructors Constructor Description SoAutoThresholdingProcessing()Constructor.
 - 
Method Summary- 
Methods inherited from class com.openinventor.imageviz.engines.SoImageVizEngineabortEvaluate, isEvaluating, startEvaluate, waitEvaluate
 - 
Methods inherited from class com.openinventor.inventor.engines.SoEnginecopy, getByName, getOutput, getOutputName
 - 
Methods inherited from class com.openinventor.inventor.fields.SoFieldContainercopyFieldValues, copyFieldValues, enableNotify, fieldsAreEqual, get, getAllFields, getEventIn, getEventOut, getField, getFieldName, hasDefaultValues, isNotifyEnabled, set, setToDefaults
 - 
Methods inherited from class com.openinventor.inventor.misc.SoBasedispose, getName, isDisposable, isSynchronizable, setName, setSynchronizable, touch
 - 
Methods inherited from class com.openinventor.inventor.InventorgetNativeResourceHandle
 
- 
 
- 
- 
- 
Field Detail- 
computeModepublic final SoSFEnum<SoImageVizEngine.ComputeModes> computeMode Select the compute Mode (2D or 3D or AUTO) . Default is MODE_AUTO
 - 
objectLightnesspublic final SoSFEnum<SoAutoThresholdingProcessing.ObjectLightnessType> objectLightness Select the lightness mode for object to detect. . Default is BRIGHT_OBJECTS
 - 
inGrayImagepublic final SoSFImageDataAdapter inGrayImage The input grayscale image. Default value is NULL. Supported types include: grayscale image.
 - 
intensityRangeInputpublic final SoSFVec2f intensityRangeInput The input intensity range. Default value isSbVec2f(0.0f,255.0f).
 - 
thresholdCriterionpublic final SoSFEnum<SoAutoThresholdingProcessing.ThresholdCriterions> thresholdCriterion The criterion to detect thresholds on histogram. . Default is ENTROPY
 - 
rangeModepublic final SoSFEnum<SoAutoThresholdingProcessing.RangeModes> rangeMode Select the input intensity range mode. . Default is MIN_MAX
 - 
outBinaryImagepublic final SoImageVizEngineOutput<SoSFImageDataAdapter,SoImageDataAdapter> outBinaryImage The output binary image. Default value is NULL. Supported types include: binary image.
 - 
outResultpublic final SoImageVizEngineAnalysisOutput<SoAutoThresholdingProcessing.SbAutoThresholdingDetail> outResult The thresholding results. Default value is NULL.
 
- 
 
-