Skip to content

A full-scale cortical microcircuit spiking network model (Shimoura et al 2018)

Notifications You must be signed in to change notification settings

ModelDBRepository/244261

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1 Commit
 
 
 
 
 
 

Repository files navigation

Introduction

This is a reference implementation of the following model:

T.C. Potjans and M. Diesmann. “The Cell-Type Specific Cortical Microcircuit: Relating Structure and Activity in a Full-Scale Spiking Network Model”. In: Cerebral Cortex 24.3 (2014), pp. 785–806.

Platform information

Platform: Ubuntu

gcc (GCC): 5.4.0

Python: 2.7.5

Brian: 2.0.1

Matplotlib: 2.0.0

NumPy: 1.11.1

Pandas: 0.19.2

SciPy: 0.19.0

Joblib: 0.11

Multiprocessing: 0.70a1

Weave 0.15.0

Cython 0.23.4

The network model is implemented using the simulator for spiking neural networks Brian 2, which is written in Python. For data processing and visualization we use Matplotlib, NumPy, Pandas and Scipy. To run multiple simulations in parallel we use Joblib and Multiprocessing.

Packages installation

To assure that all data and figures will be generated as presented in the article, we recommend to follow the instructions below and use the modules in the same versions described here. Although the code also works in newer versions, for Pandas v.0.2.0 (or newer) some colors are not displayed as presented in the article (e.g. figure 2 barplots might be displayed only in blue).

Python installation

The network simulation is implemented with Python (v.2.7.5). Although, there is no restriction for more recent versions (Tested in Python v.3.6.3).

To install Python 2, type in console:

$sudo apt-get update 
$sudo apt-get install python2.7

Installing pip

We use pip, a package management system, to install the Python modules described above. To install pip in Ubuntu type in a terminal:

sudo apt-get install python-pip

Upgrade pip to the latest version:

pip install --upgrade pip

Installation of packages using pip can be done with the following command:

pip install --user PYTHON_PACKAGE_NAME

Python modules installation using pip (recommended)

To install the required packages type in terminal:

pip install --user brian2
pip install --user matplotlib==2.0.0
pip install --user numpy==1.11.1
pip install --user pandas==0.19.2
pip install --user scipy==0.19.0
pip install --user joblib==0.11
pip install --user weave==0.15.0
pip install --user cython==0.23.4

or

pip install --user brian2 matplotlib==2.0.0 numpy==1.11.1 pandas==0.19.2 scipy==0.19.0 joblib==0.11

All software packages are also available in the anaconda distribution, and in brian-team channel (see below).

Alternative installation (using Anaconda)

Alternatively, you can install the scientific Python modules with the Anaconda data science platform.

For 32 bits system use the download link: https://repo.continuum.io/archive/Anaconda2-5.0.1-Linux-x86.sh For 64 bits system use the download link: https://repo.continuum.io/archive/Anaconda2-5.0.0-Linux-ppc64le.sh

To install open a terminal in the folder containing the downloaded file and type:

bash Anaconda2-5.0.1-Linux-x86.sh

for 32 bits.

or

bash Anaconda2-5.0.0-Linux-ppc64le.sh

for 64 bits.

Python modules installation using Anaconda

Brian 2 and Joblib are not included in Anaconda by default.

To install brian-team channel, necessary to install Brian 2, open a terminal and type:

conda install -c brian-team brian2

For further information access the website: http://brian2.readthedocs.io/en/stable/introduction/install.html

For Joblib install:

conda install joblib=0.11

The other useful packages can be installed with:

conda install PYTHON_PACKAGE_NAME

Code repository

This folder contains seven Python codes:

  • netRun.py: Main script to run the simulations. Here is defined the protocols to run the experiments.
  • netPD.py: Assemble parameters of the network model.
  • netParams.py: Networks structure parameters.
  • netModels.py: Function responsible to make connections between different populations of neurons and to connect stimulation (background or DC currents).
  • neuronModels.py: Neuron model equations and parameters.
  • figures.py: Functions to build figures 2, 5 and 6 from the article.
  • ks_test.py: Script to build figures 3 and 4 from the article.

Running the scripts

The main script used to simulate the network and generate figures [], can be run typing the following command in a terminal:

python netRun.py ARG1 ARG2

where ARG1 and ARG2 are command line arguments, passed to the script to specify the experimental protocol and the simulation time in seconds, respectively. The experimental protocols are specified below:

protocol = 0: Spontaneous activity (figure 2) protocol = 1: DC input and layer-independent experiments (figures 5A and 5B) protocol = 2: Layer-independent randomized to generate histograms in figure 5C protocol = 3: Dependence of network activity on the background firing rate and the relative inhibitory synaptic strength (figure 6) protocol = 4: comparison of spontaneous activity using equations 3 or 4 from paper to calculate the number of synapses between populations protocol = 5: response to transient thalamic input (figure 7)

After running the simulations, every data generated will be saved in the data folder (../data/) and the figures will be saved in the figures folder (./figures/).

WARNING: It is required around 13GB of RAM for each network to be simulated.

Running the scripts takes approx. 4 minutes to simulate 1 second of network activity.

To run protocol 0 for 60 seconds type in the console:

python netRun.py 0 60.0

Obs: there is the possibility to run the code in parallel using openmp implemented by Brian 2. To do so uncomment lines 32-33. Nevertheless, all simulations were done without it.

To run protocol 1 for 60 seconds type in the console:

python netRun.py 1 60.0

To run protocol 2 for 5 seconds type in the console:

python netRun.py 2 5.0

To run protocol 3 for 10 seconds type in the console:

python netRun.py 3 10.0

Observe that protocols 2 and 3 vary over several parameters and this way cost some time. Instead of running the simulation in serial which is default, one can run the range of parameters in parallel by simply attributing False to the variable serial (line 83 in netRun.py). The number of cores can be set in the variable num_cores (line 84 in netRun.py). Obs: in this case the memory cost is multiplied by num_cores.

To run protocol 4 for 60 seconds type in the console:

python netRun.py 4 60.0

Obs: to compare data from NEST it is necessary to run the original code available at http: //www.opensourcebrain.org/projects/potjansdiesmann2014.

To run protocol 5 for 100 seconds type in the console:

python netRun.py 5 100.0

About

A full-scale cortical microcircuit spiking network model (Shimoura et al 2018)

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages