Unet论文研读以及pytorch下环境搭建

@


前言

Unet多应用于CNN中图像分割领域。对于小数据集也有很好的性能。

一、Unet

1.Unet网络框架

   论文中只用分割出细胞边界,所以最后使用的是2个1*1卷积得到背景和目标两个。如果是多目标分割,根据分割目标的种类来决定使用1*1的卷积的数量来输出Segmentation map.注:对于多目标的Label标注:可以使用不同颜色,然后使用One-hot编码生成Label进行训练。
Unet network architecture

2.Unet运用的 Skip connection

语义分割网络在特征融合时也有2种办法:
(1)FCN式的逐点相加,也叫加操作。如图1。
(2)U-Net式的channel维度拼接融合,也叫叠操作。如图2。

FCN的Skip connection

图1 FCN中Skip connection方式

Unet的Skip connection

图2 Unet中Skip connection方式

Copy and crop操作: 经过两次3*3卷积后,大小变为28×28,然后经过一次2*2卷积,变为56×56,这时和左侧大小为64×64的图像进行维度的叠加,但是由于图像大小不同,需要将左侧的64×64大小的图像裁剪为56×56大小,此处的裁剪是合理的,原因看下一步3中讲的Overlap-tile策略。

3.Unet应用的Overlap-tile策略

   可以发现Unet论文中输入的图像是572×572但是输出图像确实388×388.这是不是就意味着原图像存在信息丢失的现象呢?实际上不是的,经过了no padding的卷积操作,输入图像和输出图像肯定是不一样的尺寸,但是Unet在论文中提及了一种策略--Overlap-tile,将图像进行镜像扩充和输入网络,这样经过卷积后得到的输出图像和实际需要提取的图像是相同的尺寸。
   例如下图,实际需要分割的图像是黄色框所选中部分,但是输入到网络中的图像是蓝色部分,对空白部分进行镜像填充,这样经过网络后所得到的的输出大小尺寸适合实际需要分割的图像大小是一样的。
Overkap-tile

4.Unet的LossFunction

   Unet训练时对细胞边界的像素点增加了权重,使用加权损失函数,可以更注重细胞边界分割。此处d1,d2个人不清楚是使用什么计算的距离
LossFunction

二、Pytorch环境搭建及Training

1.相关资源

数据集:https://github.com/Rwzzz/Unet
代码:https://github.com/Rwzzz/Unet

2.实验结果

  • 训练集大小30张图片
  • 训练时间epochs=40,batch_size=1
  • 训练环境 pytorch1.7

在实际训练中为了方便,没有采用Unet中的策略。
统一输入和输出尺寸的两种方案:
1.padding='same'形式
2.对小分辨率特征图进行填充后进行维度的连接。

Loss值

图1.训练的Loss

分割图

图2.测试集预测结果

总结

    Unet模型简单,并且使用较少的数据集,可以达到非常理想的分割效果,对于医学和其他一些数据集比较少的领域优势很大。

posted @ 2021-03-23 10:34  一半丶  阅读(1354)  评论(0编辑  收藏  举报