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

网站建设课程的感受湖南省百川电力建设有限公司网站

网站建设课程的感受,湖南省百川电力建设有限公司网站,做英语四级题的网站,wordpress mysql索引什么是UNet U-Net由收缩路径和扩张路径组成。收缩路径是一系列卷积层和汇集层#xff0c;其中要素地图的分辨率逐渐降低。扩展路径是一系列上采样层和卷积层#xff0c;其中特征地图的分辨率逐渐增加。 在扩展路径中的每一步#xff0c;来自收缩路径的对应特征地图与当前特征…什么是UNet U-Net由收缩路径和扩张路径组成。收缩路径是一系列卷积层和汇集层其中要素地图的分辨率逐渐降低。扩展路径是一系列上采样层和卷积层其中特征地图的分辨率逐渐增加。 在扩展路径中的每一步来自收缩路径的对应特征地图与当前特征地图级联。 主干结构解析 左边为特征提取网络编码器右边为特征融合网络解码器 高分辨率—编码—低分辨率—解码—高分辨率 特征提取网络 高分辨率—编码—低分辨率 前半部分是编码, 它的作用是特征提取(获取局部特征,并做图片级分类)得到抽象语义特征 由两个3x3的卷积层RELU再加上一个2x2的maxpooling层组成一个下采样的模块一共经过4次这样的操作 特征融合网络 低分辨率—解码—高分辨率 利用前面编码的抽象特征来恢复到原图尺寸的过程, 最终得到分割结果(掩码图片) 代码 import torch.nn as nn import torch# 编码器(论文中称之为收缩路径)的基本单元 def contracting_block(in_channels, out_channels):block torch.nn.Sequential(# 这里的卷积操作没有使用padding,所以每次卷积后图像的尺寸都会减少2个像素大小nn.Conv2d(kernel_size(3, 3), in_channelsin_channels, out_channelsout_channels),nn.BatchNorm2d(out_channels),nn.ReLU(),nn.Conv2d(kernel_size(3, 3), in_channelsout_channels, out_channelsout_channels),nn.BatchNorm2d(out_channels),nn.ReLU())return block# 解码器论文中称之为扩张路径的基本单元 class expansive_block(nn.Module):def __init__(self, in_channels, mid_channels, out_channels):super(expansive_block, self).__init__()# 每进行一次反卷积通道数减半尺寸扩大2倍self.up nn.ConvTranspose2d(in_channels, in_channels // 2, kernel_size(3, 3), stride2, padding1,output_padding1)self.block nn.Sequential(# 这里的卷积操作没有使用padding,所以每次卷积后图像的尺寸都会减少2个像素大小nn.Conv2d(kernel_size(3, 3), in_channelsin_channels, out_channelsmid_channels),nn.BatchNorm2d(mid_channels),nn.ReLU(),nn.Conv2d(kernel_size(3, 3), in_channelsmid_channels, out_channelsout_channels),nn.BatchNorm2d(out_channels),nn.ReLU())def forward(self, e, d):d self.up(d)# concat# e是来自编码器部分的特征图d是来自解码器部分的特征图它们的形状都是[B,C,H,W]diffY e.size()[2] - d.size()[2]diffX e.size()[3] - d.size()[3]# 裁剪时先计算e与d在高和宽方向的差距diffY和diffX然后对e高方向进行裁剪具体方法是两边分别裁剪diffY的一半# 最后对e宽方向进行裁剪具体方法是两边分别裁剪diffX的一半# 具体的裁剪过程见下图一e e[:, :, diffY // 2:e.size()[2] - diffY // 2, diffX // 2:e.size()[3] - diffX // 2]cat torch.cat([e, d], dim1) # 在特征通道上进行拼接out self.block(cat)return out# 最后的输出卷积层 def final_block(in_channels, out_channels):block nn.Conv2d(kernel_size(1, 1), in_channelsin_channels, out_channelsout_channels)return blockclass UNet(nn.Module):def __init__(self, in_channel, out_channel):super(UNet, self).__init__()# 编码器 (Encode)self.conv_encode1 contracting_block(in_channelsin_channel, out_channels64)self.conv_pool1 nn.MaxPool2d(kernel_size2, stride2)self.conv_encode2 contracting_block(in_channels64, out_channels128)self.conv_pool2 nn.MaxPool2d(kernel_size2, stride2)self.conv_encode3 contracting_block(in_channels128, out_channels256)self.conv_pool3 nn.MaxPool2d(kernel_size2, stride2)self.conv_encode4 contracting_block(in_channels256, out_channels512)self.conv_pool4 nn.MaxPool2d(kernel_size2, stride2)# 编码器与解码器之间的过渡部分(Bottleneck)self.bottleneck nn.Sequential(nn.Conv2d(kernel_size(3, 3), in_channels512, out_channels1024),nn.BatchNorm2d(1024),nn.ReLU(),nn.Conv2d(kernel_size(3, 3), in_channels1024, out_channels1024),nn.BatchNorm2d(1024),nn.ReLU())# 解码器(Decode)self.conv_decode4 expansive_block(1024, 512, 512)self.conv_decode3 expansive_block(512, 256, 256)self.conv_decode2 expansive_block(256, 128, 128)self.conv_decode1 expansive_block(128, 64, 64)self.final_layer final_block(64, out_channel)def forward(self, x):# Encodeencode_block1 self.conv_encode1(x)encode_pool1 self.conv_pool1(encode_block1)encode_block2 self.conv_encode2(encode_pool1)encode_pool2 self.conv_pool2(encode_block2)encode_block3 self.conv_encode3(encode_pool2)encode_pool3 self.conv_pool3(encode_block3)encode_block4 self.conv_encode4(encode_pool3)encode_pool4 self.conv_pool4(encode_block4)# Bottleneckbottleneck self.bottleneck(encode_pool4)# Decodedecode_block4 self.conv_decode4(encode_block4, bottleneck)decode_block3 self.conv_decode3(encode_block3, decode_block4)decode_block2 self.conv_decode2(encode_block2, decode_block3)decode_block1 self.conv_decode1(encode_block1, decode_block2)final_layer self.final_layer(decode_block1)return final_layerif __name__ __main__:image torch.rand((1, 3, 572, 572))unet UNet(in_channel3, out_channel2)mask unet(image)print(mask.shape)#输出结果torch.Size([1, 2, 388, 388])
http://www.yutouwan.com/news/360624/

