segment_contour_attrib_xldsegment_contour_attrib_xldSegmentContourAttribXldSegmentContourAttribXldsegment_contour_attrib_xld (Operator)

Name

segment_contour_attrib_xldsegment_contour_attrib_xldSegmentContourAttribXldSegmentContourAttribXldsegment_contour_attrib_xld — Segment XLD contour parts whose local attributes fulfill given conditions.

Signature

segment_contour_attrib_xld(Contour : ContourPart : Attribute, Operation, Min, Max : )

Herror segment_contour_attrib_xld(const Hobject Contour, Hobject* ContourPart, const char* Attribute, const char* Operation, double Min, double Max)

Herror T_segment_contour_attrib_xld(const Hobject Contour, Hobject* ContourPart, const Htuple Attribute, const Htuple Operation, const Htuple Min, const Htuple Max)

void SegmentContourAttribXld(const HObject& Contour, HObject* ContourPart, const HTuple& Attribute, const HTuple& Operation, const HTuple& Min, const HTuple& Max)

HXLDCont HXLDCont::SegmentContourAttribXld(const HTuple& Attribute, const HString& Operation, const HTuple& Min, const HTuple& Max) const

HXLDCont HXLDCont::SegmentContourAttribXld(const HString& Attribute, const HString& Operation, double Min, double Max) const

HXLDCont HXLDCont::SegmentContourAttribXld(const char* Attribute, const char* Operation, double Min, double Max) const

HXLDCont HXLDCont::SegmentContourAttribXld(const wchar_t* Attribute, const wchar_t* Operation, double Min, double Max) const   (Windows only)

static void HOperatorSet.SegmentContourAttribXld(HObject contour, out HObject contourPart, HTuple attribute, HTuple operation, HTuple min, HTuple max)

HXLDCont HXLDCont.SegmentContourAttribXld(HTuple attribute, string operation, HTuple min, HTuple max)

HXLDCont HXLDCont.SegmentContourAttribXld(string attribute, string operation, double min, double max)

def segment_contour_attrib_xld(contour: HObject, attribute: MaybeSequence[str], operation: str, min: MaybeSequence[Union[int, float, str]], max: MaybeSequence[Union[int, float, str]]) -> HObject

Description

segment_contour_attrib_xldsegment_contour_attrib_xldSegmentContourAttribXldSegmentContourAttribXldSegmentContourAttribXldsegment_contour_attrib_xld segments the contour in ContourContourContourContourcontourcontour into contour parts ContourPartContourPartContourPartContourPartcontourPartcontour_part. The segmentation of the contour depends on the values of its attributes AttributeAttributeAttributeAttributeattributeattribute (see the possible values for AttributeAttributeAttributeAttributeattributeattribute below). The operator checks which attribute values lie within the given limits (MinMinMinMinminmin, MaxMaxMaxMaxmaxmax) and returns the corresponding contour segments with its attributes in ContourPartContourPartContourPartContourPartcontourPartcontour_part.

If OperationOperationOperationOperationoperationoperation is set to 'and'"and""and""and""and""and", each of the given attributes must lie within the limits. If OperationOperationOperationOperationoperationoperation is set to 'or'"or""or""or""or""or", at least one of the attributes has to be within the limits. The attributes are processed in the same order as they are given in AttributeAttributeAttributeAttributeattributeattribute. If only one attribute is used, the value of OperationOperationOperationOperationoperationoperation is ignored. The parameters MinMinMinMinminmin and MaxMaxMaxMaxmaxmax can be set to 'min'"min""min""min""min""min" or 'max'"max""max""max""max""max" in order to leave bottom and top limit, respectively, open.

Note that not all attributes are defined in all contours per default. Which attributes are defined for a contour depends on how the contour was instantiated, and whether some operations have been previously performed on it. For example, the attributes 'width_right'"width_right""width_right""width_right""width_right""width_right" and 'width_left'"width_left""width_left""width_left""width_left""width_left" are only defined, if the contour was created with the operator lines_gausslines_gaussLinesGaussLinesGaussLinesGausslines_gauss. Likewise, the attribute 'distance'"distance""distance""distance""distance""distance" is only present if the distances to some other contour was previously calculated with distance_contours_xlddistance_contours_xldDistanceContoursXldDistanceContoursXldDistanceContoursXlddistance_contours_xld or apply_distance_transform_xldapply_distance_transform_xldApplyDistanceTransformXldApplyDistanceTransformXldApplyDistanceTransformXldapply_distance_transform_xld.

Condition:

Possible values for AttributeAttributeAttributeAttributeattributeattribute:

'edge_direction':

Edge direction

'angle':

Angle of the direction perpendicular to the contour

'response':

Magnitude of the second derivative

'width_right':

Line width to the right of the line

'width_left':

Line width to the left of the line

'contrast':

Contrast of the line point

'asymmetry':

Asymmetry of the line point

'distance':

Minimum pointwise distance to a reference contour

To find out which operators add the attributes above to contours and further details about those attributes, see get_contour_attrib_xldget_contour_attrib_xldGetContourAttribXldGetContourAttribXldGetContourAttribXldget_contour_attrib_xld.

Execution Information

Parameters

ContourContourContourContourcontourcontour (input_object)  xld_cont(-array) objectHXLDContHObjectHXLDContHobject

Contour to be segmented.

ContourPartContourPartContourPartContourPartcontourPartcontour_part (output_object)  xld_cont-array objectHXLDContHObjectHXLDContHobject *

Segmented contour parts.

AttributeAttributeAttributeAttributeattributeattribute (input_control)  string(-array) HTupleMaybeSequence[str]HTupleHtuple (string) (string) (HString) (char*)

Contour attributes to be checked.

Default value: 'distance' "distance" "distance" "distance" "distance" "distance"

List of values: 'angle'"angle""angle""angle""angle""angle", 'asymmetry'"asymmetry""asymmetry""asymmetry""asymmetry""asymmetry", 'contrast'"contrast""contrast""contrast""contrast""contrast", 'distance'"distance""distance""distance""distance""distance", 'edge_direction'"edge_direction""edge_direction""edge_direction""edge_direction""edge_direction", 'response'"response""response""response""response""response", 'width_left'"width_left""width_left""width_left""width_left""width_left", 'width_right'"width_right""width_right""width_right""width_right""width_right"

OperationOperationOperationOperationoperationoperation (input_control)  string HTuplestrHTupleHtuple (string) (string) (HString) (char*)

Linkage type of the individual attributes.

Default value: 'and' "and" "and" "and" "and" "and"

List of values: 'and'"and""and""and""and""and", 'or'"or""or""or""or""or"

MinMinMinMinminmin (input_control)  real(-array) HTupleMaybeSequence[Union[int, float, str]]HTupleHtuple (real / integer / string) (double / int / long / string) (double / Hlong / HString) (double / Hlong / char*)

Lower limits of the attribute values.

Default value: 150.0

Minimum increment: 0.001

Recommended increment: 1.0

MaxMaxMaxMaxmaxmax (input_control)  real(-array) HTupleMaybeSequence[Union[int, float, str]]HTupleHtuple (real / integer / string) (double / int / long / string) (double / Hlong / HString) (double / Hlong / char*)

Upper limits of the attribute values.

Default value: 99999.0

Minimum increment: 0.001

Recommended increment: 1.0

Restriction: Max >= Min

Example (HDevelop)

read_image (Image, 'fabrik')
edges_sub_pix (Image, Edges, 'canny', 1, 20, 40)
* select 'vertical' edges:
segment_contour_attrib_xld (Edges, ContourPart, 'edge_direction', \
                            'and', rad(90-20), rad(90+20))

Result

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

Possible Predecessors

lines_gausslines_gaussLinesGaussLinesGaussLinesGausslines_gauss, edges_sub_pixedges_sub_pixEdgesSubPixEdgesSubPixEdgesSubPixedges_sub_pix, apply_distance_transform_xldapply_distance_transform_xldApplyDistanceTransformXldApplyDistanceTransformXldApplyDistanceTransformXldapply_distance_transform_xld, distance_contours_xlddistance_contours_xldDistanceContoursXldDistanceContoursXldDistanceContoursXlddistance_contours_xld

Possible Successors

fit_line_contour_xldfit_line_contour_xldFitLineContourXldFitLineContourXldFitLineContourXldfit_line_contour_xld, fit_ellipse_contour_xldfit_ellipse_contour_xldFitEllipseContourXldFitEllipseContourXldFitEllipseContourXldfit_ellipse_contour_xld, fit_circle_contour_xldfit_circle_contour_xldFitCircleContourXldFitCircleContourXldFitCircleContourXldfit_circle_contour_xld, fit_rectangle2_contour_xldfit_rectangle2_contour_xldFitRectangle2ContourXldFitRectangle2ContourXldFitRectangle2ContourXldfit_rectangle2_contour_xld

See also

split_contours_xldsplit_contours_xldSplitContoursXldSplitContoursXldSplitContoursXldsplit_contours_xld, get_contour_global_attrib_xldget_contour_global_attrib_xldGetContourGlobalAttribXldGetContourGlobalAttribXldGetContourGlobalAttribXldget_contour_global_attrib_xld, query_contour_attribs_xldquery_contour_attribs_xldQueryContourAttribsXldQueryContourAttribsXldQueryContourAttribsXldquery_contour_attribs_xld, get_contour_attrib_xldget_contour_attrib_xldGetContourAttribXldGetContourAttribXldGetContourAttribXldget_contour_attrib_xld

Module

Foundation