当前位置: 首页 > news >正文

计算神经网络中梯度的核心机制 - 反向传播(backpropagation)算法(1)

计算神经网络中梯度的核心机制 - 反向传播(backpropagation)算法(1)

flyfish

链式法则在深度学习中的主要应用是在反向传播(backpropagation)算法中。
从简单的开始 ,文本说的就是链式法则

R \mathbb{R} R

  • 英文:The set of real numbers
  • 解释:符号 R \mathbb{R} R 表示所有实数的集合,包括所有正数、负数和零。在英语中,这个符号称为 “the set of real numbers” 或简称 “the reals”。
  • 读作:实数集
  • 含义:符号 R \mathbb{R} R 表示所有实数的集合。在数学中,这个符号用来指代从负无穷到正无穷的所有实数。

f ∘ g f \circ g fg

  • 读作 f f f 复合 g g g
  • 含义:符号 ∘ \circ 表示函数的复合。复合函数 f ∘ g f \circ g fg 表示先应用函数 g g g,然后将 g g g 的输出作为函数 f f f 的输入。形式上,这可以写作:
    ( f ∘ g ) ( x ) = f ( g ( x ) ) (f \circ g)(x) = f(g(x)) (fg)(x)=f(g(x))

例子

假设我们有两个函数 g ( x ) = 2 x + 3 g(x) = 2x + 3 g(x)=2x+3 f ( u ) = u 3 f(u) = u^3 f(u)=u3,复合函数 f ∘ g f \circ g fg 表示为:
( f ∘ g ) ( x ) = f ( g ( x ) ) = f ( 2 x + 3 ) = ( 2 x + 3 ) 3 (f \circ g)(x) = f(g(x)) = f(2x + 3) = (2x + 3)^3 (fg)(x)=f(g(x))=f(2x+3)=(2x+3)3

箭头符号的意义

  • f : A → B f: A \to B f:AB 表示函数 f f f 将集合 A A A 中的每个元素映射到集合 B B B 中的一个元素。
  • x ↦ f ( x ) x \mapsto f(x) xf(x) 表示 x x x 经过函数 f f f 的映射得到 f ( x ) f(x) f(x)

例子

  1. 简单映射
    f : R → R f: \mathbb{R} \to \mathbb{R} f:RR 表示一个从实数集合到实数集合的函数。具体的映射可以是:
    f ( x ) = x 2 f(x) = x^2 f(x)=x2
    这里, f f f 将每个实数 x x x 映射到它的平方 x 2 x^2 x2
  2. 复合函数的映射
    如果有两个函数 g g g f f f
  • g : R → R g: \mathbb{R} \to \mathbb{R} g:RR
  • f : R → R f: \mathbb{R} \to \mathbb{R} f:RR并且 g ( x ) = 2 x + 3 g(x) = 2x + 3 g(x)=2x+3 f ( u ) = u 3 f(u) = u^3 f(u)=u3,那么复合函数 f ∘ g f \circ g fg 可以表示为:
    ( f ∘ g ) ( x ) = f ( g ( x ) ) (f \circ g)(x) = f(g(x)) (fg)(x)=f(g(x))
    具体的映射是:
    g : x ↦ 2 x + 3 g: x \mapsto 2x + 3 g:x2x+3
    f : u ↦ u 3 f: u \mapsto u^3 f:uu3
    结合起来:
    ( f ∘ g ) : x ↦ ( 2 x + 3 ) 3 (f \circ g): x \mapsto (2x + 3)^3 (fg):x(2x+3)3

函数的映射关系

在数学中,函数的定义和使用广泛应用于各种映射关系中。箭头符号帮助我们清晰地描述这些关系。更具体地:

  • 箭头 → \to 用于描述集合之间的映射关系。
  • 箭头 ↦ \mapsto 用于描述具体的元素如何被映射。

复合函数的表示

复合函数的映射关系可以通过箭头符号更直观地表示:

  1. g : A → B g: A \to B g:AB
  2. f : B → C f: B \to C f:BC
  3. 复合函数 f ∘ g f \circ g fg 的映射关系为 f ∘ g : A → C f \circ g: A \to C fg:AC
    假设 g g g x x x 映射到 u u u,即 g : x ↦ u g: x \mapsto u g:xu,并且 f f f u u u 映射到 y y y,即 f : u ↦ y f: u \mapsto y f:uy。那么复合函数 f ∘ g f \circ g fg x x x 直接映射到 y y y,即:
    ( f ∘ g ) : x ↦ f ( g ( x ) ) (f \circ g): x \mapsto f(g(x)) (fg):xf(g(x))

