![数学建模与数学规划:方法、案例及编程实战(Python+COPT/Gurobi实现)](https://wfqqreader-1252317822.image.myqcloud.com/cover/577/52521577/b_52521577.jpg)
上QQ阅读APP看本书,新人免费读10天
设备和账号都新为新人
1.2.7 半定规划
半定规划(Semidefinite Programming,SDP)的目标函数为线性表达式,约束条件包含半正定约束。在给出其一般形式之前,我们先来介绍一下什么是半正定矩阵。
半正定矩阵(Positive Semidefinite Matrix):给定实对称矩阵A∈Rn×n,若对于任意n维非零实向量x,xTAx≥0恒成立,则称矩阵A为半正定矩阵。
![](https://epubservercos.yuewen.com/0DD641/31155568907421606/epubprivate/OEBPS/Images/txt002_34.jpg?sign=1739258844-yeMz44k7iUG0nNkrFRJSm6dd8ucKgTZI-0-a66d7682b6be214ef6b3906c5646b1ed)
为方便叙述,定义以下符号:
·Sn:所有n维对称矩阵的集合。
·:所有n维半正定(Positive Semidefinite,PSD)矩阵的集合。
根据文献[36][3],半定规划的标准形式如下:
![](https://epubservercos.yuewen.com/0DD641/31155568907421606/epubprivate/OEBPS/Images/txt002_36.jpg?sign=1739258844-4PZzwxz2X7HWLxPxcPCf6kwRltOwzqq9-0-be527822071544a7cfbad109bda77c54)
其中,C∈Rn×n;X∈Sn,是半正定决策变量矩阵;Ai∈Rn×n,bi∈R;符号“·”表示矩阵的内积,即,符号
表示半正定,约束
一般被称为半正定锥约束。
下面给出一个半定规划的简单例子。考虑一个最小化问题,令n=3,m=3,且给定下列参数:
![](https://epubservercos.yuewen.com/0DD641/31155568907421606/epubprivate/OEBPS/Images/txt002_40.jpg?sign=1739258844-TJ05WA0I3KvzokJHgIra62ZvGL4nbvVC-0-0db27a995ac192fc8202ba90fe5a0aba)
以及一个3×3的决策变量矩阵:
![](https://epubservercos.yuewen.com/0DD641/31155568907421606/epubprivate/OEBPS/Images/txt002_41.jpg?sign=1739258844-fLNfS9BjvaJT0JEQwcTpnSykolSdw01o-0-e7b7b55e7523ddf25a164cee90cd3410)
则上述数据就可以构建一个SDP的数值案例。注意,X为对称矩阵,因此xij=xji,∀i,j∈{1,2,3}。
接下来将其写成展开的形式。
![](https://epubservercos.yuewen.com/0DD641/31155568907421606/epubprivate/OEBPS/Images/txt002_42.jpg?sign=1739258844-3qsTX9XIs56fxSRL6kjs3UnrU2FVh2Dj-0-425a91d1cfe3450af1c976478dd1da78)
其他部分的展开也类似。最终,上述案例可以写成如下形式:
![](https://epubservercos.yuewen.com/0DD641/31155568907421606/epubprivate/OEBPS/Images/txt002_43.jpg?sign=1739258844-dGxhm5ARcI4aTHqgEjSYKmzcFcgr9aAa-0-8281afbcfd0483e29bbc869c1b0d00a4)