EvoLP.jl

A playground for evolutionary computation in Julia

EvoLP.jl is a playground for evolutionary computation in Julia. It provides a set of predefined building blocks that can be coupled together to quickly generate evolutionary computation solvers and compute statistics for a variety of optimisation tasks, including discrete, continuous and combinatorial optimisation.

Features

You can combine these blocks to make your own algorithms or use some of the included minimisers: a generational GA, 1+1 Evolutionary Algorithm and Particle Swarm Optimisation solver.

Installation

You can install EvoLP from the REPL using the built-in package manager:

julia> import Pkg
julia> Pkg.add("EvoLP")

Getting started

Citing EvoLP.jl

If you find EvoLP.jl useful in your work or research, we kindly request that you cite the following paper:

@inproceedings{Sanchez-DiazEvoLP2023a,
  address = {Bergen, NO},
  author = {Sánchez-Díaz, Xavier F. C. and Mengshoel, Ole Jakob},
  booktitle = {Proceedings of the 5th Symposium of the Norwegian AI Society},
  editor = {Galimullin, Rustam and Touileb, Samia},
  month = jun,
  publisher = {CEUR Workshop Proceedings},
  series = {NAIS 2023: Symposium of the Norwegian AI Society 2023},
  title = {EvoLP.jl: A Playground for Evolutionary Computation in Julia},
  url = {https://ceur-ws.org/Vol-3431/},
  year = {2023}
}

Acknowledgements

       

EvoLP.jl started as a toolbox for internal use by PhD students of NTNU’s Open AI Lab, and whose funding is provided by Project no. 311284 by The Research Council of Norway.

License

EvoLP is licensed under the MIT License which makes it free and open source.