脉冲神经网络 神经元模型-HH模型(1)

脉冲神经网络 神经元模型-HH模型

  • Hodgkin Huxley 神经元模型及实现
    • 一 原理
      • 1. 电路图
      • 2. 常微分方程
    • 二 代码实现-python版本
      • 1. 模拟离子通道
      • 2. 模拟膜电位
    • 三 代码实现-matlab版本
    • 四 参考

Hodgkin Huxley 神经元模型及实现

最近在接触脉冲神经网络相关知识,如有错误,请多多指教!

一 原理

1. 电路图

在这里插入图片描述
Hodgkin-Huxley(HH)模型可以看作是rc电路模型的扩展,该模型除了泄漏通道外还包含钠(Na)和钾(K)通道。离子通道被建模为与电池串联的电阻器。电池表示特定离子的平衡电势,电阻器反映通道对特定离子的渗透性。与泄漏通道的固定电阻相比,Na和K通道的电阻有自己的动态特性,这取决于跨膜的电压。
更精确地说,对于给定的膜电位,每个通道都有相应的开启和关闭速率。这些通道的打开还是关闭是由霍奇金根据经验建立的函数和函数来描述的。这些和函数可以用在微分方程中来描述开放通道的比例如何随时间变化:
d n d t = α n ( V ) ( 1 − n ) − β n ( V ) n ( 公 式 一 ) \frac{dn}{dt} = \alpha_n(V)(1-n) - \beta_n(V)n (公式一) dtdn=αn(V)(1n)βn(V)n
alpha_n和 beta_n描述打开通道的比例如何随时间变化
τ n = 1 α n + β n ( 公 式 二 ) \tau_n = \frac{1}{\alpha_n + \beta_n} (公式二) τn=αn+βn1()
表示多久通道才会打开
n ∞ = α n α n + β n ( 公 式 三 ) n_{\infty} = \frac{\alpha_n}{\alpha_n + \beta_n}(公式三) n=αn+βnαn()
表示通道打开的概率

2. 常微分方程

在这里插入图片描述
由于HH模型需要使用4个常微分方程进行表示模型,故计算较为复杂,很难进行大规模仿真。但其精确地描绘出膜电压的生物特性,能够很好地与生物神经元的电生理实验结果相吻合

二 代码实现-python版本

import numpy as np
import matplotlib.pyplot as plt
%matplotlib inline

1. 模拟离子通道

# 离子通道被建模为与电池串联的电阻器。电池表示特定离子的平衡电势,电阻器反映通道对特定离子的渗透性
V = np.arange(-80.0,80,0.01) # [mV]#n用来限制k离子的通透性,m和h用来限制na离子,因为na离子含有失活门,即使通道本身是打开的,如果失活门阻塞通道,离子电流也不能流动。
alpha_n = 0.01 *(10-V)/(np.exp((10-V)/10)-1)
alpha_m = 0.1*(25-V)/((np.exp((25-V)/10))-1)
alpha_h = 0.07 * np.exp(-(V/20))beta_m = 4* (np.exp(-V/18))
beta_h = 1/(np.exp((30-V)/10)+1)
beta_n = 0.125 * np.exp(-(V/80))#公式二、公式三实现
tau_n = 1/(alpha_n + beta_n)
inf_n = alpha_n*tau_ntau_m = 1/(alpha_m + beta_m)
inf_m = alpha_m*tau_m tau_h = 1/(alpha_h + beta_h)
inf_h = alpha_h*tau_h#绘图
plt.clf()
plt.subplot(1,2,1)
plt.plot(V,inf_n)
plt.plot(V,inf_m)
plt.plot(V,inf_h)
plt.title('Steady state values') 
plt.xlabel('Voltage (mV)')
plt.subplot(1,2,2)
plt.plot(V,tau_n)
plt.plot(V,tau_m)
plt.plot(V,tau_h)
plt.title('Time constants') 
plt.xlabel('Voltage (mV)')
plt.legend(['n','m','h'])

运行结果如下图:由图可知,K离子选通变量 n n n表明在平衡电位,大多数K趋于关闭。随着膜电位的增加,通道开始打开,但有一定的延迟。对于钠通道,当膜电位增加时,m值也增加,时间常数表明变化几乎是瞬时的(值很小)。然而, h h h趋于下降,这说明,在相对高的电压下,许多钠通道会打开,但大多数通道是失活的,因此几乎不会有离子电流。
在这里插入图片描述

2. 模拟膜电位

− C m d V d t = g L ( V − E L ) + g K n 4 ( V − E K ) + g N a m 3 h ( V − E N a ) − I e x t e r n ( 公 式 四 ) -C_m\frac{dV}{dt} = g_L(V-E_L) + g_Kn^4(V-E_K) + g_{Na}m^3h(V-E_Na) - I_{extern} (公式四) CmdtdV=gL(VEL)+gKn4(VEK)+gNam3h(VENa)Iextern

