11、PyTorch中如何进行向量微分、矩阵微分与计算雅克比行列式

devtools/2024/11/30 9:07:56/

文章目录

  • 1. Jacobian matrix
  • 2. python 代码

1. Jacobian matrix

  • 计算
    f ( x ) = [ f 1 = x 1 2 + 2 x 2 f 2 = 3 x 1 + 4 x 2 2 ] , J = [ ∂ f 1 ∂ x 1 ∂ f 1 ∂ x 2 ∂ f 2 ∂ x 1 ∂ f 2 ∂ x 2 ] = [ 2 x 1 2 3 8 x 2 ] \begin{equation} f(x)=\begin{bmatrix} f_1=x_1^2+2x_2\\\\f_2=3x_1+4x_2^2\end{bmatrix}, J=\begin{bmatrix} \frac{\partial f_1}{\partial x_1}&\frac{\partial f_1}{\partial x_2}\\\\ \frac{\partial f_2}{\partial x_1}&\frac{\partial f_2}{\partial x_2} \end{bmatrix}=\begin{bmatrix} 2x_1&2\\\\3&8x_2\end{bmatrix} \end{equation} f(x)= f1=x12+2x2f2=3x1+4x22 ,J= x1f1x1f2x2f1x2f2 = 2x1328x2
  • 我们假设 x 1 = 1 , x 2 = 2 x_1=1,x_2=2 x1=1,x2=2,可得Jacobian matrix 表示如下:
    J = [ 2 x 1 2 3 8 x 2 ] = [ 2 2 3 16 ] \begin{equation} J=\begin{bmatrix} 2x_1&2\\\\3&8x_2\end{bmatrix}=\begin{bmatrix} 2&2\\\\3&16\end{bmatrix} \end{equation} J= 2x1328x2 = 23216
  • 因为fx为向量,所以在pytorch中一般是没有的,我们需要定义一个标量z
    z = [ 1 1 ] [ f 1 f 2 ] → ∂ z ∂ f = [ 1 1 ] \begin{equation} z=\begin{bmatrix}1&1\end{bmatrix}\begin{bmatrix}f_1\\\\f_2\end{bmatrix}\to \frac{\partial z}{\partial f}=\begin{bmatrix}1&1\end{bmatrix} \end{equation} z=[11] f1f2 fz=[11]
  • 根据链式法则:
    ∂ z ∂ f ⋅ ∂ f ∂ x = ∂ z ∂ x \begin{equation} \frac{\partial z}{\partial f} \cdot\frac{\partial f}{\partial x}= \frac{\partial z}{\partial x} \end{equation} fzxf=xz
  • 假设我们代入可得:
    ∂ z ∂ f ⋅ ∂ f ∂ x = [ 1 1 ] [ 2 2 3 16 ] = [ 5 18 ] \begin{equation} \frac{\partial z}{\partial f} \cdot\frac{\partial f}{\partial x}= \begin{bmatrix}1&1\end{bmatrix}\begin{bmatrix} 2&2\\\\3&16\end{bmatrix}=\begin{bmatrix}5&18\end{bmatrix} \end{equation} fzxf=[11] 23216 =[518]
  • 根据pytorch中的自动微分,我们可以得到
    ∂ z ∂ x = [ 5 18 ] \begin{equation} \frac{\partial z}{\partial x}=\begin{bmatrix}5&18\end{bmatrix} \end{equation} xz=[518]
  • 小结1:我们用自动微分,是无法像直接用jacobian函数样求解jacobian矩阵,而是因为引入[1,1]向量后,只能求得和值[5,18]
  • 小结2:想用反向传播求得jacobian矩阵,需要将fx中的每一项标量拆开求得,后再叠加在一起

2. python 代码

