tensorflow2.x --------------------DenseNet-----------------------------

news2025/1/17 3:03:49

用tensorflow2.4实现了DenseNet-121,训练基于ImageNet图像数据集,图片输入大小为 224x224 。网络结构采用包含4个DenseBlock的DenseNet-BC,每个DenseNet-BC由若干个 BN+ReLU+1x1 Conv+BN+ReLU+3x3 Conv(Dense_layer)且每个DenseBlock的特征图大小分别为56,28,14,7,DenseNet中每个DenseBlock分别有 [6,12,24,16] 个Dense_layer,在每个DenseBlock后连接Transition module,Transition module 包括一个1x1的卷积和2x2的AveragePooling,具体结构为BN+ReLU+1x1 Conv+2x2 AveragePooling,Transition module层还可以起到压缩模型的作用,假定Transition module的上层DenseBlock得到的特征图channels数为 m ,Transition层可以产生m*n个channels,其中 n 是压缩系数(compression rate)。当 n=1 时,channelss数经过Transition层没有变化,即没有压缩模型,文中使用n=0.5 。具体网络结构如下图:
在这里插入图片描述
具体代码如下:

import tensorflow as tf
import numpy as np
import os
from tensorflow.keras.layers import *
from tensorflow.keras import Model
class  DenseLayer(Model):
    def __init__(self,bottleneck_size,growth_rate):
        super().__init__()
        self.filters=growth_rate
        self.bottleneck_size=bottleneck_size
        self.b1=BatchNormalization()
        self.a1=Activation('relu')
        self.c1=Conv2D(filters=self.bottleneck_size,kernel_size=(1,1),strides=1)
        self.b2=BatchNormalization()
        self.a2=Activation('relu')
        self.c2=Conv2D(filters=32,kernel_size=(3,3),strides=1,padding='same')
    def call(self,*x):
        x=tf.concat(x,2)
        x=self.b1(x)
        x=self.a1(x)
        x=self.c1(x)
        x=self.b2(x)
        x=self.a2(x)
        y=self.c2(x)    
        return y
class DenseBlock(Model):
    def __init__(self,Dense_layers_num,growth_rate):#Dense_layers_num每个denseblock中的denselayer数,growth
        super().__init__()
        self.Dense_layers_num=Dense_layers_num
        self.Dense_layers=[]
        bottleneck_size=4*growth_rate
        for i in range(Dense_layers_num):
            layer=DenseLayer(bottleneck_size,growth_rate)
            self.Dense_layers.append(layer)
    def call(self,input):
        x=[input]
        for layer in self.Dense_layers:
            output=layer(*x)
            x.append(output)
        y=tf.concat(x,2)
        return y
class Transition(Model):
    def __init__(self,filters):
        super().__init__()
        self.b=BatchNormalization()
        self.a=Activation('relu')
        self.c=Conv2D(filters=filters,kernel_size=(1,1),strides=1)
        self.p=AveragePooling2D(pool_size=(2,2),strides=2)
        
    def call(self,x):
        x=self.b(x)
        x=self.a(x)
        x=self.c(x)
        y=self.p(x)
        return y 
class DenseNet(Model):
    def __init__(self,block_list=[6,12,24,16],compression_rate=0.5,filters=64):
        super().__init__()
        growth_rate=32
        self.c1=Conv2D(filters=filters,kernel_size=(7,7),strides=2)
        self.b1=BatchNormalization()
        self.a1=Activation('relu')
        self.p1=MaxPooling2D(pool_size=(3,3),strides=2,padding='same')
        self.blocks=tf.keras.models.Sequential()
        input_channel=filters
        for i,layers_in_block in enumerate(block_list):
            if i<3 :
                self.blocks.add(DenseBlock(layers_in_block,growth_rate))
                block_out_channels=input_channel+layers_in_block*growth_rate
                self.blocks.add(Transition(filters=block_out_channels*0.5))
            if i==3:
                self.blocks.add(DenseBlock(Dense_layers_num=layers_in_block,growth_rate=growth_rate))
        self.p2=GlobalAveragePooling2D()
        self.d2=Dense(1000,activation='softmax') 
    def call(self,x):
        x=self.c1(x)
        x=self.b1(x)
        x=self.a1(x)
        x=self.p1(x)
        x=self.blocks(x)
        x=self.p2(x)
        y=self.d2(x)
        return y
