CS231n作业笔记2.6:卷积层以及池化层的实现

2023-12-15 23:38

本文主要是介绍CS231n作业笔记2.6:卷积层以及池化层的实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

CS231n简介

详见 CS231n课程笔记1:Introduction。
本文都是作者自己的思考,正确性未经过验证,欢迎指教。

作业笔记

就是简单实现一下卷积层以及池化层,唯一的难点在于确定索引值,稍微注意一下就好。

1. 卷积层

1.1. 前向传播

使用np.pad做填充。

  N, C, H, W = x.shapeF, C, HH, WW = w.shapestride = conv_param['stride']pad = conv_param['pad']H_new = 1 + (H + 2 * pad - HH) / strideW_new = 1 + (W + 2 * pad - WW) / stridex = np.pad(x,((0,0),(0,0),(pad,pad),(pad,pad)),'constant',constant_values=0)out = np.zeros([N,F,H_new,W_new])for n in xrange(N):for f in xrange(F):for hh in xrange(H_new):for ww in xrange(W_new):out[n,f,hh,ww] = np.sum(x[n,:,hh*stride:hh*stride + HH,ww*stride:ww*stride+WW]*w[f])+b[f]

1.2. 后向传播

  x, w, b, conv_param = cacheN, C, H, W = x.shapeF, C, HH, WW = w.shapestride = conv_param['stride']pad = conv_param['pad']H_new, W_new = dout.shape[-2:]dx, dw, db = None, None, Nonedx = np.zeros_like(x)dx = np.pad(dx,((0,0),(0,0),(pad,pad),(pad,pad)),'constant',constant_values=0)dw = np.zeros_like(w)db = np.zeros_like(b)for n in xrange(N):for f in xrange(F):for hh in xrange(H_new):for ww in xrange(W_new):db[f] += dout[n,f,hh,ww]dw[f] += dout[n,f,hh,ww]*x[n,:,hh*stride:hh*stride + HH,ww*stride:ww*stride+WW]dx[n,:,hh*stride:hh*stride + HH,ww*stride:ww*stride+WW] += dout[n,f,hh,ww]*w[f]dx = dx[:,:,pad:H-pad,pad:W-pad]

2. 池化函数

2.1. 前向传播

  N, C, H, W = x.shapepool_height = pool_param['pool_height']pool_width = pool_param['pool_width']stride = pool_param['stride']H_new = 1 + (H - pool_height) / strideW_new = 1 + (W - pool_width) / strideout = np.zeros([N,C,H_new,W_new])for n in xrange(N):for c in xrange(C):for h in xrange(H_new):for w in xrange(W_new):out[n,c,h,w] = np.max(x[n,c,h*stride:(h*stride+pool_height), w*stride:(w*stride+pool_width)])

2.2. 后向传播

  N, C, H, W = x.shapepool_height = pool_param['pool_height']pool_width = pool_param['pool_width']stride = pool_param['stride']H_new = 1 + (H - pool_height) / strideW_new = 1 + (W - pool_width) / stridedx = np.zeros_like(x)for n in xrange(N):for c in xrange(C):for h in xrange(H_new):for w in xrange(W_new):max_index = np.argmax(x[n,c,h*stride:(h*stride+pool_height), w*stride:(w*stride+pool_width)])dx[n,c,h*stride+max_index/pool_width,w*stride+max_index%pool_width] += dout[n,c,h,w]

这篇关于CS231n作业笔记2.6:卷积层以及池化层的实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/498325

相关文章

Spring Boot 整合 Redis 实现数据缓存案例详解

《SpringBoot整合Redis实现数据缓存案例详解》Springboot缓存,默认使用的是ConcurrentMap的方式来实现的,然而我们在项目中并不会这么使用,本文介绍SpringB... 目录1.添加 Maven 依赖2.配置Redis属性3.创建 redisCacheManager4.使用Sp

Kali Linux安装实现教程(亲测有效)

《KaliLinux安装实现教程(亲测有效)》:本文主要介绍KaliLinux安装实现教程(亲测有效),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、下载二、安装总结一、下载1、点http://www.chinasem.cn击链接 Get Kali | Kal

C#使用MQTTnet实现服务端与客户端的通讯的示例

《C#使用MQTTnet实现服务端与客户端的通讯的示例》本文主要介绍了C#使用MQTTnet实现服务端与客户端的通讯的示例,包括协议特性、连接管理、QoS机制和安全策略,具有一定的参考价值,感兴趣的可... 目录一、MQTT 协议简介二、MQTT 协议核心特性三、MQTTNET 库的核心功能四、服务端(BR

SpringCloud整合MQ实现消息总线服务方式

《SpringCloud整合MQ实现消息总线服务方式》:本文主要介绍SpringCloud整合MQ实现消息总线服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、背景介绍二、方案实践三、升级版总结一、背景介绍每当修改配置文件内容,如果需要客户端也同步更新,

Dubbo之SPI机制的实现原理和优势分析

《Dubbo之SPI机制的实现原理和优势分析》:本文主要介绍Dubbo之SPI机制的实现原理和优势,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Dubbo中SPI机制的实现原理和优势JDK 中的 SPI 机制解析Dubbo 中的 SPI 机制解析总结Dubbo中

使用Java实现Navicat密码的加密与解密的代码解析

《使用Java实现Navicat密码的加密与解密的代码解析》:本文主要介绍使用Java实现Navicat密码的加密与解密,通过本文,我们了解了如何利用Java语言实现对Navicat保存的数据库密... 目录一、背景介绍二、环境准备三、代码解析四、核心代码展示五、总结在日常开发过程中,我们有时需要处理各种软

Java 压缩包解压实现代码

《Java压缩包解压实现代码》Java标准库(JavaSE)提供了对ZIP格式的原生支持,通过java.util.zip包中的类来实现压缩和解压功能,本文将重点介绍如何使用Java来解压ZIP或RA... 目录一、解压压缩包1.zip解压代码实现:2.rar解压代码实现:3.调用解压方法:二、注意事项三、总

NGINX 配置内网访问的实现步骤

《NGINX配置内网访问的实现步骤》本文主要介绍了NGINX配置内网访问的实现步骤,Nginx的geo模块限制域名访问权限,仅允许内网/办公室IP访问,具有一定的参考价值,感兴趣的可以了解一下... 目录需求1. geo 模块配置2. 访问控制判断3. 错误页面配置4. 一个完整的配置参考文档需求我们有一

Linux实现简易版Shell的代码详解

《Linux实现简易版Shell的代码详解》本篇文章,我们将一起踏上一段有趣的旅程,仿照CentOS–Bash的工作流程,实现一个功能虽然简单,但足以让你深刻理解Shell工作原理的迷你Sh... 目录一、程序流程分析二、代码实现1. 打印命令行提示符2. 获取用户输入的命令行3. 命令行解析4. 执行命令

基于MongoDB实现文件的分布式存储

《基于MongoDB实现文件的分布式存储》分布式文件存储的方案有很多,今天分享一个基于mongodb数据库来实现文件的存储,mongodb支持分布式部署,以此来实现文件的分布式存储,需要的朋友可以参考... 目录一、引言二、GridFS 原理剖析三、Spring Boot 集成 GridFS3.1 添加依赖