多智能体一致性(Consensus)中的矩阵理论(Matrix Theory)

2023-05-16

文章目录

  • 写在前面
  • 一致性算法
    • 连续时间
    • 离散时间
  • 一致性证明
    • 连续时间
    • 离散时间
  • 矩阵理论
    • 特征值和特征向量
    • 特征多项式
    • 代数重数
    • 几何重数
  • 总结

写在前面

最近在看一些分布式优化的文章,但是大部分文章都是用的离散时间算法。我之前一直研究的是连续时间一致性(consensus)控制问题,现在想把离散时间控制拾起来。

这篇文章前半部分讲解连续和离散系统的一致性算法,互相做个对比,加深一下印象和理解;后半部分回顾在算法证明中会用到的矩阵理论的基本知识。

下面进入文艺复兴环节,让我们回顾一下最经典的一致性算法和矩阵理论的基本知识吧。

一致性算法

考虑状态 x i ∈ R m x_i\in\mathbb R^m xiRm,图 G = ( V , E ) \mathcal G=(\mathcal V,\mathcal E) G=(V,E)和单积分器系统
x ˙ i = u i , i ∈ V . \dot x_i=u_i,\quad i\in\mathcal V. x˙i=ui,iV.

连续时间

首先,给出连续时间一致性算法:
x ˙ i = − ∑ j ∈ N i a i j ( x i − x j ) , i ∈ V , \dot x_i=-\sum_{j\in\mathcal N_i}a_{ij}(x_i-x_j),\quad i\in\mathcal V, x˙i=jNiaij(xixj),iV,
写成矩阵形式为
x ˙ = − ( L ⊗ I m ) x , \dot x=-(L\otimes I_m)x, x˙=(LIm)x,
其中 A = [ a i j ] ∈ R n × n A=[a_{ij}]\in\mathbb R^{n\times n} A=[aij]Rn×n邻接矩阵(adjacency matrix),如果 ( j , i ) ∈ E (j,i)\in\mathcal E (j,i)E,那么 a i j > 0 a_{ij}>0 aij>0,否则 a i j = 0 a_{ij}=0 aij=0 L = [ l i j ] ∈ R n × n L=[l_{ij}]\in\mathbb R^{n\times n} L=[lij]Rn×n拉普拉斯矩阵(Laplacian matrix),满足
l i i = ∑ j = 1 , j ≠ i n a i j , l i j = − a i j ,   i ≠ j 。 l_{ii}=\sum_{j=1,j\neq i}^n a_{ij},\qquad l_{ij}=-a_{ij},\,i\neq j。 lii=j=1,j=inaij,lij=aij,i=j

离散时间

然后,给出离散时间一致性算法:
x i , k + 1 = ∑ j ∈ N i d i j x i , k , i ∈ V , x_{i,k+1}=\sum_{j\in\mathcal N_i}d_{ij}x_{i,k},\quad i\in\mathcal V, xi,k+1=jNidijxi,k,iV,
写成矩阵形式为
x k + 1 = ( D ⊗ I m ) x k , x_{k+1}=(D\otimes I_m)x_{k}, xk+1=(DIm)xk,
其中 k ∈ N k\in N kN离散时间指数(discrete-time index); D = [ d i j ] ∈ R n × n D=[d_{ij}]\in\mathbb R^{n\times n} D=[dij]Rn×n行随机矩阵(row-stochastic matrix),满足 d i i > 0 d_{ii}> 0 dii>0对所有 i ∈ V i\in\mathcal V iV成立,如果 ( j , i ) ∈ E (j,i)\in\mathcal E (j,i)E,那么 d i j > 0 d_{ij}>0 dij>0,否则 d i j = 0 d_{ij}=0 dij=0

Vicsek模型1是离散时间一致性算法的特例,该模型中如果 ( j , i ) ∈ E (j,i)\in\mathcal E (j,i)E,那么令 d i j = 1 1 + ∣ N i ∣ d_{ij}=\frac{1}{1+|\mathcal N_i|} dij=1+Ni1 ∣ N i ∣ |\mathcal N_i| Ni表示智能体 i i i邻居(neighbor)个数。但是Vicsek模型不一定能保证为双随机矩阵(doubly-stochastic matrix)。已知 L L L的情况下,令 D = e − L D=e^{-L} D=eL虽然可以得到双随机矩阵,但是无法保证分布式实现。

想要得到满足前面条件的双随机矩阵,一种简单的办法是:如果 ( j , i ) ∈ E (j,i)\in\mathcal E (j,i)E,那么令 d i j = 1 / g d_{ij}=1/g dij=1/g d i i = 1 − ∑ j ≠ i d i j d_{ii}=1-\sum_{j\neq i} d_{ij} dii=1j=idij,其中 g > n g>n g>n

一致性证明

