Operator Reference

opening_segopening_segOpeningSegOpeningSegopening_seg (Operator)

opening_segopening_segOpeningSegOpeningSegopening_seg — Separate overlapping regions.

Warning

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

Signature

opening_seg(Region, StructElement : RegionOpening : : )

Herror opening_seg(const Hobject Region, const Hobject StructElement, Hobject* RegionOpening)

Herror T_opening_seg(const Hobject Region, const Hobject StructElement, Hobject* RegionOpening)

void OpeningSeg(const HObject& Region, const HObject& StructElement, HObject* RegionOpening)

HRegion HRegion::OpeningSeg(const HRegion& StructElement) const

def opening_seg(region: HObject, struct_element: HObject) -> HObject

Description

The opening_segopening_segOpeningSegOpeningSegopening_seg operation is defined as a sequence of the following operators: erosion1erosion1Erosion1Erosion1erosion1, connectionconnectionConnectionConnectionconnection and dilation1dilation1Dilation1Dilation1dilation1 (see example). Only one iteration is done in erosion1erosion1Erosion1Erosion1erosion1 and dilation1dilation1Dilation1Dilation1dilation1.

opening_segopening_segOpeningSegOpeningSegopening_seg serves to separate overlapping regions whose area of overlap is smaller than StructElementStructElementStructElementstructElementstruct_element. It should be noted that the resulting regions can overlap without actually merging (see expand_regionexpand_regionExpandRegionExpandRegionexpand_region). opening_segopening_segOpeningSegOpeningSegopening_seg uses the center of gravity as the reference point of the structuring element.

Structuring elements (StructElementStructElementStructElementstructElementstruct_element) can be generated with operators such as gen_circlegen_circleGenCircleGenCirclegen_circle, gen_rectangle1gen_rectangle1GenRectangle1GenRectangle1gen_rectangle1, gen_rectangle2gen_rectangle2GenRectangle2GenRectangle2gen_rectangle2, gen_ellipsegen_ellipseGenEllipseGenEllipsegen_ellipse, draw_regiondraw_regionDrawRegionDrawRegiondraw_region, gen_region_polygongen_region_polygonGenRegionPolygonGenRegionPolygongen_region_polygon, 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 opened.

StructElementStructElementStructElementstructElementstruct_element (input_object)  region objectHRegionHObjectHObjectHobject

Structuring element (position-invariant).

RegionOpeningRegionOpeningRegionOpeningregionOpeningregion_opening (output_object)  region-array objectHRegionHObjectHObjectHobject *

Opened regions.

Example (HDevelop)

* Simulation of opening_seg
* opening_seg(Region,StructElement,RegionOpening):
    erosion1(Region,StructElement,H1,1)
    connection(H1,H2)
    dilation1(H2,StructElement,RegionOpening,1)

Example (C)

/* Simulation of opening_seg */
my_opening_seg(Hobject Region, Hobject StructElement, Hobject *Opening)
{
  Hobject  H1,H2;
  erosion1(Region,StructElement,&H1,1);
  connection(H1,&H2);
  dilation1(H2,StructElement,Opening,1);
}

/* separation of circular objects */
gen_random_regions(&Regions,"circle",8.5,10.5,0.0,0.0,0.0,0.0,400,512,512);
union1(Regions,&UnionReg);
gen_circle(&Mask,100,100,8.5);
opening_seg(UnionReg,Mask,&RegionsNew);

Example (C++)

#include "HIOStream.h"
#if !defined(USE_IOSTREAM_H)
using namespace std;
#endif
#include "HalconCpp.h"

main()
{
  HWindow  w;
  HRegionArray regs = HRegionArray::GenRandomRegions("circle",8.5,10.5,
                                                  0,0,0,0,400,512,512);

  HRegionArray ureg = regs.Union1();
  HRegion      crc  = HRegion::GenCircle(100,100,8.5);
  HRegionArray ops  = ureg.OpeningSeg(crc);

  w.SetColor("red");   regs.Display(w);  w.Click();
  w.SetColored(12);    ops.Display(w);   w.Click();

  return(0);
}

Example (HDevelop)

* Simulation of opening_seg
* opening_seg(Region,StructElement,RegionOpening):
    erosion1(Region,StructElement,H1,1)
    connection(H1,H2)
    dilation1(H2,StructElement,RegionOpening,1)

Complexity

Let F1 be the area of the input region, and F2 be the area of the structuring element. Then the runtime complexity for one region is:

Result

opening_segopening_segOpeningSegOpeningSegopening_seg 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, gen_circlegen_circleGenCircleGenCirclegen_circle, gen_ellipsegen_ellipseGenEllipseGenEllipsegen_ellipse, gen_rectangle1gen_rectangle1GenRectangle1GenRectangle1gen_rectangle1, gen_rectangle2gen_rectangle2GenRectangle2GenRectangle2gen_rectangle2, draw_regiondraw_regionDrawRegionDrawRegiondraw_region, gen_region_pointsgen_region_pointsGenRegionPointsGenRegionPointsgen_region_points, gen_region_polygon_filledgen_region_polygon_filledGenRegionPolygonFilledGenRegionPolygonFilledgen_region_polygon_filled

Possible Successors

expand_regionexpand_regionExpandRegionExpandRegionexpand_region, reduce_domainreduce_domainReduceDomainReduceDomainreduce_domain, select_shapeselect_shapeSelectShapeSelectShapeselect_shape, area_centerarea_centerAreaCenterAreaCenterarea_center, connectionconnectionConnectionConnectionconnection

Alternatives

erosion1erosion1Erosion1Erosion1erosion1, connectionconnectionConnectionConnectionconnection, dilation1dilation1Dilation1Dilation1dilation1

Module

Foundation