The Leaky Integrate-and-Fire (LIF) Neuron Mode

基础知识

1.在产生动作电位之前,进入突触接触部位的电流必须沿树突向下扩散并穿过神经元胞体,并导致尖峰起始区的膜去极化超过阈值,导致兴奋性突触后电位的整合。换句话说动作电位建模有三个阶段分别是:突触;树突;神经元胞体

2.泄露电流:可以想象突触中的正电荷流入就像打开水一样,水会从漏水的花园软管(树突)中流下来。 水可以采取两种途径:沿着软管内部或通过泄漏。 同样,突触电流可以通过两条路径:沿着树突内部或穿过树突膜。 当电流沿着树突向下,离突触更远, 由于离子电流通过膜通道的泄漏,EPSP(兴奋性突触后电位)振幅将减小。

膜作为电路的生物物理学

想象一个离子电流在树突内流动,如基础知识中提到的一样,电流的流动存在两种途径:沿着树突内部或穿过树突膜;因此换一种说法就送当离子电流撞击树突的细胞膜时存在两种后果:造成膜电位的改变或泄露出膜
大多数电流将采取最小电阻的路径;因此,随着膜电阻的增加,更多的去极化电流将在树突内部流动而不是“泄漏”出膜。 随着内阻的增加,更多的电流会泄露出膜。
以下为膜电路的具体讲解:

树突膜的脂质双层在电路中表示为电容器,因为电荷可以积累在膜的两侧,这一性质也叫做膜的电容;由于树突内电流对于路径的选择会取决于膜电阻,因此在电路中用一个膜电导来表示(g=1/R);由于胞内外存在离子浓度的差异,因此代表脂质双层的电容器连接了一个电源,通过极板内外电荷的差异来模拟离子浓度的差异;由于动作电位的发生需要钠钾离子通道的开放,而这些离子通道的开放和关闭都是不定的,因此用一个耦合到电池的可变电导来指代这些离子通道。

膜电位的一阶微分方程

在LIF模型中忽略了那些不直接参与动作电位的离子通道(可能起到很重要的调控作用)

经过一系列简单的数学变换,最终将膜电位的一阶微分方程转变为上图形式

随后对动作电位的激发过程作出定义:达到阈值-激发动作电位-复位到平衡电位-绝对不应期
当膜电位达到或超过阈值,此时的膜电位会被重置为复位电位并在绝对不应期保持,随后再次开始下一个循环

下图为涉及的所有参数

整个过程的代码实现

def run_LIF(pars, Iinj, stop=False):"""Simulate the LIF dynamics with external input currentArgs:pars       : parameter dictionaryIinj       : input current [pA]. The injected current here can be a valueor an arraystop       : boolean. If True, use a current pulseReturns:rec_v      : membrane potentialrec_sp     : spike times"""# Set parametersV_th, V_reset = pars['V_th'], pars['V_reset']tau_m, g_L = pars['tau_m'], pars['g_L']V_init, E_L = pars['V_init'], pars['E_L']dt, range_t = pars['dt'], pars['range_t']Lt = range_t.sizetref = pars['tref']# Initialize voltage and currentv = np.zeros(Lt)v[0] = V_initIinj = Iinj * np.ones(Lt)if stop:  # set end of current to 0 if current pulseIinj[:int(len(Iinj) / 2) - 1000] = 0Iinj[int(len(Iinj) / 2) + 1000:] = 0tr = 0.  # the count for refractory duration# Simulate the LIF dynamicsrec_spikes = []  # record spike timesfor it in range(Lt - 1):if tr > 0:  # check for refractorinessv[it] = V_resettr = tr - 1elif v[it] >= V_th:  # reset voltage and record spike eventrec_spikes.append(it)v[it] = V_resettr = tref / dt# calculate the increment of the membrane potentialdv = (-(v[it] - E_L) + Iinj[it] / g_L) * (dt / tau_m)# update the membrane potentialv[it + 1] = v[it] + dvrec_spikes = np.array(rec_spikes) * dtreturn v, rec_spikespars = default_pars(T=500)
v, sp = run_LIF(pars, Iinj=100, stop=True)

引用

恒定电流

高斯白噪声(GWN)电流

在存在噪声的情况下,spike可以由噪声带来的波动所驱使,随机波动在一定可能下恰好足以触发响应,使得神经元放电,而这种波动驱使倾向于在膜电位没有达到阈值时出现,在达到阈值后便转为平均驱动

LIF模型不足

1.在之前提到过,LIF模型忽略了除钠钾通道外其他离子通道的开放对于动作电位产生的影响
2.当输入电流时,真实神经元有一个适应的过程,即从当输入一个恒定的电流I(从0到K整个过程),根据LIF模型,我们可以推断发放率应该是恒定的,这是因为reset的存在。但在真实神经元并非这样工作,需要经过一个过程才能输出稳定的发放率。快速脉冲神经元(fast-spiking),其本身就没有适应性所以可以很好的对应LIF模型;除了 fast-spiking 和regular-spiking还有 bursting and stuttering神经元,当有恒定输入时,会产生一系列脉冲会周期的(bursting)或不周期的(stuttering)因为长间隔而产生中断。如图B
上图,快速脉冲(fast-spiking)神经元(A)在不适应的情况下有短的间隔时间间隔,而常规的脉冲神经元(C)表现适应,可见在间隔期间增加。许多神经元在抑制电流I1<0被终止后发出抑制反弹尖峰(D)

