orientation_points_xldorientation_points_xldOrientationPointsXldOrientationPointsXldorientation_points_xld (Operator)

Name

orientation_points_xldorientation_points_xldOrientationPointsXldOrientationPointsXldorientation_points_xld — Orientation of contours or polygons treated as point clouds.

Signature

orientation_points_xld(XLD : : : Phi)

Herror orientation_points_xld(const Hobject XLD, double* Phi)

Herror T_orientation_points_xld(const Hobject XLD, Htuple* Phi)

void OrientationPointsXld(const HObject& XLD, HTuple* Phi)

HTuple HXLD::OrientationPointsXld() const

static void HOperatorSet.OrientationPointsXld(HObject XLD, out HTuple phi)

HTuple HXLD.OrientationPointsXld()

def orientation_points_xld(xld: HObject) -> Sequence[float]

def orientation_points_xld_s(xld: HObject) -> float

Description

The operator orientation_points_xldorientation_points_xldOrientationPointsXldOrientationPointsXldOrientationPointsXldorientation_points_xld calculates the orientation of the point clouds given by the contours or polygons XLDXLDXLDXLDXLDxld (i.e., the order of the points in the contour or polygon is not taken into account). The orientation Phi is calculated the same way as in elliptic_axis_points_xldelliptic_axis_points_xldEllipticAxisPointsXldEllipticAxisPointsXldEllipticAxisPointsXldelliptic_axis_points_xld. If the contour or polygon is closed (end point = start point), the end point of the contour or polygon is not taken into account to avoid that it receives twice the weight of the other points.

In addition, the contour point p_{m} with maximum distance to the center of gravity c is calculated. If the angle between the vector and the vector given by Phi is greater than , the value of is added to the angle. If XLDXLDXLDXLDXLDxld consists of only two points, PhiPhiPhiPhiphiphi is given by the direction from the first point towards the second point.

orientation_points_xldorientation_points_xldOrientationPointsXldOrientationPointsXldOrientationPointsXldorientation_points_xld should be used if the contour XLDXLDXLDXLDXLDxld intersects itself or if it is not possible to close the contour using a line from end to start point without self-intersection, because in this case orientation_xldorientation_xldOrientationXldOrientationXldOrientationXldorientation_xld does not produce useful results. To test whether the contours or polygons intersect themselves, test_self_intersection_xldtest_self_intersection_xldTestSelfIntersectionXldTestSelfIntersectionXldTestSelfIntersectionXldtest_self_intersection_xld can be used.

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

Execution Information

Parameters

XLDXLDXLDXLDXLDxld (input_object)  xld(-array) objectHXLDHObjectHXLDHobject

Contours or polygons to be examined.

PhiPhiPhiPhiphiphi (output_control)  angle.rad(-array) HTupleSequence[float]HTupleHtuple (real) (double) (double) (double)

Orientation of the contours or polygons (radians).

Assertion: - pi < Phi && Phi <= pi

Possible Predecessors

gen_contours_skeleton_xldgen_contours_skeleton_xldGenContoursSkeletonXldGenContoursSkeletonXldGenContoursSkeletonXldgen_contours_skeleton_xld, edges_sub_pixedges_sub_pixEdgesSubPixEdgesSubPixEdgesSubPixedges_sub_pix, threshold_sub_pixthreshold_sub_pixThresholdSubPixThresholdSubPixThresholdSubPixthreshold_sub_pix, gen_contour_polygon_xldgen_contour_polygon_xldGenContourPolygonXldGenContourPolygonXldGenContourPolygonXldgen_contour_polygon_xld

Alternatives

orientation_xldorientation_xldOrientationXldOrientationXldOrientationXldorientation_xld, elliptic_axis_points_xldelliptic_axis_points_xldEllipticAxisPointsXldEllipticAxisPointsXldEllipticAxisPointsXldelliptic_axis_points_xld, smallest_rectangle2_xldsmallest_rectangle2_xldSmallestRectangle2XldSmallestRectangle2XldSmallestRectangle2Xldsmallest_rectangle2_xld

See also

moments_region_2ndmoments_region_2ndMomentsRegion2ndMomentsRegion2ndMomentsRegion2ndmoments_region_2nd

Module

Foundation