The present application claims priority from Japanese patent application JP2014-96462 filed on May 8, 2014, the content of which is hereby incorporated by reference into this application.
In order for a robot to autonomously move through a space and perform a certain specific task, the robot needs to estimate its own position with respect to the surrounding environment. One known estimation method is to match a shape of the surrounding environment measured using a distance sensor mounted on the robot with an environment map prepared in advance.
Further, in Japanese Patent No. 5452442, there is disclosed a method in which, in order to continue an operation of the robot even when there is a region in which an arrangement or a shape of the objects in the space changes over time, the robot automatically updates an environment map based on a set region to be updated.
The map updating method described in Japanese Patent No. 5452442 is based on the assumption that the robot is capable of frequently measuring a completely still object in a region that is not to be updated. When the region to be updated is extensive and the measurement range of the distance sensor for that region is narrow, the updating of the map is carried out without measuring a completely still object for long periods, which can lead to a distorted map being produced for that region. Consequently, there has been a problem in that when the robot moves from a region in which movable objects are dominant into a region in which completely still objects are dominant, a phenomenon occurs in which an own-position estimation result momentarily changes dramatically, which can prevent the robot from operating normally.
Therefore, there is a need for a robot capable of obtaining a seamless own-position estimation result even when a robot moves back and forth between a region in which movable objects are dominant and a region in which completely still objects are dominant.
A representative example of this invention is a robot, including: a measurement unit configured to measure an object in a space; a storage unit configured to store map data representing information about the object in the space determined in advance; an own-position estimation unit configured to calculate an own position of a mobile unit moving through the space by matching measurement data acquired by the measurement unit with the map data; a classification unit configured to acquire class-based measurement data obtained by classifying the measurement data into at least two predetermined classes; a class-based own-position estimation unit configured to estimate an own position of the mobile unit for each of the at least two predetermined classes by matching a class-based map having a position of the objects recorded therein for each class with the class-based measurement data; an integration unit configured to integrate the own positions estimated for the respective at least two predetermined classes; and a control unit configured to control the mobile unit based on information from the integration unit.
According to one embodiment of this invention, a seamless own-position estimation result can be obtained.
First Embodiment
Embodiments of this invention are described below with reference to the drawings. In the following embodiments, a procedure operated by a mobile robot equipped with a manipulator is described.
Further, the robot includes class-based own-position estimation units 104, each of which is configured to estimate an own position by preparing in advance for each class a class-based map 103 representing position information about objects, and geometrically matching the class-based measurement data 102 with the map 103 corresponding to that class.
In addition, the robot includes an integration unit 107 configured to determine an own position of the robot by converting each estimated class-based own position 105 into a predetermined common coordinate system by adding a coordinate conversion amount 106 obtained from a comparative positional relationship among each of the maps, and integrating each of the class-based own positions.
The own position obtained by the integration unit 107 is stored in an own-position storage unit 108. A control unit 109 autonomously moves the robot by reading the positions of surrounding objects from a class-based map storage unit, and controlling a mobile unit 110 so that the robot does not collide with the objects in the space. For example, the position of mobile unit 110 corresponds to own position of the robot.
The measurement unit 100 is capable of measuring a predetermined attribute of the objects in the space.
It should be noted that the measurement apparatus of the measurement unit 100 is not limited to a distance sensor employing laser, a camera or sonar may also be used, as long as the measurement apparatus measures the surrounding objects. When a camera is used, the shapes of the objects or a comparative orientation of the measurement unit 100 with respect to the objects can be measured based on marker recognition, image feature extraction, and the like. Further, the measurement unit may include two or more sensors.
The measurement unit 100 simultaneously measures n pieces of data while changing the measurement direction φ by a predetermined angular resolution δφ each time. The measurement direction of an i-th piece of measurement data is represented as φi, and the measured distance is represented as ri. The combination (ri,φi) of distance and direction at this stage is the position of the object to be measured represented in a polar coordinate system with the measurement unit 100 at the center.
It should be noted that the measurement data indicated by the dotted arrows represent the tracks of the laser 201 during measurement, and the end points of the arrows are measurement point positions 300. The thin solid lines represent the objects 200 in a space. The dotted arrows hitting these objects are data that has been successfully measured. The laser beams that do not hit a thin solid line indicate that no measurements could be made. The thick solid lines 301 represent the ultimately measured shapes 301. The conversion from the position (ri,φi) represented in a polar coordinate system into an orthogonal coordinate system (sxi,syi) with the measurement unit 100 at the origin is carried out based on Expression 1.
sxi=ri cos φi
syi=ri sin φi Expression 1
The classification unit 101 divides the objects into classes based on an attribute of the objects measured by the measurement unit 100.
In the case of searching for a linear shape, when a straight line is fitted to the shapes of the objects obtained by measuring, and a region on the straight line is present in a fixed amount or more, this region is output as a straight line. Further, when there are no other shapes surrounding the measured point, a small column, such as a shelf leg, is obtained by extracting that region.
Further, using the reflection intensity of the measurement target object obtained by the measurement unit 100, the classification unit 101 classifies the measurement data with the brightness value determination unit 401 based on whether or not the reflection intensity value is equal to or more than a threshold. The classification unit 101 outputs the classification results obtained by these processes with the separation unit 402 as the class-based measurement data 102 that are different to each other. It should be noted that the classification unit 101 may be configured so as to include only any one of the shape matching unit 400 and the brightness value determination unit 401.
It should also be noted that the map coordinate system is not limited to this. The shapes existing in the space are represented as black lines, such as an object 601. The objects represented here are objects measured at a time point in the past, and recorded on the map. Next, an example of the representation of the lattice is described. An empty cell 602 represents that there is nothing in the space in the corresponding region. Further, an occupied cell 603 represents that an object exists in that cell. Whether or not an object exists is represented as an existence probability of the object in the form of a multivalue probability described below.
In this embodiment, the shape of an object in the space is represented on the map as an existence probability of the object. In the map, information about the object is recorded based on a vote value, which is converted into an existence probability during reading. First, the probability of an object existing for the value m(x,y) of the lattice cell at the coordinates (x,y) of the map coordinate system is p(m(x,y)). Here, p(m) is defined as in Expression 2 based on a sigmoidal function according to the value of the vote value.
Here, whether or not an object exists is determined from the value of p(m(x,y)) based on, for example, a comparison result with a parameter. Further, the probability p(m(x,y)) is calculated from the value of the vote value m(x,y) stored for each cell. The representational method of these maps is not limited to the example described above. Another method may be used, as long as such method is capable of recording the measured shapes. The maps according to this embodiment are provided in advance, and may be created using map generation technology (simultaneous localization and mapping) and the like.
txi=sxi cos θ−syi sin θ+x
tyi=sxi sin θ+syi cos θ+y Expression 3
The map coordinate system is determined as a linear transformation from the coordinate system of the measurement unit 100. The optimum position (x*,y*,θ*) when the result obtained by converting into the map coordinate system is geometrically adjusted to the map is determined as shown in Expression 4. Expression 4 can be solved by a search method such as a method of steepest descent by plugging in an initial value close to the optimum solution in advance.
x=x*+px
y=x*+py
θ=θ*+pθ Expression 5
In addition, the integration unit 107 determines the own position of the robot by taking a weighted average with an own-position calculation unit 801 of each of the own-position estimation results converted into one coordinate system using a weighting recorded in a weighting table 800, and stores the determined own position in the own-position storage unit 108.
The robot may also set a predetermined priority for each class, and use an own position estimated based on a class having a high priority. When the robot is moving through the environment, it is desirable if the objects to be preferentially utilized when estimating the own position can be changed based on the location and situation.
Consequently, as illustrated in
In addition, when the robot grips an article on the shelf, a detailed position of the gripping target is necessary. However, because the precise position of the gripping target is unknown, it is difficult to grasp the target article based only on the own position of the robot and articular angle information. Therefore, the interior of the shelf is measured with a distance sensor mounted on the robot's fingers. In the movement mode when grasping the article on the shelf, the weighting of the own position relating to the comparative orientation with the gripping target article obtained from the shape of the shelf interior is increased, and the weighting obtained from the own position of the robot and the articulated angle information is decreased. As a result, the target article can be precisely gripped.
According to the first embodiment of this invention, a seamless own-position estimation result can be obtained even when a robot moves back and forth between a region in which movable objects are dominant and a region in which completely still objects are dominant, by appropriately integrating class-based own-position estimation results obtained from measurement data divided into classes, such as movable objects and completely still objects, with the use of weighting based on the existence ratio and the like.
Second Embodiment
In this embodiment, the movement procedure of a low-profile robot configured to lift up and carry a shelf is described.
In the update, the vote value m(x,y) stored for the coordinates corresponding to the position where the object is measured is increased or decreased. This allows the existence probability of an object at that position to be increased or decreased. The position (tx,ty) of the lattice map is determined based on Expressions 6 and 7 from the measured shape and the position of the measurement unit 100 at the measurement time point. Parameters α and β relating to the update degree at this time are set by inputting for each class a predetermined value into an update degree table 1300 in advance.
m(tx,ty)←m(tx,ty)+α Expression 6
m(tx,ty)←m(tx,ty)−β Expression 7
Further, when using a camera instead of a distance sensor, the comparative relationship between the position of the low-profile robot and the shelf position may be recognized by observing a marker placed on a lower surface of the shelf. In the area where the robot is under the shelf, by selecting a weighting table in which the weighting of the comparative relationship with the shelf obtained by the camera is high and the weighting of the own-position estimation result obtained by the distance sensor is low, the low-profile robot can obtain a precise own-position estimation directly under the shelf.
Further, when following another robot 1900, a target robot 1900 can be followed by increasing the weighting of the robot to be followed, and issuing a control to the mobile unit to follow that robot 1900.
Third Embodiment
The specific integration processing is carried out by, using the class-based own positions 105 and the coordinate conversion amount 106 in the same manner as in
This invention is not limited to the above-described embodiments but includes various modifications. The above-described embodiments are explained in details for better understanding of this invention and are not limited to those including all the configurations described above. A part of the configuration of one embodiment may be replaced with that of another embodiment; the configuration of one embodiment may be incorporated to the configuration of another embodiment. A part of the configuration of each embodiment may be added, deleted, or replaced by that of a different configuration.
The above-described configurations, functions, and processors, for all or a part of them, may be implemented by hardware: for example, by designing an integrated circuit. The above-described configurations and functions may be implemented by software, which means that a processor interprets and executes programs providing the functions. The information of programs, tables, and files to implement the functions may be stored in a storage device such as a memory, a hard disk drive, or an SSD (Solid State Drive), or a storage medium such as an IC card, or an SD card.
The drawings shows control lines and information lines as considered necessary for explanations but do not show all control lines or information lines in the products. It can be considered that almost of all components are actually interconnected.
Number | Date | Country | Kind |
---|---|---|---|
2014-096462 | May 2014 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
7689321 | Karlsson | Mar 2010 | B2 |
8798840 | Fong | Aug 2014 | B2 |
20040167669 | Karlsson | Aug 2004 | A1 |
20040230340 | Fukuchi | Nov 2004 | A1 |
20050187678 | Myeong | Aug 2005 | A1 |
20070100498 | Matsumoto | May 2007 | A1 |
20070156286 | Yamauchi | Jul 2007 | A1 |
20090326713 | Moriya | Dec 2009 | A1 |
20100094460 | Choi et al. | Apr 2010 | A1 |
20110010033 | Asahara | Jan 2011 | A1 |
Number | Date | Country |
---|---|---|
101000507 | Jul 2007 | CN |
101509781 | Aug 2009 | CN |
102538779 | Jul 2012 | CN |
5452442 | Mar 2014 | JP |
Entry |
---|
Chinese Office Action issued in counterpart Chinese Application No. 201510212751.4 dated Jun. 29, 2017 with partial English translation (16 pages). |
Wei, “Design and implementation of panoramic vision system for RoboCup medium-sized robots”, Chinese Doctoral Dissertations & Master's Theses Full-text Database (Master) Information Science and Technology, the 3rd phase, 2006, pp. 33-47 with English translation (30 pages). |
Number | Date | Country | |
---|---|---|---|
20150321346 A1 | Nov 2015 | US |