【每天学点AI】前向传播、损失函数、反向传播
在深度学习的领域中,前向传播、反向传播和损失函数是构建和训练神经网络模型的三个核心概念。今天,小编将通过一个简单的实例,解释这三个概念,并展示它们的作用。
前向传播:神经网络的“思考”过程
前向传播是神经网络计算的基础步骤,它涉及将输入数据逐层传递,通过神经网络的权重和激活函数,最终输出预测结果。这个过程包含“样本数据输入、算法模型、输出”这几个步骤。
我们来举个简单的例子,比如给一个小宝宝看一张图片,然后问他:“这上面画的是什么?”他就会用他的小脑袋瓜去“思考”这张图片,然后告诉你答案。前向传播就像是这个过程,只不过小宝宝换成了神经网络。
- 样本数据输入:这一步将图像、文字、语音等样本数据转换为我们电脑能识别的数字输入。就像小宝宝看到图片,神经网络也接收到一张图片,这张图片被转换成一串数字。
- 算法模型:简单来说,就是一些数学计算,主要包含线性层+规则化层+激活,线性层负责做线性函数的拟合;规则化层负责把我们的线性拟合规则化,方便后面的计算;激活层负责的是变成非线性化,因为我们的现实世界是非线性的。所以整个过程就是:我们输入的样本是非线性的,我们通过这样一堆数学公式,去拟合非线性的样本数据。
- 输出层:也是一些数学运算,比如Linear或者Conv,负责将模型的输出转换为预测结果输出。
这个过程可以用下面的数学公式表示:

损失函数:告诉神经网络它错了多少
损失函数是衡量模型预测结果与真实标签之间差距的依据,它的核心作用是告诉我们模型的预测结果“错”得有多离谱。通俗来说,损失函数就像是一个裁判,它给模型的预测结果打分,分数越低,说明模型的预测结果越接近真实情况,模型的性能就越好。损失函数是为了让我们反向传播起作用的。就像如果小宝宝猜错了,你会告诉他:“不对哦,这是数字8,不是3。”损失函数就像是这句话,它告诉神经网络:“嘿,你的答案有点偏差。”
下面是几种常用的损失函数:
L1 Loss(MAE):平均绝对误差,对异常值的容忍性更高,但当梯度下降恰好为0时无法继续进行。就像是你告诉小宝宝:“你的答案差了多远。”这个距离就是损失值。

L2 Loss(MSE):均方误差,连续光滑,方便求导,但易受到异常值的干扰。这就像是你告诉小宝宝:“你的答案差了多少个单位。”这个单位的平方和就是损失值。

Smooth L1 Loss:处理异常值更加稳健,同时避免了L2 Loss的梯度爆炸问题。就像是你告诉小宝宝:“你的答案差了多远,但我不会因为你猜得特别离谱就惩罚你。”这个损失函数对极端错误更宽容。

