ClassesClasses | | Operators

thinning_seqthinning_seqThinningSeqThinningSeq (Operator)

Name

thinning_seqthinning_seqThinningSeqThinningSeq — Remove the result of a hit-or-miss operation from a region (sequential).

Warning

thinning_seqthinning_seqThinningSeqThinningSeqThinningSeq is obsolete and is only provided for reasons of backward compatibility.

Signature

thinning_seq(Region : RegionThin : GolayElement, Iterations : )

Herror thinning_seq(const Hobject Region, Hobject* RegionThin, const char* GolayElement, const Hlong Iterations)

Herror T_thinning_seq(const Hobject Region, Hobject* RegionThin, const Htuple GolayElement, const Htuple Iterations)

void ThinningSeq(const HObject& Region, HObject* RegionThin, const HTuple& GolayElement, const HTuple& Iterations)

HRegion HRegion::ThinningSeq(const HString& GolayElement, const HTuple& Iterations) const

HRegion HRegion::ThinningSeq(const HString& GolayElement, Hlong Iterations) const

HRegion HRegion::ThinningSeq(const char* GolayElement, Hlong Iterations) const

static void HOperatorSet.ThinningSeq(HObject region, out HObject regionThin, HTuple golayElement, HTuple iterations)

HRegion HRegion.ThinningSeq(string golayElement, HTuple iterations)

HRegion HRegion.ThinningSeq(string golayElement, int iterations)

Description

thinning_seqthinning_seqThinningSeqThinningSeqThinningSeq calculates the sequential thinning of the input regions with a structuring element from the Golay alphabet (GolayElementGolayElementGolayElementGolayElementgolayElement). To do so, thinning_seqthinning_seqThinningSeqThinningSeqThinningSeq calls the operator thinning_golaythinning_golayThinningGolayThinningGolayThinningGolay with all possible rotations of the structuring element IterationsIterationsIterationsIterationsiterations times. If IterationsIterationsIterationsIterationsiterations is chosen large enough, the operator calculates the skeleton of a region if the structuring elements 'l' or 'm' are used. For the element 'c' the background and foreground are exchanged in order to have an effect on the interior boundary of a region. If a very large value or 'maximal' is passed for IterationsIterationsIterationsIterationsiterations the iteration stops if no more changes occur. The following structuring elements are available:

'l'

Skeleton, similar to skeletonskeletonSkeletonSkeletonSkeleton. This structuring element is also used in morph_skizmorph_skizMorphSkizMorphSkizMorphSkiz.

'm'

A skeleton with many “hairs” and multiple (parallel) branches.

'd'

A skeleton without multiple branches, but with many gaps, similar to morph_skeletonmorph_skeletonMorphSkeletonMorphSkeletonMorphSkeleton.

'c'

Uniform erosion of the region.

'e'

One pixel wide lines are shortened. This structuring element is also used in morph_skizmorph_skizMorphSkizMorphSkizMorphSkiz.

'i'

Isolated points are removed. (Only IterationsIterationsIterationsIterationsiterations = 1 is useful.)

'f'

Y-junctions are eliminated. (Only IterationsIterationsIterationsIterationsiterations = 1 is useful.)

'f2'

One pixel long branches and corners are removed. (Only IterationsIterationsIterationsIterationsiterations = 1 is useful.)

'h'

A kind of inner boundary, which, however, is thicker than the result of boundaryboundaryBoundaryBoundaryBoundary, is generated. (Only IterationsIterationsIterationsIterationsiterations = 1 is useful.)

'k'

Junction points are eliminated, but also new ones are generated.

The Golay elements, together with all possible rotations, are described with the operator golay_elementsgolay_elementsGolayElementsGolayElementsGolayElements.

Execution Information

Parameters

RegionRegionRegionRegionregion (input_object)  region(-array) objectHRegionHRegionHobject

Regions to be processed.