model=DenseNet()


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/18840.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

听我劝,自学游戏建模真的很难

我的个人建议一直是偏向不要自学建模的&#xff08;特别是零基础&#x1f923;&#xff09;&#xff0c;学习3D游戏建模除了单纯需要为爱发电还需要能够自行✅掌握软件操作技巧和✅纠错改正&#xff0c;后者都是自学非常❌难做到的&#x1f62d; 除此之外&#xff0c;还有以下…

详解Unity中的Nav Mesh新特性|导航寻路系统 (二)

前言 第一篇我们简要概述了新版NavMesh的一些新增功能&#xff0c;以及旧版的对比。本篇我们来讲一讲NavMeshSurface、NavMeshLink这两个组件的参数以及如何应用&#xff0c;接下来就进入正题吧。 本系列提要 Unity新版NavMesh专题博客共分成三篇来讲解&#xff1a; 【本篇为…

Golang入门笔记(最后一章 17 封版)—— 映射map

映射 (map) 作为一个常用的类型&#xff0c;Go语言已为我们开发者内置了map类型。 基本语法&#xff1a; var 变量名 map [keyT类型] valueT类型 这里T就是一个类型代表&#xff08;我这么写&#xff0c;有点受到了Java的泛型影响&#xff09;&#xff0c;key的类型通常为str…

【20-业务开发-基础业务-商品模块-分类管理-前端展示后端具有层级关系的目录数据-商品系统三级分类的逻辑删除前后端代码实现】

一.知识回顾 【0.三高商城系统的专题专栏都帮你整理好了&#xff0c;请点击这里&#xff01;】 【1-系统架构演进过程】 【2-微服务系统架构需求】 【3-高性能、高并发、高可用的三高商城系统项目介绍】 【4-Linux云服务器上安装Docker】 【5-Docker安装部署MySQL和Redis服务】…

JUC线程池——newSingleThreadExecutor源码解析JDK提供线程池ThreadPoolExecutor执行任务流程解析

newSingleThreadExecutor源码解析&&JDK提供线程池ThreadPoolExecutor执行任务流程解析测试代码核心代码解析ThreadPoolExecutor内部类&#xff1a;Worker解析调试台线程切换到执行异步任务的线程ThreadPoolExecutor&#xff1a;getTask()LinkedBlockingQueue&#xff1…

shell-函数

函数介绍 shell中有系统函数&#xff0c;也可以自定义函数 系统函数 basename basename [pathname] [suffix] 返回完整路径最后的/的部分&#xff0c;常用于获取文件名 basename命令会删掉所有的前缀包括最后一个/字符&#xff0c;然后将字符串显示出来 suffix为后缀&#…

java计算机毕业设计专业招聘网站(附源码、数据库)

java计算机毕业设计专业招聘网站&#xff08;附源码、数据库&#xff09; 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat8.5 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技…

从零搭建个人博客项目并通过github部署上线

文章目录一、环境准备二、创建hexo博客项目1.全局安装hexo-cil工具2.新建hexo项目3.启动项目三、部署上线1.新建github仓库2.修改配置项3.部署项目一、环境准备 1.Node.js (版本需不低于 10.13) 2.Git https://hexo.io/zh-cn/ hexo博客官方文档 二、创建hexo博客项目 1.全局安…

dhtmlx甘特图marker不随小时移动

dhtmlx甘特图marker是什么&#xff1f; 就是一个跟着日期变化的标记&#xff0c;如下图所示 这段代码是用来调整标记的样式&#xff0c;展示文本的关键代码&#xff0c;如要配置今日标记&#xff0c;需在plugins添加maker后加上这段代码 start_date是用来获得日期的&#xf…

Ubuntu20单机搭建MongoDB4.2集群详细

文章目录 MongoDB文件下载选择你的服务器的安装路径配置文件启动服务集群配置MongoDB文件下载 curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-ubuntu1604-4.2.23.tgz # 直接将版本号4.2.23换成自己需要的版本号即可 将文件下载到你的服务路径选择你的服务器…

《士兵突击》哪些最精彩的话语

