Hopfield 网络简介

引入

Hopfield网络的概念

Hopfield 网络的应用

Hopfield 网络由于能够非常有效地存储和检索信息,因此在各个领域都很有用。 尽管它们如今并不像用于一般机器学习任务的其他类型的人工神经网络那样常见,但它们仍然具有重要的特定应用:

1.联想记忆:该模型的主要应用之一是其联想记忆能力。 他们可以存储一组模式,然后从部分或嘈杂的版本中检索完整的模式。
2.优化问题:这些网络可用于解决优化问题,例如旅行商问题。 它们收敛到最小能量状态,这可以代表此类问题的最优或接近最优的解决方案。
3.模式识别:它们对于模式识别很有用,特别是在需要识别不完整或扭曲模式的情况下。
4.信号和图像处理:它们可用于过滤和恢复图像和信号的任务,利用其识别模式和校正失真的能力。
5.控制和决策系统:在一些特定的工程应用中,Hopfield 网络可用于控制系统和自动决策,其中快速收敛到稳定的解决方案至关重要。
6.大脑过程建模:它们提供了一个模型来理解大脑如何存储和检索信息,这有助于神经科学研究。
总之,这些人工神经网络模型特别适合需要基于部分或噪声输入检索存储信息的情况以及可以根据能量最小化进行映射的问题。

能量函数

Hopfield 网络的一个关键概念是 “能量景观” 的概念。 网络的配置状态可以通过其能量函数来描述,网络试图将其最小化。 这会导致网络动态中的稳定状态或“吸引子”。

存储和检索

该神经网络可以存储模式或记忆。 当接近存储记忆的模式呈现给网络时,网络会演化到最近的吸引子,从而有效地检索整个记忆。

动力学

每个神经元的状态由它从其他神经元接收的输入的加权和确定。 如果这个总和超过某个阈值,神经元就会被激活; 否则,神经元就会关闭。

Hopfield 网络的对后世影响及其历史地位

  • 物理灵感
    霍普菲尔德将神经网络的动力学与物理学中的系统(特别是统计力学)进行了比较。 这种跨学科方法是革命性的,为神经计算研究开辟了新途径。

  • 对人工智能和神经科学的影响
    该模型影响了人工智能和理论神经科学。 它提供了一个框架来理解复杂的计算如何从简单的神经交互中产生。

  • 未来研究的基础
    Hopfield 网络为神经网络的未来发展奠定了基础,包括深度学习和循环神经网络的进步。

Hopfield Networks 如何学习?

学习过程通过一种基于赫布规则的称为“赫布训练”的方法进行。 这条规则通常被总结为:“神经元一起放电,连接在一起”,并且是模型学习的基本原则。 让我们通过查看步骤来理解这一点:

  • 初始化:最初,网络的权重使用等于零或小的随机值的值进行初始化。
  • Hebbian 训练:在此阶段,网络会接触到必须学习的一组模式。 应用赫布规则来更- 新神经元之间的突触权重,按以下方式完成:
  1. 对于每种训练模式,都会考虑每对可能的神经元。
  2. 如果两个神经元处于相同状态(均活跃或均不活跃),则它们之间的突触权重会增加; 否则,重量保持不变,甚至可能减少。
  3. 这加强了神经元之间的连接,这些神经元在训练模式中往往处于相同的状态。
  • 模式存储:权重更新会导致网络“记住”训练模式。 换句话说,训练模式成为网络能量函数的最小值点。
  • 收敛到稳定状态:训练后,当向网络呈现新模式(可能不完整或有噪声)时,神经元根据突触权重更新其状态。 网络倾向于进化到一种能量最小化的状态,这在理想情况下是记忆模式之一。

Python 示例
为了说明 Hopfield 网络,让我们使用 Python 来举一个简单的例子:

import numpy as np

class HopfieldNetwork:
    def __init__(self, size):
        self.size = size
        self.weights = np.zeros((size, size))

    def train(self, data):
        for pattern in data:
            self.weights += np.outer(pattern, pattern)
        np.fill_diagonal(self.weights, 0)

    def predict(self, pattern):
        result = np.copy(pattern)
        for _ in range(100):  # 
            for i in range(self.size):
                result[i] = 1 if np.dot(self.weights[i], result) > 0 else -1
        return result