复合函数的概念

如果我们有两个函数:

  • g : A → B g: A \to B g:AB
  • f : B → C f: B \to C f:BC
    其中,函数 g g g 将集合 A A A 中的元素映射到集合 B B B,而函数 f f f 将集合 B B B 中的元素映射到集合 C C C。那么,复合函数 f ∘ g f \circ g fg 将集合 A A A 中的元素直接映射到集合 C C C,即:
    ( f ∘ g ) ( x ) = f ( g ( x ) ) (f \circ g)(x) = f(g(x)) (fg)(x)=f(g(x))

例子

  1. 简单的复合函数
    g ( x ) = x 2 g(x) = x^2 g(x)=x2 f ( u ) = sin ⁡ ( u ) f(u) = \sin(u) f(u)=sin(u)。复合函数 ( f ∘ g ) ( x ) (f \circ g)(x) (fg)(x) 表示为:
    ( f ∘ g ) ( x ) = f ( g ( x ) ) = sin ⁡ ( x 2 ) (f \circ g)(x) = f(g(x)) = \sin(x^2) (fg)(x)=f(g(x))=sin(x2)
    在这个例子中,先计算内部函数 g ( x ) = x 2 g(x) = x^2 g(x)=x2,然后将结果代入到外部函数 f ( u ) = sin ⁡ ( u ) f(u) = \sin(u) f(u)=sin(u)
  2. 其他例子
    g ( x ) = 2 x + 3 g(x) = 2x + 3 g(x)=2x+3 f ( u ) = u 3 f(u) = u^3 f(u)=u3。复合函数 ( f ∘ g ) ( x ) (f \circ g)(x) (fg)(x) 表示为:
    ( f ∘ g ) ( x ) = f ( g ( x ) ) = ( 2 x + 3 ) 3 (f \circ g)(x) = f(g(x)) = (2x + 3)^3 (fg)(x)=f(g(x))=(2x+3)3

假设我们有两个函数 g ( x ) g(x) g(x) f ( u ) f(u) f(u)

  1. 先绘制 g ( x ) g(x) g(x) 的图形。例如, g ( x ) = x 2 g(x) = x^2 g(x)=x2 是一个抛物线。
  2. 然后将 g ( x ) g(x) g(x) 的输出代入 f ( u ) f(u) f(u),绘制 f ( g ( x ) ) f(g(x)) f(g(x)) 的图形。例如, f ( u ) = sin ⁡ ( u ) f(u) = \sin(u) f(u)=sin(u),将 u = x 2 u = x^2 u=x2 代入,得到 sin ⁡ ( x 2 ) \sin(x^2) sin(x2) 的图形。
    在这里插入图片描述
import numpy as np
import matplotlib.pyplot as plt# 定义两个函数
def g(x):return x**2def f(u):return np.sin(u)# 生成x的值
x = np.linspace(-2, 2, 400)
y_g = g(x)
y_f = f(y_g)# 初始化图形
fig, (ax1, ax2, ax3) = plt.subplots(3, 1, figsize=(8, 12))# 绘制函数 g(x)
ax1.plot(x, y_g, label=r'$g(x) = x^2$', color='blue')
ax1.set_title('Function $g(x)$')
ax1.set_xlabel('$x$')
ax1.set_ylabel('$g(x)$')
ax1.legend()# 绘制函数 f(u)
u = np.linspace(0, 4, 400)
ax2.plot(u, f(u), label=r'$f(u) = \sin(u)$', color='green')
ax2.set_title('Function $f(u)$')
ax2.set_xlabel('$u$')
ax2.set_ylabel('$f(u)$')
ax2.legend()# 绘制复合函数 h(x) = f(g(x))
ax3.plot(x, y_f, label=r'$h(x) = \sin(x^2)$', color='red')
ax3.set_title('Composite Function $h(x) = f(g(x))$')
ax3.set_xlabel('$x$')
ax3.set_ylabel('$h(x)$')
ax3.legend()# 调整子图之间的间距
plt.subplots_adjust(hspace=0.5)# 显示图形
plt.show()

链式法则(Chain Rule)是微积分中一个重要的求导法则,它用于求复合函数的导数。复合函数是指一个函数的输入是另一个函数的输出,形式上可以写作 y = f ( g ( x ) ) y = f(g(x)) y=f(g(x))。链式法则告诉我们如何求这种复合函数的导数。

如果我们有两个函数 f f f g g g,其中 y = f ( u ) y = f(u) y=f(u) u = g ( x ) u = g(x) u=g(x),那么根据链式法则,复合函数 y = f ( g ( x ) ) y = f(g(x)) y=f(g(x)) x x x 的导数可以表示为:
d y d x = d y d u ⋅ d u d x \frac{dy}{dx} = \frac{dy}{du} \cdot \frac{du}{dx} dxdy=dudydxdu

用更直观的方式理解,链式法则表明:

  1. 首先求出内部函数 u = g ( x ) u = g(x) u=g(x) x x x 的导数,即 d u d x \frac{du}{dx} dxdu
  2. 然后求出外部函数 y = f ( u ) y = f(u) y=f(u) u u u 的导数,即 d y d u \frac{dy}{du} dudy
  3. 最后将这两个导数相乘,得到复合函数 y = f ( g ( x ) ) y = f(g(x)) y=f(g(x)) x x x 的导数。

例子

假设有函数 y = sin ⁡ ( x 2 ) y = \sin(x^2) y=sin(x2),我们希望求 y y y x x x 的导数。

  1. 首先,我们将 y = sin ⁡ ( x 2 ) y = \sin(x^2) y=sin(x2) 看作两个函数的复合,即 y = sin ⁡ ( u ) y = \sin(u) y=sin(u) u = x 2 u = x^2 u=x2
  2. 对内部函数 u = x 2 u = x^2 u=x2 求导: d u d x = 2 x \frac{du}{dx} = 2x dxdu=2x
  3. 对外部函数 y = sin ⁡ ( u ) y = \sin(u) y=sin(u) 求导: d y d u = cos ⁡ ( u ) \frac{dy}{du} = \cos(u) dudy=cos(u)
  4. 将这两个结果相乘: d y d x = d y d u ⋅ d u d x = cos ⁡ ( x 2 ) ⋅ 2 x \frac{dy}{dx} = \frac{dy}{du} \cdot \frac{du}{dx} = \cos(x^2) \cdot 2x dxdy=dudydxdu=cos(x2)2x
    所以, y = sin ⁡ ( x 2 ) y = \sin(x^2) y=sin(x2) x x x 的导数为:
    d y d x = 2 x cos ⁡ ( x 2 ) \frac{dy}{dx} = 2x \cos(x^2) dxdy=2xcos(x2)

微分符号 d d d 的含义

  1. 导数的定义
    导数表示函数在某一点的变化率。对于函数 y = f ( x ) y = f(x) y=f(x),它在 x x x 处的导数定义为: d y d x = lim ⁡ Δ x → 0 Δ y Δ x \frac{dy}{dx} = \lim_{\Delta x \to 0} \frac{\Delta y}{\Delta x} dxdy=limΔx0ΔxΔy这里, Δ y \Delta y Δy Δ x \Delta x Δx 分别表示 y y y x x x 的增量。当这些增量趋近于零时,我们用 d y dy dy d x dx dx 来表示这些非常小的变化量。
  2. 微分表示法
    微分符号 d d d 用于表示一个函数的微小变化。例如, d x dx dx 表示变量 x x x 的一个非常小的变化量。同样地, d y dy dy 表示函数 y y y 的一个非常小的变化量。如果 y = f ( x ) y = f(x) y=f(x),那么 d y dy dy 表示 y y y x x x 的微小变化,可以表示为: d y = f ′ ( x ) ⋅ d x dy = f'(x) \cdot dx dy=f(x)dx这里, f ′ ( x ) f'(x) f(x) 是函数 f ( x ) f(x) f(x) 的导数,表示 x x x 处的变化率。

链式法则中的 d d d