目录 1、人不能过得太舒服&#xff0c;太舒服了容易出问题 2、别混日子了&#xff0c;小心日子把你给混了 3、想到和得到&#xff0c;中间还有两个字&#xff0c;那就是要做到 4、每做对一件小事&#xff0c;就被他像救命稻草一样抓着 5、我会带着问题生活&#xff0c;因为…

Qt 事件处理机制简介

1.Qt中事件的来源&#xff0c;谁接收处理。 Qt中事件的来源有两个&#xff1a;程序外部和内部&#xff0c;多数情况下来自操作系统&#xff0c;可以通过bool QEvent::spontaneous() const函数来获知&#xff0c;返回true&#xff0c;事件发生在应用程序之外(系统事件)&#xf…

SAP S4 FI后台详细配置教程- PART1 (通用配置及基础架构篇)

目录 一 、基础配置 3、设置国家区域 4、货币设置 二 、企业结构 1、定义公司 2、定义公司代码 3、维护成本控制范围 4、给公司分配公司代码 5、把公司代码分配给控制范围 本文是会是一篇比较详细文章&#xff0c;也是本人的学习记录。介绍如何在SAP从 0 到 1配置 一家公司 PAR…

虚拟机的 Ubuntu 没有 /dev/fb0 的解决办法

目录 一、概述 二、没有/dev/fb0的可能原因 三、解决过程 四、vesafb:mtrr,ywrap vga0x315的解释 一、概述 近期在学习FrameBuffer相关内容&#xff0c;想在Vmware虚拟机打开Ubuntu 12.04的系统使用一下&#xff0c;发现没有/dev/fb0的文件&#xff0c;于是上网搜索解决办法&…

数据结构之链表(带头双向循环链表)

文章目录前言一、带头双向循环链表二、双向链表的实现1.双向链表的定义2.双向链表的接口3.接口的实现创建返回链表的头结点创建一个新节点打印链表链表的销毁尾插尾删头插头删在链表中进行查找在pos前面插入数据链表删除pos位置处的节点4.主函数&#xff08;测试&#xff09;总…

vue-vuetify-admin案例讲解

vue-vuetify-admin案例讲解1. Introduction1.1 directory structure1.2 vue-cli1.3 vuex1.3.1 在store目录创建index.js1.3.2 在main.js中引入1.3.2 操作数据1.3.4 获取store中的值1.4 vue-router1.5 axios1.6 vuetify2. Code2.1 入门2.2 入门2.3 入门3. xxxvue-vuetify-admin:…

面试:常用的设计模式总结

一、Retrofit中的设计模式 二、OKHTTP中的设计模式 1、责任链模式interceptor拦截器&#xff1a;最主要的是5个拦截器 2、建造者&#xff1a;okhttp的client创建用了 3、观察者&#xff1a;返回结果抽离应该算是 4、工厂模式&#xff1a;Call 的创建用了工厂&#xff0c;Ca…

几何算法——10.欧拉操作

几何算法——10.欧拉操作1 欧拉操作1.1 欧拉操作的设计思想1.2 欧拉操作的选取1.3 几个典型的欧拉操作1.3.1 mvfs1.3.2 mev1.3.3 mef1.3.4 kemr1.3.5 kfmrh1.4 一个欧拉操作的实例1.5 欧拉操作的三点结论2. 非流形体2.1 非流形模型&#xff08;non-manifold model&#xff09;2…

动力节点索引优化解决方案学习笔记——性能分析

2. 性能分析 2.1 MySQL常见瓶颈 SQL中对大量数据进行比较、关联、排序、分组时CPU的瓶颈。 实例内存满足不了缓存数据或排序等需要&#xff0c;导致产生大量的物理IO。查询数据时扫描过多数据行&#xff0c;导致查询效率低。 2.2 Explain 使用EXPLAIN关键字可以模拟优化器执…

Super Vlan理论讲解

目录 Super Vlan作用 Super Vlan类型 Super Vlan通信规则 华为Super Vlan配置 传统Vlan部署中&#xff0c;一个Vlan对应一个网段和一个Vlanif接口来实现Vlan间的通信 造成了IP地址的浪费&#xff0c;因此提出了Super Vlan技术 Super Vlan作用 Super Vlan又称为聚合&#x…