无论对于连续时间或是离散时间系统,状态 x x x都可以写成关于 t t t k k k的函数,即
x ( t ) = ( e − L t ⊗ I m ) x ( 0 ) , x(t)=(e^{-Lt}\otimes I_m)x(0), x(t)=(eLtIm)x(0)
或者
x k = ( D k ⊗ I m ) x 0 。 x_k=(D^k\otimes I_m)x_0。 xk=(DkIm)x0
下面需要一致集 S = { x ∈ R n m ∣ x 1 = ⋯ = x n } \mathcal S=\{x\in\mathbb R^{nm}| x_1=\cdots=x_n \} S={xRnmx1==xn}吸引(attractive)的正不变(positive invariant)集,即满足
lim ⁡ t → ∞ e − L t = lim ⁡ k → ∞ D k = 1 n c T , \lim_{t\to\infty} e^{-Lt}=\lim_{k\to\infty}D^k=1_nc^T, tlimeLt=klimDk=1ncT
才有 lim ⁡ t → ∞ x ( t ) = lim ⁡ k → ∞ x k = ( 1 n c T ⊗ I m ) x ( 0 ) \lim_{t\to\infty} x(t)=\lim_{k\to\infty} x_k=(1_nc^T\otimes I_m)x(0) limtx(t)=limkxk=(1ncTIm)x(0)

连续时间

定理1 (Lemma 2.6 2):拉普拉斯矩阵 L ∈ R n × n L\in\mathbb R^{n\times n} LRn×n对应的 e − L t , ∀ t ≥ 0 e^{-Lt}, \forall t\geq 0 eLt,t0是主对角元大于0的行随机矩阵。另外, Rank ⁡ ( L ) = n − 1 \operatorname{Rank}(L)=n-1 Rank(L)=n1当且仅当 L L L有单个0特征根。此外,若 L L L有单个0特征根,且 L T L^T LT关于0特征根的标准化特征向量为 c c c,即
1 n T c = 1 , L T c = 0 , 1_n^Tc = 1,\quad L^Tc = 0, 1nTc=1,LTc=0,
那么 e − L t → 1 n c T e^{-Lt}\to 1_nc^T eLt1ncT,当 t → ∞ t\to \infty t

证明:由于 L L L是方阵,将 − L -L L特征分解(谱分解)得到 − L = P J P − 1 -L=PJP^{-1} L=PJP1,其中 P = [ p 1 , ⋯   , p n ] ∈ R n × n P=[p_1,\cdots,p_n]\in\mathbb R^{n\times n} P=[p1,,pn]Rn×n J = diag ⁡ ( 0 , − λ 2 , ⋯   , − λ n ) J=\operatorname{diag}(0,-\lambda_2,\cdots,-\lambda_n) J=diag(0,λ2,,λn)。不失一般性,我们令 p 1 = 1 n p_1=1_n p1=1n对应0特征根,而 λ 2 , ⋯   , λ n \lambda_2,\cdots,\lambda_n λ2,,λn都大于0。

由矩阵指数的性质3,易知 e − L t = P e J t P − 1 e^{-Lt}=Pe^{Jt}P^{-1} eLt=PeJtP1。故 e − L t e^{-Lt} eLt有特征根1对应特征向量 1 n 1_n 1n,即 e − L t 1 n = 1 n e^{-Lt}1_n=1_n eLt1n=1n,因此是行随机矩阵。此外,可以看出 e J t → diag ⁡ ( 1 , 0 , ⋯   , 0 ) e^{Jt}\to \operatorname{diag}(1,0,\cdots,0) eJtdiag(1,0,,0),当 t → ∞ t\to\infty t,即
P e J t P − 1 → [ 1 n p 2 ⋯ p n ] [ 1 0 ⋯ 0 0 0 ⋯ 0 ⋮ ⋮ ⋱ ⋮ 0 0 ⋯ 0 ] [ c T ν 2 T ⋮ ν n T ] , Pe^{Jt}P^{-1}\to\begin{bmatrix}1_n &p_2&\cdots&p_n\end{bmatrix}\begin{bmatrix}1&0&\cdots &0\\ 0&0&\cdots&0\\ \vdots&\vdots&\ddots&\vdots\\ 0&0&\cdots&0\\ \end{bmatrix}\begin{bmatrix}c^T\\\nu_2^T\\\vdots\\ \nu_n^T \end{bmatrix}, PeJtP1[1np2pn]100000000cTν2TνnT,
t → ∞ t\to\infty t。故 e − L t → 1 n c T e^{-Lt}\to 1_nc^T eLt1ncT,当 t → ∞ t\to\infty t,又因为 e − L t e^{-Lt} eLt行随机,即 e − L t 1 n = 1 n ( c T 1 n ) = 1 n e^{-Lt}1_n=1_n(c^T1_n)=1_n eLt1n=1n(cT1n)=1n,故 1 n T c = 1 1_n^Tc=1 1nTc=1

