| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> Python知识库 -> [数值计算-11]:多元函数求最小值 - 偏导数与梯度下降法&Python法代码示例 -> 正文阅读 |
|
[Python知识库][数值计算-11]:多元函数求最小值 - 偏导数与梯度下降法&Python法代码示例 |
作者主页(文火冰糖的硅基工坊):https://blog.csdn.net/HiWangWenBing 本文网址:https://blog.csdn.net/HiWangWenBing/article/details/119854683 目录 前置参考:[数值计算-10]:一元非线性函数求最小值 - 梯度下降法&Python法代码示例 https://blog.csdn.net/HiWangWenBing/article/details/119832688 第1章 多元非线性函数1.1 什么是多元函数设D为一个非空的n 元有序数组的集合, f为某一确定的对应规则。 若对于每一个有序数组?( x1,x2,…,xn)∈D,通过对应规则f,都有唯一确定的实数y与之对应,则称对应规则f为定义在D上的n元函数。 记为y=f(x1,x2,…,xn) 其中 ( x1,x2,…,xn)∈D。 变量x1,x2,…,xn称为自变量,y称为因变量。 当n=1时,为一元函数,记为y=f(x),x∈D, 当n=2时,为二元函数,记为z=f(x,y),(x,y)∈D。 二元及以上的函数统称为多元函数。 1.2 二元函数的几何图形设D是二维空间R2的一个非空子集,称映射f:D→R为定义在D上的二元函数,通常记为 z=f(x,y),(x,y)∈D 其中点集D称为该函数的定义域,x、y称为自变量,z称为因变量. 如二元函数:z = f(x,y) =??x^2 + y^2 + 1 1.3. 函数的元与方程的元的区别一元函数与二元方程:y= f(x)? => y - f(x) = 0 二元函数与三元方程:z= f(x,y)? => z?- f(x,y) = 0 第2章 向量vector2.1 什么是向量在数学中,向量(也称为欧几里得向量、几何向量、矢量),指具有大小(magnitude)和方向的量。它可以形象化地表示为带箭头的线段。 与向量对应的量叫做数量(物理学中称标量),数量(或标量)只有大小,没有方向。 2.2?向量的维度向量的投影轴的个数,就是向量的维度,如:? (1)一维向量 A= [P1] = [Px] =【2】, 1维向量,投影值为2 (2)二维向量 A= [P1,P2] = [Px, Py] =【4,3】, 2维向量,在2个维度方向的投影值分别为4,3. (3)三维向量 A= [P1,P2,P3] = [Px, Py, Pz] =【2,3,5】, 3维向量,在个3维度方向的投影值为2,3,5 2.3 向量的组成成分就是向量在各个维度方向或数轴方向的投影,就是向量的成分,表示为:A= [P1,P2,P3, .....Pn] 2.4 向量的方向箭头所指:代表向量的方向。 2.5 向量的大小线段长度:代表向量的大小。 2.6 向量在此文中的作用(1)描述多元函数在空间中任意点的坐标组成, 即不同维度方向上的数值。 (2)描述多元函数在空间中任意点的切线组成,即不同维度方向上切线/导数值。
第3章 多元函数的偏导数/偏微分3.1 一元函数的切线和导数一元函数的切线和导数,有现成的公式求导数,如下图所示: ?那么,对于二元函数或多元函数,求导数,该如何计算呢? 这就需要用到偏导数的概念:通过临时固化其他维度分量的数值,用来求解多元函数在某个维度方向的导数或切线斜率。 然后,把所有维度方向的导数组成一个向量,就得到多元函数在空间中某一点处的导数或梯度P = {P1, P2, P3.....Pn}; 其中Pi是在i维度方向上的偏导数。 3.2 什么多元函数的偏导数/偏微分其中: x1, x2,....Xi......表示的是维度方向,而不是指在单个维度方向上的数值序列.? {x1.0, x1.1, x1.2.....x1.n..}? 表示在x1的维度方向的序列 {x2.0, x2.1, x2.2.....x2.n..}? 表示在x2的维度方向的序列 {xi.0,? xi.1, xi.2? .....xi.n..}? 表示在x2的维度方向的序列 为了编码混淆,我们把不同的维度,使用不同的字母表示,并用二元函数为例: z = f(x,y), 则在(xi,yi)处的偏导数为: 3.3 偏导数的计算方法(1)导函数解析法 f'(x,y)|x 为f(x,y)在任意点(x,y)处相对于x的偏导函数 ,则在(xi,yi)处的对x的偏导数=?f'(xi,yi)|x f'(x,y)|y?为f(x,y)在任意点(x,y)处相对于y的偏导函函,则在(xi,yi)处的对y的偏导数 =?f'(xi,yi)|y (2)极限法 在(xi,yi)处对x求偏导: ?? ? ? 在(xi,yi)处对y求偏导: ? ? ? ? (3)数值计算法(类似极限法) 详见: [数值计算-9]:一元非线性函数求导数(数值微分)- 解析法与迭代法&Python法代码示例 https://blog.csdn.net/HiWangWenBing/article/details/119824982 第4章 梯度4.1 什么梯度在空间几何中,空间中的任意一点的梯度,就是一个向量, 4.2 梯度的标量表示法? 4.3 梯度的向量表示法4.4 梯度的复数表示4.5 梯度的计算梯度的计算就是偏导数的计算。 某个维度方向的梯度值 = 学习率 * 偏导数 * (-1) 第5章 梯度下降法求多元函数的极小值 - 原理5.1 二元与一元函数梯度下降法的比较?(1)一元函数的梯度下降法图示 (2)二元函数的梯度下降法图示: ? 与一元函数的梯度下降法求极小值大体相同,主要区别在于:
5.2 迭代算法? 5.3?收敛条件
第6章 梯度下降法求多元函数的极小值 - 代码示例6.1 前提条件
6.2?二元函数图形
输出: 6.3?二元偏导函数图形(1)对x的偏导函数
输出: (2)对y的偏导函数
6.4?二元函数梯度下降法(1)梯度下降法算法函数
(2)梯度下降法运行:学习率=0.1
(2.0370359763344878e-09, 2.0370359763344878e-09, 1.0)
Out[11]: <mpl_toolkits.mplot3d.art3d.Path3DCollection at 0x1dd0e292340> (3)梯度下降法运行:学习率=0.5
(0.0, 0.0, 1.0)
Out[12]: <mpl_toolkits.mplot3d.art3d.Path3DCollection at 0x1dd0e2f3d60> (4)梯度下降法运行:学习率=0.9
(2.0370359763344985e-09, 2.0370359763344985e-09, 1.0)
Out[15]: <mpl_toolkits.mplot3d.art3d.Path3DCollection at 0x1dd0e49f250> 作者主页(文火冰糖的硅基工坊):https://blog.csdn.net/HiWangWenBing 本文网址:https://blog.csdn.net/HiWangWenBing/article/details/119854683 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 | -2024/12/26 23:35:41- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |
数据统计 |