The present invention contains subject matter related to Japanese Patent Application JP 2005-109249 filed in the Japanese Patent Office on Apr. 5, 2005, the entire content of which is incorporated herein by reference.
1. Field of the Invention
The present invention generally relates to an information processing apparatus and method and a program, and more particularly, to an information processing apparatus and method and a program, for creating an action corresponding to teaching given by the user.
2. Description of the Related Art
With the recent technological innovation, there have been developed robots capable of acting in various manners. For having the robot make a user-desired action, however, the user has to teach the robot something for the action.
For having a humanoid type robot, for example, make an action on an external object, such as moving its hand to the object in a predetermined position (will be referred to as “reaching action” hereunder) or handling the object by hand, the user should have the robot structurally learn relations between its own motion and external object, not any single trajectory (trajectory in a control command or the like). To this end, the user should make teach the robot unilaterally as well as repeatedly correspondingly to the level of learning the robot has achieved.
Also, to teach the robot a plurality of actions in parallel, the user has to explicitly inform the robot of what action he is going to teach before starting the teaching.
Further, in case the user and robot interact with each other for cooperation, the user has to previously know the repertory of actions the robot can do.
As mentioned above, teaching the robot to act on an external object is not simple and cannot be done efficiently.
It is therefore desirable to overcome the above-mentioned drawbacks of the related art by providing an information processing apparatus and method and a program, for easily and efficiently teaching the robot to act on an external object.
According to the present invention, there is provided a first information processing apparatus including:
a learning means for learning a predetermined time-series pattern;
an output means for outputting a time-series pattern corresponding to the result of learning by the learning means; and
an adjusting means supplied with a time-series pattern obtained from an action made by an action unit on the basis of a time-series pattern supplied from the output means and external teaching for the action to adjust a time-series pattern supplied from the output means correspondingly to the input time-series pattern,
the learning means learning the time-series pattern supplied from the output means and adjusted by the adjusting means.
The external teaching may be given correspondingly to a user's touch on the action unit.
According to the present invention, there is also provided a second information processing apparatus including:
a learning means for learning a predetermined time-series pattern;
an output means for outputting a time-series pattern corresponding to the result of learning by the learning means; and
an adjusting means supplied with a time-series pattern obtained from an action made by an action unit on the basis of a time-series pattern supplied from the output means and external teaching for the action to adjust a time-series pattern supplied from the output means correspondingly to the input time-series pattern.
Each of the above first and second information processing apparatuses is formed from a recurrent type neural network. In each of the apparatuses, the learning means can acquire, as the result of learning the time-series pattern, a weighting factor and parametric bias parameter in the recurrent type neural network, the output means can calculate the parametric bias parameter on the basis of the weighting factor and output a time-series pattern corresponding to the parametric bias parameter resulted from the calculation, and the adjusting means can be supplied with a time-series pattern obtained from an action made by the action unit on the basis of the time-series pattern supplied from the output means and time-series pattern obtained external teaching for the action to change the parametric bias parameter correspondingly to the input time-series pattern.
According to the present invention, there is also provided a first information processing method including the steps of:
learning a predetermined time-series pattern;
outputting a time-series pattern corresponding to the result of learning in the learning step; and
receiving a time-series pattern obtained based on an action made by an action unit on the basis of a time-series pattern supplied from the outputting step and external teaching for the action to adjust a time-series pattern supplied from the outputting step correspondingly to the input time-series pattern,
in the learning step, there being learned the time-series pattern supplied from the outputting means and adjusted by the adjusting means.
According to the present invention, there is also provided a first program including the steps of:
learning a predetermined time-series pattern;
outputting a time-series pattern corresponding to the result of learning in the learning step; and
receiving a time-series pattern obtained based on an action made by an action unit on the basis of a time-series pattern supplied from the outputting step and external teaching for the action to adjust a time-series pattern supplied from the outputting step correspondingly to the input time-series pattern,
in the learning step, there being learned the time-series pattern supplied from the outputting means and adjusted by the adjusting means.
In the above first information processing apparatus, method and program, learning is made of a predetermined time-series pattern, a time-series pattern corresponding to the result of learning is outputted, there is supplied a time-series pattern obtained based on an action made by an action unit on the basis of the output time-series pattern and external teaching for the action to adjust the output time-series pattern correspondingly to the input time-series pattern, and learning is made of the adjusted output time-series pattern.
According to the present invention, there is also provided a second information processing method including the steps of:
learning a predetermined time-series pattern;
outputting a time-series pattern corresponding to the result of learning in the learning step; and
receiving a time-series pattern obtained based on an action made by an action unit on the basis of a time-series pattern supplied from the outputting step and external teaching for the action to adjust a time-series pattern supplied from the outputting step correspondingly to the input time-series pattern.
According to the present invention, there is also provided a second program including the steps of:
learning a predetermined time-series pattern;
outputting a time-series pattern corresponding to the result of learning in the learning step; and
receiving a time-series pattern obtained based on an action made by an action unit on the basis of a time-series pattern supplied from the outputting step and external teaching for the action to adjust a time-series pattern supplied from the outputting step correspondingly to the input time-series pattern.
In the above second information processing apparatus, method and program, learning is made of a predetermined time-series pattern, a time-series pattern corresponding to the result of learning is outputted, and there is supplied a time-series pattern obtained based on an action made by an action unit on the basis of the output time-series pattern and external teaching for the action to adjust the output time-series pattern correspondingly to the input time-series pattern.
According to the present invention, a robot can be taught about an action to an external object easily and efficiently.
The present invention will be described in detail below concerning embodiments thereof with reference to the accompanying drawings. The subject matter as set forth in an appended Claim corresponds to an embodiment described herein. The following description is intended to confirm that an embodiment to support the invention as set forth in an appended Claim is disclosed herein. Therefore, even if any embodiment disclosed herein is not stated herein as corresponding to a subject matter as set forth in an appended Claim, it does not means that the embodiment does not correspond to the subject matter. On the contrary, even if an embodiment is disclosed herein as corresponding to a subject matter as set forth in an appended Claim, it does not mean that the embodiment does not correspond to any other than the subject matter.
Furthermore, the following description does not means that an invention corresponding to an embodiment disclosed herein as a whole is not set forth in an appended Claim. In other words, the following description does not deny existence of an invention corresponding to an embodiment disclosed herein but not set forth in any appended Claim, that is, an invention that will be added in future by divisional application or amending.
The information processing apparatus as set forth in Claim 1 includes:
a learning means for learning a predetermined time-series pattern (e.g., learning unit 201 in
an output means for outputting a time-series pattern corresponding to the result of learning by the learning means (e.g., output unit 202 in
an adjusting means supplied with a time-series pattern obtained from an action made by an action unit on the basis of a time-series pattern supplied from the output means and external teaching for the action to adjust a time-series pattern supplied from the output means correspondingly to the input time-series pattern (e.g., adjusting unit 203 in
the learning means learning the time-series pattern supplied from the output means and adjusted by the adjusting means.
In the information processing apparatuses as set forth in Claims 2 and 7, the external teaching is given correspondingly to a user's touch on the action unit (e.g., direct teaching shown in
The information processing apparatuses as set forth in Claims 3 and 8 is formed from a recurrent type neural network (e.g., RNN11 in
the learning means acquires, as the result of learning the time-series pattern, a weighting factor and parametric bias parameter (e.g., parameter P) in the recurrent type neural network;
the output means calculates the parametric bias parameter on the basis of the weighting factor and output a time-series pattern corresponding to the parametric bias parameter resulted from the calculation; and
the adjusting means can be supplied with a time-series pattern obtained from an action made by the action unit on the basis of the time-series pattern supplied from the output means and time-series pattern obtained external teaching for the action to change the parametric bias parameter correspondingly to the input time-series pattern.
The information processing method as set forth in Claim 4 and program as set forth in Claim 5 include the steps of:
learning a predetermined time-series pattern (e.g., operation of the learning unit 201 in
outputting a time-series pattern corresponding to the result of learning in the learning step (e.g., operation of the output unit 202 in
receiving a time-series pattern obtained based on an action made by an action unit on the basis of a time-series pattern supplied from the outputting step and external teaching for the action to adjust a time-series pattern supplied from the outputting step correspondingly to the input time-series pattern (e.g., operation of the adjusting unit 203 in
in the learning step, there being learned the time-series pattern supplied from the outputting means and adjusted by the adjusting means.
The information processing apparatus as set forth in Claim 6 includes:
a learning means for learning a predetermined time-series pattern (e.g., learning unit 201 in
an output means for outputting a time-series pattern corresponding to the result of learning by the learning means (e.g., output unit 202 in
an adjusting means supplied with a time-series pattern obtained from an action made by an action unit on the basis of a time-series pattern supplied from the output means and external teaching for the action to adjust a time-series pattern supplied from the output means correspondingly to the input time-series pattern (e.g., adjusting unit 203 in
The information processing method as set forth in Claim 9 and program as set forth in Claim 10 include the steps of:
learning a predetermined time-series pattern (e.g., operation of the learning unit 201 in
outputting a time-series pattern corresponding to the result of learning in the learning step (operation of the output unit 202 in
receiving a time-series pattern obtained based on an action made by an action unit on the basis of a time-series pattern supplied from the outputting step and external teaching for the action to adjust a time-series pattern supplied from the outputting step correspondingly to the input time-series pattern (e.g., operation of the adjusting unit 203 in
Referring now to
The robot 1 can learn teaching given by the user and act correspondingly to the result of learning.
For example, once the user has moved the hand portion 2A of the hand 2 of the robot 1 to an object W which is in a predetermined relation with the hand portion 2A while holding the arm 2 in hand (namely, touching directly the robot 1 to teach the latter how to reach the object W; reaching action) as shown in
The arm unit 2 incorporates a video camera 51 installed in a predetermined place such as the hand portion 2A and various sensors 52-1 to 52-n installed in predetermined places such as the hand portion 2A and including a sensor to detect an external pressure (pressure applied by the direct touch by the object W or user's hand), sensor to detect a position (x, y) of the object W in a picture captured by the video camera 51, etc.
The arm unit 2 also incorporates a motor group 12 including motors 121-1 to 121-m (will be referred to as “motors 121” hereunder wherever appropriate) which drive the action units such as the arm unit 2, hand portion 2A, etc.
The robot 1 also includes a monitor unit 13 including a video camera 71 installed in a predetermined place such as the head unit of the robot 1 and various sensors 72-1 to 72-k such as a sensor to detect a position (x, y) of the object W in a picture captured by the video camera 71, etc.
The robot 1 further includes a controller 11 to learn teaching given by the user and control each of the units of the robot 1 in order to have the robot 1 act according to the results of the learning.
For example, the controller 11 learns user's direct teaching (e.g., trajectory of the hand portion 2A as shown in
The controller 11 also generates an output vector time series (e.g., motor command output vector mt for driving the motor 121) on the basis of the result of learning during an autonomous action, and outputs the output vector time series to each motor 121.
In this embodiment, the controller 11 is formed from a recurrent type neural network (RNN) having applied thereto the neural network having been studied as one model concerning the human and animal brains. Learning and autonomous action are implemented by calculation based on this model.
The “RNN” (will be referred to as “RNN 11” hereunder) is configured as shown in
The RNN 11 includes an input layer 111, intermediate layer 112 and an output layer 113, each of which is formed from an arbitrary number of neurons.
A neuron 111-1 of the input later 111 is supplied with data Xt (t=1, 2, . . . ). A parametric bias node 111-2 which is a neuron of the input layer 111 is supplied with a parameter Pt. Further, data supplied from a neuron 113-2 of the output layer 113 as context data ct indicative of the internal state of the RNN 11 is fed back to a neuron 111-3 of the input layer 111.
Neurons of the intermediate layer 112 make weighting addition of input data, and output the results of addition one after another to a next stage. More particularly, the neurons make calculation (based on a nonlinear function) of the data xt, parameter Pt and context ct on the basis of a predetermined weighting factor, and then output the result of calculation to the output layer 113.
A neuron 113-1 of the output layer 113 outputs data x*t+1 corresponding to the input data.
The RNN 11 includes an operational unit 121 that makes learning based on back-propagation and another operational unit 122 that sets a weighting factor for the RNN 11.
That is, the RNN 11 can hold a plurality of dynamic structures by calculating a weighting factor and parameter, corresponding to a time-series pattern supplied at the time of learning, and associating the value of the parametric bias node (parameter Pt) with the time-series pattern.
After completion of the learning, the RNN 11 can output a time-series pattern (predicted) obtained as results of the learning and which corresponds to a coefficient and parameter P, and adjust the output time-series pattern by appropriately changing the parameter P correspondingly to the input time-series pattern (result).
It is assumed here that the RNN 11 is made to previously learn a time-series pattern A indicated with a curve L11, time-series pattern B indicated with a curve L12 and a time-series pattern C indicated with a curve L13 as shown in
In this case, when, for example, the parameter PA is given to the RNN 11, the time-series pattern A will be outputted. On the contrary, when the parameter A is given to the RNN 11, the parameter PA will be outputted.
Note that even when supplied with any parameter other than the parameter P obtained by learning, the RNN 11 can generate a predetermined time-series pattern on the basis of the relation with the parameter P obtained by learning, and output the time-series pattern (it has a function of generalization).
The details of the RNN 11 are referred to the Japanese Patent Application Laid Open Nos. 2004-030627 and 2004-030628.
Next, teaching made by the user to the robot 1 will be explained concerning the action of reaching the object W on a desk (as shown in
Given a position of the object W, the robot 1 can make the reaching action to move the hand portion 2A from an arbitrary initial position to the object W (will be referred to as “first reaching action” hereunder) as shown in
First, there will be described teaching for the first reaching action (to move the hand portion 2A from the arbitrary initial position to the object W when the position of the object W is given, as shown in
It is assumed here that the hand portion 2A of the robot 1 is in a position A11 while the object W is in a position B1 (the hand portion 2A and object W are in such a physical relation with each other) as shown in
With this teaching, the robot 1 will learn a trajectory along which the hand portion 2A around the position A11 is moved to around the position B1. As a result, the robot 1 can move the hand portion 2A from the position A11 or from around the latter, for example, from the position A12 or A13 (to be more accurate, position A12 or A13 in a physical relation with the position B1) in the direction of an arrow starting at a position A12 or A13 in
With only the above teaching, however, the robot 1 will not be able to have the hand portion 2A from an initial position away from the position A11, such as the position A14 or A15, to the object W (as indicated with an arrow starting at a position A14 or A15 in
On this account, the robot 1 is then made to autonomously move the hand portion 2A from the position A14 as shown in
When the hand portion 2A of the robot 1 is going to leave the object W, the user holds the arm unit 2 of the robot 1 and guides it so that the hand portion 2A of the robot 1 will move to the object W as indicated with a solid-line arrow in
Having thus been taught, the robot 1 will further learn a trajectory along which the hand portion 2A around the position A14 is moved to around the position B1. As a result, the robot 1 will be able to move the hand portion 2A to the object W even when the hand portion 2A is initially around the position A14 as shown in
With only the above teaching, however, the robot 1 will not be able to move the hand portion 2A from the position A15 to the object W (as indicated with an arrow starting at the position A15 in
On this account, the robot 1 is further made to autonomously move the hand portion 2A from the position A15 as shown in
When the hand portion 2A of the robot 1 is going to leave the object W, the user holds the arm unit 2 of the robot 1 and guides it so that the hand portion 2A of the robot 1 will reach the object W as indicated with a solid-line arrow in
Having thus been taught, the robot 1 will further learn a trajectory along which the hand portion 2A around the position A15 is moved to around the position B1. As a result, the robot 1 will be able to move the hand portion 2A to the object W even when the hand portion 2A is initially around the position A15 as shown in
As above, the teaching is made to move the hand portion 2A from an arbitrary initial position to the object W (first reaching action) when a position of the object W is given.
Next, there will be described teaching for the second reaching action to move the hand portion 2A from an arbitrary initial position to the object W in an arbitrary position as shown in
This teaching is basically similar to the first teaching having been explained above. Namely, the user holds the arm unit 2 of the robot 1 and guides it to the object W. It should be noted that in this case, the second teaching is to be made following the first teaching.
It is assumed here that the hand portion 2A of the robot 1 is in a position A21 while the object W is in a position B2 different from the position B1 (the hand portion 2A and object W are in such a physical relation with each other) as shown in
Having thus been taught, the robot 1 will further learn a trajectory along which the hand portion 2A around the position A21 is moved to around the position B2. As a result, the robot 1 will be able to move the hand portion 2A around the position A21 to the object W around the position B2 as shown in
Next, the initial position of the hand portion 2A of the robot 1 is changed to a position A22 while the position of the object W is changed to a position B3, as shown in
Having thus been taught, the robot 1 will further learn a trajectory along which the hand portion 2A around the position A22 is moved to around the position B3. As a result, the robot 1 will be able to move the hand portion 2A from around the position A22 to the object W around the position B3 as shown in
Next, the initial position of the hand portion 2A of the robot 1 is changed to a position A23 while the position of the object W is changed to a position B4, as shown in
Having thus been taught, the robot 1 will further learn a trajectory along which the hand portion 2A is moved from around the position A23 to around the position B4. As a result, the robot 1 will be able to move the hand portion 2A from around the position A23 to the object W around the position B4 as shown in
The teaching (second teaching) for moving the hand portion 2A from a predetermined initial position to the object W in an arbitrary position is made as above.
With the first and second teaching for the first and second reaching actions, the robot 1 will be able to know the relation between the object W and arm unit 2 and make the reaching action along a trajectory shown in
The user can teach the robot about the reaching action as having been described above.
The robot 1 will learn the aforementioned teaching as will be described below with reference to the flow diagram shown in
First in step S11, the neuron 111-1 of the input layer 111 of the controller (or RNN in
In step S112, the intermediate layer 112 of the RNN 11 calculates the input xt on the basis of the weighting factor, and outputs a predicted value x*t+1 from the neuron 113-1 of the output layer 113.
In step S13, the operational unit 121 acquires an input xt+1 at a next time t+1 as teacher data.
In step S14, the operational unit 121 calculates a difference between the teacher input xt+1 acquired in step S13 and predicted value x*t+1 calculated in step S12.
In step S15, the RNN 11 is supplied with the difference calculated in step S14 from the neuron 113-1 of the output layer 113 and propagates it to the intermediate layer 112 and then to the input layer 111 to provide a result of calculation dXbpt.
In step S16, the intermediate layer 112 acquires a corrected value dXU of the internal state as given by the following equation (1):
Further, the intermediate layer 112 corrects the corrected value dXU as given by the following equations (2), (3) and (4):
dlXUt=ε·dXUt+monentum·dlXUt (2)
XUt=XUt+dlXUt (3)
Xt=sigmoid(XUt) (4)
In step S17, the parametric bias node 111-2 stores a value (parameter P) of the internal state.
Next in step S18, the RNN 11 judges whether it is to exit the learning. In case it is determined that it is not to exit the learning, the RNN 11 returns to step S11 where it will repeat the subsequent steps of operation.
In case it is determined in step S18 that it is to exit the learning, the RNN 11 will exit the learning.
With the above operations for the learning, one time-series pattern is learned for the RNN 11.
In the learning of the teaching for the above reaching action (in
Note that in this embodiment, the sensor vector s includes joint-angle information on the arm unit 2 of the robot 1 and positional information on an external object (object W) and the motor command output vector m includes joint-angle command value etc. of the arm unit 2.
Next, the sensor input vector st+1 at the time t+1 and motor command output vector mt+1 are supplied as the input xt+1 to the operational unit 121 (as in step S13) in which a difference between the teacher data input xt+1 and predicted value x*t+1 is calculated (as in step S14).
A weighting factor and parameter P are calculated based on the calculated difference (as in steps S15 to S17).
Note that the weighting factor is changed by the back-propagation used in the ordinary neural network.
The learning having been explained above with reference to the flow diagram in
In the first teaching shown in
In the example shown in
After learning of a plurality of time-series patterns as above, the parameters P acquired by learning the time-series patterns are held as the results of learning, respectively, and the weighting factors obtained through the learning are set in the real RNN 11. The weighting factors are set in the RNN 11 as will be described below with reference to the flow diagram in
In step S21, the operational unit 122 of the RNN 11 (in
Next in step S22, the operational unit 122 sets the synthetic value (mean value) calculated in step S21 as a weighting factor in the neuron of the intermediate layer 112 of the real RNN 11.
Thus, weight factors obtained through learning of a plurality of time-series patterns will be set in each neuron of the intermediate layer 112 of the real RNN 11.
With the above learning, information on a dynamic structure commonly usable in generating a plurality of teaching time-series patterns will be held for the weighting factor of each neuron in the intermediate layer 112, and information (parameter P) necessary for switching the dynamic structure commonly usable as above to a suitable one for generating each of the teaching time-series patterns be set in the parametric bias node 111-2 of the input layer 111.
More specifically, with the learning for the reaching action, information on a dynamic structure commonly usable in generating a plurality of teaching time-series patterns (sensor input vector st and motor command output vector mt when the hand portion 2A is moved along a trajectory indicated with a solid line in
Thus, learning is made in response to user's direct teaching.
That is, according to the present invention, the robot 1 acting in response to preceding teaching can be taught to make an action complementing the present one, to thereby improve the accuracy of action. Thus, the robot 1 can be taught efficiently to make an action on an external object. Also, the robot 1 can be taught to make a complicated action incorporating actions the robot 1 has already learned. Further, the user can have deeper knowledge of the bodily limitation and learning ability of the robot 1 more deeply through such a teaching, and thus can make more effective teaching to the robot 1.
Also, since the user can confirm the action of the robot 1 by actually seeing it and teach the robot 1 according to the result of confirmation, so he or she has not to know the repertory of actions of the robot 1 in advance.
As will be seen from the above, the robot 1 can learn various actions from the user's teaching, and the user can have deeper knowledge of the action characteristics of the robot 1. So, it is expectable that the user and robot 1 can interact with each other more smoothly and deeply.
Next, the autonomous action of the robot 1 having learned as above will be explained below with reference to the flow diagram in
First in step S31, the parametric bias node 111-2 of the RNN 11 is supplied with the parameter P.
In step S32, the intermediate layer 112 makes weighting factor-based calculation of the parameter P supplied to the parametric bias node 111-2 in step S31.
Then in step S33, the neuron 113-1 of the output layer 113 in the RNN 11 supplies the operational unit 121 with a predicted value X*t at a predetermined time t, corresponding to the parameter P supplied in step S31.
In step S34, the operational unit 121 acquires input t at a time t as teacher data.
In step S35, the operational unit 121 calculates a difference between the predicted value x*t and teacher data input xt.
In step S36, the RNN 11 judges, based on the result of calculation from step S35, whether the parametric bias value (parameter P) of the parametric bias node 111-2 is to be changed. In case it has been determined because the difference is large that the parametric bias value should be changed, the RNN 11 goes to step S37 where it will determine a parametric bias value (parameter P) corresponding to the difference.
After that, the RNN 11 returns to step S31 and the parametric bias node 111-2 is supplied with the parameter P determined in step S37. Thereafter, the operations in step S32 and subsequent steps are effected as above.
If it has been determined in step S36 that the parametric bias value has not to be changed, the RNN 11 returns to step S33 in which the operations in this step and subsequent steps will be effected as above.
In an autonomous action of the robot 1 having learned the teaching for the aforementioned reaching action (as in
In the parametric bias node 111-2 calculates the input parameter P on the basis of a weighting factor (in step S32), and outputs a predicted value s*t of the sensor input vector st, corresponding to the calculated, to the operational unit 121. It should be noted that the parametric bias node 111-2 also outputs a motor command output vector mt corresponding to the calculation.
The operational unit 121 acquires the sensor input vector st supplied correspondingly to an action of the robot 1, based on the motor command output vector mt from the parametric bias node 111-2, as teacher data input xt (in step S34), and calculates a difference between the sensor input vector st itself and predicted value s*t of the sensor input vector st.
In case the calculated difference is small, that is, in case the relation between the hand portion 2A and object W has varied as predicted (when the hand portion 2A has approached the object W as predicted), the parametric bias value will not be changed but a sensor input vector s and motor command output vector m (time-series pattern), corresponding to the parameter P, will continuously be outputted.
On the contrary, if the difference is large, the parametric bias value (parameter P) will be changed, and the sensor input vector s and motor command output vector m will be outputted correspondingly to the value of the parameter P.
In an example shown in
The difference becomes large when the prediction has been incorrect or when the position of the object W has been changed from a position B2 to position B3 (as in
Note that during the reaching action, the motor command output vector m from the neuron 113-1 is feedback-looped to the neuron 111-1 as shown in
In the foregoing, the teaching of the reaching action to the robot 1 and making the reaching action by the robot 1 has been described by way of example. Also, the robot 1 can be taught to continuously roll a ball W on a desk top between the right and left arm units 2 (hand portions 2A) as will be described below with reference to
In this embodiment, the robot 1 can be directly taught by the user to knock back a ball W, having come to near the left hand, by the left hand and the ball W, having come to near the right hand, by the right hand. Namely, the robot 1 can learn a dynamic physical relation with the ball W and thus continuously roll the ball W.
Also, the robot 1 can be taught to lift the ball W with both hands as shown in
Note that for teaching the robot 1 to make two actions, one being the ball rolling action and the other being the ball lifting action, for example, the user should teach the robot 1 for the ball rolling action and then hold the arm units 2 of the robot 1 and guide them to lift the ball W. Thereby, the robot 1 can be taught to lift the ball after rolling it.
That is, even when the robot 1 is taught to the two actions, namely, the ball rolling and lifting actions, the user may not clearly specify any action about which he is going to teach the robot 1. The user can easily teach the robot 1 a plurality of teaching.
Also, the robot 1 can be taught to stack up blocks in predetermined colors according to their colors as shown in
Note that although the user teaches the robot 1 by holding (touching) the arm unit(s) 2 and guiding it as above, the body part(s) of the robot 1 to be so guided are not limited to the arm unit(s) 2 but may be any other appropriate body part(s) of the robot 1 depending upon an action about which the user is going to teach the robot 1. Also, the teaching may not be made by holding and guiding a body part of the robot 1 but with a word or manual sign (showing a closed hand, showing an open hand or pointing a direction in which the body part is to be moved).
In the aforementioned embodiment, the controller 11 is formed from the RNN 11. The aforementioned learning and autonomous actions are implemented through operations of the RNN 11. However, the learning and autonomous actions may also be implemented by a device or module constructed as shown in
As shown, the controller 11 includes a learning unit 201 that learns a predetermined time-series pattern (learning of a trajectory indicated with a solid-line arrow in
For an autonomous action, the output unit 202 of the controller 11 outputs a time-series pattern (to move the hand portion 2A to the object W in the position B1 as in
The aforementioned series of operations may be effected by hardware and can also be effected by software. In the latter case, a personal computer 501 as shown in
As shown in
The CPU 511, ROM 512 and RAM 512 are connected to each other via a bus 515 to which an input/output interface 516 is also connected.
The input/output interface 516 has connected thereto an input unit 518 including a keyboard, mouse and the like, output unit 517 including a display of CRT or LCD type, speaker and the like, and a communication unit 519 including a modem, terminal adapter and the like. The communication unit 519 makes communications over a network.
The input/output interface 516 has also connected thereto a drive 520 in which a magnetic disk 531, optical disk 523, magneto-optical disk 533 or semiconductor memory 534 is appropriately loaded to install a computer program read from such a recording medium into the hard disk 514 as necessary.
To effect a series of operations by a software, a program for the software is installed from a network or recording medium into the personal computer 501.
As shown in
Note that those skilled in the art should understand that the steps of stating a program to be recorded to a recording medium of course include steps of operation made time-serially in the order described herein as well as steps of operation not effected time-serially but effected in parallel or individually.
It should be understood by those skilled in the art that various modifications, combinations, sub-combinations and alterations may occur depending on design requirements and other factors insofar as they are within the scope of the appended claims or the equivalents thereof.
Number | Date | Country | Kind |
---|---|---|---|
2005-109249 | Apr 2005 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5255096 | Boyle | Oct 1993 | A |
Number | Date | Country |
---|---|---|
02160487 | Jun 1990 | JP |
Number | Date | Country | |
---|---|---|---|
20070239641 A1 | Oct 2007 | US |