RegionThinRegionThinRegionThinRegionThinregionThin (output_object)  region(-array) objectHRegionHRegionHobject *

Result of the thinning operator.

GolayElementGolayElementGolayElementGolayElementgolayElement (input_control)  string HTupleHTupleHtuple (string) (string) (HString) (char*)

Structuring element from the Golay alphabet.

Default value: 'l' "l" "l" "l" "l"

List of values: 'c'"c""c""c""c", 'd'"d""d""d""d", 'e'"e""e""e""e", 'f'"f""f""f""f", 'f2'"f2""f2""f2""f2", 'h'"h""h""h""h", 'i'"i""i""i""i", 'k'"k""k""k""k", 'l'"l""l""l""l", 'm'"m""m""m""m"

IterationsIterationsIterationsIterationsiterations (input_control)  integer HTupleHTupleHtuple (integer / string) (int / long / string) (Hlong / HString) (Hlong / char*)

Number of iterations. For 'f', 'f2', 'h' and 'i' the only useful value is 1.

Default value: 20

Suggested values: 'maximal'"maximal""maximal""maximal""maximal", 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 15, 20, 30, 40, 50, 70, 100, 150, 200

Typical range of values: 1 ≤ Iterations Iterations Iterations Iterations iterations (lin)

Minimum increment: 1

Recommended increment: 1

Complexity

Let F be the area of an input region. Then the runtime complexity for one region is:

Result

thinning_seqthinning_seqThinningSeqThinningSeqThinningSeq returns 2 (H_MSG_TRUE) if all parameters are correct. The behavior in case of empty or no input region can be set via:

Otherwise, an exception is raised.

Possible Predecessors

thresholdthresholdThresholdThresholdThreshold, regiongrowingregiongrowingRegiongrowingRegiongrowingRegiongrowing, connectionconnectionConnectionConnectionConnection, union1union1Union1Union1Union1, watershedswatershedsWatershedsWatershedsWatersheds, class_ndim_normclass_ndim_normClassNdimNormClassNdimNormClassNdimNorm, gen_circlegen_circleGenCircleGenCircleGenCircle, gen_ellipsegen_ellipseGenEllipseGenEllipseGenEllipse, gen_rectangle1gen_rectangle1GenRectangle1GenRectangle1GenRectangle1, gen_rectangle2gen_rectangle2GenRectangle2GenRectangle2GenRectangle2, draw_regiondraw_regionDrawRegionDrawRegionDrawRegion, gen_region_pointsgen_region_pointsGenRegionPointsGenRegionPointsGenRegionPoints, gen_struct_elementsgen_struct_elementsGenStructElementsGenStructElementsGenStructElements, gen_region_polygon_filledgen_region_polygon_filledGenRegionPolygonFilledGenRegionPolygonFilledGenRegionPolygonFilled

Possible Successors

pruningpruningPruningPruningPruning, reduce_domainreduce_domainReduceDomainReduceDomainReduceDomain, select_shapeselect_shapeSelectShapeSelectShapeSelectShape, area_centerarea_centerAreaCenterAreaCenterAreaCenter, connectionconnectionConnectionConnectionConnection, complementcomplementComplementComplementComplement

Alternatives

skeletonskeletonSkeletonSkeletonSkeleton, morph_skizmorph_skizMorphSkizMorphSkizMorphSkiz, expand_regionexpand_regionExpandRegionExpandRegionExpandRegion

See also

hit_or_miss_seqhit_or_miss_seqHitOrMissSeqHitOrMissSeqHitOrMissSeq, erosion_golayerosion_golayErosionGolayErosionGolayErosionGolay, differencedifferenceDifferenceDifferenceDifference, thinning_golaythinning_golayThinningGolayThinningGolayThinningGolay, thinningthinningThinningThinningThinning, thickening_seqthickening_seqThickeningSeqThickeningSeqThickeningSeq

Module

Foundation


ClassesClasses | | Operators