在链式法则中, d d d 表示不同变量的微小变化。例如:

  • d u du du 表示变量 u u u 的微小变化量。

  • d x dx dx 表示变量 x x x 的微小变化量。

  • d y dy dy 表示函数 y y y 的微小变化量。
    链式法则告诉我们,当我们有复合函数 y = f ( g ( x ) ) y = f(g(x)) y=f(g(x)) 时, y y y x x x 的变化可以分解为 y y y u u u 的变化以及 u u u x x x 的变化:
    d y d x = d y d u ⋅ d u d x \frac{dy}{dx} = \frac{dy}{du} \cdot \frac{du}{dx} dxdy=dudydxdu
    这里,每个 d d d 都表示相应变量的微小变化。例如:

  • d y d x \frac{dy}{dx} dxdy 表示 y y y x x x 的变化率。

  • d y d u \frac{dy}{du} dudy 表示 y y y u u u 的变化率。

  • d u d x \frac{du}{dx} dxdu 表示 u u u x x x 的变化率。
    通过这样分解,我们可以更容易地计算复合函数的导数。

基于极限和增量来理解链式法则

  1. 定义复合函数和导数
  • y = f ( u ) y = f(u) y=f(u),其中 u = g ( x ) u = g(x) u=g(x)
  • 我们需要求 y = f ( g ( x ) ) y = f(g(x)) y=f(g(x)) x x x 的导数。
  1. 增量表示
  • Δ x \Delta x Δx x x x 的一个非常小的增量。
  • 相应的, u u u 有一个非常小的增量 Δ u \Delta u Δu,其中 Δ u = g ( x + Δ x ) − g ( x ) \Delta u = g(x + \Delta x) - g(x) Δu=g(x+Δx)g(x)
  • y y y 的增量表示为 Δ y = f ( g ( x + Δ x ) ) − f ( g ( x ) ) \Delta y = f(g(x + \Delta x)) - f(g(x)) Δy=f(g(x+Δx))f(g(x))
  1. 导数的定义 d y d x = lim ⁡ Δ x → 0 Δ y Δ x \frac{dy}{dx} = \lim_{\Delta x \to 0} \frac{\Delta y}{\Delta x} dxdy=limΔx0ΔxΔy
  2. 应用链式法则的思想 Δ y = f ( g ( x + Δ x ) ) − f ( g ( x ) ) \Delta y = f(g(x + \Delta x)) - f(g(x)) Δy=f(g(x+Δx))f(g(x))可以表示为: Δ y Δ x = f ( g ( x + Δ x ) ) − f ( g ( x ) ) Δ x \frac{\Delta y}{\Delta x} = \frac{f(g(x + \Delta x)) - f(g(x))}{\Delta x} ΔxΔy=Δxf(g(x+Δx))f(g(x))
  3. 拆分增量
    由于 u = g ( x ) u = g(x) u=g(x),我们可以引入 Δ u \Delta u Δu Δ y Δ x = f ( g ( x + Δ x ) ) − f ( g ( x ) ) g ( x + Δ x ) − g ( x ) ⋅ g ( x + Δ x ) − g ( x ) Δ x \frac{\Delta y}{\Delta x} = \frac{f(g(x + \Delta x)) - f(g(x))}{g(x + \Delta x) - g(x)} \cdot \frac{g(x + \Delta x) - g(x)}{\Delta x} ΔxΔy=g(x+Δx)g(x)f(g(x+Δx))f(g(x))Δxg(x+Δx)g(x)
  4. 极限过程
    Δ x → 0 \Delta x \to 0 Δx0,我们有 Δ u → 0 \Delta u \to 0 Δu0,因此: d y d x = lim ⁡ Δ x → 0 ( f ( g ( x + Δ x ) ) − f ( g ( x ) ) g ( x + Δ x ) − g ( x ) ⋅ g ( x + Δ x ) − g ( x ) Δ x ) \frac{dy}{dx} = \lim_{\Delta x \to 0} \left( \frac{f(g(x + \Delta x)) - f(g(x))}{g(x + \Delta x) - g(x)} \cdot \frac{g(x + \Delta x) - g(x)}{\Delta x} \right) dxdy=Δx0lim(g(x+Δx)g(x)f(g(x+Δx))f(g(x))Δxg(x+Δx)g(x))根据导数的定义,我们有: d y d x = ( lim ⁡ Δ u → 0 Δ y Δ u ) ⋅ ( lim ⁡ Δ x → 0 Δ u Δ x ) \frac{dy}{dx} = \left( \lim_{\Delta u \to 0} \frac{\Delta y}{\Delta u} \right) \cdot \left( \lim_{\Delta x \to 0} \frac{\Delta u}{\Delta x} \right) dxdy=(Δu0limΔuΔy)(Δx0limΔxΔu)
  5. 导数表示 d y d x = d y d u ⋅ d u d x \frac{dy}{dx} = \frac{dy}{du} \cdot \frac{du}{dx} dxdy=dudydxdu其中, d y d u = lim ⁡ Δ u → 0 Δ y Δ u \frac{dy}{du} = \lim_{\Delta u \to 0} \frac{\Delta y}{\Delta u} dudy=Δu0limΔuΔy d u d x = lim ⁡ Δ x → 0 Δ u Δ x \frac{du}{dx} = \lim_{\Delta x \to 0} \frac{\Delta u}{\Delta x} dxdu=Δx0limΔxΔu
    因此复合函数的导数可以表示为外层函数的导数乘以内层函数的导数。

