Class ErodingSkeleton
- All Implemented Interfaces:
- ArrayProcessor,- IterativeArrayProcessor<Matrix<? extends UpdatableBitArray>>
The simplest algorithm of multidimensional skeletonization of binary matrices, based on sequential
 erosions of the matrix by some small pattern.
More precisely, this class is an implementation of IterativeArrayProcessor interface,
 iteratively processing some bit matrix (Matrix(UpdatableBitArray)), named
 result and passed to the getInstance method.
 In this implementation:
- performIteration(ArrayContext)method calculates- erosion(result,P) of the current result matrix by some small pattern P (usually little circle or square, in 2-dimensional case) and- opening(result,Q,- Morphology.SubtractionMode.NONE) of this matrix by some other pattern Q, usually equal to P or little greater than P. The opening is subtracted (in the set-theoretical sense) from the source result matrix and the difference (i.e. "thin" areas in the bit image) is united with the erosion (also in the set-theoretical sense). Then the result matrix is replaced with this union.
- done()method returns true if the last iteration was unable to change the matrix: all "objects" are already "thin" (removed after the erosion).
- result()method always returns the reference to the source matrix, passed to- getInstancemethod.
The algorithm, implemented by this class, does not guarantee that connected "objects" (areas filled by 1 elements) stay connected and does not guarantee that the resulting "skeleton" will be "thin" enough. But it guarantees that resulting "skeleton" does not contain areas "larger" than the pattern Q used for opening operation.
This class is based on Matrices.asShifted method
 with some elementwise logical operations (AND, OR, NOT).
 So, the matrix is supposed to be infinitely pseudo-cyclically continued, as well
 Matrices.asShifted method supposes it.
 You can change this behavior by appending the source matrix with zero elements
 by calling Matrix.subMatrix(long[], long[], Matrix.ContinuationMode)Matrix.ContinuationMode.ZERO_CONSTANT.
This class can process a matrix with any number of dimensions.
This class is not thread-safe, but is thread-compatible and can be synchronized manually, if multithread access is necessary.
- Author:
- Daniel Alievsky
- 
Field SummaryFields inherited from class net.algart.arrays.AbstractIterativeArrayProcessorcontext, memoryModel
- 
Method SummaryModifier and TypeMethodDescriptionbooleandone()Returns true if and only if the algorithm was successfully finished and there is no sense to perform further iterations.longEstimates the number of iterations, that should be performed from this moment to finish the algorithm.voidfreeResources(ArrayContext context) If there are some resources, allocated by this object, which are not controlled by Java garbage collectors — files, streams, sockets, locks, etc. — this method tries to release them (for example, to close any files).static ErodingSkeletongetInstance(ArrayContext context, Matrix<? extends UpdatableBitArray> matrix, Pattern erosionPattern, Pattern openingPattern) Creates new instance of this class.voidperformIteration(ArrayContext context) Performs the next iteration of the iterative algorithm.Matrix<? extends UpdatableBitArray>result()Returns the result of the previous iteration.toString()Returns a brief string description of this object.Methods inherited from class net.algart.arrays.AbstractIterativeArrayProcessorchain, context, limitIterations, part, processMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface net.algart.arrays.ArrayProcessorcontextMethods inherited from interface net.algart.arrays.IterativeArrayProcessorchain, limitIterations, process
- 
Method Details- 
getInstancepublic static ErodingSkeleton getInstance(ArrayContext context, Matrix<? extends UpdatableBitArray> matrix, Pattern erosionPattern, Pattern openingPattern) Creates new instance of this class.- Parameters:
- context- the- contextthat will be used by this object; may be null, then it will be ignored.
- matrix- the bit matrix that should be processed and returned by- result()method.
- erosionPattern- the pattern that will be used for erosion operation at every iteration.
- openingPattern- the pattern that will be used for opening operation at every iteration.
- Returns:
- new instance of this class.
- Throws:
- NullPointerException- if one of the arguments is null.
 