引理1 (Lemma C.2):给定矩阵 A ∈ R n × n A\in\mathbb R^{n\times n} ARn×n和特征根 λ ∈ C \lambda \in\mathbb C λC,假设 x , y x,y x,y满足(i) A x = λ x Ax=\lambda x Ax=λx,(ii) A T y = λ y A^Ty=\lambda y ATy=λy,(iii) x T y = 1 x^Ty =1 xTy=1。如果 ∣ λ ∣ = ρ ( A ) > 0 |\lambda|=\rho(A)>0 λ=ρ(A)>0,其中 ρ ( A ) \rho(A) ρ(A) A A A的谱半径,且 λ \lambda λ是唯一具有最大模数(maximum modulus)的特征根,那么 lim ⁡ m → ∞ ( λ − 1 A ) m → x y T \lim_{m\to\infty}(\lambda^{-1}A)^m\to xy^T limm(λ1A)mxyT

A ∈ R n × n A\in\mathbb R^{n\times n} ARn×n可约矩阵(reducible),即要么为全0矩阵,要么存在置换矩阵 P ∈ R n × n P\in\mathbb R^{n\times n} PRn×n使得 P T A P P^TAP PTAP分块上三角阵(block upper triangular form)。 A ∈ R n × n A\in\mathbb R^{n\times n} ARn×n非负矩阵(nonnegative),即所有元素都大于等于0。

命题1 (Lemma C.3):方阵 A ∈ R n × n A\in\mathbb R^{n\times n} ARn×n是不可约的当且仅当与矩阵 A A A对应的有向图 Γ ( A ) \Gamma(A) Γ(A)是强连通的

引理2 (Lemma C.4):如果 A ∈ R n × n A\in\mathbb R^{n\times n} ARn×n是非负的不可约(irreducible)矩阵,那么 ρ ( A ) \rho(A) ρ(A) A A A的一个特征根,且存在一个非0特征向量 x ≥ 0 x\geq 0 x0(即非负)使得 A x = ρ ( A ) x Ax=\rho(A)x Ax=ρ(A)x

接下来需要证明 c ≥ 0 c\geq 0 c0 c c c L L L关于0的左特征向量,即 L T c = 0 L^T c=0 LTc=0。由引理1和引理3可得, c c c ( e − L ) T (e^{-L})^T (eL)T的关于1的特征向量,再由下章的定理1.1, c c c L T L^T LT关于0的特征向量。由引理2可知, c ≥ 0 c\geq 0 c0 L L L是不可约矩阵可由强连通性保证,下面的引理3证明 L L L的单个0特征根性质。

一般来说, L L L至少一个0特征根,而圆盘定理(Gershgorin’s disc theorem)只能确保 L L L的根都位于右半平面或虚轴上,但无法保证0特征根只有一个。事实上,当图 G \mathcal G G不连通时,可能有多个0特征根,且0特征根的个数等于图的连通分量个数。

引理3 (Lemma 2.4):给定矩阵 A ∈ R n × n A\in\mathbb R^{n\times n} ARn×n,其中 a i i ≤ 0 a_{ii}\leq 0 aii0 a i j ≥ 0 a_{ij}\geq 0 aij0 ∀ i ≠ j \forall i\neq j i=j,且 ∑ j = 1 n a i j = 0 \sum_{j=1}^n a_{ij}=0 j=1naij=0对任意 i i i成立,那么 A A A有至少一个0特征根和相关的特征向量 1 n 1_n 1n,其他非0特征根都位于右半开平面。此外, A A A有唯一的0特征根,当且仅当 A A A对应的有向图 Γ ( A ) \Gamma(A) Γ(A)有一个有向生成树(directed spanning tree)。

离散时间

引理4 (Lemma 2.16):如果一个非负矩阵 A = [ a i j ] ∈ R n A=[a_{ij}]\in\mathbb R^n A=[aij]Rn满足 ∑ j = 1 n d i j = μ > 0 \sum_{j=1}^nd_{ij}=\mu>0 j=1ndij=μ>0,那么 μ \mu μ A A A关于特征向量 1 n 1_n 1n的一个特征根,且 ρ ( A ) = μ \rho(A)=\mu ρ(A)=μ,其中 ρ ( ⋅ ) \rho(\cdot) ρ()表示谱半径。另外,特征根 μ \mu μ代数重数(algebraic multiplicity)为1,当且仅当 A A A对应的有向图 Γ ( A ) \Gamma(A) Γ(A)有一个有向生成树。此外,如果 d i i > 0 , i = 1 , ⋯   , n d_{ii}>0,i=1,\cdots,n dii>0,i=1,,n,(i) 那么 ∣ λ ∣ < μ |\lambda|<\mu λ<μ对任意 λ ≠ μ \lambda\neq \mu λ=μ成立,(ii) 如果有向图 Γ ( A ) \Gamma(A) Γ(A)有一个有向生成树,那么 μ \mu μ是唯一具有最大模数的特征根。

证明:矩阵 A A A行和为 μ \mu μ,即 A 1 n = μ 1 n A1_n=\mu 1_n A1n=μ1n。再由非负性和圆盘定理, ρ ( A ) ≤ μ \rho(A)\leq \mu ρ(A)μ。故 μ \mu μ A A A关于特征向量 1 n 1_n 1n的一个特征根,且 ρ ( A ) = μ \rho(A)=\mu ρ(A)=μ

