多智能体集群协同控制笔记(1):线性无领航多智能体系统的一致性

news2025/1/18 7:39:20

对于连续时间高阶线性多智能体系统的状态方程为:
x ˙ i ( t ) = A x i ( t ) + B u i ( t ) , i = 1 , 2.. N \dot {\mathbf{x}}_i(t)=A\mathbf{x}_i(t)+B\mathbf{u}_i(t),i=1,2..N x˙i(t)=Axi(t)+Bui(t),i=1,2..N
下标 i i i代表第 i i i个智能体, u i ( t ) ∈ R q × 1 \mathbf{u}_i(t)\in R^{q \times 1} ui(t)Rq×1表示第 i i i个智能体的控制输入变量, x i ( t ) ∈ R p × 1 \mathbf{x}_i(t)\in R^{p \times 1} xi(t)Rp×1表示第 i i i个智能体的状态变量。系统的一致性即设计控制器 u i ( t ) \mathbf{u}_i(t) ui(t)保证如下等式成立:
lim ⁡ t → ∞ x 1 ( t ) = lim ⁡ t → ∞ x 2 ( t ) = . . . = lim ⁡ t → ∞ x N ( t ) \lim_{t\rightarrow\infty}\mathbf{x}_1(t)=\lim_{t\rightarrow\infty}\mathbf{x}_2(t)=...=\lim_{t\rightarrow\infty}\mathbf{x}_N(t) tlimx1(t)=tlimx2(t)=...=tlimxN(t)

  • 定义Laplacian矩阵 L = { l i j } i , j = 1 , . . N L=\{l_{ij}\}_{i,j=1,..N} L={lij}i,j=1,..N,其中:
    l i j = { ∑ j = 1 , j ≠ i N a i j i = j − a i j i ≠ j l_{ij}=\begin{cases} \sum_{j=1,j\ne i}^Na_{ij} & i = j\\ -a_{ij}& i\ne j \end{cases} lij={j=1,j=iNaijaiji=ji=j

  • 定义变量: ξ i ( t ) = ∑ j = 1 N a i j ( x i ( t ) − x j ( t ) ) \mathbf{\xi}_i(t)=\sum_{j=1}^Na_{ij}(\mathbf{x}_i(t)-\mathbf{x}_j(t)) ξi(t)=j=1Naij(xi(t)xj(t)),定义:
    ξ ( t ) = ( L ⊗ I p ) X ( t ) \mathbf{\xi}(t)=(L\otimes I_p)X(t) ξ(t)=(LIp)X(t)
    其中: X ( t ) = [ x 1 T ( t ) , x 2 T ( t ) , . . x N T ( t ) ] T X(t)=[\mathbf{x}_1^T(t),\mathbf{x}_2^T(t),..\mathbf{x}_N^T(t)]^T X(t)=[x1T(t),x2T(t),..xNT(t)]T ξ ( t ) = [ ξ 1 ( t ) T , ξ 2 ( t ) T , . . ξ N ( t ) T ] T \mathbf{\xi}(t)=[\mathbf{\xi}_1(t)^T,\mathbf{\xi}_2(t)^T,..\mathbf{\xi}_N(t)^T]^T ξ(t)=[ξ1(t)T,ξ2(t)T,..ξN(t)T]T

  • 定义控制器: u i ( t ) = c K 1 ξ i ( t ) \mathbf{u}_i(t)=cK_1\mathbf{\xi}_i(t) ui(t)=cK1ξi(t),总的控制策略为:
    u ( t ) = ( I N ⊗ c K 1 ) ξ ( t ) = ( I N ⊗ c K 1 ) ( L ⊗ I p ) X ( t ) \mathbf{u}(t)=(I_N\otimes cK_1)\mathbf{\xi}(t) =(I_N\otimes cK_1)(L\otimes I_p)X(t) u(t)=(INcK1)ξ(t)=(INcK1)(LIp)X(t)
    其中 K 1 K_1 K1是待求的控制增益矩阵, c c c为加权参数;

  • 定义 L L L为该系统的Laplacian矩阵,存在一个酉矩阵 Y Y Y,使得:
    Y T L Y = d i a g ( λ 1 , λ 2 , . . . λ N ) Y^TLY=\mathbf{diag}(\lambda_1,\lambda_2,...\lambda_N) YTLY=diag(λ1,λ2,...λN)
    其中: λ 1 = 0 ; λ i > 0 , i ∈ { 2 , 3 , . . N } \lambda_1=0;\lambda_i >0,i \in \{ 2,3,..N\} λ1=0;λi>0,i{2,3,..N},由于 L L L有右特征向量 1 N \mathbf{1}_N 1N, Y Y Y可以写成:
    Y = [ 1 N N , M 1 ] Y=[\frac{\mathbf{1}_N}{\sqrt{N}}, M_1] Y=[N 1N,M1]

  • 定义: ε ( t ) = [ ε 1 ( t ) T , ε 2 ( t ) T , . . ε N ( t ) T ] T = ( Y T ⊗ I p ) ξ ( t ) \mathbf{\varepsilon}(t)=[\mathbf{\varepsilon}_1(t)^T,\mathbf{\varepsilon}_2(t)^T,..\mathbf{\varepsilon}_N(t)^T]^T=(Y^T\otimes I_p)\mathbf{\xi}(t) ε(t)=[ε1(t)T,ε2(t)T,..εN(t)T]T=(YTIp)ξ(t),其中 p p p x i ( t ) \mathbf{x}_i(t) xi(t)的维度。

    1.无向连通图定理

    引理1.1: 当多智能体系统网络为无向连通图时,系统实现状态一致的充要条件是:

ε ˉ ( t ) = [ ε 2 ( t ) T , ε 3 ( t ) T , . . ε N ( t ) T ] T = 0 \mathbf{\bar \varepsilon}(t)=[\mathbf{\varepsilon}_2(t)^T,\mathbf{\varepsilon}_3(t)^T,..\mathbf{\varepsilon}_N(t)^T]^T=\mathbf{0} εˉ(t)=[ε2(t)T,ε3(t)T,..εN(t)T]T=0

​ 且 ε ˉ ( t ) \bar{\varepsilon}(t) εˉ(t)同时也满足:
ε ˙ ( t ) = ( I N ⊗ A + c Λ N ⊗ B K 1 ) ε ( t ) ε ˉ ˙ ( t ) = ( I N − 1 ⊗ A + c Λ N − 1 ⊗ B K 1 ) ε ˉ ( t ) ( ∗ ) \dot \varepsilon(t) = (I_N\otimes A+c\Lambda_N \otimes BK_1)\varepsilon(t)\\ \dot{\bar{\varepsilon}}(t) = (I_{N-1}\otimes A+c\Lambda_{N-1} \otimes BK_1)\bar{\varepsilon}(t) \quad (*) ε˙(t)=(INA+cΛNBK1)ε(t)εˉ˙(t)=(IN1A+cΛN1BK1)εˉ(t)()
​ 其中: Λ N − 1 = d i a g ( λ 2 , . . . λ N ) \Lambda_{N-1}=diag(\lambda_2,...\lambda_N) ΛN1=diag(λ2,...λN) Λ N = d i a g ( λ 1 , λ 2 , . . . λ N ) \Lambda_{N}=diag(\lambda_1,\lambda_2,...\lambda_N) ΛN=diag(λ1,λ2,...λN)

定理1.1:给定矩阵 Q 1 = Q 1 T > 0 Q_1=Q_1^T>0 Q1=Q1T>0 R 1 = R 1 T > 0 R_1=R_1^T>0 R1=R1T>0,若如下Riccati方程有正定解 P 1 = P 1 T > 0 P_1=P_1^T>0 P1=P1T>0
P 1 A + A P 1 T + Q 1 − P 1 B R 1 − 1 B T P 1 = 0 P_1A+AP_1^T+Q_1-P_1BR_1^{-1}B^TP_1=\mathbf{0} P1A+AP1T+Q1P1BR11BTP1=0
​ 则系统 ( ∗ ) (*) ()渐进稳定,由引理1.1可知,原系统能达到一致性。

​ 其中系统的控制增益矩阵 K 1 = − R 1 − 1 B T P 1 K_1=-R_1^{-1}B^TP_1 K1=R11BTP1,且加权系数 c c c满足 c ≥ 1 2 min ⁡ i = 2 , . . . N λ i ( L ) c\geq\frac{1}{2\min_{i=2,...N}{\lambda_i(L)}} c2mini=2,...Nλi(L)1

​ 证明:构造Lyapunov函数 V 1 ( t ) = 0.5 ε ˉ T ( t ) ( I N − 1 ⊗ P 1 ) ε ˉ ( t ) V_1(t)=0.5\bar{\varepsilon}^T(t)(I_{N-1}\otimes P_1)\bar{\varepsilon}(t) V1(t)=0.5εˉT(t)(IN1P1)εˉ(t),其满足:
V 1 ˙ ( t ) = 0.5 ε ˉ ˙ T ( t ) ( I N − 1 ⊗ P 1 ) ε ˉ ( t ) + 0.5 ε ˉ T ( t ) ( I N − 1 ⊗ P 1 ) ε ˉ ˙ ( t ) = ε ˉ T ( t ) ( I N − 1 ⊗ P 1 ) ε ˉ ˙ ( t ) = ε ˉ ( t ) T ( I N − 1 ⊗ P 1 ) ( I N − 1 ⊗ A + c Λ N − 1 ⊗ B K 1 ) ε ˉ ( t ) = ε ˉ T ( t ) ( I N − 1 ⊗ P 1 A + c Λ N − 1 ⊗ P 1 B K 1 ) ε ˉ ( t ) = ε ˉ T ( t ) ( I N − 1 ⊗ P 1 A − c Λ N − 1 ⊗ P 1 B R 1 − 1 B T P 1 ) ε ˉ ( t ) \dot{V_1}(t)=0.5\dot{\bar{\varepsilon}}^T(t)(I_{N-1}\otimes P_1)\bar{\varepsilon}(t)+0.5\bar{\varepsilon}^T(t)(I_{N-1}\otimes P_1)\dot{\bar{\varepsilon}}(t)\\ =\bar{\varepsilon}^T(t)(I_{N-1}\otimes P_1)\dot{\bar{\varepsilon}}(t)\\=\bar{\varepsilon}(t)^T(I_{N-1}\otimes P_1)(I_{N-1}\otimes A+c\Lambda_{N-1} \otimes BK_1)\bar{\varepsilon}(t)\\=\bar{\varepsilon}^T(t)(I_{N-1}\otimes P_1A+c\Lambda_{N-1}\otimes P_1BK_1)\bar{\varepsilon}(t)\\=\bar{\varepsilon}^T(t)(I_{N-1}\otimes P_1A-c\Lambda_{N-1}\otimes P_1BR_1^{-1}B^TP_1)\bar{\varepsilon}(t) V1˙(t)=0.5εˉ˙T(t)(IN1P1)εˉ(t)+0.5εˉT(t)(IN1P1)εˉ˙(t)=εˉT(t)(IN1P1)εˉ˙(t)=εˉ(t)T(IN1P1)(IN1A+cΛN1BK1)εˉ(t)=εˉT(t)(IN1P1A+cΛN1P1BK1)εˉ(t)=εˉT(t)(IN1P1AcΛN1P1BR11BTP1)εˉ(t)
​ 由于 c ≥ 1 2 min ⁡ i = 2 , . . . N λ i ( L ) c\geq\frac{1}{2\min_{i=2,...N}{\lambda_i(L)}} c2mini=2,...Nλi(L)1,因此 c Λ N − 1 ≥ I N − 1 2 c\Lambda_{N-1}\geq\frac{I_{N-1}}{2} cΛN12IN1。带入上式有:
V 1 ˙ ( t ) = ε ˉ T ( t ) ( I N − 1 ⊗ P 1 A − c Λ N − 1 ⊗ P 1 B R 1 − 1 B T P 1 ) ε ˉ ( t ) ≤ ε ˉ T ( t ) ( I N − 1 ⊗ P 1 A − I N − 1 2 ⊗ P 1 B R 1 − 1 B T P 1 ) ε ˉ ( t ) = ε ˉ T ( t ) ( I N − 1 2 ⊗ ( P 1 A + A T P 1 ) − I N − 1 2 ⊗ P 1 B R 1 − 1 B T P 1 ) ε ˉ ( t ) = − 1 2 ε ˉ T ( t ) ( I N − 1 ⊗ Q 1 ) ε ˉ ( t ) \dot{V_1}(t)=\bar{\varepsilon}^T(t)(I_{N-1}\otimes P_1A-c\Lambda_{N-1}\otimes P_1BR_1^{-1}B^TP_1)\bar{\varepsilon}(t)\\ \leq \bar{\varepsilon}^T(t)(I_{N-1}\otimes P_1A-\frac{I_{N-1}}{2}\otimes P_1BR_1^{-1}B^TP_1)\bar{\varepsilon}(t)\\=\bar{\varepsilon}^T(t)( \frac{I_{N-1}}{2}\otimes (P_1A+A^TP_1) -\frac{I_{N-1}}{2}\otimes P_1BR_1^{-1}B^TP_1)\bar{\varepsilon}(t)\\=-\frac{1}{2}\bar{\varepsilon}^T(t)(I_{N-1}\otimes Q_1)\bar{\varepsilon}(t) V1˙(t)=εˉT(t)(IN1P1AcΛN1P1BR11BTP1)εˉ(t)εˉT(t)(IN1P1A2IN1P1BR11BTP1)εˉ(t)=εˉT(t)(2IN1(P1A+ATP1)2IN1P1BR11BTP1)εˉ(t)=21εˉT(t)(IN1Q1)εˉ(t)
​ 由直积的性质有:
λ min ⁡ ( I N − 1 ⊗ Q 1 ) = λ min ⁡ ( Q 1 ) λ max ⁡ ( I N − 1 ⊗ P 1 ) = λ max ⁡ ( P 1 ) \lambda_{\min}(I_{N-1}\otimes Q_1)=\lambda_{\min}(Q_1)\\ \lambda_{\max}(I_{N-1}\otimes P_1)=\lambda_{\max}(P_1) λmin(IN1Q1)=λmin(Q1)λmax(IN1P1)=λmax(P1)
​ 由矩阵的极大极小值原理:
V 1 ˙ ( t ) V 1 ( t ) = − 1 2 ε ˉ T ( t ) ( I N − 1 ⊗ Q 1 ) ε ˉ ( t ) 1 2 ε ˉ T ( t ) ( I N − 1 ⊗ P 1 ) ε ˉ ( t ) ≤ − λ min ⁡ ( Q 1 ) ε ˉ T ( t ) ε ˉ ( t ) λ max ⁡ ( P 1 ) ε ˉ T ( t ) ε ˉ ( t ) = − λ min ⁡ ( Q 1 ) λ max ⁡ ( P 1 ) = − δ \frac{\dot{V_1}(t)}{V_1(t)}=\frac{-\frac{1}{2}\bar{\varepsilon}^T(t)(I_{N-1}\otimes Q_1)\bar{\varepsilon}(t)}{\frac{1}{2}\bar{\varepsilon}^T(t)(I_{N-1}\otimes P_1)\bar{\varepsilon}(t)}\leq-\frac{\lambda_{\min}(Q_1)\bar{\varepsilon}^T(t)\bar{\varepsilon}(t)}{\lambda_{\max}(P_1)\bar{\varepsilon}^T(t)\bar{\varepsilon}(t) }=-\frac{\lambda_{\min}(Q_1)}{\lambda_{\max}(P_1)}=-\delta V1(t)V1˙(t)=21εˉT(t)(IN1P1)εˉ(t)21εˉT(t)(IN1Q1)εˉ(t)λmax(P1)εˉT(t)εˉ(t)λmin(Q1)εˉT(t)εˉ(t)=λmax(P1)λmin(Q1)=δ
​ 解上述不等式有:
V 1 ( t ) ≤ V 1 ( 0 ) e − δ t V_1(t)\leq V_1(0)e^{-\delta t} V1(t)V1(0)eδt
​ 带入 V 1 ( t ) ≥ 0.5 λ min ⁡ ( P 1 ) ∣ ∣ ε ˉ ( t ) ∣ ∣ 2 V_1(t)\geq 0.5\lambda_{\min}(P_1)||\bar{\varepsilon}(t)||^2 V1(t)0.5λmin(P1)∣∣εˉ(t)2 V 1 ( 0 ) ≤ 0.5 λ max ⁡ ( P 1 ) ∣ ∣ ε ˉ ( 0 ) ∣ ∣ 2 V_1(0)\leq 0.5\lambda_{\max}(P_1)||\bar{\varepsilon}(0)||^2 V1(0)0.5λmax(P1)∣∣εˉ(0)2有:
∣ ∣ ε ˉ ( t ) ∣ ∣ ≤ λ max ⁡ ( P 1 ) λ min ⁡ ( P 1 ) ∣ ∣ ε ˉ ( 0 ) ∣ ∣ e − δ t 2 ||\bar{\varepsilon}(t)||\leq \sqrt\frac{\lambda_{\max}(P_1)}{\lambda_{\min}(P_1)}||\bar{\varepsilon}(0)||e^{\frac{-\delta t}{2}} ∣∣εˉ(t)∣∣λmin(P1)λmax(P1) ∣∣εˉ(0)∣∣e2δt
​ 因此上述系统(*)是一致指数稳定的,其必然是渐进稳定的。

2.仿真

2.1 问题

​ 设固定翼无人机集群中每个无人机的俯仰方向运动模型的线性化系统方程为:
( α ˙ ( t ) q ˙ ( t ) ) = ( − 1.175 0.9871 − 8.458 − 0.8776 ) ( α ( t ) q ( t ) ) + ( − 0.194 − 0.03593 − 19.29 − 3.803 ) ( δ i a i l ( t ) δ i r u d ( t ) ) \begin{pmatrix} \dot{\alpha}(t) \\ \dot{q}(t) \end{pmatrix} = \begin{pmatrix} -1.175&0.9871\\-8.458&-0.8776 \end{pmatrix} \begin{pmatrix} {\alpha}(t) \\ {q}(t) \end{pmatrix}+ \begin{pmatrix} -0.194&-0.03593\\-19.29&-3.803 \end{pmatrix}\begin{pmatrix} {\delta}_i^{\mathbf{ail}}(t) \\ {\delta}_i^{\mathbf{rud}}(t) \end{pmatrix} (α˙(t)q˙(t))=(1.1758.4580.98710.8776)(α(t)q(t))+(0.19419.290.035933.803)(δiail(t)δirud(t))
​ 其中: α ( t ) \alpha(t) α(t):无人机俯仰角; q i ( t ) q_i(t) qi(t):无人机俯仰角速度;

δ a i l ( t ) \delta^{\mathbf{ail}}(t) δail(t):副翼操作指令; δ r u d ( t ) \delta^{\mathbf{rud}}(t) δrud(t):升降舵操作指令;

​ 先有3架无人机,其通信拓扑图如下:

在这里插入图片描述

​ 3架无人机的初值为:
( α 1 ( 0 ) q 1 ( 0 ) ) = ( 10 − 3 ) ; ( α 2 ( 0 ) q 2 ( 0 ) ) = ( − 7 2 ) ; ( α 3 ( 0 ) q 3 ( 0 ) ) = ( 4 − 1 ) \begin{pmatrix} {\alpha}_1(0) \\ {q}_1(0) \end{pmatrix}=\begin{pmatrix} 10\\ -3\end{pmatrix}; \begin{pmatrix} {\alpha}_2(0) \\ {q}_2(0) \end{pmatrix}=\begin{pmatrix} -7\\ 2\end{pmatrix}; \begin{pmatrix} {\alpha}_3(0) \\ {q}_3(0) \end{pmatrix}=\begin{pmatrix} 4\\ -1\end{pmatrix} (α1(0)q1(0))=(103);(α2(0)q2(0))=(72);(α3(0)q3(0))=(41)
​ 设计控制策略使3架无人机能完成俯仰角与俯仰角速度上的一致性。

2.2 求解

A = ( − 1.175 0.9871 − 8.458 − 0.8776 ) A=\begin{pmatrix} -1.175&0.9871\\-8.458&-0.8776 \end{pmatrix} A=(1.1758.4580.98710.8776) B = ( − 0.194 − 0.03593 − 19.29 − 3.803 ) B=\begin{pmatrix} -0.194&-0.03593\\-19.29&-3.803 \end{pmatrix} B=(0.19419.290.035933.803),设 R 1 = 50 I 2 R_1=50I_2 R1=50I2 Q 1 = 10 I 2 Q_1=10I_2 Q1=10I2

利用Matlab中的 care求解Riccati方程 P 1 A + A P 1 T + Q 1 − P 1 B R 1 − 1 B T P 1 = 0 P_1A+AP_1^T+Q_1-P_1BR_1^{-1}B^TP_1=\mathbf{0} P1A+AP1T+Q1P1BR11BTP1=0得到:
P 1 = ( 6.1743 − 0.2904 − 0.2904 0.9991 ) = P 1 T > 0 P_1 = \begin{pmatrix} 6.1743&-0.2904\\-0.2904&0.9991 \end{pmatrix} =P_1^T>0 P1=(6.17430.29040.29040.9991)=P1T>0
代码如下:

>> A=[-1.175 0.9871;-8.458 -0.8776];
>> B = [-0.194 -0.03593;-19.29 -3.803];
>> R1 = 50*eye(2);
>> Q1 = 10*eye(2);
>> P1 = care(A,B,Q1,R1)

P1 =

    6.1743   -0.2904
   -0.2904    0.9991

故由定理1.1多智能体系统可以实现一致性。

可以知道在验证线性系统一致性的过程中并没有考虑个体间的通信Laplacian矩阵。这说明同构多智能体线性系统的一致性本质上与其Laplacian矩阵无关!!!

可以得到其Laplacian矩阵为:
L = ( 1 − 1 0 − 1 2 − 1 0 − 1 1 ) L=\begin{pmatrix} 1&-1&0\\-1&2&-1\\0&-1&1 \end{pmatrix} L= 110121011
其中矩阵 K 1 = − R 1 − 1 B T P 1 = ( − 0.0881 0.3843 − 0.0177 0.0758 ) K_1=-R_1^{-1}B^TP_1=\begin{pmatrix} -0.0881 &0.3843\\-0.0177&0.0758\end{pmatrix} K1=R11BTP1=(0.08810.01770.38430.0758) c c c要满足 c ≥ 1 2 min ⁡ i = 2 , . . . N λ i ( L ) = 0.5 c\geq\frac{1}{2\min_{i=2,...N}{\lambda_i(L)}}=0.5 c2mini=2,...Nλi(L)1=0.5,取 c = 0.6 c=0.6 c=0.6。得到控制策略:
u ( t ) = c K 1 ξ ( t ) = ( I 2 ⊗ ( − 0.0529 0.2306 − 0.0106 0.0455 ) ) ξ ( t ) \mathbf{u}(t)=cK_1\mathbf{\xi}(t)=(I_2\otimes\begin{pmatrix} -0.0529 & 0.2306\\-0.0106 &0.0455\end{pmatrix})\mathbf{\xi}(t) u(t)=cK1ξ(t)=(I2(0.05290.01060.23060.0455))ξ(t)
下面用代码验证其可行性:

这里需要将连续系统零阶离散化,因此需要的采样时间很重要,不同采样时间会导致最后结果不收敛:

Δ t = 0.04 s \Delta t=0.04s Δt=0.04s时:

在这里插入图片描述

Δ t = 0.06 s \Delta t=0.06s Δt=0.06s时:

在这里插入图片描述

可以看到差距甚大,几乎不能用,因此说明了采样时间的重要性。同时也说明了该一致性控制策略有效!

3.代码

clc,clear;
A=[-1.175 0.9871;-8.458 -0.8776];
B = [-0.194 -0.03593;-19.29 -3.803];
c = 0.6;
K1 = [-0.0881 0.3843;...
      -0.0177 0.0758]; 
L = [1 -1 0;
    -1 2 -1;
     0 -1 1];
x1 = [10,-3]';x1_array = x1;
x2 = [-7,2]'; x2_array = x2;
x3 = [4,-1]'; x3_array = x3;
x_0 = [x1,x2,x3];
% 设置采样时间
delta_t = 0.04;
% num个时间步长内仿真
num = 100;
x = [x1;x2;x3];
%x_array = zeros(3*2,num);
for k = 1:num
   % 设计总的控制策略
   U = kron(L,c*K1*eye(2))*x;
   u1 = U(1:2);
   u2 = U(3:4);
   u3 = U(5:6);
for i = 1:3 
   x1 = (eye(2) +delta_t*A)*x1 + delta_t*B*u1; 
   x2 = (eye(2) +delta_t*A)*x2 + delta_t*B*u2;
   x3 = (eye(2) +delta_t*A)*x3 + delta_t*B*u3;
end
x = [x1;x2;x3];
x1_array = [x1_array,x1];
x2_array = [x2_array,x2];
x3_array = [x3_array,x3];
end
% 下面开始画图
subplot(121)
hold on;grid on;box on;
plot(delta_t*(1:num),x1_array(1,1:num),'r.-');
plot(delta_t*(1:num),x2_array(1,1:num),'g.-');
plot(delta_t*(1:num),x3_array(1,1:num),'b.-');
xlabel('时间/s');ylabel('俯仰角');
legend('无人机1','无人机2','无人机3');
subplot(122)
hold on;grid on;box on;
plot(delta_t*(1:num),x1_array(2,1:num),'r.-');
plot(delta_t*(1:num),x2_array(2,1:num),'g.-');
plot(delta_t*(1:num),x3_array(2,1:num),'b.-');
xlabel('时间/s');ylabel('俯仰角速度');
legend('无人机1','无人机2','无人机3');

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【vulhub漏洞复现】Thinkphp 2.x 任意代码执行

一、漏洞详情影响版本 thinkphp 2.x但是由于thinkphp 3.0版本在Lite模式下没有修复该漏洞,所以也存在该漏洞漏洞原因:e 和 /e模式匹配路由:e 配合函数preg_replace()使用, 可以把匹配来的字符串当作正则表达式执行; /e 可执行模式&#xff0c…

vue入门

一、准备 本文是基于HBuilderX工具来讲解的。 1、工具 HBuilderX 2、 二、介绍 Vue是一个做网页的框架。 一个网页都是由多个模块(组件)拼成的。而Vue的组件化技术正式应用了这个思想。 三、创建项目 使用HBuilderX 创建项目。 1、创建空白项目…

【联机对战】微信小程序联机游戏开发流程详解

现有一个微信小程序叫中国象棋项目,棋盘类的单机游戏看着有缺少了什么,现在给补上了,加个联机对战的功能,增加了可玩性,对新手来说,实现联机游戏还是有难度的,那要怎么实现的呢,接下…

MySQL表的增删查改(基础)

gitee:博客中的所有操作整合新增语法:insert [into] table_name values(value_list)[案例] 创建一个学生表进行数据插入1.1单行数据全列插入[提示]我们可以想在记事本上写下命令,让后复制到数据库客户端,这样可以在出错的时候进行快速修改.同时为了美观和明了,我们可以进行适当…

15个Spring扩展点,一般人知道的不超过5个!

Spring的核心思想就是容器,当容器refresh的时候,外部看上去风平浪静,其实内部则是一片惊涛骇浪,汪洋一片。Spring Boot更是封装了Spring,遵循约定大于配置,加上自动装配的机制。很多时候我们只要引用了一个…

苹果认证MFI学习

MFi是"Made for iPhone/iPod/iPad“的缩写。 MFi包含一系列技术或标准,你所开发的配件,要符合这个标准,才能够苹果设备如手机所认可,才能得到授权在市场销售。 比如蓝牙数据传输,就需要符合iAP2协议&#xff0c…

统计学习方法学习笔记——概论(一)

# 文章内容来自学习李航老师的《统计学习方法》后的总结,相当于学习笔记,若有不正确的地方还请大家指正。# 所需先验知识:概率论与数理统计、线性代数一、 统计学习概述可能有些小伙伴没有听过统计学习,但是我相信机器学习大家一定…

智慧物业管理系统【源码好优多】

简介 《智慧物业》一个免费开源的基于java的物业管理系统。未来将涵盖停车、安保、客服、工单、收费、财务、办公自动化等模块,构建一个软硬件一体的智慧物业解决方案。 功能 系统内置功能: 资产管理 商业区管理、楼栋管理、商铺管理、商铺租售 缴费…

【数电基础】——组合逻辑电路

目录 1.大纲 2.组合逻辑电路的特点 3.组合逻辑电路分析步骤 4.组合逻辑电路设计 5.组合逻辑电路中的竞争和冒险(重要) 6.怎样消除竞争冒险现象 7.常用的MSI组合逻辑器件 1.加法器 1.一位半加器 2.一位全加器 2.数据选择器 1.二选一数据选择器&#x…

spring容器,@Bean 与 @Component 用在同一个类上,会怎么样?

疑虑背景疑虑描述最近,在进行开发的过程中,发现之前的一个写法,类似如下以我的理解,Configuration 加 Bean 会创建一个 userName 不为 null 的 UserManager 对象,而 Component 也会创建一个 userName 为 null 的 UserM…

第七章 分词器:Text Analysis

1、分词器认知基础 1.1 基本概念 分词器官方称之为文本分析器,顾名思义,是对文本进行分析处理的一种手段,基本处理逻辑为按照预先制定的分词规则,把原始文档分割成若干更小粒度的词项,粒度大小取决于分词器规则。 1.2 分词发生时期 分词器的处理过程发生在 Index Tim…

【牛客刷题专栏】0x0D:JZ5 替换空格(C语言编程题)

前言 个人推荐在牛客网刷题(点击可以跳转),它登陆后会保存刷题记录进度,重新登录时写过的题目代码不会丢失。个人刷题练习系列专栏:个人CSDN牛客刷题专栏。 题目来自:牛客/题库 / 在线编程 / 剑指offer: 目录前言问题…

ICV光子盒:2023全球量子通信与安全产业发展展望

近日,全球著名的前沿科技咨询机构ICV与国内专注量子领域的行业研究机构光子盒,联合发布了2023全球量子通信与安全产业发展展望。报告主要从技术进展、产业生态、公司分析、网络建设、投资概况、政策发布、产业预测、展望观点的几方面对2023全球量子通信与…

【Java】Java进阶学习笔记(三)—— 面向对象(多态)

【Java】Java进阶学习笔记(三)—— 面向对象(多态)一、多态的概念1、多态的优点2、多态存在的三个必要条件3、多态中的成员特点4、重写方法的快捷键二、多态的转型1、向上转型2、向下转型3、代码示例4、转型的异常类型转换异常ins…

无线蓝牙耳机哪个品牌延迟低?玩游戏延迟低的蓝牙耳机推荐

无线蓝牙耳机因为摆脱了线的束缚,在使用上会更便捷,不少人喜欢戴蓝牙耳机玩游戏,但又怕蓝牙耳机有延迟。正因为蓝牙耳机摆脱了线的束缚,在信号传输的过程中难免产生延迟。那么,无线蓝牙耳机哪个品牌延迟低?…

【Linux】程序员的易筋经——冯诺依曼体系结构

文章目录👉冯诺伊曼体系结构👈概念内存的重要性👉操作系统(Operating System)👈概念目的定位特征发展和分类运行机制体系结构👉冯诺伊曼体系结构👈 概念 下图是描述冯诺依曼体系结…

6天重建一遍中国台湾省,三维模型还可以这样做!

说起三维模型,大家脑海中显现的大多是一个可通过电子屏幕进行全方位展示的立体物体。一般来说,所显示的物体既可以是现实世界的实体,也可以是通过想象所创作的虚构物体。 而实景三维正是镜像作用于现实世界真实化表达的新兴技术,是…

Java中的过滤器和拦截器

Java中的过滤器和拦截器 一.应用场景 拦截器应用场景 拦截器本质上是面向切面编程(AOP),符合横切关注点的功能都可以放在拦截器中来实现,主要的应用场景包括: 登录验证,判断用户是否登录。权限验证&…

JSP的分页

分页在读取数据库里的数据需要用,在以后数据库肯定还会有很多数据,一个页面装不下,所以需要分页功能。数据库查询的分页语句是“SELECT * FROM emp LIMIT 0, 5;”这里0是指起始行,5是查询5行,第二页起始行就是5&#x…

QT 实现右键菜单

有时我们希望在窗口中右键弹出菜单,这里来介绍一下QT中怎么实现. .h 中添加事件相应函数声明和变量定义: private:// 菜单事件void contextMenuEvent(QContextMenuEvent* event) override;void initMenu();private:QMenu* m_pMenu nullptr;在构造函数中…