位置: IT常识 - 正文

FCN全卷积网络理解及代码实现(来自pytorch官方实现)(全卷积网络fcn详解)

编辑:rootadmin
FCN全卷积网络理解及代码实现(来自pytorch官方实现)

推荐整理分享FCN全卷积网络理解及代码实现(来自pytorch官方实现)(全卷积网络fcn详解),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:全局卷积,全卷积网络(fcn)与图像分割,全局卷积,fcn全卷积神经网络搭建,什么是全卷积网络,fcn全卷积神经网络搭建,fcn全卷积神经网络搭建,全卷积网络fcn详解,内容如对您有帮助,希望把文章链接给更多的朋友!

视频链接:https://www.bilibili.com/video/BV1J3411C7zd?vd_source=a0d4f7000e77468aec70dc618794d26f 代码:https://github.com/WZMIAOMIAO/deep-learning-for-image-processing

FCN是2015年提出的首个端对端的针对像素级预测的全卷积网络。 如今的pytorch实现的FCN都是基于ResNet-50的backbone,不是论文中的VGG16,且使用的是空洞卷积(也叫膨胀卷积)

pytorch官方实现的FCN网络结构图

博主github:https://github.com/WZMIAOMIAO/deep-learning-for-image-processing/tree/master/pytorch_segmentation/fcn

一、相比以前网络的巨大提升:

二、传统使用池化层最后得到的其实是一个长度为1000的向量:

而换为卷积层之后,最后得到的是1000通道的2D图像,可以可视化为heat map图。

三、回顾VGG16

一般说的vgg16是D: 全连接操作前后:77512(通道)

【假设忽略偏置】\color{red}{【假设忽略偏置】}【假设忽略偏置】 全连接FC1计算:计算对应某一个结点的输出,将该节点与上一层某一个结点的权重与输入对应节点数值相乘,再求和

FC1参数:25088*4096=102760448

下层使用7*7的卷积核、stride=1,4096个卷积核的一个卷积层

Conv参数:77512*4096=102760448

一个卷积核和FC1一个节点参数量一样\color{red}{一个卷积核和FC1一个节点参数量一样}一个卷积核和FC1一个节点参数量一样,一共4096个卷积核,FC也是4096个节点。

【不忽略偏置的正常卷积操作,4096个卷积核应该有4096个偏置项】\color{red}{【不忽略偏置的正常卷积操作,4096个卷积核应该有4096个偏置项】}【不忽略偏置的正常卷积操作,4096个卷积核应该有4096个偏置项】

PS:全连接层

全连接层的输入是一维数组,多维数组需先进行Flatten进行一维化处理,然后连接全连接层。全连接层的每一个结点都与上一层的所有结点相连,用来把前边提取到的特征综合起来。由于其全相连的特性,一般全连接层的参数也是最多的。全连接图结构如下: 其中,x1、x2、x3为全连接层的输入,a1、a2、a3为输出,有

全连接层参数计算

权值参数=输入一维数组大小*全连接层输出结点数 偏置参数b=全连接层输出结点数

eg: 输入有[5044]个神经元结点,输出有500个结点,则一共需要5044*500=400000个权值参数W和500个偏置参数b

卷积和全连接层

卷积跟全连接都是一个点乘的操作,区别在于卷积是作用在一个局部的区域,而全连接是对于整个输入而言,那么只要把卷积作用的区域扩大为整个输入,那就变成全连接了,我就不给出形式化定义了。所以我们只需要把卷积核变成跟输入的一个map的大小一样就可以了,这样的话就相当于使得卷积跟全连接层的参数一样多。 eg:输入是224x224x3 的图像,假设经过变换之后最后一层是[7x7x512]的,那么传统的方法应该将其展平成为一个7x7x512长度的一层,然后做全连接层,假设全连接层为4096×1000层的(假设有1000个分类结果)。 那么用1×1卷积核怎么做呢,因为1×1卷积核相当于在不同channel之间做线性变换,所以:

先选择7×7的卷积核,输出层特征层数为4096层,这样得到一个[1×1×4096]层的 然后再选择用1×1卷积核,输出层数为1000层,这样得到一个[1×1×1000]层这样就搞定了。

四、FCN-32s、16s、8s的区别

上采样倍率为32的模型对应的就是FCN-32s,16s、8s同理。

FCN-32s

FCN原论文中backbone的第一个卷积层padding=100,为了防止图片过小(例如192192)后面的卷积层会报错。 如果图片小于3232的话在卷积过程就会报错。 但是没必要设置,只要输入图片大小大于32*32,我们就可以将padding设置为3。 对于FCN-32s:

vgg16 backbone输出的特征图大小就为h/32,w/32,512。高度宽度变为原图的1/32。

之后经过FC6层:由于我们将FC6卷积层的padding设置为3、卷积核大小7*7,通过FC6之后将不会改变特征图的高和宽;且我们使用了4096个卷积核,所以这里就得到了4096个2D特征图。

FCN全卷积网络理解及代码实现(来自pytorch官方实现)(全卷积网络fcn详解)

经过FC7:使用了1*1大小的卷积核,步距也为1,所以输出特征图shape也不会发生变化。

之后经过卷积核大小为1*1的卷积层:它的卷积核的个数和我们的分类类别数一样(包含背景,对于voc为20类+1背景),将特征图通道数变为num_cls。

之后通过一个转置卷积:这里的s32我们会将特征图上采样32倍【原论文中使用的是双线性插值】,得到特征图大小变为h,w,num_cls。

之后特征图经过一个softmax处理就能得到针对每一个pixel的预测类别。 前面的backbone使用的是vgg16的预训练权重,整个结构十分简单,但是效果还是非常不错的。 其实这里的转置卷积在原论文中其实是将参数给冻结住了,冻结住意味着其实它就是一个简单的双线性卷积了。

所以这里其实可以不使用转置卷积,可以直接使用深度学习框架提供给我们的双线性插值方法。

为什么会冻结呢?作者说冻结不冻结作者觉得结果好像没有什么差别,而且冻结参数会少一些。up主觉得冻结不冻节效果一般的原因是这里的上采样倍率太大了,有点强人所难的感觉。有兴趣的可以看一下u-net中的上采样率是多少。

FCN-16s

FC6、FC7、Conv2d核32s的一样。 不同点:

转置卷积上采样率变为了2倍,之后高和宽变为1/16下面分支经过maxpool4之后变也为1/16,通道数为512;后接上了一个1*1卷积、卷积核数量为num_cls、步长为1,得到特征图大小1/16、通道数变为num_cls之后进行一个相加操作,转置卷积上采样16倍就得到了原图大小h,w,num_cls

【FCN−16s中融合了来自maxpool4的信息】\color{red}{【FCN-16s中融合了来自maxpool4的信息】}【FCN−16s中融合了来自maxpool4的信息】

须知:vgg16经过mxpool3之后特征图大小下采样率为8,经过maxpool4后下采样率为16。

FCN-8s

不同点:

8s还利用了来自于mxpool3的信息,经过16s类似的1*1卷积层后得到一个1/8,通道数为num_cls的特征图;FCN-16s上两层后得到的1/16特征图,经过一个转置卷积上采样,采样率为2倍就能得到一个和maxpool3输出尺寸一样的1/8的特征图一块进行一个相同位置元素的相加操作【进一步的融合】,最后进行一个上采样倍率为8的转置卷积就能得到一个和原图大小一样的特征图大小h,w,num_cls。

【由此可见,FCN−16s和FCN−8s融合了一个底层的信息;而FCN32s是最简单的,它没有融合底层信息】\color{red}{【由此可见,FCN-16s和FCN-8s融合了一个底层的信息;而FCN32s是最简单的,它没有融合底层信息】}【由此可见,FCN−16s和FCN−8s融合了一个底层的信息;而FCN32s是最简单的,它没有融合底层信息】在网上看到最多的是FCN-32的实现。

五、损失计算

针对每一个pixel都会去计算它所对应的一个Cross Entropy Loss,然后将所有pixel的交叉熵损失进行一个求平均操作就得到了一个我们网络的最终的一个损失

六、语义分割评价指标

见前言:语义分割前沿

七、代码实现

ResNet-50中先经过conv1 7*7的一个卷积

conv_2:3*3的一个最大池化下采样,再接上3个残差块(对应右图layer1)conv_3:4个残差块(对应layer2)

不同的地方:\color{red}{不同的地方:}不同的地方:

layer3:这里也有6个残差结构,1个Bottleneck1+5个Bottleneck2layer4:3个残差结构,1个Bottleneck1+2个Bottleneck2

Bottleneck1:

将残差连接的2*2卷积层步距改为1,原来resnet这个分支会进行一个下采样将高和宽缩短为一半,【这里因为语义分割中下采样倍率过大的话,再还原成原图后,这里的效果其实会受影响,所以我们这里就没有必要再做一个下采样了。】

