Hands-on CasADi course on optimal control

November 18-20, 2024 – Leuven, Belgium

(download this description as flyer)

Target audience

Academic/industrial researchers or tool-developers that seek practical ways to tackle large/complex continuous optimization problems, and optimal control problems in particular. People seeking to quickly gain familiarity with CasADi through a broad range of practical exercises.

CasADi?

Originating from KU Leuven’s “Optimization in Engineering Center” under guidance of prof. Moritz Diehl, CasADi [1] is an open-source software framework for nonlinear optimization and algorithmic differentiation. It facilitates rapid - yet efficient - implementation of different methods for numerical optimal control, both in an offline context and for nonlinear model predictive control.

Format

Seminars (40%) paired with computer exercises (60%). The seminars provide a bird’s-eye view on optimization and optimal control, serving as teaser for further study or as recap for the experienced. The computer exercises aim to deepen understanding of the theory, and leave the participants well-equipped to solve a broad range of problems using CasADi by themselves.

Covered topics

Newton-type methods for constrained nonlinear programming – integration methods – direct transcription of optimal control problems (OCP) – model predictive control (MPC) – CasADi 3.6 syntax and best practices

(click for more details)

Module 1: Rootfinding on a nonlinear set of equations: Newton's method
  • Understand the Newton step in a high-dimensional search space
  • Understand how (approximated) Jacobians are central to the Newton's method
  • Using CasADi to evaluate Jacobians
  • Understand some common failure modes of Newton's method
Module 2: CasADi basics: Expressions graphs and Functions
  • Get a clear mental image on basic CasADi concepts
  • Get acquainted with a consistent vocabulary to talk about CasADi concepts
  • Reason about CasADi types
  • Learn to read CasADi error messages
Module 3: Constraint nonlinear programming: Newton-type methods and interior point
  • Understand the conditions for optimality
  • Understand how Newton-type methods orginate from rootfinding
  • Learn how to build an SQP and interior point method in CasADi
Module 4: Integration of CasADi integrator, rootfinder and nonlinear programming
  • Learn how to compose CasADi building blocks to solve non-trivial engineering problems
Module 5: CasADi Opti stack for easy nonlinear programming
  • Learn how to use Opti for nonlinear programming
  • Learn some simple debugging skills for common failure cases of nonlinear programming
Module 6: Nonlinear programming for fitting problems
  • Understand how several fitting algorithms are related
  • Learn how to use L1 and L2 norms in CasADi
  • Understand the robustness property of L1 norm
  • Solve a parameter estimation problem from scratch in Opti
Module 7: Direct methods for optimal control
  • Understand single shooting and multipleshooting
  • Understand the sparsity structure present in multiple shooting
  • Learn how to choose between single- and multiple shooting
Module 8: Implementing model predictive control in CasADi
  • Understand MPC as an extension of optimal control
  • Learn how to speed up a CasADi MPC problem
  • Understand that MPC does not necessarily lead to a good controller
Module 9: Time-optimal control in CasADi
  • Understand how time-optimal control is intrinsically harder
  • Understand the difference between trajectory tracking and path tracking
  • Learn how to implement periodic racing problems
  • Learn how to interpret Lagrange multipliers
Module 10: Dealing with non-smoothness in optimal control
  • Learn how destroy convergence.
  • Learn how artificial smoothing is a pragmatic strategy with trade-offs.
  • Learn how an exact reformulation can avoid trade-offs.
Module 11: Perform integration of system dynamics with collocation.
  • Get an intuitive understanding of a collocation method
  • Understand the connection to rootfinding
Module 12: Another direct method for optimal control: direct collocation
  • Understand how direct collocation differs from multiple shooting with a collocation integrator
  • Learn how to implement direct collocation
  • Understand the sparsity structure resulting from direct collocation
  • Learn the benefits of direct collocation
The contents of the physical course will be close to the contents of the self-paced hands-on course, with updates from casadi 3.6. What sets the physical course apart is really the networking opportunity, ability to ask live questions, the focus and the peer pressure that provides a stimulus to perform the exercises instead of procrastinating. In practice, I see a large difference in capabilities of students coming out of these courses, in spite of the proximity in contents.

Prerequisites

Basic mathematical skills (analysis, calculus, linear algebra) are required. Experience with programming in MATLAB/Octave or Python is required, unless you partner up with an experienced person.

Tutor

Joris Gillis obtained his PhD in electrical engineering at KU Leuven in 2015. Currently active at MECO, KU Leuven and part-time freelancer, he pursues large-scale applications in optimal control and is highly active as a main developer of CasADi since 2010.

Practicalities

The course will take place at the Park Inn hotel, Martelarenlaan 36, 3010 Leuven, Belgium, starting each day at 9:00 and ending at 18:00. Participants are required to bring their own laptops (Linux/Windows/Mac); no software is needed besides a working installation of MATLAB/Octave or Python.

Registration

The registration fee amounts to 1050 EUR excl. VAT (850 EUR for PhD students). Early bird discount (75 EUR) applies until July 1. The registration fee covers for daily mini-breakfasts, refreshments during the breaks, and lunch. A joint dinner is included on Tuesday evening. Lodging is not included.

The number of participants is capped to 40. Registration closes October 20.

Register now

Subscribe to the newsletter if you wish to be kept up to date of further courses. You may also pre-register to a future course to get priority in registration, or follow a pre-recorded course.

Organizer: Joris Gillis, joris@yacoda.com, +32496432937, Yacoda BV, Glabbeeksestraat 37, 3300 Vissenaken, Belgium. BE0642979742

[1] Joel A. E. Andersson, Joris Gillis, Greg Horn, James B. Rawlings, M. Diehl, “CasADi – A software framework for nonlinear optimization and optimal control,” Mathematical Programming Computation, 2018.