The present disclosure relates to a method and system for training a robot using human-assisted task demonstration.
Robots are electro-mechanical devices that can manipulate objects using a series of robotic links. The robotic links are connected to each other by joints, each of which may be independently or interdependently driven by a joint motor and/or another suitable actuator. Each robotic joint represents an independent control variable or degree of freedom. End-effectors, which are also referred to as manipulators, are the particular end links used to directly perform a given work task or skill such as grasping a work tool, stacking one part with respect to another, etc. Precise motion control through the robot's various degrees of freedom may be organized by task level: object level control, i.e., the ability to control the behavior of a grasped object, end-effector control, and joint-level control. Collectively, the various control levels cooperate to achieve the required robotic dexterity and work task-related functionality.
A modification to an object handled by a robot in the execution of a task sequence typically requires relatively expensive retraining of the associated control hardware. This tends to be true even if the grasped object surfaces themselves have not changed. Similarly, changes to the positioning of the object in the robot's surrounding work environment as a result of error and/or relaxed operating rigidity may also require expensive retraining. However, existing robot manipulator control software is not easily retooled to meet changing flexibility requirements.
A method and a system are disclosed herein for training a robot using human-assisted task demonstration and virtual deictic markers assigned to perceptual features of the robot's work environment. Conventional manipulators are typically designed to operate in a highly structured environment with a minimum of variability, often requiring specific movement trajectories. These trajectories must be manually programmed for each new robotic task. Even systems that incorporate sensor feedback for autonomous trajectory planning require significant programmer interaction to identify the robotic task, adjust the required movement parameters, set the required manipulator grasp positions, and adjust trajectories in critical locations. The present approach is intended to provide a specific mechanism for dynamically assigning work tasks to such manipulators, e.g., two-finger or multi-finger grippers.
In particular, the present method includes moving the robot through the robot's configuration space to demonstrate a work task, and recording motor schema describing a required sequence of behavior of the robot during the movement. The method also includes recording sensory data describing performance and state values of the robot while moving across the configuration space, and detecting perceptual features of objects located in the environment. Additionally, the method includes assigning the virtual deictic markers to these detected perceptual features, e.g., objects, locations, times, places, etc., with the markers later used to guide automated behavior of the robot. The assigned markers and the recorded motor schema are used to subsequently control the robot in execution of another robotic task.
In another embodiment, the method includes capturing data sequences of changing positions of a manipulator of the robot from operator-controlled movements of the robot, and extracting data segments from the captured data sequences. The data segments represent actions of the robot during execution of a given task. The method may include detecting objects in the work environment of the robot and assigning a virtual deictic marker to at least some of the detected objects, and/or other perceptual data such as time, place, locations, etc. This associates an observed object's spatial orientation in the environment with movements performed by the robot relative to that object. Thereafter, the markers are combined to produce a generalized marker. The generalized marker maintains a record of visual features common between the markers, along with rotational and translational offsets required for these markers to match.
The present approach teaches a robotic work task to a robot using a series of learned examples, each being human-demonstrated in some manner, and associated primitive moves or “task primitives”. Example task primitives include moving from point A to point B, opening a gripper, closing a gripper, etc. Context-based action selection sequences perceptually guide movement between the primitives in a dynamic environment. The present approach can be quickly applied to new and different work tasks with minimal training or reprogramming of the robot.
The markers noted above are learned by the robot through direct human demonstration. For example, in a simple grasp of an object by a two-finger gripper, an operator may physically handle the gripper and move it into position so as to grasp the object at point A, or use an input device such as a joystick to backdrive the robot to the same effect. The operator then moves the robot arm and gripper to point B and opens the gripper, thereby depositing the object at point B.
All the while, the robot records perceptual data describing, for instance, the approach angle, the departure angle, the position, and the orientation of the object, e.g., using one or more 3D cameras, joint angle sensors, etc. The robot also records the forces or torques applied by the gripper to the grasped object, joint angles, and potentially other information. The robot learns precisely where the source object was placed without actually learning the exact path taken by the gripper. This information is filled in during post processing and execution from the motor schema and recorded markers.
A system is also disclosed that includes a robot having an arm and a manipulator connected to the arm, a sensor array which measures sensory data describing performance and state values of the robot, and a perceptual sensor which collects images of objects located in the environment. The system also includes an electronic control unit (ECU) in communication with the robot, the sensor array, and the perceptual sensors. The ECU includes recorded motor schema describing a sequence of behavior of the robot. The ECU is configured to execute the above method.
The above features and advantages and other features and advantages of the present invention are readily apparent from the following detailed description of the best modes for carrying out the invention when taken in connection with the accompanying drawings.
With reference to the drawings, wherein like reference numbers refer to the same or similar components throughout the several views, an example robot 10 is shown in
Robotic joints 17 may connect the various arm segments 18. Each robotic joint 17 may be driven by a joint actuator such as a motor 19 so as to move the manipulator 20 to desired positions during execution of a work task. Raw sensor data (arrow 15) describing robot performance values is relayed to an electronic control unit (ECU) 22 and used thereby to control the actions of the robot 10. The raw sensor data (arrow 15) describes performance and state values of the robot 10. Example raw sensor data (arrow 15) may include torque, force, speed, and acceleration of the manipulator 20.
To collect such data, a sensor array 33 may be connected to the robot 10, shown in
The ECU 22 may be accessed via a user interface 24. The ECU 22 may include logic elements 40 as explained below with reference to
Any computer-readable memory used in conjunction with the ECU 22 may include non-transitory/tangible memory that may be non-volatile or volatile. Non-volatile media may include, for example, optical or magnetic disks and other persistent memory. Example volatile media may include dynamic random access memory (DRAM), which may constitute a main memory. Other examples include a floppy, flexible disk, or hard disk, magnetic tape or other magnetic medium, a CD-ROM, DVD, and/or any other optical medium, as well as other possible memory devices such as flash memory.
The robot 10 of
The robot 10 learns required grasp positions and approach directions when learning to grasp an object, for instance the example object 23. That information is attached to the markers assigned by the ECU 22 at runtime to any perceptual features detected in the environment in which the robot 10 operates. As explained in detail below, the manipulator 20 first learns and records the required markers via human demonstration and then dynamically assigns the learned markers to detected perceptual features. This in turn allows for rapid adaptation to a changing environment while still completing multi-step assembly processes.
Repetition of any new assembly task can be broken into three distinct parts: the demonstration of the task by a human operator, such as grasping the object 23 and stacking the grasped object 23 on another object 21, a set of robotic skills and associated functions, and a support framework for extracting the required markers and assigning these markers at runtime to any other objects detected by the perceptual sensors 25, e.g., a 3D stereo camera, a high-resolution camera, and/or other sensors in communication with the ECU 22 via a wired or wireless communication channel 26.
Beginning with human demonstration, the present approach contemplates that a human operator physically moves the robot 10 of
Although the robot 10 of
With respect to robotic skills, behavioral imitation of a demonstrated work task is based around recognizing and repeating known robotic skills such as grasping the object 23, dropping the object 23, etc. Each skill in the repertoire of the robot 10, which may be embodied as motor schema 28 recorded by the ECU 22, can be defined by four generic functions: a recognition function, a predictor function, a cost estimation function, and motor schema 28. For purposes of imitation the origin of each skill is unimportant. It could be either learned or pre-programmed. The four generic functions noted above may be represented as follows:
recognizeri(T){tsa,Ma,Ea}
predictor(Ma,Pb,Wt)Wt+1
estimatori(Ma,E,Wt)costa,b(t),∀PbεWt
motor_schemai(Ma,Pb,Wt)J(t+1)
The recognizer function, i.e., recognizeri(T), identifies 1) the earliest time step ts in the recorded data stream T at which the skill is completed; 2) a floating marker Ma containing information necessary for task-specific execution of skill i; and 3) a recognized end-state E for the manipulated object, e.g., the object 23, which may be grasped by the robot 10 and placed on another object, e.g., the object 21. The information contained in the floating marker Ma is specific to each skill, but may contain a manipulation object type, an approach vector, a grasp position, a departure or exit vector, etc. In general, each marker Ma contains all of the knowledge necessary for the motor schema 28 of
The prediction function, i.e., predictor (Ma, Pb, Wt), identifies the expected end-state as a result of assigning a marker (Ma) to a particular visually detected object. The current state of the world, Wt, may be defined as:
W
t
={P(t),J(t),sensors(t)}
where P(t) is the set of all objects visually identified and localized in time step t, J(t) is the most recent joint angle configuration of the robot 10, and sensors(t) is the set of data returned by all other available sensors used in conjunction with the robot 10. The prediction function then identifies Wt+1. This allows runtime marker assignment conducted by the ECU 22 to penalize marker assignments which will not lead to another marker assignment in the future.
The cost estimation function, i.e., estimatori(Ma, E, Wt), is then the runtime mechanism for identifying the best perceived object to which to assign a marker (Ma). This function returns the cost of assigning the extracted marker Ma to all objects in the set P, given Wt and the set of all recognized end-states E. If the knowledge is available, the cost estimation function may include penalties for hard to reach or impossible to reach positions given the manipulator's position and/or obstacle placements in the environment.
Finally, the deictic motor schema 28 of
Referring to
At step 104, the position and orientation of the object 21 is recorded via the perceptual sensors 25 of
At step 106, the operator then physically moves the robot across its configuration space (C). For instance, the arm 16 and/or the manipulator 20 may be moved either manually by direct contact and an applied force, or indirectly via the input device 13 of
At step 108, the raw sensor data (arrow 15) of
At step 110, the ECU 22 executes post-processing to assign markers to objects in the environment describing the perceptual features detected at step 108. As noted above, the markers are virtual, and thus are recorded via the ECU 22 to relate the perceived features to, for example, object features, locations, places, start/stop times, and the like.
At step 112, the ECU 22 controls the robot 10 in a subsequent task using the markers of step 110 to guide the recorded motor schema 28. The robot 10 can thus repeat the learned maneuver using the recorded markers and schema, with the schema defining task primitives such as “pick up object”, “drop off object”, “move from point A to point B”, etc.
Step 112 may entail using a cost function and grasp recognition analysis to determine how best to guide the motor schema 28 via the markers in the best manner, given up to date knowledge of the environment in which the robot 10 operates. Therefore, step 112 may be broken into different subtasks as described below with reference to
The present imitation learning problem is focused on supporting the recognition of robotic skills and real-time assignment of markers to detected objects in the environment of the robot 10. This problem is divided into two distinct areas: skill recognition and marker assignment. Each of these will now be discussed in turn with reference to
Given a set of known skills with recognizer functions R, wherein R returns the earliest time step at which a skill is completed, the following iterative method 200 usable as part of method 100 parses the training data stream, T, to identify robotic skills. After starting (*), step 202 includes using the ECU 22 of
At step 204, the learned marker Ma created by the recognizer Ri is saved to a set of valid markers m. For example, there may be three valid markers corresponding to the three grasp types in the example of step 202.
At step 206, the ECU 22 removes all of the training data through tsa from the data stream T.
At step 208, the ECU 22 determines whether any additional actions are detected in the data stream T. If additional actions are detected, the method 200 repeats step 202. Otherwise, the method 200 is finished (**).
The end result of the iterative process, embodied herein as the example method 200, is a set of markers m learned from a single training session T. If there exist more than one training session covering the same demonstration, then the method 200 could be repeated for all training sessions, growing the set of markers m each time. Generalized knowledge of the task sequence may be inferred from multiple examples as explained later hereinbelow.
The marker assignment step 204 noted above occurs at runtime after all markers have been extracted and the robot 10 of
At step 204, for each marker Ma the ECU 22 of
The ECU 22 then identifies the combination {Ma, Pk} having the lowest overall cost, adding a small negative value to the combination used in the previous time step as a hysteresis value to prevent oscillation. The ECU 22 then sends the identified marker/assigned object position to a behavioral loop for execution by a deictic motor schema Si associated with the marker Ma which may be recorded in memory. The marker with the lowest execution cost may be passed on to the behavioral control module of
Perception in the ECU 22 of
At one level, the logic elements 40 include various hardware drivers 50 for the robot 10 of
Each of these control modules 46, 47, and 48 is in communication with a top-level learning module 41. The learning module 41 records perceptual data in a database 44 during training and uses the recorded perceptual data in the future to direct perceptual attention and behavioral control through marker and task assignment. The learning module 41 may include a passive services module 42 and an active services module 43. The passive services module 42 may handle task learning and generalization, e.g., the core steps of observing human operator-directed start and stop positions, approach and departure angles, etc. The active services module 43 may be used for planning of training, error detection, marker assignment, and the like. The user interface 24 provides an access point to the learning module 41 and the behavioral control module 48 in the example embodiment of
Referring to
Beginning with step 302, a training session is loaded into memory of the ECU 22.
At step 304, the associated recognizer functions as described above for all known motor schema/skills for the loaded session are then run by the ECU 22 of
At step 306, the marker associated with the earliest completed recognized skill is then saved, e.g., in the database 44 of
The recognizer function also returns a marker Ma to be assigned to perceptual objects at runtime. This marker should contain enough information for the cost estimation function to predict the cost of grasping the object, and for the generic motor schema to duplicate the demonstrated grasp on an object to which the marker has been assigned. For a grasp skill, the unique information to be extracted from the human demonstration is the object type, the final position of the robot 10 relative to the object, i.e., the grasp position, and the object-relative direction from which to approach the grasp position.
Step 308 entails identifying the grasp position. This position is the simplest to identify, as the point in the datastream T is known at which the robot 10 begins grasping the object, e.g., object 23 of
At step 310 of
m
target
rotation
=R
robot(tsgrasp)*Robject−1(tsgrasp)
{right arrow over (m)}
target=({right arrow over (X)}robot(tsgrasp)−{right arrow over (X)}object(tsgrasp))*Robject−1(tsgrasp)
Identifying the direction from which to approach the grasp point is more difficult because it is unknown how the “approach” begins in T. Knowing the approach direction is important so as to prevent knocking over the object with the attached tool as the manipulator 20 moves into place. One option for identifying this start point for the approach path is to find an earlier time step in the recorded data stream at which the robot still needs to travel a minimum distance to reach the desired grasp location:
{right arrow over (X)}
app
={right arrow over (X)}
robot(tsapp)−{right arrow over (X)}robot(tsgrasp),
such that
|{right arrow over (X)}app|>travel_distmin
Given the known object models used with the perceptual system, we can improve on this simple minimum distance model by incorporating the size of the grasped object D in three dimensions to account for variable sizes.
Box={right arrow over (k)}+{right arrow over (D)}original(O)*Robject(tsgrasp)
This returns a rotated bounding box surrounding the grasp point beyond which the robot end-effector must move to avoid bumping into the target object. The vector k is a constant offset, typically of the same value for all dimensions, to allow for additional error such as gripper size or maneuvering room.
A problem with this method for identifying an approach direction is that it assumes the human demonstrator traveled in a straight line to reach the target. While this is often true, it is not always the case. Even expert users have to readjust occasionally when the position of the manipulator 20 is misjudged, sometimes backing off and approaching the target object again. An arbitrary distance threshold from which to calculate a straight line approach ignores these corrections, and may not correctly capture a safe approach vector to the grasp point. For this reason, a filter may be used that is weighted by current velocity up to the first point outside the bounding box. This approach may be less likely to knock over an arbitrary-sized object.
Identifying the approach path at step 310 includes converting the approach path to an object-relative reference frame to simplify its use with assigned deictic markers in arbitrary positions:
{right arrow over (m)}
approach=({right arrow over (F)}app(tsapp)+{right arrow over (X)}robot(tsgrasp)−{right arrow over (X)}object)*Robject−1(tsgrasp)
The object relative end-effector position (mtarget), rotation (mtarget
Given a set of markers extracted from the training data, the next important aspect of the learning module 41 of
An example of a cost estimation function implementation is provided in the form of the grasp skill estimator. The cost estimation functions or values of the ECU 22 of
Referring to
Step 404 may include filtering out objects already in a valid end state, and assigning infinite cost to objects in the environment that are already correctly placed.
Step 406 may include identifying the requisite grasp point in global coordinates for each remaining object to be grasped:
R
grasp
=m
target
rotation
*R
object
{right arrow over (X)}
grasp
={right arrow over (X)}
object
+{right arrow over (m)}
target
*R
object
{right arrow over (X)}
approach
={right arrow over (X)}
object
+{right arrow over (m)}
approach
*R
object
where mtarget
At step 408, the ECU 22 may use an inverse kinematic model of the robot 10 to identify the set of joint angles with the minimum change per joint necessary to achieve Xgrasp and Xapproach. The cost da,b for assigning marker Ma to object Pb, not including penalties, is the Euclidean distance from the current end-effector position to the target position Xgrasp.
The choice of cost estimation function is arbitrary. The change in joint angles was described above instead of the Euclidean distance, but this approach demonstrated potential problems in reaching all target objects. Although some objects are close enough in practice for a reactive motor schema to attempt a grasp of that object, the actual target point may be just out of reach according to the inverse kinematics of the robot 10, and so may result in an incorrect infinite value. Another solution therefore is to assign finite penalties for grasps believed to be out of reach, and to let the reactive motor schema controlling the robot 10 attempt those grasps if other, easier to grasp objects have already been picked up and placed in a proper end state.
Still referring to
At step 412, the ECU 22 can assign penalties for objects that are unreachable due to obstacles in the path of the approach vector. Such obstacles may be detected by various means, such as via the obstacle perception module 46 shown in
The above description assumes that all objects P are independent physical objects recognized and localized by an external visual recognition system. This system enables learning from human demonstration of manipulation tasks involving such objects, provided they are visible. Such a perceptual system, however, can cause problems when manipulating partially-assembled objects, or when handling objects with some rotational symmetry.
In the former case, the robot 10 of
The answer to this problem is twofold. First, more visual features are needed to better represent the visual space. People can distinguish between many such problems using generic features such as corners, colors, or edges, so a robot requires these features in addition to object recognition capabilities. Second, the robot 10 needs the capability to generalize across multiple trials to identify those features that do not change between examples and add them to an existing perceptual model. In this fashion, the robot 10 learns what visual features besides the base object model are critical to the assembly task.
The present approach may be implemented using a simulated 3D visual imaging system mounted over the robot workspace. This provides a color image and range information from which corners and color blobs can be found within an image and localized in 3D. By default, the height of a detected feature is the highest point from the workspace within one pixel of the visual center. During training, these general features are added to the data stream T to be passed to the appropriate recognizers once the task demonstration is complete.
To allow for the presence of new visual features in the data stream, recognizer functions are adjusted to record all visual features, including objects of interest, at critical times such as grasping the object, or dropping it off. All features contain a type and 3D location, as well as rotation when available. To minimize computational load, the set of interesting visual features may be restricted to within a calibrated range of the grasp/release point.
Marker Generalization
A new generalizor function is then responsible for determining that two markers are the same, and finding the intersection of their two feature sets. The generalizor takes two markers as input and outputs a single new marker of the same type as the inputs. Because of practical variations between scenarios, one may elect not to discard the inputs, but rather can use the new generalized marker in parallel.
generalizor(Ma,Mb)Mnew
The generalizor solves a system of equations for the grasp skill. If two markers, Ma and Mb, are actually the same example, then there should exist some translation Xtransf and rotation Rtransf that will transform Ma into Mb. The challenge is identifying the set of matching features in both markers for which this transformation is true.
{right arrow over (X)}
feature,b=({right arrow over (X)}feature,a−{right arrow over (X)}robot,a)*Rtransf+{right arrow over (X)}transf
R
feature,b
=R
transf
*R
feature,a
Xfeature,b, Rfeature,b are the location and rotation of a single recorded feature, where implemented features include corners, color blobs, and objects of interest. If Ma and Mb are variations of the same general marker, then, using a Levenberg-Marquardt (LM) solver to solve for Xtransf and Rtransf, the total error between the solved feature(s) position/rotation and the recorded positions in Mb should be less than some threshold. Note that the rotational component of these equations is only included when a feature, including object location, is considered for inclusion. Furthermore, the rotational component of a feature with known orientation could be dropped independently of relative position using this separation, making symmetry investigations practical. Therefore grasping a cube needs four non-planar features, which could be three corners and an object centroid, or four corners, etc.
The above equations do not solve for the rotation of the robot gripper, e.g., manipulator 20 of
Cost Estimation with Generalized Markers
Cost estimation as described above does not change once a matched collection of features has been identified in the current perceptual space. To find those matched features, one may use the same LM-based problem solver to identify feature sets which match with a minimum of additional error. Their associated rotation then becomes the rotation of the “object” the robot needs to pick up. Using this new “object's” rotation, the cost estimation equations described above remain the same.
A major drawback to this visual feature based approach is the effects of occlusion. Corners located at the bottom of an object, for example, may not be visible at all locations in the workspace to an overhead camera due to the viewing angle. Similarly, other objects may hide visible features from a single camera. Therefore, generic models may be significantly impacted when using a specific set of visual features that are not always visible. In the case of object-specific features, as opposed to features created by the combination of two objects, a possible solution is to use a priori knowledge of feature locations obtained from the object model in conjunction with real-time object positions and rotation information returned by object tracking.
As opposed to generalized markers which depend on feature visibility, the object tracking system, e.g., tracking module 47 of
Imitation learning via the ECU 22 of
This approach may be used in various manipulator-based scenarios, including stacking, kitting, and peg-in-hole tasks. Furthermore, as noted above multiple demonstrations can be combined through logical inference to identify deictic markers with complex targets and symmetry conditions based on generic visual features such as corners and color blobs. Fast training of robots is thus enabled by use of predetermined task primitives for complex assembly tasks without expensive robot retraining, and without resorting to CAD models.
While the best modes for carrying out the invention have been described in detail, those familiar with the art to which this invention relates will recognize various alternative designs and embodiments for practicing the invention within the scope of the appended claims.