Learning When to Drive in Intersections by Combining Reinforcement Learning and Model Predictive Control

  • 2019-08-01 02:00:49
  • Tommy Tram, Ivo Batkovic, Mohammad Ali, Jonas Sjöberg
  • 3

Abstract

In this paper, we propose a decision making algorithm intended for automatedvehicles that negotiate with other possibly non-automated vehicles inintersections. The decision algorithm is separated into two parts: a high-leveldecision module based on reinforcement learning, and a low-level planningmodule based on model predictive control. Traffic is simulated with numerouspredefined driver behaviors and intentions, and the performance of the proposeddecision algorithm was evaluated against another controller. The results showthat the proposed decision algorithm yields shorter training episodes and anincreased performance in success rate compared to the other controller.

 

Quick Read (beta)

Learning When to Drive in Intersections by Combining Reinforcement Learning and Model Predictive Control

Tommy Tram1,2,3, Ivo Batkovic1,2,3, Mohammad Ali1, and Jonas Sjöberg2 This work was partially supported by the Wallenberg AI, Autonomous Systems and Software Program (WASP) funded by the Knut and Alice Wallenberg Foundation.1 Affiliated with Zenuity AB, Gothenberg, Sweden {tommy.tram, ivo.batkovic, mohammad.ali}@zenuity.com2 Affiliated with the Department of Electrical Engineering, Chalmers University of Technology, Gothenberg, Sweden {tommy.tram, ivo.batkovic, jonas.sjoberg}@chalmers.se3 Affiliated with AI Innovation of Sweden, Gothenburg, Sweden
Abstract

In this paper, we propose a decision making algorithm intended for automated vehicles that negotiate with other possibly non-automated vehicles in intersections. The decision algorithm is separated into two parts: a high-level decision module based on reinforcement learning, and a low-level planning module based on model predictive control. Traffic is simulated with numerous predefined driver behaviors and intentions, and the performance of the proposed decision algorithm was evaluated against another controller. The results show that the proposed decision algorithm yields shorter training episodes and an increased performance in success rate compared to the other controller.

\usetikzlibrary

patterns

I Introduction

How can a self-driving vehicle interact and drive safely through intersections with other road users? Interactions between road users in intersections is a complex problem to solve, making it difficult to address using conventional rule based systems. Many advancements aim to solve this problem by trying to imitate human drivers [1] or predicting what other drivers in traffic are planning to do [2]. In [3], the authors show that by modeling the decision process as a partially observable Markov decision process, the model can account for uncertainty in sensing the environment and [4] showed some probabilistic guarantees when solving the problem using reinforcement learning (RL).

Previous research [5] showed that reinforcement learning can be used to learn a negotiation behavior between vehicles without vehicle to vehicle communication when driving in an intersection. The method found a policy that could avoid collisions in an intersection with crossing traffic, where other vehicles have different intentions. Since the previous work separates the framework in a high-level decision maker and a low-level controller, the high-level decision making algorithm can focus on the task when to drive, while the low level controller handles the comfort of passengers in the car by generating a smooth acceleration profile. We showed how this worked for intersections with a single crossing point, where Short Term Goal (STG) actions could choose one car to follow. This architecture, similar to Fig. 1, gives the decision algorithm, the RL policy, the flexibility to choose actions that can safely drive through the intersection by switching between numerous STG. A solution with a simple controller holds well when the distance between intersection are far away from each other, but when there are several crossing points in close succession, the system would have a hard time avoiding collisions due to the increased complexity of multiple points and timeing where a collision can occur.

Fig. 1: Representation of the decision making architecture. The dashed line marks the decision algorithm that is separated into two parts; the high-level decision maker, denoted as the policy, and the low-level controller.

In this paper, we instead propose to combine the high-level decision maker from [5] with a Model Predictive Controller (MPC) in a framework presented in Fig. 1. The performance of the MPC controller is benchmarked against a Sliding Mode controller that was used in [5]. The benefit of the MPC is that it can consider multiple vehicles at the same time and generate an optimal trajectory, which instantly gives feedback on performance and feasibility, i.e. predicting collisions, to the high-level decision maker. In contrast to [6], where the authors prove stability and recursive feasibility using an MPC approach and assuming that agents can cooperate, we restrict ourselves to non-cooperative scenarios.