链接: 引用.
而GIF模型从这两个方面对LIF模型进行了update
对于GIF以及LIF之后会补充

欢迎关注我们!奇趣多多,数模多多!

The Leaky Integrate-and-Fire (LIF) Neuron Mode-LIF神经元模型相关推荐

  1. 求给定精度的简单交错序列部分和_单个神经元的简单模型:Leaky integrate and fire (LIF) model...

    神经元的交流,传输与活动,都离不开一个个非常短暂的脉冲-Spike.有各种各样的模型,可以描述神经元的电位变化,发放,比如HH模型等等.但是如果只考虑比较粗糙的一些性质,比如膜电位的简单变化和spik ...

  2. 神经元模型hhmodel模型_单个神经元的简单模型:Leaky integrate and fire (LIF) model

    神经元的交流,传输与活动,都离不开一个个非常短暂的脉冲-Spike.有各种各样的模型,可以描述神经元的电位变化,发放,比如HH模型等等.但是如果只考虑比较粗糙的一些性质,比如膜电位的简单变化和spik ...

  3. snntorch:P2—【LIF神经元模型】手撕公式、代码实现与演示

    LIF神经元模型是现阶段脉冲神经网络的搭建与训练过程中使用最多的神经元模型,既保留了HH模型中关于生物神经元的核心思想,具有一定的仿生型,也兼顾了普通人工神经元计算效率高的特点,所以本文就LIF神经元 ...

  4. 深入解析:在Tensorflow框架中构建和实现SNN网络和LIF神经元模型

    尊敬的读者,你好!我非常荣幸有机会与你们分享这篇文章.在这篇文章中,我将探讨在Tensorflow框架中如何实现脉冲神经网络(Spiking Neural Network, SNN)和漏电积分火(Le ...

  5. 窥探当今AI芯片中的类脑模型

    来源:脑人言 撰文丨邓 磊(加州大学-圣塔芭芭拉分校UCSB 博士后) 责编丨高茂森 Soma 排版丨夏獭 科学研究的动机,并非仅仅是出于能看到多酷炫的应用,而是因为我们尚有诸多未知世界需要探寻,这是 ...

  6. 脉冲神经网络_【强基固本】脉冲神经网络(SNN)

    "强基固本,行稳致远",科学研究离不开理论基础,人工智能学科更是需要数学.物理.神经科学等基础学科提供有力支撑,为了紧扣时代脉搏,我们推出"强基固本"专栏,讲解 ...

  7. 脉冲神经网络的五脏六腑

    脉冲神经元模型 传统的人工神经元模型主要包含两个功能,一是对前一层神经元传递的信号计算加权和,二是采用一个非线性激活函数输出信号. 前者用于模仿生物神经元之间传递信息的方式,后者用来提高神经网络的非线 ...

  8. 窥探当今AI芯片中的类脑模型(转)

    来源:脑人言 撰文丨邓 磊(加州大学-圣塔芭芭拉分校UCSB 博士后) 责编丨高茂森 Soma 排版丨夏獭 科学研究的动机,并非仅仅是出于能看到多酷炫的应用,而是因为我们尚有诸多未知世界需要探寻,这是 ...

  9. 一种利用NeuCube和动态视觉传感器对运动目标进行精确识别的视觉脉冲神经网络系统(译)

    原文题目为: A Retinotopic Spiking Neural Network System for Accurate of Moving Objects Using NeuCube and ...

最新文章

  1. 【maven】配置多个仓库
  2. map、mapPartitions、mapPartitionsWithIndex区别在哪里?
  3. [转] Bookmarklet(书签工具)编写指南
  4. mySQL 数据库错误
  5. 媒体查询 200304
  6. Python+django网页设计入门(11):在线考试与自动评分
  7. Flex的TabNavigator中tab触发的事件
  8. .net mvc web api 返回 json 内容,过滤值为null的属性
  9. 千年虫← 2000, 2020→千年虫现身Splunk 平台,立即修复!
  10. 基于python的性能测试工具_基于 Python 的性能测试工具 locust 与 LR 的简单对比[转发]...
  11. C语言-十进制转换为二进制函数
  12. hdu 4128 Running relay (线性规划转半平面交)
  13. linux下codeblocks汉化
  14. LeGO-LOAM 系列(1): LeGO-LOAM 安装以及概述
  15. matlab箭头大小固定,科学网—Matlab 粗箭头绘制 - 肖鑫的博文
  16. 4个小方法,让你的抖音发出来的视频更清楚
  17. docker 搭建私有仓库registry (多用户)
  18. 2014阿里实习生面试题——mysql如何实现索引的
  19. 今日互联网关注(写在清明节后):每天都有值得关注的大变化
  20. java.sql.SQLException: Incorrect string value: ‘\xE5\x8D\x97\xE6\x98\x8C‘ for column ‘address‘ at ro

热门文章

  1. 打破安逸,追求卓越的6个不要 - This is Daloong‘s blog
  2. python32模拟鼠标和键盘操作
  3. 在洋葱(Onion)架构中实现领域驱动设计
  4. python大数_使用python的金融大数定律
  5. Spark 练习测试题(答案仅供参考)
  6. C++ 如何让程序暂停一会儿
  7. 一个简单的电子邮箱验证
  8. countdown软件测试死亡时间真假,countdown
  9. 主流视频会议租用产品对比
  10. 不想使用notepad++,快使用notepad--来替换