【笔记】网络流基本概念

文章目录

      • 最大流相关概念
      • 最小割相关概念
      • 费用流相关概念


最大流相关概念

流网络:由一些点和有向边组成的可以有环的图,记作 G = ( V , E ) G=(\text V,\text E) G=(V,E),其中 V \text V V 是点集, E \text E E 是边集。定义 n = ∣ V ∣ , m = ∣ E ∣ n=|\text V|,m=|\text E| n=V,m=E,在本篇文章中使用。

源点:在一个流网络中,入度为 0 0 0 且能流出的流量为 ∞ \infty 的点。一般用斜体大写字母 S S S 表示。

汇点:在一个流网络中,出度为 0 0 0 且能流入的流量为 ∞ \infty 的点。一般用斜体大写字母 T T T 表示。

流网络里的每一条边都有一个属性,称为该边的 容量(该边每秒最多能流过的单位流量),一般用 c ( u , v ) c(u, v) c(u,v) 表示。 { u ∈ V , v ∈ V , ( u , v ) ∈ E } \{u\in \text V,v\in \text V,(u,v)\in \text E\} {uV,vV,(u,v)E}

注意

  1. 在讨论流网络时为了简化讨论,默认不存在反向边,因为就算存在反向边,我们也可以将反向边中间加上一个点,这样就从两个点之间的双向边变成了三个点之间的环。
  2. 如果有一条边不存在,我们就定义它的容量为 0 0 0

下图为一个流网络,存在源点 S S S 和汇点 T T T,每条边上都有对应的容量。

G1


可行流: 对于任意满足以下两个条件的流,被称为可行流,用字母 f f f 表示。 ∣ f ∣ |f| f 表示该可行流的流量。

  1. 容量限制。每条边流过的流量不能超过这条边的容量。即:

0 < f ( u , v ) ≤ c ( u , v ) { u ∈ V , v ∈ V , ( u , v ) ∈ E } 0<f(u,v)\leq c(u,v)\{u\in \text V,v\in \text V,(u,v)\in \text E\} 0<f(u,v)c(u,v){uV,vV,(u,v)E}

  1. 流量守恒。对于流网络中除源点和汇点外的每个点,都有流入的流量与流出的流量相等。即:

∀ x ∈ V / { S , T } , ∑ ( u , x ) ∈ E f ( u , x ) = ∑ ( x , v ) ∈ E f ( x , v ) \forall x\in \text V/\{S,T\},\sum_{(u,x)\in \text E}f(u,x)=\sum_{(x,v)\in \text E}f(x,v) xV/{S,T},(u,x)Ef(u,x)=(x,v)Ef(x,v)

最大流: 流网络中流量值最大的一个 可行流 被称为该流网络的 最大可行流,简称为最大流。

G2
这张图显示的是原图的最大流,值为 9 9 9

残量网络:对于任意一个流网络 G G G 中的任意一个可行流 f f f,都能对应一个残量网络,记作 G f G_f Gf

G f G_f Gf 的构造: V f = V , E f = E ∪ { ( v , u ) ∣ ∀ ( u , v ) ∈ E } \text V_f=\text V,\text E_f=\text E\cup \{(v,u)|\forall (u,v)\in \text E\} Vf=V,Ef=E{(v,u)∣∀(u,v)E}

