See our gallery for images of the flying arena where students implement their algorithms for making a quad-rotor drone fly autonomously.
Abstract
Quad-rotors are becoming more and more commonplace as technological advancements increase capabilities and reduce costs. Quad-rotor vehicles are encountered both for domestic entertainment and industrial applications, some examples are: toys for people of all ages, professional cinematography, or, inspection of industrial scale structures and processes. One reason why quad-rotors have become so pervasive is their mechanical simplicity, which lends itself to the high operational reliability. Moreover, the control and estimation techniques required to stabilise a quad-rotor around hover utilises only the control theory taught to under-graduates, while acrobatic feats and fleet manoeuvres inspire many directions in current research.The learning objectives of this course are:
- Be able to derive the continuous-time equations of motion for a general N-rotor vehicle,
- Be able to simulate a general N-rotor vehicle for the purpose of testing and tuning controller and estimator designs,
- Be able to explain how flight performance is affected by changes in the parameters of the N-rotor vehicle, for example mass, centre of gravity location, propeller aerodynamics,
- Be able to explain why a quad-rotor design allows the control architecture to be de-coupled into a collection of separate simple controllers,
- Experienced the challenges of tuning a PID and/or LQR controller for achieving stable hover of a quad-rotor, both in simulation and on the real-world system,
- Be able to write C++ code for implementing a PID and/or LQR controller.
This video shows highlights from the third time we ran the course in Autumn semester 2018.
Since then we made some adjustments to accommodate online teaching while still enabling the hands-on element of the course. This video shows highlights from this transition and the Spring semester 2020.
Course Material
We are still updating aspects of the course, so please check here occasionally for the latest script and exercise materials.Course Script
		The course script is intended as a stand alone script that allows the student to review all the theory we cover in class, as well as provide additional information for those students wishing to delve further particular topics.
		
		The script can be downloaded here (Version 2023-Feb-22), and is also available in the ETH Research Collection.
		
		The script includes a introduction to Simulink tutorial that provides step-by-step instructions for simulating a simple pendulum system. The end point of the tutorial can be downloaded with the following links. The multiple Simulink files are identical, just saved for different versions of Matlab, choose the file that is compatible with the version of Matlab you have installed on your computer.
		
		Parameter script:  
			matlab parameter script
		
		Simulink template:  
			R2017b
			,  
			R2015a
		
		(These files were uploaded on 2018-Feb-14)
		
Class dates for the Autumn 2025 Semester
		The first class will take place on Wednesday, September 24, 2025, 08:15-12:00 in Room GLC E24 for ALL enrolled students.
        
        Following that, classes will occur as enlisted below.
        The students will be split into two groups (A and B) and the classes for each group will occur, in most cases, on alternating weeks.
        
        The schedule for Group A is:
        
- Class 2, Wednesday, October 01, 2025, 08:15-12:00, Room GLC E29.1
- Class 3, Wednesday, October 15, 2025, 08:15-12:00, Room GLC E29.1
- Class 4, Wednesday, October 29, 2025, 08:15-12:00, Room ETL D12
- Class 5, Wednesday, November 12, 2025, 08:15-12:00, Room ETL D12
- Class 6, Wednesday, November 26, 2025, 08:15-12:00, Room ETL D12
And the schedule for Group B is:
- Class 2, Wednesday, October 08, 2025, 08:15-12:00, Room GLC E29.1
- Class 3, Wednesday, October 22, 2025, 08:15-12:00, Room GLC E29.1
- Class 4, Wednesday, November 05, 2025, 08:15-12:00, Room ETL D12
- Class 5, Wednesday, November 19, 2025, 08:15-12:00, Room ETL D12
- Class 6, Wednesday, December 03, 2025, 08:15-12:00, Room ETL D12
Exercise 1
			The goal of exercise 1 is to simulate the equations of motion for an N-rotor vehicle and through this gain a deeper understanding and intuition for the vehicle's behaviour.
			
			Exercise Sheet (Version 2020-Sept-28)
			
			The following files provide a template for Simulink that will assist in getting started with this exercise. To use the template you should save all files locally on you computer into the same folder. The multiple Simulink files are identical, just saved for different versions of Matlab, choose the file that is compatible with the version of Matlab you have installed on your computer.
			
			Parameter scripts: (right-click and select "Download linked file")
			
simulation paramters
			
get vehicle paramters
			
visualise N-rotor vehicle
			
get default controller
			
compute equilibrium thrusts
			
get reference specification
			
function equations of motion template
			
			Simulink template:  
				R2017b
				,
				R2016b
				,  
				R2015b
			
			Or, for convenience, all files together in one Zip file
			
			(These files were uploaded on 2023-Feb-22)
			
			The following files provide a sample solution to part A of this exercise. Only the Simulink file is provided and should be saved into the same folder as all the template files provided above. This Simulink file with the solution can be open and run without causing any conflict with the template Simulink file that you edited as part of completing part A of the exercise sheet.
			
			Solution for Part A:  
				R2017b
				,
				R2016b
				,
				R2015b
			
			(These files were uploaded on 2023-Feb-22)
			
			
			
			
			
			
			
		
Exercise 2
			The goal of exercise 2 is to design, implement, and tune a PID and LQR controller for the Crazyflie 2.0 quad-rotor vehicle.
			
			Exercise Sheet (Version 2023-Feb-22)
			
			
			The following files provide a template for Simulink that are the starting point for this exercise. To use the template you should save all files locally on you computer into the same folder. The multiple Simulink files are identical, just saved for different versions of Matlab, choose the file that is compatible with the version of Matlab you have installed on your computer.
			
			Parameter scripts: (right-click and select "Download linked file")
			
simulation paramters
			
get crazyflie vehicle paramters
			
visualise N-rotor vehicle
			
get default controller
			
get crazyflie inner controller
			
compute equilibrium thrusts
			
get measurement noise details
			
get reference specification
			
			Simulink template:  
				R2017b
				,
				R2016b
				,  
				R2015b
			
			Or, for convenience, all files together in one Zip file
			
			(These files were uploaded on 2023-Feb-22)
			
			
			
			
			Visualisation
			
			The following script plots a visualisation of the N-rotor vehicle design:
			
			N-rotor vehicle visualisation script
			
			The following script plots a visualisation of trajectory simulated by the Simulink model:
			
			Trajectory visualisation script
			
			To use the trajectory visualisation script, first compile and run the Simulink model, then enter either of the following commands in the Matlab Command Window:
			
>> traj_handles = visualise_nrotor_trajectory( simout_full_state ) >> traj_handles = visualise_nrotor_trajectory( simout_full_state , [] , nrotor_vehicle_layout_true )
Exercise 3
			The goal of exercise 3 is to familiarise with the practical setup and then implement and tune a PID controller for altitude and yaw.
			
			Exercise Sheet (Version 2022-Sep-26)
			
			
			
			
		
Exercise 4
			The goal of exercise 4 is to continue your implementation and tuning a PID controller for altitude and yaw, and then to implement an LQR controller for the x and y positions.
			
			Exercise Sheet (Version 2022-Sep-26)
			
			
			
			The following example MATLAB script will assist in tuning your outer LQR controller. To use the example you should save the file locally on you computer and run the script in MATLAB. Further details are explained in the comments of the script.
			Note that the controller sample time in the lab is 1/200 and 1/50 for the at home setup.
			
			
			matlab LQR synthesis example script