Update README.md

Signed-off-by: David Rotermund <54365609+davrot@users.noreply.github.com>
This commit is contained in:
David Rotermund 2024-02-16 16:23:58 +01:00 committed by GitHub
parent bcc6cbe13f
commit 54ea4f43fd
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -7,17 +7,33 @@ Simulating neurons is an ideal project for training systematic programming. Clas
## Mandatory tasks ## Mandatory tasks
1. Goal of this project is to compare different neuron models. Think about how you would organize those models in a hierarchy of Python classes. Which attributes and methods would you like to define for those classes? The neurons you have to cover are the leaky integrate-and-fire neuron (LIAF), quadratic integrate-and-fire neuron (QIAF), the conductance-based Connor-Stevens neuron, exponential integrate-and-fire neuron (EIAF), and a rate-based MT neuron (DivInE model). **We will ask some of you to present your thoughts on this task before you are going to implement the class hierarchy.** ### 1.
2. Implement and test your neuron models by driving them with a constant input current $I$. Plot their membrane potentials or outputs over time. For integrating the DEQs, you can use the standard Euler scheme with appropriately chosen step width $\Delta t$. Goal of this project is to compare different neuron models. Think about how you would organize those models in a hierarchy of Python classes. Which attributes and methods would you like to define for those classes? The neurons you have to cover are the leaky integrate-and-fire neuron (LIAF), quadratic integrate-and-fire neuron (QIAF), the conductance-based Connor-Stevens neuron, exponential integrate-and-fire neuron (EIAF), and a rate-based MT neuron (DivInE model).
3. Compute the neurons's gain functions $g$ as the average firing rate $r=g(I)$ numerically (for the MT neuron: in a suitable interval from $[0, T]$). For the LIAF neuron, compute the gain function also with sympy and plot it in comparison to the numerical curve.
4. Replace the Euler scheme for the Connor-Stevens neuron by the Python solver implementing the adaptive Runge-Kutta 4th/5th order scheme. Compare it with the Euler scheme. How small do you have to choose $\Delta t$ to obtain approximately the same precision as with Runge-Kutta? **We will ask some of you to present your thoughts on this task before you are going to implement the class hierarchy.**
5. Determine whether the neuron models are of **type-I** or **type-II** (see the ['Neuronal Dynamics' textbook](https://neuronaldynamics.epfl.ch), if you do not know what this means) by assessing the slope of the gain curve you obtained numerically.
### 2.
Implement and test your neuron models by driving them with a constant input current $I$. Plot their membrane potentials or outputs over time. For integrating the DEQs, you can use the standard Euler scheme with appropriately chosen step width $\Delta t$.
### 3.
Compute the neurons's gain functions $g$ as the average firing rate $r=g(I)$ numerically (for the MT neuron: in a suitable interval from $[0, T]$). For the LIAF neuron, compute the gain function also with sympy and plot it in comparison to the numerical curve.
### 4.
Replace the Euler scheme for the Connor-Stevens neuron by the Python solver implementing the adaptive Runge-Kutta 4th/5th order scheme. Compare it with the Euler scheme. How small do you have to choose $\Delta t$ to obtain approximately the same precision as with Runge-Kutta?
### 5.
Determine whether the neuron models are of **type-I** or **type-II** (see the ['Neuronal Dynamics' textbook](https://neuronaldynamics.epfl.ch), if you do not know what this means) by assessing the slope of the gain curve you obtained numerically.
## Voluntary tasks: Neurons... ## Voluntary tasks: Neurons...
1. For fluffing up your class hierarchy, you can add the original Hodgkin-Huxley model, and/or you can add adaptation to the Connor-Stevens model and the Exponential integrate-and-fire neuron. ### 1.
2. Compute the gain functions with sympy also for the QIAF neuron and the MT neuron, and plot them in comparison to the numerical curves. Note that you have to use commensurable time constants for the MT neuron to be able to solve the differential equations analytically. For fluffing up your class hierarchy, you can add the original Hodgkin-Huxley model, and/or you can add adaptation to the Connor-Stevens model and the Exponential integrate-and-fire neuron.
3. Extend your class(es) such that you can drive your neurons with a time-varying current $I(t)$.
### 2.
Compute the gain functions with sympy also for the QIAF neuron and the MT neuron, and plot them in comparison to the numerical curves. Note that you have to use commensurable time constants for the MT neuron to be able to solve the differential equations analytically.
### 3.
Extend your class(es) such that you can drive your neurons with a time-varying current $I(t)$.
## Voluntary tasks: ...and cables ## Voluntary tasks: ...and cables
@ -27,13 +43,30 @@ with parameters $a>0$, $b<0$, and external current $I_{ext}(t, x)$.
In this task, you can implement numerical schemes for solving the cable equation, and use a model neuron to provide input. In this task, you can implement numerical schemes for solving the cable equation, and use a model neuron to provide input.
1. Approximate the temporal and spatial derivatives by finite differences with respect to a discretization $\Delta t$ and $\Delta x$ in time and space. Write down the forward Euler scheme for solving the partial differential equation using these expressions. ### 1.
2. Implement a numerical integration routine for the passive cable in Python. Take care at the boundaries! We will use sealed ends, i.e. require that the current flowing through the ends of your cable is zero. Approximate the temporal and spatial derivatives by finite differences with respect to a discretization $\Delta t$ and $\Delta x$ in time and space. Write down the forward Euler scheme for solving the partial differential equation using these expressions.
3. Test your cable with $a=1$ and $b=-1$: Give it a length $L=1$, and discretise it into $100$ segments.
4. Give an external current pulse at $t=0$ and $x_0=0.1$, and observe how the voltage profile changes over time for an interval of $T=0.1$ (you could show this in an animated graph). Theory tells us that numerical stability requires $\Delta t < 0.5 \Delta x^2$. ### 2.
5. Plot the time courses of the membrane potential at different distances $x$ from $x_0$ into the same graph. If you would be a brain-'designer', where would you place a synapse that should have a large impact on the postsynaptic cell? Implement a numerical integration routine for the passive cable in Python. Take care at the boundaries! We will use sealed ends, i.e. require that the current flowing through the ends of your cable is zero.
6. Create the same plot, but now provide input pulses with a frequency of 10 per time unit, for $T=1$, and set $b=-100$.
7. Numerical stability: Observe what happens if the condition on $\Delta t$ stated above does not hold. To circumvent those problems, you can use much larger time steps if you implement the **Crank-Nicholson** algorithm for integrating the cable equation (have a look at Wikipedia for [Crank-Nicolson](https://en.wikipedia.org/wiki/Crank%E2%80%93Nicolson_method) and the [Thomas-algorithm](https://en.wikipedia.org/wiki/Tridiagonal_matrix_algorithm); they can be implemented with a few more lines of code). ### 3.
8. Experiment with your cable: connect one end to your Connor-Stevens neuron, drive the neuron with a constant supra-threshold input current, and observe how the generated spikes propagate over the dendrite. You can also couple a 'receiving' neuron to the end of the cable. Test your cable with $a=1$ and $b=-1$: Give it a length $L=1$, and discretise it into $100$ segments.
9. How about wrapping your cable into a class? Can you find a Python module which provides an alternative integration scheme for this PDE such as **py-pde**?
### 4.
Give an external current pulse at $t=0$ and $x_0=0.1$, and observe how the voltage profile changes over time for an interval of $T=0.1$ (you could show this in an animated graph). Theory tells us that numerical stability requires $\Delta t < 0.5 \Delta x^2$.
### 5.
Plot the time courses of the membrane potential at different distances $x$ from $x_0$ into the same graph. If you would be a brain-'designer', where would you place a synapse that should have a large impact on the postsynaptic cell?
### 6.
Create the same plot, but now provide input pulses with a frequency of 10 per time unit, for $T=1$, and set $b=-100$.
### 7.
Numerical stability: Observe what happens if the condition on $\Delta t$ stated above does not hold. To circumvent those problems, you can use much larger time steps if you implement the **Crank-Nicholson** algorithm for integrating the cable equation (have a look at Wikipedia for [Crank-Nicolson](https://en.wikipedia.org/wiki/Crank%E2%80%93Nicolson_method) and the [Thomas-algorithm](https://en.wikipedia.org/wiki/Tridiagonal_matrix_algorithm); they can be implemented with a few more lines of code).
### 8.
Experiment with your cable: connect one end to your Connor-Stevens neuron, drive the neuron with a constant supra-threshold input current, and observe how the generated spikes propagate over the dendrite. You can also couple a 'receiving' neuron to the end of the cable.
### 9.
How about wrapping your cable into a class? Can you find a Python module which provides an alternative integration scheme for this PDE such as **py-pde**?