TSP问题—Hopfield神经网络算法

Posted 数学推理与编程之美

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了TSP问题—Hopfield神经网络算法相关的知识,希望对你有一定的参考价值。

本章涉及知识点

1、生物神经元的结构

2、Hopfield神经网络结构

3、神经动力学

4、CHNN的网络结构

5、一般性CHNN模型的状态方程推导

6、一般性CHNN模型的能量方程定义

7、CHNN模型下TSP的置换矩阵设计

8、CHNN模型下TSP的能量方程定义

9、CHNN模型下TSP的能量方程和状态方程的优化

10、CHNN模型下TSP输入状态和输出状态的更新方法

11、Hopfield求解TSP问题的步骤

12、python编程实现Hopfield

13、结果分析

一、生物神经元的结构



人类的大脑,有着大约860亿个神经元,而神经元,是构成神经网络系统结构和功能的基本单位,其主要构成成分包括树突、胞体、轴突和细胞膜

神经元的主要功能是接受外界或不同神经元的信号刺激,产生兴奋或者抑制的神经冲动,并通过突触传递到下一个神经元进行信息交互

我们需要知道以下几个生物神经元的名词概念

(1)树突:从胞体发出的一个至多个突起,呈放射状,用来接受外界的刺激

(2)轴突:每个神经元有且只有一个轴突,用来向外界输出神经冲动

(3)突触:将一个神经元的神经冲动,传递到另一个神经元的相互接触的结构

从上述的概念可以看出:一个生物神经元可以接受多组输入,产生单组输出,且输入输出呈非线性关系

我们通过对神经元和神经网络进行数学建模,用计算机来尽量模拟生物神经网络的学习和思考过程,这样的网络叫做人工神经网络(ANN),ANN按照信息流可以分为前馈式和后馈式

这章研究的Hopfield神经网络就属于反馈式神经网络

二、Hopfield神经网络结构

Hopfield神经网络有如下特点

(1)每个神经元既是输入也是输出,构成单层全连接递归网络

(2)网络的突触权值不同于其他的神经网络是通过有监督或无监督反复学习来获得,而是在搭建网络时就按照一定的规则计算出来,且网络的权值在整个网络迭代过程中不再改变

(3)网络的状态是随时间的变化而变化的,每个神经元在t时刻的输出状态和自己t-1时刻有关

(4)引入能量函数的概念,用来判断网络迭代的稳定性,即网络的收敛,就是指能量函数达到极小值

(5)网络的解,即是网络运行到稳定时,各个神经元的状态集合

TSP问题—Hopfield神经网络算法


Hopfield神经网络也是递归神经网络(RNN)的前身,Hopfield模型分为:

离散型(DHNN):适用于处理联想记忆问题

连续性(CHNN):适用于处理组合优化问题

三、神经动力学

神经动力学的定义:将神经网络看做是一种非线性动力学系统,系统的状态集合随时间的变化而变化

令系统的输出状态变量集合为

TSP问题—Hopfield神经网络算法


其中t是连续时间变量,则系统的输出状态和输出状态的增量可以用下面的微分方程表示

TSP问题—Hopfield神经网络算法


其中F函数是S型非线性函数映射,一般F取对称sigmoid双曲正切函数来完成输出状态的非线性映射

TSP问题—Hopfield神经网络算法


四、CHNN的网络结构

TSP问题是组合优化,使用Hopfield神经网络的CHNN模型,将网络抽象为

(1)Hopfield神经网络等效为放大电子电路

(2)Hopfield每一个神经元等效为一个电子放大器元件

(3)Hopfield每一个神经元的输入和输出,等效为电子元件的输入电压和输出电压

(4)每一个电子元件(神经元)输出的电信号有正负值,正值代表兴奋,负值代表抑制

(5)每一个电子元件(神经元)的输入信息,包含恒定的外部电流输入,和其它电子元件的反馈连接

根据以上等效抽象,CHNN的电路拓扑图结构为

