HALCON Reference Manual 10.0.2
Table of Contents / XLD / Features ClassesClassesClasses | | | Operators

circularity_xldcircularity_xldcircularity_xldCircularityXldCircularityXld (Operator)

Name

circularity_xldcircularity_xldcircularity_xldCircularityXldCircularityXld — Shape factor for the circularity (similarity to a circle) of contours or polygons.

Signature

circularity_xld(XLD : : : Circularity)

Herror circularity_xld(const Hobject XLD, double* Circularity)

Herror T_circularity_xld(const Hobject XLD, Htuple* Circularity)

Herror circularity_xld(Hobject XLD, double* Circularity)

Herror circularity_xld(Hobject XLD, HTuple* Circularity)

double HXLD::CircularityXld() const

HTuple HXLDArray::CircularityXld() const

void HOperatorSetX.CircularityXld(
[in] IHUntypedObjectX* XLD, [out] VARIANT* Circularity)

VARIANT HXLDX.CircularityXld()

VARIANT HXLDContX.CircularityXld()

VARIANT HXLDPolyX.CircularityXld()

VARIANT HXLDParaX.CircularityXld()

VARIANT HXLDModParaX.CircularityXld()

VARIANT HXLDExtParaX.CircularityXld()

static void HOperatorSet.CircularityXld(HObject XLD, out HTuple circularity)

HTuple HXLD.CircularityXld()

Description

The operator circularity_xldcircularity_xldcircularity_xldCircularityXldCircularityXld calculates the similarity of each input contour or polygon with a circle. The input contour or polygon must not intersect itself, otherwise the resulting parameter is not meaningful (Whether the input contour or polygon intersects itself or not can be determined with test_self_intersection_xldtest_self_intersection_xldtest_self_intersection_xldTestSelfIntersectionXldTestSelfIntersectionXld). If the input contour or polygon is not closed it will be closed automatically.

Calculation:

If F is the area enclosed by the contour or polygon and max is the
maximum distance from the center to all contour or polygon pixels, the shape
factor
CircularityCircularityCircularityCircularitycircularity is defined as:
                    CircularityCircularityCircularityCircularitycircularity = F / (max^2 * pi)

The shape factor CircularityCircularityCircularityCircularitycircularity of a circle is 1. If the contour or polygon encloses an elongated area CircularityCircularityCircularityCircularitycircularity is smaller than 1. The operator circularity_xldcircularity_xldcircularity_xldCircularityXldCircularityXld especially responds to large bulges.

If more than one contour or polygon is passed, the numerical values of the shape factor are stored in a tuple in the same order as the respective contours or polygons in XLDXLDXLDXLDXLD.

Parallelization

Parameters

XLDXLDXLDXLDXLD (input_object)  xld(-array) objectHXLDHXLDHXLDXHobject

Contours or polygons to be examined.

CircularityCircularityCircularityCircularitycircularity (output_control)  real(-array) HTupleHTupleVARIANTHtuple (real) (double) (double) (double) (double)

Roundness of the input contours or polygons.

Assertion: (0 <= Circularity) && (Circularity <= 1.0)

Result

The operator circularity_xldcircularity_xldcircularity_xldCircularityXldCircularityXld returns the value 2 (H_MSG_TRUE) if the input is not empty. The behavior in case of empty input (no input contour available) is set via the operator set_system('no_object_result',<Result>)set_system("no_object_result",<Result>)set_system("no_object_result",<Result>)SetSystem("no_object_result",<Result>)SetSystem("no_object_result",<Result>). If necessary an exception is raised.

Possible Predecessors

gen_contours_skeleton_xldgen_contours_skeleton_xldgen_contours_skeleton_xldGenContoursSkeletonXldGenContoursSkeletonXld, edges_sub_pixedges_sub_pixedges_sub_pixEdgesSubPixEdgesSubPix, threshold_sub_pixthreshold_sub_pixthreshold_sub_pixThresholdSubPixThresholdSubPix, gen_contour_polygon_xldgen_contour_polygon_xldgen_contour_polygon_xldGenContourPolygonXldGenContourPolygonXld, test_self_intersection_xldtest_self_intersection_xldtest_self_intersection_xldTestSelfIntersectionXldTestSelfIntersectionXld

Alternatives

compactness_xldcompactness_xldcompactness_xldCompactnessXldCompactnessXld, convexity_xldconvexity_xldconvexity_xldConvexityXldConvexityXld, eccentricity_xldeccentricity_xldeccentricity_xldEccentricityXldEccentricityXld

See also

area_center_xldarea_center_xldarea_center_xldAreaCenterXldAreaCenterXld, select_shape_xldselect_shape_xldselect_shape_xldSelectShapeXldSelectShapeXld

Module

Foundation


Table of Contents / XLD / Features ClassesClassesClasses | | | Operators
HALCON Reference Manual 10.0.2 Copyright © 1996-2011 MVTec Software GmbH