Skip to main content
  • Poster presentation
  • Open access
  • Published:

Brian 2 - the second coming: spiking neural network simulation in Python with code generation

Brian 2 is a fundamental rewrite of the Brian [1, 2] simulator for spiking neural networks. Brian is written in the Python programming language and focuses on simplicity and extensibility: neuronal models can be described using mathematical formulae (differential equations) and with the use of physical units. Depending on the model equations, several integration methods are available, ranging from exact integration for linear differential equations to numerical integration for arbitrarily complex equations. The same formalism can also be used to specify synaptic models, allowing the user to easily define complex synapse models.

Brian 2 keeps most of the syntax and functionality consistent with previous versions of Brian, but achieves more consistency and modularity as well as adding new features such as a simpler and more general new formulation of refractoriness. A consistent interface centered around human-readable descriptions using mathematical notation allows the specification of neuronal models (including complex reset, threshold and refractory conditions), synaptic models (including complex plasticity rules) and synaptic connections. Every aspect of Brian 2 has been designed with extensibility and adaptability in mind, which, for example, makes it straightforward to implement new numerical integration methods.

Even though Brian 2 benefits from the ease of use and the flexibility of the Python programming language, its performance is not limited by the speed of Python: At the core of the simulation machinery Brian 2 makes use of fully automated runtime code generation [3], allowing the same model to be run in the Python interpreter, in compiled C++ code or on a GPU using CUDA libraries[4]. The code generation system is designed to be extensible to new target languages and its output can also be used on its own: for situations where high performance is necessary and/or where a Python interpreter is not available (for example for robotics applications), Brian 2 offers tools to assist in assembling the generated code into a stand-alone version that runs independently of Brian or a Python interpreter.

To ensure the correctness and maintainability of the software, Brian 2 includes an extensive, full coverage test suite. Debugging of simulation scripts is supported by a configurable logging system, allowing simple monitoring of the internal details of the simulation process.

Brian is made available under a free software license and all development takes place in public code repositories [5].

References

  1. Goodman DFM, Brette R: The Brian Simulator. Frontiers in Neuroscience. 2009, 3: 192-197. 10.3389/neuro.01.026.2009.

    Article  PubMed Central  PubMed  Google Scholar 

  2. The Brian spiking neural network simulator. [http://briansimulator.org]

  3. Goodman DFM: Code Generation: A Strategy for Neural Network Simulators. Neuroinformatics. 2010, 8 (3): 183-196. 10.1007/s12021-010-9082-x.

    Article  PubMed  Google Scholar 

  4. CUDA programming guide. [http://docs.nvidia.com/cuda/index.html]

  5. Brian 2 code repository. [https://github.com/brian-team/brian2]

Download references

Acknowledgements

This work was partly supported by the European Research Council (ERC StG 240132).

Author information

Authors and Affiliations

Authors

Rights and permissions

This article is published under license to BioMed Central Ltd. This is an Open Access article distributed under the terms of the Creative Commons Attribution License (http://creativecommons.org/licenses/by/2.0), which permits unrestricted use, distribution, and reproduction in any medium, provided the original work is properly cited.

Reprints and permissions

About this article

Cite this article

Stimberg, M., Goodman, D.F., Benichoux, V. et al. Brian 2 - the second coming: spiking neural network simulation in Python with code generation. BMC Neurosci 14 (Suppl 1), P38 (2013). https://0-doi-org.brum.beds.ac.uk/10.1186/1471-2202-14-S1-P38

Download citation

  • Published:

  • DOI: https://0-doi-org.brum.beds.ac.uk/10.1186/1471-2202-14-S1-P38

Keywords