An example implementation for avoiding leg collisions may involve a biped robot reducing a three-dimensional system to a two-dimensional projection of the biped robot's feet. An example biped robot may determine a touchdown location for a swing foot. The biped robot may determine lateral positions of the touchdown location and the swing foot, each relative to a stance foot. Based on one or more of the determined lateral positions of the touchdown location and the swing foot, each relative to the stance foot, the biped robot may determine an intermediate swing point for the swing foot that is not on a line defined by the swing foot and the touchdown location. The biped robot may further cause the swing foot to move to the intermediate swing point, and then cause the swing foot to move to the touchdown location.
|
1. A method comprising:
determining a touchdown location for a swing foot of a biped robot, the biped robot having a stance foot, wherein the swing foot and the stance foot are each coupled to a body of the biped robot;
determining a lateral position of the touchdown location relative to the stance foot by determining that the touchdown location is laterally outside of a medial side of the stance foot;
determining a forward velocity of the biped robot;
based on the determined forward velocity of the biped robot and the determined lateral position of the touchdown location relative to the stance foot indicating a collision between the swing foot and stance foot, updating the touchdown location, wherein updating the touchdown location is further based on the determination that the lateral position of the touchdown location is laterally outside of the medial side of the stance foot; and
causing, by the biped robot, the swing foot to move to the updated touchdown location.
10. A biped robot comprising:
a first foot;
a second foot;
a processor;
a memory; and
program instructions stored in the memory that, when executed by the processor, cause the biped robot to perform operations comprising:
determining a touchdown location for the first foot;
determining a lateral position of the touchdown location relative to the second foot by determining that the touchdown location is laterally outside of a medial side of the second foot;
determining a forward velocity of the biped robot;
based on the determined forward velocity of the biped robot and the determined lateral position of the touchdown location relative to the second foot indicating a collision between the first foot and second foot, updating the touchdown location, wherein updating the touchdown location is further based on the determination that the lateral position of the touchdown location is laterally outside of the medial side of the second foot; and
causing the first foot to move to the updated touchdown location.
18. An article of manufacture including a non-transitory computer-readable medium, having stored thereon program instructions that, upon execution by a computing device, cause the computing device to perform operations comprising:
determining a touchdown location for a first foot of a biped robot, the biped robot having a second foot, wherein the first foot and second foot are each coupled to a body of the biped robot;
determining a lateral position of the touchdown location relative to the second foot by determining that the touchdown location is laterally outside of a medial side of the second foot;
determining a forward velocity of the biped robot;
based on the determined forward velocity of the biped robot and the determined lateral position of the touchdown location relative to the second foot indicating a collision between the first foot and second foot, updating the touchdown location, wherein updating the touchdown location is further based on the determination that the lateral position of the touchdown location is laterally outside of the medial side of the second foot; and
causing the first foot to move to the updated touchdown location.
2. The method of
3. The method of
4. The method of
5. The method of
6. The method of
7. The method of
8. The method of
9. The method of
11. The biped robot of
12. The biped robot of
13. The biped robot of
14. The biped robot of
15. The biped robot of
16. The biped robot of
17. The biped robot of
|
This application is a continuation of and claims priority to U.S. patent application Ser. No. 14/538,777, filed Nov. 11, 2014, which is hereby incorporated by reference in its entirety.
As technology advances, various types of robotic devices are being created for performing a variety of functions that may assist users. Robotic devices may be used for applications involving material handling, transportation, welding, assembly, and dispensing, among others. Over time, the manner in which these robotic systems operate is becoming more intelligent, efficient, and intuitive. As robotic systems become increasingly prevalent in numerous aspects of modern life, the desire for efficient robotic systems becomes apparent. Therefore, a demand for efficient robotic systems has helped open up a field of innovation in actuators, movement, sensing techniques, as well as component design and assembly.
The present disclosure generally relates to controlling a legged robot. Specifically, implementations described herein may allow for efficient operation of a legged robot that may determine and avoid a potential leg collision between a swing leg and a stance leg. These as well as other aspects, advantages, and alternatives will become apparent to those of ordinary skill in the art by reading the following detailed description, with reference where appropriate to the accompanying drawings.
A first example implementation may include (i) determining a touchdown location for a swing foot of a biped robot, the biped robot having a stance foot, where the swing foot and stance foot are each coupled to a body of the biped robot, (ii) determining a lateral position of the touchdown location relative to the stance foot, (iii) determining a lateral position of the swing foot relative to the stance foot, (iv) based on one or more of the determined lateral positions of the touchdown location and the swing foot, each relative to the stance foot, determining an intermediate swing point for the swing foot, where the intermediate swing point is not on a line defined by the swing foot and the touchdown location, (v) causing, by the biped robot, the swing foot to move to the intermediate swing point, and (vi) after causing the swing foot to move to the intermediate swing point, causing the swing foot to move to the touchdown location.
A second example implementation may include (i) determining a touchdown location for a swing foot of a biped robot, the biped robot having a stance foot, where the swing foot and stance foot are each coupled to a body of the biped robot, (ii) determining a forward velocity of the biped robot, (iii) determining a lateral position of the touchdown location relative to the stance foot, (v) based on the determined forward velocity of the biped robot and the determined lateral position of the touchdown location relative to the stance foot, updating the touchdown location, and (vi) causing, by the biped robot the swing foot to move to the updated touchdown location.
A third example implementation may include a system having means for performing operations in accordance with the first example implementation.
A fourth example implementation may include a system having means for performing operations in accordance with the second example implementation.
A fifth example implementation may include a biped robot having (i) a body, (ii) a swing foot coupled to the body, (iii) a stance foot coupled to the body, (iv) a processor; (v) a non-transitory computer readable medium; and (vi) program instructions stored on the non-transitory computer readable medium that, when executed by the processor, cause the biped robot to perform operations in accordance with the first example implementation.
A sixth example implementation may include a biped robot having (i) a body, (ii) a swing foot coupled to the body, (iii) a stance foot coupled to the body, (iv) a processor; (v) a non-transitory computer readable medium; and (vi) program instructions stored on the non-transitory computer readable medium that, when executed by the processor, cause the biped robot to perform operations in accordance with the second example implementation.
Example implementations are described herein. The words “example,” “exemplary,” and “illustrative” are used herein to mean “serving as an example, instance, or illustration.” Any implementation or feature described herein as being an “example,” being “exemplary,” or being “illustrative” is not necessarily to be construed as preferred or advantageous over other implementations or features. The example implementations described herein are not meant to be limiting. Thus, the aspects of the present disclosure, as generally described herein and illustrated in the figures, can be arranged, substituted, combined, separated, and designed in a wide variety of different configurations, all of which are contemplated herein. Further, unless otherwise noted, figures are not drawn to scale and are used for illustrative purposes only. Moreover, the figures are representational only and not all components are shown. For example, additional structural or restraining components might not be shown.
Example implementations relate to the determination and avoidance of potential leg collisions of a robot. The determination of potential leg collisions may involve determining forward and lateral positions of a swing foot and a touchdown location for the swing foot, both in relation to a stance foot. Avoiding a potential leg collision may involve adjusting a swing path of the swing foot, and/or updating the touchdown location.
In some previous systems, an example robot may determine potential collisions of its legs by monitoring, via received sensor data, the movement and position of each of the links and joints in both of its legs. This may allow the robot to determine potential collisions between each of these components. For instance, the robot may monitor the trajectory of the robot's right knee in relation to the robot's left thigh, left knee, left shin, and left foot, and may do the same for the robot's right thigh, right shin, right foot, and so forth. This may result in a relatively large computational demand on the processor(s) of the robot.
Further, if a potential collision is determined between one or more of the links and/or joints, determining corrective measures to avoid the potential collision may also require a relatively large amount of processor capacity and time. For example, altering the trajectory of a swing leg to avoid one joint-joint or joint-link collision might not ensure that all determined collisions have been avoided. Thus, the robot may need to determine multiple possible corrections simultaneously. Nonetheless, this approach may be desirable in some applications, where relatively large gait disturbances, such as adductions or abductions of the legs, may be possible.
In some implementations discussed below, the determination of potential leg collisions may be simplified based on the morphology of the robot. For instance, in some cases, the joints of the robot's swing leg may maintain a relatively constant relationship during most gaits, such that the hip, knee, and foot remain in approximately the same plane, which may be referred to as a swing plane. Similarly, the hip, knee, and foot of the stance leg may remain in approximately the same stance plane. Although these planes may rotate about the respective hips of the robot as the feet move laterally, the hips of the robot remain a fixed distance from each other. Therefore, as the feet approach a collision, the distance between the two planes increases in the direction of the robot's hips.
Based on these known geometric constraints, a determination that the feet of the robot will not collide in two dimensions (forward and lateral) implies that no part of the robot's legs above the feet will collide in three dimensions (forward, lateral, and vertical). Thus, the robot may simplify its determination of potential leg collisions by determining only the relative forward and lateral positions of its feet. This simplified approach to determining potential leg collisions may be less complex, and therefore require less computation and a lower processor demand, while retaining the same operation and achieving the same outcome.
Although a biped robot will be discussed below, other robot configurations are possible. For instance, the same analysis may apply to a given stance leg and a given swing leg on a quadruped robot, among other possibilities.
In some examples, the biped robot in a walking gait may include a stance foot (e.g., the left foot) and a swing foot (e.g., the right foot) for a given step. The biped robot may determine a desired touchdown location for the swing foot, and may further determine the lateral positions of the determined touchdown location and the swing foot, each relative to the stance foot. If the biped robot determines that one or both of (i) the position of the determined touchdown location or (ii) the position of the swing foot is laterally outside of (e.g., to the left of) the stance foot, a leg collision may potentially occur.
Additionally, the biped robot may monitor the forward position of the swing foot relative to the stance foot, which may allow the biped robot to further simplify the leg collision monitoring. For example, when the biped robot determines that the swing foot has moved forward past the front of the stance foot, the biped robot may discontinue the lateral collision monitoring described above, as a leg collision is no longer likely. This may further reduce the computation and processor demand for leg collision monitoring while retaining the same operation and achieving the same outcome.
When a potential leg collision is determined, the robot may also determine a gait correction to avoid the collision by considering only the forward and lateral positions of the feet. For example, the biped robot may determine an intermediate swing point for the swing foot. The intermediate swing point may be approximately located at one of the medial corners of the stance foot. The biped robot may then cause the swing foot to move to the intermediate swing point. After reaching the intermediate swing point, the swing foot may be clear of the stance foot, and thus the biped robot may cause the swing foot to move to the originally determined touchdown location. Thus, the biped robot may accomplish both operations of determining a potential leg collision and avoiding the leg collision by reducing a three-dimensional system to a two-dimensional analysis.
In some cases, the biped robot may determine an expanded footprint for one or both of the feet to further avoid leg collisions. For example, the stance foot may have a given footprint based on the structure of the foot. The biped robot may determine an expanded footprint that is larger than the structural footprint of the foot, and then determine the relative lateral positions of the swing foot, stance foot, and touchdown location, as well as the intermediate swing point(s), based on the expanded footprint.
Referring now to the figures,
As shown in
Processor(s) 102 may operate as one or more general-purpose processors or special purpose processors (e.g., digital signal processors, application specific integrated circuits, etc.). The processor(s) 102 may be configured to execute computer-readable program instructions 106 that are stored in the data storage 104 and are executable to provide the operations of the robotic system 100 described herein. For instance, the program instructions 106 may be executable to provide functionality of controller(s) 108, where the controller(s) 108 may be configured to cause activation and deactivation of the mechanical components 110 and the electrical components 116.
The data storage 104 may exist as various types of storage configured to hold memory. For example, the data storage 104 may include or take the form of one or more computer-readable storage media that can be read or accessed by processor(s) 102. The one or more computer-readable storage media can include volatile and/or non-volatile storage components, such as optical, magnetic, organic or other memory or disc storage, which can be integrated in whole or in part with processor(s) 102. In some implementations, the data storage 104 can be implemented using a single physical device (e.g., one optical, magnetic, organic or other memory or disc storage unit), while in other implementations, the data storage 104 can be implemented using two or more physical devices, which may communicate via wired or wireless communication. Further, in addition to the computer-readable program instructions 106, the data storage 104 may include additional data such as diagnostic data, among other possibilities.
The robotic system 100 may include at least one controller 108, which may interface with the robotic system 100. The controller 108 may serve as a link between portions of the robotic system 100, such as a link between mechanical components 110 and/or electrical components 116. In some instances, the controller 108 may serve as an interface between the robotic system 100 and another computing device. Further, the controller 108 may serve as an interface between the robotic system 100 and a user(s). The controller 108 may include various components for communicating with the robotic system 100, including a joystick(s), buttons, among others. The example interfaces and communications noted above may be implemented via a wired or wireless connection, or both. The controller 108 may perform other functions for the robotic system 100 as well. Other examples of controllers may exist.
Mechanical components 110 represent possible hardware of the robotic system 100 that may enable the robotic system 100 to operate and perform physical operations. As a few examples, the robotic system 100 may include actuator(s), extendable leg(s) (“legs”), arm(s), wheel(s), one or more structured bodies for housing the computing system or other components, and other mechanical components. The mechanical components 110 may depend on the design of the robotic system 100 and may also be based on the functions and/or tasks the robotic system 100 may be configured to perform. As such, depending on the operation and functions of the robotic system 100, different mechanical components 110 may be available for the robotic system 100 to utilize. In some examples, the robotic system 100 may be configured to add and/or remove mechanical components 110, which may involve assistance from a user and/or other robot. For example, the robotic system 100 may be initially configured with four legs, but may be altered by a user or the robotic system 100 to remove two of the four legs to operate as a biped. Other examples of mechanical components 110 may be included within some implementations.
Additionally, the robotic system 100 may include one or more sensor(s) 112 arranged to sense aspects of the robotic system 100. The sensor(s) 112 may include one or more force sensors arranged to measure load on various components of the robotic system 100. In an example, the sensor(s) 112 may include one or more force sensors on each leg. Such force sensors on the legs may measure the load on the actuators that move one or more members of the legs.
The sensor(s) 112 may further include one or more position sensors. Position sensors may sense the position of the actuators of the robotic system. In one implementation, position sensors may sense the extension, retraction, or rotation of the actuators on the legs of the robot. The sensor(s) 112 may further include one or more velocity and/or acceleration sensors. For instance, the sensor(s) 112 may include an inertial measurement unit (IMU). The IMU may sense velocity and acceleration in the world frame, with respect to the gravity vector. The velocity and acceleration of the IMU may then be translated to the robotic system, based on the location of the IMU in the robotic system and the kinematics of the robotic system. Other sensor(s) 112 are also possible, including proximity sensors, motion sensors, load sensors, touch sensors, depth sensors, ultrasonic range sensors, and infrared sensors, among other possibilities.
The sensor(s) 112 may provide sensor data to the processor(s) 102 to allow for appropriate interaction of the robotic system 100 with the environment as well as monitoring of operation of the systems of the robotic system 100. The sensor data may be used in evaluation of various factors for activation and deactivation of mechanical components 110 and electrical components 116 by controller 108 and/or a computing system of the robotic system 100.
The sensor(s) 112 may provide information indicative of the environment of the robot for the controller 108 and/or computing system to use to determine operations for the robotic system 100. For example, the sensor(s) 112 may capture data corresponding to the terrain of the environment or location of nearby objects, which may assist with environment recognition and navigation, etc. In an example configuration, the robotic system 100 may include a sensor system that includes RADAR, LIDAR, SONAR, VICON®, one or more cameras, a global positioning system (GPS) transceiver, and/or other sensors for capturing information of the environment of the robotic system 100. The sensor(s) 112 may monitor the environment in real-time and detect obstacles, elements of the terrain, weather conditions, temperature, and/or other parameters of the environment for the robotic system 100.
Further, the robotic system 100 may include other sensor(s) 112 configured to receive information indicative of the state of the robotic system 100, including sensor(s) 112 that may monitor the state of the various components of the robotic system 100. The sensor(s) 112 may measure activity of systems of the robotic system 100 and receive information based on the operation of the various features of the robotic system 100, such the operation of extendable legs, arms, or other mechanical and/or electrical features of the robotic system 100. The sensor data provided by the sensors may enable the computing system of the robotic system 100 to determine errors in operation as well as monitor overall functioning of components of the robotic system 100. For example, the computing system may use sensor data to determine a stability of the robotic system 100 during operations as well as measurements related to power levels, communication activities, components that require repair, among other information. As an example configuration, the robotic system 100 may include gyroscope(s), accelerometer(s), and/or other possible sensors to provide sensor data relating to the state of operation of the robot. Further, sensor(s) 112 may also monitor the current state of a function, such as a gait, that the robotic system 100 may currently be operating. Other example uses for the sensor(s) 112 may exist as well.
Additionally, the robotic system 100 may also include one or more power source(s) 114 configured to supply power to various components of the robotic system 100. Among possible power systems, the robotic system 100 may include a hydraulic system, electrical system, batteries, and/or other types of power systems. As an example illustration, the robotic system 100 may include one or more batteries configured to provide charge to components that may receive charge via a wired and/or wireless connection. Within examples, components of the mechanical components 110 and electrical components 116 may each connect to a different power source or may be powered by the same power source. Components of the robotic system 100 may connect to multiple power sources 114 as well.
Within example configurations, any type of power source may be used to power the robotic system 100, such as a gasoline engine. Further, the power source(s) 114 may charge using various types of charging, such as wired connections to an outside power source, wireless charging, combustion, or other examples. Additionally, the robotic system 100 may include a hydraulic system configured to provide power to the mechanical components 110 using fluid power. Components of the robotic system 100 may operate based on hydraulic fluid being transmitted throughout the hydraulic system to various hydraulic motors and hydraulic cylinders, for example. The hydraulic system of the robotic system 100 may transfer a large amount of power through small tubes, flexible hoses, or other links between components of the robotic system 100. Other power sources may be included within the robotic system 100 within examples.
The electrical components 116 may include various components capable of processing, transferring, providing electrical charge or electric signals, for example. Among possible examples, the electrical components 116 may include electrical wires, circuitry, and/or wireless communication transmitters and receivers to enable operations of the robotic system 100. The electrical components 116 may interwork with the mechanical components 110 to enable the robotic system 100 to perform various functions. The electrical components 116 may be configured to provide power from the power source(s) 114 to the various mechanical components 110, for example. Further, the robotic system 100 may include electric motors. Other examples of electrical components 116 may exist as well.
The robot 200 may be a physical representation of the robotic system 100 shown in
Additionally, the computing system may monitor systems of the robot 200 during operation, to determine errors and/or monitor regular operation, for example. In some example configurations, the computing system may serve as a connection between the various systems of the robot 200 that coordinates the operations of the systems together to enable the robot 200 to perform functions. Further, although the operations described herein correspond to a computing system of a robot performing tasks, the computing system may be made of multiple devices, processors, controllers, and/or other entities configured to assist in the operation of the robot. Additionally, the computing system may operate using various types of memory and/or other components.
Although the robot 200 includes four legs 204a-204d in the illustration shown in
Further, different types of robots may use different gaits due to differences in design that may prevent use of certain gaits. Although some gaits may have specific names (e.g., walk, trot, run, bound, gallop, etc.), the distinctions between gaits may overlap. The gaits may be classified based on footfall patterns—the locations on the ground surface for the placement the feet 206a-206d. Similarly, gaits may also be classified based on mechanics.
One or more systems of the robot 200, such as the control system 118, may be configured to operate the legs 204a-204d to cause the robotic 200 to move. Additionally, the robot 200 may include other mechanical components, which may be attached to the robot 200 at various positions. The robot 200 may include mechanical arms, grippers, or other features. In some examples, the legs 204a-204d may have other types of mechanical features that enable control upon various types of surfaces that the robot may encounter, such as wheels, etc. Other possibilities also exist.
As part of the design of the example robot 200, the body 208 of the robot 200 connects to the legs 204a-204d and may house various components of the robot 200. As such, the structure of the body 208 may vary within examples and may further depend on particular operations that a given robot may have been designed to perform. For example, a robot developed to carry heavy loads may have a wide body that enables placement of the load. Similarly, a robot designed to reach high speeds may have a narrow, small body that does not have substantial weight. Further, the body 208 as well as the legs 204 may be developed using various types of materials, such as various metals or plastics. Within other examples, a robot may have a body with a different structure or made of other types of materials.
The sensor(s) 210 of the robot 200 may include various types of sensors, such as the camera or sensing system shown in
The load 212 carried by the robot 200 may represent various types of cargo that the robot 200 may transport. The load 212 may also represent external batteries or other types of power sources (e.g., solar panels) that the robot 200 may utilize. The load 212 represents one example use for which the robot 200 may be configured. The robot 200 may be configured to perform other operations as well.
Additionally, as shown with the robotic system 100, the robot 200 may also include various electrical components that may enable operation and communication between the mechanical features of the robot 200. Also, the robot 200 may include one or more computing systems that include one or more processors configured to perform various operations, including processing inputs to provide control over the operation of the robot 200. The computing system may include additional components, such as various types of storage and a power source, etc.
During operation, the computing system may communicate with other systems of the robot 200 via wired or wireless connections and may further be configured to communicate with one or more users of the robot. As one possible illustration, the computing system may receive an input from a user indicating that the user wants the robot to perform a particular gait in a given direction. The computing system may process the input and may perform an operation that may cause the systems of the robot to perform the requested gait. Additionally, the robot's electrical components may include interfaces, wires, busses, and/or other communication links configured to enable systems of the robot to communicate.
Furthermore, the robot 200 may communicate with one or more users and/or other robots via various types of interfaces. In an example implementation, the robot 200 may receive input from a user via a joystick or similar type of interface. The computing system may be configured to measure the amount of force and other possible information from inputs received from a joystick interface. Similarly, the robot 200 may receive inputs and communicate with a user via other types of interfaces, such as a mobile device or a microphone. The computing system of the robot 200 may be configured to process various types of inputs.
Example implementations are discussed below for determining and avoiding potential leg collisions in an example robot based on a two-dimensional projection of the robot's feet. Flow charts 500 and 900, shown in
In addition, the flow charts 500 and 900 and other operations disclosed herein provide the operation of possible implementations. In this regard, each block may represent a module, a segment, or a portion of program code, which includes one or more instructions executable by a processor for implementing specific logical operations. The program code may be stored on any type of computer readable medium, for example, such as a storage device including a disk or hard drive. In addition, each block may represent circuitry that is wired to perform the specific logical operations.
Further, the term ground surface as used herein is meant to encompass any possible surface or terrain that the robot may encounter, and is not meant to be limiting. For instance, the ground surface may be indoors or outdoors, may be rigid or loose, such as sand or gravel, and may include discontinuities or irregularities such as stairs, rocks, fallen trees, debris, and the like. Numerous other examples exist.
A. First Example Implementation for Avoiding Leg Collisions
At block 502, a biped robot may determine a touchdown location for a swing foot that is coupled to a body of the biped robot. The biped robot may be, for example, the biped robot 400 shown in
The touchdown location for the swing foot represents a target location for the swing foot to contact the ground surface at the end of its swing trajectory. Further, the touchdown location may be determined by the robot 400 at a given frequency throughout a step, such as a frequency in the range of 1-10,000 Hz. For example, the robot may determine the touchdown location for the swing foot every five milliseconds.
The touchdown location for a given step may be determined by the robot 400 based on a number of factors, such as the heading of the robot, and the current needs of the robot to maintain its balance or correct any gait errors that may have occurred. Gait errors may include a slip of the robot's foot or a collision with an obstacle, among other examples. However, in some cases the determined touchdown location may result in a swing trajectory for the swing foot that may collide with the stance leg.
To determine whether such a collision may occur, at block 504, the robot 400 may determine a lateral position of the touchdown location relative to the stance foot. Similarly, at block 506, the robot 400 may determine a lateral position of the swing foot relative to the stance foot. In some cases, one or both of these may indicate that a potential collision is possible. The lateral positions of the robot's feet may be determined based on data received from sensors of the robot 400, such as position and movement sensors in the robot's legs 402, 403, which may provide data regarding the angles of the robot's leg joints.
In some implementations, the robot 400 may expand the single point or footprint representation for the stance foot 405 in order to introduce a factor of safety in avoiding leg collisions. For example, the robot 400 may determine a lateral side 602a, a medial side 602b, a posterior side 602c, and an anterior side 602d of the stance foot 405 that is each outwardly offset from the footprint such that they define an expanded footprint 602, shown as the dashed rectangle in
The distance that the expanded footprint 602 is offset from the structural footprint may be based on a number of factors, such as the robot's configuration, gait, and velocity, among other possibilities. In some examples, the expanded footprint 602 may be offset from the structural footprint of the stance foot 405 within the range of 2-10 centimeters. Although the expanded footprint 602 is shown in
In the example shown in
At block 508, the robot 400 may, based on one or more of the determined lateral positions of the touchdown location 601 and the swing foot 406, each relative to the stance foot 405, determine an intermediate swing point 604 for the swing foot 406. The intermediate swing point represents a two-dimensional point through which the swing foot 406 may move without colliding with the stance foot 405. For example, as shown in
In
At block 510 the robot may cause the swing foot 406 to move to the intermediate swing point 604. For instance, the robot 400 may cause the actuators in the hip, knee, and/or ankle joints to move the robot's leg such that the trajectory of the swing foot 406 follows a line 605 from its current position to the intermediate swing point 604. In some examples, the robot 400 may cause a medial edge 406a of the swing foot 406 to move to the intermediate swing point 604. Alternatively, the robot may determine an expanded footprint, as discussed above, for the swing foot 406, and may cause a medial side of the expanded footprint to move to the intermediate swing point 604. In yet another example, the robot 400 may determine the size of the stance foot's expanded footprint 602 based on the width of the swing foot 406, and may cause the center of the swing foot 406 to move to the intermediate swing point 604. Other possibilities exist.
As noted above, the determination of potential leg collisions and the avoidance of the collisions are accomplished by the robot 400 in two dimensions, by focusing on the forward and lateral positions of the touchdown location and robot's feet 405, 406. Accordingly, the intermediate swing point 604 is a two-dimensional point, without a vertical (z-axis) component. Therefore, while the robot 400 may alter the forward and/or lateral trajectory of the swing foot 406 to cause the swing foot 406 to move to the intermediate swing point 604, the vertical component of the swing foot's trajectory 406 (i.e., it's height off the ground surface) might not need to be adjusted.
At block 512, after causing the causing the swing foot 406 to move to the intermediate swing point 604, the robot 400 may cause the swing foot 406 to move to the touchdown location 601. For example, the robot 400 may cause the trajectory of the swing foot 406 to follow a line 606 from the intermediate swing point 604 to the touchdown location 601. Thus, the robot 400 may place the swing foot 406 in the originally determined touchdown location, while also avoiding the potential collision of its legs.
In some implementations, the robot 400 may repeat the operations of determining the lateral positions of the touchdown location 601 and the swing foot 406, each relative to the stance foot 405, at a frequency until the robot 404 detects an indication to stop repeating the operations. The frequency may be within the range of 1-10,000 Hz. Other frequencies are also possible depending on the size, configuration, and gait of the robot, among other considerations. For example, the robot 400 may determine the relative lateral positions of its feet and the touchdown location every three milliseconds. This may allow the robot 400 to respond to disturbances that may occur during a step, while the swing foot 406 is following a determined swing trajectory. Based on the updated relative lateral positions of the feet and touchdown location, the robot 404 may also update the intermediate swing point 604 as necessary.
To further reduce the computational demand on its processor(s), the robot 400 may detect an indication to stop determining the lateral positions of the touchdown location 601 and the swing foot 406, each relative to the stance foot 405. For example, for a given step of the robot 400, once the swing foot 406 passes the stance foot 405 in the forward direction, a collision of the robot's legs might no longer be likely to occur. Thus, the determination of the relative lateral positions might be temporarily discontinued.
To detect this situation, the robot 400 may determine a forward position of the swing foot 406 relative to the stance foot 405 at a given frequency. The indication to stop repeating the determination of relative lateral positions may include an indication that the forward position of the swing foot 406 is anterior to the anterior side 602d of the stance foot 405. After the swing foot 406 reaches the touchdown location 601, it may become the stance foot for the next step of the robot 400, as the stance foot 405 lifts up from the ground surface to become the swing foot. The robot 400 may then resume determining the relative lateral positions of its feet and the next touchdown location.
In the example shown in
Based on the determined lateral position the swing foot 406 relative to the stance foot 405, the robot 404 may determine an intermediate swing point 703 for the swing foot 406, as shown in
The robot 400 may then cause the swing foot 406 to move to the intermediate swing point 703, for example, along the line 704. For instance, the robot 400 may cause the medial edge 406a of the swing foot 406 to move to the intermediate swing point 703, among other possibilities noted above. After causing the swing foot 406 to move to the intermediate swing point 703, the robot 400 may cause the swing foot 406 to move to the touchdown location 701. For example, the robot 400 may cause the trajectory of the swing foot 406 to follow a line 705 from the intermediate swing point 703 to the touchdown location 701.
In this situation, the robot 400 may determine two intermediate swing points, as shown in
The robot 400 may then cause the swing foot 406 to move to the first intermediate swing point 803, for example, along the line 805. For instance, the robot 400 may cause the medial edge 406a of the swing foot 406 to move to the intermediate swing point 805, among other possibilities noted above. After causing the causing the swing foot 406 to move to the intermediate swing point 803, the robot 400 may cause the swing foot 406 to move to the second intermediate swing point 804. For example, the robot 400 may cause the trajectory of the swing foot 406 to follow a line 806 from the first intermediate swing point 803 to the second intermediate swing point 804. The robot 400 may then cause the swing foot 406 to move to the touchdown location 801, for example, along the line 807.
B. Second Example Implementation for Avoiding Leg Collisions
At block 902, a biped robot may determine a touchdown location for a swing foot that is coupled to a body of the biped robot. The biped robot may be, for example, the biped robot 400 shown in
The touchdown location may correspond to a target location where the swing foot may contact the ground surface at the end of its swing trajectory. The touchdown location for a given step may be determined by the robot 400 based on a number of factors, such as the heading of the robot, and the current needs of the robot to maintain its balance or correct any gait errors that may have occurred. Gait errors may include a slip of the robot's foot or a collision with an obstacle, among other examples. However, in some cases the determined touchdown location may result in a swing trajectory for the swing foot that may collide with the stance leg.
Thus, at block 904, the robot 400 may determine a lateral position of the touchdown location relative to the stance foot. The lateral positions of the robot's feet may be determined based on data received from sensors of the robot 400, such as position and movement sensors in the robot's legs 402, 403, which may provide data regarding the angles of the robot's leg joints. As discussed above with respect to flowchart 700, the lateral position of the touchdown location relative to the stance foot may indicate a potential leg collision.
The stance foot 405 of the robot 400 may have a structural footprint, shown as the solid rectangle in
In the example shown in
In some implementations, the robot 400 may be taking relatively small steps, which may correspond to moving at forward velocity that is relatively low. In these situations, the touchdown location 1001 for the swing foot 406 of the robot 400 might not be forward of the stance foot 405, as shown in
Therefore, to detect these potential situations, the robot 400 may, at block 906, determine a forward velocity of the robot 400. The forward velocity may be determined based on data received from sensors of the robot 400, such as movement and positions sensors in the robot's legs 402, 403, or an inertial measurement unit within the robot's body 404. Other examples are also possible. The robot 400 may determine that the forward velocity of the robot 400 is less than a non-zero threshold velocity. The threshold velocity may be within the range of 0.1 to 0.8 meters per second. For example, the non-zero threshold velocity may be 0.5 meters per second. Other thresholds are possible, and may vary depending on the configuration, size, and gait of the robot.
At block 908, the robot 400 may, based on the determined forward velocity of the robot 400 and the determined lateral position of the touchdown location 1001 relative to the stance foot 405, update the touchdown location 1001. For example, the robot 400 may determine that the forward velocity of the robot 400 is less than the non-zero threshold velocity, which may indicate relatively small steps, and that the touchdown location 1001 is laterally outside of the stance foot 405. These two determinations, in conjunction, may indicate that the touchdown location 1001 is overlapping with the stance foot 405. Thus, the robot 400 may update the touchdown location 1001 by moving it such that the swing foot 406 moves along a swing trajectory that does not collide with the stance foot 405.
For example, the robot 400 may move the touchdown location 1001 anterior to the anterior side 602d of the stance foot 405, as shown in
In some implementations, the robot 400 may need to take a backward step. For example, if the robot 400 has a relatively low or perhaps a zero forward velocity, a disturbance may cause the robot 400 to begin to fall backwards. In this case, the same logic as above may apply in the lateral direction, but may be reversed in the forward direction. Thus, the robot 400 may update the touchdown location 1001 by moving it posterior to the posterior side of the stance foot 405.
At block 910, the robot 400 may cause the swing foot 406 to move to the updated touchdown location 1003. In some cases, where the robot 400 has determined the intermediate swing point 1004, the robot may cause the swing foot 406 to move the intermediate swing point 1004, on line 1005 for example, before causing the swing foot 406 to move to the updated touchdown location 1003. For instance, the robot 400 may cause the medial edge 406a of the swing foot 406 to move to the intermediate swing point 1004, among other possibilities noted above. The robot 400 may then cause the swing foot 406 to move to the updated touchdown location 1003 along line 1006, which may be collinear with line 1005.
As discussed above with respect to flowchart 500, the robot 400 may repeat the operations described with respect to flowchart 900 at a given frequency. Similarly, the robot 400 may determine the forward position of the swing foot with respect to the stance foot 405, and may stop repeating the operations upon detecting an indication that the swing foot 405 is anterior to the anterior side 602d of the stance foot.
While various implementations and aspects have been disclosed herein, other aspects and implementations will be apparent to those skilled in the art. The various implementations and aspects disclosed herein are for purposes of illustration and are not intended to be limiting, with the true scope and spirit being indicated by the following claims.
Patent | Priority | Assignee | Title |
11383381, | Aug 06 2019 | BOSTON DYNAMICS, INC | Footstep contact detection |
11447195, | Aug 06 2019 | BOSTON DYNAMICS, INC | Leg swing trajectories |
11999423, | Aug 06 2019 | Boston Dynamics, Inc. | Leg swing trajectories |
Patent | Priority | Assignee | Title |
4834200, | Dec 15 1986 | Agency of Industrial Science & Technology; Ministry of International Trade & Industry | Method and apparatus for dynamic walking control of robot |
5151859, | Jun 29 1989 | Honda Giken Kogyo Kabushiki Kaisha | Legged walking robot and system for controlling the same |
5355064, | Mar 04 1992 | Honda Giken Kogyo Kabushiki Kaisha | Control system for legged mobile robot |
5416393, | May 20 1992 | Honda Giken Kogyo Kabushiki Kaisha | Legged mobile robot foot structure |
5432417, | Apr 30 1992 | Honda Giken Kogyo Kabushiki Kaisha | Locomotion control system for legged mobile robot |
5459659, | May 29 1992 | Honda Giken Kogyo Kabushiki Kaisha | Attitude stabilization control system for a legged mobile robot |
5644204, | Nov 03 1994 | Anti-slip control for a legged robot and realisitc simulation of a legged creature | |
5737217, | Dec 30 1993 | Honda Giken Kogyo Kabushiki Kaisha | System for detecting and controlling the position of a mobile robot |
5808433, | Sep 29 1995 | Honda Giken Kogyo Kabushiki Kaisha | Method of generating gait of legged walking robot and system for controlling its locomotion |
5838130, | Jan 25 1996 | Honda Giken Kogyo Kabushiki Kaisha | Locomotion control system of legged mobile robot |
5974366, | Dec 18 1996 | Honda Giken Kogyo Kabushiki Kaisha | Apparatus for detecting the landing position of foot sole of legged moving robot |
6064167, | Aug 04 1997 | Honda Giken Kogyo Kabushiki Kaisha | Control system for controlling the knee joint actuators of a legged robot in response to a detected fall condition so as to lower the center of gravity of the robot |
6177776, | Jun 20 1997 | Honda Giken Kogyo Kabushiki Kaisha | Apparatus for recognizing the landed state of foot of legged moving robot |
6374157, | Nov 30 1998 | Sony Corporation | Robot device and control method thereof |
6484068, | Jul 24 2001 | BOSTON DYNAMICS, INC | Robot apparatus and method for controlling jumping of robot device |
6493607, | Nov 09 1994 | Amada America, Inc.; Amada Company, Ltd. | Method for planning/controlling robot motion |
6802382, | Apr 03 2000 | Sony Corporation; Jinichi, Yamaguchi | Robot moving on legs and control method therefor, and relative movement measuring sensor for robot moving on legs |
6943520, | Jun 07 2001 | Japan Science and Technology Agency | Two-legs walking type moving device, method and device for controlling its walking |
6992455, | Feb 15 2002 | Sony Corporation; Yamaguchi, Jinichi | Leg device for leg type movable robot, and method of controlling leg type movable robot |
6992457, | Feb 18 2002 | Japan Science and Technology Agency | Two-legged walding locomotion apparatus and its walking controller |
6999851, | Aug 30 2002 | Sony Corporation | Robot apparatus and motion controlling method therefor |
7013201, | Nov 24 1999 | Sony Corporation; Jinichi, Yamaguchi | Legged mobile robot and method of controlling operation of the same |
7076331, | Nov 30 1998 | Sony Corporation | Robot, method of robot control, and program recording medium |
7120518, | Apr 27 2001 | Honda Giken Kogyo Kabushiki Kaisha | Device for generating motion of legged mobile robot |
7236852, | Oct 11 2002 | Sony Corporation; Yamaguchi, Jinichi | Motion controlling apparatus and method and remote controlling apparatus and method for legged mobile robot |
7386364, | Mar 15 2002 | Sony Corporation; Yamaguchi, Jinichi | Operation control device for leg-type mobile robot and operation control method, and robot device |
7603234, | Jun 27 2003 | HONDA MOTOR CO , LTD | Controller of legged mobile robot |
7606634, | Nov 27 2004 | HONDA MOTOR CO , LTD | Control device for mobile body |
7657345, | Aug 25 2003 | Sony Corporation; ADVANCED TELECOMMUNICATIONS RESEARCH INSTITUTE INTERNATIONAL | Robot and attitude control method of robot |
7734377, | Oct 15 2004 | HONDA MOTOR CO , LTD | Gait generator of legged mobile robot |
7734378, | Jun 27 2003 | HONDA MOTOR CO , LTD | Gait generation device for legged mobile robot |
7881824, | Mar 18 2002 | Sony Corporation; Jinichi Yamaguchi | System and method of controlling a legged locomotion robot |
7949430, | Nov 29 2006 | FLORIDA INSTITUTE FOR HUMAN & MACHINE COGNITION, INC | Determination of foot placement for humanoid push recovery |
8060253, | Mar 31 2004 | HONDA MOTOR CO , LTD | Systems and methods for controlling a legged robot based on rate of change of angular momentum |
8108070, | Jul 18 2006 | Toyota Jidosha Kabushiki Kaisha | Robot and control method thereof |
8172013, | Oct 25 2007 | Toyota Jidosha Kabushiki Kaisha | Legged robot and control method of legged robot |
8195332, | Nov 21 2007 | Honda Motor Co., Ltd.; Florida Institute for Human & Machine Cognition, Inc. (IHMC) | Learning capture points for humanoid push recovery |
8239084, | Sep 11 2006 | Hitachi, LTD | Moving device |
8306657, | Oct 28 2009 | Honda Motor Co., Ltd. | Control device for legged mobile robot |
8311731, | Mar 23 2007 | Arriver Software AB | Robots with collision avoidance functionality |
8332068, | Dec 19 2008 | Honda Motor Co., Ltd. | Intelligent stepping for humanoid fall direction change |
8386076, | Sep 12 2007 | Toyota Jidosha Kabushiki Kaisha | Legged robot and its control method |
8396593, | Mar 01 2010 | Honda Motor Co., Ltd. | Gait generating device of legged mobile robot |
8457830, | Mar 22 2010 | In-line legged robot vehicle and method for operating | |
8532824, | Dec 28 2009 | Honda Motor Co., Ltd. | Control device for robot |
8565921, | Jul 22 2010 | Toyota Jidosha Kabushiki Kaisha | Biped walking robot |
8583283, | Mar 23 2004 | Honda Motor Co., Ltd. | Legged mobile robot and control system thereof |
8630763, | Mar 22 2010 | Method of operating an in-line legged robot vehicle | |
8688307, | Sep 29 2008 | HONDA MOTOR CO , LTD | Moving device and method for controlling same |
8738178, | Oct 19 2005 | Korea Institute of Science and Technology | Method for controlling the walk of humanoid robot |
8825391, | Aug 04 2011 | GOOGLE LLC | Building elevation maps from laser data |
8849454, | Mar 21 2011 | HONDA MOTOR CO , LTD | Humanoid robot push recovery on level and non-level ground |
8855820, | Jan 10 2012 | Honda Motor Co., Ltd. | Leg motion trajectory generation device for legged mobile robot |
8855821, | May 30 2011 | SAMSUNG ELECTRONICS CO , LTD | Robot and control method thereof |
8924021, | Apr 27 2006 | HONDA MOTOR CO LTD | Control of robots from human motion descriptors |
8948956, | Nov 20 2009 | Murata Machinery, Ltd | Autonomous mobile body and control method of same |
8965573, | Jun 30 2009 | SOFTBANK ROBOTICS EUROPE | Method for controlling the walking motion of a mobile robot, and robot implementing said method |
9044862, | Aug 10 2009 | Samsung Electronics Co., Ltd. | Path planning apparatus and method for robot |
9102055, | Mar 15 2013 | GOOGLE LLC | Detection and reconstruction of an environment to facilitate robotic interaction with the environment |
9207678, | May 07 2013 | HANWHA AEROSPACE CO , LTD | Method and apparatus for constructing map for mobile robot |
9266233, | Mar 15 2013 | SRI International | Exosuit system |
9317743, | May 10 2012 | President and Fellows of Harvard College | System and method for automatically discovering, characterizing, classifying and semi-automatically labeling animal behavior and quantitative phenotyping of behaviors in animals |
9352470, | Nov 11 2014 | BOSTON DYNAMICS, INC | Yaw slip handling in a robotic device |
20020183897, | |||
20030009259, | |||
20030154201, | |||
20040044440, | |||
20040099450, | |||
20040167641, | |||
20040172165, | |||
20040193323, | |||
20040205417, | |||
20040230340, | |||
20040236467, | |||
20050021176, | |||
20050067993, | |||
20050075755, | |||
20050077856, | |||
20050110448, | |||
20050113973, | |||
20050120820, | |||
20050216097, | |||
20050228539, | |||
20050240307, | |||
20060064203, | |||
20060076167, | |||
20060173578, | |||
20060247800, | |||
20070003915, | |||
20070126387, | |||
20070150095, | |||
20070152620, | |||
20070156283, | |||
20070193789, | |||
20070220637, | |||
20070227786, | |||
20070241713, | |||
20080065269, | |||
20080133055, | |||
20080160873, | |||
20080208391, | |||
20090005906, | |||
20090030530, | |||
20090171503, | |||
20090306821, | |||
20090312867, | |||
20090325699, | |||
20100017028, | |||
20100057253, | |||
20100113980, | |||
20100126785, | |||
20100161120, | |||
20100161126, | |||
20100174409, | |||
20100252395, | |||
20100277483, | |||
20100292838, | |||
20110009241, | |||
20110022232, | |||
20110098857, | |||
20110098860, | |||
20110172825, | |||
20110178637, | |||
20110224827, | |||
20110231050, | |||
20110257764, | |||
20110264264, | |||
20110301756, | |||
20120072026, | |||
20120158175, | |||
20120203359, | |||
20120245734, | |||
20120259463, | |||
20120277907, | |||
20120310412, | |||
20120316682, | |||
20120316683, | |||
20120316684, | |||
20130079929, | |||
20130144439, | |||
20130178983, | |||
20130184861, | |||
20130206488, | |||
20130238122, | |||
20130238183, | |||
20140019082, | |||
20150051734, | |||
20150073592, | |||
20150120044, | |||
20150134080, | |||
20150202768, | |||
JP2008183701, | |||
KR100815247, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Nov 11 2014 | BLANKESPOOR, KEVIN | Google Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 039387 | /0032 | |
Aug 09 2016 | Boston Dynamics, Inc. | (assignment on the face of the patent) | / | |||
May 15 2017 | Google Inc | BOSTON DYNAMICS, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 043546 | /0004 | |
Jun 14 2021 | BOSTON DYNAMICS, INC | BOSTON DYNAMICS, INC | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 057711 | /0202 | |
Jun 14 2021 | BOSTON DYNAMICS, INC | BOSTON DYNAMICS, INC | CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATIONS NUMBERS 63127573 AND 11 302759 AND THE CITY OF THE ASSIGNEE PREVIOUSLY RECORDED AT REEL: 057111 FRAME: 0202 ASSIGNOR S HEREBY CONFIRMS THE ASSIGNMENT | 057964 | /0415 |
Date | Maintenance Fee Events |
Nov 03 2021 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Date | Maintenance Schedule |
May 15 2021 | 4 years fee payment window open |
Nov 15 2021 | 6 months grace period start (w surcharge) |
May 15 2022 | patent expiry (for year 4) |
May 15 2024 | 2 years to revive unintentionally abandoned end. (for year 4) |
May 15 2025 | 8 years fee payment window open |
Nov 15 2025 | 6 months grace period start (w surcharge) |
May 15 2026 | patent expiry (for year 8) |
May 15 2028 | 2 years to revive unintentionally abandoned end. (for year 8) |
May 15 2029 | 12 years fee payment window open |
Nov 15 2029 | 6 months grace period start (w surcharge) |
May 15 2030 | patent expiry (for year 12) |
May 15 2032 | 2 years to revive unintentionally abandoned end. (for year 12) |