梯度,方向导数,相关概念

2024-06-20 07:08

本文主要是介绍梯度,方向导数,相关概念,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.

http://blog.cvmarcher.com/posts/2015/06/27/gradient-descent/



梯度下降法是求解神经网络的方法中最流行的一个,思想很简单,就是函数沿着梯度的方向下降的最快。通常来讲,我们在求解机器学习问题的时候,都会定义一个目标函数,然后基于这个目标函数又定义出损失函数,通过最小化损失函数来使得目标函数达到最优。那么在最小化损失函数的时候就可以用上梯度下降了。

思想简单,实现也很简单。在这篇文章里面,我主要是想讲讲梯度这个东西,因为我经常会被这个概念搞糊涂掉。梯度大一高数(记忆中高中也是讲过…)有教。什么是梯度?首先,它是一个向量,那向量肯定会有方向嘛,梯度的方向呢是使得方向导数达到最大值的方向,它的模就是方向导数的最大值。那什么是方向导数?理解这个东西需要知道导数这个概念,下面我打算从数学定义来说明导数/偏导数/方向导数/梯度这四个东西。

导数

这个我想没有人会不知道。

定义
当函数 y=f(x) y=f(x)的自变量在一点 x0 x0上产生一个增量 Δx Δx时,函数输出值的增量与自变量增量 Δx Δx的比值在 Δx Δx趋于 0 0时的极限如果存在,即为 f(x) f(x) x0 x0处的导数,记作 f(x0) f′(x0) dfdx(x0) dfdx(x0) dfdxx=x0 dfdx|x=x0

我们从小到大对导数的认识就是认为它是函数曲线在相应点的切线的斜率。

偏导数

慢慢的,我们当然不能仅限于一元函数的情况,那么多元函数求导是一个怎么概念?在多元函数情况下,通常我们计算的是偏导数,那么什么是偏导数?简单来讲,就是函数只对某个变量求导得到的导数就是函数关于这个变量的偏导数。比方说,对于二元函数 z=f(x,y) z=f(x,y),当我们把 y y固定住,然后对 x x求导,那么得到的导数称为 f(x,y) f(x,y) x x的偏导数,记为 dzdx dzdx。同样的,固定 x x,对 y y求导得到的便是对 y y的偏导数,记为 dzdy dzdy

方向导数

那么实际上,偏导数 dzdx dzdx dzdy dzdy是函数沿着相应的坐标轴方向的变化率(因为每次我们都固定住其它的变量),那么如果需要同时考虑其他方向的变化率,该怎么办?这就引申出方向导数的概念了。

定义
z=f(x,y) z=f(x,y)在一点 P0(x0,y0) P0(x0,y0)的一个邻域内有定义,又设 l l→是给定的一个方向,其方向余弦为 (cosα,cosβ) (cosα,cosβ),若极限
limt0f(x0+tcosα,y0+tcosβ)f(x0,y0)t limt→0f(x0+tcosα,y0+tcosβ)−f(x0,y0)t
存在,则称此极限值为函数 z=f(x,y) z=f(x,y) P0 P0点沿方向 l l→的方向导数,记为 dzdlx0,y0 dzdl→|x0,y0

实际上, dzdlx0,y0 dzdl→|x0,y0是等于 dzdxx0,y0cosα+dzdyx0,y0cosβ dzdx|x0,y0cosα+dzdy|x0,y0cosβ

其中 t t为点 P0(x0,y0) P0(x0,y0)到点 Pt(x0+tcosα,y0+tcosβ) Pt(x0+tcosα,y0+tcosβ)的距离。

很容易推广到多元的情况,比如三元函数 u=f(x,y,z) u=f(x,y,z)在点 P0(x0,y0,z0) P0(x0,y0,z0)沿方向 l l→的方向导数如下面是式子, l l→方向的方向余弦为 (cosα,cosβ,cosγ) (cosα,cosβ,cosγ)

dudlx0,y0,z0=dudxx0,y0,z0cosα+dudyx0,y0,z0cosβ+dudyx0,y0,z0cosγ dudl→|x0,y0,z0=dudx|x0,y0,z0cosα+dudy|x0,y0,z0cosβ+dudy|x0,y0,z0cosγ

