首页 理论教育 详解二次规划算法

详解二次规划算法

时间:2023-07-02 理论教育 版权反馈
【摘要】:设在迭代的第k步,已知可行点xk,在该点的有效集为,考虑子问题为方便起见,将原点平移到xk,即令δk=x-xk,代入式并去掉目标函数中的常数项,得等价的子问题其中,ck=c+Hxk,用求解等式约束二次规划问题的方法求出上述问题的最优解δk。

详解二次规划算法

考虑的二次规划问题为

其中,Hn阶对称矩阵(Hessian矩阵);c978-7-111-53743-4-Chapter03-110.jpgn维列向量。优化问题共有m个约束,形成可行域记为978-7-111-53743-4-Chapter03-111.jpg。此时的问题就是在满足约束条件的集合(可行域)中寻找一点x*使目标函数达到最小。

1.等式约束问题的解

等式约束二次规划问题可描述为

其中,978-7-111-53743-4-Chapter03-113.jpgbm维列向量。假设A是列满秩矩阵(即AT是行满秩矩阵)。对等式约束问题式(3-67),可求出解析解。

Lagrange方法

等式约束问题式(3-67)的Lagrange函数为

最优解的必要条件是

写为矩阵形式得

系数矩阵978-7-111-53743-4-Chapter03-117.jpg称为Lagrange矩阵。如果它是可逆的,则方程组(3-70)有唯一解。

下面来导出方程(3-70)的求解公式。假设HATH-1A非奇异,则

因此,由式(3-70)可得解的表达式

下面给出另外一种表达式,设978-7-111-53743-4-Chapter03-120.jpg是问题(3-67)的任一个可行点,即978-7-111-53743-4-Chapter03-121.jpg满足978-7-111-53743-4-Chapter03-122.jpg。而在此点处的目标函数梯度978-7-111-53743-4-Chapter03-123.jpg,利用978-7-111-53743-4-Chapter03-124.jpg978-7-111-53743-4-Chapter03-125.jpg,可将式(3-73)改写为

式(3-74)为等式约束问题(3-67)的唯一的最优解和Lagrange乘子。

2.有效集方法

本节对具有等式和不等式约束的二次规划问题的有效集方法进行叙述。首先给出有效集的定义:

定义3.1 记978-7-111-53743-4-Chapter03-127.jpg。对任意978-7-111-53743-4-Chapter03-128.jpg,称集合

是在x*处的有效约束集或起作用的约束集,简称有效集。

二次规划问题的可行域是凸集,故当H为半正定时,它是一个凸规划问题,此时,任何局部最优解都是全局最优解。有效集方法是建立在下述结论之上的。

定理3.3 对式(3-66),设可行域978-7-111-53743-4-Chapter03-130.jpg非空,978-7-111-53743-4-Chapter03-131.jpg,x*是全局最优解(K-T点)的充要条件是x*满足K-T条件,即存在978-7-111-53743-4-Chapter03-132.jpg使得

同时,还可以得到一个引理:

定理3.4设x*是式(3-66)的可行点,如果x*是下述问题

的K-T点,且相应的Lagrange乘子λ*满足

x*是式(3-66)的K-T点。

有效集方法是一种迭代算法,在每次迭代中,都以问题可行点为起点,把在该点的有效约束按照等式约束处理,而把在该点的非有效约束暂时去掉不考虑,这样,把问题转化为仅带等式约束的二次凸规划问题来求解。求得一个新的更好的可行点,再重复以上步骤,经过有限次迭代就可求得凸二次规划问题的最优解。

第一步:形成子问题,并求解。设在迭代的第k步,已知可行点xk,在该点的有效集为978-7-111-53743-4-Chapter03-136.jpg,考虑子问题(www.xing528.com)

为方便起见,将原点平移到xk,即令δk=x-xk,代入式(3-78)并去掉目标函数中的常数项,得等价的子问题