#!/usr/bin/env python
# -*- coding:utf-8 -*-
# @FileName  :JacobianTest.py
# @Time      :2024/11/25 19:28
# @Author    :Jason Zhang
import torch
from torch import nn
from torch.autograd.functional import jacobiandef funx(x):return torch.stack([x[0] ** 2 + 2 * x[1], 3 * x[0] + 4 * x[1] ** 2])if __name__ == "__main__":run_code = 0in_x = torch.tensor([1.0, 2.0], dtype=torch.float, requires_grad=True)y = funx(in_x)y.backward(torch.ones_like(y))my_jacobian = jacobian(funx, in_x)print(f"my_jacobian=\n{my_jacobian}")x_grad = in_x.gradin_x_ones = torch.ones_like(in_x)jacobian_x_grad = in_x_ones @ my_jacobianprint(f"x_grad={x_grad}")print(f"jacobian_x_grad={jacobian_x_grad}")
my_jacobian=
tensor([[ 2.,  2.],[ 3., 16.]])
x_grad=tensor([ 5., 18.])
jacobian_x_grad=tensor([ 5., 18.])

http://www.ppmy.cn/devtools/138148.html

相关文章

大数据HCIA笔记1

概述 当下主流的流计算使用Flink Hadoop Hadoop的核心组件:HDFS(分布式文件系统)、Yarn(资源调度)、MapReduce(批量计算引擎) HDFS HDFS -- Hadoop Distributed File System HDFS核心进程(组件):NameNode,DataNode Nam…

2024-2025 ICPC, NERC, Southern and Volga Russian Regional Contest(cf)(个人记录)

A: 思路&#xff1a;一开始有点懵逼&#xff0c;理解错题意了}&#xff0c; 由于是顺序分配&#xff0c;因此前面的人可以选择的条件更多&#xff0c;后面的人更少&#xff0c;我们从后向前遍历即可 #include<bits/stdc.h>using namespace std;typedef long long ll; ty…

github webhooks 实现网站自动更新

本文目录 Github Webhooks 介绍Webhooks 工作原理配置与验证应用云服务器通过 Webhook 自动部署网站实现复制私钥编写 webhook 接口Github 仓库配置 webhook以服务的形式运行 app.py Github Webhooks 介绍 Webhooks是GitHub提供的一种通知方式&#xff0c;当GitHub上发生特定事…

Leetcode(区间合并习题思路总结,持续更新。。。)

讲解题目&#xff1a;合并区间 以数组 intervals 表示若干个区间的集合&#xff0c;其中单个区间为 intervals[i] [starti, endi] 。请你合并所有重叠的区间&#xff0c; 并返回一个不重叠的区间数组&#xff0c;该数组需恰好覆盖输入中的所有区间。示例 1&#xff1a;输入&a…

windows10桌面鼠标右键出现卡顿解决方法 - 副本

步骤如下&#xff1a; 1、按下“WinR” windows10鼠标点击右键出现卡顿的解决方法就为大家介绍到这里了。遇到类似问题的朋友&#xff0c;不要太过紧张&#xff0c;只要按照上面步骤操作一遍就好了。组合键打开运行&#xff0c;输入“regedit”点击确定打开注册表编辑器&…

Flink四大基石之State

State state 可以理解为-- 历史计算结果 有状态计算和无状态计算 无状态计算: 不需要考虑历史数据, 相同的输入,得到相同的输出!如:map, 将每个单词记为1, 进来一个hello, 得到(hello,1),再进来一个hello,得到的还是(hello,1) 有状态计算: 需要考虑历史数据, 相同的输入,可…

HTTP(网络)

目录 1.Http的基本代码 1.1 HttpServer.hpp 1.2 简单测试一下 1.3 用telnet测试一下 1.4 用浏览器访问 1.5 返回相应的过程&#xff08;网页版本&#xff09;​编辑 1.5.1 再次用浏览器访问 1.6 返回相应的过程&#xff08;文件版本&#xff09; 1.6.1网页 1.6.2 测试 …

亚马逊开发视频人工智能模型,The Information 报道

根据《The Information》周三的报道&#xff0c;电子商务巨头亚马逊&#xff08;AMZN&#xff09;已开发出一种新的生成式人工智能&#xff08;AI&#xff09;&#xff0c;不仅能处理文本&#xff0c;还能处理图片和视频&#xff0c;从而减少对人工智能初创公司Anthropic的依赖…