Integrate and Fire Model: A simple neuronal model
Studying the brain involves understanding the intricate activity of billions of interconnected neuronsꜛ, the fundamental units of the brain. One useful tool in this endeavor is the Integrate-and-Fire model, a simplified representation of neuronal behavior. This model approximates the changes in a neuron’s membrane potentialꜛ in response to an input current. If the membrane potential reaches a threshold, the neuron ‘fires’ a signal, also known as an action potentialꜛ, to other neurons and then resets. While a simplification, the model captures essential dynamics of neuronal firing and provides a computationally efficient approach to simulate and explore the behavior of large neuronal networks, aiding our understanding of brain function. In this blog post, we explore the model and run some simulations in Python to see how it works.
Model derivation
The Integrate-and-Fire model is primarily based on the properties of an electrical circuit that represents a neuron. The neuron is depicted as a capacitor, which can accumulate and store charge. The basic electrical circuit representing a leaky integrate-and-fire model consists of a capacitor, representing the membrane’s capacity to store charge, and a resistor, representing the membrane’s resistance to current flow. This model captures the essential features of a neuron’s response to incoming signals. When the neuron receives an input current, the membrane voltage changes. The Integrate-and-Fire model describes how the neuron integrates these incoming signals over time and fires an action potential once the membrane voltage exceeds a certain threshold.
In order to derive an equation that links the momentary voltage to the input current, we consider the described electrical circuit, use the law of current conservation and split the driving current into two components. The first component is the resistive current, which is proportional to the voltage difference across the resistor. We can denote this as:
\[I_R = {U_R \over R} = { {U(t) - U_\text{rest} } \over R}\]where $I$ is the current, $U_R = U(t) - U_\text{rest}$ is the voltage along the resistance, and $R$ is the resistance. $U_\text{rest}$ is the resting potential of the neuron, which is the membrane potential when the neuron is not receiving any input.
The second component is the capacitive current, which is proportional to the rate of change of voltage across the capacitor:
\[I_C=C{dU(t) \over dt}\]where $C$ is the capacitance and $dU/dt$ is the change of voltage with respect to time $t$.
The total current is the sum of the resistive and capacitive currents:
\[I(t) = I_C+I_R = { {U(t) - U_\text{rest} } \over R} + C{dU(t) \over dt}\] \[\Leftrightarrow \; C{dU(t) \over dt} = - { {U(t) - U_\text{rest} } \over R} + I(t)\]Multiplying by $R$ and introducing the time constant $\tau := RC$, we get:
\[\Leftrightarrow \; RC{dU(t) \over dt} = - (U(t) - U_\text{rest}) + RI(t)\] \[\Leftrightarrow \; \tau {dU(t) \over dt} = - (U(t) - U_\text{rest}) + RI(t)\]This is the standard equation of the leaky Integrate-and-Fire model (LIF), which describes the change of the membrane potential $U(t)$ over time. The term “leaky” refers to the fact that the model integrates its input currents over time, but the voltage tends to “leak” back towards zero, which reflects the loss of charge across the membrane due to resistive currents.
By resubstituting of $U_R(t) = U(t) - U_\text{rest}$ we get
\[\tau {dU_R(t) \over dt} = - U_R(t) + RI(t)\]which is another form of the equation commonly used in the literature, where $U_R$ is sometimes also denoted as $V$.
The equation is a first-order linear differential equation, and we can derive an analytical solution using an exponential function. Assuming that at time $t=0$, the voltage across the membrane is $U_0$, and there’s no input current, i.e., $I(t) = 0$, the solution of the differential equation is given by:
\[U_R(t) = U(t) - U_\text{rest} = U_0 e^{-\frac{t-t_0}{\tau} }\]for $t \geq t_0$. This equation shows that in the absence of an input, the membrane potential decays exponentially towards the resting potential $U_\text{rest}$ with a time constant $\tau$. The time constant $\tau$ is a measure of the membrane’s resistance to current flow. The larger the time constant, the slower the membrane potential decays towards the resting potential.
In the presence of a time-dependent input current $I(t)\neq 0$, the neuron’s voltage changes in response to this input. In this case, the solution of the Integrate-and-Fire model is given by:
\[U(t) = U_\text{rest} + \frac{R}{\tau} \int_0^\infty I(t') e^{-\frac{t-t'}{\tau}} dt'\]The above equation describes the membrane potential $U(t)$ at time $t$ as a function of the time-dependent input current $I(t)$. $I(t)$ is often simulated as a step function, i.e., $I(t) = I_0$ for $t \geq t_0$ or a sinusoidal function, i.e., $I(t) = I_0 \sin(\omega t)$, where $I_0$ is the amplitude of the input current and $\omega$ is the frequency of the input current.
The term $e^{-(t-t’)/\tau_m}$ serves as a ‘memory kernel’, giving more weight to recent inputs (as time $t’$ approaches $t$) and less weight to older inputs (as $t’$ is far from $t$).
When a firing threshold $U_{th}$ is added to the model, the voltage resets after reaching this threshold, which is incorporated into the equation by introducing a new term:
\[U(t) = U_\text{rest} + \frac{R}{\tau} \int_0^\infty (I(t') - I_\text{reset}) e^{-\frac{t-t'}{\tau}} dt'\]Here, $I_{reset}$ represents the resetting current that fires whenever the membrane potential reaches the threshold $U_{th}$. This equation is often expressed using a Dirac delta function:
\[U(t) = U_\text{rest} + \frac{R}{\tau} \int_0^\infty (I(t')\; -\] \[\; \sum_n \delta(t' - t^{(n)}) \; e^{-\frac{t-t'}{\tau}} dt'\]The sum $\sum_n$ runs over all firing times $t^{(n)}$ before time $t$. The reset current $I_{reset}$ is defined as:
\[I_\text{reset} = \frac{1}{R} (U_{th} - U_\text{rest} - RI(t^{(n)}))\]In simple terms, the reset current $I_\text{reset}$ is the amount of current needed to bring the neuron’s potential down from the threshold $U_{th}$ back to the resting potential $U_\text{rest}$ immediately after a firing event at time $t^{(n)}$
Simulating with Python
To better understand the dynamics of the Integrate-and-Fire model, I’ve written some simple Python code to simulate the Integrate-and-Fire model incorporating the equations above. I used a basic Euler method for numerical integration, which might not be accurate for large time steps or fast dynamics. For a more accurate simulation, you might want to use a more sophisticated method like Runge-Kutta or use a library like Brian2ꜛ that is specifically designed for simulating spiking neural networks.
The code is implemented in an interactive Jupyter notebook and you can change the parameters of the model using sliders. You can run the notebook in Google Colab or Binder by clicking on one of the buttons below:
Or download the notebook from this GitHub repositoryꜛ and run it locally.
The code models a single Integrate-and-Fire neuron for different input currents $I(t)$. First, the membrane potential $U(t)$ and corresponding spike times are calculated using the equation for a constant input current $I(t) = I_0$:
Second, the membrane potential $U(t)$ and corresponding spike times are calculated using the equation for a time-variable input current $I(t)$:
Third, the membrane potential $U(t)$ and corresponding spike times are calculated for two constant input currents $I_{0,1}$ and $I_{0,2}$:
As we can see from the simulations, the input current is not the only factor that determines the neuron’s membrane potential and dynamics. The capacity $C$ and resistance $R$ of the neuron’s membrane also play an important role. The membrane capacity $C$ determines how much charge is needed to change the membrane potential by a certain amount. The membrane resistance $R$ determines how fast the membrane potential changes in response to an input current.
Furthermore, the membrane potential also “leaks” over time due to the resistance of the neuron’s membrane. This leak causes the membrane potential to decay towards its resting state whenever the input current is low or absent. So, even if a large current input is applied to the neuron, if it is not sustained over a sufficient period of time, the neuron may not fire an action potential because the input current may decay before reaching the firing threshold. Conversely, a sustained, lower-intensity current that is applied over a longer period of time may be able to trigger an action potential. Therefore, both the intensity and the timing of the incoming current are crucial for the neuron to reach the firing threshold and generate an action potential in the Integrate-and-Fire model. To demonstrates this, the provided Jupyter notebook also provides a comparison of the following four scenarios:
- A high intensity current input that decays quickly.
- A sustained, lower-intensity current.
- A high intensity current input with long duration.
- A lower-intensity current input with short duration.
We see, how quickly the membrane potential decays in the first scenario, even though the input current is much higher than in the second scenario. Using a higher membrane time constant in the third scenario, the membrane potential does not decay over the simulated time period. In scenario two and four, the current intensity was not high enough to reach the firing threshold. However, in scenario two, the current was sustained over a longer period of time.
Please feel free to use the code for your own projects. If you find a bug or have a suggestion for improvement, please open an issue, send me an email or leave a comment in the comment section below.
Spiking Neural Networks
Integrate-and-Fire neurons are used in artificial neuronal networks to simulate the behavior of biological neurons. These Spiking Neural Networks (SNNs) attempt to model the dynamics of biological systems more closely than traditional Artificial Neural Networks (ANNs), which use different, simpler models for their neurons. Here are some reasons why Integrate-and-Fire neurons are useful in SNNs:
- Integrate-and-fire neurons capture the temporal dynamics of real neurons. In a SNN, the timing of the spikes can carry information, which is a feature not present in traditional ANNs.
- Spiking neurons only need to transmit information when they spike, as opposed to continuously. This makes them potentially more efficient, both computationally and energetically, than traditional ANNs, where every neuron produces an output for every input.
- Because Integrate-and-Fire neurons are a simple model of real neurons, networks that use them can potentially capture more biological phenomena than traditional ANNs. This can be useful in computational neuroscience, where the goal is to understand how real brains compute. However, it is important to note that SNNs are still a simplification of real neural networks, and they do not capture all the complexity of biological systems. And in particular, the Integrate-and-Fire model is a simplification of the biological processes happening in a real neuron. There are more accurate models like the Hodgkin-Huxley model or the FitzHugh-Nagumo model that capture more of the biological details of real neurons – under the cost of increased computational complexity and thus computation time.
- There are learning rules like spike-timing-dependent plasticity (STDP) that are naturally defined on the spikes that Integrate-and-Fire neurons produce. These learning rules can be used to train SNNs to perform tasks, and they are often more biologically plausible than the learning rules used in traditional ANNs.
However, there are also challenges associated with using Integrate-and-Fire neurons in artificial networks. For instance, training SNNs can be more difficult than training traditional ANNs due to the non-differentiable nature of the spiking nonlinearity. There are several approaches to training SNNs, such as converting them to rate-based networks during training and then converting them back to spiking networks for inference. Another challenge is the computational cost of simulating SNNs, which can be higher than that of traditional ANNs due to the need to simulate the spiking dynamics of the neurons. Nevertheless, there are also hardware implementations of SNNs that can take advantage of the sparsity and asynchrony of spiking neurons to achieve high computational efficiency.
Conclusion
The Integrate-and-Fire model is a simple yet powerful tool for simulating the behavior of neurons. It captures the essential dynamics of neuronal firing and provides a computationally efficient approach to simulate and explore the behavior of large neuronal networks. The model is widely used in computational neuroscience and artificial neural networks to study the dynamics of neurons and networks of neurons. By adjusting the parameters of the model, one can explore how different factors influence the firing behavior of neurons and how networks of neurons process information. Thus, the Integrate-and-Fire model is a valuable tool for understanding the brain and developing biologically inspired artificial intelligence systems.
The name “Integrate-and-Fire” reflects the model’s signal processing mechanism. The neuron integrates incoming signals, summing up the incoming current over time. When this sum, corresponding to the membrane potential, crosses a specific threshold, the neuron fires, generating an action potential and resetting its membrane potential.
The beauty of the Integrate-and-Fire model is in its simplicity. Despite being a simplification of the biological processes occurring in real neurons, it captures the essential characteristics of neuronal dynamics: the integration of inputs and the generation of action potentials. This model is a cornerstone of computational neuroscience, forming the basis for more complex neuron models and large-scale simulations of neural networks.
It is important to note that the leaky Integrate-and-Fire model discussed here is just one of many variants. Other variants include the quadratic Integrate-and-Fire model, the exponential Integrate-and-Fire model, the adaptive Integrate-and-Fire model, and many more. Each variant has its own complexity, advantages, and disadvantages, and the choice of model depends on the specific research question. And while the Integrate-and-Fire model is a useful tool for studying neuronal dynamics, it is important to remember that it is a simplification of complex neural processes. For a more detailed and biologically accurate model, one might consider using the Hodgkin-Huxley model or other more complex neuron models.
References
The theoretical background of this tutorial is based on the book “Neuronal Dynamics – From single neurons to networks and models of cognition” by Wulfram Gerstner, Werner M. Kistler, Richard Naud and Liam Paninski (Cambridge University Press, 2014), where you can delve deeper into the topic. The book is freely available online at neuronaldynamics.epfl.chꜛ.
comments