反向传播:神经网络的“自我修正”过程
反向传播是利用损失函数的梯度来更新网络参数的过程。它从输出层开始,逆向通过网络,利用链式法则计算每个参数对损失函数的梯度。包含这几个过程:
- 计算输出层误差梯度:首先计算输出层的误差梯度,这是损失函数对输出层权重的敏感度。
- 逐层反向传播:然后从输出层开始,逆向通过网络,逐层计算误差梯度。
- 更新权重和偏置:使用梯度下降算法,根据计算出的梯度更新网络中每一层的权重和偏置。
所以前向传播、反向传播、损失函数之间的关系是这样的:
他们都是深度学习训练过程中的核心。前向传播负责生成预测结果,损失函数负责量化预测结果与真实标签之间的差异,而反向传播则负责利用这些差异来更新模型参数,以减少损失函数的值。
通过三者的结合,我们可以构建、训练并优化深度学习模型,使其能够从数据中学习复杂的模式,并在各种任务如图像识别、自然语言处理和预测分析中做出准确的预测。
前向传播、反向传播、损失函数属于机器学习领域中的核心概念,在AI全体系课程中,是理解其他更复杂机器学习算法的基础,掌握这几个概念对于深入学习机器学习、理解更高级的算法以及在实际应用中设计和优化模型都具有重要的意义。通过理解前向传播、反向传播和损失函数,学习者能够更好地把握机器学习模型的工作原理,为进一步探索深度学习和其他高级机器学习技术打下坚实的基础。
【每天学点AI】前向传播、损失函数、反向传播的更多相关文章
- 小白学习之pytorch框架(6)-模型选择(K折交叉验证)、欠拟合、过拟合(权重衰减法(=L2范数正则化)、丢弃法)、正向传播、反向传播
下面要说的基本都是<动手学深度学习>这本花书上的内容,图也采用的书上的 首先说的是训练误差(模型在训练数据集上表现出的误差)和泛化误差(模型在任意一个测试数据集样本上表现出的误差的期望) ...
- 机器学习(ML)八之正向传播、反向传播和计算图,及数值稳定性和模型初始化
正向传播 正向传播的计算图 通常绘制计算图来可视化运算符和变量在计算中的依赖关系.下图绘制了本节中样例模型正向传播的计算图,其中左下角是输入,右上角是输出.可以看到,图中箭头方向大多是向右和向上,其中 ...
- caffe中 softmax 函数的前向传播和反向传播
1.前向传播: template <typename Dtype> void SoftmaxLayer<Dtype>::Forward_cpu(const vector< ...
- caffe中的前向传播和反向传播
caffe中的网络结构是一层连着一层的,在相邻的两层中,可以认为前一层的输出就是后一层的输入,可以等效成如下的模型 可以认为输出top中的每个元素都是输出bottom中所有元素的函数.如果两个神经元之 ...
- BP原理 - 前向计算与反向传播实例
Outline 前向计算 反向传播 很多事情不是需要聪明一点,而是需要耐心一点,踏下心来认真看真的很简单的. 假设有这样一个网络层: 第一层是输入层,包含两个神经元i1 i2和截距b1: 第二层是隐含 ...
- 反向传播算法(前向传播、反向传播、链式求导、引入delta)
参考链接: 一文搞懂反向传播算法
- 前向传播和反向传播实战(Tensor)
前面在mnist中使用了三个非线性层来增加模型复杂度,并通过最小化损失函数来更新参数,下面实用最底层的方式即张量进行前向传播(暂不采用层的概念). 主要注意点如下: · 进行梯度运算时,tensorf ...
- Tensorflow笔记——神经网络图像识别(一)前反向传播,神经网络八股
第一讲:人工智能概述 第三讲:Tensorflow框架 前向传播: 反向传播: 总的代码: #coding:utf-8 #1.导入模块,生成模拟数据集 import t ...
- 深度学习与CV教程(4) | 神经网络与反向传播
作者:韩信子@ShowMeAI 教程地址:http://www.showmeai.tech/tutorials/37 本文地址:http://www.showmeai.tech/article-det ...
- DNN网络(二)反向传播算法
本文摘自: https://www.cnblogs.com/pinard/p/6422831.html http://www.cnblogs.com/charlotte77/p/5629865.htm ...
随机推荐
- 卷积神经网络CNN实战:MINST手写数字识别——调用模型/模型预测
import torch import torchvision.transforms as transforms from PIL import Image import numpy as np im ...
- 处理报错 ResizeObserver loop completed with undelivered notifications.
// 处理报错 ResizeObserver loop completed with undelivered notifications. export const handlerResizeObse ...
- You are currently using minified code outside of NODE_ENV === 'production'. This means that you are running a slower development build of Redux.
You are currently using minified code outside of NODE_ENV === 'production'. This means that you are ...
- Oracle——navicat连接Oracle数据库报错(12514)
2024/07/22 1.问题描述 2.解决办法 3.参考材料 1.问题描述 与其他厂商做数据对接时,对方提供相关视图,我navicat连接Oracle数据库时报错,其报错代码如下: ORA-1251 ...
- Mac上HomeBrew安装及换源教程
Mac上HomeBrew安装及换源教程 Mac的Mac OS系统来源于Unix系统,得益于此Mac系统的使用类似于Linux,因此Linux系统中的包管理概念也适用于Mac,而HomeBrew便是其中 ...
- .NET 开源报表神器 Seal-Report
前言 Seal-Report 是一款.NET 开源报表工具,拥有 1.4K Star.它提供了一个完整的框架,使用 C# 编写,最新的版本采用的是 .NET 8.0 . 它能够高效地从各种数据库或 N ...
- Node.js开发博客项目笔记-初始化路由(博客列表、新增、更新、删除、详情、登录)(3)
工程目录 如图所示,工程目录如下: 我们在工程下新建src的目录,src目录下新建三个文件夹: controller:交互数据放到该目录下: model:model类放到该目录下: router:路由 ...
- 小tips:npm与npx的区别
npm npm是Node.js的软件包管理器,其目标是自动化的依赖性和软件包管理. 这意味着,可以在package.json文件中为项目指定所有依赖项(软件包),当需要为其安装依赖项时,只要运行npm ...
- Angular 18+ 高级教程 – Change Detection & Ivy rendering engine
前言 不熟悉 Angular 的朋友可能不了解 Change Detection 和目前当火的 Signal 之间的关系,以至于认为现在应该要学习新潮流 Signal 而不是已经过时的 Change ...
- Spring技术书的代码资源下载
我是清华社编辑,这些资源获得作者授权,免费提供给读者个人学习使用.禁止任何形式的商用. 二维码用微信扫,按提示填写你的邮箱,转到电脑上打开邮箱下载.清华国企网盘,比较快速.安全.放心下载. 百度网盘链 ...