TSP问题—Hopfield神经网络算法


其中,Ui表示放大电子元件的输入电压,Vi表示输出电压,运算放大器i表示第i个神经元

五、一般性CHNN模型的状态方程推导

设电容C两端的电压为Uc,存储的电荷量为Q,则

TSP问题—Hopfield神经网络算法


则经过电容C的电流为

TSP问题—Hopfield神经网络算法


根据基尔霍夫电流定律,CHNN等效电路的电流关系为

TSP问题—Hopfield神经网络算法


令Tij表示神经元之间连接的权值

TSP问题—Hopfield神经网络算法


则电流关系化简为

TSP问题—Hopfield神经网络算法


上式就是关于CHNN模型中输入电压ui和ui增量的微分方程关系,也就是CHNN模型的状态方程,其中输入电压vi满足非线性映射规则f

TSP问题—Hopfield神经网络算法


六、一般性CHNN模型的能量方程定义

在神经网络的优化过程中,目标函数是用来判断当前网络是否达到稳定,即网络的优化,就是目标函数逼近达到最小值的过程,一般的优化算法有:梯度下降法、牛顿法、启发式优化等

但是在Hopfield网络中,由于网络的权重全程保持不变,神经元当前时刻状态和上一个时刻相关,为此我们采用能量函数来衡量Hopfield网络的稳定性

由于CHNN的能量函数定义为

TSP问题—Hopfield神经网络算法


能量函数E是单调下降,故Hopfield网络是稳定的

至此,有了Hopfield网络的CHNN模型的状态方程和能量函数,我们就可以来尝试抽象和转化TSP问题

七、CHNN模型下TSP的置换矩阵设计

我们的案例里有8个城市,通过构造NN模型,将每一个城市对应于神经网络的每一个神经元,即案例的TSP问题可以用8x8=64个神经元组成的Hopfield网络来求解

为了满足TSP的规则,我们设计置换矩阵的形式如下

TSP问题—Hopfield神经网络算法


置换矩阵负责翻译并遵从TSP的规则:

(1)一个城市只能被访问一次,翻译为:矩阵每行有且只有一个1,其余元素均为0

(2)一次只能访问一个城市,翻译为:矩阵每列有且只有一个1,其余元素均为0

(3)共访问过n个城市,翻译为:矩阵的全部元素中1的数量为n

在神经网络迭代优化过程中,每次神经元输出的状态集合只要满足上述置换矩阵的规则,则证明该组输出状态就是一个TSP问题的解,我们只要在这些解中找到最小代价的解即可

八、CHNN模型下TSP的能量方程定义

对于TSP问题,我们在一般性CHNN能量函数的基础上,需要考虑以下两点问题来设计出TSP的能量函数

(1)TSP的能量函数需要量化的翻译置换矩阵的规则

(2)在TSP问题中的n!个合法路线中,能量函数要有利于量化表示最短路线的解

为此,我们设计TSP能量函数的第一项为

TSP问题—Hopfield神经网络算法


上式翻译为:每一行中的每一个城市x,必须有且只有一个1,符合置换矩阵的第一条规则

设计TSP能量函数的第二项为

TSP问题—Hopfield神经网络算法


上式翻译为:每一列中的每一个城市x,必须有且只有一个1,符合置换矩阵的第二条规则

设计TSP能量函数的第三项为

TSP问题—Hopfield神经网络算法


上式翻译为:整个矩阵有n个1,符合置换矩阵的第三条规则

设计TSP能量函数的第四项为

TSP问题—Hopfield神经网络算法


上式包含神经网络输出中有效解的路径长度信息,dxy表示城市x到城市y的距离

为此,TSP的能量函数E整合为

TSP问题—Hopfield神经网络算法


其中参数ABCD称为权值,前三项是满足TSP置换矩阵的约束条件,最后一项包含优化目标函数项

九、CHNN模型下TSP的能量方程和状态方程的优化

