title: Introduction to Computational Neuroscience author: author:
- name: Stephen J Eglen affiliation: University of Cambridge email: [email protected] date: 2016-11-07 ...
- In case of fire/emergency: nearest fire-exit is on basement level, walking back the way we came.
- Break at 12:55-13:05; bathrooms outside; cafe in central core upstairs open til 16:00.
- Consider pairing up with someone else if you want to focus on the science rather than difficulties of learning matlab; there is no time today to give an introduction to matlab.
This is the third time I've tried this, so be patient! If nothing else, in two hours I hope you get to see what you can do with simple computer models.
Download these notes from http://www.damtp.cam.ac.uk/user/sje30/cnw-2016.zip and right-click to extract/unzip all the files.
Matlab is one of the most popular computational environments around. (But there are alternatives that I prefer ... R, julia, python.) We will use it today for expedience.
Given some differential equation for how x changes over time and so initial condition (i.e. x = some value at time t = 0), we can integrate them numerically using Euler integration.
Depending on the step-size h.
Solve differential equation
with initial conditions
Known solution:
We will open euler1.m in matlab and then run the script by typing "euler1" at the prompt (or you can hit the button titled "Run selection").
-
Use the zoom buttons on the graph to see how close the approximation is, especially for t<2.
-
Extend the maximal time from 5 to 20. Does it still work with h=0.2?
-
See what happens when you vary the step size in the solution (try values of h between 0.01 and 5.) with larger solutions.
-
Try solving another differential equation with x(0)=0:
Its all in the channels!
http://tinyurl.com/matthews-channel
See assignment 3
Matlab has built-in functions for numerical integration of ODEs, e.g. ode23, ode45, ode23s. We will use them here so that we focus on the problem and not the numerics.
Run with default I=0.1 and then compare with I=10.
-
Can you find the critical value of I where you first get a spike generated?
-
Can you work out the units on I (check equation 1 and Table 1 of spa3)?
-
Estimate the firing rate (in Hz) for the model as you vary I from 0 to 500. Can you plot a graph of it? e.g. see hh_plotrate.m for a template.
-
(Advanced) Apply a pulse of negative current with I=-50 for 5 ms followed by I=0 and describe what happens.
-
Try other manipulations, e.g. what if you set dh/dt to zero? What would this simulate?
Let's simplify the models as far as we can; we are going to use the simplification due to Izhikevich.
Read the basic description and guess which is the real data.
-
izh.m has the basic code for one of the models. Try to adapt using parameters a,b,c,d to generate each of the plots from above. e.g. how can you make a chattering cell (CH)?
-
Explore figure1.m. This regenerates figure 1 of the 2004 paper. See if you can follow in the code how the model is adapted in each case.
Eqn 6.18 from Wilson (1999). Couple two neurons that inhibit each other.
We will first run the script WTA2.m with input to neuron 1 = 60 and input to neuron 2 = 70. We will examine the phase plane.
-
When the input to both cells is equal, what is the critical value when one neurons dominates? Start with input to both cells equal to 20.
-
Examine what happens when input to both neurons is 100. Run it several times and see which one wins. Can you explain (and then test) your result?
Wilson (Chapter 12) shows how pairs of neurons coupled with reciprocal inhibition can generate out-of-phase firing (not WTA).
Try IPSPinteractions.m with
-
Edit the script IPSPinteractions.m so that TauSyn is set to 2 ms (rather than 1 ms) and repeat with above parameters. What do you observe?
-
As above, but with
$I_1 = 1.05$ ; now what happens? -
(Advanced) investigate the Clione.m script. These are two coupled neurons that are mutually inhibitory, but with each neuron modelled by 4 ODEs (eq 12.18, p191). Importantly here there is only external input to one neuron between 2ms and 3ms. After starting the script, set current strength to 0.5 and inhibitory conductance to 9.
Wilson (Chapter 14) shows how to model recurrent circuity found in
areas such as CA3 of hippocampus. 256 neurons are reciprocally
coupled with adjustable weights. Several patterns have been stored
transiently, and then weights
For this exercise, you will need to be in Chapter14
folder. Simply cd Chapter14
in the matlab prompt.
-
Run
CA3memory.m
and test all four patterns. -
Try adding your own pattern, either similar to the others, or distinct, using
CA3learning.m
. When you start, you get to add 32 pixels to a grid (current pixel number is listed at the top of the figure -- it is a basic, but useful, image editor!)
-
If you wish to learn more, we have some comp neuro lectures next term.
-
Questions?
Much of this material came from some of the following sources. Note that Wilson's book is freely available as pdf.
Dayan P, Abbott LF (2001) Theoretical Neuroscience: Computational and Mathematical Modeling of Neural Systems. MIT Press.
Izhikevich EM (2004) Which model to use for cortical spiking neurons? IEEE Trans Neural Netw 15:1063–1070.
Trappenberg T (2010) Fundamentals of Computational Neuroscience. 2nd edition. OUP. https://web.cs.dal.ca/~tt/fcns/
Wilson HR (1999) Spikes decisions and actions. OUP. http://cvr.yorku.ca/webpages/wilson.htm#book (including PDF of the book).