Applying MPC directly to the problem could lead to a growing complexity with the number of vehicles in the intersection, e.g., the vehicle needs to decide based on multiple options which vehicle to yield for, and which to drive in front of. Therefore, we propose to separate the problem into two parts: the first being a high-level decision maker, which structures the problem, and the second being a low level planner, which optimizes a trajectory given the traffic configuration.

For the high-level decision maker, RL is used to find a policy for how the vehicle should drive through the intersection, and MPC is used as a low-level planner to optimize a safe trajectory. Compared to [7, 8] where all vehicles are controlled using MPC to stay in safe sets, based on models of other vehicles’ future trajectory, this could possibly be perceived as too conservative for a passenger. By combining RL and MPC, the decision policy will learn which action is optimal by using feedback from the MPC controller in the reward function. Since MPC uses predefined models, e.g. vehicle models and other obstacle prediction models, the performance relies on their accuracy and assumptions. To mitigate this, we use Q-learning, a model-free RL approach, to maximize the expected future reward based on the experience gained during an entire episode. This approach is able to compensate, to some extent, for model errors and is explained more in Section IV-A.

In this work, we focus on the integration between policy and actuation, by having an MPC controller directly giving feedback to the decision maker through immediate reward, allowing the policy to know how comfortably the controller can handle an action and give feedback sooner if the predicted outcome may be good or bad.

This paper is structured as follows. Section II introduces the problem formulation along with the two-layers of the decision algorithm. Section III presents three agents used for simulation and validation. Implementation details are presented in Section IV, and the results are shown in Section V followed by discussion in Section VI. Finally, we draw conclusions in Section VII.

II Problem formulation

The goal of the ego-vehicle is to drive along a predefined route that has one or two intersections with crossing traffic, where the intent of other road users is unknown. Therefore, the ego-vehicle needs to assess the driving situation and drive comfortably, while avoiding collisions with any vehicle11 1 Although our approach can be extended to other road users, for convenience of exposition we’ll refer to vehicles. that may cross. In this section, we define the underlying Partially Observable Markov Decision Process (POMDP) and present how the problem is decomposed using RL for decision making and MPC for planning and control.

II-A Partially Observable Markov Decision Process

A POMDP [9] is defined by the 7-tuple (𝒮,𝒜,𝒯,,Ω,𝒪,γ), where 𝒮 is the state space, 𝒜 an action space that is defined in section III-A, 𝒯 the transition function, the reward function :𝒮×𝒜 is defined in IV-D, Ω an observation space, 𝒪 the probability of being in state st given the observation ot, and γ the discount factor.

A POMDP is a generalization of the Markov Decision Process (MDP) [10] and therefore works in the same way in most aspects. At each time instant t, an action, at𝒜, is taken, which will change the environment state st to a new state st+1. Each transition to a state st with an action at has a reward rt given by a reward function . The key difference from a regular MDP is that the environment state st is not entirely observable, e.g., the intention of other vehicles is not known. In order to find the optimal solution for our problem, we need to know the future intention of other drivers. Instead, we can only partially perceive the state though observations otΩ.

II-B Q-Learning

In the reinforcement learning problem, an agent observes the state st of the environment, takes an action at, and receives a reward rt at every time step t. Through experience, the agent learns a policy π in a way that maximizes the accumulated reward in order to find the optimal policy π*. In Q-learning, the policy is represented by a state action value function Q(st,at). The optimal policy is given by the action that gives the highest Q-value.

π*(st)=argmaxatQ*(st,at) (1)

Following the Bellman equation, the optimal Q-function Q*(st,at) is given by

Q*(st,at)=𝔼[rt+γmaxat+1Q*(st+1,at+1)|st,at]. (2)

III Agents

The action space 𝒜 is made out of six actions. The first two actions: α1 take way, and α2 give way, have the simple goal of crossing the intersection and stopping before the intersection, respectively. The actions α2+j has the goal of following a vehicle j.

In the following, we explain the two agents used for control of the ego vehicle and how they apply each action and how the surrounding traffic is modeled with varying intentions.

III-A MPC agent

We model the vehicle motion with states 𝐱3 and control 𝐮, defined as

𝐱:=[peveae],𝐮:=je, (3)

where we denote the position along the driving path in a Frenet frame as pe, the velocity as ve, the acceleration as ae, and the jerk as je, see Fig. 1(a). In addition, we assume that measurements of other vehicles are provided through an observation 𝐨. We limit the scope of the problem to consider at most four vehicles, and define the observations as

𝐨:=[p1v1pegocross,1p4v4pegocross,4], (4)

where we denote the position along its path as pj, the velocity as vj, and pegocross,j for j[1,4], as the distance to the ego-vehicle from the intersection point, see Fig. 1(a). Note that we distinguish between pegocross,j, since vehicles can cross at different points, see Fig. 4.

We assume that there exists a lateral controller that stabilizes the vehicle along the driving path. To that end, we only focus on the longitudinal control. Given the state representation, the dynamics of the vehicle is then modeled using a triple integrator with jerk as control input.

The objective of the agent is to safely track a reference, i.e. follow a path with a target speed, acceleration, and jerk profile, while driving comfortably and satisfying constraints that arise from physical limitations and other road users, e.g. not colliding in intersections with crossing vehicles. Hence, we formulate the problem as a finite horizon, constrained optimal control problem

min𝐱¯,𝐮¯ k=0N-1[𝐱¯k-𝐫k𝐱𝐮¯k-𝐫k𝐮][Q¯S¯S¯R¯][𝐱¯k-𝐫k𝐱𝐮¯k-𝐫k𝐮] (5a)
  +[𝐱¯N-𝐫N𝐱]P¯[𝐱¯N-𝐫N𝐱]
s.t.  𝐱¯0=𝐱^0, (5b)
  𝐱¯k+1=A𝐱¯k+B𝐮¯k, (5c)
  h(𝐱¯k,𝐮¯k,𝐨¯k,a)0, (5d)

where k is the prediction time index, N is the prediction horizon, Q¯, R¯, and S¯ are the stage costs, P¯ is the terminal cost, 𝐱¯k and 𝐮¯k are the predicted state and control inputs, 𝐫k𝐱 and 𝐫k𝐮 are the state and control input references, 𝐨¯k denotes the predicted state of vehicles in the environment which need to be avoided, and a is the action from the high-level decision maker in Sec. II-B. Constraint (5b) enforces that the prediction starts at the current state estimate 𝐱^0, (5c) enforces the system dynamics, and (5d) enforces constraints on the states, control inputs, and obstacle avoidance.

The reference points, 𝐫k𝐱, 𝐫k𝐮 are assumed to be set-points of a constant velocity trajectory, e.g. following the legal speed-limit of the road. Therefore, we set the velocity reference according to the speed limit, and the acceleration and jerk to zero.

III-A1 Obstacle prediction

In order for the vehicle planner in (5) to be able to properly avoid collisions, it is necessary to provide information about the surrounding vehicles in the environment. Therefore, similarly to [11], we assume that a sensor system provides information about the environment, and that there exists a prediction layer which generates future motions of other vehicles in the environment. The accuracy of the prediction layer does indeed affect the performance of the planner, however, since the high-level decision maker is separated from the low level control, the decisions can still be made robust to handle model errors and prediction errors.

In this paper, for simplicity the future motion of other agents is estimated by a constant velocity prediction model. The motion is predicted at every time instant for prediction times k[0,N], and is used to form the collision avoidance constraints, which we describe in the next section. Even though more accurate prediction methods do exist, e.g. [12, 13], we use this simple model to show the potential of the overall framework.

(a) Observations
(b) Velocity profile examples of various intention agents.
Fig. 2: Observations and agents in a scenario

III-A2 Collision avoidance