# 参数定义 可参考
# 平衡电位
E_Na = 115.0   # [mV]
E_K  = -12.0   # [mV]
E_L  = 10.6    # [mV]# 最大电导
g_Na = 120.0   # [mS]
g_K  = 36.0    # [mS]
g_L  = 0.3     # [mS]dt = 0.01      # [ms]
T = 40         # [ms]
t = np.arange(0,T,dt)V = np.zeros(len(t))
n = np.zeros(len(t))
m = np.zeros(len(t))
h = np.zeros(len(t))I_E = 0.0
V[0] = 0.0
h[0] = 0.59
m[0] = 0.05
n[0] = 0.31# 在10ms是注入10mA的电流,然后15ms再次置电流为0
for i in range(1,len(t)):if i == 1000:I_E = 10.0if i == 1500:I_E = 0.0# Calculate the alpha and beta functions (代码同上)alpha_n = (0.1 - 0.01*V[i-1]) / ( np.exp(1   - 0.1*V[i-1]) - 1)alpha_m = (2.5 - 0.1 *V[i-1]) / ( np.exp(2.5 - 0.1*V[i-1]) - 1)alpha_h = 0.07*np.exp(-V[i-1]/20.0)beta_n = 0.125*np.exp(-V[i-1]/80.0)beta_m = 4.0 * np.exp(-V[i-1]/18.0)beta_h = 1 / ( np.exp(3 - 0.1*V[i-1]) + 1)# Calculate the time constants and steady state valuestau_n = 1.0/(alpha_n + beta_n)inf_n = alpha_n*tau_ntau_m = 1.0/(alpha_m + beta_m)inf_m = alpha_m*tau_mtau_h = 1.0/(alpha_h + beta_h)inf_h = alpha_h*tau_h# 更新n,m,h  n[i]  = (1-dt/tau_n)*n[i-1] + (dt/tau_n)*inf_nm[i]  = (1-dt/tau_m)*m[i-1] + (dt/tau_m)*inf_mh[i]  = (1-dt/tau_h)*h[i-1] + (dt/tau_h)*inf_h# 公式四# 更新膜电位方程I_Na = g_Na*(m[i]**3)*h[i]  * (V[i-1]-E_Na)I_K  = g_K *(n[i]**4)       * (V[i-1]-E_K)I_L  = g_L                  * (V[i-1]-E_L)#dv = -(I_Na + I_K + I_L - I_E)dv = I_E - (I_Na + I_K + I_L)V[i]  = V[i-1] + dv*dtplt.clf()
plt.subplot(1,3,1)
plt.plot(t,V)
# 膜电位变化
plt.title('Membrane potential')
plt.subplot(1,3,2)
plt.plot(t,n)
plt.plot(t,m)
plt.plot(t,h)
plt.title('Gating variables')
plt.legend(['n','m','h'])
plt.subplot(1,3,3)
plt.plot(t,g_Na*h * m**3)
plt.plot(t,g_K*n**4)
plt.title('Ionic currents')
plt.legend(['Na','K'])

运行结果如下图:
在这里插入图片描述

三 代码实现-matlab版本

%% Basic Hodgkin-Huxley Implementation
% Equations from Hodgkin, Huxley, J. Physiol (1952) 117, 500-544clear;
figure(1);clf;dt = 0.001;
t = 0:dt:40;
% Nernst Potentials
Ena = 115; Ek = -12; El = 10.6;% Maximum Conductances
gna = 120; gk = 36; gl = 0.3;% Membrane Capacitance
C = 1;% 离子通道打开
an = @(u) (0.1-0.01*u)/(exp(1-0.1*u)-1);
am = @(u) (2.5-0.1*u)/(exp(2.5-0.1*u)-1);
ah = @(u) 0.07*exp(-u/20);% 离子通道关闭
bn = @(u) 0.125*exp(-u/80);
bm = @(u) 4*exp(-u/18);
bh = @(u) 1/(exp(3-0.1*u)+1);% DEFINE FORMULAE FOR STEADY STATE GATE ACTIVATIONSm_inf = @(u) am(u) / ( am(u) + bm(u) );
n_inf = @(u) an(u) / ( an(u) + bn(u) );
h_inf = @(u) ah(u) / ( ah(u) + bh(u) );% INITIALIZE STATE VARIABLESm = 0*t + m_inf(0);
n = 0*t + n_inf(0);
h = 0*t + h_inf(0);
v = 0*t;% DEFINE STIMULUS STRENGTH, DURATION, & DELAYtSTIM_START = 10;
tSTIM_DUR = 1;
STIM_STRENGTH = 10;% DEFINE MISCinRange = @(x,a,b) (x>=a) & (x<b);% MAIN LOOPfor i = 1:length(t)-1% extract membrane voltageu = v(i);% solve for membrane currentsIk  = gk  * n(i)^4      * (u - Ek);Ina = gna * m(i)^3*h(i) * (u - Ena);Il  = gl  *               (u - El);   Imem = Ik + Ina + Il;% determine stimulus current, if anyIstim = 0;if inRange( t(i) , tSTIM_START , tSTIM_START+tSTIM_DUR)Istim = STIM_STRENGTH;end% define the state variable derivativesdv = (Istim - Imem)/C;dm = am(u) * (1-m(i)) - bm(u) * m(i);dh = ah(u) * (1-h(i)) - bh(u) * h(i);dn = an(u) * (1-n(i)) - bn(u) * n(i);% use forward euler to increment the state variablesv(i+1) = v(i) + dv*dt;m(i+1) = m(i) + dm*dt;h(i+1) = h(i) + dh*dt;n(i+1) = n(i) + dn*dt;end% plot the results
plot(t,v);
axis([t(1) t(end) -20 120]);
xlabel('time (ms)');
ylabel('membrane voltage (mV)');

