hit_or_misshit_or_missHitOrMissHitOrMiss (Operator)

Name

hit_or_misshit_or_missHitOrMissHitOrMiss — Hit-or-miss operation for regions.

Signature

hit_or_miss(Region, StructElement1, StructElement2 : RegionHitMiss : Row, Column : )

Herror hit_or_miss(const Hobject Region, const Hobject StructElement1, const Hobject StructElement2, Hobject* RegionHitMiss, const Hlong Row, const Hlong Column)

Herror T_hit_or_miss(const Hobject Region, const Hobject StructElement1, const Hobject StructElement2, Hobject* RegionHitMiss, const Htuple Row, const Htuple Column)

void HitOrMiss(const HObject& Region, const HObject& StructElement1, const HObject& StructElement2, HObject* RegionHitMiss, const HTuple& Row, const HTuple& Column)

HRegion HRegion::HitOrMiss(const HRegion& StructElement1, const HRegion& StructElement2, Hlong Row, Hlong Column) const

static void HOperatorSet.HitOrMiss(HObject region, HObject structElement1, HObject structElement2, out HObject regionHitMiss, HTuple row, HTuple column)

HRegion HRegion.HitOrMiss(HRegion structElement1, HRegion structElement2, int row, int column)

Description

hit_or_misshit_or_missHitOrMissHitOrMissHitOrMiss performs the hit-or-miss-transformation. First, an erosion with the structuring element StructElement1StructElement1StructElement1StructElement1structElement1 is done on the input region RegionRegionRegionRegionregion. Then an erosion with the structuring element StructElement2StructElement2StructElement2StructElement2structElement2 is performed on the complement of the input region. The intersection of the two resulting regions is the result RegionHitMissRegionHitMissRegionHitMissRegionHitMissregionHitMiss of hit_or_misshit_or_missHitOrMissHitOrMissHitOrMiss.

The hit-or-miss-transformation selects precisely the points for which the conditions given by the structuring elements StructElement1StructElement1StructElement1StructElement1structElement1 and StructElement2StructElement2StructElement2StructElement2structElement2 are fulfilled. StructElement1StructElement1StructElement1StructElement1structElement1 determines the condition for the foreground pixels, while StructElement2StructElement2StructElement2StructElement2structElement2 determines the condition for the background pixels. In order to obtain sensible results, StructElement1StructElement1StructElement1StructElement1structElement1 and StructElement2StructElement2StructElement2StructElement2structElement2 must fit like key and lock. In any case, StructElement1StructElement1StructElement1StructElement1structElement1 and StructElement2StructElement2StructElement2StructElement2structElement2 must be disjunct. RowRowRowRowrow and ColumnColumnColumnColumncolumn determine the reference point of the structuring elements.

Structuring elements (StructElement1StructElement1StructElement1StructElement1structElement1, StructElement2StructElement2StructElement2StructElement2structElement2) can be generated by calling operators like gen_region_pointsgen_region_pointsGenRegionPointsGenRegionPointsGenRegionPoints, etc.

Execution Information

Parameters

RegionRegionRegionRegionregion (input_object)  region(-array) objectHRegionHRegionHobject

Regions to be processed.

StructElement1StructElement1StructElement1StructElement1structElement1 (input_object)  region objectHRegionHRegionHobject

Erosion mask for the input regions.

StructElement2StructElement2StructElement2StructElement2structElement2 (input_object)  region objectHRegionHRegionHobject

Erosion mask for the complements of the input regions.

RegionHitMissRegionHitMissRegionHitMissRegionHitMissregionHitMiss (output_object)  region(-array) objectHRegionHRegionHobject *

Result of the hit-or-miss operation.

RowRowRowRowrow (input_control)  point.y HTupleHTupleHtuple (integer) (int / long) (Hlong) (Hlong)

Row coordinate of the reference point.

Default value: 16

Suggested values: 0, 16, 32, 128, 256

Typical range of values: 0 ≤ Row Row Row Row row ≤ 511 (lin)

Minimum increment: 1

Recommended increment: 1

ColumnColumnColumnColumncolumn (input_control)  point.x HTupleHTupleHtuple (integer) (int / long) (Hlong) (Hlong)

Column coordinate of the reference point.

Default value: 16

Suggested values: 0, 16, 32, 128, 256

Typical range of values: 0 ≤ Column Column Column Column column ≤ 511 (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

hit_or_misshit_or_missHitOrMissHitOrMissHitOrMiss 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

Possible Successors

differencedifferenceDifferenceDifferenceDifference, reduce_domainreduce_domainReduceDomainReduceDomainReduceDomain, select_shapeselect_shapeSelectShapeSelectShapeSelectShape, area_centerarea_centerAreaCenterAreaCenterAreaCenter, connectionconnectionConnectionConnectionConnection

Alternatives

erosion2erosion2Erosion2Erosion2Erosion2, dilation2dilation2Dilation2Dilation2Dilation2

See also

gen_region_pointsgen_region_pointsGenRegionPointsGenRegionPointsGenRegionPoints, gen_region_polygon_filledgen_region_polygon_filledGenRegionPolygonFilledGenRegionPolygonFilledGenRegionPolygonFilled

Module

Foundation