Skip to content

Integer linear programming (ILP) approach to the school timetabeling problem.

License

Notifications You must be signed in to change notification settings

vtfanta/ILP-Timetable-Maker

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

3 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ILP Timetable Maker

This project has been done as a semestral work for the Combinatorial Algorithms course held at the Czech Technical University in Prague in the summer semester of 2021/2022.

The task was to design an algorithm which provides a timetable for the whole school under the given constraints. The constraints include (not exhaustively):

  • Number of teachers is limited,
  • individual teachers can teach only certain subjects,
  • number of classrooms is limited,
  • the class' curriculum has to be fulfilled,
  • if a class has lessons in the afternoon, lunch break has to be included,
  • capacity of the school canteen is limited at any given time
  • ...

The problem is solved using the integer linear programming and uses the Gurobi solver and its Python API.

Further details are described in the PDF report.

An example of the resulting timetable is shown below.

Resulting timetable.

About

Integer linear programming (ILP) approach to the school timetabeling problem.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages