首页 > 其他分享 >2.4 微积分

2.4 微积分

时间:2023-05-24 10:34:57浏览次数:33  
标签:None set frac 微积分 axes partial legend 2.4

2.4.1 导数和微分

导数是啥无需多讲,可以代码实现求 \(f(x)=3x^2-4x\) 在 \(x=1\) 处的导数的趋近值

%matplotlib inline
import numpy as np
from matplotlib_inline import backend_inline
from d2l import torch as d2l
def f(x):  # 定义f(X)
    return 3 * x ** 2 - 4 * x

def numerical_lim(f, x, h):  # 求导函数
    return (f(x + h) - f(x)) / h

h = 0.1
for i in range(5):
    print(f'h={h:.5f}, numerical limit={numerical_lim(f, 1, h):.5f}')
    h *= 0.1
h=0.10000, numerical limit=2.30000
h=0.01000, numerical limit=2.03000
h=0.00100, numerical limit=2.00300
h=0.00010, numerical limit=2.00030
h=0.00001, numerical limit=2.00003

使用matplotlib对导数的这种解释进行可视化。

ps:#@save是d2l包的标记,用来把函数、类或者语句保存在d2l包中,以后无需定义即可调用。

def use_svg_display():  #@save
    """使用svg格式在Jupyter中显示绘图"""
    backend_inline.set_matplotlib_formats('svg')

def set_figsize(figsize=(3.5, 2.5)):  #@save
    """设置matplotlib的图表大小"""
    use_svg_display()
    d2l.plt.rcParams['figure.figsize'] = figsize  # 这里可以直接使用d2l.plt是因为导入语句 from matplotlib import pyplot as plt已标记为保存到d2l包中

#@save
def set_axes(axes, xlabel, ylabel, xlim, ylim, xscale, yscale, legend):
    """设置matplotlib的轴"""
    axes.set_xlabel(xlabel)
    axes.set_ylabel(ylabel)
    axes.set_xscale(xscale)
    axes.set_yscale(yscale)
    axes.set_xlim(xlim)
    axes.set_ylim(ylim)
    if legend:
        axes.legend(legend)
    axes.grid()

#@save
def plot(X, Y=None, xlabel=None, ylabel=None, legend=None, xlim=None,
         ylim=None, xscale='linear', yscale='linear',
         fmts=('-', 'm--', 'g-.', 'r:'), figsize=(3.5, 2.5), axes=None):
    """绘制数据点"""
    if legend is None:
        legend = []

    set_figsize(figsize)
    axes = axes if axes else d2l.plt.gca()

    # 如果X有一个轴,输出True
    def has_one_axis(X):
        return (hasattr(X, "ndim") and X.ndim == 1 or isinstance(X, list)
                and not hasattr(X[0], "__len__"))

    if has_one_axis(X):
        X = [X]
    if Y is None:
        X, Y = [[]] * len(X), X
    elif has_one_axis(Y):
        Y = [Y]
    if len(X) != len(Y):
        X = X * len(Y)
    axes.cla()
    for x, y, fmt in zip(X, Y, fmts):
        if len(x):
            axes.plot(x, y, fmt)
        else:
            axes.plot(y, fmt)
    set_axes(axes, xlabel, ylabel, xlim, ylim, xscale, yscale, legend)
x = np.arange(0, 3, 0.1)
plot(x, [f(x), 2 * x - 3], 'x', 'f(x)', legend=['f(x)', 'Tangent line (x=1)'])

image

2.4.2 偏导数

无需多言

2.4.3 梯度

梯度(gradient)向量也就是一个包含n个偏导数的向量:

\[\nabla_xf(x)=\left[\frac{\partial f(x)}{\partial x_1},\frac{\partial f(x)}{\partial x_2},\dots,\frac{\partial f(x)}{\partial x_3}\right]^T \]

2.4.4 链式法则

无需多言

练习

(1)绘制函数 \(y=f(x)=x^3-\frac{1}{x}\) 和其在 \(x=1\) 处切线的图像。

def g(x):  # 定义g(X)
    return x ** 3 - 1 / x

x = np.arange(0, 3, 0.1)
plot(x, [g(x), 4 * x - 4], 'x', 'g(x)', legend=['g(x)', 'Tangent line (x=1)'])
C:\Users\AncilunKiang\AppData\Local\Temp\ipykernel_8840\2032550329.py:2: RuntimeWarning: divide by zero encountered in true_divide
  return x ** 3 - 1 / x

image


(2)求函数 \(f(x)=3x_1^2+5e^{x_2}\)的梯度值

求两个偏导,写成向量形式即可。

