[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

US20170080564A1 - Standby mode of a humanoid robot - Google Patents

Standby mode of a humanoid robot Download PDF

Info

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
Application number
US15/311,739
Other versions
US10576632B2 (en
Inventor
Sébastien DALIBARD
Alexandre Mazel
Cyrille Collette
Bruno Maisonnier
Jérôme Monceaux
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Aldebaran SAS
Original Assignee
SoftBank Robotics Europe SAS
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by SoftBank Robotics Europe SAS filed Critical SoftBank Robotics Europe SAS
Publication of US20170080564A1 publication Critical patent/US20170080564A1/en
Assigned to SOFTBANK ROBOTICS EUROPE reassignment SOFTBANK ROBOTICS EUROPE ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: DALIBARD, Sébastien, MAISONNIER, BRUNO, MAZEL, ALEXANDRE
Application granted granted Critical
Publication of US10576632B2 publication Critical patent/US10576632B2/en
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J9/00Programme-controlled manipulators
    • B25J9/16Programme controls
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J9/00Programme-controlled manipulators
    • B25J9/16Programme controls
    • B25J9/1674Programme controls characterised by safety, monitoring, diagnostic
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N3/00Computing arrangements based on biological models
    • G06N3/004Artificial life, i.e. computing arrangements simulating life
    • G06N3/008Artificial 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
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J19/00Accessories fitted to manipulators, e.g. for monitoring, for viewing; Safety devices combined with or specially adapted for use in connection with manipulators
    • B25J19/02Sensing devices
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J9/00Programme-controlled manipulators
    • B25J9/16Programme controls
    • B25J9/1656Programme controls characterised by programming, planning systems for manipulators
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J9/00Programme-controlled manipulators
    • B25J9/16Programme controls
    • B25J9/1679Programme controls characterised by the tasks executed
    • B25J9/1682Dual arm manipulator; Coordination of several manipulators
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J19/00Accessories fitted to manipulators, e.g. for monitoring, for viewing; Safety devices combined with or specially adapted for use in connection with manipulators
    • B25J19/0054Cooling 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

A computer-implemented method of executing a standby mode for a robot, comprises 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 the 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 described.

Description

    TECHNICAL FIELD
  • This patent relates to the field of data processing and more particularly to standby modes of a robot.
  • BACKGROUND
  • 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.
  • SUMMARY
  • 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.
  • BRIEF DESCRIPTION OF DRAWINGS
  • 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.
  • DETAILED DESCRIPTION
  • 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. 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). 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 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. 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 or software 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 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. 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)

1. A method of executing a standby mode in a humanoid 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;
wherein an optimization rule comprises the maximization of the dissipation of the heat of one or more of the robot.
2. The method of claim 1, wherein the one or more parameters comprise temperature measures and/or energy consumption values and/or values quantifying signs of wear or combinations thereof.
3. The method of claim 1, wherein an optimization rule comprises a rule of minimization of the consumption of energy.
4. The method of claim 1, wherein an optimization rule comprises the minimization of wear of one or more parts of the robot.
5. (canceled)
6. The method of claim 1, wherein executing an optimization rule comprises the execution of an animation or predefined motion of one or more parts of the robot.
7. The method of claim 1, wherein a predefined motion is associated with a body posture associated with a social engagement score exceeding a predefined threshold.
8. The method of claim 6, further comprising executing said predefined motion or animation.
9. The method of claim 8, wherein the execution of the predefined motion is enhanced or enabled by an active accessory.
10. The method of claim 1, wherein one or more optimization rules are locally predefined or retrieved from a distant server.
11. A computer program comprising instructions for carrying out the steps of the method according to claim 1 when said computer program is executed on a suitable computer device.
12. A system comprising means adapted to carry out the steps of the method according to claim 1.
US15/311,739 2014-06-05 2015-06-05 Standby mode of a humanoid robot Expired - Fee Related US10576632B2 (en)

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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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

Patent Citations (5)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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