US20170080564A1 - Standby mode of a humanoid robot - Google Patents
Standby mode of a humanoid robot Download PDFInfo
- Publication number
- US20170080564A1 US20170080564A1 US15/311,739 US201515311739A US2017080564A1 US 20170080564 A1 US20170080564 A1 US 20170080564A1 US 201515311739 A US201515311739 A US 201515311739A US 2017080564 A1 US2017080564 A1 US 2017080564A1
- Authority
- US
- United States
- Prior art keywords
- robot
- executing
- standby
- optimization
- parameters
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
- 238000005457 optimization Methods 0.000 claims abstract description 33
- 238000000034 method Methods 0.000 claims abstract description 30
- 238000005265 energy consumption Methods 0.000 claims abstract description 9
- 238000004590 computer program Methods 0.000 claims abstract description 7
- 230000033001 locomotion Effects 0.000 claims description 31
- 238000011161 development Methods 0.000 abstract description 15
- 230000018109 developmental process Effects 0.000 abstract description 15
- 230000000694 effects Effects 0.000 description 22
- 241000282414 Homo sapiens Species 0.000 description 12
- 230000003993 interaction Effects 0.000 description 12
- 230000036544 posture Effects 0.000 description 8
- 230000000284 resting effect Effects 0.000 description 7
- 238000001514 detection method Methods 0.000 description 6
- 230000006399 behavior Effects 0.000 description 5
- 230000008451 emotion Effects 0.000 description 5
- 210000003128 head Anatomy 0.000 description 5
- 230000036541 health Effects 0.000 description 4
- 210000002414 leg Anatomy 0.000 description 4
- 238000007726 management method Methods 0.000 description 4
- 230000003278 mimic effect Effects 0.000 description 4
- 230000007958 sleep Effects 0.000 description 4
- 238000004891 communication Methods 0.000 description 3
- 238000001816 cooling Methods 0.000 description 3
- 230000006266 hibernation Effects 0.000 description 3
- 238000012544 monitoring process Methods 0.000 description 3
- 238000012913 prioritisation Methods 0.000 description 3
- 230000008569 process Effects 0.000 description 3
- 238000012545 processing Methods 0.000 description 3
- 230000008439 repair process Effects 0.000 description 3
- 230000029058 respiratory gaseous exchange Effects 0.000 description 3
- 238000012360 testing method Methods 0.000 description 3
- 230000008901 benefit Effects 0.000 description 2
- 230000000295 complement effect Effects 0.000 description 2
- 230000001934 delay Effects 0.000 description 2
- 238000013461 design Methods 0.000 description 2
- 238000006073 displacement reaction Methods 0.000 description 2
- 210000005069 ears Anatomy 0.000 description 2
- 230000002996 emotional effect Effects 0.000 description 2
- 210000003414 extremity Anatomy 0.000 description 2
- 230000006870 function Effects 0.000 description 2
- 230000005484 gravity Effects 0.000 description 2
- 230000004807 localization Effects 0.000 description 2
- 230000007774 longterm Effects 0.000 description 2
- 230000008447 perception Effects 0.000 description 2
- 230000003068 static effect Effects 0.000 description 2
- 230000000007 visual effect Effects 0.000 description 2
- 230000002618 waking effect Effects 0.000 description 2
- 241001282135 Poromitra oscitans Species 0.000 description 1
- 206010041235 Snoring Diseases 0.000 description 1
- 206010044565 Tremor Diseases 0.000 description 1
- 206010048232 Yawning Diseases 0.000 description 1
- 230000009471 action Effects 0.000 description 1
- 230000004913 activation Effects 0.000 description 1
- 238000001994 activation Methods 0.000 description 1
- 239000008186 active pharmaceutical agent Substances 0.000 description 1
- 238000004458 analytical method Methods 0.000 description 1
- 210000003423 ankle Anatomy 0.000 description 1
- 230000002146 bilateral effect Effects 0.000 description 1
- 230000015572 biosynthetic process Effects 0.000 description 1
- 230000004397 blinking Effects 0.000 description 1
- 238000004364 calculation method Methods 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 230000001055 chewing effect Effects 0.000 description 1
- 230000009849 deactivation Effects 0.000 description 1
- 230000003247 decreasing effect Effects 0.000 description 1
- 238000003745 diagnosis Methods 0.000 description 1
- 230000037213 diet Effects 0.000 description 1
- 235000005911 diet Nutrition 0.000 description 1
- 239000012636 effector Substances 0.000 description 1
- 210000001513 elbow Anatomy 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 230000007613 environmental effect Effects 0.000 description 1
- 210000002683 foot Anatomy 0.000 description 1
- 210000001061 forehead Anatomy 0.000 description 1
- 239000011521 glass Substances 0.000 description 1
- 210000004247 hand Anatomy 0.000 description 1
- 230000003862 health status Effects 0.000 description 1
- 230000001771 impaired effect Effects 0.000 description 1
- 230000010365 information processing Effects 0.000 description 1
- 230000000977 initiatory effect Effects 0.000 description 1
- 230000002452 interceptive effect Effects 0.000 description 1
- 210000003127 knee Anatomy 0.000 description 1
- 210000003141 lower extremity Anatomy 0.000 description 1
- 239000000314 lubricant Substances 0.000 description 1
- 238000012423 maintenance Methods 0.000 description 1
- 230000007257 malfunction Effects 0.000 description 1
- 238000005259 measurement Methods 0.000 description 1
- 210000003739 neck Anatomy 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000010355 oscillation Effects 0.000 description 1
- 210000004197 pelvis Anatomy 0.000 description 1
- 230000000704 physical effect Effects 0.000 description 1
- 238000012552 review Methods 0.000 description 1
- 230000033764 rhythmic process Effects 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 210000002832 shoulder Anatomy 0.000 description 1
- 230000003997 social interaction Effects 0.000 description 1
- 208000013623 stereotypic movement disease Diseases 0.000 description 1
- 238000003786 synthesis reaction Methods 0.000 description 1
- 238000011144 upstream manufacturing Methods 0.000 description 1
- 238000012795 verification Methods 0.000 description 1
- 238000005303 weighing Methods 0.000 description 1
- 210000000707 wrist Anatomy 0.000 description 1
Images
Classifications
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B25—HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
- B25J—MANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
- B25J9/00—Programme-controlled manipulators
- B25J9/16—Programme controls
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B25—HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
- B25J—MANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
- B25J9/00—Programme-controlled manipulators
- B25J9/16—Programme controls
- B25J9/1674—Programme controls characterised by safety, monitoring, diagnostic
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06N—COMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
- G06N3/00—Computing arrangements based on biological models
- G06N3/004—Artificial life, i.e. computing arrangements simulating life
- G06N3/008—Artificial life, i.e. computing arrangements simulating life based on physical entities controlled by simulated intelligence so as to replicate intelligent life forms, e.g. based on robots replicating pets or humans in their appearance or behaviour
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B25—HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
- B25J—MANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
- B25J19/00—Accessories fitted to manipulators, e.g. for monitoring, for viewing; Safety devices combined with or specially adapted for use in connection with manipulators
- B25J19/02—Sensing devices
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B25—HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
- B25J—MANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
- B25J9/00—Programme-controlled manipulators
- B25J9/16—Programme controls
- B25J9/1656—Programme controls characterised by programming, planning systems for manipulators
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B25—HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
- B25J—MANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
- B25J9/00—Programme-controlled manipulators
- B25J9/16—Programme controls
- B25J9/1679—Programme controls characterised by the tasks executed
- B25J9/1682—Dual arm manipulator; Coordination of several manipulators
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B25—HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
- B25J—MANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
- B25J19/00—Accessories fitted to manipulators, e.g. for monitoring, for viewing; Safety devices combined with or specially adapted for use in connection with manipulators
- B25J19/0054—Cooling means
Definitions
- This patent relates to the field of data processing and more particularly to standby modes of a robot.
- Companion robots advantageously can establish an emotional relationship with human beings, with interactive dialogs and physical actions performed in the tangible reality.
- Standby methods known in the technical field of personal computing are not well adapted to robots, and a fortiori to humanoid robots.
- a computer-implemented method of executing a standby mode for a robot comprising the steps of measuring one or more parameters associated with one or more parts of the robot (e.g. the temperature of one or more motors); receiving one or more standby optimization rules associated with said parameters (e.g. maximizing the dissipation of the heat of the motor), and executing one or more received standby optimization rules (e.g. executing a body animation to cool down motors).
- the monitored parameters comprise motor temperature measures and/or energy consumption values and/or values quantifying signs of wear.
- Optimization rules comprise the minimization of the consumption of energy and/or the minimization of wear and/or the maximization of the dissipation of the heat.
- a predefined animation can be associated a valuable social engagement score.
- FIG. 1 illustrates the global technical environment of the invention
- FIG. 2 details some aspects of an embodiment of the method
- FIG. 3 details some particular aspects of a specific embodiment of the method.
- Humanoid robots are an emerging form of “social technology”. As companion robots, humanoid robots are increasingly considered as partners by human users, maintaining a durable if not emotional relationship and continuously learning (from each other, i.e. robots learning from users and vice-versa). For example, and even if being only machines, personal robots present a great value for coaching activities (e.g. diet, sport or education). Compared to personal computers, simulated emotions and body language allow for more engaging, persuasive, convincing or otherwise trustful relationships.
- Humanoid robots are information processing machines and therefore a wide range of comparisons with personal computers can be established. Some aspects can be considered common ground. Some other aspects are very different when comparing personal robots and personal computers.
- a companion robot can follow its owner (i.e. present displacement capabilities) and can touch objects or interact with its environment.
- owner i.e. present displacement capabilities
- design a personal computer is lacking such various environmental feedbacks.
- This “multimodal” feature or characteristics implies deep consequences regarding the management of applications on the robot (among other aspects, e.g. including the management of standby modes).
- a particular difference relates to the handling of standby modes, wherein in addition to energy savings aspects, a robot can incidentally and/or opportunistically and/or on-purpose evaluate, select and further execute different animations or sequences of movements.
- animations or motions for example can cool down motors and/or enable system verifications, while maintaining or developing the relationship with human users (“user experience”).
- FIG. 1 illustrates the global and technical environment of the invention.
- a robot 130 comprises sensors and actuators.
- a logic or “mind” 100 is implemented in the robot or associated with it (for example remotely) and comprises a collection of software 110 and hardware components 120 .
- the robot 130 is interacting (by bilateral or two-ways communications 140 , including one or more dialog sessions) with one or more users 150 .
- Said one or more users can access other computing devices 160 (for example a personal computer such as a wearable computer or a smartphone or a tablet), which can be connected devices (in communication with a cloud of servers and/or a fleet of other robots or connected objects, etc).
- a connected device can be a wearable computer (e.g. watch, glasses, immersive helmet, etc).
- the specific robot 130 on the figure is taken as an example only of a humanoid robot in which the invention can be implemented.
- the lower limb of the robot on the figure is not functional for walking, but can move in any direction on its base which rolls on the surface on which it lays.
- the invention can be easily implemented in a robot which is fit for walking.
- the robot can comprise various kinds of sensors. Some of them are used to control the position and movements of the robot. This is the case, for instance, of an inertial unit, located in the torso of the robot, comprising a 3-axis gyrometer and a 3-axis accelerometer.
- the robot can also include two 2D color RGB cameras on the forehead of the robot (top and bottom).
- a 3D sensor can also be included behind the eyes of the robot.
- the robot can also optionally comprise laser lines generators, for instance in the head and in the base, so as to be able to sense its relative position to objects/beings in its environment.
- the robot can also include microphones to be capable of sensing sounds in its environment.
- the robot of the invention can also include sonar sensors, possibly located at the front and the back of its base, to measure the distance to objects/human beings in its environment.
- the robot can also include tactile sensors, on its head and on its hands, to allow interaction with human beings. It can also include bumpers on its base to sense obstacles it encounters on its route.
- the robot of the invention can also include LEDs, for instance in its eyes, ears and on its shoulders and loudspeakers (for example located in its ears).
- the robot can communicate with a base station, with other connected devices or with other robots through various networks (3G, 4G/LTE, Wifi, BLE, mesh, etc).
- the robot comprises a battery or source of energy.
- the robot can access a charging station fit for the type of battery that it includes. Position/movements of the robots are controlled by its motors, using algorithms which activate the chains defined by each limb and effectors defined at the end of each limb, in view of the measurements of the sensors.
- the robot can embed a tablet with which it can communicate messages (audio, video, web pages) to its environment, or receive entries from users through the tactile interface of the tablet.
- the robot does not embed or present a screen but it does have a video projector, with which data or information can be projected on surfaces in the vicinity of the robot. Said surfaces can be flat (e.g. floor) or not (e.g. deformations of the projecting surfaces can be compensated to obtain a substantially flat projection).
- embodiments of the invention remain valid: the claimed interaction model is only supplemented or complemented by visual interaction means. In any case, would the graphical means be out of order or deactivated on purpose, the conversational mode of interaction remains.
- the robot does not comprise such graphical user interface means.
- Existing humanoid robots are generally provided with advanced speech capabilities but are generally not provided with GUI.
- Increasing communities of users will probably not use graphical means (e.g. tablet, smartphone), even as a complement, to communicate with the robot, by choice and/or necessity (young people, impaired persons, because of a practical situation, etc).
- the collection of software 110 (non-exhaustively) comprises software modules or objects or software code parts, in interaction with one another, including “extractors” 111 , “activity suggestions” 112 , “mind prioritization” 113 , “package manager” 114 , “User historical data” 115 , “Focused Autonomous activity” 116 and “Focused Dialog Topic” 117 and a “Health Monitoring Service” 118 .
- An “Extractor Service” 111 generally senses or perceives something internal or external of the robot and provides short term data into the robot's memory.
- An Extractor service receives input readings from the robot sensors; these sensor readings are preprocessed so as to extract relevant data in relation to the position of the robot, identification of objects/human beings in its environment, distance of said objects/human beings, words pronounced by human beings or emotions thereof. Extractor services in particular comprise: face recognition, people perception, engagement zones, waving detection, smile detection, gaze detection, emotion detection, voice analysis, speech recognition, sound localization, movement detection, panoramic compass, robot pose, robot health diagnosis, battery, QR code handling, home automation, tribes, time and schedule.
- An “Actuator Service” makes the robot 130 physically do or perform actions.
- Motion tracker, LEDs, Behavior manager are examples of “Actuator Services”.
- a “Data Service” provides long-term stored data. Examples of Data Services are a User Session Service 115 , which stores user data, and their history of what they have done with the robot and a Package Manager Service 114 , which provides a scalable storage of procedures executed by the robot, with their high level definition, launch conditions and tags. “Package Manager” in particular provides the scalable storage of Activities and Dialogs, and the Manifest. The “Manifest” contains metadata such as launch conditions, tags, and high level descriptions.
- a “Mind Service” (for example a service Mind Prioritization 113 ) is one that will be controlled by the robot's central “Mind” when it is initiating action.
- “Mind Services” tie together “Actuator services” 130 , “Extractor services” 111 and “Data services” 115 .
- Basic Awareness is a “Mind Service”. It subscribes to “Extractor Services” such as People perception, Movement detection, and Sound localization to tell the Motion Service to move.
- the “Mind” 113 configures Basic Awareness's behavior based on the situation. At other times, Basic Awareness is either acting own its own, or is being configured by a Running Activity.
- “Autonomous Life” is a Mind Service. It executes behavior activities. Based on the context of a situation, the Mind can tell autonomous life what activity to focus (“Focused Autonomous Activity” 116 ). Metadata in manifests tie this information into the mind. Any activity can have access to one or more of the Operating System APIs. Activities can also directly tell Autonomous Life what activity to focus, or tell the Dialog Service what topic to focus on.
- the “Dialog” service can be configured as a Mind Service. It subscribes to the speech recognition extractor and can use “Animated Speech Actuator Service” to speak. Based on the context of a situation, the Mind can tell the Dialog what topics to focus on (a “Dialog Topic”).
- the “Dialog” service also has its algorithms for managing a conversation and is usually acting on its own.
- One component of the Dialog service can be a “Focused Dialog Topic” service 117 . Dialog Topics can programmatically tell the Mind to switch focus to (or execute or launch) a different Activity or Dialog Topic, at any time.
- One example of possible method to determine the Dialog Topic can comprise: at the moment that an dialog topic or activity's launch conditions become true or false, a list of all possible Activities or Dialog Topics for the moment is sent to the Mind; the list is filtered according to activity prioritization; the list order is randomized; the list is sorted (or scored) to give precedence to Activities or Dialog Topics that are “unique” and have been started less often; a special check to make sure the top Dialog Topic or Activity in this list isn't the same activity as the previous activity that was executed. The list can be again sorted and filtered according to the preferences of the user.
- the robot can implement a “health monitoring” service 118 .
- a “health monitoring” service 118 can act as a daemon or a “watchdog”, to review or control or regulate the different priorities of the robot.
- Such a service can monitor (continuously, intermittently or periodically) the status of the internal components of the robot and measure or anticipate or predict or correct hardware failures.
- the fleet e.g. installed base
- the embedded service can continuously detect faulty situations and synchronize them with a “cloud” service (once every minute for example).
- the “health monitoring” service 118 can contribute, if not lead, the different standby modes disclosed hereafter.
- Hardware components 120 comprise processing means 121 , memory means 122 , Input/Output I/O means 123 , mass storage means 124 and network access means 125 , said means interacting with one another (caching, swapping, distributed computing, load balancing, etc).
- the processing means 121 can be a CPU (multicore or manycore) or a FPGA.
- the memory means 122 comprise one or more of a flash memory or a random access memory.
- the I/O means 123 can comprise one or more of a screen (e.g. touch screen), a light or LED, a haptic feedback, a virtual keyboard, a mouse, a trackball, a joystick or a projector (including a laser projector).
- the storage means 124 can comprise one or more of a hard drive or a SSD.
- the network access means can provide access to one or more networks such as a 3G, 4G/LTE, Wifi, BLE or a mesh network.
- Network traffic can be encrypted (e.g. tunnel, SSL, etc).
- computing resources can be remotely accessed, for example as a complement to local resources (available in the robot itself). For example, further CPU units can be accessed through the Cloud for voice recognition computing tasks.
- Computing resources also can be shared. In particular, a plurality of robots can share resources. Connected devices in the vicinity of the robot also can share resources to some extent, for example via secured protocols.
- Display means also can be shared. For example, the television can be used as a further display by the robot when passing by.
- FIG. 2 details some aspects of an embodiment of the method.
- a computer-implemented method of executing a standby mode for a robot comprising the steps of measuring 220 one or more parameters associated with one or more parts of the robot (e.g. the temperature of one or more motors); receiving 230 one or more standby optimization rules associated with said parameters (e.g. maximizing the dissipation of the heat of the motor), and executing 240 one or more received standby optimization rules (e.g. executing a body animation to cool down motors).
- the monitored parameters at step 220 comprise motor temperature measures and/or energy consumption values and/or values quantifying signs of wear.
- optimization rules 231 comprise the minimization of the consumption of energy and/or the minimization of wear and/or the maximization of the dissipation of the heat.
- a predefined animation can be played by the robot.
- Said animation can be associated with a high score (user-friendly attitude, “social engagement”). This criterion can be measured afterwards, but also can be taken account upstream in order to select which animation to execute.
- a computer-implemented method of executing a standby mode in or by a robot comprising the steps of measuring one or more parameters associated with one or more parts of the robot; receiving one or more standby optimization rules associated with said parameters, and executing one or more received standby optimization rules.
- Events and/or parameters associated with one or more parts of the robot are continuously (or intermittently or periodically) monitored (e.g. watchdog or daemon executing on the robot itself or on/by some other connected devices or robots).
- Parts of the robot comprise articular chains (arm, hand, leg, foot or head for example) and its associated motors, for example located at articular locations (wrist, elbow, shoulder, knee, ankle, neck, pelvis, etc).
- Standby optimization rules can be stored locally or accessed through a network.
- Rules can be predefined or not. Rules can be static or dynamically defined. In some embodiments, rules can depend on the set of monitored parameters. Rules can also be defined by the user, at least partly (behavior type, energy saving profile, etc), or be defined by the manufacturer or the seller of the robot.
- these rules can aim to optimize the system status of the robot (e.g. check system parts, cool down motors, etc) and/or (i.e. in combination or alternatively) to adopt a user-friendly attitude (e.g. socially engaging posture or animation).
- a user-friendly attitude e.g. socially engaging posture or animation
- the motion controller can check the current temperature of the motors of the chain at step 320 , and according to some embodiments can choose an idle or resting posture 330 for that chain, thereby and for example minimizing the power consumption of the hottest joints.
- the motion controller can optionally play a “safe” animation 340 , e.g. have to robot to execute a slow animation (at low speed, with low energy consumption).
- a robot can enter or leave different machine states (generally referred to as “standby”): hibernation state, sleep state or mode, or otherwise idle state.
- sleep state or mode or otherwise idle state.
- these particular states can be designed or adapted so that to optimize system parameters.
- the companion robot when unsolicited or otherwise inactive can remain in certain resting or standby states or modes, sometimes analogous to computer systems, to restore its abilities and/or cool down its motors and/or perform checkup tasks and/or save energy and/or to appear quiet. Different modes or states are possible. By decreasing energy consumption levels, the robot can “actively standby”, “standby”, “hibernate”, “sleep” or “power off” (the terminology can change, different combinations of deactivated internal circuits being possible).
- the “active standby” mode can mean that the robot powers off a selected but limited number of internal components to save energy. Waking up times delays generally very short.
- the “standby” mode increases the number of inactive components, and waking-up delays can be increased. Th hibernation means that the robot remains ready for a prompt (i.e. rapid or fast) waking up, saving energy by shutting down selected processes, while maintaining a subset of other ones. For example, the robot may maintain its computer vision or at least its microphones.
- the module called “basic awareness” generally is maintained in active state at all times. In the “sleep” mode, the robot can power off almost entirely, for example adopting a resting posture, suitable for stable equilibrium, and saving energy.
- the “shutting down” process in some embodiments is tightly controlled. In particular, it can serve to diagnose the state of the robot. Symmetrically, the “booting-up” (or starting-up) process performs a series of predefined tasks, which diagnoses possible malfunctions.
- a logical software supervisor continuously runs in the background (e.g. the “Basic Awareness” software module of the robot's operating system) and performs said resting and/or standby optimization steps.
- the one or more parameters comprise temperature measures and/or energy consumption values and/or values quantifying signs of wear or combinations thereof.
- Monitored parameters can comprise parameters such as the temperature (or heat) of the different motors (for example located at articular locations, as measured or as computed or simulated) and/or the measured or estimated wear levels (affecting the longevity and maintenance of the robot) and/or the measured or estimated remaining levels of energy (or battery management parameters).
- a hierarchy of parameters can be defined. In general, temperature (e.g. of motors) is a critical parameter (short term). Energy consumption has an effect versus battery life. Signs of wear have a long-term impact. The definition of the perimeter of such parameters and the knowledge of their values (measured or simulated/estimated or accessed from external sensors) can contribute to the global management of the robotic system.
- an optimization rule comprises a rule of minimization of the consumption of energy.
- the energy consumption of the motor can be optimized, sometimes without stopping completely the robot.
- a complete shut down may present the risk of not being able to reboot one or more motors of the robot. In some cases, it thus can be wise not to stop entirely at least some parts of the robot, i.e. it is advantageous to maintain the robot in some specific idle states.
- an optimization rule comprises the minimization of wear of one or more parts of the robot.
- an optimization rule comprises the maximization of the dissipation of the heat of one or more motors of the robot.
- Idle animations can incidentally cool down the motors of the robot. Animations also can be specifically designed to cool down parts and/or to optimize cooling in view of local conditions (and to spare energy as well, in some embodiments). For example, in order to cool the shoulders of the robot, the arms may move slightly back and forth (and then fall down by gravity, saving energy). Additional sensors (e.g. an anemometer, embedded or remotely accessed) can help the robot to decide which animations to execute (for example to take advantage from a particular local air flow).
- Additional sensors e.g. an anemometer, embedded or remotely accessed
- the step of executing an optimization rule comprises a step of executing an animation or predefined motion of one or more parts of the robot.
- An animation is a sequence of motions or movements. Motions are movements in space (i.e. displacements of one or more parts of the robot), e.g. correspond to “body language” in some embodiments.
- An animation can be further associated with the communication of sounds and/or visual effects (voice synthesis, blinking, flashing lights if any, display or projection of of information, etc).
- an animation can be predefined, i.e. the geometry is entirely predefined.
- an animation is rule-based, i.e. rules of movement are deterministic and predefined but the exact sequence performed in the reality can depend on other external factors (collisions or risks of collision with obstacles, measured temperature of motors, temperature of the room, applauds, emotions of the attending audience etc). Rules aim at reaching a compromise between restoring the parts of the robot (e.g. cooling down parts, testing proper functions, evaluate damages or wears, etc) and energy savings (testing functions cost energy and tests can be applied incidentally or opportunistically when performing other tasks).
- these animations are performed at low speeds (and/or low intensity), i.e. at low energy.
- a part of the robot can combine motions (pitch, roll, yaw), for example at low intensity/velocity.
- animations can comprise one or more of the motions comprising rocking, swinging, swaying, balancing (e.g. an arm or a leg or the torso), dancing (e.g. coordinated movements of low amplitude), counterbalancing, poising, breathing, body rocking, shaking, trembling, moon-walking, kneeling down, noding, chewing (or equivalent) and combinations thereof.
- the robot in idle state, the robot can slightly shake its head in rhythm (e.g. as if listening to music). Additionally the robot can emit sounds to mimic yawning or snoring or sighing. Further specific standby embodiments are described.
- the head of the robot remains permanently active (i.e. substantially).
- slow body animations are advantageously socially engaging, e.g. invites users for interaction.
- the robot When standing up, the robot for example can move its center of gravity from one leg to another (to spare constraints), while imitating human behaviors.
- the resting state of the robot is a known initial state: developers of software applications can know the starting parameters of the robot when booting it up. In other words, software developers do not have to worry about the state of the robot when starting the execution of a software application (e.g. an activity).
- the described operations monitor and/or continuously correct the state of the different parts of the robot, ensuring that the robot is fully functional and/or its status is known at any moment.
- motors e.g. at articular locations
- motors can be cooled down by specific animations.
- certain positions or attitude can be selected, minimizing constraints.
- the robot can perform movements of low amplitude, which advantageously optimize the cooling down of internal parts such as heated motors.
- these movements or gestures or oscillations can be specifically designed to recover (e.g. cool down or optimize or repair or restore) problematic parts (e.g. over-heated or damaged) of the robot.
- a predefined motion is associated with a body posture associated with a social engagement score exceeding a predefined threshold.
- the animation which is planned for execution can be similar to a static (or dynamic) body posture or language whose “user-friendliness” (or “social engagement score”) can be known (e.g. scored) in advance. For example crossing one's legs is less engaging than giving a hand.
- a “slow” animation can make the robot to appear “alive”, i.e. inviting a user for interaction.
- the animation can mimic a “breathing” state.
- Such a posture signals to users that the robot is still active and is ready for interaction, even if no particular software program or activity (e.g storytelling, weather reporting, dancing, etc) is executing on the robot.
- the human attitude can be an incident advantage.
- the mimic of a human opened posture e.g. social attitude or body language calling for interaction
- the robot has to restore or recover or restart or otherwise repair its components first.
- the “idle animations” or “resting movements” or otherwise predefined motions an correspond to system's optimizations (incidentally or on purpose). If a candidate system optimization additionally results in a positive “social” attitude or appeal, the acceptance or ponderation or weighing associated with said candidate optimization can be increased (for example). Alternatively, user feedbacks and experiences can modify—if not lead—“standby” or “hibernation” or “sleep” mode states.
- the optimization criterion is associated with the status of the system and its subsystems. In some embodiments, the optimization criterion is associated with the social engagement. In some embodiments, both types of criterion (system optimization and mimic of social interaction) can be used simultaneously (or concurrently in some embodiments).
- the method further comprises executing said predefined motion or animation.
- the execution of the predefined motion is enhanced or enabled by an active accessory.
- external devices such as “intelligent” clothes can be worn by the robot.
- enhanced clothes can both help to cool down the robot at selected points, while simulating living artifacts (e.g. pneumatic system to simulate breathing, engaging or inviting for interaction).
- Accessories can be passive but also active: fans embedded in clothes or appropriate apertures can facilitate the air low or circulation and further cool down the required part of the robot.
- one or more optimization rules are locally predefined or retrieved from a distant server.
- the robot is autonomous (rules are hard coded or otherwise embedded in the robot without the need of a network connection).
- the robot is controlled or influenced by data retrieved from a distant server (e.g. the “Cloud”).
- optimization rules are partly local and partly remotely accessed.
- a computer program comprising instructions for carrying out one or more steps of the method when said computer program is executed on a suitable computer device.
- the disclosed methods can take form of an entirely hardware embodiment (e.g. FPGA), an entirely software embodiment or an embodiment containing both hardware and software elements.
- Software embodiments include but are not limited to firmware, resident software, microcode, etc.
- the invention can take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system.
- a computer-usable or computer-readable can be any apparatus that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
- the medium can be an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system (or apparatus or device) or a propagation medium.
Landscapes
- Engineering & Computer Science (AREA)
- Robotics (AREA)
- Mechanical Engineering (AREA)
- Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- General Health & Medical Sciences (AREA)
- Computing Systems (AREA)
- Biomedical Technology (AREA)
- Biophysics (AREA)
- Computational Linguistics (AREA)
- Data Mining & Analysis (AREA)
- Evolutionary Computation (AREA)
- Life Sciences & Earth Sciences (AREA)
- Molecular Biology (AREA)
- Artificial Intelligence (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Mathematical Physics (AREA)
- Software Systems (AREA)
- Health & Medical Sciences (AREA)
- Manipulator (AREA)
- Toys (AREA)
- User Interface Of Digital Computer (AREA)
- Testing Of Devices, Machine Parts, Or Other Structures Thereof (AREA)
- Feedback Control In General (AREA)
Abstract
Description
- This patent relates to the field of data processing and more particularly to standby modes of a robot.
- Personal computers (e.g. laptops, tablets, smartphones, etc) and robots (e.g. humanoid robots) are very different objects.
- The man-machine interaction with a robot (for example with a companion humanoid robot) is very different than interactions with a personal computer. Companion robots advantageously can establish an emotional relationship with human beings, with interactive dialogs and physical actions performed in the tangible reality.
- Standby methods known in the technical field of personal computing are not well adapted to robots, and a fortiori to humanoid robots.
- There is a need for methods and systems of specific standby modes for robots.
- There is disclosed a computer-implemented method of executing a standby mode for a robot, comprising the steps of measuring one or more parameters associated with one or more parts of the robot (e.g. the temperature of one or more motors); receiving one or more standby optimization rules associated with said parameters (e.g. maximizing the dissipation of the heat of the motor), and executing one or more received standby optimization rules (e.g. executing a body animation to cool down motors). The monitored parameters comprise motor temperature measures and/or energy consumption values and/or values quantifying signs of wear. Optimization rules comprise the minimization of the consumption of energy and/or the minimization of wear and/or the maximization of the dissipation of the heat. In developments, a predefined animation can be associated a valuable social engagement score.
- Further aspects are disclosed, including the optional use of accessories. System aspects and computer programs are also described.
- Embodiments of the present invention will now be described by way of example with reference to the accompanying drawings in which like references denote similar elements, and in which:
-
FIG. 1 illustrates the global technical environment of the invention; -
FIG. 2 details some aspects of an embodiment of the method; -
FIG. 3 details some particular aspects of a specific embodiment of the method. - Humanoid robots are an emerging form of “social technology”. As companion robots, humanoid robots are increasingly considered as partners by human users, maintaining a durable if not emotional relationship and continuously learning (from each other, i.e. robots learning from users and vice-versa). For example, and even if being only machines, personal robots present a great value for coaching activities (e.g. diet, sport or education). Compared to personal computers, simulated emotions and body language allow for more engaging, persuasive, convincing or otherwise trustful relationships.
- Humanoid robots are information processing machines and therefore a wide range of comparisons with personal computers can be established. Some aspects can be considered common ground. Some other aspects are very different when comparing personal robots and personal computers.
- For example, regarding the aspect of “software applications”, some quite substantial differences can be briefly underlined. A first significant difference lies in the multimodal characteristics of a personal robot, i.e. by design. A companion robot can follow its owner (i.e. present displacement capabilities) and can touch objects or interact with its environment. By design, a personal computer is lacking such various environmental feedbacks. This “multimodal” feature or characteristics implies deep consequences regarding the management of applications on the robot (among other aspects, e.g. including the management of standby modes).
- A particular difference relates to the handling of standby modes, wherein in addition to energy savings aspects, a robot can incidentally and/or opportunistically and/or on-purpose evaluate, select and further execute different animations or sequences of movements. Such animations or motions for example can cool down motors and/or enable system verifications, while maintaining or developing the relationship with human users (“user experience”).
- The
FIG. 1 illustrates the global and technical environment of the invention. Arobot 130 comprises sensors and actuators. A logic or “mind” 100 is implemented in the robot or associated with it (for example remotely) and comprises a collection ofsoftware 110 andhardware components 120. Therobot 130 is interacting (by bilateral or two-ways communications 140, including one or more dialog sessions) with one ormore users 150. Said one or more users can access other computing devices 160 (for example a personal computer such as a wearable computer or a smartphone or a tablet), which can be connected devices (in communication with a cloud of servers and/or a fleet of other robots or connected objects, etc). In particular, a connected device can be a wearable computer (e.g. watch, glasses, immersive helmet, etc). - The
specific robot 130 on the figure is taken as an example only of a humanoid robot in which the invention can be implemented. The lower limb of the robot on the figure is not functional for walking, but can move in any direction on its base which rolls on the surface on which it lays. The invention can be easily implemented in a robot which is fit for walking. - In some embodiments of the invention, the robot can comprise various kinds of sensors. Some of them are used to control the position and movements of the robot. This is the case, for instance, of an inertial unit, located in the torso of the robot, comprising a 3-axis gyrometer and a 3-axis accelerometer. The robot can also include two 2D color RGB cameras on the forehead of the robot (top and bottom). A 3D sensor can also be included behind the eyes of the robot. The robot can also optionally comprise laser lines generators, for instance in the head and in the base, so as to be able to sense its relative position to objects/beings in its environment. The robot can also include microphones to be capable of sensing sounds in its environment. The robot of the invention can also include sonar sensors, possibly located at the front and the back of its base, to measure the distance to objects/human beings in its environment. The robot can also include tactile sensors, on its head and on its hands, to allow interaction with human beings. It can also include bumpers on its base to sense obstacles it encounters on its route. To translate its emotions and communicate with human beings in its environment, the robot of the invention can also include LEDs, for instance in its eyes, ears and on its shoulders and loudspeakers (for example located in its ears). The robot can communicate with a base station, with other connected devices or with other robots through various networks (3G, 4G/LTE, Wifi, BLE, mesh, etc). The robot comprises a battery or source of energy. The robot can access a charging station fit for the type of battery that it includes. Position/movements of the robots are controlled by its motors, using algorithms which activate the chains defined by each limb and effectors defined at the end of each limb, in view of the measurements of the sensors.
- In a specific embodiment, the robot can embed a tablet with which it can communicate messages (audio, video, web pages) to its environment, or receive entries from users through the tactile interface of the tablet. In another embodiment, the robot does not embed or present a screen but it does have a video projector, with which data or information can be projected on surfaces in the vicinity of the robot. Said surfaces can be flat (e.g. floor) or not (e.g. deformations of the projecting surfaces can be compensated to obtain a substantially flat projection). In both embodiments (with screen and/or with a projector), embodiments of the invention remain valid: the claimed interaction model is only supplemented or complemented by visual interaction means. In any case, would the graphical means be out of order or deactivated on purpose, the conversational mode of interaction remains.
- In an embodiment, the robot does not comprise such graphical user interface means. Existing humanoid robots are generally provided with advanced speech capabilities but are generally not provided with GUI. Increasing communities of users will probably not use graphical means (e.g. tablet, smartphone), even as a complement, to communicate with the robot, by choice and/or necessity (young people, impaired persons, because of a practical situation, etc).
- The collection of software 110 (non-exhaustively) comprises software modules or objects or software code parts, in interaction with one another, including “extractors” 111, “activity suggestions” 112, “mind prioritization” 113, “package manager” 114, “User historical data” 115, “Focused Autonomous activity” 116 and “Focused Dialog Topic” 117 and a “Health Monitoring Service” 118.
- An “Extractor Service” 111 generally senses or perceives something internal or external of the robot and provides short term data into the robot's memory. An Extractor service receives input readings from the robot sensors; these sensor readings are preprocessed so as to extract relevant data in relation to the position of the robot, identification of objects/human beings in its environment, distance of said objects/human beings, words pronounced by human beings or emotions thereof. Extractor services in particular comprise: face recognition, people perception, engagement zones, waving detection, smile detection, gaze detection, emotion detection, voice analysis, speech recognition, sound localization, movement detection, panoramic compass, robot pose, robot health diagnosis, battery, QR code handling, home automation, tribes, time and schedule.
- An “Actuator Service” makes the
robot 130 physically do or perform actions. Motion tracker, LEDs, Behavior manager are examples of “Actuator Services”. - A “Data Service” provides long-term stored data. Examples of Data Services are a
User Session Service 115, which stores user data, and their history of what they have done with the robot and aPackage Manager Service 114, which provides a scalable storage of procedures executed by the robot, with their high level definition, launch conditions and tags. “Package Manager” in particular provides the scalable storage of Activities and Dialogs, and the Manifest. The “Manifest” contains metadata such as launch conditions, tags, and high level descriptions. - A “Mind Service” (for example a service Mind Prioritization 113) is one that will be controlled by the robot's central “Mind” when it is initiating action. “Mind Services” tie together “Actuator services” 130, “Extractor services” 111 and “Data services” 115. Basic Awareness is a “Mind Service”. It subscribes to “Extractor Services” such as People perception, Movement detection, and Sound localization to tell the Motion Service to move. The “Mind” 113 configures Basic Awareness's behavior based on the situation. At other times, Basic Awareness is either acting own its own, or is being configured by a Running Activity.
- “Autonomous Life” is a Mind Service. It executes behavior activities. Based on the context of a situation, the Mind can tell autonomous life what activity to focus (“Focused Autonomous Activity” 116). Metadata in manifests tie this information into the mind. Any activity can have access to one or more of the Operating System APIs. Activities can also directly tell Autonomous Life what activity to focus, or tell the Dialog Service what topic to focus on.
- The “Dialog” service can be configured as a Mind Service. It subscribes to the speech recognition extractor and can use “Animated Speech Actuator Service” to speak. Based on the context of a situation, the Mind can tell the Dialog what topics to focus on (a “Dialog Topic”). The “Dialog” service also has its algorithms for managing a conversation and is usually acting on its own. One component of the Dialog service can be a “Focused Dialog Topic” service 117. Dialog Topics can programmatically tell the Mind to switch focus to (or execute or launch) a different Activity or Dialog Topic, at any time. One example of possible method to determine the Dialog Topic can comprise: at the moment that an dialog topic or activity's launch conditions become true or false, a list of all possible Activities or Dialog Topics for the moment is sent to the Mind; the list is filtered according to activity prioritization; the list order is randomized; the list is sorted (or scored) to give precedence to Activities or Dialog Topics that are “unique” and have been started less often; a special check to make sure the top Dialog Topic or Activity in this list isn't the same activity as the previous activity that was executed. The list can be again sorted and filtered according to the preferences of the user.
- The robot can implement a “health monitoring”
service 118. Such a service can act as a daemon or a “watchdog”, to review or control or regulate the different priorities of the robot. Such a service can monitor (continuously, intermittently or periodically) the status of the internal components of the robot and measure or anticipate or predict or correct hardware failures. In a development, the fleet (e.g. installed base) of robots is monitored. The embedded service can continuously detect faulty situations and synchronize them with a “cloud” service (once every minute for example). In some embodiments, the “health monitoring”service 118 can contribute, if not lead, the different standby modes disclosed hereafter. -
Hardware components 120 comprise processing means 121, memory means 122, Input/Output I/O means 123, mass storage means 124 and network access means 125, said means interacting with one another (caching, swapping, distributed computing, load balancing, etc). The processing means 121 can be a CPU (multicore or manycore) or a FPGA. The memory means 122 comprise one or more of a flash memory or a random access memory. The I/O means 123 can comprise one or more of a screen (e.g. touch screen), a light or LED, a haptic feedback, a virtual keyboard, a mouse, a trackball, a joystick or a projector (including a laser projector). The storage means 124 can comprise one or more of a hard drive or a SSD. The network access means can provide access to one or more networks such as a 3G, 4G/LTE, Wifi, BLE or a mesh network. Network traffic can be encrypted (e.g. tunnel, SSL, etc). - In an embodiment, computing resources (calculations, memory, I/O means, storage and connectivity) can be remotely accessed, for example as a complement to local resources (available in the robot itself). For example, further CPU units can be accessed through the Cloud for voice recognition computing tasks. Computing resources also can be shared. In particular, a plurality of robots can share resources. Connected devices in the vicinity of the robot also can share resources to some extent, for example via secured protocols. Display means also can be shared. For example, the television can be used as a further display by the robot when passing by.
- The
FIG. 2 details some aspects of an embodiment of the method. - There is disclosed a computer-implemented method of executing a standby mode for a robot, comprising the steps of measuring 220 one or more parameters associated with one or more parts of the robot (e.g. the temperature of one or more motors); receiving 230 one or more standby optimization rules associated with said parameters (e.g. maximizing the dissipation of the heat of the motor), and executing 240 one or more received standby optimization rules (e.g. executing a body animation to cool down motors).
- The monitored parameters at
step 220 comprise motor temperature measures and/or energy consumption values and/or values quantifying signs of wear. - Examples of
optimization rules 231 comprise the minimization of the consumption of energy and/or the minimization of wear and/or the maximization of the dissipation of the heat. - In a development, for example as a result of the step of executing 240 one or more received standby optimization rules, a predefined animation can be played by the robot. Said animation can be associated with a high score (user-friendly attitude, “social engagement”). This criterion can be measured afterwards, but also can be taken account upstream in order to select which animation to execute.
- Detailed embodiments and developments are now discussed.
- There is disclosed a computer-implemented method of executing a standby mode in or by a robot, comprising the steps of measuring one or more parameters associated with one or more parts of the robot; receiving one or more standby optimization rules associated with said parameters, and executing one or more received standby optimization rules.
- Events and/or parameters associated with one or more parts of the robot are continuously (or intermittently or periodically) monitored (e.g. watchdog or daemon executing on the robot itself or on/by some other connected devices or robots).
- Parts of the robot comprise articular chains (arm, hand, leg, foot or head for example) and its associated motors, for example located at articular locations (wrist, elbow, shoulder, knee, ankle, neck, pelvis, etc).
- Standby optimization rules can be stored locally or accessed through a network. Rules can be predefined or not. Rules can be static or dynamically defined. In some embodiments, rules can depend on the set of monitored parameters. Rules can also be defined by the user, at least partly (behavior type, energy saving profile, etc), or be defined by the manufacturer or the seller of the robot.
- Depending on the combination of the monitored parameters (e.g. perimeter, values, thresholds), particular rules can be applied. In some embodiments, these rules can aim to optimize the system status of the robot (e.g. check system parts, cool down motors, etc) and/or (i.e. in combination or alternatively) to adopt a user-friendly attitude (e.g. socially engaging posture or animation).
- In a particular embodiment described
FIG. 3 , when no user motion command is sent to an articular chain, it can be considered idle 300 (for example upon excess or below some predefined thresholds). If not, a user orsoftware program command 310 is executed. If the chain is considered “idle”, the motion controller can check the current temperature of the motors of the chain atstep 320, and according to some embodiments can choose an idle or restingposture 330 for that chain, thereby and for example minimizing the power consumption of the hottest joints. In an embodiment, as long as the chain is detected of assessed as idle, the motion controller can optionally play a “safe”animation 340, e.g. have to robot to execute a slow animation (at low speed, with low energy consumption). - Different activations or deactivations of the robot (“states” or “modes”) are now described. A robot can enter or leave different machine states (generally referred to as “standby”): hibernation state, sleep state or mode, or otherwise idle state. In particular, these particular states can be designed or adapted so that to optimize system parameters.
- The companion robot when unsolicited or otherwise inactive can remain in certain resting or standby states or modes, sometimes analogous to computer systems, to restore its abilities and/or cool down its motors and/or perform checkup tasks and/or save energy and/or to appear quiet. Different modes or states are possible. By decreasing energy consumption levels, the robot can “actively standby”, “standby”, “hibernate”, “sleep” or “power off” (the terminology can change, different combinations of deactivated internal circuits being possible).
- In some embodiments, for example, the “active standby” mode can mean that the robot powers off a selected but limited number of internal components to save energy. Waking up times delays generally very short. The “standby” mode increases the number of inactive components, and waking-up delays can be increased. Th hibernation means that the robot remains ready for a prompt (i.e. rapid or fast) waking up, saving energy by shutting down selected processes, while maintaining a subset of other ones. For example, the robot may maintain its computer vision or at least its microphones. The module called “basic awareness” generally is maintained in active state at all times. In the “sleep” mode, the robot can power off almost entirely, for example adopting a resting posture, suitable for stable equilibrium, and saving energy. The “shutting down” process in some embodiments is tightly controlled. In particular, it can serve to diagnose the state of the robot. Symmetrically, the “booting-up” (or starting-up) process performs a series of predefined tasks, which diagnoses possible malfunctions.
- In some embodiments, a logical software supervisor continuously runs in the background (e.g. the “Basic Awareness” software module of the robot's operating system) and performs said resting and/or standby optimization steps.
- In a development, the one or more parameters comprise temperature measures and/or energy consumption values and/or values quantifying signs of wear or combinations thereof.
- Monitored parameters can comprise parameters such as the temperature (or heat) of the different motors (for example located at articular locations, as measured or as computed or simulated) and/or the measured or estimated wear levels (affecting the longevity and maintenance of the robot) and/or the measured or estimated remaining levels of energy (or battery management parameters). A hierarchy of parameters can be defined. In general, temperature (e.g. of motors) is a critical parameter (short term). Energy consumption has an effect versus battery life. Signs of wear have a long-term impact. The definition of the perimeter of such parameters and the knowledge of their values (measured or simulated/estimated or accessed from external sensors) can contribute to the global management of the robotic system.
- There are further disclosed specific aspects of such states of the robot, i.e. when not fully awakened. In particular, there is disclosed that one or more of these particular states can be handled in such a way that to recover and/or repair and/or restore and/or diagnose the health status of the robot. The following minimization (or maximization) operations can be of local perimeter (e.g. one or more parts of the robot) or of global perimeter (e.g. considering the robot in whole).
- In a development, an optimization rule comprises a rule of minimization of the consumption of energy.
- In a development, for example when no specific software application is executing on the robot, the energy consumption of the motor can be optimized, sometimes without stopping completely the robot. A complete shut down may present the risk of not being able to reboot one or more motors of the robot. In some cases, it thus can be wise not to stop entirely at least some parts of the robot, i.e. it is advantageous to maintain the robot in some specific idle states.
- In a development, an optimization rule comprises the minimization of wear of one or more parts of the robot.
- Some resting attitudes for example can counterbalance past or current mechanical efforts. Parts provided with lubricant (if any) can be appropriately handled according to the described method.
- In a development, an optimization rule comprises the maximization of the dissipation of the heat of one or more motors of the robot.
- Idle animations can incidentally cool down the motors of the robot. Animations also can be specifically designed to cool down parts and/or to optimize cooling in view of local conditions (and to spare energy as well, in some embodiments). For example, in order to cool the shoulders of the robot, the arms may move slightly back and forth (and then fall down by gravity, saving energy). Additional sensors (e.g. an anemometer, embedded or remotely accessed) can help the robot to decide which animations to execute (for example to take advantage from a particular local air flow).
- In a development, the step of executing an optimization rule comprises a step of executing an animation or predefined motion of one or more parts of the robot.
- An animation is a sequence of motions or movements. Motions are movements in space (i.e. displacements of one or more parts of the robot), e.g. correspond to “body language” in some embodiments. An animation can be further associated with the communication of sounds and/or visual effects (voice synthesis, blinking, flashing lights if any, display or projection of of information, etc).
- In an embodiment, an animation can be predefined, i.e. the geometry is entirely predefined. In another embodiment, an animation is rule-based, i.e. rules of movement are deterministic and predefined but the exact sequence performed in the reality can depend on other external factors (collisions or risks of collision with obstacles, measured temperature of motors, temperature of the room, applauds, emotions of the attending audience etc). Rules aim at reaching a compromise between restoring the parts of the robot (e.g. cooling down parts, testing proper functions, evaluate damages or wears, etc) and energy savings (testing functions cost energy and tests can be applied incidentally or opportunistically when performing other tasks).
- In an embodiment, these animations are performed at low speeds (and/or low intensity), i.e. at low energy. A part of the robot can combine motions (pitch, roll, yaw), for example at low intensity/velocity. For example, animations can comprise one or more of the motions comprising rocking, swinging, swaying, balancing (e.g. an arm or a leg or the torso), dancing (e.g. coordinated movements of low amplitude), counterbalancing, poising, breathing, body rocking, shaking, trembling, moon-walking, kneeling down, noding, chewing (or equivalent) and combinations thereof. For example, in idle state, the robot can slightly shake its head in rhythm (e.g. as if listening to music). Additionally the robot can emit sounds to mimic yawning or snoring or sighing. Further specific standby embodiments are described.
- In an embodiment, the head of the robot remains permanently active (i.e. substantially).
- In some embodiments, slow body animations are advantageously socially engaging, e.g. invites users for interaction. When standing up, the robot for example can move its center of gravity from one leg to another (to spare constraints), while imitating human behaviors.
- The resting state of the robot is a known initial state: developers of software applications can know the starting parameters of the robot when booting it up. In other words, software developers do not have to worry about the state of the robot when starting the execution of a software application (e.g. an activity). The described operations monitor and/or continuously correct the state of the different parts of the robot, ensuring that the robot is fully functional and/or its status is known at any moment.
- Advantageously, motors (e.g. at articular locations) can be cooled down by specific animations. Depending on which motors are excessively hot, certain positions or attitude can be selected, minimizing constraints. In an embodiment, the robot can perform movements of low amplitude, which advantageously optimize the cooling down of internal parts such as heated motors. In an embodiment, these movements or gestures or oscillations can be specifically designed to recover (e.g. cool down or optimize or repair or restore) problematic parts (e.g. over-heated or damaged) of the robot.
- In a development, a predefined motion is associated with a body posture associated with a social engagement score exceeding a predefined threshold.
- The animation which is planned for execution can be similar to a static (or dynamic) body posture or language whose “user-friendliness” (or “social engagement score”) can be known (e.g. scored) in advance. For example crossing one's legs is less engaging than giving a hand.
- Advantageously, a “slow” animation can make the robot to appear “alive”, i.e. inviting a user for interaction. In some embodiments, the animation can mimic a “breathing” state. Such a posture signals to users that the robot is still active and is ready for interaction, even if no particular software program or activity (e.g storytelling, weather reporting, dancing, etc) is executing on the robot. In other words, in some embodiments, the human attitude can be an incident advantage. In some other embodiments, the mimic of a human opened posture (e.g. social attitude or body language calling for interaction) can be fully part of the decision model. In some cases, it may well happen that the requirements derived from states of the mechanical and/or electrical parts of the robot cannot be congruent (i.e. married, or combined) with such socially engaging postures. In such cases, the robot has to restore or recover or restart or otherwise repair its components first.
- The “idle animations” or “resting movements” or otherwise predefined motions an correspond to system's optimizations (incidentally or on purpose). If a candidate system optimization additionally results in a positive “social” attitude or appeal, the acceptance or ponderation or weighing associated with said candidate optimization can be increased (for example). Alternatively, user feedbacks and experiences can modify—if not lead—“standby” or “hibernation” or “sleep” mode states.
- In some embodiments, the optimization criterion is associated with the status of the system and its subsystems. In some embodiments, the optimization criterion is associated with the social engagement. In some embodiments, both types of criterion (system optimization and mimic of social interaction) can be used simultaneously (or concurrently in some embodiments).
- In a development, the method further comprises executing said predefined motion or animation.
- In a development, the execution of the predefined motion is enhanced or enabled by an active accessory.
- In an embodiment, external devices such as “intelligent” clothes can be worn by the robot. For example, enhanced clothes can both help to cool down the robot at selected points, while simulating living artifacts (e.g. pneumatic system to simulate breathing, engaging or inviting for interaction). Accessories can be passive but also active: fans embedded in clothes or appropriate apertures can facilitate the air low or circulation and further cool down the required part of the robot.
- In a development, one or more optimization rules are locally predefined or retrieved from a distant server.
- In an embodiment, the robot is autonomous (rules are hard coded or otherwise embedded in the robot without the need of a network connection). In another embodiment, the robot is controlled or influenced by data retrieved from a distant server (e.g. the “Cloud”). In yet another embodiment, optimization rules are partly local and partly remotely accessed.
- There is disclosed a computer program comprising instructions for carrying out one or more steps of the method when said computer program is executed on a suitable computer device.
- There is disclosed a system comprising means adapted to carry out one or more steps steps of the method.
- The disclosed methods can take form of an entirely hardware embodiment (e.g. FPGA), an entirely software embodiment or an embodiment containing both hardware and software elements. Software embodiments include but are not limited to firmware, resident software, microcode, etc. The invention can take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system. A computer-usable or computer-readable can be any apparatus that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device. The medium can be an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system (or apparatus or device) or a propagation medium.
Claims (12)
Applications Claiming Priority (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
EP14305847 | 2014-06-05 | ||
EP14305847.7A EP2952299A1 (en) | 2014-06-05 | 2014-06-05 | Standby mode of a humanoid robot |
EP14305847.7 | 2014-06-05 | ||
PCT/EP2015/062537 WO2015185709A2 (en) | 2014-06-05 | 2015-06-05 | Standby mode of a humanoid robot |
Publications (2)
Publication Number | Publication Date |
---|---|
US20170080564A1 true US20170080564A1 (en) | 2017-03-23 |
US10576632B2 US10576632B2 (en) | 2020-03-03 |
Family
ID=51059387
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US15/311,739 Expired - Fee Related US10576632B2 (en) | 2014-06-05 | 2015-06-05 | Standby mode of a humanoid robot |
Country Status (13)
Country | Link |
---|---|
US (1) | US10576632B2 (en) |
EP (1) | EP2952299A1 (en) |
JP (1) | JP2017516673A (en) |
KR (1) | KR102071116B1 (en) |
CN (1) | CN106575376A (en) |
AU (2) | AU2015270429A1 (en) |
BR (1) | BR112016028468A2 (en) |
CA (1) | CA2953246C (en) |
MX (1) | MX2016015825A (en) |
NZ (1) | NZ727011A (en) |
RU (1) | RU2663657C2 (en) |
SG (1) | SG11201609561UA (en) |
WO (1) | WO2015185709A2 (en) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20190084150A1 (en) * | 2017-09-21 | 2019-03-21 | Fu Tai Hua Industry (Shenzhen) Co., Ltd. | Robot, system, and method with configurable service contents |
US10513038B2 (en) * | 2016-03-16 | 2019-12-24 | Fuji Xerox Co., Ltd. | Robot control system |
US11029803B2 (en) * | 2019-09-23 | 2021-06-08 | Lg Electronics Inc. | Robot |
Families Citing this family (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109079782A (en) * | 2018-08-09 | 2018-12-25 | 上海常仁信息科技有限公司 | A kind of dropproof robot |
DE102019121013B4 (en) | 2018-08-09 | 2022-12-29 | Fanuc Corporation | CONTROL DEVICE, LUBRICATION COOLING METHOD AND ADMINISTRATION DEVICE |
RU2709523C1 (en) * | 2019-02-19 | 2019-12-18 | Общество с ограниченной ответственностью "ПРОМОБОТ" | System for determining obstacles to movement of robot |
WO2023054091A1 (en) * | 2021-10-01 | 2023-04-06 | ソニーグループ株式会社 | Information processing device and method, robot device and driving method, and program |
WO2024142800A1 (en) * | 2022-12-29 | 2024-07-04 | パナソニックIpマネジメント株式会社 | Transport control system, transport system, and control method for transport control system |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20060128261A1 (en) * | 2004-12-14 | 2006-06-15 | Honda Motor Co., Ltd. | Cooling arrangement for a humanoid robot |
US20100193694A1 (en) * | 2009-02-02 | 2010-08-05 | Redlen Technologies | Solid-state radiation detector with improved sensitivity |
JP2010193694A (en) * | 2009-02-20 | 2010-09-02 | Namiki Precision Jewel Co Ltd | Driving motor of servo unit for radio control |
US20110224827A1 (en) * | 2009-04-22 | 2011-09-15 | Toyota Jidosha Kabushiki Kaisha | Robot controller, robot control method, and legged robot |
US20140125678A1 (en) * | 2012-07-11 | 2014-05-08 | GeriJoy Inc. | Virtual Companion |
Family Cites Families (25)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP0269373A3 (en) | 1986-11-20 | 1988-08-17 | Unimation Inc. | Multiaxis robot control having protection system with energy and backup velocity monitoring |
JPH05111891A (en) * | 1991-10-21 | 1993-05-07 | Mitsubishi Electric Corp | Robot controller |
JP3612545B2 (en) | 2000-07-21 | 2005-01-19 | 学校法人東海大学 | Robot joint device |
JP4625910B2 (en) | 2000-09-19 | 2011-02-02 | 学校法人東海大学 | Mobile robot joint control device |
EP1327503B1 (en) | 2000-10-11 | 2017-12-06 | Sony Corporation | Robot control system and robot control method |
US7113848B2 (en) | 2003-06-09 | 2006-09-26 | Hanson David F | Human emulation robot system |
JP3942586B2 (en) * | 2003-12-02 | 2007-07-11 | 株式会社国際電気通信基礎技術研究所 | Communication robot |
JP4027350B2 (en) | 2004-06-29 | 2007-12-26 | ファナック株式会社 | Robot standby position return program creation device |
JP2006181648A (en) * | 2004-12-24 | 2006-07-13 | Toyota Motor Corp | Robot arm driving device |
US7389156B2 (en) | 2005-02-18 | 2008-06-17 | Irobot Corporation | Autonomous surface cleaning robot for wet and dry cleaning |
KR101329891B1 (en) | 2005-02-18 | 2013-11-20 | 아이로보트 코퍼레이션 | Autonomous surface cleaning robot for wet and dry cleaning |
JP2007061962A (en) * | 2005-08-31 | 2007-03-15 | Yaskawa Electric Corp | Mobile robot and temperature adjustment device and method therefor |
JP2007069302A (en) * | 2005-09-07 | 2007-03-22 | Hitachi Ltd | Action expressing device |
EP1795314B1 (en) | 2005-12-12 | 2009-10-21 | HONDA MOTOR CO., Ltd. | Legged mobile robot control system |
JP5033994B2 (en) | 2006-01-19 | 2012-09-26 | 株式会社国際電気通信基礎技術研究所 | Communication robot |
US20080282062A1 (en) | 2007-05-07 | 2008-11-13 | Montvelishsky Michael B | Method and apparatus for loading data and instructions into a computer |
JP2008296308A (en) * | 2007-05-30 | 2008-12-11 | Panasonic Corp | Movement control system, movement control method, and movement control program for housework support robot arm |
CN101298260B (en) * | 2008-06-11 | 2010-06-02 | 清华大学 | Low-power consumption two-foot walking moving system and walking control method thereof |
KR20100028358A (en) | 2008-09-04 | 2010-03-12 | 삼성전자주식회사 | Robot and method for controlling safe of the same |
CN201304244Y (en) * | 2008-11-14 | 2009-09-09 | 成都绿芽科技发展有限公司 | Multifunctional robot |
JP5298841B2 (en) | 2008-12-26 | 2013-09-25 | 富士通株式会社 | Robot and robot work execution method |
JP2010162663A (en) | 2009-01-19 | 2010-07-29 | Seiko Epson Corp | Cooling mechanism, cooling device and cooling method of robot arm |
JP5950234B2 (en) * | 2010-02-25 | 2016-07-13 | 本田技研工業株式会社 | A momentum-based balance controller for humanoid robots on non-horizontal and unsteady ground |
KR101772974B1 (en) * | 2010-12-21 | 2017-09-12 | 삼성전자주식회사 | Method for generating human-like motion of humanoid robot |
JP2014062235A (en) | 2012-08-28 | 2014-04-10 | Toray Ind Inc | Waterproof heat conductive resin composition and molded article |
-
2014
- 2014-06-05 EP EP14305847.7A patent/EP2952299A1/en not_active Withdrawn
-
2015
- 2015-06-05 BR BR112016028468A patent/BR112016028468A2/en not_active Application Discontinuation
- 2015-06-05 KR KR1020177000003A patent/KR102071116B1/en active IP Right Grant
- 2015-06-05 CN CN201580029773.5A patent/CN106575376A/en active Pending
- 2015-06-05 SG SG11201609561UA patent/SG11201609561UA/en unknown
- 2015-06-05 NZ NZ727011A patent/NZ727011A/en not_active IP Right Cessation
- 2015-06-05 RU RU2016152152A patent/RU2663657C2/en not_active IP Right Cessation
- 2015-06-05 WO PCT/EP2015/062537 patent/WO2015185709A2/en active Application Filing
- 2015-06-05 AU AU2015270429A patent/AU2015270429A1/en not_active Abandoned
- 2015-06-05 MX MX2016015825A patent/MX2016015825A/en unknown
- 2015-06-05 JP JP2016571145A patent/JP2017516673A/en active Pending
- 2015-06-05 US US15/311,739 patent/US10576632B2/en not_active Expired - Fee Related
- 2015-06-05 CA CA2953246A patent/CA2953246C/en not_active Expired - Fee Related
-
2018
- 2018-11-21 AU AU2018267604A patent/AU2018267604A1/en not_active Abandoned
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20060128261A1 (en) * | 2004-12-14 | 2006-06-15 | Honda Motor Co., Ltd. | Cooling arrangement for a humanoid robot |
US20100193694A1 (en) * | 2009-02-02 | 2010-08-05 | Redlen Technologies | Solid-state radiation detector with improved sensitivity |
JP2010193694A (en) * | 2009-02-20 | 2010-09-02 | Namiki Precision Jewel Co Ltd | Driving motor of servo unit for radio control |
US20110224827A1 (en) * | 2009-04-22 | 2011-09-15 | Toyota Jidosha Kabushiki Kaisha | Robot controller, robot control method, and legged robot |
US20140125678A1 (en) * | 2012-07-11 | 2014-05-08 | GeriJoy Inc. | Virtual Companion |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10513038B2 (en) * | 2016-03-16 | 2019-12-24 | Fuji Xerox Co., Ltd. | Robot control system |
US20190084150A1 (en) * | 2017-09-21 | 2019-03-21 | Fu Tai Hua Industry (Shenzhen) Co., Ltd. | Robot, system, and method with configurable service contents |
US11029803B2 (en) * | 2019-09-23 | 2021-06-08 | Lg Electronics Inc. | Robot |
Also Published As
Publication number | Publication date |
---|---|
JP2017516673A (en) | 2017-06-22 |
WO2015185709A3 (en) | 2016-03-10 |
US10576632B2 (en) | 2020-03-03 |
EP2952299A1 (en) | 2015-12-09 |
SG11201609561UA (en) | 2016-12-29 |
RU2663657C2 (en) | 2018-08-08 |
RU2016152152A (en) | 2018-07-09 |
KR20170042544A (en) | 2017-04-19 |
CA2953246A1 (en) | 2015-12-10 |
CN106575376A (en) | 2017-04-19 |
WO2015185709A2 (en) | 2015-12-10 |
AU2018267604A1 (en) | 2018-12-06 |
CA2953246C (en) | 2019-08-20 |
RU2016152152A3 (en) | 2018-07-09 |
AU2015270429A1 (en) | 2016-12-08 |
NZ727011A (en) | 2018-04-27 |
MX2016015825A (en) | 2017-06-28 |
KR102071116B1 (en) | 2020-01-29 |
BR112016028468A2 (en) | 2017-08-22 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10576632B2 (en) | Standby mode of a humanoid robot | |
KR101982420B1 (en) | Collision detection | |
CA2946040C (en) | Executing software applications on a robot | |
CN106660205B (en) | System, method and computer program product for handling humanoid robot-human interaction | |
US20230305530A1 (en) | Information processing apparatus, information processing method and program | |
JP6368796B2 (en) | Robot motion monitoring | |
WO2015158881A1 (en) | Methods and systems for managing dialogs of a robot | |
US11675360B2 (en) | Information processing apparatus, information processing method, and program | |
US11446813B2 (en) | Information processing apparatus, information processing method, and program |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STPP | Information on status: patent application and granting procedure in general |
Free format text: FINAL REJECTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NOTICE OF ALLOWANCE MAILED -- APPLICATION RECEIVED IN OFFICE OF PUBLICATIONS |
|
ZAAA | Notice of allowance and fees due |
Free format text: ORIGINAL CODE: NOA |
|
ZAAB | Notice of allowance mailed |
Free format text: ORIGINAL CODE: MN/=. |
|
AS | Assignment |
Owner name: SOFTBANK ROBOTICS EUROPE, FRANCE Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:DALIBARD, SEBASTIEN;MAZEL, ALEXANDRE;MAISONNIER, BRUNO;REEL/FRAME:051522/0638 Effective date: 20170330 |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: PUBLICATIONS -- ISSUE FEE PAYMENT VERIFIED |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
LAPS | Lapse for failure to pay maintenance fees |
Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
STCH | Information on status: patent discontinuation |
Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362 |
|
FP | Lapsed due to failure to pay maintenance fee |
Effective date: 20240303 |