运行结果
在这里插入图片描述

四 参考

  1. Hodgkin Huxley
  2. matlab参考代码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/48077.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

(DEAP)基于图卷积神经网络的脑电情绪识别(附代码)

1. 数据集介绍以及特征部分见上篇文章&#xff1a; DEAP数据集介绍以及特征提取部分 深度学习基于DEAP的脑电情绪识别情感分类(附代码)_qq_3196288251的博客-CSDN博客 2. 图卷积神经网络哟结合LSTM 本文主要介绍利用图卷积神经网络结合LSTM进行脑电情绪识别。 由于脑电通道…

神经元是多输入单输出吗,单输入单输出神经网络

1、人工神经网络的知识表示形式 人工神经网络的知识表示形式&#xff1a; 1、每个神经元都是一个多输入单输出的信息处理单元 &#xff1b; 2、神经元输入分兴奋性输入和抑制性输入两种类型 &#xff1b; 3、神经元具有空间整合特性和阈值特性 &#xff1b; 4、神经元输入与输…

神经元内信号传递的计算模型-HH模型

神经元内信号传递的计算模型-HH模型 神经元动力学可以被设想为一个总和过程(有时也称为“集成”过程)&#xff0c;并结合一种触发动作电位高于临界电压的机制。 在这里主要介绍Hodgkin Huxley模型模拟离子通道&#xff0c;膜电势的改变。 原理 基础知识 细胞膜两侧离子浓度…

Pytorch+PyG实现GAT(图注意力网络)

文章目录 前言一、导入相关库二、加载Cora数据集三、定义GAT网络四、定义模型五、模型训练六、模型验证七、结果 前言 大家好&#xff0c;我是阿光。 本专栏整理了《图神经网络代码实战》&#xff0c;内包含了不同图神经网络的相关代码实现&#xff08;PyG以及自实现&#xf…

脑电信号特征提取方法与应用

前言 脑电图(EEG)信号在理解与脑功能和脑相关疾病的电活动方面发挥着重要作用。典型的脑电信号分析流程如下&#xff1a;(1)数据采集&#xff1b;(2)数据预处理&#xff1b;(3)特征提取&#xff1b;(4)特征选择&#xff1b;(5)模型训练与分类&#xff1b;(6)性能评估。当信号分…

基础2-用卷积神经网络进行颅内和头皮脑电图数据分析的广义癫痫预测

A Generalised Seizure Prediction with Convolutional Neural Networks for Intracranial and Scalp Electroencephalogram Data Analysis 为了改善耐药癫痫和强直性癫痫患者的生活&#xff0c;癫痫预测作为最具挑战性的预测数据分析工作之一已引起越来越多的关注。许多杰出的…

异质图神经网络(持续更新ing...)

诸神缄默不语-个人CSDN博文目录 本文将对异质图神经网络&#xff08;HGNN, heterogeneous graph neural networks&#xff09;的方法演变进行梳理和介绍。 最近更新时间&#xff1a;2023.5.10 最早更新时间&#xff1a;2022.10.31 文章目录 1. 异质图2. 处理为同质图3. 知识图…

Python画棵圣诞树 ~ Merry Christmas ~

圣诞节快到了&#xff0c;用python、turtle画棵圣诞树吧~_Ding2langdang的博客-CSDN博客 转载于Ding2langdang 最近圣诞节快到啦&#xff0c;CSDN的热搜也变成了”代码画颗圣诞树“&#xff0c;看了几篇博客&#xff0c;发现原博主把一些圣诞树给融合在了一起。 我更喜欢树叶…

圣诞树网页和圣诞树应用程序