{ c ′ ( u , v ) = c ( u , v ) − f ( u , v ) [ ( u , v ) ∈ E ] c ′ ( v , u ) = f ( u , v ) [ ( v , u ) ∈ E ] \left\{\begin{matrix} c'(u,v)=c(u,v)-f(u,v)[(u,v)\in \text E] \\ c'(v,u)=f(u,v)[(v,u)\in \text E] \end{matrix}\right. {c(u,v)=c(u,v)f(u,v)[(u,v)E]c(v,u)=f(u,v)[(v,u)E]

上图最大流对应的残量网络如下:

Gf
原网络 G G G 的可行流 f f f 与残量网络 G f G_f Gf 的可行流 f ′ f' f 的关系

  1. f + f ′ f+f' f+f 也是 G G G 的一个可行流。
  2. ∣ f + f ′ ∣ = ∣ f ∣ + ∣ f ′ ∣ |f+f'|=|f|+|f'| f+f=f+f

证明

首先定义一下两个可行流的相加。如果是两个同向边相加,则将容量累加,如果是反向边,就把残量网络里的流量在原网络里减去。

然后看可行流需要满足的两个条件。

首先看是否满足容量限制。对于同向边,由于 0 ≤ f ′ ( u , v ) ≤ c ′ ( u , v ) = c ( u , v ) − f ( u , v ) 0\leq f'(u,v)\leq c'(u,v)=c(u,v)-f(u,v) 0f(u,v)c(u,v)=c(u,v)f(u,v),因此同向边满足 0 ≤ f ( u , v ) + f ′ ( u , v ) ≤ c ( u , v ) 0\leq f(u,v)+f'(u,v)\leq c(u,v) 0f(u,v)+f(u,v)c(u,v)

对于反向边,由于 0 ≤ f ′ ( u , v ) ≤ c ′ ( u , v ) = f ( v , u ) ≤ c ( v , u ) 0\leq f'(u,v)\leq c'(u,v)=f(v,u)\leq c(v,u) 0f(u,v)c(u,v)=f(v,u)c(v,u),因此反向边满足 0 ≤ f ( v , u ) − f ′ ( u , v ) ≤ c ( v , u ) 0\leq f(v,u)-f'(u,v)\leq c(v,u) 0f(v,u)f(u,v)c(v,u)

综上可知,两个可行流相加是满足容量限制的。

对于是否满足流量守恒,这不需要证明,由于原网络满足流量守恒,残量网络也满足流量守恒,那么对于同向边,流入的累加流入的,流出的累加流出的,满足流量守恒,而反向边只不过是相互抵消了一部分的流量,同样满足流量守恒。

由此得出,原网络的任意一个可行流加上残量网络的任意一个可行流所得到的流都是原网络的一个可行流。

对于计算得到的新流的流量值,因为流量值是可行流净往外流出的流量,因此新流的净往外流出的流量 = 原网络的可行流净往外流出的流量 + 残量网络的可行流净往外流出的流量

作用

通过以上特性,任何一个在残量网络里面发现的流量 >0 的可行流,都能用来增加原网络的可行流。

同时得到一个推论,如果残量网络中存在任何一个流量 >0 的可行流,那么原网络里的可行流就一定不是最大的可行流。

对于最大流来说反过来也是正确的,即如果残量网络中不存在任何一个流量 >0 的可行流,那么原网络里的可行流就一定是最大的可行流。这个反命题可以通过下文的 最大流最小割定理 得出。

增广路径: 在残量网络中从源点出发,沿着容量 >0 的边,存在一条路径能走到汇点,这条路径被称为 增广路径

注意: 增广路径一般指没有环的简单路径。


最小割相关概念

: 对于流网络 G = ( V , E ) G=(V,E) G=(V,E),将点集 V \text V V 分成两个子集 S , T \text S,\text T S,T(子集中的节点不需要连通),保证 S ∪ T = V , S ∩ T = ∅ \text S\cup \text T=\text V,\text S\cap \text T=\varnothing ST=V,ST=,且 S ∈ S , T ∈ T S \in \text S,T \in \text T SS,TT,像这样的一种将点集划分的结果,就称为割。

割的容量: 所有从 S \text S S 指向 T \text T T 的边的容量之和,即:

c ( S , T ) = ∑ u ∈ S ∑ v ∈ T c ( u , v ) c(\text S,\text T)=\sum_{u\in \text S}\sum_{v \in \text T}c(u,v) c(S,T)=uSvTc(u,v)

最小割:从流网络中割的所有划分方案中找出割的容量的最小值,被称为该流网络的最小割,又叫最小割的容量 n n n 个点的流网络中存在 2 n − 2 2^{n-2} 2n2 种割的划分方案。

割的流量:流网络中所有从 S \text S S 流到 T \text T T 的流量,减去所有从 T \text T T 流到 S \text S S 的流量。即:

f ( S , T ) = ∑ u ∈ S ∑ v ∈ T f ( u , v ) − ∑ u ∈ T ∑ v ∈ S f ( u , v ) f(\text S,\text T)=\sum_{u\in \text S}\sum_{v \in \text T}f(u,v)-\sum_{u\in \text T}\sum_{v \in \text S}f(u,v) f(S,T)=uSvTf(u,v)uTvSf(u,v)

  • 性质 1 1 1:对于 ∀ [ S , T ] , ∀ f \forall[\text S,\text T],\forall f [S,T],f,都有 f ( S , T ) ≤ c ( S , T ) f(\text S,\text T)\leq c(\text S,\text T) f(S,T)c(S,T)
  • 证明 1 1 1
    ∵ f ( S , T ) = ∑ u ∈ S ∑ v ∈ T f ( u , v ) − ∑ u ∈ T ∑ v ∈ S f ( u , v ) \because f(\text S,\text T)=\sum_{u\in \text S}\sum_{v \in \text T}f(u,v)-\sum_{u\in \text T}\sum_{v \in \text S}f(u,v) f(S,T)=uSvTf(u,v)uTvSf(u,v)

    ∑ u ∈ T ∑ v ∈ S f ( u , v ) ≥ 0 \sum_{u\in \text T}\sum_{v \in \text S}f(u,v)\ge0 uTvSf(u,v)0

∴ f ( S , T ) ≤ ∑ u ∈ S ∑ v ∈ T f ( u , v ) ≤ ∑ u ∈ S ∑ v ∈ T c ( u , v ) = c ( S , T ) \therefore f(\text S,\text T)\le \sum_{u\in \text S}\sum_{v \in \text T}f(u,v) \le \sum_{u\in \text S}\sum_{v \in \text T}c(u,v)=c(\text S,\text T) f(S,T)uSvTf(u,v)uSvTc(u,v)=c(S,T)

命题得证。

  • 性质 2 2 2:对于 ∀ [ S , T ] , ∀ f \forall[\text S,\text T],\forall f [S,T],f,都有 f ( S , T ) = ∣ f ∣ f(\text S,\text T)=|f| f(S,T)=f

  • 证明 2 2 2
    ∵ f ( S , V ) = f ( S , S ) + f ( S , T ) \because f(\text S,\text V)=f(\text S,\text S)+f(\text S,\text T) f(S,V)=f(S,S)+f(S,T)
    f ( S , S ) = 0 f(\text S,\text S)=0 f(S,S)=0
    ∴ f ( S , T ) = f ( S , V ) = f ( { S } , V ) + f ( S − { S } , V ) \therefore f(\text S,\text T)=f(\text S,\text V)=f(\{S\},\text V)+f(\text S−\{S\},\text V) f(S,T)=f(S,V)=f({S},V)+f(S{S},V)

f ( S − { S } , V ) f(\text S−\{S\},\text V) f(S{S},V) S − { S } \text S−\{S\} S{S} 不包含 S , T S,T S,T,由于 f ( S − { S } , V ) f(\text S−\{S\},\text V) f(S{S},V) = 出去的流量 - 回来的流量,在不包含源点和汇点的前提下,其他点的流量的流出和流入都是固定的,流出多少就流回来多少,所以 f ( S − { S } , V ) = 0 f(\text S−\{S\},\text V)=0 f(S{S},V)=0。因此 f ( S , T ) = f ( { S } , V ) = ∣ f ∣ f(\text S,\text T)=f(\{S\},\text V)=|f| f(S,T)=f({S},V)=f

  • 性质 3 3 3 f ( X , Y ) = − f ( Y , X ) f(\text X,\text Y)=-f(\text Y,\text X) f(X,Y)=f(Y,X)
  • 证明 3 3 3
    f ( X , Y ) = ∑ u ∈ X ∑ v ∈ Y f ( u , v ) − ∑ u ∈ X ∑ v ∈ Y f ( v , u ) f(\text X,\text Y)=\sum_{u\in \text X}\sum_{v\in \text Y}f(u,v)-\sum_{u\in \text X}\sum_{v\in \text Y}f(v,u) f(X,Y)=uXvYf(u,v)uXvYf(v,u)

f ( X , Y ) = − { ∑ u ∈ X ∑ v ∈ Y f ( v , u ) − ∑ u ∈ X ∑ v ∈ Y f ( u , v ) } f(\text X,\text Y)=-\left\{\sum_{u\in \text X}\sum_{v\in \text Y}f(v,u)-\sum_{u\in \text X}\sum_{v\in \text Y}f(u,v)\right\} f(X,Y)={uXvYf(v,u)uXvYf(u,v)}

∴ f ( X , Y ) = − f ( Y , X ) \therefore f(\text X,\text Y)=-f(\text Y,\text X) f(X,Y)=f(Y,X)

  • 性质 4 4 4 f ( Z , X ∪ Y ) = f ( Z , X ) + f ( Z , Y ) f(\text Z,\text X\cup\text Y)=f(\text Z,\text X)+f(\text Z,\text Y) f(Z,XY)=f(Z,X)+f(Z,Y)

  • 证明 4 4 4

f ( Z , X ∪ Y ) = { ∑ u ∈ Z ∑ v ∈ X f ( u , v ) + ∑ u ∈ Z ∑ v ∈ Y f ( u , v ) } − { ∑ u ∈ Z ∑ v ∈ X f ( v , u ) + ∑ u ∈ Z ∑ v ∈ Y f ( v , u ) } f(\text Z,\text X\cup\text Y)=\left\{\sum_{u\in \text Z}\sum_{v\in \text X}f(u,v)+\sum_{u\in \text Z}\sum_{v\in \text Y}f(u,v)\right\}−\left\{\sum_{u\in \text Z}\sum_{v\in \text X}f(v,u)+\sum_{u\in \text Z}\sum_{v\in \text Y}f(v,u)\right\} f(Z,XY)={uZvXf(u,v)+uZvYf(u,v)}{uZvXf(v,u)+uZvYf(v,u)}

∴ f ( Z , X ∪ Y ) = f ( Z , X ) + f ( Z , Y ) \therefore f(\text Z,\text X\cup\text Y)=f(\text Z,\text X)+f(\text Z,\text Y) f(Z,XY)=f(Z,X)+f(Z,Y)

  • 性质 5 5 5 f ( X , X ) = 0 f(\text X,\text X)=0 f(X,X)=0
  • 证明 5 5 5

f ( X , X ) = ∑ u ∈ X ∑ v ∈ X f ( u , v ) − ∑ u ∈ X ∑ v ∈ X f ( v , u ) = 0 f(\text X,\text X)=\sum_{u\in \text X}\sum_{v\in \text X}f(u,v)−\sum_{u\in \text X}\sum_{v\in \text X}f(v,u)=0 f(X,X)=uXvXf(u,v)uXvXf(v,u)=0

  • 推论: 通过 性质 1性质 2 可知,对于 ∀ [ S , T ] , ∀ f \forall[\text S,\text T],\forall f [S,T],f,都有 ∣ f ∣ ≤ c ( S , T ) |f|\leq c(\text S,\text T) fc(S,T),所以就有 最大流 ≤ \leq 最小割(对于证明最大流最小割定理有重要作用)

最大流最小割定理

对于任意一个流网络 G = ( V , E ) G=(V,E) G=(V,E) 都满足:

  1. 可行流 f f f 是最大流。

⇔ \Leftrightarrow

  1. 可行流 f f f 的残量网络中不存在增广路。

⇔ \Leftrightarrow

  1. ∃ [ S , T ] , ∣ f ∣ = c ( S , T ) \exist [\text S,\text T],|f|=c(\text S,\text T) [S,T],f=c(S,T)

证明

  • 1 ⇒ 2 1\Rightarrow 2 12:反证法。假设 f f f 是最大流,且 G f G_f Gf 存在增广路径。这说明 G f G_f Gf 存在至少一个流量大于 0 0 0 的可行流 f ′ f' f。这样能构造出原网络中另一个可行流 f + f ′ f+f' f+f,且 ∣ f + f ′ ∣ > ∣ f ∣ |f+f'|>|f| f+f>f,说明 f f f 不是最大流,与假设矛盾。
  • 2 ⇒ 3 2\Rightarrow 3 23:构造一个割,使得它在残量网络中不存在增广路径,且 ∣ f ∣ = c ( S , T ) |f|=c(\text S,\text T) f=c(S,T)。定义集合 S \text S S 为在 G f G_f Gf 中从 S S S 出发,沿容量大于 0 0 0 的边走能走到的所有的点。由于残量网络中不存在增广路径,所以集合 S \text S S 中不可能包含 T T T。在定义集合 T = V − S \text T = \text V - \text S T=VS,即为构造的合法割。对于正向边 ( u , v ) [ u ∈ S , v ∈ T ] (u,v)[u\in \text S,v\in \text T] (u,v)[uS,vT],由于 u , v u,v u,v 不相通,所以 f ′ ( u , v ) = 0 f'(u, v)=0 f(u,v)=0,所以 f ( u , v ) = c ( u , v ) f(u,v)=c(u,v) f(u,v)=c(u,v)。对于反向边 ( u , v ) [ u ∈ T , v ∈ S ] (u,v)[u\in \text T,v\in \text S] (u,v)[uT,vS] 同理, c ′ ( v , u ) = 0 c'(v,u)=0 c(v,u)=0,即 f ( u , v ) = 0 f(u,v)=0 f(u,v)=0。发现原网络中 ∀ ( u , v ) ( u ∈ S , v ∈ T ) \forall (u,v)(u\in\text S,v\in\text T) (u,v)(uS,vT),都有 f ( u , v ) = c ( u , v ) , f ( v , u ) = 0 f(u,v)=c(u,v),f(v,u)=0 f(u,v)=c(u,v),f(v,u)=0。因此 ∣ f ∣ = f ( S , T ) = ∑ u ∈ S ∑ v ∈ T f ( u , v ) − ∑ u ∈ S ∑ v ∈ T f ( v , u ) = ∑ u ∈ S ∑ v ∈ T f ( u , v ) = ∑ u ∈ S ∑ v ∈ T c ( u , v ) = c ( S , T ) |f|=f(\text S,\text T)=\sum_{u\in\text S}\sum_{v\in\text T}f(u,v)-\sum_{u\in\text S}\sum_{v\in\text T}f(v,u)=\sum_{u\in\text S}\sum_{v\in\text T}f(u,v)=\sum_{u\in\text S}\sum_{v\in\text T}c(u,v)=c(\text S,\text T) f=f(S,T)=uSvTf(u,v)uSvTf(v,u)=uSvTf(u,v)=uSvTc(u,v)=c(S,T)
  • 3 ⇒ 1 3\Rightarrow 1 31:由上文最小割的推论中已知 ∣ f ∣ ≤ c ( S , T ) |f|≤c(\text S,\text T) fc(S,T),且最大流是可行流的一种,所以最大流 ≤ c ( S , T ) \leq c(\text S,\text T) c(S,T)。易知 ∣ f ∣ ≤ |f|\leq f 最大流,而 ∣ f ∣ = c ( S , T ) ≥ |f|=c(\text S,\text T)\geq f=c(S,T) 最大流。即 ∣ f ∣ ≥ |f|\geq f 最大流。综上得出 ∣ f ∣ = |f|= f= 最大流。已证最大流 ≤ \leq 最小割,而最小割又是割的容量的最小值,得出最小割 ≤ c ( S , T ) = ∣ f ∣ ≤ \leq c(\text S,\text T)=|f|\leq c(S,T)=f 最大流,即最小割 ≤ \leq 最大流,最终得出最大流 = 最小割。

费用流相关概念

费用:对于任意一个可行流 f f f,每条边 ( u , v ) (u,v) (u,v) 都有流量 f ( u , v ) f(u,v) f(u,v) 和费用 w ( u , v ) w(u,v) w(u,v),该可行流的费用为 ∑ f ( u , v ) × w ( u , v ) \sum f(u,v)\times w(u,v) f(u,v)×w(u,v)

最大费用流: 所有最大可行流中费用最大的流称为最大费用最大流。

最小费用流: 所有最大可行流中费用最小的流称为最小费用最大流。

注意: 一张图 G G G 有最大流,那么就一定有最小费用最大流,但是存在一些特殊的图,图中存在一个从源点无法到达的闭环,闭环中的费用是负的,这时最小费用流可能比我们求出来的更小,因此我们求费用流的做法存在局限性,并不一定能求出最小费用最大流。

如何求最小费用最大流

最小费用最大流是基于 EK 算法来求的,只需要把 EK 算法中找增广路径的 BFS 算法换成找最短路的 SPFA 算法就可以求最小费用最大流了。

之前我们定义残量网络中反向边的流量等于正向边的容量,表示一个退流的概念,因此我们还需要定义一下反向边的费用,我们希望在退流的同时将费用也退掉,因此可以定义反向边的费用等于负的正向边的费用。

注意: 由于 SPFA 算法遇到负权回路会进入死循环,所以我们常规的求最小费用最大流的算法并不能处理有负权回路的网络。如果网络中存在负权回路,就需要用消圈法来做。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/288449.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQL Server 安装教程

安装数据库 1、启动SQL Server2014安装程序&#xff0c;运行setup.exe文件&#xff0c;打开”SQL Server安装中心“对话框&#xff0c;单击左侧 的导航区域中的”安装“选项卡。 2、选择”全新SQL Server独立安装或向现有安装添加功能“&#xff0c;启动SQL Server2014安装向导…

Python新手常犯的8个错误,你中招了吗?

我们都知道Python是一门非常流行和强大的编程语言&#xff0c;而作为一个刚入门Python编程的新手&#xff0c;你可能会犯一些常见的错误&#xff0c;这些错误可能会阻碍你的学习和项目进展。 如何避免这些常见的错误呢&#xff1f;在本文中&#xff0c;小狮妹将为你介绍8个新手…

XXE漏洞 [NCTF2019]Fake XML cookbook1

打开题目 查看源代码 发现我们post传入的数据都被放到了doLogin.php下面 访问一下看看 提示加载外部xml实体 我们知道外部xml实体的格式是 <!ENTITY 实体名称 SYSTEM "URI/URL"> bp抓包一下看看 得到flag 或者这样 但是很明显这样是不行的&#xff0c;因为…

Ubuntu18.04 上通过 jihu 镜像完成 ESP-IDF 编译环境搭建流程

为了解决国内开发者从 github 克隆 esp 相关仓库慢的问题&#xff0c;已将 esp-idf 和部分重要仓库及其关联的子模块镜像到了 jihu&#xff0c;这些仓库将自动从原始仓库进行同步。此篇博客用来阐述 Ubuntu18.04 上通过 jihu 镜像完成 ESP-IDF 编译环境搭建流程。 注&#xff1…

年底事情繁杂,快利用项目管理工具,提升团队协作效率!

一晃眼&#xff0c;又是年底了&#xff0c;临近年关&#xff0c;季度报告、年终总结、新一年的计划与预算等&#xff0c;估计会让职场团队忙到飞起&#xff0c;恨不得一天变成25小时。 同时岁末年终时&#xff0c;往往是职场人工作的高压期、心态的疲惫期&#xff0c;又经常被…

【经典LeetCode算法题目专栏分类】【第7期】快慢指针与链表

《博主简介》 小伙伴们好&#xff0c;我是阿旭。专注于人工智能AI、python、计算机视觉相关分享研究。 ✌更多学习资源&#xff0c;可关注公-仲-hao:【阿旭算法与机器学习】&#xff0c;共同学习交流~ &#x1f44d;感谢小伙伴们点赞、关注&#xff01; 快慢指针 移动零 class…

JNI逆向

IDA&#xff1a;JNI类型转换 1.IDA高版本&#xff08;IDA 高版本内置了定义的JNI结构体; 如果没有的话&#xff0c;在Views->Open subviews -> Type Libraries 中添加Android ARM的lib即可&#xff09; 解决方法: 只需要对JNIEnv 指针&#xff08;JNIEnv * &#xff09…

Python安装及配置

一、前置说明 Python的安装有两种方式&#xff1a;1. 访问Python官方网站下载安装&#xff1b;2. 使用Python的开源发行版进行安装。 Anaconda 是一个用于科学计算、数据分析和机器学习的开源发行版&#xff0c;它包含了许多常用的科学计算和数据分析库。Anaconda 不仅仅是 P…

vscode颜色主题插件one dark Pro安装

1.点击扩展图标→搜索“one dark Pro”→第一个点击安装 2.安装成功后&#xff0c;不要忘了点击设置颜色主题 3.看下效果&#xff1a;

【Spark-ML源码解析】Word2Vec

前言 在阅读源码之前&#xff0c;需要了解Spark机器学习Pipline的概念。 相关阅读&#xff1a;SparkMLlib之Pipeline介绍及其应用 这里比较核心的两个概念是&#xff1a;Transformer和Estimator。 Transformer包括特征转换和学习后的模型两种情况&#xff0c;用来将一个DataFr…

drf知识--02

APIView执行流程分析 源码分析&#xff1a; # 1 在路由中&#xff1a;path(books/, views.BookView.as_view()),请求来了 # 2 先看 as_view()---->APIView的 as_view---》as_view执行结果跟之前一样&#xff0c;去除了csrf认证classmethoddef as_view(cls, **initkwargs):vi…

弧形导轨的类型及应用

弧形导轨又叫圆弧形导轨&#xff0c;滚轮弧形导轨&#xff0c;是通过V型滚轮在圆弧形V型导轨面上的滚动&#xff0c;实现圆周运动&#xff1b;在工业自动化中&#xff0c;有些应用需要弧线运动&#xff0c;或者两个相交或平行的直线运动&#xff0c;这些情况需要通过弧线运动连…