Skip to content
This repository has been archived by the owner on Dec 16, 2022. It is now read-only.

Latest commit

 

History

History
98 lines (71 loc) · 3.71 KB

README.md

File metadata and controls

98 lines (71 loc) · 3.71 KB

DOI:10.1016/j.cor.2022.106089

PL-Heuristic

Code and experiments for the paper:

Wouda, Niels A., Ayse Aslan, and Iris F. A. Vis. 2023. ‘An Adaptive Large Neighbourhood Search Metaheuristic for Hourly Learning Activity Planning in Personalised Learning’. Computers & Operations Research 151: 106089. https://doi.org/10.1016/j.cor.2022.106089.

This repository hosts all code used in the development of an hourly scheduling heuristic for personalised learning. The repository exposes several executable packages: one for the heuristic, the integer linear program model, the validator, and an analysis tools for the heuristic and ILP results. The heuristic quickly solves a problem using a sub-optimal method (minutes). The ILP takes considerably longer (hours to days), but does guarantee optimality. The validator tool verifies a given solution satisfies the imposed constraints.

Note that this repository assumes an /experiments directory is set-up, and populated with the experimental data. The data is of considerable size, and as such not part of the repository itself. The data may be downloaded from the data repository (download the file first revision.zip).

Finally, analysis notebooks are available in /notebooks. These notebooks reproduce the results from the paper.

Analysis

The analysis tool is available in src/analyse.py. It can be used to analyse results from an ILP or heuristic run on an entire experiment. Usage,

poetry run python -m src.analyse heuristic 1

Which analyses the heuristic output in experiment 1. If an output does not exist, it is skipped - you are informed of this. After analysing all files in an experiment, a cached file is created in cache/ to speed-up subsequent analyses - this can be overridden using the --force flag. Use the --help flag to see all options.

Notebooks analysing the cached files are available in the repository root. These contain most results described in the paper.

How to use

Ensure you have a recent Python environment (e.g. Python 3.9) and install the packages indicated in the pyproject.toml file.

For the ILP formulation, more is needed: you need to have Gurobi installed on your machine, with the relevant Python bindings exposed.

Heuristic

Available in src/heuristic.py. The heuristic is based on the adaptive large neighbourhood search (ALNS) metaheuristic, and performs several operators to achieve a reasonable solution in little time. No optimality guarantees are made. Usage,

poetry run python -m src.heuristic 1 5

For experiment 1, instance 5. The assignment output will be written to the experiments directory, as experiments/1/5-heuristic.json.

ILP

Available in src/ilp.py. The ILP solves the indicated experiment instance to optimality, but might take a considerable amount of time to achieve this. Furthermore, the ILP relies on Gurobi, which is commercial software. Usage,

poetry run python -m src.ilp 1 5

For experiment 1, instance 5. The assignment output will be written to the experiments directory, as experiments/1/5-ilp.json.

Validator

Available in src/validator.py. Given the by now familiar experiment and instance arguments, the validator confirms the ILP and heuristic solutions (where available) satisfy the problem constraints. Usage,

poetry run python -m src.validator 1 5

For experiment 1, instance 5. An exit code of 0 indicates the ILP and heuristic solutions both meet the problem constraints, 1 suggests one or more constraints fail. In this case output is printed hinting which constraint is violated.