可视化

  • g(x):定义了内层函数 sin ⁡ ( x ) \sin(x) sin(x)
  • f(u):定义了外层函数 exp ⁡ ( u ) \exp(u) exp(u)
  • g_prime(x) 和 f_prime(u):定义了对应的导数。
  • h(x):复合函数 e sin ⁡ ( x ) e^{\sin(x)} esin(x)
  • h_prime(x):复合函数的导数,使用链式法则 f ′ ( g ( x ) ) ⋅ g ′ ( x ) f'(g(x)) \cdot g'(x) f(g(x))g(x)

在这里插入图片描述

import numpy as np
import matplotlib.pyplot as plt
import matplotlib.animation as animation# 定义两个函数及其导数
def g(x):return np.sin(x)def f(u):return np.exp(u)def g_prime(x):return np.cos(x)def f_prime(u):return np.exp(u)# 复合函数及其导数
def h(x):return f(g(x))def h_prime(x):return f_prime(g(x)) * g_prime(x)# 生成x的值
x = np.linspace(0, 2 * np.pi, 400)
y_g = g(x)
y_f = f(y_g)
y_h = h(x)# 初始化图形
fig, (ax1, ax2, ax3) = plt.subplots(3, 1, figsize=(8, 12))# 绘制函数 g(x)
ax1.plot(x, y_g, label=r'$g(x) = \sin(x)$', color='blue')
ax1.set_title('Function $g(x)$')
ax1.set_xlabel('$x$')
ax1.set_ylabel('$g(x)$')
ax1.legend()# 绘制函数 f(u)
u = np.linspace(-1, 1, 400)
ax2.plot(u, f(u), label=r'$f(u) = e^{u}$', color='green')
ax2.set_title('Function $f(u)$')
ax2.set_xlabel('$u$')
ax2.set_ylabel('$f(u)$')
ax2.legend()# 绘制复合函数 h(x) = f(g(x))
ax3.plot(x, y_h, label=r'$h(x) = e^{\sin(x)}$', color='red')
ax3.set_title('Composite Function $h(x) = f(g(x))$')
ax3.set_xlabel('$x$')
ax3.set_ylabel('$h(x)$')
ax3.legend()plt.subplots_adjust(hspace=0.5)# 初始化点和切线
point1, = ax1.plot([], [], 'ro')  # 点
tangent_line1, = ax1.plot([], [], 'r--')  # 切线point2, = ax2.plot([], [], 'ro')  # 点
tangent_line2, = ax2.plot([], [], 'r--')  # 切线point3, = ax3.plot([], [], 'ro')  # 点
tangent_line3, = ax3.plot([], [], 'r--')  # 切线def init():point1.set_data([], [])tangent_line1.set_data([], [])point2.set_data([], [])tangent_line2.set_data([], [])point3.set_data([], [])tangent_line3.set_data([], [])return point1, tangent_line1, point2, tangent_line2, point3, tangent_line3def animate(i):x0 = i * 2 * np.pi / 100  # 从 0 开始,步长为 2π / 100y0_g = g(x0)y0_h = h(x0)# 绘制 g(x) 的点和切线slope_g = g_prime(x0)point1.set_data([x0], [y0_g])tangent_x1 = np.array([x0 - 0.5, x0 + 0.5])tangent_y1 = y0_g + slope_g * (tangent_x1 - x0)tangent_line1.set_data(tangent_x1, tangent_y1)# 绘制 f(g(x)) 的点和切线u0 = y0_gy0_f = f(u0)slope_f = f_prime(u0)point2.set_data([u0], [y0_f])tangent_x2 = np.array([u0 - 0.5, u0 + 0.5])tangent_y2 = y0_f + slope_f * (tangent_x2 - u0)tangent_line2.set_data(tangent_x2, tangent_y2)# 绘制 h(x) = f(g(x)) 的点和切线slope_h = h_prime(x0)point3.set_data([x0], [y0_h])tangent_x3 = np.array([x0 - 0.5, x0 + 0.5])tangent_y3 = y0_h + slope_h * (tangent_x3 - x0)tangent_line3.set_data(tangent_x3, tangent_y3)return point1, tangent_line1, point2, tangent_line2, point3, tangent_line3ani = animation.FuncAnimation(fig, animate, frames=100, init_func=init, blit=True)# 保存为gif
ani.save('chain_rule_animation.gif', writer='imagemagick')# 显示动画
plt.show()

