机械优化设计报告(5)1基于MATLAB可行方向法求极值的实现姓名:xxx学号:xxx(北京理工大学机械与车辆学院车辆工程,北京100081)摘要:在工程实际的优化设计中,随着设计变量数和约束条件数的增加,随机方向搜索法和复合形法等直接优化解法的求解效率会偏低。可行方向法,顾名思义,一种始终在可行域内寻找下降方向的搜索法,以其收敛速度快、效果好的优点已成为求解约束非线性问题的一种有代表性的直接解法,同时也是求解大型约束优化问题的主要方法之一。本文将简单介绍可行方向法的数学思想,采用线性规划法和约束最优步长法编写MATLAB程序,最后通过算例完成对优化问题的求解。关键字:可行方向法;MATLAB;优化方法。1.可行方向法的基本数学思想1.1可行方向法的搜索策略可行方向法迭代的第一步都是从可行域的某一初始点(0)X出发,沿负梯度(0)()fX方向移至某一个或J个起作用约束面的交集()kX上。以后的搜索路线和迭代计算可根据约束函数和目标函数的不同性状,分别采用以下三种不同策略继续搜索。1)由点()kX出发,沿可行方向作一维最优化搜索,若所得新点(1)kX在可行域内,则再沿(1)()kfX方向作一维最优化搜索;若所得的新点不在可行域内,则将它移至约束面上再反复重复上述步骤,若(1)()kfX,则停止迭代,如图1.1所示。2)由点()kX出发,沿可行方向作一维最优化搜索,若所得新点(1)kX在可行域外,则沿可行方向以最大步长到达另一个约束面上一点,将该点作为迭代点(1)kX进行反复搜索,直至满足给出的K-T条件,如图1.2所示。机械优化设计报告(5)23)沿着约束面进行搜索。对于只具有线性约束的非线性规划问题,如图1.3所示,从点()kX出发,沿约束面移动,在有限的几步内即可搜索到约束最优点;对于非线性约束函数,如图1.4所示情况,就是沿着约束面的切线移动,但这样将会进入非可行域,使问题变得复杂。此时,应将进入非可行域的新点X设法调整回约束边界。调整方法为:先规定约束面容差0,建立新的约束边界,然后将已经离开约束面的X点沿起作用约束的负梯度方向()gX返回约束面上,计算公式为(1)()ktXXgX式中,t为调整步长,可以用试探法确定,也可以用下式估计,使其回到约束边界上。()()()tTgXgXgX(1-1)图1.1图1.2机械优化设计报告(5)3图1.3图1.4不管采用哪种搜索方法都要进行两条决策:一是产生一个适用的可行方向()kd;二是沿()kd方向确定一个不会越出可行域的适当的步长因子。1.2产生可行方向和步长的数学原理可行方向要保证沿该方向作微小移动后所得的新点是可行点,且目标函数值有所下降。显然可行方向应满足可行和下降两个条件。这里从数学原理的角度分析可行性和下降性。1.2.1可行性设()kX为可行域D中的一个点,即()kXD。对于某一方向()kd来说,若存在数00A,使其对于任意的A0(0)AA,式1-2均成立,则称方向()kd对()kX点满足可行性条件。()()kkXAdD(1-2)若点()kX在可行域内,即()kX为内点,则任何方向都满足可行性条件。当点()kX在某一约束边界上时,如图1.5所示,该约束面就是起作用约束。当点()kX位于一个约束面上时,如图1.6所示,作出()kX初起作用约束的梯度机械优化设计报告(5)4()gX和切线,可见只要()kd与起作用约束的梯度成直角或钝角,则可指向可行域内,满足可行性条件。当()kX同时处于J个约束面时,就要求()kd与这J个约束面的梯度均垂直或交成钝角,如图1.6所示,写成数学表达式如下:()()()0(1,2,,)TkkjgXdjJ式中,J为起作用约束的个数。上式称为可行性条件。图1.5图1.61.2.2下降性沿一方向搜索时,要求下降愈快愈好。对某一点来说,负梯度方向为最速下降方向。如果负梯度方向是可行方向,那么负梯度方向是最有利的方向;否则为了保证目标函数值有所下降,至少要使搜索方向()kd与目标函数的负梯度方向成锐角或与梯度方向成钝角,写成数学表达式为()()()0TkkfXd该式称为下降性条件。如图1.7所示,可行下降方向显然位于点()kX约束面的切线与目标函数等值线的切线所围成的扇形区域内,推广到一般的情况就是可行方向在目标函数超等值面的超切面和J个起作用约束的超切面所围成的超锥体内。该区域称为可行下降方向区。机械优化设计报告(5)5图1.7综上所述,当点()kX位于J个起作用的约束面上时,满足()()()()()0(1,2,,)()0TkkjTkkgXdjJfXd(1-3)式中,()kd即为可行方向。1.3可行方向的产生本文采用线性规划法来产生可行方向,用约束最优步长确定最优步长,为后面编制MATLAB程序做理论基础。本节先阐述线性规划法,下节再对约束最优步长法进行描述。线性规划法对包含线性和非线性的不等式约束的最优化问题都适用,但不允许有等式约束。其基本原理是将具有一阶连续偏导数的目标函数和约束条件在()kX点用Taylor展开式展成线性近似函数(一次项),并用这些线性近似函数代替目标函数和它的约束条件,使得问题线性化。这样min()fX成为()()()min{()[()]()}()kkTknfXfXXXXR机械优化设计报告(5)6约束条件()0ugX变为()()()()[()]()0(1,2,,)kkTkuugXgXXXum用(1)kX代替上式中的X,得到()()()min{()[()]}kkkTkfXfXds.t.()()()()[()]0(1,2,,)kkkTukugXgXdum式中,()()kfX、()()kugX为常数,只有搜索方向()kd和k是未知量。当迭代点()kX位于J个起作用约束边界的交点上时,问题就变成求解线性规划问题:()()min[()]nkkTXRfXds.t.()()[()]0(1,2,,J)kkTugXdu式中,()kd只起到方向作用,故规定其向量的模是有界的,也就是规定()kd每个分量的绝对值不大于1,即()j||1(1,2,,)kdjn由于可行方向还得满足式1-3的可行性和下降性条件,故确定可行方向的线性规划数学模型如下:()()()min()[()]nkkkTXRZdfXds.t.()()[()]0kkTfXd()()[()]0(1,2,,J)kkTugXdu()j11(1,2,,)kdjn(1-4)求解后,可得到迭代方向()kd,作为下一步的搜索方向。1.4最优步长的确定由线性规划法求的可行方向()kd后,由()kX出发,找到该方向上的可行新点(1)kX。新点必须满足两个条件,一是新点(1)kX必须还是可行点,二是目标函数值具有最大的下降量。约束最优步长即可满足这两点,可用以下一维搜索法求机械优化设计报告(5)7解:()()min()kkfXds.t.max0式中,()()maxsup{|()0(1,2,,)}kkugXdum。2.可行方向法的迭代过程和算法流程图2.1迭代过程1)输入收敛精度;2)形成可行初始点(0)X,令k=1;3)确定起作用约束下标集合,()()(){|()0(1)}kkiEXigXim;4)判断E是否为空集,若是空集则说明()kX在可行域内,转步骤5);否则说明()kX在约束边界上,转步骤6);5)判断是否满足终止条件()()kfX,若满足,转步骤10);若不满足,则取搜索方向为()()()kkdfX,转步骤8);6)采用线性规划法,用式1-4求解后,得到可行方向()kd;7)判断0kZ是否成立,若成立,则转步骤10)输出,停机结束;若不成立,则继续下一步;8)采用约束最优步长法进行一维搜索,得到新点(1)kX;9)令k=k+1,转步骤3);10)输出*()kXX,**()ffX,停机结束。2.2算法流程图算法流程图如图2-1。机械优化设计报告(5)8开始结束(0)k=1X给定,选初始可行点,()()(){|()0(1)}kkiEXigXim确定起作用的约束集()()kEX?()()()()()()()()()jmin()[()]..[()]0[()]0(1,2,,J)11(1,2,,)kkkkTkkTkkTukdZdfXdstfXdgXdudjn求解线性规划,确定可行方向()()?kfX()()()kkdfX*()kXX0?kZk()()max()()maxmin()..0sup{|()0(1,2,,)}kkkkufXdstgXdum求解一维搜索问题,得到约束步长其中()(1)()1kkkkXXdkkNYNYYN图2-1可行方向法的算法流程图3.可行方向法的MATLAB程序functionkxfxf(x0)eps=1.0e-6;%刚开始给的x0为行向量x0=transpose(x0);funcsz=length(x0);G1=G;fork=1:1:50机械优化设计报告(5)9%'f(x)梯度:'sf=diff_val(x0);sf=eval('sf');%'f(x)梯度范数:'norm_s=norm(diff_val(x0));GL=length(G);G1=G;G_copy=G;fori=1:1:GLg=subs(G1(i,:),x,x0);G1(i,:)=g;endG_zero=eval('G1');fori=GL:-1:1ifabs(G_zero(i,:))0.1G_zero(i,:)=[];G_copy(i,:)=[];endendI=size(G_zero,1);add=-ones(I,1);%根据E是否为空集(I==0)确定不同情况下的搜索方向ifI==0ifnorm_s=3'最优解:''自变量值:'x0'目标函数值:'f=fval(x0)'迭代次数:'k'======================================================'returnelsed0=-diff_val(x0);%线性搜索d0=transpose(d0);vmax=gmin(x0,d0);h=fmin(x0,d0,vmax);x0=x0+h*d0;endelse机械优化设计报告(5)10%线性规划grad=jacobian(G_copy,x);G_zero=subs(grad,x,x0);Ac=[sf;G_zero];lb=-1*ones(sz,1);ub=ones(sz,1);p=zeros(I+1,1);dz=size(1,sz);c=sf*dz';[dz,mn,m1,m2,m3]=linprog(c,Ac,p,[],[],lb,ub);z0=sf*dz;z0=abs(z0);ifz00.01'最优解:''自变量值:'x0'目标函数值:'f=fval(x0)'迭代次数:'k'======================================================'returnelsed0=dz;%线性搜索vmax=gmin(x0,d0);h=fmin(x0,d0,vmax);x0=x0+h*d0;endendend程序中用到一些回调函数,简单列举如下,.m文件详细内容见附录一。func记录函数及其自变量信息fval(x0)计算函数在x0处得函数值gmin(x0,d0)求函数在满足约束条件下的k最小值fmin(x0,d0,vmax)求函数在[0,vmax]上的最小值机械优化设计报告(5)11diff_val(x0)计算函数在x0处得导数值。4.利用MATLAB求解实例4.1实例本文以课本例题5.3为例来验证可行方向法在MATLAB里的实现。已知目标函数212()412fXxx