Python Other
Latest commit a33c1c1 Feb 21, 2017 @wvangeit wvangeit committed on GitHub Merge pull request #207 from BlueBrain/fix_division_zero
Fix division by zero in IBEA

Build Status Join the chat at Code Climate Documentation Status


The Blue Brain Python Optimisation Library (BluePyOpt) is an extensible framework for data-driven model parameter optimisation that wraps and standardises several existing open-source tools.

It simplifies the task of creating and sharing these optimisations, and the associated techniques and knowledge. This is achieved by abstracting the optimisation and evaluation tasks into various reusable and flexible discrete elements according to established best-practices.

Further, BluePyOpt provides methods for setting up both small- and large-scale optimisations on a variety of platforms, ranging from laptops to Linux clusters and cloud-based compute infrastructures.


When you use the BluePyOpt software or method for your research, we ask you to cite the following publication:

Van Geit W, Gevaert M, Chindemi G, Rössert C, Courcol J, Muller EB, Schürmann F, Segev I and Markram H (2016). BluePyOpt: Leveraging open source software and cloud infrastructure to optimise model parameters in neuroscience. Front. Neuroinform. 10:17. doi: 10.3389/fninf.2016.00017

 AUTHOR={Van Geit, Werner  and  Gevaert, Michael  and  Chindemi, Giuseppe  and  Rössert, Christian  and  Courcol, Jean-Denis  and  Muller, Eilif Benjamin  and  Schürmann, Felix  and  Segev, Idan  and  Markram, Henry},   
TITLE={BluePyOpt: Leveraging open source software and cloud infrastructure to optimise model parameters in neuroscience},
JOURNAL={Frontiers in Neuroinformatics},


We are providing support using a chat channel on Gitter.


  • 2017/01/04: BluePyOpt is now considered compatible with Python 3.6+.
  • 2016/11/10: BluePyOpt now supports NEURON point processes. This means we can fit parameters of Adex/GIF/Izhikevich models, and also synapse models.
  • 2016/06/14: Started a wiki:
  • 2016/06/07: The BluePyOpt paper was published in Frontiers in Neuroinformatics (for link, see above)
  • 2016/05/03: The API documentation was moved to ReadTheDocs
  • 2016/04/20: BluePyOpt now contains the code of the IBEA selector, no need to install a BBP-specific version of DEAP anymore
  • 2016/03/24: Released version 1.0



If you want to use the ephys module of BluePyOpt, you first need to install Neuron with Python support on your machine.

And then bluepyopt itself:

pip install bluepyopt

Cloud infrastructure

We provide instructions on how to set up an optimisation environment on cloud infrastructure or cluster computers here

Quick Start

Single compartmental model

An iPython notebook with an introductory optimisation of a one compartmental model with 2 HH channels can be found at

There is a Binder Virtual Machine available that allows you to run this notebook in your browser:

Landscape example Figure: The solution space of a single compartmental model with two parameters: the maximal conductance of Na and K ion channels. The color represents how well the model fits two objectives: when injected with two different currents, the model has to fire 1 and 4 action potential respectively during the stimuli. Dark blue is the best fitness. The blue circles represent solutions with a perfect score.

Neocortical Layer 5 Pyramidal Cell

Scripts for a more complex neocortical L5PC are in this directory

With a notebook:

And you can run this in a VM:

API documentation

The API documentation can be found on ReadTheDocs.


This work has been partially funded by the European Union Seventh Framework Program (FP7/2007­2013) under grant agreement no. 604102 (HBP)