DarkNet网络结构

news/2024/7/3 17:48:53 标签: 深度学习, 人工智能, 计算机视觉

一、darknet53网络结构图

文字版:卷积+(下采样卷积+1残差块)+(下采样卷积+2残差块)+(下采样卷积+8残差块)+(下采样卷积+8残差块)+(下采样卷积+4*残差块)

在这里插入图片描述

     不难看出,darknet53就是重复堆叠下采样卷积+n*残差块(n为残差块的个数)这个结构而组成的。而更基本的结构就是残差块了,因此我们先构建出残差块,然后重复堆叠上述结构darknet53就完成了。

二、残差快结构

       残差块结构不止下图这一种,但我们只讨论darknet53中用到的这种。如下图所示,残差块结构由两条支路组成,一条支路将上一层输出的feature map进行卷积等操作,另一条支路将上一层输出的feature map恒等映射,并与刚才卷积操作完的feature map进行逐元素相加,因此两条支路的通道数必须相等。也就是说发生卷积等操作的那条支路(残差路)的输出不能改变feature map的通道数。

另外,darknet53在所有的卷积之后和激活(leakyrelu)之前会插入bn层(batch normalization)。 

import torch
import torch.nn as nn
# 残差模块
class ResidualBlock(nn.Module):
    def __init__(self,inplanes,planes):
        # inplanes是下采样卷积完输入到残差支路的通道数,planes是一个列表,planes[0]是残差第一个卷积操作输出通道数,也是第二个卷积操作输入通道数
        # planes[1]是残差第二个卷积操作输出通道数
        super(ResidualBlock,self).__init__()
        # 残差支路的第一个卷积操作:卷积核1*1,步长1,不填充,不加偏置
        self.conv1 = nn.Conv2d(inplanes,planes[0],kernel_size=1,stride=1,padding=0,bias=False)
        # bn层的输入参数是上一层输出的通道数
        self.bn1 = nn.BatchNorm2d(planes[0])
        # LeakyReLU的参数是负半轴的斜率,正半轴是1
        self.relu1 = nn.LeakyReLU(0.1)
        # 残差支路的第二个卷积操作:卷积核3*3,步长1,填充1(p=1),不加偏置
        # 卷积输出尺寸计算公式 (n-f+2p)/s+1 此处f=3,p=1,s=1
        self.conv2 = nn.Conv2d(planes[0],planes[1],kernel_size=3,stride=1,padding=1,bias=False)
        self.bn2 = nn.BatchNorm2d(planes[1])
        self.relu2 = nn.LeakyReLU(0.1)

        # 【注】darknet的基本操作:卷积+bn+relu

    def forward(self,x):
        # 恒等映射支路
        residual = x 
        out = self.conv1(x)
        out = self.bn1(out)
        out = self.relu1(out)
        out = self.conv2(out)
        out = self.bn2(out)
        out = self.relu2(out)
		# 将恒等映射与残差路逐元素相加	
        out = residual + out

 基本结构:下采样卷积+残差块

下图示下采样卷积+n*残差块结构:

在这里插入图片描述

       除了第一个单独的卷积+bn+激活操作,一共有5组下采样卷积+n*残差块,按顺序是:(下采+1残差)(下采+2残差)(下采+8残差)(下采+8残差)(下采+4*残差),所以待会儿会出现一个储存残差块个数的列表blocks_num=[1,2,8,8,4]


http://www.niftyadmin.cn/n/1385613.html

相关文章

Web开发要做好浏览器兼容谈何容易?

浏览器兼容虽说是web开发的基本要求,但是要做到完全兼容各种浏览器谈何容易?对于开发和设计都由程序员兼着的小公司的信息部门来说,更是雪上加霜。就连京东商城,包括百度做出了的东西,也都很难保证主流浏览器的完全兼容。其中最典型的是京东&#xff0c…

windows系统通过CMD将文件copy到远程电脑

在需要上传文件的电脑上使用管理员权限运行cmd,输入runas /user:administrator cmd 回车net share IPC$ net use \\IP地址\ipc$ password /user:username xcopy note.ejs \\IP地址\C$\clothes\views /Y net use \\IP地址\ipc$ /delete转载于:https://www.cnblogs.co…

Extjs中FieldSet的收缩和展开实例

Extjs中FieldSet的收缩和展开实例: FieldSet表单控件属于Ext.form.FieldSet的类,继承自:Ext.Panel,表示对某一组字段的标准容器,其中最主要的一个功能就是收缩和展开收缩与展开demo: items: [id:check_email_hacklog_s…

简单的dp加贪心

题目链接:传送门 这个题目让我纠结了好久,之后恍然大悟是求最长的递减序列,并加上贪心的算法,如果有大于两个的发射系统,应该判断使导弹的高度与此时个个发射系统的高度比较,选取高度差最小的去执行这次的拦…

python文件目录下的__init__文件

一、声明包 python 中的项目结构是按照目录来组织的,每个python 文件就是一个模块,将模块整合在一起就是包,也就是把服务于某个功能的一系列模块放在一个目录中,这样如果想要使用某个包中的某个功能,只需要导入相应包中…

DBunit、Spring TestContext实践

1、定义接口UserDao.java package com.bao.dbunit.dao;import com.bao.dbunit.entity.User;public interface UserDao {public User getUserByNick(String nick);public void save(User user);public void update(User user);public void remove(String nick);}Pojo类&#xff…

微信公众平台开发(105) 分享到朋友圈和发送给好友

<script type"text/javascript">function onBridgeReady() {var mainTitle"华章书院",mainDesc"2014最受企业家喜爱的商业图书评选",mainURL"http://hz.huiyiw.org/hzshuyuan/home/index.php",mainImgUrl "http://hz.huiyi…

linux环境下载google云盘文件

python环境下安装gdown pip install gdownAfter that, you can download any file from Google Drive by running one of these commands: gdown https://drive.google.com/uc?id<file_id> # for files gdown <file_id> # alt…