Skip to content

Selected Topics in Mathematical Optimization, now in Julia

License

Notifications You must be signed in to change notification settings

francops1722/STMO

 
 

Repository files navigation

Selected Topics in Mathematical Optimization

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.

Course content

  1. Intro to Julia and bracket search
  2. Quadratic optimization
  3. Automatic differentiation
  4. Unconstrained convex optimization
  5. Constrained convex optimization
  6. Optimal transportation
  7. Minimum spanning trees
  8. Shortest path problems
  9. NP-hard problems
  10. Heuristics and metaheuristics

Using this repo

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.

Binder

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.

Installation instructions

Github

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.

Installing Julia

  1. Download the Julia binaries for your system here we suggest installing the current stable release, v1.5.0
  2. Check the Platform Specific Instructions of the official website to install Julia

Installing the STMO package

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 the master branch.

Running the IJulia Notebook

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.

Gitter

While the course is given remotely, you can ask questions about the project and chapters via Gitter:

Gitter

About

Selected Topics in Mathematical Optimization, now in Julia

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Jupyter Notebook 80.9%
  • Julia 19.1%