thinning thinning Thinning Thinning thinning (Operator)
Name
thinning thinning Thinning Thinning thinning
— Remove the result of a hit-or-miss operation from a region.
Warning
thinning thinning Thinning Thinning Thinning thinning
is obsolete and is only provided for
reasons of backward compatibility.
Signature
Herror thinning (const Hobject Region , const Hobject StructElement1 , const Hobject StructElement2 , Hobject* RegionThin , const Hlong Row , const Hlong Column , const Hlong Iterations )
Herror T_thinning (const Hobject Region , const Hobject StructElement1 , const Hobject StructElement2 , Hobject* RegionThin , const Htuple Row , const Htuple Column , const Htuple Iterations )
void Thinning (const HObject& Region , const HObject& StructElement1 , const HObject& StructElement2 , HObject* RegionThin , const HTuple& Row , const HTuple& Column , const HTuple& Iterations )
HRegion HRegion ::Thinning (const HRegion& StructElement1 , const HRegion& StructElement2 , Hlong Row , Hlong Column , Hlong Iterations ) const
static void HOperatorSet .Thinning (HObject region , HObject structElement1 , HObject structElement2 , out HObject regionThin , HTuple row , HTuple column , HTuple iterations )
HRegion HRegion .Thinning (HRegion structElement1 , HRegion structElement2 , int row , int column , int iterations )
Description
thinning thinning Thinning Thinning Thinning thinning
performs a thinning of the input regions
using morphological operations. The operator first applies a
hit-or-miss-transformation to Region Region Region Region region region
(cf.
hit_or_miss hit_or_miss HitOrMiss HitOrMiss HitOrMiss hit_or_miss
), and then removes the detected points from
the input region. The parameter Iterations Iterations Iterations Iterations iterations iterations
determines
the number of iterations performed.
For the choice of the structuring elements StructElement1 StructElement1 StructElement1 StructElement1 structElement1 struct_element_1
and StructElement2 StructElement2 StructElement2 StructElement2 structElement2 struct_element_2
, as well as for Row Row Row Row row row
and
Column Column Column Column column column
, the same restrictions described under
hit_or_miss hit_or_miss HitOrMiss HitOrMiss HitOrMiss hit_or_miss
apply.
Structuring elements (StructElement1 StructElement1 StructElement1 StructElement1 structElement1 struct_element_1
,
StructElement2 StructElement2 StructElement2 StructElement2 structElement2 struct_element_2
) can be generated with operators such as
gen_circle gen_circle GenCircle GenCircle GenCircle gen_circle
, gen_rectangle1 gen_rectangle1 GenRectangle1 GenRectangle1 GenRectangle1 gen_rectangle1
, gen_rectangle2 gen_rectangle2 GenRectangle2 GenRectangle2 GenRectangle2 gen_rectangle2
,
gen_ellipse gen_ellipse GenEllipse GenEllipse GenEllipse gen_ellipse
, draw_region draw_region DrawRegion DrawRegion DrawRegion draw_region
,
gen_region_polygon gen_region_polygon GenRegionPolygon GenRegionPolygon GenRegionPolygon gen_region_polygon
, gen_region_points gen_region_points GenRegionPoints GenRegionPoints GenRegionPoints gen_region_points
, etc.
Execution Information
Multithreading type: reentrant (runs in parallel with non-exclusive operators).
Multithreading scope: global (may be called from any thread).
Automatically parallelized on tuple level.
Parameters
Region Region Region Region region region
(input_object) region(-array) →
object HRegion HObject HRegion Hobject
Regions to be processed.
StructElement1 StructElement1 StructElement1 StructElement1 structElement1 struct_element_1
(input_object) region →
object HRegion HObject HRegion Hobject
Structuring element for the foreground.
StructElement2 StructElement2 StructElement2 StructElement2 structElement2 struct_element_2
(input_object) region →
object HRegion HObject HRegion Hobject
Structuring element for the background.
RegionThin RegionThin RegionThin RegionThin regionThin region_thin
(output_object) region(-array) →
object HRegion HObject HRegion Hobject *
Result of the thinning operator.
Row Row Row Row row row
(input_control) point.y →
HTuple int HTuple Htuple (integer) (int / long) (Hlong ) (Hlong )
Row coordinate of the reference point.
Default value: 0
Typical range of values: 0
≤
Row
Row
Row
Row
row
row
≤
511
(lin)
Minimum increment: 1
Recommended increment: 1
Column Column Column Column column column
(input_control) point.x →
HTuple int HTuple Htuple (integer) (int / long) (Hlong ) (Hlong )
Column coordinate of the reference point.
Default value: 0
Typical range of values: 0
≤
Column
Column
Column
Column
column
column
≤
511
(lin)
Minimum increment: 1
Recommended increment: 1
Iterations Iterations Iterations Iterations iterations iterations
(input_control) integer →
HTuple int HTuple Htuple (integer) (int / long) (Hlong ) (Hlong )
Number of iterations.
Default value: 1
Suggested values: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 12, 15, 17, 20, 30, 40, 50
Typical range of values: 1
≤
Iterations
Iterations
Iterations
Iterations
iterations
iterations
(lin)
Minimum increment: 1
Recommended increment: 1
Complexity
Let F be the area of an input region, F1 the area of the
structuring element 1, and F2 the area of the structuring element
2. Then the runtime complexity for one object is:
Result
thinning thinning Thinning Thinning Thinning thinning
returns TRUE if all parameters are correct.
The behavior in case of empty or no input region can be set via:
no region:
set_system('no_object_result',<RegionResult>)
empty region:
set_system('empty_region_result',<RegionResult>)
Otherwise, an exception is raised.
Possible Predecessors
threshold threshold Threshold Threshold Threshold threshold
,
regiongrowing regiongrowing Regiongrowing Regiongrowing Regiongrowing regiongrowing
,
connection connection Connection Connection Connection connection
,
union1 union1 Union1 Union1 Union1 union1
,
watersheds watersheds Watersheds Watersheds Watersheds watersheds
,
class_ndim_norm class_ndim_norm ClassNdimNorm ClassNdimNorm ClassNdimNorm class_ndim_norm
,
gen_circle gen_circle GenCircle GenCircle GenCircle gen_circle
,
gen_ellipse gen_ellipse GenEllipse GenEllipse GenEllipse gen_ellipse
,
gen_rectangle1 gen_rectangle1 GenRectangle1 GenRectangle1 GenRectangle1 gen_rectangle1
,
gen_rectangle2 gen_rectangle2 GenRectangle2 GenRectangle2 GenRectangle2 gen_rectangle2
,
draw_region draw_region DrawRegion DrawRegion DrawRegion draw_region
,
gen_region_points gen_region_points GenRegionPoints GenRegionPoints GenRegionPoints gen_region_points
,
gen_region_polygon_filled gen_region_polygon_filled GenRegionPolygonFilled GenRegionPolygonFilled GenRegionPolygonFilled gen_region_polygon_filled
Possible Successors
reduce_domain reduce_domain ReduceDomain ReduceDomain ReduceDomain reduce_domain
,
select_shape select_shape SelectShape SelectShape SelectShape select_shape
,
area_center area_center AreaCenter AreaCenter AreaCenter area_center
,
connection connection Connection Connection Connection connection
Alternatives
thinning_golay thinning_golay ThinningGolay ThinningGolay ThinningGolay thinning_golay
,
thinning_seq thinning_seq ThinningSeq ThinningSeq ThinningSeq thinning_seq
See also
hit_or_miss hit_or_miss HitOrMiss HitOrMiss HitOrMiss hit_or_miss
Module
Foundation