相关文章:

计算神经网络中梯度的核心机制 - 反向传播(backpropagation)算法(1)

计算神经网络中梯度的核心机制 - 反向传播(backpropagation)算法(1) flyfish 链式法则在深度学习中的主要应用是在反向传播(backpropagation)算法中。 从简单的开始 ,文本说的就是链式法则 R …...

VUE实现简易购物车

主要是对基础的指令的使用&#xff0c;直接上代码&#xff1a; <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0">&l…...

混沌工程——从捣乱的视角看系统稳定性

概念 混沌工程是通过捣乱实验探究系统稳定性的实践过程&#xff0c;其作战武器是风险因子&#xff0c;即在健康的运行环境中引入风险变量来验证系统对风险的抵抗能力&#xff0c;它的作用是推动系统容错能力建设、验证监控告警及时性、提升研发问题排查能力。 混沌工程的工作…...

Windows宝塔面板部署ThinkPHP8.0创建Vue项目案例

安装ThinkPHP8.0 登录宝塔面板&#xff0c;创建一个站点。 输入composer代码&#xff0c;执行完成后自动创建TP目录 composer create-project topthink/think tp 网站目录设置为tp&#xff0c;运行目录设置为public 设置PHP版本为8.0以上&#xff0c;不然会出现下面的报错代…...

5G频段简介

5G频段 5G网络一共有29个频段&#xff0c;主要被分为两个频谱范围&#xff0c;其中6GHz以下的频段共有26个&#xff08;统称为Sub6GHz&#xff09;&#xff0c;毫米波频段有3个。目前国内主要使用的是Sub6GHz&#xff0c;包括n1/n3/n28/n41/n77/n78/n79共7个频段。具体介绍如下…...

【python学习】bytearray 数组

在Python中&#xff0c;bytearray 是一个可变序列&#xff0c;用于表示一个字节数组。与不可变的 bytes 类型相比&#xff0c;bytearray 允许你修改其内容。你可以通过索引来访问和修改 bytearray 中的元素&#xff0c;也可以添加或删除元素。 使用 bytearray 的一些示例&…...

Labview_Occurrencel(事件发生)

PS&#xff1a;这里遇到 一个很Low的事情&#xff1a; 在停止第二个while循环的时候出现了停止不了的情况。因为等待事件发生设置的超时时间为:-1。所以等事件发生后出现了条件接线端已经执行的情况&#xff0c;所以当下次事件发生时未能及时停止。初版的停止设置如下图&#x…...

天气网站爬虫及可视化

摘要&#xff1a;随着互联网的快速发展&#xff0c;人们对天气信息的需求也越来越高。本论文基于Python语言&#xff0c;设计并实现了一个天气网站爬虫及可视化系统。该系统通过网络爬虫技术从多个天气网站上获取实时的天气数据&#xff0c;并将数据进行清洗和存储。同时&#…...

【python - 数据】

一、序列 序列&#xff08;sequence&#xff09;是一组有顺序的值的集合&#xff0c;是计算机科学中的一个强大且基本的抽象概念。序列并不是特定内置类型或抽象数据表示的实例&#xff0c;而是一个包含不同类型数据间共享行为的集合。也就是说&#xff0c;序列有很多种类&…...

几种热管的构造