相关文章:

  • 北滘企业网站开发网站开发项目怎么接
  • 微信企业邮箱怎么注册网站全站优化
  • 网站建设整个流程图北京设计网站建设
  • 比较好用的网站山西做网站的企业
  • 太原自助建站软件wp网站怎么用插件做html网页
  • 建设网站江西免费隐私网站推广
  • 网站建设声明函下载网址大全到桌面
  • 艾特软件 网站建设网站软件下载大全
  • 英国T4学生签证 可以做网站吗深圳手工外发加工网
  • 网站的维护方案桃江县建设局网站
  • 做网站时怎样申请域名网站估值
  • 装修公司网站如何做网络推广产品推广介绍
  • 做选择网站中国十大建筑设计公司排名
  • 乐达淄博网站建设制作宿州城乡建设局网站
  • 建立网站的流程是什么免费域名注册网站源码
  • 网站集约化建网站用自己的主机做服务器
  • 建设网站的意义 作用蝉知cms wordpress
  • 做外贸找工厂货源网站qt 网站开发
  • 个人怎么做淘宝客网站360建筑网app下载
  • 公司取名字seo教程搜索引擎优化入门与进阶
  • seo是东莞企业网站排seo租房网站
  • 网站开发图网站反向代理怎么做
  • 电商设计培训课程怎么做百度seo网站
  • 建个购物网站网站主页与导航栏的设计
  • 阿里巴巴国际站入口动漫设计一个月能挣多少钱
  • 咸阳网站开发哪家好wordpress显示产品类别
  • 莆田做网站公司东莞百推网络
  • 微电影网站源码烟台58同城网站建设
  • 哪个网站可以接图纸做全国最火的电商代运营公司
  • 邢台市教育局网站建设seo优化的好处