A contracting model of the basal ganglia (Girard et al. 2008)

 Download zip file 
Help downloading and running models
Basal ganglia model : selection processes between channels, dynamics controlled by contraction analysis, rate-coding model of neurons based on locally projected dynamical systems (lPDS).
1 . Gurney K, Prescott TJ, Redgrave P (2001) A computational model of action selection in the basal ganglia. II. Analysis and simulation of behaviour. Biol Cybern 84:411-23 [PubMed]
2 . Prescott TJ, Montes González FM, Gurney K, Humphries MD, Redgrave P (2006) A robot model of the basal ganglia: behavior and intrinsic processing. Neural Netw 19:31-61 [PubMed]
3 . Girard B, Tabareau N, Pham QC, Berthoz A, Slotine JJ (2008) Where neuroscience and dynamic system theory meet autonomous robotics: a contracting basal ganglia model for action selection. Neural Netw 21:628-41 [PubMed]
Citations  Citation Browser
Model Information (Click on a link to find other models with that property)
Model Type: Realistic Network;
Brain Region(s)/Organism: Thalamus; Basal ganglia;
Cell Type(s): Neostriatum medium spiny direct pathway GABA cell; Thalamus geniculate nucleus/lateral principal GLU cell; Thalamus reticular nucleus GABA cell; Subthalamus nucleus projection neuron; Globus pallidus neuron; Neostriatum fast spiking interneuron;
Gap Junctions:
Receptor(s): D1; D2;
Transmitter(s): Dopamine;
Simulation Environment: Python;
Model Concept(s): Action Selection/Decision Making;
Implementer(s): Girard, Benoit [girard at isir.upmc.fr];
Search NeuronDB for information about:  Neostriatum medium spiny direct pathway GABA cell; Thalamus geniculate nucleus/lateral principal GLU cell; Thalamus reticular nucleus GABA cell; D1; D2; Dopamine;
First contact:

running "python CBGTC.py" should simulate the contracting basal
ganglia model (CBG) in three tests: 

* The first one replicates the test used in (Gurney et al 2001b) to
  generate their fig. 2a, also used in (Girard et al 2008) to generate
  fig 3. The terminal output should provide information about the
  performance of the program in each of the five steps. To generate
  new versions of the aforementioned figures, log files have to be

* The second one successively provides the model with 200 random input
  vectors, and computes 5 different scores: 

    - the first one reflects how frequently the maximum input is the
      disinhibited one after convergence,

    - the second one computes the selection contrast between the
      channel with maximum input and its strongest competitor,

    - the third one computes the amplification in the frontal cortex
      of the channel with maximum input with regard to its raw input,

    - the fourth one compares the amplification of the winning channel
      with its strongest competitor's amplification (amplification

    - the last one is the average time needed to reach the convergence
      of selection process.

  This test writes on the terminal the average value of each of these

* The third one replicates (Prescott et al 2006) systematic salience
  search used to generate their figure 7, as well as (Girard et al
  2008) fig. 4. Only efficiency of channels 1 and 2 is computed with
  the provided code, using them to compute efficiency and distortion
  is straightforward (eqns. 7 and 8 in the Prescott et al paper).

The corresponding log files are stored in the log/ directory:

* BG and ThFC respectively contain the activity of the each neuron of
  the basal ganglia and thalamo-cortical modules at each time
  step. The GPi/SNr output used to generate (Girard et al 2008) fig. 3
  has to be read in columns 26, 27 and 28 of BG_CBG.

  With gnuplot, this should do the trick : 
  plot 'BG_GPR' using 26 with lines, '' u 27 w l, '' u 28 w l

* e1 and e2 contain the matrices of the efficiency scores of channel 1
  and 2 for the third test.

The program will try to use the psycho library to increase computation
speed, if not available, a 'Psyco not available.' message will be
displayed, but the program should compute without problem.

Some more details:

The basalganglia.py and thalamusFC.py respectively define the
basalganglia and thalamusFC classes. The basalganglia corresponds to
the intrinsic basal ganglia circuitry (Striatum, GPe, GPi, SNr), the
thalamusFC to the thalamo-cortical loop (Th, TRN and FC).

The CBGTC.py defines the CBGTC class, which contains one instance of
the basalganglia object and one instance of the thalamusFC, allowing
the simulation of a complete cortico-baso-thalamo-cortical loop.  It
contains the various test functions allowing the replication of some
of the papers figures.

The program contains the code to also run the GPR model (Gurney et al
2001a), just create a CBGTC object with the model set to 'GPR' (just
look at the main() code in CBGTC.py).

You can also use some custom CBG model, i.e. using lPDS neurons and
the CBG structure, but with your own parameters. Create a CBGTC object
with model set to 'CBGcustom', and with a vector containing the 25
parameters (once again, look at the main() in CBGTC.py).

These three classes (basalganglia, thalamusFC, CBGTC) have the same
generic architecture:

stateReset() sets all neurons to 0

paramInit(opt_param) defines the synaptic weights and the neuron
biases, opt_parameter being used for the CBGcustom type of model only.

stepCompute(dt,inputs) updates the model state, integrating over
timestep "dt" and salience input "salience", using the (very) basic
Euler method.

logAll() obviously logs the internal state of the model in the
dedicated log files in the log/ directory.

The programs are commented (at least a bit), do not hesitate to dig
into them to get more details about the other functions.