This application claims priority from Korean Patent Application No. 10-2015-0177369, filed on Dec. 11, 2015, in the Korean Intellectual Property Office, the disclosure of which is incorporated herein in its entirety by reference.
1. Field
Apparatuses and methods consistent with exemplary embodiments relate to determining obstacle collision by using an object moving path, and more particularly, to determining obstacle collision by using a topological skeleton of an object moving path.
2. Description of the Related Art
In order to create an optimum moving path for an object such as a moving robot along which the object does not collide with any obstacle, it may be required to predetermine whether the object will collide with an obstacle on the moving path and a distance between the object and the obstacle.
One or more exemplary embodiments provide a method and apparatus for determining obstacle collision by using an object moving path, whereby topological skeleton points in a path area are used to determine the obstacle collision, thereby reducing the number of operations necessary for determining obstacle collision in comparison to the case when all points in the path area are used.
One or more exemplary embodiments provide a method and apparatus for determining obstacle collision by using an object moving path, whereby only some points of a topological skeleton based on a determined error value are selected, a path area is modeled, and the modeled path area is used to determine the obstacle collision so as to adjust a modeling error and operation reduction effects according to the modeling error.
Various aspects will be set forth in part in the description which follows and, in part, will be apparent from the description, or may be learned by practice of the presented exemplary embodiments.
According to one or more embodiments, there is provided a method of determining obstacle collision by using an object moving path. The method may include: acquiring a topological skeleton corresponding to a path area on an image including a moving path of an object and an obstacle; determining, from among skeleton points forming the topological skeleton, branch points that are interconnecting points between branches of the topological skeleton; determining a target branch from among the branches by using the branch points; selecting, from among points forming the target branch, a plurality of target points to determine whether the moving path is a collision path of the object; and determining whether the moving path is the collision path by using the target points.
The selecting the target points may include: creating a filling circle for each of the target points, the filling circle having the each of the target points as a center and a shortest distance between a boundary of the path area and the each of the target points as a radius; calculating error values for the each of the target points by using the filling circles; and selecting target points such that the error value is less than a preset error threshold.
The calculating of the error values may include acquiring, for each pair of the target points that do not have another target point in between, two intersections between two filling circles corresponding to the each pair of the target points and two lines that contact the two filling circles, and calculating the error values based on a least value from among distances between the intersections and the lines.
The calculating the error values may include acquiring, for each pair of the target points that do not have another target point in between, two intersections between two filling circles corresponding to the each pair of the target points, and calculating the error values based on a greatest value from among shortest distances between the boundary of the path area and the intersections.
The calculating the error values may include calculating the error values based on the number of points in a portion of the path area which does not overlap the filling circles.
The creating the filling circle may include acquiring a shortest distance between the boundary of the path area and the each of the each of the target points based on a value obtained by Euclidean distance transforming the image based on the boundary of the path area.
The determining whether the moving path is the collision path may include determining whether the moving path is the collision path by comparing, for each of the target points, a shortest distance between a boundary of the path area and the each of the target points with a shortest distance between a boundary of the obstacle and the each of the target points.
The moving path may be determined as the collision path when there is a target point with respect to which the shortest distance between the boundary of the path area and the target point is longer than the shortest distance between the boundary of the obstacle and the target point.
The acquiring the topological skeleton may include acquiring a first median by Euclidean distance transforming the image based on a boundary of the path area; acquiring a second median by detecting feature points from the first median; acquiring a third median by thinning feature points of the second median; and acquiring the topological skeleton by detecting largest connected points from among thinned points of the third median.
The determining the branch points may include: determining, for each of the skeleton points, a neighboring skeleton point in a horizontal or vertical direction as a first neighbor skeleton point; determining another skeleton point not neighboring the first neighbor skeleton point in the horizontal or vertical direction but neighboring the each one of the skeleton points in a diagonal direction as a second neighbor skeleton point; and determining one of the skeleton points having three or more neighboring skeleton points as the branch point.
The determining the target branch may include determining, from among the branches, a branch formed of the greatest number of points as the target branch.
According to one or more embodiments, there is provided an apparatus for determining obstacle collision by using an object moving path which may include: a topological skeleton acquirer configured to acquire a topological skeleton corresponding to a path area in an image including a moving path of an object and an obstacle; a branch point determiner configured to determine, from among skeleton points forming the topological skeleton, branch points that are interconnecting points between branches of the topological skeleton; a target branch determiner configured to determine a target branch from among the branches by using the branch points; a target point selector configured to select, from among points forming the target branch, a plurality of target points to determine whether the moving path is a collision path of the object; and a collision path determiner configured to determine whether the moving path is the collision path by using the target points.
These and/or other aspects will become apparent and more readily appreciated from the following description of the exemplary embodiments, taken in conjunction with the accompanying drawings, in which:
As the inventive concept of the present application allows for various changes, the exemplary embodiments will be illustrated in the drawings and described in detail in the written description. However, this is not intended to limit the inventive concept to particular modes of practice or embodiments, and it will be appreciated that all changes, equivalents, and substitutes that do not depart from the spirit and technical scope of the inventive concept are encompassed in the exemplary embodiments. In the description of the exemplary embodiments, certain detailed explanations of the related art are omitted when it is deemed that they may unnecessarily obscure the essence of the inventive concept. As used herein, the term “and/or” includes any and all combinations of one or more of the associated listed items. Expressions such as “at least one of,” when preceding a list of elements, modify the entire list of elements and do not modify the individual elements of the list.
In the description herein, while such terms as “first,” “second,” etc., may be used to describe various components, such components must not be limited to the above terms. The above terms are used only to distinguish one component from another.
The terms used herein are merely used to describe the exemplary embodiments and are not intended to limit the inventive concept. An expression used in the singular encompasses the expression of the plural, unless it has a clearly different meaning in the context. In the descriptions herein, it is to be understood that the terms such as “including,” “having,” and “comprising” are intended to indicate the existence of the features, numbers, steps, actions, components, parts, or combinations thereof disclosed in the specification, and are not intended to preclude the possibility that one or more other features, numbers, steps, actions, components, parts, or combinations thereof may exist or may be added.
The exemplary embodiments may be described in terms of functional block components and various processing steps. Such functional blocks, e.g.,
In the exemplary embodiments and the accompanying drawings, like reference numerals in the drawings denote like elements, and thus their description will not be repeated
Referring to
The topological skeleton acquirer 110 may acquire a topological skeleton that corresponds to a path area on an image including an obstacle and a moving path of an object.
The moving path of the object may be a path area generated when the object moves. The object may have preset horizontal and vertical lengths, and the path area may be a path that has an area with respect to a size of the object.
The object may collide with or avoid the obstacle while moving. The obstacle may be arranged on the image as a line or an area.
The topological skeleton may be a group of points away from a boundary of the path area by an identical distance. For example, the topological skeleton may be a medial axis formed in the path area.
Hereinafter, points on an image forming the topological skeleton are referred to as skeleton points.
The branch point determiner 120 may determine, from among skeleton points that form the topological skeleton, branch points that are interconnecting points between branches of the topological skeleton.
The topological skeleton may be classified as nodes connected to at least two lines and branches connected to the nodes.
Hereinafter, a point on the image and corresponding to a node is referred to as a branch point, a point corresponding to an end point from among points forming a branch is referred to as an end point, and a point other than the end point from among the points forming the branch is referred to as a normal point.
The target branch determiner 130 may determine a target branch from among the branches by using the branch points.
In this case, the target branch determiner 130 may determine a branch formed of the greatest number of points as the target branch.
The target point selector 140 may select, from among points forming the target branch, a plurality of target points for determining whether the moving path is a collision path.
The target point selector 140 may select all or some of the points that form the target branch as the target points.
When the target point selector 140 selects only some of the points that form the target branch as the target points, the target point selector 140 may select the target points such that an error value is less than a preset error threshold. The error value may be a modeling error value of the path area.
For example, the target point selector 140 may select only some of the points that form the target branch as the target points, model a path area by creating a filling circle for each of the target points, and select the target points such that a modeling error value is less than the preset error threshold.
In this case, the target point selector 140 may select more target points and create more filling circles to reduce a modeling error value such that the modeling error value is less than the preset error threshold.
The collision path determiner 150 may determine whether the moving path is the collision path by using the target points.
That is, when there is an obstacle on the moving path, the collision path determiner 150 may determine that the moving path is the collision path.
According to exemplary embodiments, when the collision path determiner 150 determines that the moving path is not the collision path, the collision path determiner 150 may calculate a distance between the object moving along the moving path under control of the apparatus 100 and the obstacle on the moving path as an evaluation index of the moving path.
Referring to
For each of the target points, the filling circle creator 210 may create a filling circle having the each of the target points as the center and a shortest distance between a boundary of the path area and the each of the target points as a radius.
That is, the filling circle creator 210 may model the path area by creating a filling circle for the each of the target points.
According to exemplary embodiments, the filling circle creator 210 may acquire the shortest distance between the boundary of the path area and the each of the target points based on a value obtained by Euclidean distance transforming the image based on the boundary of the path area, and set the acquired distance as the radius of the filling circle.
The error value calculator 220 may calculate error values by using the filling circles.
According to exemplary embodiments, for each pair of the target points that do not have another target point therebetween, the error value calculator 220 may acquire two intersections between two filling circles corresponding to the each pair of the target points and two lines that simultaneously contact the two filling circles, and calculate the error values based on the least value from among distances between the intersections and the lines.
According to exemplary embodiments, for each pair of the target points that do not have another target point therebetween, the error value calculator 220 may acquire two intersections between two filling circles corresponding to the each pair of the target points, and calculate the error values based on the greatest value from among the shortest distances between the boundary of the path area and the intersections.
According to exemplary embodiments, the error value calculator 220 may calculate the error values based on the number of points included in a portion of a path area which does not overlap the filling circles.
Referring to
First, the topological skeleton acquirer (110 of
Second, the branch point determiner (120 of
Third, the target branch determiner (130 of
Fourth, the target point selector (140 of
Lastly, the collision path determiner (150 of
Although not shown in
Referring to
First, in the selecting the target points (S340) of
In operation S410, the filling circle creator (210 of
Next, in the selecting of the target points (S340) of
In operation S420, for each pair of the target points that do not have another target point therebetween, the error value calculator (220 of
In operation S420, for each pair of target points that do not have another target point therebetween, the error value calculator (220 of
In operation S420, the error value calculator (220 of
Lastly, in the selecting the target points (S340) of
Referring to
First, in the acquiring the topological skeleton (S310) of
Second, in the acquiring the topological skeleton (S310) of
Third, in the acquiring the topological skeleton (S310) of
Fourth, in the acquiring the topological skeleton (S310) of
Referring to
First, in the determining the branch points (S320) of
Based on the determination of operation S610, when the surrounding skeleton point neighbors the central skeleton point in the horizontal or the vertical direction, in the determining the branch points (S320) of
Based on the determination of operation S610, when the surrounding skeleton point does not neighbor the central skeleton point in the horizontal or the vertical direction, in the determining the branch points (S320) of
Based on the determination of operation S620, when the surrounding skeleton point does not neighbor the first neighbor skeleton point in the horizontal or the vertical direction, in the determining the branch points (S320) of
Based on the determination of operation S630, when the surrounding skeleton point neighbors the central skeleton point in the diagonal direction, in the determining the branch points (S320) of
When the surrounding skeleton point neighbors the first neighbor skeleton point in the horizontal or the vertical direction based on the determination of operation S620 or when the surrounding skeleton point does not neighbor the central skeleton point in the diagonal direction based on the determination of operation S630, in the determining the branch points (S320) of
After determining the neighbor skeleton point condition by performing operations S610, S620, and S630, in the determining the branch points (S320) of
Based on the determination of operation S640, when the central skeleton point has three or more neighbor skeleton points, in the determining the branch points (S320) of
Based on the determination of operation S640, when the central skeleton point does not have three or more neighbor skeleton points, in the determining the branch points (S320) of
The branch point determiner (120 of
Referring to
In the determining the collision path (S350) of
In this case, the radius corresponding to the target point may be equal to the shortest distance between the boundary of the path area and the target point.
Based on the determination of operation S710, when there is at least one radius of the filling circle corresponding to the target point greater than the shortest distance between the target point and the obstacle, in the determining the collision path (S350) of
Based on the determination of operation S710, when there is no radius of the filling circle corresponding to the target point greater than the shortest distance between the target point and the obstacle, in the determining the collision path (S350) of
According to an exemplary embodiment, based on the determination of operation S710, when there is no radius of the filling circle corresponding to the target point greater than the shortest distance between the target point and the obstacle, in the determining the collision path (S350) of
The distance from the object to the obstacle on the object moving path may be utilized as an evaluation index of the object moving path.
Referring to
The object moving path 810 may be a course that the object 820 passes as the center of the object 820 moves from a starting point 831 to a finish point 832 along a central line 830.
In this case, since the object 820 has a width w and a length d, a thickness of the object moving path 810 may be greater than the width w of the object 820.
Referring to
Referring to
First, suppose that a point from among the points forming the topological skeleton is referred to as a central point, and points that neighbor the central point are referred to as surrounding points. One central point and one surrounding point may be neighbors in eight directions. For example, one central point may have one surrounding point in any of two horizontal directions, two vertical directions, and four diagonal directions. As shown in
In this case, the branch point determiner (120 of
For example, when there is one neighboring point, the branch point determiner (120 of
Even when any one of the surrounding points neighbor the central point, when that surrounding point is neighbors another surrounding point in a horizontal or vertical direction, the branch point determiner (120 of
Referring to
In an exemplary embodiment, as shown in
In another exemplary embodiment, as shown in
According to such method, the error value 110 may be adjusted by modifying a distance between the target points C1 and C2 on the topological skeleton 1120.
For example, when the distance between the target points C1 and C2 on the topological skeleton 1120 increases, the intersections of the two filling circles created with respect to the target points C1 and C2 may be located closer to the topological skeleton 1120, which thus may lead to an increase in the error value 1110.
Although not shown in
Referring to
That is, when an error threshold increases, a distance between target points arranged on a topological skeleton corresponding to a path area may increase, and thus the number of filling circles created on each of the target points may decrease.
Accordingly, the method of determining the obstacle collision by using the object moving path according to an exemplary embodiment may be used to increase modeling error and decrease the number of filling circles, thus reducing an amount of operations or calculation necessary or required for determining obstacle collision.
The method and apparatus according to the above exemplary embodiments may be used to determine obstacle collision by using topological skeleton points of a path area, and thus operations or calculations necessary or required for determining obstacle collision may be reduced in comparison to when using all points in the path area.
Based on an error value set according to the method and apparatus according to the above exemplary embodiments, some points may be selected from the topological skeleton to model the path area, and the obstacle collision may be determined by using the modeled path area. Accordingly, modeling error and operation reduction effects according to the modeling error may be adjusted.
The aforementioned embodiments may be implemented through program instructions that are executable via various computer devices and recorded in computer-readable recording media. Examples of the computer-readable recording media include magnetic media (e.g., hard disks, floppy disks, or magnetic tapes), optical media (e.g., CD-ROMs or DVDs), magneto-optical media (e.g., floptical disks), and hardware devices specifically designed to store and execute the program instructions (e.g., ROM or RAM). Furthermore, the computer-readable recording media may include intangible media that are transmittable via networks, for example, software or applications that may be transmitted and distributed over networks.
The program instructions recorded on the media may be those specially designed and constructed, or they may be of the kind well-known and available to those of ordinary skill in the computer software arts. Examples of the program instructions not only include machine codes that are made by compilers but also computer-executable high level language codes that may be executed by using an interpreter.
The particular implementations shown and described herein are illustrative examples of the embodiments and are not intended to otherwise limit the scope of the inventive concept in any way. For the sake of brevity, conventional electronics, control systems, software development and other functional aspects of the systems may not be described in detail. Furthermore, the connecting lines, or connectors shown in the various figures presented are intended to represent exemplary functional relationships and/or physical or logical couplings between the various elements. It should be noted that many alternative or additional functional relationships, physical connections or logical connections may be present in a practical device. Moreover, no item or component is essential to the practice of embodiments unless the element is specifically described as “essential” or “critical.”
While one or more exemplary embodiments have been described with reference to the figures, it will be understood by those of ordinary skill in the art that various changes in form and details may be made therein without departing from the spirit and scope of the inventive concept as defined by the following claims.
Number | Date | Country | Kind |
---|---|---|---|
10-2015-0177369 | Dec 2015 | KR | national |
Number | Name | Date | Kind |
---|---|---|---|
9333652 | Hu | May 2016 | B2 |
20040249809 | Ramani et al. | Dec 2004 | A1 |
20150169979 | Ko et al. | Jun 2015 | A1 |
20150251315 | Brandenberger | Sep 2015 | A1 |
20160207198 | Willfor | Jul 2016 | A1 |
20170072850 | Curtis | Mar 2017 | A1 |
Number | Date | Country |
---|---|---|
10-2010-0070582 | Jun 2010 | KR |
10-2015-0071781 | Jun 2015 | KR |
Number | Date | Country | |
---|---|---|---|
20170169288 A1 | Jun 2017 | US |