This invention is related to the problem of mapping an operation area for a mobile robot.
Mobile robots have gradually been deployed into our everyday lives. Entertainment robots, floor-cleaning robots, security guard robots, and others have been made commercially available. Human-type robots (humanoids) are demonstrating reliable running motion in research laboratories in Japan (for instance, a patent WO/2006/062948 discloses technology on a legged robot). Extensive attempts have been made to make those autonomous robots understand their surroundings.
Patents WO/2006/046053, WO/2006/046049, and WO/2006/046044 discuss methods of cleaning a flooring surface with a dedicated hardware system. However, they do not mention how the robot recognizes its surroundings.
Another patent WO/2005/092632 discloses a method for a mobile robot to navigate using two-dimensional barcodes which are formed at predetermined intervals on a floor. However, installing the extra-hardware on the floor is expensive and time-consuming for users.
Another patent WO/2005/098476 discloses a method for an autonomous mobile robot to estimate its position using optical emitters and optical sensors to detect their reflected light. However, the use of the light source makes the application of this robot expensive and limits its application possibilities.
Other patents WO/99/59042 and WO/2000/043186 disclose methods for a mobile robot to systematically cover an area by pasting boundary markers and by sensing the area edges. The use of special markers makes the system expensive and installation tedious, and limits its application areas.
Other patents WO/2005/081074, WO/2005/006098, and WO/1999/028800 disclose methods for a mobile robot to dock to a base station. This method helps the robot to understand the geometrical relations around the base station, but the robot's understanding of the whole operation area cannot be expected.
Another patent WO/2001/038945 discloses a method of mapping surroundings using multiple mobile robots. However, if there is a method using only one robot would be much more useful.
Another invention U.S. Pat. No. 6,009,359 describes methods of mobile mapping to generate a geometrically precise three-dimensional detailed model of an unknown indoor environment. However, how to avoid odometry errors on a mobile robot is not specifically described.
Still another invention U.S. Pat. No. 6,965,209 discloses a method for a robot to confine to a particular space by using a portable barrier signal transmitter. However, obviously, a method that does not use such a hardware piece is preferred.
Patent disclosures WO/88/004081 and U.S. Pat. No. 4,821,192, describe a mobile robot navigation method using a node map. The node map is pre-designed by a human and given to the robot as data. What advantages can be expected by using this node map in not clearly addressed.
Traditionally, the Simultaneous Localization And Mapping (SLAM) approach has been pursued in the robotics research community for the purpose of mapping an unknown operation area. In this approach, a self-contained autonomous mobile robot is supposed to explore and map unknown surroundings by itself.
A patent disclosure WO/2004/059900 describes a SLAM method using image sensors. Another patent WO/2001/078951 discloses a method for a mobile robot to find a semi-optimal path to a given goal in a wholly unknown, unpredictable and partly, dynamic large-scale environment. Another patent U.S. Pat. No. 7,015,831, describes methods of generating and updating a map with a visual sensor and the SLAM technology.
Limitations of the SLAM approach are as follows: (1) The precision of the map obtained is limited because of the mobile robot's poor odometry capability (“odometry” is the function of a mobile robot that estimates its own robot frame ((x, y), θ) by accumulating the robot's incremental movement at each sampling time). (2) The robot loses its positional identification in a complex operation area because of odometry errors, and hence, autonomous mapping of a complex operation area becomes very difficult. (3) Furthermore, this approach lacks a fundamental consideration in the mapping problem: Depending on situations, a robot may have to deal with multiple operation areas in given surroundings. The robot is never able to know these distinct operation areas autonomously without humans' instruction.
An algorithm for a mobile robot to track a linear or circular path using the curvature is disclosed in U.S. Pat. No. 6,134,486. This algorithm is useful if v≠0, and hence, the curvature is defined. However, in this present invention, the condition (v≠0) is not guaranteed. Therefore, the present invention does not adopt this prior invention.
An algorithm for recording a manually driven vehicle's motion is disclosed in a patent U.S. Pat. No. 6,314,341. In this prior patent, the robot's motion is generated by human's physical force while the motors' power is off. This motion-generation means is not useful enough in case the robot is too heavy for a human to move around.
The problem to be solved in the present patent is for a mobile robot to map of an operation area A. This problem is further divided into the following three sub-problems:
Before describing the solution methods, we need to introduce definitions on (1) 2-DOF motion and 2-DOF motion command, and (2) graphs and maps.
Definitions on 2-DOF Motion and 2-DOF Motion Command: Consider a two-dimensional rigid body mobile robot 1 in a plane, where the global Cartesian frame (coordinate system) 2 is defined, as shown in
M=(v, μ, ω), (EQ. 1)
where v7 is the “translation speed,” μ8 the “translation direction” in the robot frame, and ω=dθ/dt9 the “rotation speed” in the global frame, as shown in
If the robot's motion capacity is limited so that the translation direction is always equal to the robot's body direction θ, or μ=0, the motion described in (EQ. 1) becomes
M=(v, 0, ω) (EQ. 2)
Because this motion has only two variables, v and ω, we call it a “two degrees of freedom” motion or “2-DOF” motion. The motion capacity of conventional vehicles, such as automobiles, bicycles, tricycles, and differential-drive vehicles is under this limitation. These vehicles cannot move sideways. When there is no ambiguity, a 2-DOF motion might be represented as M=(v, ω).
To map an operation area, a human guides a robot in the area. For that mission, the use of restricted 2-DOF motion is actually better than 3-DOF motion. The reasons are as follows: (1) The robot direction is aligned to the edge direction in the graph; hence, the sensors mounted on the left/right side of the robot can aim straight at side objects. This positioning of the robot is the best for the geometrical-feature-detection function. (2) The number of human-detecting sensors can be minimized because the robot always heads to the human. (3) In the human-tracking session, the robot turns to the human when the robot properly recognizes human. The human confirms that the robot is functioning appropriately and feels comfortable with this robot's responsiveness. (4) The required output of two variables from the human-detecting sensor system simplifies the system.
Even if a mobile robot has the 3-DOF motion capacity, there is no advantage to using 3-DOF motion for this human-guided mapping purpose. Therefore, the present invention can be applied to every mobile robot.
For a robot to track a human, sensors must detect human's action and return data so that the robot can execute an appropriate tracking motion. Because the motion has only 2-DOF, the sensor only needs generate “2-DOF motion command” CM:
CM=(cv, cω), (EQ. 3)
where, cv is a variable for controlling translation-speed v and cω a variable for controlling rotation-speed ω (
Definitions on Graphs and Maps: An extensive use of a graph to represent an operation area is another feature of the present invention. A graph G is a pair (V, E), where Vis a set of “vertices” and E a set of “edges.” A vertex is associated with a position (x, y) in the given operation area in the global frame. An edge is a pair (P, Q) of two distinct vertices, P and Q. The two vertices are called its “ends” of the edge. If (P, Q) is an edge, so is (Q, P. A sequence of vertices, H=(P0, P1, . . . , Pn) (n≧1) is called a “path,” if (Pk, Pk+1) is an edge for k=0, . . . , n−1. A path His called a “cycle” if P0=Pn and n≧2. A cycle is said to be “simple” if all vertices in the sequence are distinct except the last vertex.
The edges in a cycle H encircle a finite area. That area is called the “closed area” of H. Two distinct simple cycles in a graph G are said to be “independent” if those closed areas have no intersection. If an edge belongs to two independent cycles, it is called an “inside edge”; otherwise, it is called a “boundary edge.” A vertex P is called a “boundary vertex” if there is at least one boundary edge that has P as one of the ends. A vertex that is not a boundary vertex is called an “inside vertex.”
All boundary edges in a graph form a cycle, a “boundary cycle,” Hb. There are more than one boundary cycle in any graph. There are numerous ways to traverse all vertices and all edges in a given G. The selection of a traversing path is totally left to the human's discretion. However, it is generally recommended to traverse a boundary cycle in G first. The edges and vertices left out of the boundary cycle will be traversed later. In that case, the boundary vertex positions will work as landmarks in determining other vertex positions.
The present invention proposes, given an operation area A, that first a human defines a graph
G=G(A)=(V, E), (EQ. 4)
which is embedded in A, where V is the set of vertices and E the set of edges. This graph G should appropriately represent the geometrical features of the operation area A. The final output of the mapping session is a map file Z:
Z=Z(G)=Z(G(A))=(RV, RE), (EQ. 5)
where Rv is the set of vertex records for V and RE the set of edge records for E. These two record sets are incrementally created during the mapping session. The set of vertex records and the set of edge records form the map of G (and area A). This data is compact and well organized because it is based on the graph structure.
Data structure of a vertex record: A vertex record includes a vertex number, an anchor, a position in the global frame, and a name (string). Each vertex has a unique vertex number n (=0, 1, 2, . . . ) in the order of creation. The n-th vertex may be referred as vertex(n). An anchor is a vertex number m, where this vertex has been localized based on the position of vertex(m). When the record of a vertex is newly created, its anchor is defined as ∞; it means that the position is based on nothing. Only exception is vertex(0); its anchor is defined as 0. A vertex with an anchor of ∞ is said to be “anchor-less”; otherwise it is “anchored.” As the mapping session proceeds, the position and anchor in a vertex record are modified by the localization task 206. At the end of a mapping session, the anchor of all vertices becomes 0. Every vertex name is provided by the human. The set of all vertex names is common symbolic knowledge shared by humans/robot, which enables intelligent and efficient human-robot communication.
Data structure of an edge record: An edge record includes an edge number, two end-vertex numbers, a distance, and geometrical features on both sides. The distance is the Euclidean distance between the two end positions.
Examples of Operation Areas and Their Graphs: Let us present three examples of operation areas and their graphs.
As shown in
Operation area A2 120 can be represented by a graph G2 121, as shown in
G2 121 has two independent cycles, (A, B, C, D, G, A) 122 and (G, D, E, F, G) 123, which share an edge, (D, G) 124, which is the only inside edge in G2. Using all boundary edges, a boundary cycle can be formed as: H2b=(A, B, C, D, E, F, G, A), in which the inside edge (D, G) is not included.
Operation area A3 130 can be represented by a graph G3 131 as shown in
Features of the Solution Method: A human defines a graph G that is embedded in and represents the given operation area A. All the mapping tasks are based on this graph G. The novel concept in the present invention is that a human is deeply committed to the problem solving to this degree. It is very difficult for a robot to understand the geometric relations of an operation area. Since a graph can have any complexity, this method can deal with an operation area of any complexity.
In the same surroundings, a human may want to teach a robot two or more distinct operation areas using the present invention. For instance, two distinct cleaning areas in an office for a vacuum robot can be named as “weekday” and “weekend.” The set of names of maps (operation areas) becomes the common symbolic knowledge shared by humans and the robot, serving as an intelligent and efficient interface. This is one of the major advantages of the present invention.
Human-Guided Mapping Method 200: The top-level algorithm of the present invention is shown as Flowchart 200 in
Task 201: A human defines a graph G that represents the given operation area A; this is the starting point. All the vertices and edges in G must be placed inside the operation area. This graph G should represent A in an optimal manner. Generally, vertices are assigned to T-intersections, cross intersections, L-intersections, dead-end points, and boundary points, because these positions have distinct geometrical importance. For two vertices, an edge is assigned if the human wants the mobile robot to move along the straight segment between them in the forthcoming task execution sessions.
Task 202: At this initial state, the mobile robot is placed a vertex, which is defined as the “home” of G. As the initialization of the mapping function, the vertex record vertex(0, 0, p, name) of this home is created with the number of 0, the anchor of 0, the robot position p, and name that is provided by the human.
Task 203: The human moves forward along an edge and stops at a vertex, while the robot tracks the human. The decision on the path selection is done by the human. The precision of the map depends on this path selection. This task execution by the human-robot team ends at the next vertex, one end of this edge. The details of this task 203 are described below.
Task 204: The vertex where the human-robot team stopped falls in one of two kinds. The team may be stopping at this vertex for the first time; or the team may have visited this vertex before and it came back here again. This information teaches the robot the graph structure.
If the team stops at this vertex for the first time, the human communicates the fact by reporting m=−1, which is not a valid vertex number. If the team has already visited this vertex and has created its record as vertex(m) before, the human communicates the fact by returning that vertex number m (≧0).
Task 205: This vertex is new and a vertex record should be created. The robot asks the human its name, which is provided by the human. The robot creates a vertex record vertex(nv, ∞, p, name), with nv as the vertex number, an anchor of ∞, the current robot position p, and name which is given by the human.
Task 206: Because the robot comes back to an existing vertex(m) again, a new vertex record is not created. Instead, localization procedures for the robot and for vertices are executed. The details of this task are described below.
Task 207: In this case the present vertex is not new, but the last edge may be new. The robot possesses enough information to make this decision. If needed, go to Task 208 for edge-record creation.
Task 208: The robot creates an edge record. The most important information in it is the two vertex numbers of its ends. This information defines the connectivity of G. Side-object geometrical features are valuable too.
Task 209: The human tells the robot if all the edges in G have been traversed or not. Only the human possesses this knowledge.
Task 210: As the last task, the robot outputs the map Z(G) of G, which includes the set RV of vertex records and the set RE of edge records. The former has been accumulated in Tasks 202 and 205, and modified in Task 206; the latter has been accumulated in Task 208. The map Z=(RV, RE) is output with a unique file name. This map is later retrieved by its name.
Task 206: Localizing Robot and Vertices with vertex(m): The robot has just stopped at vertex(m), which had been created before. Through this vertex identification taught by the human, the robot unambiguously understands the connectivity in G. Furthermore, the robot can correct its own position, the positions and anchors of other vertices. First, an “odometry error correction” e is computed (as preparation for vertex localization) and second, the robot position (a part of the robot frame) is localized:
e=(xe, ye)=(xm−x, ym−y), (EQ. 6)
(x,y)=(xm, ym), (EQ. 7)
The reasoning of this localization is that the previous vertex position (xm, ym), which is the robot position then, does not include any potential odometry errors; hence, the old value is considered ‘more correct’ than the present robot position (x, y).
Now we can discuss on the vertex-localization part. Consider the last part of the path H that the team has made:
H=( . . . , vertex(n−3), vertex(n−2), vertex(n−1), vertex(m)) (EQ. 8)
The team was going to create vertex(n), but actually it turns out to be equal to vertex(m) and was not created. We examine this sequence in a reverse order from vertex(n−1) and see which one appears first, vertex(m) itself or an anchored vertex?
(Case I: vertex(m) itself comes first) In this case, the path becomes:
H=(vertex(m), vertex(m+1), . . . , vertex(n−1), vertex(m)), (EQ. 9)
where n≧m+2 and all the vertices except the first/last are anchor-less. This path H is a cycle.
(Case II: an anchored vertex comes first) This case is further divided into two sub-cases. The first sub-case is where vertex(n−1) in (EQ. 8) is actually anchored. In this sub-case, there is no anchor-less vertex in H and the following vertex localization is not necessary. In the other sub-case, the path becomes:
H=(vertex(i), vertex(j), vertex(j+1), . . . , vertex(j+k), vertex(m)), (EQ. 10)
where vertex(i) is anchored, k≧0, and all the vertices in-between are anchor-less.
The vertex localization algorithms for both cases are almost identical, and hence, only the first case is described here:
The number u of the edges in the cycle H in (EQ. 9) is
u=n−m(≧2) (EQ. 11)
With u and the odometry error correction e in (EQ. 6), the correction values for the vertices in this cycle are evaluated as:
0, e/u, 2×e/u, . . . , (u−1)×e/u, e (EQ. 12)
These values are added to the positions of each vertex in H in (EQ. 9). Here 0=(0, 0). Thus, the odometry error accumulated in the traversing of His distributed equally among the vertices in the cycle. Now the anchors of all vertices in H is set to min(m, anchor(vertex(m))), but the anchor of vertex(m) stays.
So far, it was assumed that “inner cycles” in the cycle H do not exist. Now, consider a case where there is an inner cycle HI41 in H40, as illustrated In
The effectiveness and robustness of the localization algorithms are one of the most important features of the present invention. The human plays crucial roles in the localization; otherwise the results at this level could never be attained. How the human-guided mapping algorithm 200 and the localization algorithm 206 work on the prior graph examples?
In GI 111 shown in
In G2 121 shown in
In G3 131 shown in
Human guides robot along an edge 203: The human guides the robot along one edge in this task. The flowchart is shown in
Task 2030: The robot waits until the human starts forward walking.
Task 2031: The robot detects a 2-DOF motion command CM by sensing the human's action as depicted in
Task 2032: Using the motion command CM, the robot controls its 2-DOF motion as depicted in
Task 2033: The robot extracts geometrical features of left/right objects, while traversing this edge. Details of Task 2033 are given below.
Task 2034: The robot waits for the next timer interrupt, and then leaves this program point.
Task 2035: If the human is still moving forward, the robot repeats the previous four tasks again; otherwise exit this task 203.
Detecting Motion Command 2031: While the human traverses an edge, the robot tracks the human. To track the human, the robot detects the human's action through a sensor system. This task 2031 outputs a sensing result, which is a standard interface, a 2-DOF motion command CM=(cv, cω) at each sampling time, as shown in
In
In
With each of the method described above, the human's position (xh, yh) in the robot frame is obtained. The Cartesian coordinates are converted into (dh, ph) in the polar coordinate system using the following standard equation:
(dh, ph)=((xh2+yh2)1/2,a tan2(yh, xh)) (EQ. 13)
where dh is the distance from the robot frame's origin 4 to the human and ph the direction relative to the X-axis direction in the robot frame 4. These polar coordinates are further translated into a 2-DOF motion command as follows:
CM=(cv, cω)=(g0×(dh−DN), g1×ph) (EQ. 14)
Here DN is a “neutral distance” and, g0 and g1 are constant conversion factors. If the human stops while letting the robot track, the robot will eventually stop keeping this neutral distance DN between them (Task 2032 functions in this way). Thus, if these sensors are used in the human-in-front situation, the 2-DOF motion command CM is detected.
(Task 20310 continued): In some situations, the human may want to guide the robot in other positional relations than the front position. In the following two examples, the human positions him or herself to the left side of the robot 1 (other cases can be handled by a similar algorithm). The laser range finder 21 detects the human's “actual position” (xa, ya) 11 in
In this human-left positioning, there exist coordinates (XT, YT) which satisfy the condition that, if the human's actual position (xa, ya)=(XT, YT), the human wants the robot does not move, or equivalently M=(v, ω)=(0, 0). This position can be called a “neutral position” (in this human-left case, YT>0). Using these constants, we convert a human's actual position (xa, ya) into a human's “virtual position” (xh, yh) as follows:
(xh, yh)=(xa−XT+DN, ya−YT) (EQ. 15)
Having these (xh, yh), (EQ. 13) and (EQ. 14) are applied again to obtain the 2-DOF motion command CM for the next task 2032.
(Task 20311) Force-torque sensing method: The human 1 contacts the mobile robot through a force-torque sensor, which detects force and torque applied to the robot by the human. Even though the human applies force and torque to the robot, that does not mean the human forcibly drags, pushes, or turns the robot. The robot senses small force and torque; that information is conveyed to its motion-control algorithm to move its body, which may be heavy.
A force applied toward the robot's body direction tends to increase the robot's translation speed v. A force applied to the robot in the other direction tends to move the robot backward. A counterclockwise torque in the horizontal plane about the vertical axis tends to turn the robot 1 to the left; a clockwise torque tends to turn it to the right.
To embody this concept, “sensor fixtures” are introduced here. As illustrated in
A variation of sensor fixture 34 shown in
The third sensor fixture 36 in
In each sensor-fixture embodiment, a pair (fh, qh) of force and torque is obtained. This pair is converted into a 2-DOF motion command by the following equation:
CM=(cv, cω)=(g2×fh, g3×qh), (EQ. 16)
where g2 and g3 are positive conversion constants. This 2-DOF motion command CM is the output of Task 20311 and becomes an input to Task 2032.
(Task 20312) Force-sensing method: The human's intention on the robot's motion is conveyed through an elastic string 40 depicted in
The horizontal component f42 of the force applied to the robot is detected by the force sensor 41 and is decomposed into two orthogonal components: fx43 in the X-direction and fy44 in the Y-direction in the robot frame 4. These force components are translated into a 2-DOF motion command by the following equation:
CM=(cv, cω)=(g4×fx, gs×fy), (EQ. 17)
where g4 and g5 are positive conversion constants. This 2-DOF command CM is the output of Task 20312 and an input to Task 2032.
(Task 20313) Joystick method: A human communicates with a mobile robot through a joystick, which is not contacting the robot. The X-component xj and Y-component yj of the joystick displacement outputs are transmitted to the robot through a communication channel and are converted into a 2-DOF motion command as follows:
CM=(cv, cω)=(g6×xj, g7×yj), (EQ. 18)
where g6 and g7 are positive conversion constants. Thus, Task 20313 reports a 2-DOF motion command for the next task 2032.
Task 2032: Executing Motion Command: The purpose of this task is to embody the robot's 2-DOF motion given a standardized 2-DOF motion command CM=(cv, cω), which is an output of Task 2031 as shown in
(Task 20320) Translation Speed Control: A typical feedback-control algorithm for translation speed v is the following:
α=α+(−A0×α−A1×v+A2×cv)×dt, (EQ. 19)
v=v+α×dt, (EQ. 20)
where α is the acceleration, dt a sampling time interval, and A0, A1, A2 positive feedback gains. The symbol “=” stands for substitution in the last two equations. Namely, the translation speed is obtained by two integrations. Due to these integrations, the robot's translation speed control is extremely smooth.
This rule moves robot forward if cv>0 (dh>DN in the position-sensing method and fh>0 in the force-control method). In this forward-moving state, we say the human is “pulling” the robot. The robot moves backward if cv<0. In this backward-moving state, we say the human is “pushing” the robot.
If the human stops walking after pulling the robot, the robot eventually stops. However, because of the human's fuzzy stopping and inevitable disturbances of the sensor output, the robot's stopping behavior is not very crisp. Furthermore, the robot tends to oscillates between the push/pull states before it really stops, because the effect of the input cv to speed v in (EQ. 19) and (EQ. 20) is symmetric in both positive and negative regions.
However, in some applications, this symmetric property of translation speed control is undesirable. The human-tracking motion is one of such cases, where backward motion is neither necessary nor useful. The human wants only to pull or to stop the robot. A simple way to embody this requirement is replacing (EQ. 20) by
v=max(v+α×dt, 0) (EQ. 21)
Then the robot never moves backward. Under this rule, when cv becomes negative, the robot eventually stops and is stable.
Likewise, there are some applications, in which only backward motion is desirable. A simple method to embody this requirement is replacing (EQ. 20) by
v=min(v+α×dt, 0 (EQ. 22)
This completes the algorithm description for Task 20320.
(Task 20321) Rotation Speed Control: A typical feedback-control algorithm for rotation speed ω with cω is:
ξ=ξ+(−B0ξ−B1×ω+B2×cω)×dt, (EQ. 23)
ω=ω+ξ×dt, (EQ. 24)
where ξ is the time derivative of ω (the acceleration of rotation speed), dt a sampling time interval, and B0, B1, B2 positive feedback gains. In the last two equations, an (=) symbol means an assignment operation. Due to the two integrations to obtain ω, the rotation speed control is extremely smooth. If cω>0 (the robot detects the human on Its left in the position-sensing method, or the human applies a counterclockwise torque in the torque-sensing method), the rotation speed ω eventually becomes positive so that the robot turns left; If cω<0, the rotation speed w eventually becomes negative so that the robot turns right. In either case, the robot's body direction eventually turns toward the human.
This completes the 2-DOF motion control algorithm of Tasks 20321 and 2032.
Task 2033: Extract Side Features along Edge: While traversing an edge tracking a human, the robot can extract geometric features on both left and right sides using its side sensors. At the end of an edge traversing, this geometrical information is saved in the edge record created. Walls and furniture are typical examples of side objects.
One typical side-object-feature-extraction method is the one using sonars and the least-squares-fit algorithm. In
T=F#S#G, (EQ. 25)
where a (#) symbol stands for the composition of two-dimensional transformations. By extracting the position component from frame T, we obtain the estimated “target position” Tp.
As the robot moves, a sonar scans surrounding objects and reports a target position (Tp) sequence. By applying the least-squares-fit algorithm to the position sequence, we can obtain a linear segment. This abstract and compressed data is handily fit to an edge record and will be used for navigating and localizing the robot in a future.
Recording Human-Guided Motion: For playback and other purposes, a human-guided robot's 2-DOF motion can be recorded as a “motion file,” which is a set of “motion records.” An nth motion record includes (a) a translation speed vn and (b) a rotation speed ωn. Let us assume that the range of n is [0, N−1]. Notice that a motion file is hardware independent; a motion file created on a mobile robot can be reproduced on another robot which has a different hardware system.
Motion Playback of Human-Guided Motion: Having a motion file, the original 2-DOF motion can be reproduced using the translation speed vn and rotation speed ωn in one of the two ways, forward and backward playback:
(0) Forward playback: In this playback session, each motion M=(vn, ωn) is reproduced for n=0 to N−1. The reproduced translation direction of the robot is the same as the recorded translation direction.
(1) Backward playback: In this playback session, each motion M=(−vn, −ωn) is reproduced for n=N−1 to 0. The reproduced translation direction of the robot is the opposite direction of the one in the recorded translation direction.
An embodiment of a 2-DOF motion M=(v, ω) is illustrated in
vL=v−D×ω, (EQ. 26)
vR=v+D×ω, (EQ. 27)
where D is one half of the tread. If these wheel-speeds are embodied, the original 2-DOF motion M=(v, ω) is reproduced.
The best mode for carrying out the present invention is an embodiment on a wheeled 2-DOF mobile robot with sonars in front, as shown in
The present invention endows intelligence to an individual mobile robot by making it understand its specific operation area.
Therefore, the present invention can be adopted to manufacture a wide variety of mobile-robot products including the following categories: (1) entertainment robots, (2) educational robots, (3) mobile platforms for research activities, (4) vacuum-cleaning robots, floor-polishing robots, security guard robots, intelligent wheel chairs, and other service robots, (5) intelligent shopping carts and intelligent golf carts, (6) material-transfer and material-handling robots.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/US2006/040844 | 10/18/2006 | WO | 00 | 5/28/2008 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2008/048260 | 4/24/2008 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
4589810 | Heindl et al. | May 1986 | A |
4816998 | Ahlbom | Mar 1989 | A |
4821192 | Taivalkoski et al. | Apr 1989 | A |
5109340 | Kanayama | Apr 1992 | A |
5739657 | Takayama et al. | Apr 1998 | A |
6009359 | El-Hakim et al. | Dec 1999 | A |
6134486 | Kanayama | Oct 2000 | A |
6285920 | McGee et al. | Sep 2001 | B1 |
6314341 | Kanayama | Nov 2001 | B1 |
6347261 | Sakaue et al. | Feb 2002 | B1 |
6453212 | Asama et al. | Sep 2002 | B1 |
6965209 | Jones et al. | Nov 2005 | B2 |
7015831 | Karlsson et al. | Mar 2006 | B2 |
7848850 | Hoshino et al. | Dec 2010 | B2 |
20030114959 | Sakamoto et al. | Jun 2003 | A1 |
20030144763 | Mori et al. | Jul 2003 | A1 |
20050041839 | Saitou et al. | Feb 2005 | A1 |
20050256611 | Pretlove et al. | Nov 2005 | A1 |
20060056678 | Tanaka et al. | Mar 2006 | A1 |
20060140450 | Hong et al. | Jun 2006 | A1 |
20060241792 | Pretlove et al. | Oct 2006 | A1 |
20070022078 | Gupta et al. | Jan 2007 | A1 |
20070233318 | Lei | Oct 2007 | A1 |
20100222925 | Anezaki | Sep 2010 | A1 |
Number | Date | Country | |
---|---|---|---|
20090198375 A1 | Aug 2009 | US |