梯度

因为引入了方向导数,那么自然而然就会想,在同一点上的所有方向导数中是否有最大值?显然是有的,而且这个方向导数就是梯度了!

假设令 g=(dzdxx0,y0,dzdyx0,y0) g→=(dzdx|x0,y0,dzdy|x0,y0),那么就有

dzdlx0,y0=gl=|g||l|cosg,l=|g|cosg,l dzdl→|x0,y0=g→⋅l→=|g→||l→|cos⟨g→,l→⟩=|g→|cos⟨g→,l→⟩

显然,当 g,l=0 ⟨g→,l→⟩=0的时候,也就是 gl g→跟l→同向的时候,函数关于 l l→的方向导数最大,且最大值为 |g| |g→|

这里, g=(dzdxx0,y0,dzdyx0,y0) g→=(dzdx|x0,y0,dzdy|x0,y0)就成为函数在点 P0(x0,y0) P0(x0,y0)的梯度,记为 grad z|x0,y0 grad z|x0,y0

梯度下降法也是从这里来,当我们在求解的时候没办法直接得到最优解,只能不断逼近最优解,而逼近的时候又想尽可能的快,那么只能沿着函数变化最剧烈的方法(也就是梯度方向)的反方向走。这里顺便提一下梯度上升法,其实是跟梯度下降法一样,只是它是用于求解函数的最大值,在逼近最优解的时候,沿着梯度方向走。

这篇关于梯度,方向导数,相关概念的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

关于Maven生命周期相关命令演示

《关于Maven生命周期相关命令演示》Maven的生命周期分为Clean、Default和Site三个主要阶段,每个阶段包含多个关键步骤,如清理、编译、测试、打包等,通过执行相应的Maven命令,可以... 目录1. Maven 生命周期概述1.1 Clean Lifecycle1.2 Default Li

numpy求解线性代数相关问题

《numpy求解线性代数相关问题》本文主要介绍了numpy求解线性代数相关问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 在numpy中有numpy.array类型和numpy.mat类型,前者是数组类型,后者是矩阵类型。数组

Redis的Hash类型及相关命令小结

《Redis的Hash类型及相关命令小结》edisHash是一种数据结构,用于存储字段和值的映射关系,本文就来介绍一下Redis的Hash类型及相关命令小结,具有一定的参考价值,感兴趣的可以了解一下... 目录HSETHGETHEXISTSHDELHKEYSHVALSHGETALLHMGETHLENHSET

python中的与时间相关的模块应用场景分析

《python中的与时间相关的模块应用场景分析》本文介绍了Python中与时间相关的几个重要模块:`time`、`datetime`、`calendar`、`timeit`、`pytz`和`dateu... 目录1. time 模块2. datetime 模块3. calendar 模块4. timeit

sqlite3 相关知识

WAL 模式 VS 回滚模式 特性WAL 模式回滚模式(Rollback Journal)定义使用写前日志来记录变更。使用回滚日志来记录事务的所有修改。特点更高的并发性和性能;支持多读者和单写者。支持安全的事务回滚,但并发性较低。性能写入性能更好,尤其是读多写少的场景。写操作会造成较大的性能开销,尤其是在事务开始时。写入流程数据首先写入 WAL 文件,然后才从 WAL 刷新到主数据库。数据在开始

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

log4j2相关配置说明以及${sys:catalina.home}应用

${sys:catalina.home} 等价于 System.getProperty("catalina.home") 就是Tomcat的根目录:  C:\apache-tomcat-7.0.77 <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5p %c{1}:%L - %msg%n" /> 2017-08-10

Node Linux相关安装

下载经编译好的文件cd /optwget https://nodejs.org/dist/v10.15.3/node-v10.15.3-linux-x64.tar.gztar -xvf node-v10.15.3-linux-x64.tar.gzln -s /opt/node-v10.15.3-linux-x64/bin/npm /usr/local/bin/ln -s /opt/nod