- 
performIterationDescription copied from interface:IterativeArrayProcessorPerforms the next iteration of the iterative algorithm. If the algorithm isIterativeArrayProcessor.done(), the results are unspecified: please never call this method ifIterativeArrayProcessor.done()returns true.You usually don't need to call this method: please call IterativeArrayProcessor.process()instead. If you need to perform only one or n iterations, you may uselimitIterations(n)call.Warning: this method should ignore the current execution contextof this object. Instead, this method should use the context of execution specified by context argument. This method is called byIterativeArrayProcessor.process()method with the argument, describinga subtraskof the full algorithm. The context argument may be null: this method should work properly in this case (ignore the context).This method must be implemented while creating a new iterative array-processing algorithm. - Specified by:
- performIterationin interface- IterativeArrayProcessor<Matrix<? extends UpdatableBitArray>>
- Specified by:
- performIterationin class- AbstractIterativeArrayProcessor<Matrix<? extends UpdatableBitArray>>
- Parameters:
- context- the context used by this instance for all operations; may be null.
 
- 
donepublic boolean done()Description copied from interface:IterativeArrayProcessorReturns true if and only if the algorithm was successfully finished and there is no sense to perform further iterations.This method usually does not perform actual calculations and works very quickly (just returns and internal flag). However, this condition is not strict. You usually don't need to call this method: it is automatically called by IterativeArrayProcessor.process()method.This method must be implemented while creating a new iterative array-processing algorithm. - Specified by:
- donein interface- IterativeArrayProcessor<Matrix<? extends UpdatableBitArray>>
- Specified by:
- donein class- AbstractIterativeArrayProcessor<Matrix<? extends UpdatableBitArray>>
- Returns:
- true if and only if the algorithm was successfully finished.
 
- 
estimatedNumberOfIterationspublic long estimatedNumberOfIterations()Description copied from interface:IterativeArrayProcessorEstimates the number of iterations, that should be performed from this moment to finish the algorithm. Returns 0 if it is impossible or too difficult to estimate this number: it means that the remaining number of iteration is unknown.This method may require some time for its execution. You usually don't need to call this method: it is automatically called from time to time by IterativeArrayProcessor.process()method. It is used for creating subcontexts, describing apartof the full task.This method must be implemented while creating a new iterative array-processing algorithm. - Specified by:
- estimatedNumberOfIterationsin interface- IterativeArrayProcessor<Matrix<? extends UpdatableBitArray>>
- Specified by:
- estimatedNumberOfIterationsin class- AbstractIterativeArrayProcessor<Matrix<? extends UpdatableBitArray>>
- Returns:
- the estimated number of iterations, that should be performed from this moment to finish the algorithm.
 
- 
resultDescription copied from interface:IterativeArrayProcessorReturns the result of the previous iteration. Usually it isUpdatableArrayorMatrix<? extendsUpdatableArray>. This method returns valid result even if no iterations were performed yet. IfIterativeArrayProcessor.done()method returns true, the result of this method is the final result of iterative processing performed by this instance.This method may return null. In this case, the concrete implementation of this interface should provide additional methods for returning calculation results. This method does not perform actual calculations and works very quickly. This method must be implemented while creating a new iterative array-processing algorithm. - Specified by:
- resultin interface- IterativeArrayProcessor<Matrix<? extends UpdatableBitArray>>
- Specified by:
- resultin class- AbstractIterativeArrayProcessor<Matrix<? extends UpdatableBitArray>>
- Returns:
- the result of the previous iteration (may be null).
 
- 
freeResourcesDescription copied from interface:IterativeArrayProcessorIf there are some resources, allocated by this object, which are not controlled by Java garbage collectors — files, streams, sockets, locks, etc. — this method tries to release them (for example, to close any files). The object stays alive: if the resources will be necessary for following operations, they will be automatically re-acquired.Usually, this method just calls Array.freeResources(context)andMatrix.freeResources(context)for all temporary arrays and matrices, allocated by this object for storing work data.If IterativeArrayProcessor.result()method returns AlgART array or matrix (typical situation), this method callsArray.freeResources(context)/Matrix.freeResources(context)methods for this array / matrix.This method may be used in situations when the instance of this object has long time life and will be reused in future. This method must be implemented while creating a new iterative array-processing algorithm. - Specified by:
- freeResourcesin interface- IterativeArrayProcessor<Matrix<? extends UpdatableBitArray>>
- Specified by:
- freeResourcesin class- AbstractIterativeArrayProcessor<Matrix<? extends UpdatableBitArray>>
- Parameters:
- context- the context of execution; may be null, then it will be ignored.
 
- 
toStringReturns a brief string description of this object.
 
-