码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【图像分割】Unet-ConvLstm利用时序信息进行视频分割


    文章目录

    • 0. 介绍
    • 1. ConvLstm
      • 1.1 Lstm
    • 1.2 ConvLstm

    0. 介绍

    文章: Exploiting Temporality for Semi-Supervised Video Segmentation
    代码: https://github.com/mhashas/Exploiting-Temporality-For-Semi-Supervised-Video-Segmentation
    理解: 使用单帧标注,对视频进行分割。利用时间维度信息来推断空间信息。将传统FCN转化成时间-空间FCN。
    方法: 通过FCN语义分割网络,对时间信息建模。
    框架:
    在这里插入图片描述
    时间建模: 通常将FCN+Lstm进行结合,对时间信息进行建模。一般学习时间信息的Lstm是将CHW的特征进行一维展品。这会导致空间信息的丢失。因此通过使用ConVLSTM可以保存维度不变。

    数据集: 对CityScapes的每个数据选取30帧,其中,仅第20帧具有相对应的标签 。
    训练输入:输入四幅连续的图像(第14、16、18、20帧),其中第20帧含有标签。

    1. ConvLstm

    1.1 Lstm

    http://colah.github.io/posts/2015-08-Understanding-LSTMs/
    https://blog.csdn.net/u013398034/article/details/112789084

    RNN: 在距离相距不大时,可以通过RNN利用之前的信息。当距离变大,记忆衰减,无法建立上下文信息的连接
    RNN的理解:https://zhuanlan.zhihu.com/p/30844905
    在这里插入图片描述
    在LSTM和GRU中,内部的各种门多采用sigmoid激活函数,因为需要确定“0-1”的各种状态;而隐状态的激活函数多采用tanh。
    RNN的每个时间步的权重是相同的,bp过程相当于权重的连续相乘,因此比CNN更容易出现梯度消失和梯度爆炸,因此采用tanh比较多。tanh也会出现梯度消失和梯度爆炸,但是相比于Sigmoid好很多了。理论上ReLU+梯度裁切也可以。
    在这里插入图片描述
    4个time-steps:
    在这里插入图片描述
    LSTM: LSTM可以解决短期记忆问题
    相对于RNN的重复模块(单个tanh层),LSTM具有四个交互层
    在这里插入图片描述
    f(t)表示遗忘,σ代表sigmoid,输出的值为0-1,即f(t)的值趋于+∞时,结果趋于1,反之则为0,这个表示对上一状态遗忘了多少。
    在这里插入图片描述
    这一步表示储存,其中的σ用来决定更新值,tanh用来创建一个新的候选值,
    在这里插入图片描述
    这一步用来更新掉旧的值,并添加新的信息。C(t-1)通过f(t)将旧信息遗忘,通过上一步更新为新的值。
    在这里插入图片描述
    这一步决定输出哪些信息。σ决定输出哪些信息。首先,上一步更新的值输入到tanh然后乘以一个σ的输出,最后就输出决定要输出的部分。
    在这里插入图片描述

    1.2 ConvLstm

    https://www.jianshu.com/p/a82c0ad728f1
    https://blog.csdn.net/m0_50539226/article/details/121779369
    https://arxiv.org/pdf/1506.04214v1.pdf

    ConvLstm基于Lstm,但Lstm只能获取时间维度上的信息。由于采用了卷积核,有了聚合空间上信息的能力
    与LSTM不同之处

    • 将fully-connect layer改成convolutional layer
    • input是3D tensor
    • 核大小越大能够捕获更快的动作,否则捕获慢动作
    • 实现端到端的操作,能够处理边界问题,以及效果优于光流
    • 模型的输入:(batch_size, timestep, channel_dim, height, weight)

    细节分析:传统的Lstm是一种特殊的ConvLstm, 传统的Lstm的核大小是整个图像或者输入。
    ConvLstm使用卷积核得到的输出,会受限于卷积核的大小,步长,为保证输出的大小一致,因此需要进行填充。其填充部分类似于给未来的预测提供预留通道。即预测的结果慢慢的向内部聚拢。

    把Lstm中矩阵相乘的地方替换成卷积。
    在这里插入图片描述

  • 相关阅读:
    反转单链表
    文件上传很难搞?10分钟带你学会阿里云OSS对象存储
    网站域名被墙是什么原因?有什么解决方法?
    【数据结构】内部排序小结- -基数排序
    vivo大数据日志采集Agent设计实践
    【ESP32--FreeRTOS 任务间的同步与通信】
    1.2 三维场景动态生成正射纹理-人机交互实现区域框选
    抢先看!阿里发布2023最新版分布式核心小册,GitHub标星破已千万
    华为软件开发实习生笔试2021.3.31(三)
    layui talbe内容自动换行以及固定列自适应换行后的高度
  • 原文地址:https://blog.csdn.net/qq_44747572/article/details/128147389
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号