We denote a vehicle j with the following notation 𝐱j:=[pjvjaj], and an associated crossing point at position pcross,j in its own vehicle frame, which translated into the ego-vehicle frame is denoted as pegocross,j. For clarity, see Fig. 1(a). With a predefined road topology, we assume that the vehicles will travel along the assigned paths, and that collisions may only occur at the intersection points pcross,j between an obstacle and the ego vehicle. Hence, for collision avoidance, we use the predictions of the future obstacle states 𝐱¯kj for times k[0,N], provided by the prediction layer outside of the MPC framework. Given the obstacle measurements, the prediction layer will generate future states throughout the prediction horizon. With this information, it is possible to identify the time slots when a vehicle enters and exits the intersection.

Whenever an obstacle j is predicted to be within a threshold of pcross,j, e.g. the width of the intersecting area, the ego vehicle faces a constraint of the following form

p¯kepegocross,j+Δ,p¯kepegocross,j-Δ,

where Δ ensures sufficient padding from the crossing point that does not cause a collision. The choice of Δ must be at least such that pk together with the dimensions of the ego-vehicle does not overlap with the intersecting area.

III-A3 Take way and give way constraint

Since the constraints from the surrounding obstacles become non-convex, we rely on the high-level policy maker to decide through action a𝒜 how to construct constraint (5d) for Problem (5). The take-way action implies that the ego-vehicle drives first through the intersection, i.e., it needs to pass the intersection before all other vehicles. This implies that for any vehicle j that reaches the intersection during prediction times k[0,N], the generated constraint needs to lower bound the state pk according to

maxjpcross,j+Δpke. (6)

Similarly, if the action is to give way, then the position needs to be upper bounded by the closest intersection point so that

pkeminjpegocross,j-Δ, (7)

for all times k that the vehicle is predicted to be in the intersection.

III-A4 Following an obstacle

If action a𝒜 is not chosen to give way, or to take way, the remaining options are to follow one of the j vehicles. For such choices on a the ego-vehicle position is upper bounded by pkepegocross,j. For other vehicles ij, we construct the following constraints

  • if pcross,i<pcross,j then pcross,i+Δpke, which implies that the ego-vehicle should drive ahead of all vehicles i that are approaching the intersection;

  • if pcross,i>pcross,j then pkepcross,i-Δ, which implies that the ego-vehicle should wait to pass vehicle j and other vehicles i;

  • if pcross,i=pcross,j then the constraints generated for vehicle i becomes an upper or lower bound depending on if vehicle i is ahead or behind vehicle j into the intersection.

III-B Sliding mode agent

To benchmark the performance of using MPC, we introduce a Sliding Mode (SM) controller that was used in [5] and given by the following

