 
                 Patent Grant
 Patent Grant
                     11687084
 11687084
                    The present application claims the benefit under 35 U.S.C. 119 of European Patent Application No. 20190604.7 filed on Aug. 12, 2020, which is expressly incorporated herein by reference in its entirety.
The present invention relates to model predictive control for planning trajectories of robotic devices.
For autonomous control of a robotic device, motion planning is used for efficiently accomplishing navigation tasks. Based on sensor inputs, an actual state of the robotic device and its environment are determined, while trajectories or motion paths, respectively, are developed considering also dynamic obstacles such as moving objects or individuals in the environment.
In general, model predictive control (MPC) is an efficient technique which solves a receding horizon model-based open loop optimal control problem. Classical model predictive control techniques work well when the goal is the stabilization of constrained systems around equilibrium points or trajectories.
In G. Williams et. al., “Information theoretic MPC for model-based reinforcement learning”, International Conference on Robotics and Automation, 2017, an information theoretic approach is described to overcome some of the natural limitations of standard MPC techniques. In contrast to standard MPC techniques, Information Theoretic Model Predictive Control (IT-MPC) can work considering arbitrary system dynamics and arbitrary nonlinear cost definitions.
According to the present invention, a method for planning a trajectory, particularly for a robotic device, and a control unit and a robotic device according to the further independent claims are provided.
Further embodiments of the present invention are disclosed herein.
According to a first aspect of the present invention, a computer-implemented method for determining a control trajectory for a robotic device is provided. In accordance with an example embodiment of the present invention, the method includes the steps of:
In general, IT-MPC generates open-loop sequences of sampled controls by minimizing the Kullback-Leibler (KL) divergence between the current control distribution and the optimal one, derived by a desired cost function. Control samples for the IT-MPC are generated by a normal distribution centered around the previous control sequence. Therefore, this method performs well as long as the optimal control sequence only changes slightly from one step to the other.
However, if the optimal control sequence significantly changes, e.g., due to a new goal location or an unexpected appearance of a dynamic obstacle, the local sampling around the previous control sequence may lead to a poor convergence to the optimal control sequence. Therefore, the standard IT-MPC tends to be inappropriate for navigation of mobile robots in crowded environments.
Furthermore, the informed variant of theoretic model predictive control may iteratively evaluate a number of control trajectory samples derived from control trajectory sample prior based on a given distribution at each time step to obtain a further control trajectory sample, wherein the further control trajectory sample is determined depending on a combination of the number of weighted control trajectory samples, wherein the weights are determined based on the costs of each of the number of control trajectory samples.
In accordance with an example embodiment of the present invention, it may be provided that the data-driven trajectory prediction model comprises a neural network, particularly on the type of one of a soft actor-critic network, a trust region network, a policy optimization network, a proximal policy optimization network, a deep deterministic policy gradients network.
One approach to overcome above limitation of the poor convergence to the optimal control sequence is to use an informed sampling process by providing a predicted control trajectory as a control trajectory prior using a deep reinforcement learning algorithm. This may essentially comprise a data driven trajectory prediction model as machine-learning model which will generate a control trajectory prior based on a current state of the environment including a robot pose and poses of the detected obstacles, wherein a pose includes a position and an orientation of the robot or a part of the robot within the environment. The data driven trajectory prediction model is trained to estimate the control trajectory prior applying a training data set containing optimized control trajectories for different states of the environment. The optimized control trajectories may be provided by any kind of trajectory optimization processes for robotic devices in crowded environments. Sampling from this control trajectory prior distribution leads to an improved performance since fewer samples fall in costly parts of the state space.
In other words, one idea is to use an informed information-theoretic MPC approach for trajectory planning in crowded environments in combination with a deep reinforcement learning approach. The trajectory prediction model which is trained and is to apply a network that can generate robot control trajectories aware of the motions of surrounding dynamic objects and/or individuals.
In general, the above example method improves the information theoretic model predictive controlled technique for locally generating robot trajectories by considering a stochastic non-linear system in dynamic environments. The obtained trajectories are a result of the KL divergence minimization between the optimal sampling distribution and the actual one.
A robotic device as understood herein includes a mobile robot, such as an autonomous cleaning robot, an autonomous lawn mower or the like, as well as a robot having a movable manipulator, such as a robot arm, being configured to be moved within a given space.
A trajectory as understood herein is a planned path of a motion a robotic device may move along or a part of a robotic device, such as a manipulator, may be moved.
Particularly, the above method uses a data-driven prediction model that makes use of the potential of the IT-MPC framework.
Moreover, the control trajectory sample prior may be obtained by the modelled control trajectory sample obtained by trajectory prediction model and the control trajectory sample obtained in the last time step.
Particularly, the control trajectory sample prior may be obtained by the sum of the modelled control trajectory sample obtained by the trajectory prediction model and the control trajectory sample obtained in the last time step, particularly each weighted according to their trajectory costs according to a given cost function. The cost of a trajectory may be related to the expense to move along the trajectory in terms of energy, time, trajectory length and/or the like.
According to an example embodiment of the present invention, the modelled control trajectory sample may only be considered if the trajectory costs of the modelled control trajectory sample is higher than the trajectory costs of the control trajectory sample obtained in the last time step.
According to an aspect of the present invention, a control unit, such as a data processing device, for determining a control trajectory for a robotic device is provided. In accordance with an example embodiment of the present invention, the control unit is configured to perform the steps of:
According to a further aspect of the present invention, a robotic device comprises an actuation unit being configured to move the robotic device according to a control trajectory; and a control unit. In accordance with an example embodiment of the present invention, the control unit is configured to perform the steps of:
Example embodiments of the present invention are described in more detail below in conjunction with the figures.
    
    
    
    
  