圣诞树网页和圣诞树应用程序 1、圣诞树网页 效果图 代码 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN" "http://www.w3.org/TR/html4/frameset.dtd"> <html> <head> <title>写给xxx的的圣诞树</title> …

【圣诞节限定】教你用Python画圣诞树,做个浪漫的程序员

最近在各大社交平台看到好多圣诞树,看到大佬们画的圣诞树一个比一个精致,我也特别想尝试画一棵特别的圣诞树。下面是我画的一棵简易的圣诞树,虽然和网络上大佬们的圣诞树相比不是很精致,但是对于萌新们来说,画这样一棵简易的圣诞树还是非常轻松的。 ps:重要的不是圣诞树,…

浪漫的turtle,送给程序员自己的圣诞树

前几天一直在整 Pyqt5 相关的知识&#xff0c;在 Python UI 的世界里 Pyqt5 只是其中的一种用来做应用程序比较 nice。要在一个画布上面呈现我们需要的东西还是得依赖 turtle 比较靠谱&#xff0c;什么组件就做什么事、没有谁比谁厉害&#xff0c;只是在合适的地方用合适的组件…

用代码画两棵圣诞树送给你【附详细代码】

大家好&#xff0c;我是宁一 代码的魔力之处在于&#xff0c;可以帮我们实现许多奇奇怪怪、有趣的想法。 比如&#xff0c;用Python的Turtle库&#xff0c;可以帮我们在电脑上画出好看的图像。 下面这张樱花图就是用Turtle库实现的。 这不圣诞节快到啦。 那么就用代码来画一…

最近比较火的圣诞树HTML代码

<!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><title>张洋</title><link rel"stylesheet" href"https://cdnjs.cloudflare.com/ajax/libs/normalize/5.0.0/normalize.min.css"…

【圣诞树代码】

新建一个HTML文件&#xff0c;直接复制粘贴就行。 <!DOCTYPE html> <html lang"en" ><head><meta charset"UTF-8"><title></title><link rel"stylesheet" href"https://cdnjs.cloudflare.com/aja…

【圣诞节】简单代码实现圣诞树|圣诞贺卡 | 快来为心爱的她送上专属的圣诞礼物叭~

圣诞节马上就要到了&#xff0c;不知道给自己喜欢的人准备什么样的惊喜吗&#xff1f;作为一名程序员&#xff0c;当然是用编程制作专属于她or他的圣诞树&#xff01; 目录 &#x1f384;圣诞树 ✨3D圣诞树 代码块 打开方式 修改位置 效果展示 ✨音乐律动圣诞树 代码块…

圣诞节来了,怎能还没有圣诞树呢 快来为心爱的她送上专属的圣诞礼物叭~

&#x1f4e2;&#x1f4e2;&#x1f4e2;&#x1f4e3;&#x1f4e3;&#x1f4e3; &#x1f33b;&#x1f33b;&#x1f33b;Hello&#xff0c;大家好我叫是Dream呀&#xff0c;一个有趣的Python博主&#xff0c;小白一枚&#xff0c;多多关照&#x1f61c;&#x1f61c;&…

用Python画圣诞树 ‘‘遇见’’ 圣诞老人

这是雪程序的1.1版本。 上个版本的文章---看这里&#xff1a; 忙活半天只为了看雪--送给大家的冬至礼物https://blog.csdn.net/qq_54554848/article/details/121873955?spm1001.2014.3001.5501&#xff08;下述代码基于上个版本&#xff09; 上次我发布了--冬至礼物的博客&…

圣诞节快到了,程序员应该给女友送一个线上圣诞树

我们把下载的压缩包解压&#xff0c;把exe文件放到桌面&#xff0c;双击打开即可。 桌面效果图&#xff1a; 可以打开多个圣诞树&#xff0c;如果关闭圣诞树需要鼠标右键点击exit即可。 代码如下&#xff1a; <!DOCTYPE HEML PUBLIC> <html> <head> <me…

快要圣诞节啦,快去给小伙伴们分享漂亮的圣诞树吧

最近翻到一篇知乎&#xff0c;上面有不少用Python&#xff08;大多是turtle库&#xff09;绘制的树图&#xff0c;感觉很漂亮&#xff0c;我整理了一下&#xff0c;挑了一些我觉得不错的代码分享给大家&#xff08;这些我都测试过&#xff0c;确实可以生成喔~&#xff09; 重中…

python画圣诞树【方块圣诞树、线条圣诞树、豪华圣诞树】

文章目录 前言【便捷源码下载处】1.方块圣诞树2.线条圣诞树3.豪华圣诞树 这篇文章主要介绍了使用Python画了一棵圣诞树的实例代码,本文通过实例代码给大家介绍的非常详细&#xff0c;对大家的学习或工作具有一定的参考借鉴价值&#xff0c;需要的朋友可以参考下 前言【便捷源码…