这篇文章摘抄自沙昌基教授《数理战术学》第七章 多兵种对多兵种作战的微分对策模型,提供了求解微分方程的代码,防止自己忘记。
在《数理战术学》第79页提到:
最优火力分配策略随时间变化的根本原因在于相对作战指数向量与实际交战过程中各类作战单位的作战效果很不一致,改变例1中乙方作战指数向量,则最优火力分配策略会发生相应变化,请读者自行证明。
此文为《数理战术学》该思考题的证明。
【例】最优火力分配矩阵随时间变化的例子
设一对二作战中双方的实力向量为
x
=
[
x
1
]
,
y
=
[
y
1
y
2
]
x=[x_1],\quad y=\begin{bmatrix} y_1 \\ y_2 \end{bmatrix}
x=[x1],y=[y1y2]
其初值为
x
10
=
100
,
y
10
=
30
,
y
20
=
30
x_{10}=100,\quad y_{10}=30,\quad y_{20}=30
x10=100,y10=30,y20=30
双方毁伤系数矩阵为
A
=
[
1
1
]
,
B
=
[
9
1
]
A=\begin{bmatrix} 1\\ 1 \end{bmatrix},\quad B = \begin{bmatrix} 9 & 1 \end{bmatrix}
A=[11],B=[91]
火力分配矩阵为
Φ
=
[
ϕ
1
ϕ
2
]
,
Ψ
=
[
ψ
1
ψ
2
]
\Phi=\begin{bmatrix} \phi_1 \\ \phi_2 \end{bmatrix},\quad \Psi=\begin{bmatrix} \psi_1 & \psi_2 \end{bmatrix}
Φ=[ϕ1ϕ2],Ψ=[ψ1ψ2]
其中
0
≤
ψ
1
≤
1
,
0
≤
ψ
2
≤
1
,
0
≤
ϕ
1
,
0
≤
ϕ
2
,
ϕ
1
+
ϕ
2
≤
1
0 \le \psi_1 \le 1,\quad 0 \le \psi_2 \le 1, \\ 0 \le \phi_1, \quad 0 \le \phi_2, \quad \phi_1+\phi_2 \le 1
0≤ψ1≤1,0≤ψ2≤1,0≤ϕ1,0≤ϕ2,ϕ1+ϕ2≤1
于是,双方交战的Lanchester方程变为
{
x
˙
1
=
−
9
ψ
1
y
1
−
ψ
2
y
2
,
y
˙
1
=
−
ϕ
1
x
1
,
y
˙
2
=
−
ϕ
2
x
1
.
(1)
\left\{\begin{matrix} \begin{aligned} \dot x_1 &= -9\psi_1 y_1 - \psi_2 y_2, \\ \dot y_1 &= -\phi_1 x_1, \\ \dot y_2 &= -\phi_2 x_1. \end{aligned} \end{matrix}\right. \tag{1}
⎩⎪⎨⎪⎧x˙1y˙1y˙2=−9ψ1y1−ψ2y2,=−ϕ1x1,=−ϕ2x1.(1)
设双方的作战指数向量为
u
=
(
9
)
,
v
=
[
9
1
]
u=(9),\quad v=\begin{bmatrix} 9 \\ 1 \end{bmatrix}
u=(9),v=[91]
战斗时间为
T
=
1
6
l
n
10
+
l
n
10
9
T=\frac{1}{6}\mathrm{ln}10+\mathrm{ln}\frac{10}{9}
T=61ln10+ln910
则支付函数为
Θ
=
Θ
(
x
1
(
T
)
,
y
1
(
T
)
,
y
2
(
T
)
)
=
9
x
1
(
T
)
−
9
y
1
(
T
)
−
y
2
(
T
)
(2)
\mathit \Theta=\mathit \Theta(x_1(T),y_1(T),y_2(T))=9x_1(T)-9y_1(T)-y_2(T) \tag{2}
Θ=Θ(x1(T),y1(T),y2(T))=9x1(T)−9y1(T)−y2(T)(2)
【解】
(1)构建Hamilton函数,为
H
=
λ
(
−
9
ψ
1
y
1
−
ψ
2
y
2
)
+
μ
1
(
−
ϕ
1
x
1
)
+
μ
2
(
−
ϕ
2
x
1
)
(3)
H=\lambda(-9\psi_1y_1-\psi_2y_2)+\mu_1(-\phi_1x_1)+\mu_2(-\phi_2x_1) \tag{3}
H=λ(−9ψ1y1−ψ2y2)+μ1(−ϕ1x1)+μ2(−ϕ2x1)(3)
(2)根据Hamilton函数,求得协态方程为
{
λ
˙
=
−
∂
H
∂
x
=
μ
1
ϕ
1
+
μ
2
ϕ
2
,
μ
˙
1
=
−
∂
H
∂
y
1
=
9
λ
ψ
1
,
μ
˙
2
=
−
∂
H
∂
y
2
=
λ
ψ
2
(4)
\left\{\begin{matrix} \begin{aligned} \dot \lambda &= -\frac{\partial H}{\partial x}=\mu_1\phi_1+\mu_2\phi_2, \\ \dot \mu_1 &= -\frac{\partial H}{\partial y_1}=9\lambda\psi_1, \\ \dot \mu_2 &= -\frac{\partial H}{\partial y_2}=\lambda\psi_2 \end{aligned} \end{matrix}\right. \tag{4}
⎩⎪⎪⎪⎪⎪⎪⎨⎪⎪⎪⎪⎪⎪⎧λ˙μ˙1μ˙2=−∂x∂H=μ1ϕ1+μ2ϕ2,=−∂y1∂H=9λψ1,=−∂y2∂H=λψ2(4)
(3)横截条件为
{
λ
(
T
)
=
∂
Θ
∂
x
1
∣
T
=
9
,
μ
1
(
T
)
=
∂
Θ
∂
y
1
∣
T
=
−
9
,
μ
2
(
T
)
=
∂
Θ
∂
y
2
∣
T
=
−
1
(5)
\left\{\begin{matrix} \begin{aligned} \lambda(T) &= \frac{\partial \mathit \Theta}{\partial x_1} \bigg |_T = 9, \\ \mu_1(T) &= \frac{\partial \mathit \Theta}{\partial y_1} \bigg |_T = -9, \\ \mu_2(T) &= \frac{\partial \mathit \Theta}{\partial y_2} \bigg |_T = -1 \end{aligned} \end{matrix}\right. \tag{5}
⎩⎪⎪⎪⎪⎪⎪⎪⎪⎨⎪⎪⎪⎪⎪⎪⎪⎪⎧λ(T)μ1(T)μ2(T)=∂x1∂Θ∣∣∣∣T=9,=∂y1∂Θ∣∣∣∣T=−9,=∂y2∂Θ∣∣∣∣T=−1(5)
参考单兵种对多兵种作战的微分对策模型对于协态变量的分析可知,恒有
λ
(
t
)
>
0
,
μ
1
(
t
)
<
0
,
μ
2
(
t
)
<
0
,
0
≤
t
≤
T
.
\lambda(t)>0,\quad \mu_1(t)<0,\quad \mu_2(t)<0,\quad 0 \le t \le T.
λ(t)>0,μ1(t)<0,μ2(t)<0,0≤t≤T.
由鞍点条件可知,对于最优火力分配矩阵有
{
ψ
1
(
t
)
=
ψ
2
(
t
)
=
1
,
0
≤
t
≤
T
,
ϕ
1
(
t
)
+
ϕ
1
(
t
)
=
1
,
0
≤
t
≤
T
(6)
\left\{\begin{matrix} \psi_1(t)=\psi_2(t)=1,\quad 0 \le t \le T, \\ \phi_1(t)+\phi_1(t)=1,\quad 0 \le t \le T \end{matrix}\right. \tag{6}
{ψ1(t)=ψ2(t)=1,0≤t≤T,ϕ1(t)+ϕ1(t)=1,0≤t≤T(6)
且当
μ
1
(
t
)
<
μ
2
(
t
)
\mu_1(t)<\mu_2(t)
μ1(t)<μ2(t)时(即变量
μ
1
(
t
)
\mu_1(t)
μ1(t)让
H
H
H负得更少),有
ϕ
1
(
t
)
=
1
,
ϕ
2
(
t
)
=
0.
(7)
\phi_1(t)=1,\quad \phi_2(t)=0. \tag{7}
ϕ1(t)=1,ϕ2(t)=0.(7)
当
μ
1
(
t
)
>
μ
2
(
t
)
\mu_1(t)>\mu_2(t)
μ1(t)>μ2(t)时(即变量
μ
2
(
t
)
\mu_2(t)
μ2(t)让
H
H
H负得更少),有
ϕ
1
(
t
)
=
0
,
ϕ
2
(
t
)
=
1.
(8)
\phi_1(t)=0,\quad \phi_2(t)=1. \tag{8}
ϕ1(t)=0,ϕ2(t)=1.(8)
今因
μ
1
(
T
)
<
μ
2
(
T
)
\mu_1(T)<\mu_2(T)
μ1(T)<μ2(T),故在临近时刻
T
T
T 的一个时间区间内上式均成立,即存在
Δ
∈
[
0
,
T
)
\Delta \in [0,T)
Δ∈[0,T),使得
μ
1
(
t
)
<
μ
2
(
t
)
,
Δ
<
t
≤
T
(9)
\mu_1(t) < \mu_2(t), \quad \Delta < t \le T \tag{9}
μ1(t)<μ2(t),Δ<t≤T(9)
现在来考察
Δ
\Delta
Δ的最小值,并将这最小值仍记作
Δ
\Delta
Δ。如果该
Δ
>
0
\Delta>0
Δ>0,则意味着
Δ
\Delta
Δ再不能减小,从而必有
μ
1
(
Δ
)
=
μ
2
(
Δ
)
(9)
\mu_1(\Delta)=\mu_2(\Delta) \tag{9}
μ1(Δ)=μ2(Δ)(9)
由式
(
7
)
(7)
(7)有
ϕ
1
(
t
)
=
1
,
ϕ
2
(
t
)
=
0
,
Δ
<
t
≤
T
\phi_1(t)=1, \quad \phi_2(t)=0, \quad \Delta < t \le T
ϕ1(t)=1,ϕ2(t)=0,Δ<t≤T
那么,联立式
(
4
)
(4)
(4)、式
(
6
)
(6)
(6)和式
(
8
)
(8)
(8),则式
(
4
)
(4)
(4)变为
{
λ
˙
=
μ
1
,
μ
˙
1
=
9
λ
,
μ
˙
2
=
λ
,
Δ
<
t
≤
T
\left\{\begin{matrix} \begin{aligned} \dot \lambda &= \mu_1, \\ \dot \mu_1 &= 9\lambda, \\ \dot \mu_2 &= \lambda, \end{aligned} \end{matrix}\right. \quad \Delta < t \le T
⎩⎪⎨⎪⎧λ˙μ˙1μ˙2=μ1,=9λ,=λ,Δ<t≤T
考虑终值条件式
(
5
)
(5)
(5)进行求解。
此处编写MATLAB代码求解上述微分方程,仿真代码为
%% 《数理战术学》第7.3节 式(7.23)、式(7.29)
% 【delta <= t <= T】 区间
syms lambda(t) mu1(t) mu2(t) T
eq1 = diff(lambda,t)==mu2;con1 = lambda(T)==9;
eq2 = diff(mu1,t)==9*lambda;con2 = mu1(T)==-1;
eq3 = diff(mu2,t)==lambda;con3 = mu2(T)==-9;
sol1 = dsolve(eq1,eq2,eq3,con1,con2,con3);
因在 t = T t=T t=T处有 μ 1 ( t ) < μ 2 ( t ) \mu_1(t)<\mu_2(t) μ1(t)<μ2(t),此处需要考察 μ 1 ( t ) \mu_1(t) μ1(t)和 μ 2 ( t ) \mu_2(t) μ2(t)的初值。
如果有 μ 1 ( 0 ) < μ 2 ( 0 ) \mu_1(0)<\mu_2(0) μ1(0)<μ2(0),则在 t ∈ [ 0 , T ] t \in [0,T] t∈[0,T]内恒有 μ 1 ( t ) < μ 2 ( t ) \mu_1(t)<\mu_2(t) μ1(t)<μ2(t)。
如果有 μ 1 ( 0 ) > μ 2 ( 0 ) \mu_1(0)>\mu_2(0) μ1(0)>μ2(0),则在 t ∈ [ 0 , Δ ] t \in [0,\Delta] t∈[0,Δ]内恒有 μ 1 ( t ) < μ 2 ( t ) \mu_1(t)<\mu_2(t) μ1(t)<μ2(t),在 t ∈ ( Δ , T ] t \in (\Delta,T] t∈(Δ,T]内恒有 μ 1 ( t ) > μ 2 ( t ) \mu_1(t)>\mu_2(t) μ1(t)>μ2(t)。
即如下图(A)、(B)所示情况。
上述MATLAB代码已经求得 μ 1 ( t ) \mu_1(t) μ1(t)和 μ 2 ( t ) \mu_2(t) μ2(t)的表达式,因此只需再在MATLAB中编写代码求解 μ 1 ( 0 ) \mu_1(0) μ1(0)和 μ 2 ( 0 ) \mu_2(0) μ2(0)即可。
MATLAB代码为
%% 《数理战术学》第7.3节 式(7.30)
syms delta
res.lambda = subs(sol1.lambda, t, 0);
res.mu1 = subs(sol1.mu1, t, 0);
res.mu2 = subs(sol1.mu2, t, 0);
if eval(res.mu1) < eval(res.mu2)
disp('mu1 恒小于 mu2');
else
disp('mu1 不恒小于 mu2');
end
结果为
eval(res.mu1)=-52.101934085986272
eval(res.mu2)=-14.677992676220697
说明 μ 1 ( 0 ) < μ 2 ( 0 ) \mu_1(0)<\mu_2(0) μ1(0)<μ2(0),那么有 t ∈ [ 0 , T ] t \in [0,T] t∈[0,T]内 μ 1 ( t ) < μ 2 ( t ) \mu_1(t)<\mu_2(t) μ1(t)<μ2(t)。
即如下图所示情况。
也就是说,在 t ∈ [ 0 , T ] t \in [0,T] t∈[0,T]内,甲方的火力分配策略不会改变,持续攻击乙方第一类作战单位。该结果与上一篇文章的结果有所区别。
证明了书中结论:作战指数改变后,会导致最优火力分配策略改变。
此处可以看出,甲方与乙方第一类作战单位的交战强度比甲方与乙方第二类作战单位的交战强度更加“激烈”,并且考虑乙方第一类作战单位的作战指数大于乙方第二类作战单位的作战指数,说明乙方第一类作战单位的重要程度强于第二类作战单位的重要程度。
按照数理战术学理论,双方倾向于先完成交战强度“激烈”的交战格局。因此甲方先与乙方第一类作战单位是合理的。在交战过程中,先消灭交战强度“激烈”的敌方作战单位,减少对己方的威胁,保存己方实力,再消灭对己方威胁程度较低的敌方作战单位,符合常规作战认知。