hit_or_misshit_or_missHitOrMissHitOrMisshit_or_miss (Operator)

Name

hit_or_misshit_or_missHitOrMissHitOrMisshit_or_miss — 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)

def hit_or_miss(region: HObject, struct_element_1: HObject, struct_element_2: HObject, row: int, column: int) -> HObject

Description

hit_or_misshit_or_missHitOrMissHitOrMissHitOrMisshit_or_miss performs the hit-or-miss-transformation. First, an erosion with the structuring element StructElement1StructElement1StructElement1StructElement1structElement1struct_element_1 is done on the input region RegionRegionRegionRegionregionregion. Then an erosion with the structuring element StructElement2StructElement2StructElement2StructElement2structElement2struct_element_2 is performed on the complement of the input region. The intersection of the two resulting regions is the result RegionHitMissRegionHitMissRegionHitMissRegionHitMissregionHitMissregion_hit_miss of hit_or_misshit_or_missHitOrMissHitOrMissHitOrMisshit_or_miss.

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

Structuring elements (StructElement1StructElement1StructElement1StructElement1structElement1struct_element_1, StructElement2StructElement2StructElement2StructElement2structElement2struct_element_2) can be generated by calling operators like gen_region_pointsgen_region_pointsGenRegionPointsGenRegionPointsGenRegionPointsgen_region_points, etc.

Execution Information

Parameters

RegionRegionRegionRegionregionregion (input_object)  region(-array) objectHRegionHObjectHRegionHobject

Regions to be processed.

StructElement1StructElement1StructElement1StructElement1structElement1struct_element_1 (input_object)  region objectHRegionHObjectHRegionHobject

Erosion mask for the input regions.

StructElement2StructElement2StructElement2StructElement2structElement2struct_element_2 (input_object)  region objectHRegionHObjectHRegionHobject

Erosion mask for the complements of the input regions.

RegionHitMissRegionHitMissRegionHitMissRegionHitMissregionHitMissregion_hit_miss (output_object)  region(-array) objectHRegionHObjectHRegionHobject *

Result of the hit-or-miss operation.

RowRowRowRowrowrow (input_control)  point.y HTupleintHTupleHtuple (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 row ≤ 511 (lin)

Minimum increment: 1

Recommended increment: 1

ColumnColumnColumnColumncolumncolumn (input_control)  point.x HTupleintHTupleHtuple (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 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_missHitOrMissHitOrMissHitOrMisshit_or_miss returns 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

thresholdthresholdThresholdThresholdThresholdthreshold, regiongrowingregiongrowingRegiongrowingRegiongrowingRegiongrowingregiongrowing, connectionconnectionConnectionConnectionConnectionconnection, union1union1Union1Union1Union1union1, watershedswatershedsWatershedsWatershedsWatershedswatersheds, class_ndim_normclass_ndim_normClassNdimNormClassNdimNormClassNdimNormclass_ndim_norm

Possible Successors

differencedifferenceDifferenceDifferenceDifferencedifference, reduce_domainreduce_domainReduceDomainReduceDomainReduceDomainreduce_domain, select_shapeselect_shapeSelectShapeSelectShapeSelectShapeselect_shape, area_centerarea_centerAreaCenterAreaCenterAreaCenterarea_center, connectionconnectionConnectionConnectionConnectionconnection

Alternatives

erosion2erosion2Erosion2Erosion2Erosion2erosion2, dilation2dilation2Dilation2Dilation2Dilation2dilation2

See also

gen_region_pointsgen_region_pointsGenRegionPointsGenRegionPointsGenRegionPointsgen_region_points, gen_region_polygon_filledgen_region_polygon_filledGenRegionPolygonFilledGenRegionPolygonFilledGenRegionPolygonFilledgen_region_polygon_filled

Module

Foundation