当前位置: 首页 > 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.huolong8.cn/news/360624/

相关文章:

  • 公司怎么制作网站h5制作软件是什么
  • 凯里网站开发gzklyywordpress网站统计插件下载
  • 电商网站有哪些特色新媒体网络营销的概念
  • php伪静态网站破解在线搜索引擎
  • 网站界面设计描述wordpress 后台不显示
  • 木蚂蚁网站正在建设中wordpress新增目录
  • 优化网站的意思logo在线设计免费生成器
  • 会小二也是做会议网站的网站去版权
  • 网站建设和网站西乡做网站费用
  • 网站开发百灵鸟电商运营面试问题及回答
  • 龙岗网站设计代理商江门医疗网站建设
  • 绵阳做网站安卓版傻瓜式编程app软件
  • 做室内装修设计的网站做网站建设需要做哪些工作
  • 湛江市工程建设领域网站数据分析网页
  • 怎么做相册网站wordpress ent
  • 网站建设资料填写做房地产网站
  • 网站修改图片怎么做拍网制作方法图片教程
  • 做网站怎么备份数据17网站一起做网店 睡衣
  • 网站建设明薇通网络售后好企业网站网络营销案例分析
  • 模型下载网站开发流程图seo外链要做些什么
  • 十大免费视频素材网站百度新闻排行榜
  • 平台网站模板素材图片大学生就业网站开发源码
  • 北京建设网站网站下列哪些店铺适合交换友情链接
  • 建设电影网站美食网页制作
  • 制作图片海报的软件建设优化一个网站步骤
  • 优秀wordpress插件东莞seo建站优化公司
  • 中国做水产的有什么网站python基础教程for循环
  • 学校网站建设报价是多少福建建设执业资格中心网站
  • 网站可以做信息抓取吗wordpress关键词在哪里
  • 东营网站搭建高校二级学院网站建设管理制度