(充分性) 若 A A A对应的有向图 Γ ( A ) \Gamma(A) Γ(A)有一个有向生成树,令 B = A − μ I B=A-\mu I B=AμI,则 B B B满足引理3的条件。 B B B的0根的代数重数为1,自然 A A A μ \mu μ根代数重数也为1。

(必要性) (逆否) 若 A A A对应的有向图 Γ ( A ) \Gamma(A) Γ(A)没有向生成树,令 B = A − μ I B=A-\mu I B=AμI,则 B B B有不止一个0根, A A A μ \mu μ根代数重数大于1。

定理2 (Perron-Frobenius theorem):如果 A ∈ R n × n A\in\mathbb R^{n\times n} ARn×n非负且不可约,那么 (i) ρ ( A ) > 0 \rho(A)>0 ρ(A)>0,(ii) ρ ( A ) \rho(A) ρ(A) A A A的一个特征根,(iii) 存在正向量 x x x使得 A x = ρ ( A ) x Ax=\rho(A)x Ax=ρ(A)x,(iv) ρ ( A ) \rho(A) ρ(A) A A A的一个代数重数为1(几何重数也为1)的特征根。

一个行随机矩阵 A A A不可分解且非周期的(indecomposable and aperiodic, SIA),如果 lim ⁡ k → ∞ A k = 1 n ν T \lim_{k\to \infty}A^k=1_n\nu^T limkAk=1nνT,即极限存在且每一行都相同。

定理3 (Lemma 2.19):给定行随机矩阵 A ∈ R n × n A\in\mathbb R^{n\times n} ARn×n。如果 A A A有代数重数为1的特征根 λ = 1 \lambda=1 λ=1,且其他特征根满足 ∣ λ ∣ < 1 |\lambda|<1 λ<1,那么 A A A是SIA。特别地, lim ⁡ m → ∞ A m → 1 n ν T \lim_{m\to\infty}A^m\to 1_n\nu^T limmAm1nνT,其中 A T ν = ν A^T\nu=\nu ATν=ν 1 n T ν = 1 1_n^T\nu=1 1nTν=1。此外, ν \nu ν的每一个元素非负。

证明:SIA和左特征向量可由引理1直接推出。而 A A A A T A^T AT特征根相同(下章的结论2.1),由引理2可知特征根1对应的特征向量非负。

矩阵理论

主要介绍了特征值、特征向量、特征多项式、代数重数、几何重数以及重要的性质45

特征值和特征向量

这个定理前面有用到,如果0是 L L L的一个特征根,那么 e 0 = 1 e^0=1 e0=1也是 e − L e^{-L} eL的一个特征根,且它们相应的特征向量都为 1 n 1_n 1n,反之也一样。

定义 σ ( A ) \sigma (A) σ(A)为矩阵 A A A的特征根集。有几个重要性质:

n n n 阶方阵 A A A是非奇异方阵的充要条件是 A A A可逆,即可逆方阵就是非奇异方阵。以下命题等价:

  • 一个矩阵非奇异当且仅当它的行列式不为零。
  • 一个矩阵非奇异当且仅当它代表的线性变换是个自同构。
  • 一个矩阵半正定当且仅当它的每个特征值大于或等于零。
  • 一个矩阵正定当且仅当它的每个特征值都大于零。
  • 一个矩阵非奇异当且仅当它的秩为 n n n(满秩)。

证明:如果 λ ∈ σ ( A ) λ∈σ(A) λσ(A),则存在一个非零向量 x x x,使得 A x = λ x Ax=λx Ax=λx,从而 ( A + μ I ) x = A x + μ x = λ x + μ x = ( λ + μ ) x (A+μI)x=Ax+μx=λx+μx=(λ+μ)x (A+μI)x=Ax+μx=λx+μx=(λ+μ)x。于是 λ + μ ∈ σ ( A + μ I ) λ+μ∈σ(A+μI) λ+μσ(A+μI)。反过来,如果 λ + μ ∈ σ ( A + μ I ) λ+μ∈σ(A+μI) λ+μσ(A+μI),则存在非零向量 y y y,使得 A y + μ y = ( A + μ I ) y = ( λ + μ ) y = λ y + μ y Ay+μy=(A+μI)y=(λ+μ)y=λy+μy Ay+μy=(A+μI)y=(λ+μ)y=λy+μy。于是 A y = λ y Ay=λy Ay=λy, 从而 λ ∈ σ ( A ) λ∈σ(A) λσ(A)

特征多项式

证明:

  1. 多项式次数最高的两项和常数项已经给出,而其他求和项包含非对角因子 − a i j -a_{ij} aij,故次数不会大于 n − 2 n-2 n2,因为 t − a i j t-a_{ij} taij t − a j j t-a_{jj} tajj不是因子。
  2. p A ( λ ) = 0 ⇔ det ⁡ ( λ I − A ) = 0 ⇔ ( λ I − A ) x = 0 , x ≠ 0 ⇔ λ ∈ σ ( A ) p_A(λ)=0⇔\operatorname{det}(λI−A)=0⇔(λI−A)x=0,x≠0⇔λ∈σ(A) pA(λ)=0det(λIA)=0(λIA)x=0,x=0λσ(A)
  3. 次数为 n ⩾ 1 n⩾1 n1的多项式至多有 n n n个不同零点。