1、超薄热管构造形式 在实际应用中&#xff0c;超薄热管通常定义为厚度小于2.0mm的平板热管。超薄热管很薄&#xff0c;可紧贴电子元件表面散热&#xff0c;故被广泛应用于移动和可携带电子设备&#xff0c;如智能手机、笔记本电脑和智能手表。用于笔记本电脑和平板电脑的超薄…...

【GitOps】使用Google工具JIB实现本地无需安装容器推送镜像,加速SpringCloud项目开发

文章目录 一、效果展示二、简介三、安装Jib插件1、区分环境2、安装插件一、效果展示 本地是window系统,无docker环境,没有任何runtime,使用jib工具打包镜像并推送完成,用时20秒 二、简介 Jib 是 Google 开发的一款开源工具,旨在帮助 Java 开发者更高效地将 Java 应用程…...

【proteus经典实战】16X192点阵程序

一、简介 6X192点阵程序通常用于表示高分辨率图像或文字&#xff0c;其中16X表示像素阵列的宽度&#xff0c;192表示每个像素阵列中的点阵数&#xff0c;16X192点阵程序需要一定的编程知识和技能才能编写和调试&#xff0c;同时还需要考虑硬件设备的兼容性和性能等因素。 初始…...

小白上手AIGC-基于FC部署stable-diffusion

AIGC AIGC&#xff08;人工智能创造内容&#xff09;作为一种基于人工智能技术生成内容的新型创作模式。打破了过去大家对于AI的理解都是说只能涉足部分领域而无法涉足艺术或者是其他的创作领域的定律&#xff0c;现在的AIGC也能够创作内容了&#xff0c;而不再只是单纯的返回…...

一些指标的学习

1.平均倒数排名&#xff08;MRR&#xff09; 1.定义 MRR 是衡量检索系统返回的结果列表中第一个相关结果位置的指标。具体来说&#xff0c;它是所有查询倒数排名的平均值。 2.计算步骤 对每个查询&#xff0c;找到第一个正确答案在结果列表中的排名 &#x1d445;&#x1d44…...

dledger原理源码分析系列(三)-选主

简介 dledger是openmessaging的一个组件&#xff0c; raft算法实现&#xff0c;用于分布式日志&#xff0c;本系列分析dledger如何实现raft概念&#xff0c;以及dledger在rocketmq的应用 本系列使用dledger v0.40 本文分析dledger的选主 关键词 Raft Openmessaging 心跳/选…...

如何修改PDF文档的作者名称?

要修改一个 PDF 文档的作者名称&#xff0c;你可以按照以下步骤进行操作&#xff1a; 1. **使用 Adobe Acrobat**&#xff08;如果有&#xff09;&#xff1a; - Adobe Acrobat 是一个功能强大的 PDF 编辑工具&#xff0c;支持修改文档属性信息&#xff0c;包括作者名称。打开…...

从笔灵到AI去痕:全方位提升内容创作与学术诚信

内容为王&#xff0c;在内容创作的世界中尤为重要。然而&#xff0c;面对写作时常常感到无从下手&#xff1a;有时缺乏灵感&#xff0c;有时难以表达清楚自己的想法。AI写作助手的出现&#xff0c;为这些问题提供了创新的解决方案&#xff0c;极大地改变了内容创作的过程。 今…...

考试如果出现汉诺塔问题怎么办?

对于这道题来说 就按照测试案例里的数字进行输入 测试案例用100 那这三只鸡的具体最多能有多少只鸡呢&#xff1f; 用总数除以这只鸡的单价>>>>>>>即为这只鸡最多有 >>>>>>>> n / 单价 修改后 >>>>> 不只适…...

导出word模板开发记录

