Operator Reference

hit_or_misshit_or_missHitOrMissHitOrMisshit_or_miss (Operator)

hit_or_misshit_or_missHitOrMissHitOrMisshit_or_miss — Hit-or-miss operation for regions.

Signature

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

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

Description

hit_or_misshit_or_missHitOrMissHitOrMisshit_or_miss performs the hit-or-miss-transformation. First, an erosion with the structuring element StructElement1StructElement1StructElement1structElement1struct_element_1 is done on the input region RegionRegionRegionregionregion. Then an erosion with the structuring element StructElement2StructElement2StructElement2structElement2struct_element_2 is performed on the complement of the input region. The intersection of the two resulting regions is the result RegionHitMissRegionHitMissRegionHitMissregionHitMissregion_hit_miss of hit_or_misshit_or_missHitOrMissHitOrMisshit_or_miss.

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

Structuring elements (StructElement1StructElement1StructElement1structElement1struct_element_1, StructElement2StructElement2StructElement2structElement2struct_element_2) can be generated by calling operators like gen_region_pointsgen_region_pointsGenRegionPointsGenRegionPointsgen_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

RegionRegionRegionregionregion (input_object)  region(-array) objectHRegionHObjectHObjectHobject

Regions to be processed.

StructElement1StructElement1StructElement1structElement1struct_element_1 (input_object)  region objectHRegionHObjectHObjectHobject

Erosion mask for the input regions.

StructElement2StructElement2StructElement2structElement2struct_element_2 (input_object)  region objectHRegionHObjectHObjectHobject

Erosion mask for the complements of the input regions.

RegionHitMissRegionHitMissRegionHitMissregionHitMissregion_hit_miss (output_object)  region(-array) objectHRegionHObjectHObjectHobject *

Result of the hit-or-miss operation.

RowRowRowrowrow (input_control)  point.y HTupleintHTupleHtuple (integer) (int / long) (Hlong) (Hlong)

Row coordinate of the reference point.

Default: 16

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

Value range: 0 ≤ Row Row Row row row ≤ 511 (lin)

Minimum increment: 1

Recommended increment: 1

ColumnColumnColumncolumncolumn (input_control)  point.x HTupleintHTupleHtuple (integer) (int / long) (Hlong) (Hlong)

Column coordinate of the reference point.

Default: 16

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

Value range: 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_missHitOrMissHitOrMisshit_or_miss 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_normClassNdimNormClassNdimNormclass_ndim_norm

Possible Successors

differencedifferenceDifferenceDifferencedifference, reduce_domainreduce_domainReduceDomainReduceDomainreduce_domain, select_shapeselect_shapeSelectShapeSelectShapeselect_shape, area_centerarea_centerAreaCenterAreaCenterarea_center, connectionconnectionConnectionConnectionconnection

Alternatives

erosion2erosion2Erosion2Erosion2erosion2, dilation2dilation2Dilation2Dilation2dilation2

See also

gen_region_pointsgen_region_pointsGenRegionPointsGenRegionPointsgen_region_points, gen_region_polygon_filledgen_region_polygon_filledGenRegionPolygonFilledGenRegionPolygonFilledgen_region_polygon_filled

Module

Foundation