• 数值法求解微分博弈问题(〇)——定义


    引子

    关于微分博弈问题,先拿一个简单例子来说明。

    比如说猫猫捉老鼠。当猫猫要抓老鼠时,一般都朝着老鼠逃跑的方向追赶,老鼠为了躲避猫猫的追击,会不断地改变自己的行动策略。比如速度时快时慢,逃避的方向也时而变化,避免让猫猫抓到自己。那么对于此时的猫猫来说,就要采取相应的追赶策略,才能成功抓住老鼠。

    在这个过程中,猫猫和老鼠采取的不同追赶/逃避策略,即微分博弈中的博弈策略。

    “微分”,体现于猫猫和老鼠的运动过程都是通过微分方程描述的。

    “博弈”,或称“对策”,体现于自身具备的对策论基本特点,即拥有“局中人”、“策略”、“收益”三种要素。

    基本描述

    本文使用双方微分博弈来说明微分博弈的定义。

    红蓝双方非零和微分博弈可表述为下列形式:

    { x ˙ = f ( x ( t ) , u ( t ) , v ( t ) , t ) , x ( t 0 ) = x 0 , \left \{

    x˙=f(x(t),u(t),v(t),t),x(t0)=x0," role="presentation">x˙=f(x(t),u(t),v(t),t),x(t0)=x0,
    \right. {x˙=f(x(t),u(t),v(t),t),x(t0)=x0,

    式中, t t t 为博弈时间, x ( t ) x(t) x(t) 为红蓝双方的状态变量, u ( t ) \boldsymbol{u}(t) u(t) v ( t ) \boldsymbol{v}(t) v(t) 分别是甲乙双方的控制量, f \boldsymbol{f} f 为红蓝双方的非线性模型, t 0 t_0 t0 为博弈初始时刻, x 0 \boldsymbol{x}_0 x0 为博弈初值。

    红蓝双方的目标函数可表示为如下形式:

    J i ( u , v ) = Φ i ( x ( t f ) , t f ) + ∫ t 0 t f L i ( x ( t ) , u ( t ) , v ( t ) , t ) d t , \boldsymbol{J}_i (\boldsymbol{u},\boldsymbol{v}) = \Phi_i(\boldsymbol{x}(t_f),t_f) + \int^{t_f}_{t_0} L_i(\boldsymbol{x}(t),\boldsymbol{u}(t),\boldsymbol{v}(t),t) \text{d}t, Ji(u,v)=Φi(x(tf),tf)+t0tfLi(x(t),u(t),v(t),t)dt,

    式中, i = R , B i=R,B i=R,B 分别表示红蓝双方, t f t_f tf 表示博弈终止时间, Φ i ( x ( t f ) , t f ) \Phi_i(\boldsymbol{x}(t_f),t_f) Φi(x(tf),tf) 表示 Mayer 型目标函数,又称常值型目标函数; ∫ t 0 t f L i ( x ( t ) , u ( t ) , v ( t ) , t ) d t \int^{t_f}_{t_0} L_i(\boldsymbol{x}(t),\boldsymbol{u}(t),\boldsymbol{v}(t),t) \text{d}t t0tfLi(x(t),u(t),v(t),t)dt 表示 Lagrange 型目标函数,又称积分型目标函数; Φ i ( x ( t f ) , t f ) + ∫ t 0 t f L i ( x ( t ) , u ( t ) , v ( t ) , t ) d t \Phi_i(\boldsymbol{x}(t_f),t_f) + \int^{t_f}_{t_0} L_i(\boldsymbol{x}(t),\boldsymbol{u}(t),\boldsymbol{v}(t),t) \text{d}t Φi(x(tf),tf)+t0tfLi(x(t),u(t),v(t),t)dt 表示 Bolza 型目标函数,又称混合型目标函数。

    在求解目标函数的过程中,红蓝双方都期望分别控制 u \boldsymbol{u} u v \boldsymbol{v} v 使得己方目标函数最小。

    这也是微分博弈中博弈双方的终极目标。

    微分博弈的解

    微分博弈的解是指,存在控制变量 u ∗ ( t ) ∈ U \boldsymbol{u}^*(t) \in \boldsymbol{U} u(t)U v ∗ ( t ) ∈ V \boldsymbol{v}^*(t) \in \boldsymbol{V} v(t)V,使得对于控制变量 u ( t ) ∈ U \boldsymbol{u}(t) \in \boldsymbol{U} u(t)U v ( t ) ∈ V \boldsymbol{v}(t) \in \boldsymbol{V} v(t)V 满足下列关系:

    { J 1 ( u ∗ , v ∗ ) ≤ J 1 ( u , v ∗ ) , J 2 ( u ∗ , v ∗ ) ≤ J 2 ( u ∗ , v ) , \left \{

    J1(u,v)J1(u,v),J2(u,v)J2(u,v)," role="presentation">J1(u,v)J1(u,v),J2(u,v)J2(u,v),
    \right. {J1(u,v)J1(u,v),J2(u,v)J2(u,v),

    上述式子的意思是,对于 J 1 \boldsymbol{J}_1 J1 来说,红方取控制量 u ∗ ( t ) \boldsymbol{u}^*(t) u(t),使得一切取除了 u ∗ ( t ) u^*(t) u(t) 之外的控制量得到的目标函数 J 1 \boldsymbol{J}_1 J1 都不会是最小的,所以控制量必须取 u ∗ ( t ) u^*(t) u(t) 方可。同理,对于 J 2 \boldsymbol{J}_2 J2 来说,蓝方取控制量 v ∗ ( t ) \boldsymbol{v}^*(t) v(t) ,使得一切除了 v ∗ ( t ) v^*(t) v(t) 之外的控制量得到的目标函数 J 2 \boldsymbol{J}_2 J2 都不会是最小的,所以控制量必须取 v ∗ ( t ) v^*(t) v(t) 才可以。

    更进一步地,对于零和博弈来说,目标函数需要满足如下关系:

    J 1 = J 2 = J ( u , v ) = Φ ( x ( t f ) , t f ) + ∫ t 0 t f L i ( x ( t ) , u ( t ) , v ( t ) , t ) d t , \boldsymbol{J}_1 = \boldsymbol{J}_2 = \boldsymbol{J}(\boldsymbol{u},\boldsymbol{v}) = \Phi(\boldsymbol{x}(t_f),t_f) + \int^{t_f}_{t_0} L_i(\boldsymbol{x}(t),\boldsymbol{u}(t),\boldsymbol{v}(t),t) \text{d}t, J1=J2=J(u,v)=Φ(x(tf),tf)+t0tfLi(x(t),u(t),v(t),t)dt,

    而零和微分博弈的解则需要满足下述关系:

    J ( u ∗ , v ) ≤ J ( u ∗ , v ∗ ) ≤ J ( u , v ∗ ) , \boldsymbol{J}(\boldsymbol{u}^*,\boldsymbol{v}) \le \boldsymbol{J}(\boldsymbol{u}^*,\boldsymbol{v}^*) \le \boldsymbol{J}(\boldsymbol{u},\boldsymbol{v}^*), J(u,v)J(u,v)J(u,v),

    ( u ∗ , v ∗ ) (\boldsymbol{u}^*,\boldsymbol{v}^*) (u,v) 称为微分博弈的鞍点解。

    微分博弈的值

    定义 V = J ( u ∗ , v ∗ ) V = \boldsymbol{J}(\boldsymbol{u}^*,\boldsymbol{v}^*) V=J(u,v) 为微分博弈值,并引入上、下 δ \delta δ 对策构成的序列对 G = ( G δ , G δ ) G=({G^{\delta}},{G_{\delta}}) G=(Gδ,Gδ)。此处 δ = ( t f − t 0 ) / n \delta=(t_f-t_0)/n δ=(tft0)/n n n n 是较大整数。

    如果 V + = lim ⁡ δ → 0 V δ \boldsymbol{V}^{+}=\lim_{\delta \to 0}\boldsymbol{V}^\delta V+=limδ0Vδ V − = lim ⁡ δ → 0 V δ \boldsymbol{V}^{-}=\lim_{\delta \to 0}V_\delta V=limδ0Vδ 都存在且相等,则有微分博弈的值:

    V = V + = V − , \boldsymbol{V} = \boldsymbol{V}^+ = \boldsymbol{V}^-, V=V+=V,

    那么,微分博弈的值又可以表示为:

    V = min ⁡ u ∗ max ⁡ v ∗ J = max ⁡ v ∗ min ⁡ v ∗ J = J ( u ∗ , v ∗ ) . \boldsymbol{V} = \min_{\boldsymbol{u}^*} \max_{\boldsymbol{v}^*} \boldsymbol{J} = \max_{\boldsymbol{v}^*} \min_{\boldsymbol{v}^*} \boldsymbol{J} = \boldsymbol{J}(\boldsymbol{u}^*,\boldsymbol{v}^*). V=uminvmaxJ=vmaxvminJ=J(u,v).

    微分博弈和最优控制的对比

    微分对策可以被看作是由利益相反的双方进行控制的最优控制过程,即双边最优控制问题。文献1总结道:微分博弈和最优控制在1)运动方程、2)初始条件、3)终端条件、4)控制约束条件、5)状态向量、6)控制向量、7)最优控制性能指标泛函和微分博弈的收益、8)Hamilton函数定义、9)最优性必要条件九个方面是十分相似的。

    但两者区别在于:

    1. 微分博弈的控制量可能有多个,例如是双方微分博弈的话,那么控制变量就有两个;如果是多方微分博弈的话,那么控制变量就是多个了。
    2. 微分博弈要寻找最大值中的最小值和最小值中的最大值,而最优控制则是求最大值或最小值。

    总结

    至此,便以给出性能指标、控制系统微分方程约束、边界约束和路径约束的数学描述。上述四部分完整定义了最优控制问题。

    求解最优控制问题,也就是求解在满足上述三大类约束条件下使性能指标最小的优化问题。

    欢迎通过邮件联系我:lordofdapanji@foxmail.com


    1. 是兆雄. 微分对策与最优控制[J]. 自然杂志, 1983(10): 733-740+800. ↩︎

  • 相关阅读:
    ASAN入门参考
    009 gtsam/examples/ImuFactorsExample.cpp
    Shader Graph25-UV移动旋转缩放(自定义函数)
    Part2_扩展MATSIM_Subpart4_除个人车外的其他模式_第19章 新的基于动态事件的公共交通路由器&第20章 基于矩阵的PT路由器
    程序员应了解的那些事(111)~进程、线程及堆栈关系
    在vscode运行java代码
    【智能座舱】- 汽车产业的变革,电动化是上半场,而智能化则是下半场
    Logstash:如何连接到带有 HTTPS 访问的集群
    【23真题】易!题源全部定位!带讲解!
    怎么把图片转文字?掌握这个技巧,帮你解放双手
  • 原文地址:https://blog.csdn.net/Ruins_LEE/article/details/127129845