Model Predictive Control for Self-Driving Cars
I converted this from LaTeX using pandoc. Images are missing and other formatting errors may be present. If you’re really interested check out the official report here.
Introduction
In 2019 there were 36,500 traffic fatalities in the United States, and vehicle crashes cost the economy $340 billion [1]. In recent years, the number of traffic fatalities has been increasing, with almost 43,000 in 2021 [2]. Research in self-driving car technology offers a way to reduce the human and financial cost of crashes, as well as lower road congestion and ease the burden of drivers [3]. Toward this end, model predictive control has become a popular tool for enabling autonomous navigation. Model predictive control is well-suited to the self-driving car problem due to a number of factors, including ability to handle obstacle constraints and nonlinear vehicle models. The Society of Automotive Engineers (SAE) defined a classification system for the level of autonomy in a given vehicle, with level 0 indicating no driving automation and level 5 indicating that human intervention is never required [4]. In this report, we focus on control design, existing research, and examples for SAE level 4 autonomous vehicles using model predictive control, meaning driving without any human input in commonly occuring situations.
Overview
Model predictive control (MPC) is a general control methodology which has seen significant academic and industrial attention in the last 50 years. MPC aims to find control inputs which will drive a system toward a predefined reference state, given some constraints and a cost function which are functions of the control inputs and process state. To do so, the controller uses a model of the system. At each control step, the controller minimizes the cost with respect to a sequence of future inputs; via the model, the controller predicts how the future inputs will affect the cost function. The first control in the resulting sequence is physically applied to the process until the next control step, whereupon the optimization is repeated in a receding horizon fashion [5]. Accordingly, the defining characteristics of MPC are: the control law depending on predicted behavior; the outputs predictions are computed by a process model; the input is determined by optimising some measure of performance; and the receding horizon [6]. Significant benefits of model predictive control include conceptual simplicity, the ability to explicitly incorporate constraints in an “intellligent” fashion, easy extension to the multivariable case, and ability to handle problems lacking a control law that can be computed off-line [5]–[7].
MPC has become popular in self-driving research as a way to provide online trajectory generation and tracking. Trajectory generation is the problem of finding a sequence of vehicle states which satisfy the car’s kinematic and dynamic constraints as well as taking into consideration comfort and safety of passengers. A common application is replanning a reference trajectory in order to avoid a pop-up obstacle, as demonstrated in [8]–[10]. The open-loop trajectory generated by a controller with a cost function or constraints taking into account the obstacle and vehicle dynamics can be used to accomplish this sort of replanning. Trajectory tracking is the problem of computing from a sequence of states actuator (steering, throttle, brake) commands which result in the vehicle following the proposed trajectory in the closed-loop [11]. MPC is well-suited for both due to its ability to handle multiple inputs and outputs, consider time-dependent constraints like pop-up obstacles, use a nonlinear vehicle model, and track a potentially unfeasible reference trajectory [12].
Examples
One approach for control designs addressing both problems is the use of a hierarchical architecture in which a top-level algorithm replans a reference trajectory to avoid obstacles, then sends the trajectory to a low-level algorithm which computes actuator commands to track the replanned trajectory. The top-level controller uses a lower-fidelity vehicle model to ease computational demands, whereas the low-level controller uses a higher-fidelity model to accurately track the reference. The high-level controller is sampled at a lower rate than the low-level. Also, the two may have different prediction and control horizons. For example, [8] compared a one-level controller using a four-wheel vehicle model to a hierarchical controller using a point-mass model at the high (trajectory generation) level and a four-wheel vehicle model at the low (trajectory tracking) level. In a double lane change and obstacle avoidance manuveur on an icy road, the hierarchical controller could drive 15kph faster and took 39% less computation time.
A number of MPC designs for specific self-driving applications exist in the literature which assume a deterministic, observable environment [8]–[10], [13]–[17]. Naturally, such conditions do not hold for general driving. As Carvalho et. al. note, “driving requires forecasts, and forecasts can be highly uncertain in some driving scenarios.” Such uncertainty can arise from measurement errors, friction coefficient estimation, driver behaviour and model mismatch [18].
One approach to handling uncertainty is robust MPC, which takes into account system disturbances to guarantee the control algorithm does not violate constraints. RMPC has been implemented in driving scenarios using a so-called tube-based approach which depends on offline computation of reachable vehicle states to perform constraint tightening. The offline computation is enabled by assuming deterministic, bounded uncertainties. The tube-based approach in [19] designed a robust controller based on a force-input nonlinear bicycle model by estimating the bounds of possible disturbances using experimental data. The controller was implemented in a full-size car to avoid obstacles on an icy road. It achieved collision-free path tracking up to 80kph with computational demands similar to standard MPC.
A robust approach, however, can result in overly conservative behavior in common driving situations. Stochastic MPC reduces conservatism by allowing a small probability the constraints are violated, resulting in so-called chance constraints. This results in more natural, human-like manuevering. Furthermore, the driving aggressiveness is a tunable parameter. Instead of deterministic uncertainty like RMPC, the uncertainty is typically modelled with zero-mean Gaussian noise. In contrast to the development of nonlinear MPC methods for self-driving applications [10], [17], [20], general SMPC research has mostly focused on linear systems [21]. In [22], a linear time varying vehicle model is used with chance constraints to implement SMPC for navigating in the presence of other (unpredictable) vehicles. An Interacting Multiple Model Kalman Filter is used to estimate the positions of the other vehicles. The authors experimentally examine the effect of changing the risk parameter, i.e. the chance of constraint violation, in urban driving, and concluded altering the parameter had a significant effect on the vehicle’s navigational characteristics in urban environments.
Problem Formulation
The MPC problem described above is commonly formulated as the following constrained finite-time optimization problem.
\[\begin{align} &\mathop{\mathrm{argmin}}_{U} \text{Cost}( \cdot; T_p, T_c) \label{eq:1a} \\ \text{subj. to }& \nonumber \\ & x_{k+1} = f(x_k, u_k) & k = 0, \dots, H_p - 1 \label{eq:1b} \\ & u_k \in \mathcal{U} & k = 0, \dots, H_p - 1 \label{eq:1c} \\ & x_k \in \mathcal{X} & k = 0, \dots, H_p - 1 \label{eq:1d} \\ & u_k = u_{H_c - 1} & k = H_c, \dots, H_p -1 \label{eq:1e} \\ & x_0 = \hat{x}_0 \label{eq:1f} \end{align} \label{eq:1}\]
The vectors \(x \in \mathcal{X} \subseteq \mathbb{R}^n\) and \(u \in \mathcal{U} \subseteq \mathbb{R}^m\) are the state and input vectors. Likewise, the sequences \(X = \{ x_0, \dots, x_{H_p - 1} \}\) and \(U = \{ u_0, \dots, u_{H_p - 1} \}\) are the generated sequences of state and input vectors.
Two time horizons are considered. The prediction horizon \(H_c\) is the length of time over which the response of the model to the inputs will be forecasted. The control horizon \(H_c\) is the length of time for which the controlled variables will be optimized. Naturally, \(H_c \leq H_p\). The relation of the control and prediction horizons to the rest of the MPC process is shown in Figure [fig:mpc-demo].
The constraint [eq:1b] represents using the system model to forecast future states. Constraints [eq:1c] and [eq:1d] enforce limitations on the input and process states, while [eq:1e] represents that all controls after the control horizon are held constant at the value of the last control within the control horizon. Constraint [eq:1f] initializes the system model to the the actual value of the system \(\hat{x}\), which may have to be estimated.
The first control of the solution \(U = \{ u_0, \dots, u_{H_p - 1} \}\) to [eq:1a] is applied to the system for the next control period. The sampling rate of the control is typically assumed to be constant, but need not be in practice.
Note we assume the problem starts from the zero time for notational simplicity. At each control instance, the problem is repeated (with the same control and prediction horizons), so in general each problem starts from an offset.
Practically speaking, solving the optimization problem can be achieved with one of a number of freely available optimiization libraries. In particular, Ipopt is a library for nonlinear optimization with interfaces to general-purpose programming languages [23]. The MATLAB function fmincon is a powerful optimization tool and is called under the hood of MATLAB’s high-level MPC abstractions [24], [25]. The author also found useful the CVXPY modeling language for convex optimization problems [26], [27].
Model
If the process model \(f(x_k, u_k)\) is linear, the technique is known as linear model predictive control. The most common linear models are state space, transfer functions, impulse response, and step response models [6]. Of these, the state space model \[\begin{aligned} x_{k+1} &= Ax_k + Bu_k \\ y_k &= Cx_k + Du_k \end{aligned}\] is especially popular, in particular because of easily handling multiple-input multiple-output processes.
Of course, many actual processess – including vehicle dynamics – are nonlinear. While linearization may be feasible if the process tends to operate around a set point, for processes with extreme nonlinearities or particular startup/shutdown modes, we may wish to treat them as nonlinear explicitly instead of inducing more model mismatch via linearization. In this case, we use the general process model \[\begin{aligned} x_{k+1} &= f(x_t, u_t) \\ x_0 &= \hat{x}_0 \end{aligned}\] as in equation [eq:1]. The trade-off for more accurate process representation is more difficult system identification, increased computational complexity of the optimization problem, and the lack of nonlinear stability and robustness results [5].
Cost function
The cost function is usually implemented as a sum over “stage costs”, where each stage is a point in the prediction horizon:
\[\begin{aligned} \text{Cost}( \cdot; T_p, T_c) = \sum_{k=0}^{H_p - 1} \lVert x_k - x^{\text{ref}}_k \rVert_{Q}^2 + \sum_{k=0}^{H_c - 1} \left( \lVert u_k \rVert_{R}^2 + \lVert \Delta u_k \rVert_{S}^2 \right) \end{aligned}\] where the control increment is \[\begin{aligned} \Delta u_{k} = u_{k} - u_{k-1} \ \forall \ k = 0, \dots, H_c - 1; \ u_{-1} = u(-t_s) \end{aligned}\] which is initialized by taking the control input from the previous solution of the optimization problem \(u(-t_s)\), i.e. \(t_s\) is the sampling time.
The norm \(\lVert \cdot \rVert_{A}^2\) is the Euclidean norm weighted by the symmetric positive semidefinite matrix \(A\). Accordingly, the matrices \(Q \in \mathbb{R}^{n \times n}\) and \(R, S \in \mathbb{R}^{m \times m}\) are the tracking, input, and input increment costs, respectively. The input increment cost may be dropped depending on the application, i.e. set \(S = 0\).
An immediate concern is how to select the parameters of the cost function, since they will apparently have a significant impact on the performance of the closed-loop control. The selection of the prediction and control horizons and the weight matrices are distinct, but related, questions. In principle, best performance is given when control and prediction horizons are infinite, i.e. \(T_c = T_p = \infty\) [28]. In reality, we have to solve the control problem in a reasonable time, which requires truncating the horizons. Reasoning from the ideal case, we should set the horizons as long as possible while maintaining acceptable real-time performance. A small value of the control horizon does not give the controlller enough degrees of freedom to incorporate information about the future trajectory, so \(H_c \geq 3\) works well in practice. Furthermore, to take into account transient behavior of the process, the \(H_p - H_c\) should be larger than the process settling time.
Adjustment of the weight matrices is a mostly ad-hoc process process. One should note that for a smaller control horizon, the same \(R, S\) matrices will have less effect on the cost than for a larger control horizon. Examples of how the prediction and control horizons and objective weights affect a SISO plant are given in chapter five of [6].
Autonomous Navigation
The adaption of model predictive control to autonomous navigation is quite natural; in fact, driving is a common analogy for explaining the principle ideas of MPC [6], [29]. Depending on the particular model, we derive state and input vectors representing physical attributes of the vehicle. Then we can use the MPC formulation outlined above, with some previously planned path serving as the nominal trajectory, to enable trajectory replanning and following.
Optimization Problem
The control problem for an autonomous vehicle without obstacle avoidance can be represented as the optimization problem \[\begin{alignat}{2} &\mathop{\mathrm{argmin}}_{U} \sum_{k=0}^{H_p - 1} \lVert \xi_k - \xi^{\text{ref}}_k \rVert_{Q}^2 + \sum_{k=0}^{H_c - 1} \left( \lVert u_k \rVert_{R}^2 + \lVert \Delta u_k \rVert_{S}^2 \right) && \label{eq:2a} \\ \text{subj. to }& \nonumber \\ & \xi_{k+1} = f(\xi_k, u_k), \quad && k = 0, \dots, H_p - 1 \label{eq:2b} \\ & u_{\text{min}} \leq u_k \leq u_{\text{max}} \quad && k = 0, \dots, H_c - 1 \label{eq:2c} \\ & \xi_{\text{min}} \leq \xi_k \leq \xi_{\text{max}} \quad && k = 0, \dots, H_c - 1 \label{eq:2d} \\ & u_k = u_{H_c - 1}, \quad && k = H_c, \dots, H_p -1 \label{eq:2e} \\ & \xi_0 = \hat{\xi}_0 && \label{eq:2f} \\ & \Delta u_{k} = u_{k} - u_{k-1}, \quad && k = 0, \dots, H_c - 1 \label{eq:2g} \\ & u_{-1} = u(-t_s) && \label{eq:2h} \end{alignat} \label{eq:2}\] where \(\xi, \Xi\) have been substituted for the \(x, \mathcal{X}\) in Section 3 to represent the system state to distinguish it from the vehicle’s longitudinal position in the body frame. The state and inputs have box constraints due to the physical nature of the vehicle.
Car Models
We present two systems commonly used to model the vehicle in self-driving applications. Figure [fig:kin-model] describes notation used in both. We consider bicycle models, which lump together left and right front tires and left and right back tires into (imaginary) single front and rear tires.
While the notion of a bicycle model may seems reductive, bicycle models are popular in control design [8], [19], [22] for their balance between an accurate representation and computational simplicity. Kong et. al. examined the effectiveness of the kinematic and dynamic models by comparing the models’ open loop predictions to measurements obtained from a real car driven by an experienced driver [12]. They concluded the kinematic bicycle model provided satisfactory control performance in a range of experiments, and held several advantages over the dynamic model. Nevertheless, both models have their place in control design.
Kinematic Bicycle Model
The kinematic bicycle model assumes the vehicle movement is a function of its geometry.
\[\begin{aligned} \dot{X} &= v \cos (\psi + \beta) \\ \dot{Y} &= v \sin (\psi + \beta) \\ \dot{\psi} &= \frac{v}{l_r} \sin\beta \\ \dot{v} &= a \\ \beta &= \tan^{-1} \left( \frac{l_r}{l_f + l_r} \tan\delta \right) \end{aligned}\]
The model locates the vehicle in the global coordinates \(X, Y\) with yaw \(\psi\) radians counterclockwise from the \(X\) axis. The velocity is a direct function of the acceleration \(a\). The slip angle \(\beta\) is obtained directly from geometric calculations. Note from Figure [fig:kin-model] that \(l_r\) and \(l_f\) represent the distance from the center of gravity to the rear and front wheelbase, respectively. The vehicle state vector is \(\xi = [ X, Y, \psi, v, \beta ]^T\) and the input vector is \(u = [a, \delta]^T\).
Dynamic Bicycle Model
The dynamic bicycle model incorporates the vehicle’s interaction with the road via the lateral forces on the front and rear tires \(F_{c, f}\) and \(F_{c, r}\), respectively.
\[\begin{aligned} \ddot{x} &= \dot{\psi} \dot{y} + a \\ \ddot{y} &= -\dot{\psi} \dot{x} + \frac{2}{m}\left( F_{c, f} \cos\delta + F_{c, r} \right) \\ \ddot{\psi} &= \frac{2}{I_z} \left( l_f F_{c, f} - l_r F_{c, r} \right) \\ \dot{X} &= \dot{x} \cos\psi - \dot{y} \sin\psi \\ \dot{Y} &= \dot{x} \sin\psi + \dot{y}\cos\psi \end{aligned}\] The dynamic bicycle model captures the longitudinal and lateral accelerations in the vehicle frame \(\ddot{x}\) and \(\ddot{y}\) respectively, as well the the angular acceleration \(\ddot{\psi}\).
To calculate the tire forces, standard control designs use the linear tire model \[\begin{aligned} F_{c, i} = -C_{\alpha_i} \alpha_i \end{aligned}\] where \(i\in \{ f, r \}\), \(\alpha_i\) is the tire slip angle and \(C_{\alpha_i}\) is the tire cornering stiffness. Most vehicle manuevers falls into the range of linear tire forces [8]. However, there are a number of tire models exist which capture the nonlinearities with various complexity, such as the uni-tire, magic formula, LuGre, and Fiala [18], [30]. The tradeoff for better tire representation in extreme maneuvers is more difficult parameter estimation.
Obstacle Avoidance
Naturally, we want to be able to replan in the presence of obstacles in the trajectory, whether those represent other cars or static things like debris in the road. We focus on two means of enabling obstacle avoidance. The first uses constraints to guarantee the trajectory can not pass over the obstacle. The second uses an additional term in the cost function to represent distance from the obstacle, thereby repelling the vehicle away from it. We introduce the idea in this section and examine their implementation in Section 5.
By adding a constraint on the position of the vehicle with respect to the obstacle, we can eliminate from contention those paths which would cause a collision. \[\begin{aligned} \text{dist}(\text{car}, \text{obstacle}) + \text{safetyMargin} \geq 0 \end{aligned}\] Since establishing the length of the shortest line between the car and the obstacle is an optimization problem in itself, finding \(\text{dist}(\text{car}, \text{obstacle})\) is hard in general. In [31], a method for reformulating general collision avoidance constraints into smooth, differentiable contraints to improve optimization efficiency is given.
Accordingly, we seek a more computationally efficient method for obstacle avoidance. In [8], the obstacle distance cost \(\text{Cost}_{\text{obs}, t}\) for time \(t\) is added to the cost function \[\begin{aligned} \text{Cost}_{\text{obs}, t} = \frac{K \cdot v_t}{\text{dist}(\text{car}, \text{obstacle}) + \epsilon} \end{aligned}\] where \(K\) is a weighting term, \(v_t\) is the predicted velocity at time \(t\), and \(\epsilon\) a small value to avoid singularity.
Experiments
We implemented the control design presented in Section 4 in order to test performance in different driving situations. Two reference trajectories were used. The first, ref1, is the sinusoidal trajectory
\[\begin{aligned} Y^{\text{ref}}(X)& = 4 \sin\left(\frac{2 \pi }{100} X \right) \\ \psi^{\text{ref}}(X) &= \tan^{-1} \left( \left(\frac{8\pi}{100}\right) \cos\left(\frac{2\pi}{100} X\right) \right) \end{aligned}\]
The second, ref2, is the double lane change maneuver \[\begin{aligned} {1} Y^{\text{ref}}(X) &= \frac{d_{y1}}{2} (1 + \tanh(z_1)) - \frac{d_{y2}}{2} (1 + \tanh(z_2)) \\ \psi^{\text{ref}}(X) &= \tan^{-1} \left(d_{y1} \left(\frac{1}{\cosh(z_1)}\right)^2 \left(\frac{1.2}{d_{x1}}\right) - d_{y2} \left(\frac{1}{\cosh(z_2)^2}\right)^2 \left(\frac{1.2}{d_{x2}}\right) \right) \end{aligned}\] defined in [8], where \(z_1 = \frac{2.4}{25} (X - 27.19) - 1.2\), \(z_2 = \frac{2.4}{21.95} (X - 56.46) - 1.2\), \(d_{x1} = 25\), \(d_{x2} = 21.95\), \(d_{y1} = 4.05\), \(d_{y2} = 5.7\).
We implemented the input constraints \[\begin{aligned} -1 \leq a \leq 1, -\frac{\pi}{4} \leq \delta \leq \frac{\pi}{4}, \end{aligned}\] to reflect the physical limitations of a real car.
The initial state was \(\xi = [0, 0, 5, 0]\), or an initial velocity of 5 m/s. Without the presence of obstacles, the closed loop result almost exactly matches the reference trajectory (\(H_p = 5, H_c = 2\)).
Note the small scale in Figure 6, which shows the lateral trajectory almost exactly matched the reference. The same can be seen for ref2.
Now we turn our attention to the obstacle avoidance techniques introduced in Section 4.3. We define an obstacle as a rectangle along ref1. The vehicle must maneuver to avoid the obstacle to prevent a collision. We first examine the contraint-based technique in open-loop planning, in order to easily observe the properties of the generated trajectory. We restrict the number of the iterations the solver can take in order to reflect the potential real-time constraint when driving.
As the iterations increase, the paths become progressively smoother and converge with respect to the reference trajectory. However, the fact that every iteration has to calculate the distance to the obstacle at each control instance over the prediction horizon results in a significant computational cost which increases linearly with the number of iterations (Figure 16).
On the other hand, the cost-based avoidance method is much less computationally demanding (Figure 15). We implemented the approach described in [8] with \(K = 0.5\), \(\epsilon = 0.01\) on ref1 with the same obstacle as before.
In contrast the constraint approach, as shown in the example restricted to five iterations, there is no guarantee the controller will not plan a trajectory arbitrarily close to the obstacle. Furthermore, the obstacle cost term \(K\) must be determined on an ad-hoc basis and different values could give better or worse results depending on the exact scenario.
Note the scales in Figure [fig:costs] differ by an order of magnitude. Since real-time implementation is a central concern for MPC schemes, the computational benefit of a cost-term approach may be desirable, but depending on the application, the greater predictability of constraints could be necessary.
Conclusion
Model predictive control has been applied to many industrial processes with tremendous success. Its natural adaptation to autonomous navigation has resulted in many viable control designs, especially for linear vehicle models. The main challenge in MPC for autonomous vehicles has been the computational challenges associated with maintaining a high sampling rate while using a model detailed enough to capture nonlinearities. While advances in computing power have made such a trade-off feasible, mathematical advances in formulating the control problem continue to play their part. Much research now is focused on the concepts of robust and stochastic model predictive control, which is required to deal with the inherent environmental uncertainties encountered when driving. Possible extensions to the work described in this report include taking into account model parameter uncertainties or estimating model parameters online.
As noted in the introduction, the ultimate goal of researching autonomous navigation MPC schemes is to enable their implementation in consumer vehicles. To this end, the author believes a more general framework for choosing the vehicle’s actions is required to supervise any MPC implementations in the vehicle. To this end, future work on autonomous navigation should focus on general artificial intelligence for decision-making under uncertainty.
[1] N. H. T. S. Administration, “The economic and societal impact of motor vehicle crashes, 2019 (revised),” Feb. 2023, Available: https://crashstats.nhtsa.dot.gov/Api/Public/ViewPublication/813403
[2] N. H. T. S. Administration, “Early estimates of motor vehicle traffic fatalities and fatality rate by sub-categories in 2021,” May 2022, Available: https://crashstats.nhtsa.dot.gov/Api/Public/ViewPublication/813298
[3] S. D. Pendleton et al., “Perception, planning, control, and coordination for autonomous vehicles,” Machines, vol. 5, no. 1, p. 6, 2017.
[4] S. O.-R. A. V. S. Committee et al., “Taxonomy and definitions for terms related to driving automation systems for on-road motor vehicles,” SAE International: Warrendale, PA, USA, 2018.
[5] E. F. Camacho and C. Bordons, Model predictive control, 2nd ed. in Advanced textbooks in control and signal processing. London New York: Springer, 2004.
[6] J. A. Rossiter, Model-based predictive control: A practical approach. CRC press, 2003.
[7] D. Q. Mayne, J. B. Rawlings, C. V. Rao, and P. O. M. Scokaert, “Constrained model predictive control: Stability and optimality,” p. 26, 2000.
[8] Y. Gao, Model predictive control for autonomous and semiautonomous vehicles. University of California, Berkeley, 2014.
[9] Y. Gao, T. Lin, F. Borrelli, E. Tseng, and D. Hrovat, “Predictive control of autonomous ground vehicles with obstacle avoidance on slippery roads,” in Dynamic systems and control conference, 2010, pp. 265–272.
[10] M. A. Abbas, R. Milman, and J. M. Eklund, “Obstacle Avoidance in Real Time With Nonlinear Model Predictive Control of Autonomous Vehicles,” Canadian Journal of Electrical and Computer Engineering, vol. 40, no. 1, pp. 12–22, 2017, doi: 10.1109/CJECE.2016.2609803.
[11] C. Badue et al., “Self-driving cars: A survey,” Expert Systems with Applications, vol. 165, p. 113816, 2021.
[12] J. Kong, M. Pfeiffer, G. Schildbach, and F. Borrelli, “Kinematic and dynamic vehicle models for autonomous driving control design,” in 2015 IEEE Intelligent Vehicles Symposium (IV), 2015, pp. 1094–1099. doi: 10.1109/IVS.2015.7225830.
[13] V. Turri, A. Carvalho, H. E. Tseng, K. H. Johansson, and F. Borrelli, “Linear model predictive control for lane keeping and obstacle avoidance on low curvature roads,” in 16th International IEEE Conference on Intelligent Transportation Systems (ITSC 2013), Oct. 2013, pp. 378–383. doi: 10.1109/ITSC.2013.6728261.
[14] J. Ji, A. Khajepour, W. W. Melek, and Y. Huang, “Path Planning and Tracking for Vehicle Collision Avoidance Based on Model Predictive Control With Multiconstraints,” IEEE Transactions on Vehicular Technology, vol. 66, no. 2, pp. 952–964, Feb. 2017, doi: 10.1109/TVT.2016.2555853.
[15] B.-C. Chen, B.-C. Luan, and K. Lee, “Design of lane keeping system using adaptive model predictive control,” in 2014 IEEE International Conference on Automation Science and Engineering (CASE), Aug. 2014, pp. 922–926. doi: 10.1109/CoASE.2014.6899436.
[16] C. Liu, S. Lee, S. Varnhagen, and H. E. Tseng, “Path planning for autonomous vehicles using model predictive control,” in 2017 IEEE Intelligent Vehicles Symposium (IV), Jun. 2017, pp. 174–179. doi: 10.1109/IVS.2017.7995716.
[17] P. Falcone et al., “Nonlinear model predictive control for autonomous vehicles,” 2007.
[18] A. Carvalho, S. Lefévre, G. Schildbach, J. Kong, and F. Borrelli, “Automated driving: The role of forecasts and uncertainty—A control perspective,” European Journal of Control, vol. 24, pp. 14–32, Jul. 2015, doi: 10.1016/j.ejcon.2015.04.007.
[19] Y. Gao, A. Gray, H. E. Tseng, and F. Borrelli, “A tube-based robust nonlinear predictive control approach to semiautonomous ground vehicles,” Vehicle System Dynamics, vol. 52, no. 6, pp. 802–823, Jun. 2014, doi: 10.1080/00423114.2014.902537.
[20] B. Yi, P. Bender, F. Bonarens, and C. Stiller, “Model Predictive Trajectory Planning for Automated Driving,” IEEE Transactions on Intelligent Vehicles, vol. 4, no. 1, pp. 24–38, Mar. 2019, doi: 10.1109/TIV.2018.2886683.
[21] A. Mesbah, “Stochastic Model Predictive Control: An Overview and Perspectives for Future Research,” IEEE Control Systems Magazine, vol. 36, no. 6, pp. 30–44, Dec. 2016, doi: 10.1109/MCS.2016.2602087.
[22] A. Carvalho, Y. Gao, S. Lefevre, and F. Borrelli, Stochastic predictive control of autonomous vehicles in uncertain environments. 2014.
[23] A. Wächter and L. T. Biegler, “On the implementation of an interior-point filter line-search algorithm for large-scale nonlinear programming,” Mathematical programming, vol. 106, pp. 25–57, 2006.
[24] Mathworks, “Find minimum of constrained nonlinear multivariable function,” Mathworks Help Center. Available: https://www.mathworks.com/help/optim/ug/fmincon.html#busp5fq-6
[25] Mathworks, “Nonlinear MPC,” MATLAB Help Center. Available: https://www.mathworks.com/help/mpc/ug/nonlinear-mpc.html
[26] S. Diamond and S. Boyd, “CVXPY: A Python-embedded modeling language for convex optimization,” Journal of Machine Learning Research, vol. 17, no. 83, pp. 1–5, 2016.
[27] A. Agrawal, R. Verschueren, S. Diamond, and S. Boyd, “A rewriting system for convex optimization problems,” Journal of Control and Decision, vol. 5, no. 1, pp. 42–60, 2018.
[28] R. Findeisen and F. Allgöwer, “An introduction to nonlinear model predictive control,” 2002. Available: https://pure.tue.nl/ws/files/3079152/555518.pdf#page=120
[29] J. B. Rawlings, “Tutorial overview of model predictive control,” IEEE Control Systems Magazine, vol. 20, no. 3, pp. 38–52, Jun. 2000, doi: 10.1109/37.845037.
[30] H. Guo, Z. Yin, D. Cao, H. Chen, and C. Lv, “A Review of Estimation for Vehicle Tire-Road Interactions Toward Automated Driving,” IEEE Transactions on Systems, Man, and Cybernetics: Systems, vol. 49, no. 1, pp. 14–30, Jan. 2019, doi: 10.1109/TSMC.2018.2819500.
[31] X. Zhang, A. Liniger, and F. Borrelli, “Optimization-Based Collision Avoidance,” IEEE Transactions on Control Systems Technology, vol. 29, no. 3, pp. 972–983, May 2021, doi: 10.1109/TCST.2019.2949540.