The present invention relates to a route creation method and a route creation device which create the travel route of a traveling part to be moved by the operation of joints in a robot having a plurality of joints.
A route creation method and route creation device is known which probabilistically generate an intermediate point between an initial position and a final position, and creates the travel route of a robot by using the intermediate point (for example, Japanese Unexamined Patent Application Publication No. 2006-048372). In this route creation method and route creation device, a route is created so as to linearly connect the initial position and the final position to the intermediate point, it is determined whether or not a robot has collided against an obstacle when the robot has moved by a unit length in the route on the final position side, and it is determined whether or not the robot has collided against an obstacle when the robot has moved by a unit length in the route on the initial position side. When it is determined that the robot has not collided against an obstacle, a route is decided for the unit length of each of the routes on the final position side and the initial position side. Meanwhile, when it is determined that the robot has collided against an obstacle, an intermediate point is generated again to create a new route. This decision of a route for a unit length is repeatedly performed, and when the route on the initial position side and the route on the final position side are linked with each other, the entire route is used as the travel route of the robot.
In the above-described route creation method and route creation device, the intermediate point is probabilistically generated without taking the efficiency of the travel quantity of the robot into consideration, the route is created while only determining whether or not the robot does not collide against an obstacle, and if one travel route is found, subsequent route creation is not performed. Accordingly, when the robot has traveled along the relevant travel route, the travel quantity may increase, which may make it difficult to achieve efficient travel.
The invention has been finalized in order to solve such problems, and it is an object of the invention to provide a route creation method and a route creation device capable of creating a travel route which reduces the travel quantity of a robot and achieves the efficient travel of the robot.
An aspect of the invention provides a route creation method of creating a travel route of a traveling part to be moved by the operation of joints in a robot having a plurality of joints. The route creation method includes the steps of generating an intermediate point between the initial position and the final position of the travel route and creating a plurality of candidate routes as candidates for the travel route between the initial position and the final position with the intermediate point as a target, and evaluating the travel quantity of the traveling part of the robot with respect to each candidate route to select one travel route.
Another aspect of the invention provides a route creation device for creating a travel route of a traveling part to be moved by the operation of joints in a robot having a plurality of joints. The route creation device includes a candidate route creation unit generating an intermediate point between the initial position and the final position of the travel route and creating a plurality of candidate routes as candidates for the travel route between the initial position and the final position with the intermediate point as a target, and a travel quantity evaluation unit evaluating the travel quantity of the traveling part of the robot with respect to each candidate route to select one travel route.
With the route creation method and route creation device, a plurality of candidate routes can be created by using the generated intermediate point, and thereafter the travel quantity of the traveling part of the robot can be evaluated with respect to each candidate route to select a candidate route, which achieves the most efficient travel, as the travel route. Therefore, a travel route can be created which reduces the travel quantity of the traveling part of the robot and achieves the efficient travel of the robot.
In the route creation method, when a plurality of candidate routes are created, a partial route of a previously created candidate route may be used. In the route creation device, the candidate route creation unit may create a plurality of candidate routes by using a partial route of a previously created candidate route. With this configuration, a route can be newly created while using a previously created candidate route, and thus, a plurality of candidate route can be efficiently created.
In the route creation method, when the travel quantity of the traveling part of the robot is evaluated with respect to each candidate route, a work space where the robot is actually present may be defined, the travel quantity of the traveling part when having traveled along each candidate route may be converted into a travel quantity in the work space, and the converted travel quantity may be evaluated. In the route creation device, the travel quantity evaluation unit may define a work space where the robot is actually present, may convert the travel quantity of the traveling part when having traveled along each candidate route into a travel quantity in the work space, and may evaluate the converted travel quantity. With this configuration, the travel quantity of the traveling part of the robot when having traveled along the created candidate route can be converted into the travel quantity of the traveling part of the robot in the work space, and the converted travel quantity can be evaluated. Therefore, a travel route can be created which achieves the most efficient travel of the robot in the actual space.
According to the invention, a travel route can be created which reduces the travel quantity of the robot and achieves the efficient travel of the robot.
Hereinafter, an embodiment of a route creation method and a route creation device of the invention will be described. First,
The route creation means 2 has start/goal position decision means (unit) 5 which finally decides the start position (initial position) and the goal position (final position) of the travel route, candidate route creation means (unit) 6 which sets (temporarily sets) an intermediate point between the start position and the goal position to create a plurality of candidate routes, travel quantity evaluation means (unit) 7 which evaluates the travel quantity of the traveling part of the robot with respect to each created candidate route to select one travel route, and information storage means (unit) 8 which stores input information from the information input means 3. The start/goal position decision means 5, the candidate route creation means 6, and the travel quantity evaluation means 7 are implemented by a program stored in a hard disk or a ROM, and a CPU executing the program. The information storage means 8 is specifically a hard disk, a RAM, or the like.
The information input means 3 is means for inputting joint angle information of the initial posture and the target posture of the robot having a plurality of joints, information regarding obstacles around the robot, and a set value about the number of candidate routes as candidates for the travel route. The information input means 3 is formed by an information acquisition device, such as a camera, various kinds of sensors, or the like, a keyboard, or an optical disk drive in which data is stored in advance. The route output means 4 is specifically a driver or the like which operates the actuator of the robot.
In this embodiment, an example where a robot having a plurality of joints is a robot arm will be described.
If the angle of each articular joint 102 is known, the state of the robot arm 100, that is, the posture of the robot arm 100 can be grasped. Here, if a multidimensional coordinate space (in this example, a three-dimensional coordinate space) is set with the angles θ1, θ2, and θ3 at three articular joints 102 in
When the x and y coordinate axes are set with respect to the work space, the coordinate (x,y) of the wrist position X representing the posture of the robot arm 100 can be easily obtained by converting the coordinate (θ1,θ2,θ3) on the multidimensional coordinate space. In this example, although the state (posture) of the robot arm 100 is expressed by the three-dimensional coordinate, the state (posture) of the robot arm 100 may be expressed in a two-dimensional coordinate space or a multidimensional coordinate space. For example, in the case of a robot arm having seven articular joints 102, the state (posture) of the robot arm may be expressed as one point in a seven-dimensional coordinate space. In the case of a robot arm having three articular joints and one extendable portion, the state (posture) of the robot arm may be expressed as one point in a four-dimensional coordinate space.
Next, a process of the route creation device 1 which executes the route creation method of this embodiment will be described.
As shown in
Next, an operator sets the start position and the goal position of the travel route on the work space. If these positions are preset in advance, the operator does not need to input the positions. The operator may operate a keyboard to input the coordinate positions so as to set the start and goal positions. Alternatively, the robot arm 100 may be connected to the information input means 3 to read the coordinates when the robot arm 100 is actually positioned at the start and goal positions. Further, external environment information may be automatically or semi-automatically acquired by a camera or various kinds of sensors provided in the device.
In this case, a plurality of goal positions may be set. Although the description has been made for the robot arm 100, the number of postures (wrist position X) of the robot arm 100 there are when gripping an object at the final position is taken into consideration. The robot may grip the object from the above or grasp the object from the right/left side. A plurality of goal positions are set in advance taking such variation into consideration. With regard to an automatic machine other than the robot arm, there are many cases where the manner of gripping at the goal position varies, so in these cases, a plurality of goal positions are set. In this embodiment, description will be provided for a case where one goal position is set.
The start/goal position decision means 5 compares the input start and goal positions with information stored in the information storage means 8 to determine whether or not the input start and goal positions do not interfere with an obstacle, and when the start and goal positions do not interfere with the obstacle, the input start and goal positions are decided as the start and goal positions (S205). The verification of the presence/absence of interference will be described below in detail. When the input start and goal positions interfere with an obstacle, the goal position which interferes with the obstacle is deleted or the like, if necessary, the operator is requested to again input the goal position, and the same determination is made for the newly input start/goal position. This procedure is repeatedly performed until the start/goal position is determined.
The decided start and goal positions on the work space are converted into the start and goal positions in the multidimensional coordinate space. For convenience of explanation, description will be made assuming that the multidimensional coordinate space is a two-dimensional coordinate space θx-θy. This corresponds to a case where robot arm has two articular joints 102. Here, the start position S and the goal position G are set in the two-dimensional coordinate space θx-θy (see
Next, the procedure of the candidate route creation process (S210) when a first candidate route is created will be described with reference to
As described above, although a suitable one of a plurality of candidate intermediate points m1 is set as the intermediate point M1, the degree of manipulability is calculated for all the candidate intermediate points m1, a candidate intermediate point m1 with the highest degree of manipulability, that is, with the best manipulability is used as the intermediate point M1 (see
In this way, the start position S, the intermediate point M1, and the goal position G are decided/selected, and the start position S—the intermediate point M1 and the intermediate point M1—the goal position G are connected to each other in the two-dimensional coordinate space θx-θy at the shortest distance (the distance on the two-dimensional coordinate space θx-θy regarding the articular joint 102). With regard to the distances on the work space and the multidimensional coordinate space, any distance function may be used insofar as it can define the distance. For example, the Euclidean distance function or the like may be used. Then, a line segment on the goal position G side, that is, a predetermined length from the goal position G with respect to a vector B1 is cut on the two-dimensional coordinate space θx-θy (see
Specifically, the vector B1 is divided into minute sections (see
With regard to the vectors B1 and B2 for the predetermined length on the goal position G side and the start position S side, if there is no collision, the collision determination is performed for an additional predetermined length with the intermediate point M1 remains as it is, or with the vector B1 as it is when the vector B1 and the start position S are connected to each other (S355—no). Meanwhile, if a route is created while the collision determination is performed, it may be determined that the route being created interferes with the obstacle on the work space. When it is determined during the collision determination that there is a collision along the predetermined length, the intermediate point Mi is discarded for the predetermined length, and a new intermediate point Mi is set, Thereafter, the same candidate route creation is continued by using the new intermediate point Mi (S325, S345—no).
Hereinafter, an example where the new intermediate point M2 needs to be set by the collision determination during the candidate route creation for a second predetermined length by the intermediate point M1 will be described. When the new intermediate point M2 is set, a plurality of candidate intermediate points m2 are randomly set on the two-dimensional coordinate space θx-θy (see
After the candidate intermediate point m2 with the best manipulability from a plurality of candidate intermediate points m2 is used as the intermediate point M2, one, which is at a distance closest to the intermediate point M2 in the work space, of the goal position G and a point G′ on the candidate route created from the goal position G is selected for the use in the route creation (see
With regard to the start side when the route planning is performed by using the intermediate point M2, candidate route creation is performed by using one, which is at a distance closest to the intermediate point M2, of the start position S and a point S′ set in advance from the start position S (see
Returning to
Next, creation of a second travel route will be described with reference to
With regard to the start side, candidate route creation is performed from one, which is at a distance closest to the intermediate point M1, of the start position S and the intermediate points S1, S2, S3, and S4 (S340). Here, the intermediate point S1 is selected (see
Thereafter, similarly, the collision determination and the candidate route decision for a predetermined length are repeatedly performed on the goal side and the start side (S325, S330, S345, and S350), and finally, if the route on the start position S side and the candidate route on the goal position G side are joined together, the second candidate route L2 is decided (see
The candidate route creation process is repeatedly performed until the counter i reaches the set value n (=4), so candidate routes L3 and L4 are created on the two-dimensional coordinate space θx-θy (see
Returning to
After the travel quantity has been calculated for all the candidate routes, the travel quantities are evaluated and compared with each other (S230), and a candidate route which can have the smallest travel quantity and achieve efficient travel is decided as a travel route that should be used (S235). S225 to S235 are executed by the travel quantity evaluation means 7. The route output means 4 converts the selected travel route into a signal for an actuator and outputs the converted signal to the actuator of each articular joint 102 of the robot arm 100. Thus, the joints of the robot arm 100 are operated along the relevant travel route to move the wrist position X.
As described above, according to the route creation method of this embodiment, a plurality of candidate routes can be created by using the generated intermediate point, and thereafter the travel quantity of the wrist position X of the robot arm 100 can be evaluated with respect to each candidate route to select a candidate route, which achieves the most efficient travel of the wrist position X of the robot arm 100, as a travel route. Therefore, a travel route can be created which reduces the travel quantity of the wrist position X of the robot arm 100 and achieves the efficient travel of the wrist position X of the robot arm 100.
According to the route creation method of this embodiment, a candidate route can be newly created by using the partial route of the previously created candidate route. Therefore, a plurality of candidate routes can be efficiently created.
According to the route creation method of this embodiment, the travel quantity of the robot arm 100 when having traveled along the created candidate route can be converted into the travel quantity of the wrist position X of the robot arm 100 in the work space, and the converted travel quantity can be evaluated. Therefore, a travel route can be created which achieves the most efficient travel of the robot arm 100 in the actual space.
The invention is not limited to the above-described embodiment.
For example, when a plurality of goal positions are set and one goal position selected (S320), a goal position which is at a distance closest to the intermediate point from the goal positions may be selected.
The articular joint 102 of the robot arm 100 may be rotated or may be moved straight.
Industrial Applicability
The invention can create a travel route which reduces the travel quantity of the robot and achieves the efficient travel of the robot.
Number | Date | Country | Kind |
---|---|---|---|
2007-107368 | Apr 2007 | JP | national |
This is a Continuation application PCT/JP2008/057793 filed on Apr. 16, 2008.
Number | Name | Date | Kind |
---|---|---|---|
6249718 | Gilliland et al. | Jun 2001 | B1 |
7024276 | Ito | Apr 2006 | B2 |
7110859 | Shibata et al. | Sep 2006 | B2 |
7130718 | Gunnarsson et al. | Oct 2006 | B2 |
7298385 | Kazi et al. | Nov 2007 | B2 |
7457698 | Danko | Nov 2008 | B2 |
Number | Date | Country |
---|---|---|
A-1-289684 | Nov 1989 | JP |
A-1-315802 | Dec 1989 | JP |
A-5-250023 | Sep 1993 | JP |
A-7-141016 | Jun 1995 | JP |
A-7-225612 | Aug 1995 | JP |
A-7-253809 | Oct 1995 | JP |
A-8-118202 | May 1996 | JP |
A-10-249761 | Sep 1998 | JP |
A-2002-301674 | Oct 2002 | JP |
A-2003-103481 | Apr 2003 | JP |
A-2005-309990 | Nov 2005 | JP |
A-2006-48372 | Feb 2006 | JP |
A-2006-155559 | Jun 2006 | JP |
Number | Date | Country | |
---|---|---|---|
20100023164 A1 | Jan 2010 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/JP2008/057793 | Apr 2008 | US |
Child | 12572820 | US |