Edition 2020-2021
Michiel Stock
Maxime Van Haeverbeke
This repository contains the notes and exercises of the optimization course given in the Master of Bioinformatics Bioscience Engineering and Systems Biology at Ghent University.
The goal of this course is to give students a general overview of the rich field of mathematical optimization. This course will put a particular emphasis on practical implementations and performance. After this course, students should be able to formulate problems from computational biology as optimization problems and be able to interpret, understand, and implement new optimization algorithms.
As of 2020, we have chosen to move this course from Python to the new Julia programming language. This is not because we are too cool for Python, but because Julia is supremely suited for scientific computing. Furthermore, Julia code can be made extremely performant, on par with optimized C code. We don't expect students to fully optimize code, but throughout, we will give hints and guidelines on how to generally improve implementations, in Julia or other programming languages. No prior knowledge of Julia is needed. We will learn while doing it! To get started, you can check out our quick start guide and if you get lost, we recommend taking a look at the cheat sheet.
- Intro to Julia and bracket search
- Quadratic optimization
- Automatic differentiation
- Unconstrained convex optimization
- Constrained convex optimization
- Optimal transportation
- Minimum spanning trees
- Shortest path problems
- NP-hard problems
- Heuristics and metaheuristics
If you have Julia and IJulia-notebooks installed, clone the repo (check the section on GitHub below if you don't know what this means) and work locally in the notebooks, this is recommended as it is the only way to save your work. Otherwise, click on the badge below to open a Binder session or check the installation instructions below to install Julia and IJulia-notebooks.
While using Binder is convenient in the short term, it will take a while to start up every time, and it will only allow you to follow along with the notebooks, without having the ability to save your work.
All notebooks and pdf notes are generated from the .jmd
files in all the chapter folders. These can be build by running the build.jl
script in Julia:
include("build.jl")
Beware that building the course will take a while.
In addition to the Jupyter notebooks and PDF notes, running this script also generates some example figures. We encourage students to take a look in the scrips/
folder for some examples illustrating the theory. All PDF notes will also be made available on Ufora.
This repository also represents a Julia package, which can be loaded in the Julia REPL.
using STMO
This package contains the solution to most implementation exercises in this course. It also includes a wealth of helper functions for plotting etc.
Using Git or Github desktop is recommended for this course. In case you don't already have git or Github installed, this can be done by following the instructions for your operating system here here for Git and here for GitHub desktop. Using git, clone (i.e., download the files of) the course repository by typing
git clone https://github.com/MichielStock/STMO.git
In the command prompt, after navigating to where you want to save the course files.
- Download the Julia binaries for your system here we suggest installing the current stable release, v1.5.0
- Check the Platform Specific Instructions of the official website to install Julia
All required packages for this course are bundled together in the STMO package, which can be installed as follows.
In Julia, enter package mode by pressing the "]
" key. All required packages will be installed by then typing (or copying) at the (v1.5) pkg>
prompt:
add https://github.com/MichielStock/STMO.git
This course is work in progress and will likely be updated throughout the year. At the start of every lecture, it is a good idea to update the package by typing
update STMO
in the package mode and rebasing your repository to be in sync with themaster
branch.
If you are comfortable managing your own Python/Jupyter installation, you can just run jupyter notebook
yourself in a terminal. To simplify installation, you can alternatively type the following in Julia, at the julia>
prompt:
using IJulia
to install the IJulia kernel.
While the course is given remotely, you can ask questions about the project and chapters via Gitter: