当前位置: 首页 > java >正文

【ConvLSTM第一期】ConvLSTM原理

目录

  • 🧠 一、ConvLSTM 原理详解
    • 1.1 背景
    • 1.2 ConvLSTM 的结构
  • 参考

ConvLSTM(Convolutional Long Short-Term Memory)是一种结合了卷积神经网络(CNN)与循环神经网络(RNN)中 LSTM(长短期记忆)模型的结构,专用于处理具有时序性和空间结构的数据(如视频、时序图像等)。

在这里插入图片描述
下面我将详细讲解ConvLSTM的原理与Python实现方法。

🧠 一、ConvLSTM 原理详解

1.1 背景

传统的 LSTM适合处理一维时间序列数据(如语音、文本),但不适合处理空间结构显著的二维或三维数据(如图像或视频帧)。

LSTM 是为 一维序列(如文本、语音) 设计的,输入形状是:

(batch, time, features)

例如:

x = torch.rand(32, 10, 100)  # 32个序列,每个10步,每步是100维向量

❌ 如果你把图像当成向量输入 LSTM,会发生什么?

  • 你必须把图像 flatten(摊平),如 64×64 变成 4096
  • 这样会 丢失空间结构(像素之间的邻接关系)

ConvLSTM 的改进 —— 处理 3D 空间信息

ConvLSTM 通过将传统 LSTM 中的全连接操作替换为 卷积操作,从而保留空间结构信息。

ConvLSTM 的输入不是 (batch, time, feature),而是:

(batch, time, channels, height, width)

每一个时间步输入的是一个图像(或图像帧),保留空间结构。

🔁 它在每一时间步中,不再执行全连接运算,而是对图像执行 2D 卷积操作:
在这里插入图片描述

(+) 是矩阵乘法(LSTM)
(*) 是卷积操作(ConvLSTM)

1.2 ConvLSTM 的结构

在普通 LSTM 中,状态更新公式如下:

i_t = σ(W_xi * x_t + W_hi * h_{t-1} + b_i)
f_t = σ(W_xf * x_t + W_hf * h_{t-1} + b_f)
o_t = σ(W_xo * x_t + W_ho * h_{t-1} + b_o)
g_t = tanh(W_xg * x_t + W_hg * h_{t-1} + b_g)c_t = f_t ⊙ c_{t-1} + i_t ⊙ g_t
h_t = o_t ⊙ tanh(c_t)

LSTM的单元结构如下:
在这里插入图片描述

为了克服LSTM在处理三维信息中的不足,ConvLSTM 将 LSTM 中的2D的输入转换成了3D的tensor,最后两个维度是空间维度(行和列)。对于每一时刻t的数据,ConvLSTM 将 LSTM 中的一部分连接操作替换为了卷积操作,即通过当前输入和局部邻居的过去状态来进行预测。
在这里插入图片描述

在这里插入图片描述

在 ConvLSTM 中,相应的乘法操作 * 被替换为卷积操作 ⊛:

i_t = σ(W_xi ⊛ x_t + W_hi ⊛ h_{t-1} + b_i)
f_t = σ(W_xf ⊛ x_t + W_hf ⊛ h_{t-1} + b_f)
o_t = σ(W_xo ⊛ x_t + W_ho ⊛ h_{t-1} + b_o)
g_t = tanh(W_xg ⊛ x_t + W_hg ⊛ h_{t-1} + b_g)c_t = f_t ⊙ c_{t-1} + i_t ⊙ g_t
h_t = o_t ⊙ tanh(c_t)

其中:

  • ⊛ 表示卷积操作
  • 输入 x_t 是一个多通道图像(如帧)
  • h_t 和 c_t 是隐藏状态和单元状态的张量,包含空间结构

在这里插入图片描述

参考

1、Tensor(张量)的解释说明

Tensor(张量)就是一个多维数组。

维度举例说明
0D3.14标量
1D[1, 2, 3]向量
2D[[1,2],[3,4]]矩阵
3DRGB 图像:(通道, 高, 宽)
4D(batch, 通道, 高, 宽)一批图像
5D(batch, 时间, 通道, 高, 宽)一批视频序列(ConvLSTM 的输入张量)

PyTorch 中:

x = torch.rand(2, 10, 1, 64, 64)  # 一个 batch=2 的视频序列

表示:

  • 2 个样本
  • 每个样本有 10 帧图像(时间维度)
  • 每帧是 1 通道(灰度图)
  • 每帧的大小是 64×64(空间维度)
http://www.xdnf.cn/news/9765.html

相关文章:

  • 回文数-leetCode-009
  • [Java恶补day10] 560. 和为K的子数组
  • 每日Prompt:卵石拼画
  • 计算机图形学:(五)坐标系
  • 排序算法-归并排序与快速排序
  • 如何避免客户频繁更换对接人
  • vue3项目 前端文件下载的两种工具函数
  • spring的多语言怎么实现?
  • OSI 七大层详解
  • vue element日期范围选择器只能选择指定天数内的
  • shell脚本实现字符串子网掩码转为位数
  • mqtt协议连接阿里云平台
  • 基于多模态脑电、音频与视觉信号的情感识别算法【Nature核心期刊,EAV:EEG-音频-视频数据集】
  • Deepseek应用技巧-Dify本地化搭建合同审批助手
  • Delphi 导入excel
  • 【东枫科技】KrakenSDR 测向快速入门指南
  • Vision Transformer网络结构
  • 【穷举】数字方格
  • 文件系统与文件管理:从磁盘到内核的全链路解析
  • 高效工具-tldr
  • 网络安全的守护者:iVX 如何构建全方位防护体系
  • 镍钯金PCB有哪些工艺优势?
  • 五、web安全--XSS漏洞(2)--XSS相关payload
  • 《Discuz! X3.5开发从入门到生态共建》第3章 Discuz! X3.5 核心目录结构解析-优雅草卓伊凡
  • Parsel深度解析:从入门到高阶的网页数据抓取艺术
  • python同步mysql数据
  • WPS 免登录解锁编辑
  • 安全访问 std::tuple 的容错方法及气象领域应用
  • R3GAN利用配置好的Pytorch训练自己的数据集
  • Vue-Router中的三种路由历史模式详解