前言:
反向传播算法(英:Backpropagation algorithm,简称:BP算法)是一种监督学习算法,常被用来训练多层感知机。 它用于计算梯度计算中,降低误差。
目录:
- 链式法则
- 模型简介(Model)
- 损失函数,梯度
- 手写例子
- min-batch
一 链式法则
链式法则是反向传播算法里面的核心。
case1: , x,y,z 都是scalar
case2: ,s,x,y,z 都是scalar
case3: x,y,z 都是向量vector
二 模型(Model)
以常用的网络模型DNN 为例:
激活函数为
总的层数为 L
三 损失函数,梯度
3.1 损失函数
3.2 梯度更新
梯度计算分为两步:
Forward pass, Backward pass
a Forward pass
假设 :
利用微分和迹的关系很容易得到
b Backward pass
假设为最后一层L
我们用数学归纳法,第L层的已经求出, 假设第l+1层的已经求出来了,那么我们如何求出第l层的呢?
四 简单DNN 网络例子
4.1 说明:
这里面随机生成5张图形,分别对应手写数字1,2,3,4,5。
简单的了解一下如何快速搭建一个DNN Model, 梯度如何计算,更新的.
# -*- coding: utf-8 -*-
"""
Created on Fri Dec 15 17:21:35 2023@author: chengxf2
"""import torch
from torch import nn
from torch import optimclass DNN(nn.Module):'''它是一个序列容器,是nn.Module的子类。 `nn.Sequential` 中的层是有顺序的,而且严格按照其顺序执行相邻两个层连接必须保证前一个层的输出与后一个层的输入相匹配。'''def __init__(self):super(DNN, self).__init__()self.net = nn.Sequential(nn.Linear(in_features=28*28, out_features=500),nn.Sigmoid(),nn.Linear(in_features=500, out_features=10),nn.Sigmoid())def forward(self, input):output = self.net(input)return outputdef train():device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")model = DNN()criteon = torch.nn.CrossEntropyLoss(reduction='mean')optimizer = optim.SGD(model.parameters(), lr=0.01, momentum=0.9)batch_size= 5data = torch.rand((batch_size,28*28))epochs = 2target = torch.tensor([0,1,2,3,4])target = target.to(device)for epoch in range(epochs):yHat = model(data)loss = criteon(yHat, target)loss.backward()print("\n loss ",loss)optimizer.step()if __name__ == "__main__":train()
五 min-batch
在深度学习训练中,数据集我们通常采用min-batch 方案
我们采用随机梯度方法,是为了加快运算速度。
但是GPU 可以并行运算,所以可以采用min-batch 方法进行梯度计算。
使用min-batch 有个限制:
1: 硬件限制 batch 不能超过硬件大小
2: batch 不能太大,否则容易陷入到局部极小值点,采用小的batch 可以有一定的随机性
每次出发点都不一样,一定概率跳过局部极小值点
参考:
7: Backpropagation_哔哩哔哩_bilibili
https://www.cnblogs.com/pinard/p/6422831.html
CSDN
8-1: “Hello world” of deep learning_哔哩哔哩_bilibili