由于上式定义的能量函数过于复杂,数学家们对能量函数进行了优化,将TSP问题的能量函数改进为

TSP问题—Hopfield神经网络算法


优化后的能量函数减少了权值参数的个数,且根据能量函数E,将CHNN的动态方程优化为

TSP问题—Hopfield神经网络算法


在实际编程中,我们用这两个函数优化迭代和判定当前Hopfield神经网络的输出状态

十、CHNN模型下TSP输入状态和输出状态的更新方法

我们根据优化后CHNN的动态方程,可以写出Hopfield递归神经网络的输入状态的更新表达式为

TSP问题—Hopfield神经网络算法


上式中可以看到Hopfield递归神经网络当前时刻的输入与其上一个时刻关联

由非线性映射,我们写出Hopfield递归神经网络的输出状态的更新表达式为

TSP问题—Hopfield神经网络算法


其中输出状态的非线性映射是双曲正切函数

十一、Hopfield求解TSP问题的步骤

至此,我们总结出利用Hopfield神经网络来求解TSP问题的步骤

(1)初始化Hopfield神经网络的初值(如输入电压U0、迭代次数)和权值(A、D)

(2)计算n个城市之间的距离矩阵Dxy

(3)初始化神经网络的输入状态

TSP问题—Hopfield神经网络算法


其中加入的随机项为

TSP问题—Hopfield神经网络算法


(4)利用CHNN动态方程计算输入状态的增量

TSP问题—Hopfield神经网络算法


(5)由一阶欧拉方法更新神经网络下一个时刻的输入状态

TSP问题—Hopfield神经网络算法


(6)由sigmoid函数更新神经网络下个时刻的输出状态

TSP问题—Hopfield神经网络算法


7)计算当前的能量函数E

TSP问题—Hopfield神经网络算法


(8)检查当前神经网络的输出状态集合,是否满足TSP置换矩阵的规则

十二、python编程实现Hopfield

我们用python编程实现出Hopfield神经网络的优化步骤

动态方程计算微分方程du

TSP问题—Hopfield神经网络算法


更新神经网络的输入电压U

TSP问题—Hopfield神经网络算法


更新神经网络的输出电压V

TSP问题—Hopfield神经网络算法


计算当前网络的能量

TSP问题—Hopfield神经网络算法


检查路径的正确性

TSP问题—Hopfield神经网络算法


迭代优化Hopfield神经网络

TSP问题—Hopfield神经网络算法


十三、结果分析

我们设置以下参数来求解TSP案例

TSP问题—Hopfield神经网络算法


根据这些初值,Hopfield神经网络在经过10000次迭代优化后,找到的TSP的最优路线解为

TSP问题—Hopfield神经网络算法


最终Hopfield神经网络找到的最优哈密顿回路为



可以看到初值设置得当,Hopfield神经网络找到的最优解已经和真实最优解一致

在神经网络优化过程中,能量函数的波动为



用Hopfield神经网络求解TSP问题,我们可以总结出以下几点

(1)Hopfield神经网络是求解TSP的一种优化网络算法

(2)Hopfield神经网络通过神经动力学来映射生物神经网络,在参数设置合理的情况下,有可能找到真实最优解,比近似算法计算的效果要好

(3)Hopfield神经网络比较依赖初始权值的设置,会受到初始输入状态和输出状态的随机性影响,不一定每一次都可以找到最优解,有可能找到的是不同的次优解

案例github代码见:阅读原文

以上是关于TSP问题—Hopfield神经网络算法的主要内容,如果未能解决你的问题,请参考以下文章

TSP问题基于hopfield神经网络求解TSP问题matlab

Hopfield神经网络处理TSP问题

连续型Hopfield神经网络求解TSP问题神经网络十一

连续型Hopfield神经网络求解TSP问题神经网络十一

多层感知机MLPRBF网络Hopfield网络自组织映射神经网络神经网络算法地图

DL:Hopfield 神经网络