import numpy as np class LIF_Neuron: ''' 一个带漏电流的积分放电模型的类,该类中包含了 a. 模型的偏微分方程描述, b. 单步的数值积分。 ''' def init(self, C,g_leak, E_leak, E_thresh): self.C=C self.g_leak = g_leak self.E_leak =E_leak self.E_thresh = E_thresh def derivative(self, state, inputs=0): v = state # TODO 偏微分方程 Dv = (inputs-self.g_leak * (v - self.E_leak)) / self.C return np.array([Dv]) def step(self, state, dt, inputs=0): state_new = rk4(dt, state, inputs, self.derivative) # TODO 超过阈值后的重置: if state_new[0] >= self.E_thresh: state_new[0] = self.E_leak return state_new 对于上述类 注入逐渐增强的电流,观察脉冲发放频率的变化,将结果绘图。
时间: 2024-02-18 17:00:34 浏览: 75
好的,请给我一些时间来编写代码。
```python
import matplotlib.pyplot as plt
from scipy.integrate import odeint
def current(t):
# 定义注入电流的函数
if t < 0.1:
return 0
else:
return 0.5*(t-0.1)
# 确定模型参数
C = 1
g_leak = 0.1
E_leak = -65
E_thresh = -50
# 创建 LIF_Neuron 类实例
neuron = LIF_Neuron(C, g_leak, E_leak, E_thresh)
# 设置初始状态和时间步长
state0 = np.array([-65])
dt = 0.001
# 定义时间段并进行数值积分
t = np.arange(0, 2, dt)
state = state0
spike_count = 0
spike_times = []
for i in range(len(t)):
inputs = current(t[i])
state = neuron.step(state, dt, inputs)
if state[0] > E_thresh:
spike_count += 1
spike_times.append(t[i])
state[0] = E_leak
# 计算脉冲发放频率
firing_rate = spike_count / (t[-1] - t[0])
# 绘制脉冲发放频率随时间的变化图像
plt.plot(spike_times[:-1], np.diff(spike_times))
plt.xlabel('Time (s)')
plt.ylabel('Inter-spike Interval (s)')
plt.show()
```
运行上述代码,可以得到脉冲发放频率随时间的变化图像。
阅读全文