训练准则:

这里使用 Hebbian 准则,参看文献 《现代机器学习技术导论》,王东, § \S § 3.3.2.1.

加入运行上面网络的代码,完整代码如下:

import numpy as np

# 定义 Hopfield 网络类
class HopfieldNetwork:
    def __init__(self, size):
        self.size = size
        self.weights = np.zeros((size, size))

    # 训练函数,用于训练网络
    def train(self, data):
        for pattern in data:
            self.weights += np.outer(pattern, pattern)  # 更新权重矩阵
        np.fill_diagonal(self.weights, 0)  # 将对角线元素设置为0,避免自反馈

    # 预测函数,根据输入模式进行预测
    def predict(self, pattern):
        result = np.copy(pattern)
        for _ in range(100):  # 迭代更新模式100次
            for i in range(self.size):
                result[i] = 1 if np.dot(self.weights[i], result) > 0 else -1  # 更新每个神经元的状态
        return result

# 测试案例
if __name__ == "__main__":
    # 创建一个 Hopfield 网络,大小为4
    net = HopfieldNetwork(4)

    # 定义训练模式,训练数据包含两个模式
    patterns = [
        np.array([1, -1, 1, -1]),
        np.array([1, 1, -1, -1])
    ]

    # 训练网络
    net.train(patterns)

    # 定义测试模式
    test_pattern = np.array([1, -1, -1, -1])

    # 使用网络进行预测
    predicted_pattern = net.predict(test_pattern)

    # 打印预测结果
    print("测试模式:    ", test_pattern)
    print("预测模式:    ", predicted_pattern)

代码详细说明:

定义 HopfieldNetwork 类:

  • init(self, size):初始化网络大小和权重矩阵,权重矩阵初始化为零矩阵。
  • train(self, data):根据训练数据更新权重矩阵,使用外积计算权重更新,并将对角线元素设置为0。
  • predict(self, pattern):根据输入模式进行预测,迭代更新神经元状态100次,更新规则是根据当前权重矩阵和神经元状态的点积决定。

测试案例:

  • 创建一个4个神经元的 Hopfield 网络。
  • 定义并训练两个模式 [1, -1, 1, -1] 和 [1, 1, -1, -1]。
  • 定义一个测试模式 [1, -1, -1, -1],并使用网络进行预测。
  • 打印测试模式和预测模式。

相关推荐

  1. Hopfield 网络简介

    2024-07-23 07:26:02       21 阅读
  2. 网络安全简介

    2024-07-23 07:26:02       50 阅读
  3. 三大网络简介

    2024-07-23 07:26:02       24 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-23 07:26:02       52 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-23 07:26:02       54 阅读
  3. 在Django里面运行非项目文件

    2024-07-23 07:26:02       45 阅读
  4. Python语言-面向对象

    2024-07-23 07:26:02       55 阅读

热门阅读

  1. 为什么要学习网安技术?

    2024-07-23 07:26:02       12 阅读
  2. R语言读取txt和csv只有1列时

    2024-07-23 07:26:02       17 阅读
  3. 2024 7.15~7.21 周报

    2024-07-23 07:26:02       15 阅读
  4. 力扣 102题 二叉树的层次遍历 记录

    2024-07-23 07:26:02       15 阅读
  5. 【通俗理解】对数边缘似然:公式与应用

    2024-07-23 07:26:02       15 阅读
  6. mariadb安装centos再次踩坑

    2024-07-23 07:26:02       15 阅读
  7. PostgreSQL 8.4 ROW_NUMBER()函数

    2024-07-23 07:26:02       14 阅读
  8. 通过队列名寻找某队列-linux

    2024-07-23 07:26:02       9 阅读
  9. springboot业务逻辑写在controller层吗

    2024-07-23 07:26:02       14 阅读
  10. linux本地互传文件

    2024-07-23 07:26:02       13 阅读
  11. 异步TCP服务器;异步TCP客户端

    2024-07-23 07:26:02       13 阅读
  12. 【摸鱼笔记】了解itertools,优雅处理list

    2024-07-23 07:26:02       15 阅读