opening_seg opening_seg OpeningSeg OpeningSeg opening_seg (Operator)
opening_seg opening_seg OpeningSeg OpeningSeg opening_seg
— Separate overlapping regions.
Warning
opening_seg opening_seg OpeningSeg OpeningSeg opening_seg
is obsolete and is only provided for
reasons of backward compatibility.
Signature
Description
The opening_seg opening_seg OpeningSeg OpeningSeg opening_seg
operation is defined as a sequence of
the following operators: erosion1 erosion1 Erosion1 Erosion1 erosion1
,
connection connection Connection Connection connection
and dilation1 dilation1 Dilation1 Dilation1 dilation1
(see example).
Only one iteration is done in erosion1 erosion1 Erosion1 Erosion1 erosion1
and
dilation1 dilation1 Dilation1 Dilation1 dilation1
.
opening_seg opening_seg OpeningSeg OpeningSeg opening_seg
serves to separate overlapping regions whose
area of overlap is smaller than StructElement StructElement StructElement structElement struct_element
. It should
be noted that the resulting regions can overlap without actually
merging (see expand_region expand_region ExpandRegion ExpandRegion expand_region
). opening_seg opening_seg OpeningSeg OpeningSeg opening_seg
uses the
center of gravity as the reference point of the structuring element.
Structuring elements (StructElement StructElement StructElement structElement struct_element
) can be generated
with operators such as gen_circle gen_circle GenCircle GenCircle gen_circle
, gen_rectangle1 gen_rectangle1 GenRectangle1 GenRectangle1 gen_rectangle1
,
gen_rectangle2 gen_rectangle2 GenRectangle2 GenRectangle2 gen_rectangle2
, gen_ellipse gen_ellipse GenEllipse GenEllipse gen_ellipse
,
draw_region draw_region DrawRegion DrawRegion draw_region
, gen_region_polygon gen_region_polygon GenRegionPolygon GenRegionPolygon gen_region_polygon
,
gen_region_points gen_region_points 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
(input_object) region(-array) →
object HRegion HObject HObject Hobject
Regions to be opened.
StructElement StructElement StructElement structElement struct_element
(input_object) region →
object HRegion HObject HObject Hobject
Structuring element (position-invariant).
RegionOpening RegionOpening RegionOpening regionOpening region_opening
(output_object) region-array →
object HRegion HObject HObject Hobject *
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_seg opening_seg OpeningSeg OpeningSeg opening_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:
no region:
set_system('no_object_result',<RegionResult>) set_system("no_object_result",<RegionResult>) SetSystem("no_object_result",<RegionResult>) SetSystem("no_object_result",<RegionResult>) set_system("no_object_result",<RegionResult>)
empty region:
set_system('empty_region_result',<RegionResult>) set_system("empty_region_result",<RegionResult>) SetSystem("empty_region_result",<RegionResult>) SetSystem("empty_region_result",<RegionResult>) set_system("empty_region_result",<RegionResult>)
Otherwise, an exception is raised.
Possible Predecessors
threshold threshold Threshold Threshold threshold
,
regiongrowing regiongrowing Regiongrowing Regiongrowing regiongrowing
,
connection connection Connection Connection connection
,
union1 union1 Union1 Union1 union1
,
watersheds watersheds Watersheds Watersheds watersheds
,
class_ndim_norm class_ndim_norm ClassNdimNorm ClassNdimNorm class_ndim_norm
,
gen_circle gen_circle GenCircle GenCircle gen_circle
,
gen_ellipse gen_ellipse GenEllipse GenEllipse gen_ellipse
,
gen_rectangle1 gen_rectangle1 GenRectangle1 GenRectangle1 gen_rectangle1
,
gen_rectangle2 gen_rectangle2 GenRectangle2 GenRectangle2 gen_rectangle2
,
draw_region draw_region DrawRegion DrawRegion draw_region
,
gen_region_points gen_region_points GenRegionPoints GenRegionPoints gen_region_points
,
gen_region_polygon_filled gen_region_polygon_filled GenRegionPolygonFilled GenRegionPolygonFilled gen_region_polygon_filled
Possible Successors
expand_region expand_region ExpandRegion ExpandRegion expand_region
,
reduce_domain reduce_domain ReduceDomain ReduceDomain reduce_domain
,
select_shape select_shape SelectShape SelectShape select_shape
,
area_center area_center AreaCenter AreaCenter area_center
,
connection connection Connection Connection connection
Alternatives
erosion1 erosion1 Erosion1 Erosion1 erosion1
,
connection connection Connection Connection connection
,
dilation1 dilation1 Dilation1 Dilation1 dilation1
Module
Foundation