The mobile robot may be an autonomous cleaning robot, an autonomous lawn mower, an autonomous service or care robot or the like. In other embodiments, the robotic device may be a robot with a manipulator, such as a robot arm, wherein the the manipulating device, such as a robot gripper, shall follow a planned trajectory.
The robotic device 1 may have a configuration as it is schematically shown in 
The control unit 11 may have a microprocessor or a microcontroller as well as a memory for storing data and an algorithm code. Furthermore, the robotic device 1 has an actuation unit 12 for interaction with the environment, for instance the actuation unit 12 may include a traction motor for driving wheels of the robotic device 1 to move the robotic device 1 within the environment E. The actuation unit 12 may also include a controllable robot arm with a gripper or the like. The actuation unit 12 is controlled by the control unit 11.
Furthermore, the robotic device 1 may include a sensor system 13 for sensing the environment E, particularly to detect other objects and structures which may allow the localization of the robotic device 1 and of the dynamic objects 2, 3, 4 in the environment E such that their positions or their poses are known in the environment E. The sensor system 13 may include radar, Lidar, and/or imaging systems, such as one or more cameras to scan the environment E surrounding the robotic device 1.
When configuring such a robotic device 1, a control strategy has to be installed which allows the robotic device 1 to autonomously perform its task in the environment E. The control strategy should have implemented a collision avoidance/handling to prevent motion trajectories where a collision with another dynamic object is likely or to cope with collisions.
In simulation-based benchmarking of navigation algorithms for robotic devices, it is generally difficult to effectively model the behavior of the dynamic objects 2.
This behavior of each of the dynamic objects may contribute to or disturb the performing of the task of the robotic device 1.
Basically, in the control unit 11 of the robotic device 1, an informed information theoretic model predictive control (IT-MPC) approach is implemented and performed. The informed information theoretic model predictive control (IT-MPC) process considers stochastic non-linear discrete time systems of the form of xt+1=F(xt, vt), where xt∈n is the system state at time t of dimension n. vt∈
m corresponds to the input control variable of dimension m with white noise obliged to nominal control ut i.e. vt=ut+εt with εt˜
(0,Σ), wherein (ν0, ν1, . . . , νt
m×t
m×t
The goal of IT-MPC is to solve the stochastic optimal control problem of the form
  
    
  
  
where  is the set of possible input sequences for the system, c(xt) is a state-based cost, ϕ(xt
*can be derived as
  
    
  
  
where S(V) denotes the state cost of an entire trajectory, p may be a Gaussian with covariance Σ and η is a normalization factor. To approximate the above minimization problem, it is proposed to minimize the KL divergence between the optimal control distribution * and 
U,Σ
U*≈argmin KL(
*,
U,Σ)
In case the optimal control distribution is Gaussian, the approximation is correct, and the resulting control trajectory is optimal. Given samples Vk around a nominal control trajectory Û as described above with disturbances εk above approximative minimization problem can be solved by an importance sampling scheme
  
    
  
  
where wk are importance sampling weights. It is preferable to use above formula as an update rule in an iterative manner.
A modified informed IT-MPC algorithm is described in conjunction with the flow chart of 
  
    
      
        
        
          
            
          
          
            
          
          
            
          
        
        
          
            
          
        
      
      
        
        
        
          
            
            
          
          
            
            
          
          
            
            
          
          
            
            
          
          
            
            
          
          
            
            
          
          
            
            
          
          
            
            
          
          
            
            
          
          
            
             (0, Σ)
          
          
            
            
          
          
            
            
          
          
            
          
          
            
            
          
          
            
          
          
            
            
          
          
            
            
          
          
            
            
          
          
            
          
          
            
            
          
          
            
          
          
            
            
          
          
            
            
          
          
            
            
          
          
            
            
          
          
            
            
          
          
            
            
          
          
            
            
          
          
            
          
          
            
          
        
      
    
  
According to step S1 (line 1), an initial configuration of parameters of the process is given. So, u* indicates an initial control sequence, K a number of samples, tf a time horizon, F a transition model, ϕ terminal costs, c state costs, Σ,λ hyper-parameters and C decoder conditions.
A control loop is started in step S2 which is performed between lines 2 to 22 of pseudocode of the Informed-IT-MPC algorithm which may be terminated once the goal state is reached by the robotic device 1.
In step S2 (line 3), the state of the system is obtained by the function “GetStateEstimate”. The state of the system may be determined by processing sensor signals to obtain a pose of the robotic device 1 in/relative to the environment E and the poses and velocities of each of dynamic obstacles 2, 3, 4 in the environment E as well known in the art. Basically, this is accomplished by reading the sensor signals such as Lidar, radar and the like which are further processed to obtain the respective.
In step S3 (line 4), a control trajectory sample prior is obtained by the algorithm “InformControls” which is described below in conjunction with 
Based on the control trajectory sample prior U*, a loop between lines 5 and 16 is performed for each of the samples k.
In step S4 (lines 6 to 8) x, Sk and εk are initialized.
In step S5, starting with the control trajectory prior U* as obtained in step S3, but in further iterations modified control trajectory prior U*, movement costs are predicted. This is performed by predicting future states of the system (line 10) with the time horizon tf, and the corresponding movement costs Sk are accumulated (line 11). The so obtained movement costs are added to the terminal costs ϕ(x) in line 13.
In step S6 (line 14), importance sampling weights wk are obtained by an algorithm “ImportanceSamplingWeights” as shown in the flowchart of 
  
    
      
        
        
          
            
          
          
            
          
          
            
          
        
        
          
            
          
        
      
      
        
        
        
          
            
            
          
          
            
            
          
          
            
          
          
            
            
              
                
              
            
          
          
            
          
          
            
            
          
          
            
          
          
            
            
          
          
            
          
          
            
            
          
          
            
            
          
          
            
          
        
      
    
  
The importance sampling weights wk are determined based on the accumulated trajectory costs Sk of each control trajectory sample and the given λ.
The function to determine the importance sampling weights uses the minimum costs ρ of all control trajectory samples considered so far in step S11 (line 2). In step S12 (line 3), a normalization factor
  
    
  
  
is calculated for making all movement costs of the considered samples comparable. In step S13 (lines 4 to 6), importance sampling weights wk for each of the control trajectory samples (determined so far) are obtained depending on a difference between the respective control trajectory costs Sk and the minimum control trajectory costs over all samples. Loop of lines 4 and 6 is necessary, as only Sk is needed.
Basically, the importance sampling weights wk are the higher, the higher the difference between the control trajectory sample costs and the minimum control trajectory sample costs ρ. The importance sampling weights wk for Sk is returned to the Informed IT-MPC algorithm in line 7.
In step S7 (line15), based on the importance sampling weights wk, a further control trajectory sample U* is obtained for the loop between lines 5 and 16.
In step S8 it is queried if all samples are considered. If positive (alternative: yes), the process is continued with step S9, otherwise (alternative: no) the process is continued with step S4.
In step S9 (line 17) of the informed IT-MPC algorithm, the first control data (u*0) is applied to the robotic device 1. The predicted trajectory is updated to the following time step in step S10 (lines 18 to 20) so that (u*0) is set to the former U*1 and so on.
In step S10 it is queried if the task is completed. If positive (alternative: yes), the process is ended, otherwise (alternative: no) the process is continued with step S2.
In step S3 (line 4), a control trajectory sample prior is obtained by the algorithm which is described below in conjunction with 
  
    
      
        
        
          
            
          
          
            
          
          
            
          
        
        
          
            
          
        
      
      
        
        
        
        
          
            
            
            
          
          
            
            
            
          
          
            
            
            
          
          
            
            
            
          
          
            
            
            
          
          
            
            
            
          
          
            
            
            
          
          
            
            
            
          
          
            
            
            
          
          
            
            
            
          
          
            
            
            
          
          
            
          
          
            
            
            
          
          
            
          
          
            
            
            
          
          
            
            
            
          
          
            
          
        
      
    
  
The control trajectory sample prior u* is generated based on the actual state of the system x, the trajectory control set of the last time step u*, initial conditions needed by the network, such as some sensor inputs σ, the robotic device 1 current state φ0, ν0, a covariance metric Σ, terminal costs ϕ, state costs c and the transition model F.
In step S21 (line 2), a modelled control trajectory sample û is determined based on a data-driven trajectory prediction model (function call: DeepReinforcementLearning (σ, φ0, ν0)) which may be implemented as a machine learning model such as a neural network or the like. Inputs for the trajectory prediction model are σ, φ0, ν0 indicating the actual state of the system including the pose of the robotic device 1 and a state of the environment E.
The neural network can use different types, such as soft actor-critic, trust region, policy optimization, proximal policy optimization, deep deterministic policy gradients or the like.
The trajectory prediction model is trained to generate the modelled control trajectory sample based on the actual state of the system and has been trained by optimized control trajectories. To obtain the optimized control trajectories classical deterministic MPC techniques can be used such as described in Schoels, T. et al., “An NMPC Approach using Convex Inner Approximations for Online Motion Planning with Guaranteed Collision Freedom”, arXiv preprint arXiv:1909.08267, 2019.
In step S22 along the given time horizon, based on the actual state of the system x, the costs Ŝ of the modelled control trajectory sample û predicted by the trajectory prediction model including the respective terminal costs at the end of the time horizon is determined (lines 4, 5 and 9)
In step S23 along the given time horizon, based on the actual state of the system x, the costs S* of the further trajectory control sample of the last time step u* including the respective terminal costs at the end of the time horizon is determined (lines 6, 7 and 10)
In step S24 (line 12), the control trajectory sample prior u* for returning to step S4 of the main algorithm Alg1 is determined by a combination of the modelled control trajectory u and the further trajectory control sample u* of the last time step as determined in step S7.
For instance, the returned control trajectory sample prior u* can be generated from the lastly generated further control trajectory sample u* and the modelled control trajectory sample û. If the cost Ŝ of the modelled control trajectory sample û is higher than the costs S* of the lastly generated control trajectory sample u*, the returned control trajectory sample u* is generated according to line 12 based on a sum of the weighted control trajectories, wherein the weights are generated by the corresponding costs Ŝ and S*.
Otherwise the further control trajectory sample u* as determined by step S7 of the main algorithm is used for the following iteration.
The above algorithm aims to find a control trajectory distribution that minimizes the expected costs. The control trajectory distribution depends strongly on the cost function and on the prediction of the trajectory prediction model. The sampling-based approach is even more accurate, if the initial control trajectory sample distribution is already close to the optimal one. Instead of a naïve initialization such as a zero or constant velocity of the obstacles, the control trajectory sample distribution is guided towards low-cost areas of the state space. While using the data driven trajectory prediction model, control trajectory samples may be generated that optimize the original objective.
| Number | Date | Country | Kind | 
|---|---|---|---|
| 20190604 | Aug 2020 | EP | regional | 
| Number | Name | Date | Kind | 
|---|---|---|---|
| 20160041536 | Benosman | Feb 2016 | A1 | 
| 20170226989 | Hammerum | Aug 2017 | A1 | 
| 20180120843 | Berntorp | May 2018 | A1 | 
| 20180218262 | Okada | Aug 2018 | A1 | 
| Entry | 
|---|
| IEEE International Conference on Robotics and Automation (ICRA), Singapore, 2017; Title: “Information theoretic MPC for Model-Based Reinforcement Learning” by (“Williams”) (Year: 2017). | 
| G. Williams et. al., “Information theoretic MPC for model-based reinforcement learning”, International Conference on Robotics and Automation, 2017. Retrieved from the Internet on Jul. 29, 2021: https://www.cc.gatech.edu/˜bboots3/files/InformationTheoreticMPC.pdf. 8 Pages. | 
| Schoels, T. et al., “An NMPC Approach using Convex Inner Approximations for Online Motion Planning with Guaranteed Collision Freedom”, arXiv preprint arXiv:1909.08267, 2019. Retrieved from the Internet on Jul. 29, 2021: https://arxiv.org/pdf/1909.08267.pdf. 9 pages. | 
| Number | Date | Country | |
|---|---|---|---|
| 20220050469 A1 | Feb 2022 | US |