此外主干分支3*3卷积的步距也从2改为了1,同时引入了r参数,即膨胀系数。

Bottleneck2: 接下来通过FCN Head模块:33卷积层缩小通道为原来的1/4【2048-512】,再通过一个dropout和一个11卷积层,这里11卷积层调整特征层的channel为分割类别中的类别个数。 最后经过双线性插值还原特征图大小到原图。【图例:输入480480,上采样也到480*480】

layer3中引出的一条FCN Head,官方回答:为了防止误差梯度没法传递到网络浅层,这里就引入了一个辅助分类器。和google net中辅助分类器是差不多的。 训练的时候是可以使用辅助分类器件的【可用可不用,都可以试一下】,但是最后去预测或者部署到正式环境的时候只用主干的output,不用aux output。 up主的代码地址:https://github.com/WZMIAOMIAO/deep-learning-for-image-processing/tree/master/pytorch_segmentation/fcn

本文链接地址:https://www.jiuchutong.com/zhishi/298954.html 转载请保留说明!

上一篇:Swagger-的使用(详细教程)

下一篇:Vue中created和mounted详解(vue中created和mounted)

  • icloud怎么备份照片(icloud怎么备份照片在哪里看)

    icloud怎么备份照片(icloud怎么备份照片在哪里看)

  • 快手与快手极速版的区别(快手与快手极速版账号通用不)

    快手与快手极速版的区别(快手与快手极速版账号通用不)

  • 强国每周一答视频打不开原因(强国每周答题什么时候更新题库)

    强国每周一答视频打不开原因(强国每周答题什么时候更新题库)

  • 华为mate20支持40w快充吗(华为mate20支持40w超级快充吗)

    华为mate20支持40w快充吗(华为mate20支持40w超级快充吗)

  • 在qq中免费的气泡有哪些(在qq中免费的气泡是什么)

    在qq中免费的气泡有哪些(在qq中免费的气泡是什么)

  • 苹果xsmax突然卡屏不动(苹果xsmax突然卡屏重启了)

    苹果xsmax突然卡屏不动(苹果xsmax突然卡屏重启了)

  • 手机开飞行模式可以收到信息吗(手机开飞行模式会怎么样)

    手机开飞行模式可以收到信息吗(手机开飞行模式会怎么样)

  • 苹果8屏幕突然变暗怎么回事(苹果8屏幕突然变大)

    苹果8屏幕突然变暗怎么回事(苹果8屏幕突然变大)

  • x27摄像头无法收回(x27pro摄像头无法收起)

    x27摄像头无法收回(x27pro摄像头无法收起)

  • 全民k歌录屏为什么没有声音(全民k歌录屏为什么没有声音vivo)

    全民k歌录屏为什么没有声音(全民k歌录屏为什么没有声音vivo)

  • 进入睡眠模式的电脑怎样重新启动(进入睡眠模式的电脑怎样重新开机)

    进入睡眠模式的电脑怎样重新启动(进入睡眠模式的电脑怎样重新开机)

  • 全民k歌耳返怎么没了(全民K歌耳返怎么调成女生)

    全民k歌耳返怎么没了(全民K歌耳返怎么调成女生)

  • iphone7机身长度多少cm(iphone7机身长度多少厘米)

    iphone7机身长度多少cm(iphone7机身长度多少厘米)

  • wifi只能连接一个手机怎么办(wifi只能连接一个手机)

    wifi只能连接一个手机怎么办(wifi只能连接一个手机)

  • qq绑定手机和密保手机有什么区别(qq绑定手机和密码怎么弄)

    qq绑定手机和密保手机有什么区别(qq绑定手机和密码怎么弄)

  • 苹果xr喇叭为什么一边有声音一边没有(为什么苹果xr喇叭会有滋滋的声音呢)

    苹果xr喇叭为什么一边有声音一边没有(为什么苹果xr喇叭会有滋滋的声音呢)

  • 苹果8plus128是什么基带(iphone8plus128)

    苹果8plus128是什么基带(iphone8plus128)

  • 苹果x怎么设置指纹解锁(苹果x怎么设置门禁卡)

    苹果x怎么设置指纹解锁(苹果x怎么设置门禁卡)

  • 苹果就寝怎么恢复原始(苹果就寝模式在哪)

    苹果就寝怎么恢复原始(苹果就寝模式在哪)

  • 微信切换账号怎么还要密码(微信切换账号怎么隐藏起来)

    微信切换账号怎么还要密码(微信切换账号怎么隐藏起来)

  • 复制的网址在哪里找(我复制的网址在哪里才找到)

    复制的网址在哪里找(我复制的网址在哪里才找到)

  • xrxs区别(xr xs 区别)

    xrxs区别(xr xs 区别)

  • 淘宝退货申请在哪(淘宝退货申请在哪里申请)

    淘宝退货申请在哪(淘宝退货申请在哪里申请)

  • win10试用版和正式版的区别(win10试用版和正版有什么区别)

    win10试用版和正式版的区别(win10试用版和正版有什么区别)

  • 苹果怎么设置来电铃声音乐(苹果怎么设置来消息时有闪光灯)

    苹果怎么设置来电铃声音乐(苹果怎么设置来消息时有闪光灯)

  • 抖音怎么拍相似度(抖音怎么拍相似视频教程)

    抖音怎么拍相似度(抖音怎么拍相似视频教程)

  • 高尔夫app开发怎么做(高尔夫的app)

    高尔夫app开发怎么做(高尔夫的app)

  • 解析Linux系统中bashrc和profile文件的作用区别(linux |bc)

    解析Linux系统中bashrc和profile文件的作用区别(linux |bc)

  • win10壁纸怎么删除(win10壁纸图片怎么删除)

    win10壁纸怎么删除(win10壁纸图片怎么删除)

  • 销售货物业务的销项税额怎么计算
  • 个人所得税综合税率表2023
  • 关于美容院的会计如何做账
  • 申请电子发票需要交钱吗
  • 工会费缴纳基数
  • 深圳增值税发票选择确认平台使用
  • 计提代扣代缴个人缴纳的社会保险费分录
  • 股权投资公司如何找项目合作
  • 企业对于无法收回的应收账款
  • 固定资产采购计入什么科目
  • 虚减利润如何进行账务调整?
  • 购置房产按揭应注意事项
  • 车间领用低值易耗品记账凭证
  • 境外单位向境内单位提供咨询
  • 工伤期间奖金发放标准
  • 伙食费没有发票可以税前扣除吗
  • 税务核定利润的标准
  • 建筑挂靠管理费用如何账务处理?
  • 中标费用由哪方出
  • 买二手设备需要注意的事项
  • 电子发票会计怎么记账
  • 其他应收款社保个人部分分录
  • 单位探望病人如何报销费用?
  • 企业支付方式有几种
  • 汇算清缴时研发费用加计扣除怎么做账
  • 腾达路由器默认网关
  • 库存退回
  • 股权转让有哪些股
  • 商业折扣影响税费吗
  • 零售业如何盈利
  • 哪些企业需进行预算管理
  • mxnet github
  • 国家规定发票多久之内可以开
  • 破产企业发放工资怎么算
  • 资产负债表中各项目的期末余额
  • 不发放工资怎么办
  • php模板引擎类
  • js鼠标键盘事件
  • 北京社保月平均工资
  • pycharm pypy
  • 一般开发票都需要什么开票信息包括了什么?
  • 高速公路通行费增值税税率
  • 个税清算所得税怎么计算
  • 餐饮服务收入的增值税
  • sql查询排名前三
  • 在建工程的土地可以查封吗
  • 计提折旧的固定资产平均总值怎么算
  • 房屋预售收入
  • 垃圾处理费如何做账
  • 增值税扣税公式
  • 建筑公司工资如何
  • 手工现金日记账范本
  • 注册资本越多越好吗
  • 固定资产怎么折旧有几种方法
  • 会计账簿的登记实训报告
  • sqlserver 统计sql语句大全收藏
  • win7旗舰版无法安装net4.0
  • windows 10预览版
  • 猎豹如何添加兼容性站点
  • xp电脑启动项怎么设置启动项
  • 系统盘如何重装
  • win7看视频黑屏有声音
  • redhat linux6.5安装教程
  • windows7无法关闭密码保护共享
  • jquery 瀑布流
  • 关于shell的说法,不正确的是
  • javascript中的函数也称为什么
  • JavaScript中的变量名不区分大小写
  • 发送邮件python
  • unity update优化
  • 手机屏幕适配
  • 网络很强大
  • JavaScript中的this
  • python中编写程序
  • 税务认证系统如何操作
  • 税务局税收风险排查总结
  • 农村房屋改造问题向谁举报
  • 广东省电子税务局app下载官网
  • 宁波无犯罪证明能当场拿到吗
  • 江苏电子口岸卡邮寄大概需要多久
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设