Best assignment solutions for Natural Computing 2023/2024 offered by the University of Edinburgh. The repository contains algorithm implementations for Particle Swarm Optimization (and its variants, i.e., Cuckoo Search, Bat Algorithm, Differential Evolution), Genetic Algorithm (canonical), and Genetic Programming (tree-based). Two main directories:
documents
: contains coursework description and my reportnotebooks
: contains experiments for each of the questions
In addition, I attached my course notes. These are, however, squeezed into 6 pages which is what is allowed to be used during the NOTES PERMITTED exam.
The coursework is worth 40% of the overall course mark, only the report is assessed but the code must be provided. Maximum points (100/100) were achieved with the following feedback:
Fantastic study! Your coursework meets and exceeds expectations, demonstrating a quality that could be considered for publication. Your efforts and achievements are just excellent. Well done!
The source code (src
) mainly contains classes and functions that model certain algorithms and problems. Notebooks focus on experiments with those algorithms and problems. In particular see:
- problem1.ipynb: experiments for answering question 1 about particle cooperation
- problem2.ipynb: experiments for answering question 2 about GA and Sumplete
- problem3.ipynb: experiments for answering question 3 about GP and sequence generation
The experiment result files are not provided, however, they can all be reproduced by rerunning the cells (some may take several hours to run). There is actually no need to run the notebooks since the outputs are left displayed.
Documentation is only written for the major classes
Please use at least Python 3.10. For rendering graphs for Genetic Programming question, please install Graphviz. For example, if you're using Ubuntu:
sudo apt-get install graphviz
There are some package requirements as well. PLease install them as follows:
pip install -r requirements.txt
Please also note that the cells are designed to be run in sequence and no previous cell is expected to be rerun. This is because most of teh subsequent cells overwrite the variables created by the previous cells (for easier readability, variable names are intended to be kept the same throughout the notebooks for every experiment). So, for example, instead of initializing N_experiment_1
, N_experiment_2
, etc., the same variable N
is refreshed (with possibly different values) in every subsequent cell.
Although this may not be a good practice for long experiments (due to the results possibly getting lost), this is still intended because all the experiments are saved and can be quickly reloaded, in case we need to rerun the cells (e.g., if we change the style of the plots).
Experiments will be automatically saved as .npz
files with names generated from variable and static arguments, i.e., based on parameters that are being experimented with and the default ones. Note that, although for static arguments values are also labeled, e.g., if a static parameter is static_param["num_evaluations"] = 5000
, then the filename will match that, i.e., num_evaluations=5000.npz
, the same is not done for variable parameters (otherwise there would be too many values), only the parameter names are included, e.g., if a variable parameter is variable_param['N'] = range(1, 101)
, then the filename will match only the variable name, i.e., [N].npz
.
For this reason if multiple experiments are performed with different variable parameters, please note that the saved files may override the other ones. So either include some unique ranges for every experiment that uses the same variable parameters or include a dummy label in a static parameters dictionary, e.g., static_param["version"]=1
.
If the notebooks cannot be run due to failed imports, i.e., because sys.path.append
does not work in an expected way, please perform the following steps:
- Move
src
directory tree insidenotebooks
folder. The file layout should now look as follows:└── path/to/nat2324 ├── notebooks | ├── src/nat2324 # The source code (folders and python files) | ├── problem1.ipynb # Problem 1 notebook | ├── problem2.ipynb # Problem 2 notebook | └── problem3.ipynb # Problem 3 notebook └── ... # Other files and folders except `src`
- Prepend
src.
before imports fromnat2324
, e.g., the setup cell inproblem1.ipynb
would now look as follows:import numpy as np from src.nat2324.problems import Objective from src.nat2324.algorithms import SwarmOptimization from src.nat2324.utils import *
Some of the algorithm implementations (particularly in problem 1) took inspiration from existing repositories, or online tutorials:
- Differential Evolution: https://medium.com/@reshma_shaji/differential-evolution-what-it-is-and-how-does-it-work-81d3415c2367
- Cuckoo Search: https://github.com/ujjwalkhandelwal/cso_cuckoo_search_optimization/blob/main/cso/cso.py and https://medium.com/@evertongomede/cuckoo-search-algorithm-mimicking-nature-for-optimization-2fea1b96c82b
- Bat Algorithm: https://medium.com/it-paragon/bat-algorithm-bad-algorithm-b26ae42da8e1
Other algorithm implementations were either covered in lectures or inspiration was taken from tutorials.