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

pytorch深度学习笔记13

目录

摘要

反向传播代码实现


摘要

本篇文章继续学习尚硅谷深度学习教程,学习内容是反向传播代码实现

反向传播代码实现

在之前手写数字识别案例的基础上,对SGD的计算过程进行优化。核心就是使用误差的反向传播法来计算梯度,而不是使用差分数值计算;这将大大提升学习的效率。

对于二层网络TwoLayerNet,隐藏层由一个Affine层和一个ReLU层组成,输出层则由一个Affine层和一个Softmax-with-Loss层组成。由于之前已经实现了各层的类,现在只要用“搭积木”的方式将它们拼接在一起就可以了。

将TwoLayerNet类的代码实现改进如下:

import numpy as np from common.layers import * from common.gradient import numerical_gradient from collections import OrderedDict class TwoLayerNet: def __init__(self, input_size, hidden_size, output_size, weight_init_std = 0.01): # 初始化权重 self.params = {} self.params['W1'] = weight_init_std * np.random.randn(input_size, hidden_size) self.params['b1'] = np.zeros(hidden_size) self.params['W2'] = weight_init_std * np.random.randn(hidden_size, output_size) self.params['b2'] = np.zeros(output_size) # 生成层 self.layers = OrderedDict() self.layers['Affine1'] = Affine(self.params['W1'], self.params['b1']) self.layers['Relu1'] = Relu() self.layers['Affine2'] = Affine(self.params['W2'], self.params['b2']) self.lastLayer = SoftmaxWithLoss() def predict(self, x): for layer in self.layers.values(): x = layer.forward(x) return x # x:输入数据, t:监督数据 def loss(self, x, t): y = self.predict(x) return self.lastLayer.forward(y, t) def accuracy(self, x, t): y = self.predict(x) y = np.argmax(y, axis=1) if t.ndim != 1 : t = np.argmax(t, axis=1) accuracy = np.sum(y == t) / float(x.shape[0]) return accuracy # x:输入数据, t:监督数据 def numerical_gradient(self, x, t): loss_W = lambda W: self.loss(x, t) grads = {} grads['W1'] = numerical_gradient(loss_W, self.params['W1']) grads['b1'] = numerical_gradient(loss_W, self.params['b1']) grads['W2'] = numerical_gradient(loss_W, self.params['W2']) grads['b2'] = numerical_gradient(loss_W, self.params['b2']) return grads def gradient(self, x, t): # forward self.loss(x, t) # backward dout = 1 dout = self.lastLayer.backward(dout) layers = list(self.layers.values()) layers.reverse() for layer in layers: dout = layer.backward(dout) # 设定 grads = {} grads['W1'], grads['b1'] = self.layers['Affine1'].dW, self.layers['Affine1'].db grads['W2'], grads['b2'] = self.layers['Affine2'].dW, self.layers['Affine2'].db return grads
http://www.jsqmd.com/news/226863/

相关文章:

  • emwin抗锯齿功能底层驱动支持
  • USB2.0双层板接口布局实战案例(含原理图)
  • 为什么具身智能系统需要能“自我闭环”的认知机制
  • screen指令结合GDB调试嵌入式程序的场景分析
  • STM32CubeMX安装步骤手把手教程(零基础适用)
  • 51单片机串口通信实验:零基础实现数据收发
  • DevicePairingHandler.dll文件丢失找不到问题 免费下载方法分享
  • 【C++藏宝阁】C++入门:命名空间(namespace)详解
  • 揭秘大数据领域 Eureka 的服务发现的缓存更新机制
  • 零基础学习JLink下载的完整操作流程
  • Arduino寻迹小车图解说明:电路连接全解析
  • DevicePairingProxy.dll文件丢失找不到问题 免费下载方法分享
  • 虚拟机性能优化实战技术文章大纲CPU分配策略:核心数、亲和性设置
  • Arduino IDE环境搭建实战案例(新手必看)
  • 曾仕强老师谈婚姻前应该做什么
  • 【2025最新】基于SpringBoot+Vue的洗衣店订单管理系统管理系统源码+MyBatis+MySQL
  • ModbusPoll下载通信测试:操作指南从零实现
  • 【2025最新】基于SpringBoot+Vue的美发门店管理系统管理系统源码+MyBatis+MySQL
  • DeviceDisplayStatusManager.dll文件丢失找不到问题 免费下载方法分享
  • DeviceMetadataParsers.dll文件丢失找不到问题 免费下载方法分享
  • STM32CubeMX安装超详细版:Windows系统适配说明
  • 前后端分离师生共评作业管理系统系统|SpringBoot+Vue+MyBatis+MySQL完整源码+部署教程
  • d3d10_1core.dll文件丢失找不到 彻底修复解决办法分享
  • Keil5汉化核心要点:规避常见安装问题
  • STM32CubeMX因权限打不开?手把手设置教程
  • 前后端分离智能推荐卫生健康系统系统|SpringBoot+Vue+MyBatis+MySQL完整源码+部署教程
  • 密码发生器(多位数转个位数,去除残留的\n,fgets用法)
  • 2026年01月10日最热门的开源项目(Github)
  • 提升效率:JFlash定制STM32烧录流程
  • ego1开发板大作业vivado实践指南:温度传感器数据采集系统