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

深度学习之 SegNet

  
可训练的图像分割引擎,包含一个encoder网络,一个对应的decoder网络,衔接像素级分类层,解码网络与VGG16的13层卷积层相同。解码网络是将低分辨率的编码特征图映射到全分辨率的特征图。解码网络使用最大池化层的池化索引进行非线性上采样,上采样过程就不需要学习。上采样得到的稀疏图与可训练的滤波器卷积得到致密的特征图。
  
使用池化层索引进行上采样的优势:
  
1)提升边缘刻画度;
  
2)减少训练的参数;
  
3)这种上采样模式可以包含到任何编码-解码网络中。
  
SegNet网络的结构如下图所示:

在这里插入图片描述

  
SegNet网络结构如图1所示,Input为输入图片,Output为输出分割的图像,不同颜色代表不同的分类。语义分割的重要性就在于不仅告诉你图片中某个东西是什么,而且告知你他在图片的位置。我们可以看到是一个对称网络,由中间绿色pooling层与红色upsampling层作为分割,左边是卷积提取高维特征,并通过pooling使图片变小,SegNet作者称为Encoder,右边是反卷积(在这里反卷积与卷积没有区别)与upsampling,通过反卷积使得图像分类后特征得以重现,upsampling使图像变大,SegNet作者称为Decoder,最后通过Softmax,输出不同分类的最大值。这就是大致的SegNet过程,下面对这个过程里面使用到的方法进行介绍。
  
编码网络与滤波器族卷积得到特征图,进行BN,ReLU,最大池化。最大池化是为了获得空间小位移的平移不变。最大池化和下采样损失了边缘细节,因此,在编码过程中保存边缘信息很重要。考虑到内存原因,只保存最大池化索引,如最大特征值的位置。
  
SegNet解码技术如下图所示:

在这里插入图片描述

  
解码网络使用保存的最大池化索引上采样,得到稀疏的特征图,将特征图与可训练的解码滤波器族卷积得到致密的特征图。之后进行BN。高维的特征图输入soft-max层,对每个像素进行分类,得到每个像素属于K类的概率。 图3中右边是FCN的解码技术,FCN对编码的特征图进行降维,降维后输入到解码网络,解码网络中,上采样使用反卷积实现,上采样的特征图与降维的编码图进行element-wise add得到最终的解码特征图。FCN解码模型需要存储编码特征图,在嵌入式设备中内存紧张。
  
SegNet的Encoder过程中,卷积的作用是提取特征,SegNet使用的卷积为same卷积(详见卷积神经网络CNN(1)),即卷积后不改变图片大小;在Decoder过程中,同样使用same卷积,不过卷积的作用是为upsampling变大的图像丰富信息,使得在Pooling过程丢失的信息可以通过学习在Decoder得到。SegNet中的卷积与传统CNN的卷积并没有区别。


http://www.kler.cn/a/416258.html

相关文章:

  • 手搓一个不用中间件的分表策略
  • 数据库——索引覆盖(Covering Index)
  • 量子蚁群算法复现
  • 云轴科技ZStack助力 “上科大智慧校园信创云平台”入选上海市2024年优秀信创解决方案
  • layui table 纵向滚动条导致单元格表头表体错位问题
  • 【数据结构】填空集
  • 自动类型和推导(aotu和decltype)
  • 【verilog教程】verilog带参数例化
  • HarmonyOS NEXT应用元服务开发Intents Kit(意图框架服务)综述
  • mysql之基本常用的语法
  • 性能监控框架的底层原理
  • Spring Boot教程之十三:更改Spring Boot的默认端口
  • 摄像头原始数据读取——V4L2(userptr模式,V4L2_MEMORY_USERPTR)
  • 【单片机的结构和组成】
  • 深度学习:利用GPU进行训练
  • 牛客练习赛132
  • A-star算法
  • 扩散模型_Diffusion Model
  • 【小白学机器学习35】数据表:整洁数据表,交叉表/列联表,以及两者转化pd.pivot_table()
  • 依赖倒置原则:Java实践篇