对 \(x_1\) 求偏导得: \(f'(x_1)=6x_1\)

对 \(x_2\) 求偏导得: \(f'(x_1)=5e^{x_2}\)

最后得函数 \(f(x)\) 相对于 \(x\) 的梯度是:

\[\nabla_xf(x)=\left[6x_1\ ,\ 5e^{x_2}\right]^T \]


(3)函数 \(f(x)=||x||_2\) 的梯度是什么?

第二范数的表达式时:

\[f(x)=||x||_2=\sqrt{\sum^n_{i=1}x^2_i}=\sqrt{x_1^2+x_2^2+\dots+x_n^2} \]

求偏导是:

\[\frac{\partial f(x)}{\partial x_k}=\frac{x_k}{\sqrt{\sum^n_{i=1}x^2_i}} \]

最后得函数 \(f(x)\) 相对于 \(x\) 的梯度是:

\[\nabla_xf(x)=\left[\frac{x_1}{\sqrt{\sum^n_{i=1}x^2_i}},\frac{x_2}{\sqrt{\sum^n_{i=1}x^2_i}},\dots,\frac{x_n}{\sqrt{\sum^n_{i=1}x^2_i}}\right]^T \]


(4)尝试写出函数 \(u=f(x,y,z)\) 的链式法则,其中 \(x=x(a,b)\),\(y=y(a,b)\),\(z=z(a,b)\)。

\[\frac{\partial u}{\partial a}=\frac{\partial f}{\partial x}\frac{\partial x}{\partial a}+\frac{\partial f}{\partial y}\frac{\partial y}{\partial a}+\frac{\partial f}{\partial z}\frac{\partial z}{\partial a} \]

\[\frac{\partial u}{\partial b}=\frac{\partial f}{\partial x}\frac{\partial x}{\partial b}+\frac{\partial f}{\partial y}\frac{\partial y}{\partial b}+\frac{\partial f}{\partial z}\frac{\partial z}{\partial b} \]

标签:None,set,frac,微积分,axes,partial,legend,2.4
From: https://www.cnblogs.com/AncilunKiang/p/17427277.html

相关文章

  • httpd2.4 配置https访问
    httpd版本:Serverversion:Apache/2.4.37(AlibabaCloudLinux) 实验步骤如下:1.购买域名,使用阿里云域名购买k.com。2.购买ECS服务器(使用突发式实例-印度尼西亚,便宜3分钱一小时),带有公网IP。3.配置域名解析demo.k.com指向ECS公网IP。4.购买SSL证书,使用阿里云数字证书......
  • 2.4 过程
    过程是软件中的一种抽象,提供一种代码封装的方式,类似于函数。要提供对过程的机器级支持,必须包含以下机制:传递控制:在进入过程Q的时候,程序计数器必须被设置为Q的代码的起始地址,然后在返回时,要把程序计数器设置为P中调用Q后面那条指令的地址。传递数据:P必须能够向Q提供一个或多个参......
  • springboot 2.4 版本后的多环境配置
    beanpackagecom.example.demo.tt;importorg.springframework.beans.factory.annotation.Value;importorg.springframework.stereotype.Component;importjavax.annotation.PostConstruct;@ComponentpublicclassTT{@Value("${test.ww}")pub......
  • Neuron 2.4.0 发布:体验下一代工业物联网连接和管理
    近日,EMQ旗下的工业协议网关软件Neuron发布了最新的2.4.0版本。该版本新增了包括ABBCOMLI在内的四个南向驱动和一个北向应用,同时对现有的插件功能和UI进行了优化。快速体验Neuron新版本新增驱动插件满足不同场景需求IEC61850MMS和Allen-BradleyDF1IEC61850M......
  • 【容器化应用程序设计和开发】2.4 容器网络和存储
    往期回顾:第一章:【云原生概念和技术】第二章:2.1容器化基础知识和Docker容器第二章:2.2Dockerfile的编写和最佳实践第二章:2.3容器编排和Kubernetes调度2.4容器网络和存储容器网络和存储是容器化应用中非常重要的两个概念。容器网络可以帮助不同的容器之间进行通信,而容器存......
  • 使用ICTCLAS JAVA版(ictclas4j)进行中文分词(附ictclas,停用词表,commons-lang-2.4.jar下
    一、ICTCLAS的介绍中国科学院计算技术研究所在多年研究基础上,耗时一年研制出了基于多层隐码模型的汉语词法分析系统ICTCLAS(InstituteofComputingTechnology,ChineseLexicalAnalysisSystem),该系统的功能有:中文分词;词性标注;未登录词识别。分词正确率高达97.58%(最近的973专......
  • Wallys 2×2.4GHz 2x5GHz/ #MT7915 #MT7975 /support openwrt
    DR7915https://www.wallystech.com/Network_Card/DR7915-wifi6-MT7915-MT7975-2T2R-support-OpenWRT-802.11AX-supporting-MiniPCIe-Module.htmlMT7915+MT7975 Chipset2.4GHzmax23dBm&5GHzmax20dBmoutputpower IEEE802.11ac /axcompliant&backwardcompa......
  • Wallys 2×2.4GHz 2x5GHz/ #MT7915 #MT7975 /support openwrt
    DR7915https://www.wallystech.com/Network_Card/DR7915-wifi6-MT7915-MT7975-2T2R-support-OpenWRT-802.11AX-supporting-MiniPCIe-Module.htmlMT7915+MT7975 Chipset2.4GHzmax23dBm&5GHzmax20dBmoutputpower IEEE802.11ac /axcompliant&backwardcompa......
  • 6.2.3-6.2.4 组合
    基础知识组合概念一般地,从\(n\)个不同元素中取出\(m(m≤n)\)个元素并成一组,叫做从\(n\)个不同元素中取出\(m\)个元素的一个组合.解释(1)组合的举例:从高二(1)班\(50\)个学生中选\(5\)个学生组个篮球队;从甲、乙、丙三名同学中选出两人参加一项活动.(2)排列与组合的区别排......
  • 2.4 三色球问题
    #include<stdio.h>intmain(){intm,n,number=0;printf("红球白球黑球\n");printf("......................\n");for(m=0;m<=3;m++)/*变量m控制红球的个数*/for(n=0;n<=3;n++)/*变量n控制白球的个数*/if(8-m-n<=6)printf("%2d:%d%d%d......