exportWordDocx.js import JSZipUtils from “jszip-utils” import Docxtemplater from “docxtemplater” import {saveAs} from “file-saver” import PizZip from “pizzip” const exportWordDocx (demoUrl, docxData, fileName) > {// 读取并获得模板文件的二进制…...

PHP爬虫类的并发与多线程处理技巧

PHP爬虫类的并发与多线程处理技巧 引言&#xff1a; 随着互联网的快速发展&#xff0c;大量的数据信息存储在各种网站上&#xff0c;获取这些数据已经成为很多业务场景下的需求。而爬虫作为一种自动化获取网络信息的工具&#xff0c;被广泛应用于数据采集、搜索引擎、舆情分析…...

R语言AI模型部署方案:精准离线运行详解

R语言AI模型部署方案:精准离线运行详解 一、项目概述 本文将构建一个完整的R语言AI部署解决方案,实现鸢尾花分类模型的训练、保存、离线部署和预测功能。核心特点: 100%离线运行能力自包含环境依赖生产级错误处理跨平台兼容性模型版本管理# 文件结构说明 Iris_AI_Deployme…...

页面渲染流程与性能优化

页面渲染流程与性能优化详解&#xff08;完整版&#xff09; 一、现代浏览器渲染流程&#xff08;详细说明&#xff09; 1. 构建DOM树 浏览器接收到HTML文档后&#xff0c;会逐步解析并构建DOM&#xff08;Document Object Model&#xff09;树。具体过程如下&#xff1a; (…...

uniapp微信小程序视频实时流+pc端预览方案

方案类型技术实现是否免费优点缺点适用场景延迟范围开发复杂度​WebSocket图片帧​定时拍照Base64传输✅ 完全免费无需服务器 纯前端实现高延迟高流量 帧率极低个人demo测试 超低频监控500ms-2s⭐⭐​RTMP推流​TRTC/即构SDK推流❌ 付费方案 &#xff08;部分有免费额度&#x…...

汇编常见指令

汇编常见指令 一、数据传送指令 指令功能示例说明MOV数据传送MOV EAX, 10将立即数 10 送入 EAXMOV [EBX], EAX将 EAX 值存入 EBX 指向的内存LEA加载有效地址LEA EAX, [EBX4]将 EBX4 的地址存入 EAX&#xff08;不访问内存&#xff09;XCHG交换数据XCHG EAX, EBX交换 EAX 和 EB…...

3-11单元格区域边界定位(End属性)学习笔记

返回一个Range 对象&#xff0c;只读。该对象代表包含源区域的区域上端下端左端右端的最后一个单元格。等同于按键 End 向上键(End(xlUp))、End向下键(End(xlDown))、End向左键(End(xlToLeft)End向右键(End(xlToRight)) 注意&#xff1a;它移动的位置必须是相连的有内容的单元格…...

永磁同步电机无速度算法--基于卡尔曼滤波器的滑模观测器

一、原理介绍 传统滑模观测器采用如下结构&#xff1a; 传统SMO中LPF会带来相位延迟和幅值衰减&#xff0c;并且需要额外的相位补偿。 采用扩展卡尔曼滤波器代替常用低通滤波器(LPF)&#xff0c;可以去除高次谐波&#xff0c;并且不用相位补偿就可以获得一个误差较小的转子位…...

怎么开发一个网络协议模块(C语言框架)之(六) ——通用对象池总结(核心)

+---------------------------+ | operEntryTbl[] | ← 操作对象池 (对象数组) +---------------------------+ | 0 | 1 | 2 | ... | N-1 | +---------------------------+↓ 初始化时全部加入 +------------------------+ +-------------------------+ | …...

大模型——基于Docker+DeepSeek+Dify :搭建企业级本地私有化知识库超详细教程

基于Docker+DeepSeek+Dify :搭建企业级本地私有化知识库超详细教程 下载安装Docker Docker官网:https://www.docker.com/ 自定义Docker安装路径 Docker默认安装在C盘,大小大概2.9G,做这行最忌讳的就是安装软件全装C盘,所以我调整了下安装路径。 新建安装目录:E:\MyS…...

PLC入门【4】基本指令2(SET RST)

04 基本指令2 PLC编程第四课基本指令(2) 1、运用上接课所学的基本指令完成个简单的实例编程。 2、学习SET--置位指令 3、RST--复位指令 打开软件(FX-TRN-BEG-C)&#xff0c;从 文件 - 主画面&#xff0c;“B: 让我们学习基本的”- “B-3.控制优先程序”。 点击“梯形图编辑”…...

el-amap-bezier-curve运用及线弧度设置

文章目录 简介示例线弧度属性主要弧度相关属性其他相关样式属性完整示例链接简介 ‌el-amap-bezier-curve 是 Vue-Amap 组件库中的一个组件,用于在 高德地图 上绘制贝塞尔曲线。‌ 基本用法属性path定义曲线的路径,可以是多个弧线段的组合。stroke-weight线条的宽度。stroke…...