p A ( t ) p_A(t) pA(t)的零点之和是 A A A tr ⁡ ( A ) \operatorname{tr}(A) tr(A),而零点之积则是 A A A行列式 det ⁡ ( A ) \operatorname{det}(A) det(A)

代数重数

λ λ λ的代数重数是特征方程里面有几个根是 λ λ λ

矩阵的谱半径(spectral radius)是模最大特征根对应的模数。

上述定理表明,一个奇异的复矩阵总可以稍加平移使之成为非奇异的。

几何重数

证明:由于 det ⁡ ( t I − A T ) = det ⁡ ( t I − A ) T = det ⁡ ( t I − A ) \operatorname{det}(tI−A^T)=\operatorname{det}(tI−A)^T=\operatorname{det}(tI−A) det(tIAT)=det(tIA)T=det(tIA), 我们有 p A T ( t ) = p A ( t ) p_{A^T}(t)=p_A(t) pAT(t)=pA(t), 所以有 p A T ( λ ) = 0 p_A^T(λ)=0 pAT(λ)=0 当且仅当 p A ( λ ) = 0 p_A(λ)=0 pA(λ)=0。 类似地, det ⁡ ( t ˉ I − A ∗ ) = det ⁡ [ ( t I − A ) ∗ ] = det ⁡ ( t I − A ) ‾ \operatorname{det}(\bar tI−A^∗)=\operatorname{det}[(tI−A)^∗]=\overline{\operatorname{det}(tI−A)} det(tˉIA)=det[(tIA)]=det(tIA), 所以 p A ∗ ( t ˉ ) = p A ( t ) ‾ p_{A^∗}(\bar t)=\overline {p_A(t)} pA(tˉ)=pA(t), 又 p A ∗ ( λ ˉ ) = 0 p_A^∗(\bar λ)=0 pA(λˉ)=0当且仅当 p A ( λ ) = 0 p_A(λ)=0 pA(λ)=0

如果 x , y ∈ C n x,y∈\mathbb C^n x,yCn两者都是 A ∈ M n A∈M^n AMn的与特征值 λ λ λ相伴的特征向量,那么 x x x y y y的任何非零的线性组合也是它的与 λ \lambda λ相伴的特征向量 。实际上,与一个给定的 λ ∈ σ ( A ) λ∈σ(A) λσ(A)相伴的所有特征向量组成的集合与零向量合起来作成 C n \mathbb C^n Cn的一个子空间,该子空间就是 A − λ I A−λI AλI零空间,就是齐次线性方程组 ( A − λ I ) x = 0 (A−λI)x=0 (AλI)x=0的解集,由秩的关系知其维数是 n − rank ⁡ ( A − λ I ) n−\operatorname{rank}(A−λI) nrank(AλI)。该空间有个名字就是特征空间,下面给出特征空间的完整定义:

介绍完特征空间,就可以定义几何重数了,特征空间的维数即为几何重数。

可以证明特征值的几何重数小于或者等于它的代数重数的。

即,几何重数 = n − rank ⁡ ( A − λ I ) ≤ k = =n-\operatorname{rank}(A-\lambda I)\leq k= =nrank(AλI)k=代数重数。

一个矩阵可对角化,当且仅当它是无亏的;它有完全不同的特征值,当且仅当它是无损的且是无亏的。考虑以下矩阵的特征值 λ = 1 λ=1 λ=1, 矩阵 [ 1 0 0 2 ] \begin{bmatrix}1&0\\ 0&2\end{bmatrix} [1002],代数重数等于它的几何重数且都是 1, 它是无亏的,单位矩阵 I 2 I_2 I2是无亏的且是有损的,矩阵 [ 1 1 0 1 ] \begin{bmatrix}1&1\\ 0&1\end{bmatrix} [1011],几何重数是1, 代数重数是2,它是有亏的且是无损的。

尽管 A A A A T A^T AT有相同的特征值,它们与给定特征值相伴的特征空间有可能是不同的。比如,矩阵 A = [ 2 3 0 4 ] A=\begin{bmatrix}2&3\\ 0&4\end{bmatrix} A=[2034],那么 A A A的与特征值2相伴的(一维)特征空间是由 [ 1 0 ] \begin{bmatrix}1\\ 0\end{bmatrix} [10]生成的,而 A T A^T AT的与特征值2相伴的特征空间是由 [ 1 0 0 − 3 / 2 ] \begin{bmatrix}1&0\\ 0&-3/2\end{bmatrix} [1003/2]生成的。