asme =1c2(-c1x2+μsign(σ(x1,x2))), (8a)
where{x1=pt-pe,x2=vt-ve, (8b)
σ=c1x1+c2x2, (8c)
ape=K(vmax-ve), (8d)
ae=min(asme,ape). (8e)

The SM controller aims to keep a minimum distance to a target vehicle with a velocity of ve, by controlling the acceleration asme. The tuning parameters c1, c2, and μ are used to tune the comfort of the controller. In case no target vehicle exists, the controller maintains a target velocity vmax with a proportional control law from (8d) with the proportional constant K. The final acceleration is given by (8e). For more details about the SM agent see [5].

III-C Surrounding traffic agents

There are three intentions for agents in surrounding traffic. Examples of some velocity profiles are shown in Fig. 1(b). The intention of all agents is implemented with a SM controller with various target values. The take way intention does not yield for the crossing traffic and simply aim to keep its target reference speed. The give way intention, however, slows down to a complete stop at the start of the intersection, until crossing traffic has passed. The third intention is cautious, i.e. slowing down but not to a full stop.

IV Implementation

IV-A Deep Q-Network

Fig. 3: Representation of the network structure

The deep Q-network is structured as a three layer neural network with shared weights and a Long Short-Term Memory (LSTM) layer based on previous work [5] and shown in Fig. 3. A similar study for lane changes on a highway confirmed the importance of having equal weights for inputs that describe the state of interchangeable objects [14]. The input features ξn are composed of observations ot, introduced in section II-A and shown in Fig. 1(a), with up to four observed vehicles

ξn=[ptevteateδeptnvtnatnδn]T (9)

Normalization of the input features is done by scaling the features down to values between [-1,1] using the maximum speed vmax, maximum acceleration amax and a car’s sight range pmax. Empty observations of other vehicles [ptnvtnatnδn] has a default value of -𝟏. The input vectors are sent though two hidden layers 𝒉(1,i) and 𝒉(2,i) with shared weights 𝑾1 and 𝑾2 respectively

𝒉(1,i)=tanh(𝑾1𝝃i+𝒃1), (10)
𝒉(2,i)=tanh(𝑾2𝒉(1,i)+𝒃2). (11)

The output of each sub-network is then sent through a fully connected layer

𝒉(3)=tanh(i=14𝑾3i𝒉(2,i)+𝒃3), (12)

that is then connected to an LSTM [15] layer that can store and use previous features

𝒉t(4)=LSTM(𝒉(3)|𝒉t-1(4)). (13)

The output from the LSTM is then sent through a final layer

𝑸=(𝑾Q𝒉(4)+𝒃4)𝑸mask, (14)

where the operator denotes pointwise multiplication, 𝑸mask is a masking vector described in the next section, 𝑾Q and 𝒃4 are the weights and biases for the final layers, respectively. The optimal policy π is then given by maximizing the optimal action value function 𝑸 as

π(st)=argmaxat𝑸(st,at). (15)

IV-B Q-masking

Q-masking [16] helps the learning process by reducing the exploration space by disabling actions the agent does not need to explore. If there are less than N cars, it would then be meaningless to choose to follow a car that does not exist. Which motivates masking off cars that do not exist. In previous work [5], a high negative reward was given when an action to follow a car that did not exist was chosen, while the algorithm continued with a default action take way. The agent quickly learned to not choose cars that did not exist, but with Q-masking, the agent does not have to explore these options. For further details about the training see [5].

IV-C Simulation environment

All agents are spawned with a random intention, initial speed v0[10,30]m/s, and position p0i[10,55]m. The vehicle dimensions are 2 m wide and 4 m long. The ego car operates within comfort bounds and therefore has a limited maximum acceleration and deceleration of 5 m/s2.

Fig. 4: Illustration of a intersection scenario, where the solid line is a single crossing and together with the dashed line creates a double crossing.

Two main types of crossing were investigated. One and two crossing points as shown in Fig. 4, where the distance dcross between crossing points vary between [4,8,12,25,30,40]m with each scenarios.

The MPC agent was discretized at 30Hz, with a prediction horizon of N=100 and cost tuning of

Q¯=blockdiag(0.0,1.0,1.0),R¯=1,S¯=𝟎. (16)

IV-D Reward function tuning

There are three states that terminates an episode: success, failure, and timeout. Success is when the ego agent reaches the end of the road defined by the scenario. Failure is when the frame of the ego agent overlaps with another road users’ frame, e.g., in a collision, this frame can be the size of the vehicle or a safety boundary around a vehicle. The final terminating state is timeout, which is simply when the agent can not reach the two previous terminating states before the elapsed time τ reaches the timeout time τm.

According to [17], the Qπ values and gradient can grow to be very large if the total reward values are too large. All rewards are therefore scaled with the episode timeout time τm, which is set to 25s, to keep the total reward rt[-2,1]. The reward function is defined as follows:

rt= {1on success, -1on failure,0.5on timeout, i.e. ττm,f(pcrash,pcomf)on non-terminating updates,

where f(pcrash,pcomf) consists of

f(pcrash,pcomf)=αpcrashτmτ-tpred+βpcomfτmτ, (17)

with α[0,1], β[0,1] being weight parameters, and α+β=1. The first term pcrash corresponds to a feasibility check of Problem (5), which to a large extent depends on the validity of the accuracy of the prediction layer. The high-level decision from the policy-maker affects how the constraints are constructed, and may turn the control problem infeasible, e.g. if the decided action is to take way, while not being able to pass the intersection before all other obstacles. Therefore, whenever the MPC problem becomes infeasible we set pcrash=1, otherwise pcrash=0, to indicate that the selected action most likely will result in a collision with the surrounding environment. Because pcrash usually only triggers close to a potential collision, tpred is set to the first time a crash prediction is triggered, to scale the negative reward relatively higher the later it is predicted.

The second term pcomf relates to the comfort of the planned trajectory, which is estimated by computing and weighting the acceleration and jerk profiles as

pcomf=1σN(k=0N-1a¯k2Q¯a+j¯k2R¯j+a¯N2Q¯a),

where a¯, and j¯ are the acceleration component of the state and jerk component of the control, respectively, Qa and Rj are the corresponding weights, and σ is a normalizing factor which ensures that pcomf[0,1]. For the simulation we used Q¯a=1 and R¯j=1.

The timeout reward 0.5 was set to be higher than the average accumulated reward from pcomf, so that the total accumulated reward would be positive in case of timeouts.

V Results

For evaluation we compared the success rate of the decision-policy together with a collision to timeout ratio (CTR). The success rate is defined as the number of times the agent is able to cross the intersections without colliding with other obstacles or exceeding the time limit to cross. Since we define a time-out to be a failure, we use the CTR to separate potential collisions from the agent being too conservative.

Fig. 5 shows a comparison in success rate between the proposed MPC architecture and the previous SM agent for scenarios with only one intersection. In this scenario, the MPC agent converges after 104 training episodes, while the previous SM agent converges after 4104 training episodes. In addition, comparing the CTR metric, Tabel. I shows that the MPC agent has CTR of 0.45, while the SM agent has a CTR of 0.72. Evidently, it is apparent that the MPC is able to leverage future information into its planning horizon in order to achieve faster training, higher success rates, and also avoiding more collisions as a result.

We evaluate the performance of the MPC and SM agents for the more difficult double intersection problem, where we vary the distance between the intersection points. Table I shows the performance of the MPC and SM agent for both the single and double scenarios. The performance decreases for both agents in the double crossing scenario. However, it is evident that the MPC agent suffers less performance degradation compared to the SM agent. The CTR more than doubles for the MPC agent for the double crossing, while the already high CTR rate for the SM agent increases above rates of 0.9. Still, the MPC agent manages to outperform the SM agent.

Fig. 5: Average MPC and SM success rate for a single corssing after evaluating the policy 300 episodes.
TABLE I: Average success rates and collision to timeout rates.
Controller Success Rate CTR
Single Double Single Double
SM 96.1% 90.9% 72% 93%
MPC 97.3% 95.2% 45% 76%

VI Discussion

The benefit of being able to use a prediction horizon for the MPC is shown to mostly impact the training time for the traffic scenarios compared to the SM agent. This allows the RL decision-policy to get feedback early in the training process to see whether an action most likely will lead to a collisions. In addition, the lower CTR also implies that the use of a prediction horizon also makes the decision-policy more conservative, since it rather times out than risk collisions.

It is important to note that only little effort was put into tuning the MPC agent, and that we used very primitive prediction methods that do not hold very well in crossing scenarios, e.g. the simulated agents did not keep constant speed profiles while approaching the intersections. However, under these circumstances, the decision algorithm still managed to obtain a success rate above 95% for the double crossings.

In practice, a full decision architecture system would include a safety layer that limits which acceleration values the system can actuate in order to stay safe, followed by the decisions algorithm from this work that generates an acceleration request. The environment state, together with the new acceleration request, could be sent through a collision avoidance system that checks if the current path has a collision risk, and avoiding collision by allowing higher acceleration limits. This way, a failure would correspond to a intervention by the collision avoidance system instead of a crash.

VII Conclusion

In this paper, we proposed a decision making algorithm for intersections which consists of two components: a high-level decision maker that uses Deep Q-learning to generate decisions for how the vehicle should drive through the intersection, and a low-level planner that uses MPC to optimize safe trajectories. We tested the framework in a traffic simulation with randomized intent of other road users for both single and double crossings. Results showed that the proposed MPC agent outperforms the previous SM agent with 95.2% success rate in scenarios with double crossings compared to 90.9% for the SM agent. Results also showed that the crash timeout ratio was also significantly lower at 45% for the MPC agent compared to 72% for the SM agent in single crossings. Meaning, the proposed method is better at handling scenarios with multiple intersections and vehicles.

References

  • [1] M. Bansal, A. Krizhevsky, and A. Ogale, “ChauffeurNet: Learning to Drive by Imitating the Best and Synthesizing the Worst,” 2018.
  • [2] A. Zyner, S. Worrall, J. Ward, and E. Nebot, “Long short term memory for driver intent prediction,” in IEEE Intelligent Vehicles Symposium, Proceedings, 2017.
  • [3] S. Brechtel, T. Gindele, and R. Dillmann, “Probabilistic decision-making under uncertainty for autonomous driving using continuous pomdps,” in 17th International IEEE Conference on Intelligent Transportation Systems (ITSC).   IEEE, 2014, pp. 392–399.
  • [4] M. Bouton, J. Karlsson, A. Nakhaei, K. Fujimura, M. J. Kochenderfer, and J. Tumova, “Reinforcement learning with probabilistic guarantees for autonomous driving,” in Workshop on Safety Risk and Uncertainty in Reinforcement Learning, Conference on Uncertainty in Artificial Intelligence (UAI), 2017.
  • [5] T. Tram, A. Jansson, R. Grönberg, M. Ali, and J. Sjöberg, “Learning negotiating behavior between cars in intersections using deep q-learning,” in 2018 21st International Conference on Intelligent Transportation Systems (ITSC), Nov 2018, pp. 3169–3174.
  • [6] R. Hult, M. Zanon, S. Gros, and P. Falcone, “Optimal coordination of automated vehicles at intersections: Theory and experiments,” IEEE Transactions on Control Systems Technology, pp. 1–16, 2018.
  • [7] X. Qian, J. Gregoire, A. de La Fortelle, and F. Moutarde, “Decentralized model predictive control for smooth coordination of automated vehicles at intersection,” in 2015 European Control Conference (ECC), July 2015, pp. 3452–3458.
  • [8] G. R. de Campos, P. Falcone, and J. Sjöberg, “Autonomous cooperative driving: a velocity-based negotiation approach for intersection crossing,” in 16th International IEEE Conference on Intelligent Transportation Systems (ITSC 2013).   IEEE, 2013, pp. 1456–1461.
  • [9] M. J. Kochenderfer et al., ”Decision Making Under Uncertainty: Theory and Application”.   The MIT Press, 2015.
  • [10] R. Bellman, “A markovian decision process,” Journal of Mathematics and Mechanics, vol. 6, no. 5, pp. 679–684, 1957.
  • [11] I. Batkovic, M. Zanon, M. Ali, and P. Falcone, “Real-time constrained trajectory planning and vehicle control for proactive autonomous driving with road users,” in European Control Conference (ECC) 2019, 2019.
  • [12] S. Lefèvre, D. Vasquez, and C. Laugier, “A survey on motion prediction and risk assessment for intelligent vehicles,” ROBOMECH journal, vol. 1, no. 1, p. 1, 2014.
  • [13] I. Batkovic, M. Zanon, N. Lubbe, and P. Falcone, “A computationally efficient model for pedestrian motion prediction,” in 2018 European Control Conference (ECC), June 2018, pp. 374–379.
  • [14] C. Hoel, K. Wolff, and L. Laine, “Automated speed and lane change decision making using deep reinforcement learning,” in 2018 21st International Conference on Intelligent Transportation Systems (ITSC), Nov 2018, pp. 2148–2155.
  • [15] S. Hochreiter and J. Urgen Schmidhuber, “Long short-term memory,” Neural Computation, vol. 9, no. 8, pp. 1735–1780, 1997. [Online]. Available: http://www7.informatik.tu-muenchen.de/ hochreit http://www.idsia.ch/ juergen
  • [16] M. Mukadam, A. Cosgun, A. Nakhaei, and K. Fujimura, “Tactical decision making for lane changing with deep reinforcement learning,” in NIPS Workshop on Machine Learning for Intelligent Transportation Systems, 2017.
  • [17] H. P. van Hasselt, A. Guez, M. Hessel, V. Mnih, and D. Silver, “Learning values across many orders of magnitude,” in NIPS, 2016.