其中,ck=c+Hxk,用求解等式约束二次规划问题的方法求出上述问题的最优解δk

第二步:δk=0。这表明xk是等式约束问题(3-78)的K-T点。计算相应的Lagrange乘子λi。如果对任意978-7-111-53743-4-Chapter03-139.jpgλi≥0,则由定理3.4知,xk是原问题(3-66)的K-T点。

如果存在978-7-111-53743-4-Chapter03-140.jpg,使得λq<0,则xk不是原问题(3-66)的K-T点。这时,如果在问题(3-66)中去除约束aTqx=bq,则其后的任意可行点978-7-111-53743-4-Chapter03-141.jpg满足:978-7-111-53743-4-Chapter03-142.jpg978-7-111-53743-4-Chapter03-143.jpg978-7-111-53743-4-Chapter03-144.jpg。因此,应该让q退出978-7-111-53743-4-Chapter03-145.jpg,然后转到第一步。

第三步:δk≠0。需要分两种情况进行讨论。

(1)当xk+δk是问题(3-66)的可行点时,取xk+1=xk+δk

(2)当xk+δk不是问题(3-66)的可行点时,令xk+1=xk+αkδk,使xk+1为可行点。

下面研究如何求解步长因子αk。因为978-7-111-53743-4-Chapter03-146.jpg时,对于任意的αk都有aTiδk=0和aTixk+αkδk)=aTixk=bi,所以问题的关键为如何满足

对情况(1),必有aTiδk≥0,且式(3-80)恒成立。对情况(2),必存在aTiδk<0,故令

合并(1)~(2)两种情况可得

显然,αk∈(0,1]。当αk=1时,有效集不变;而当αk<1时,满足978-7-111-53743-4-Chapter03-150.jpgi也满足aTixk+1=bi,把此i加入978-7-111-53743-4-Chapter03-151.jpg,然后转到第一步。

根据上述分析,求解问题(3-66)的有效集方法的算法步骤总结如下:

(1)给定可行点x0,令978-7-111-53743-4-Chapter03-152.jpgk=0。

(2)求解等式约束二次规划问题(3-79),得δk。如果δk=0,转步骤(3)。否则,

1)由式(3-82)计算αk,令xk+1=xk+αkδk

2)如果αk=1,令978-7-111-53743-4-Chapter03-153.jpg

3)如果αk<1,求出使978-7-111-53743-4-Chapter03-154.jpgq,令978-7-111-53743-4-Chapter03-155.jpg

4)转步骤(4)。

(3)计算拉格朗日乘子λk=Bkgk,其中,gk=Hxk+cBk=(AkH-1ATk)-1AkH-1,而978-7-111-53743-4-Chapter03-156.jpg。取978-7-111-53743-4-Chapter03-157.jpg。如果λq≥0,则xk已是最优解,停止;否则,令978-7-111-53743-4-Chapter03-158.jpg

(4)令k+1→k,转步骤(2)。

3.初始可行点的选取

初始可行点可以用线性规划得到。随便给978-7-111-53743-4-Chapter03-159.jpg,并确定τi=-sgn978-7-111-53743-4-Chapter03-160.jpgi978-7-111-53743-4-Chapter03-161.jpg。求解下列线性规划:

其中,e=[1,…,1]T。得到的解记为978-7-111-53743-4-Chapter03-163.jpg。问题(3-83)总是可行的,它的一个初始可行点为

不难证明,如果978-7-111-53743-4-Chapter03-165.jpg是问题(3-66)的可行点,那么978-7-111-53743-4-Chapter03-166.jpg就是子问题(3-83)的最优解;反之,如果问题(3-83)的最优值为0,则问题(3-66)有可行解。从而求解式(3-83)产生原问题的一个可行解。当然,该可行解可能离QP的最优解甚远。

免责声明:以上内容源自网络,版权归原作者所有,如有侵犯您的原创版权请告知,我们将尽快删除相关内容。

我要反馈