[BibTeX] cite as:
Nikolaus Hansen, Youhei Akimoto, and Petr Baudis. CMA-ES/pycma on Github. Zenodo, DOI:10.5281/zenodo.2559634, February 2019.
pycma is a Python implementation of CMA-ES and a few related numerical optimization tools.
The Covariance Matrix Adaptation Evolution Strategy (CMA-ES) is a stochastic derivative-free numerical optimization algorithm for difficult (non-convex, ill-conditioned, multi-modal, rugged, noisy) optimization problems in continuous search spaces.
Useful links:
-
The above
notebooksfolder has some example code in Jupyter notebooks -
Hints for how to use this (kind of) optimization module in practice
Installation of the (almost) latest release
Type
python -m pip install cma
in a system shell to install the latest release from the Python Package Index (PyPI) (which may be behind the lastest release tag on Github). The release link also provides more installation hints and a quick start guide.
conda install --channel cma-es cma
installs from the conda cloud channel cma-es.
The quick way (requires git to be installed):
pip install git+https://github.com/CMA-ES/pycma.git@master
The long version: download and unzip the code (see green button above) or
git clone https://github.com/CMA-ES/pycma.git and
-
either, copy (or move) the
cmasource code folder into a folder visible to Python, namely a folder which is in the Python path (e.g. the current folder). Then,import cmaworks without any further installation. -
or, install the
cmapackage by typing within the folder, where thecmasource code folder is visible,pip install -e cmaMoving the
cmafolder away from its location would invalidate this installation.
It may be necessary to replace pip with python -m pip and/or prefixing
either of these with sudo.
-
Release
3.3.0implements- diagonal acceleration via diagonal decoding (option
CMA_diagonal_decoding, by default still off). fmin_lq_surr2for running the surrogate assisted lq-CMA-ES.optimization_tools.ShowInFolderto facilitate rapid experimentation.verb_disp_overwriteoption starts to overwrite the last line of the display output instead of continuing adding lines to avoid screen flooding with longish runs (off by default).- various smallish improvements, bug fixes and additional features and functions.
- diagonal acceleration via diagonal decoding (option
-
Release
3.2.2fixes some smallish interface and logging bugs inConstrainedFitnessALand a bug when printing a warning. Polishing mainly in the plotting functions. Added a notebook for how to use constraints. -
Release
3.2.1fixes plot of principal axes which were shown squared by mistake in version 3.2.0. -
Release
3.2.0provides a new interface for constrained optimizationConstrainedFitnessALandfmin_con2and many other minor fixes and improvements. -
Release
3.1.0fixes the return value offmin_con, improves its usability and provides abest_feasibleattribute inCMAEvolutionStrategy, in addition to various other more minor code fixes and improvements. -
Release
3.0.3provides parallelization withOOOptimizer.optimize(..., n_jobs=...)(fix for3.0.1/2) and improvedpicklesupport. -
Release
3.0.0provides non-linear constraints handling, improved plotting and termination options and better resilience to injecting bad solutions, and further various fixes. -
Version
2.7.1allows for a list of termination callbacks and a light copy ofCMAEvolutionStrategyinstances. -
Release
2.7.0logger now writes into a folder, new fitness model module, various fixes. -
Release
2.6.1allow possibly much larger condition numbers, fix corner case with growing more-to-write list. -
Release
2.6.0allows initial solutionx0to be a callable. -
Version
2.4.2added the functioncma.fmin2which, similar tocma.purecma.fmin, returns(x_best:numpy.ndarray, es:cma.CMAEvolutionStrategy)instead of a 10-tuple likecma.fmin. The result 10-tuple is accessible ines.result:namedtuple. -
Version
2.4.1includedbbobtestbed. -
Version
2.2.0added VkD CMA-ES to the master branch. -
Version
2.*is a multi-file split-up of the original module. -
Version
1.x.*is a one file implementation and not available in the history of this repository. The latest1.*version1.1.7can be found here.