总结

  • λ λ λ的代数重数是特征方程里面有几个根是 λ λ λ
  • λ λ λ的几何重数是线性空间 A x = λ x Ax=λx Ax=λx的维数。
  • 代数重数大于等于几何重数,代数重数如果大于几何重数,那么原因在于这个矩阵的Jordan标准型里面有维数大于1的Jordan块。
  • 强连通 ⇔ \Leftrightarrow 有向生成树 ⇔ \Leftrightarrow 不可约 ⇔ \Leftrightarrow 最大模数特征根代数重数为1 ⇔ \Leftrightarrow 相应特征向量非负
  • 如果是行随机,则上面条件 ⇔ \Leftrightarrow SIA ⇔ \Leftrightarrow 极限为 1 n ν T 1_n\nu^T 1nνT,其中 ν \nu ν为左特征向量

  1. Vicsek, T., Czirók, A., Ben-Jacob, E., Cohen, I., Shochet, O. (1995). Novel type of phase transition in a system of self-driven particles. Physical review letters, 75(6), 1226. ↩︎

  2. Ren, W., & Beard, R. W. (2008). Distributed consensus in multi-vehicle cooperative control . London: Springer London. ↩︎

  3. 矩阵指数. (2020, September 15). Retrieved from 维基百科, 自由的百科全书: https://zh.wikipedia.org/w/index.php?title=%E7%9F%A9%E9%98%B5%E6%8C%87%E6%95%B0&oldid=61692808 ↩︎

  4. 特征值和特征向量. 小鱼吻水. https://www.cnblogs.com/zhoukui/p/7672972.html ↩︎

  5. 特征多项式、代数重数与几何重数. 小鱼吻水. https://www.cnblogs.com/zhoukui/p/7685318.html ↩︎

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

多智能体一致性(Consensus)中的矩阵理论(Matrix Theory) 的相关文章

  • Android P阻止调用非sdk api后,Atlas该何去何从

    0 背景 自从Android 9 0后 xff0c Android就已经开始着手阻止app开发调用非sdk的api xff0c 也就是被标记为 64 hide的变量 函数 类不可以通过反射调用 xff0c 否则会提示NoSuchMethod
  • 简历应该这么写!

    很多同学刚开始找工作时 xff0c 投出去很多简历 xff0c 但是都石沉大海了 xff0c 没有后文 之所以简历不通过 xff0c 往往都是简历不够 好看 很多大公司HR经常一天要看几百份 xff0c 甚至上千份简历 xff0c 基本都是
  • 希望计算机专业同学都知道这些老师

    C语言教程 翁凯老师 赫斌 翁恺老师是土生土长的浙大码农 xff0c 从本科到博士都毕业于浙大计算机系 xff0c 后来留校教书 xff0c 一教就是20多年 翁恺老师的c语言课程非常好 xff0c 讲解特别有趣 xff0c 很适合初学者学
  • 100个python算法超详细讲解:抓交通肇事犯

    1 xff0e 问题描述 一辆卡车违反交通规则 xff0c 撞人后逃跑 现场有三人目 该事件 xff0c 但都 没有记住车号 xff0c 只记下了车号的一些特征 说 xff1a 牌照的前两位数字是相 同的 xff1b 乙说 xff1a 牌照
  • 100个python算法超详细讲解:百钱百鸡

    1 xff0e 问题描述 中国古代数学家张丘建在他的 算经 中提出了一个著名的 百钱 百鸡问题 xff1a 一只公鸡值五钱 xff0c 一只母鸡值三钱 xff0c 三只小鸡值一钱 xff0c 现 在要用百钱买百鸡 xff0c 请问公鸡 母鸡
  • 100个python算法超详细讲解:水仙花数

    1 xff0e 问题描述 输出所有的 水仙花数 所谓的 水仙花数 是指一个三位数 xff0c 其各位数字的立方 和等于该数本身 xff0c 例如 xff0c 153是 水仙花数 xff0c 因为153 61 1 3 43 1 3 43 3
  • 100个python算法超详细讲解:常胜将军

    100个python算法超详细讲解 64 谷歌学术 1 xff0e 问题描述 有火柴21根 xff0c 两人依次取 xff0c 每次每人只可取走1 xff5e 4根 xff0c 不能多取 xff0c 也不能不取 xff0c 谁取到最后一根火
  • 100个python算法超详细讲解:逆序输出数字

    100个python算法超详细讲解 64 谷哥技术 1 xff0e 问题描述 编程实现将输入的整数逆序输出 2 xff0e 问题分析 前面我们已经接触过很多的递归问题了 xff0c 这些递归问题可以简单 地分成两类 xff1a 一类可以归结
  • 100个python算法超详细讲解:角谷猜想

    1 xff0e 问题描述 角谷猜想在西方常被称为西拉古斯猜想 xff0c 据说这个问题首先是在 美国的西拉古斯大学被研究的 xff0c 而在东方 xff0c 这个问题则由将它带到日 本的日本数学家角谷静夫的名字来命名 xff0c 故被称为角
  • 100个python算法超详细讲解:统计学生成绩

    完整版下载 超详细Python算法案例讲解100例 zip Python文档类资源 CSDN下载 1 xff0e 问题描述 有5个学生 xff0c 每个学生有三门课程的成绩需要统计 要求从键盘输入学生的学号 姓名以及三门课程 的成绩 xff
  • apt update、apt upgrade 和 apt dist-upgrade 的区别

    1 root 64 kali apt update apt update 的作用是从 etc apt sources list文件中定义的源中获取的最新的软件包列表 即运行 apt update 并没有更新软件 xff0c 而是相当 win
  • C++服务器开发100个知识要点C++RAII惯用法

    最初的写法 在笔者刚学习服务器开发的时候 xff0c 公司给笔者安排了一个练习 xff1a 在 Windows 系统上写一个 C 43 43 程序 xff0c 用该程序实现一个简单的服务 xff0c 在客户端连接上来时 xff0c 给客户端
  • 人工智能知识全面讲解: 人脸识别技术

    早在40年前 xff0c 图像识别领域就有很多关于人脸识别的研究 但是在当时 xff0c 传统算法在普通图像识别中已经很难取得良好的识别效果 xff0c 更何况还要从人脸 中提取更加细微的特征 在很长一段时间里 xff0c 人脸识别主要存在
  • Redis入门完整教程:缓存的收益和成本

    图11 1左侧为客户端直接调用存储层的架构 xff0c 右侧为比较典型的缓存层 43 存储层架构 xff0c 下面分析一下缓存加入后带来的收益和成本 收益如下 xff1a 加速读写 xff1a 因为缓存通常都是全内存的 xff08 例如Re
  • Linux命令+shell脚本大全:vim 基础

    免费教程推荐 xff1a python C 43 43 Java JS Rust Go语言入门完全手册 xff08 6合1 xff09 zip Python文档类资源 CSDN下载 vim编辑器在内存缓冲区中处理数据 只要键入 vim 命令
  • Python数据结构+算法全面讲解:Python 基础

    Python 基础 本节将复习 Python 并且为前一节提到的思想提供更详细的例子 如果你刚开始学习 Python 或者觉得自己需要更多的信息 建议你查看本书结尾列出的 Python 资源 本节的目标是帮助你 复习 Python并且强化一
  • Python数据结构+算法全面讲解:定义函数、定义类

    之前的过程抽象例子调用了 Python数学模块中的 sqrt 函数来计算平方根 通常来说 可以 通过定义函数来隐藏任何计算的细节 函数的定义需要一个函数名 一系列参数以及一个函数体 函数也可以显式地返回一个值 例如 下面定义的简单函数会返回
  • 操作系统-进程

    进程是操作系统中资源分配和调度的基本单位 xff0c 而线程是进程的组成部分 xff0c 它代表了一条顺序的执行流 1 进程的出现 目的 xff1a 为了使多个程序能并发执行 xff0c 以提高资源的利用率和系统的吞吐量 2 进程组成 进程
  • ubuntu系统中查看本机cpu和内存信息的命令和用法(分色排版)

    https zhidao baidu com question 192966322 html 写出ubuntu linux系统中查看本机cpu和内存信息的命令和用法 以及如何解读这些命令 ubuntu系统中查看本机cpu和内存信息的命令和用
  • 面试题:单片机裸机和RTOS开发过程中,如何保证全局变量在中断和主循环中读写的正确性

    这个面试题时考察的关键字volatile 临界区 xff0c 原子操作和锁的概念 xff0c 因此首先需要搞清楚这几个知识点以及使用方法 1 关键字volatile 关键字volatile时告诉编译器 xff0c 被关键字volatile修

随机推荐

  • 丰润达为天津艺洲彭泽大酒店打造酒店安防监控改造项目

    衡量一个酒店是否安全的一个很重要的标准 xff0c 就是酒店的各个角落是否都布有监控设备 要知道 xff0c 很多受害人被侵害 xff0c 都是发生在监控看不到的角落 可以说监控就像是一双锐利的眼睛 xff0c 时时注视着坏蛋 xff0c
  • 对不起,这个官司我不服!数据隐私保护是阿里云的生命线

    摘要 xff1a 对阿里云来说 xff0c 保护用户数据隐私一直是我们坚守的生命线 在这次事件处理中 xff0c 保护数据隐私是我们的第一原则 阿里云认为 xff0c 作为云服务器提供商 xff0c 阿里云无权审查任何用户数据 只有收到司法
  • CentOS中添加Swap

    1 检查 Swap 空间在设置 Swap 文件之前 xff0c 有必要先检查一下系统里有没有既存的 Swap 文件 运行以下命令 xff1a 1 swapon s 如果返回的信息概要是空的 xff0c 则表示 Swap 文件不存在 2 检查
  • 优秀程序员的故事

    A君默默的工作了3年 xff0c 从项目初立 xff0c 到遍地开花 工作不忙 xff0c 工资没长 新领导来了 xff0c 下个版本重新开发 xff0c A君继续维护老版本 新招了一批人 xff0c 加班加点干了半年多 直到版本发布 xf
  • android studio 控制台输出乱码

    问题 android studio 控制台输出乱码 详细问题 解决方案 双击Shift 全局查找快捷键 xff0c 输入vmoption xff0c 选择Edit Custom CM Options 即 如果之前没有配置过 xff0c 会弹
  • Linux下使用VSCode,GCC,OpenOCD实现STM32一键编译烧录调试(CMake篇)

    Linux下使用VSCode开发STM32 xff08 二 xff09 一 开发工具安装二 测试工程简介三 CMake工具1 CMakeLists txt2 生成Makefile3 make编译 四 json脚本实现一键编译烧录调试1 la
  • CMake Error at cmake/OpenCVDetectCXXCompiler.cmake:85 (list)

    Ubuntu 18 4 安装opencv 2 4 10时遇到如下问题 xff1a CMake Error at cmake OpenCVDetectCXXCompiler cmake 85 list list GET given empty
  • Camera-IMU标定工具Kalibr的编译

    关于catkin make过程中下载suitesparse过久甚至失败的问题 xff1a 在安装kalibr时的suitesprse库时 xff0c 对应的cmakelists中会通过wget 下载压缩包 xff0c 若无法下载则整个kal
  • 远程桌面,RDP文件密码加密、解密算法(C#)

    背景 xff1a 由于项目需要 xff0c 使用RDP文件来远程登录 xff0c 需要实现点击rdp文件就可以自动连接远程桌面 xff0c 并且实现自动登录功能 xff01 自动登录 xff01 自动登录 xff01 自动登录 xff1a
  • 解决apt install存在依赖关系导致无法安装成功的办法

    安装aptitude xff0c 使用aptitude进行安装会自动给出解决方案 sudo apt get install aptitude sudo aptitude install XXX
  • cubemx在使用freertos的时候为何推荐使用除systick以外的timebase

    摘要 第一次使用stm32cubemx 在配置freertos后生成代码时会提示 When FreeRTOS is used It is strongly recommended to use a HAL timebase source o
  • 状态机编程 (一) 状态机相关概念

    基本概念 状态机编程 xff0c 又称事件驱动型编程 事件驱动程序需要一系列的精细粒度的事件处理函数来处理事件 这些事件函数必须处理的很快并返回主事件循环 所以其非常依赖于通过使用静态变量维护在从一个事件驱动函数转换到下一个执行函数时的执行
  • 后端状态估计-卡尔曼滤波器理解+扩展-SLAM14讲笔记(六)

    文章目录 系列文章目录前言一 pandas是什么 xff1f 二 使用步骤 1 引入库2 读入数据 状态估计的概率解释 xff1a 位姿x和路标y服从某种概率分布 xff0c 目的是通过某些运动数据u xff08 比如惯性测量传感器IMU输
  • OpenCV笔记.1 - OpenCV的编译和安装

    OpenCV的编译和安装 想要使用OpenCV进行图像的处理和开发 xff0c 就需要先对OpenCV库进行编译 虽然在Windows下已经有了现成的OpenCV库 xff0c 但是由于官方提供的库缺少一些关键的功能 xff08 例如Ope
  • Git中stash和stage的差别

    对于初学者来说 xff0c git中stash和stage两个命令的单词有些相似 xff0c 有可能会弄混 其实二者是两个完全不同的概念 1 stash是git中的一个命令 git stash的作用是把工作区 必须是工作区中已经被git追踪
  • 用matlab和RTB做二连杆机械臂动力学建模

    文章目录 写在前面二连杆机械臂RTB建模仿真与验证源代码 写在前面 本文使用的工具为matlab以及Peter Corke的RTB Robotics Toolbox 基于RTB 10 3 1版本 xff0c 我写了RTE Robotics
  • 机械臂协同搬运中的阻抗控制

    文章目录 阻抗模型物体阻抗分布阻抗Matlab和RTB仿真物体阻抗分布阻抗 源代码 阻抗模型 阻抗控制的目的是将原有物体动力学修正为我们期望动力学 假设有一个弹簧 xff0c 通过阻抗控制 xff0c 可以使得它的刚度降低 xff0c 实际
  • MATLAB App Designer生成独立GUI(可执行exe)并添加依赖项

    文章目录 写在前面生成步骤设置编译器编写GUI生成exe 常踩的坑 写在前面 近期 xff0c 由于朋友需求以及科研任务要求 xff0c 我研究了一下MATLAB GUI设计 xff0c 写了两个小程序 一个是读取excel部门名单生成ex
  • 用MATLAB仿真仿射队形变换(affine formation maneuver)

    文章目录 写在前面如何仿真静态编队控制构建stress matrixMATLAB求解LMI问题静态编队控制源代码 如何仿真时变轨迹和队形变换轨迹生成时变leader控制律时变轨迹和队形变换源代码 写在前面 原论文标题 xff1a Affin
  • 多智能体一致性(Consensus)中的矩阵理论(Matrix Theory)

    文章目录 写在前面一致性算法连续时间离散时间 一致性证明连续时间离散时间 矩阵理论特征值和特征向量特征多项式代数重数几何重数 总结 写在前面 最近在看一些分布式优化的文章 xff0c 但是大部分文章都是用的离散时间算法 我之前一直研究的是连