《复合形法作业(共12页).docx》由会员分享,可在线阅读,更多相关《复合形法作业(共12页).docx(12页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、精选优质文档-倾情为你奉上优化理论与最优控制作业复合形法小组成员于童 杜娟 张健华 王楠 刘海珍 复合形法流程图一复合形法的基本原理复合形法的基本思路是在n维空间的可行域中选取K个设计点(通常取n+1k2n)作为初始复合形(多面体)的顶点。然后比较复合形各顶点目标函数的大小,其中目标函数值最大的点作为坏点,以坏点之外其余各点的中心为映射中心,寻找坏点的映射点,一般说来此映射点的目标函数值总是小于坏点的,也就是说映射点优于坏点。这时,以映射点替换坏点与原复合形除坏点之外其余各点构成K个顶点的新的复合形。如此反复迭代计算,在可行域中不断以目标函数值低的新点代替目标函数值最大的坏点从而构成新复合形,
2、使复合形不断向最优点移动和收缩,直至收缩到复合形的各顶点与其形心非常接近、满足迭代精度要求时为止。最后输出复合形各顶点中的目标函数值最小的顶点作为近似最优点。补充:关于复合形法定点数目的选取数目多少的选取,要视具体情况而定,一般说来,为了防止迭代过程中产生降维,顶点数目取多一些较好。因为只要在k个顶点中有n+1个顶点所构成的n个矢量线性无关,搜索就不会在降维的空间里进行。所以k值大些,降维的可能性就小些。但是从另一方面看,顶点数目多,显然会降低计算速度。为此,对于优化问题维数n5的优化问题,一般应适当减少顶点数目,而取k=(1.251.5)n(取整)。当然,顶点的最少数目不得低于n+1.二复合
3、形法的优缺点复合形法不需要计算目标函数的导数,也不进行一维搜索,因此对目标函数和约束函数都没有特殊的要求,适用范围较广。复合形法的收敛速度较慢,特别当目标函数的维数较高和约束条件的数目增多时,这一缺点尤为突出。另外,复合形法不能用于求解具有等式约束的优化问题。三问题求解下面分别用复合形法和matlab工具箱分别进行求解并比较计算结果问题一:1-1函数的三维立体图1-2.复合形法求解寻优趋势图1-3.求解结果对照表方法复合形法Matlab工具箱x11.00041x21.00021f1.8048e-070问题二:2-1函数的三维立体图2-2.复合形法求解寻优趋势图2-3.求解结果对照表方法复合形法
4、Matlab工具箱x10.9950-0.1431* e-05x20-0.1431* e-05f0.99508.1197e-10问题三:2-1函数的三维立体图3-2.复合形法求解寻优趋势图3-3.求解结果对照表方法复合形法Matlab工具箱x1-2.95611.5345x21.05581.5345f0.99031.9860四结果分析对于求解此类问题,做出目标函数的大致图形(当然只限于三维以内)有利于我们判断函数的极值点位置以及估计函数值,同时也可以用来检验计算结果的正确性。对于问题一,两种求解方法的计算结果基本相同,但对于问题二和问题三的求解结果为何不同,我们猜想应该是matlab工具箱的求解方
5、法对求解函数有着特殊的要求所导致的,例如,要求函数可导或者连续等。附录:程序(只给出问题三的求解程序,其他问题的求解类似)一复合形法求解程序如下:syms s tf=-(sin(sqrt(s2+t2)2-0.5)/(1+0.001*(s2+t2)2+0.5;g=s+4 4-s t+4 4-t;r=rand(1,6);m=-4+(4-(-4)*r;X=reshape(m,2,3)x,maxf,trace_value,trace_meanvalue=Fuhexing(f,g,X,1.3,0.7,1,0.7,s t);xmaxftvx,tvy=size(trace_value);fxx=1:tvy-
6、1;fyy=ones(1,tvy-1);fyy=maxf*fyy;plot(fxx,trace_value(1,2:tvy),green,fxx,trace_meanvalue(1,2:tvy),blue,fxx,fyy,red)legend(最大值,平均值,终值)gridfunction x,maxf,trace_value,trace_meanvalue=Fuhexing(f,g,X,alpha,sita,gama,beta,var,eps) %f 目标函数%g 约束函数 %X 初始复合形 %alpha 反射系数 %sita 压缩系数 %gama 扩展系数 %beta 收缩系数 %var
7、自变量向量 %eps 精度 %x 目标函数取最小值时的自变量 %minf 目标函数的最小值 trace_value=0; %用于记录最大值的轨迹 trace_meanvalue=0; %用于记录平均值的轨迹 N=size(X); n=N(2); %n 为复合形的顶点个数 FX=zeros(1,n); %用于存放复合形的函数值 if nargin=8 eps=1.0e-6; end N=size(X); n=N(2); Fx=zeros(1,n);while 1 %一直执行,知道找到满足收敛条件后用 break 跳出循环 for i=1:n FX(i)=subs(f,var,X(:,i); %求
8、出复合形的函数值 end XS,IX=sort(FX); %对 FX 从大到小排序 Xsorted=X(:,IX); %Xsorted 为排好序的 X px=(sum(Xsorted,2)-Xsorted(:,1)/(n-1); %求的除最小值以为的平均值 trace_meanvalue=trace_meanvalue,sum(FX)/n; Fpx=subs(f,var,px); %求的平均值的函数值 aaa=subs(f,var,Xsorted(:,n); trace_value=trace_value,aaa; SumF=sqrt(sum(FX-Fpx).2)/(n-1); %计算收敛值
9、if SumF=0 %在约束条件内 bcon_1=0; else cof_alpha=0.5*cof_alpha; %如不在约束条件内,则循环,直到到达约束条件 end end fx2=subs(f,var,x2); %反射点函数值 反射部分结束 if fx2XS(n) %如果反射部分优于最优值 则进行扩张操作 cof_gama=gama; x3=x2+cof_gama*(x2-px); %扩张 gx3=subs(g,var,x3); fx3=subs(f,var,x3); if min(gx3)=0 %如果符合边界, if fx3XS(n) count=1; %优于最优值 else coun
10、t=2; %比最优值差 end else count=3; %不符合边界 end %扩张结束 if count=1 Xsorted(:,1)=x3; %用扩张点代替最差点 X=Xsorted; continue else Xsorted(:,1)=x2; %用反色点代替最差点 X=Xsorted; continue end else %如果反射部分 比最优值差 if fx2XS(2) %如果反射部分大于次坏值,即反射部分优于次坏值 则反射点代替 Xsorted(:,1)=x2; X=Xsorted; continue else if fx2XS(1) %如果反射点比最差点好,比次差点差 这用反
11、射点代替最差点 Xsorted(:,1)=x2; cof_beta=beta; bcon_3=1; while bcon_3=0 %符合边界值 bcon_3=5; %退出收缩 else cof_beta=0.5*cof_beta; bcon_3=bcon_3+1; %最多收缩系数调整 4 次 end end if min(gx4)=0 %符合边界值 fx4=subs(f,var,x4); FNnew=subs(f,var,Xsorted(:,1); %计算最差点函数值 if fx4FNnew %如果收缩值优于最差值 Xsorted(:,1)=x4; %收缩值代替最差值 X=Xsorted; c
12、ontinue else %收缩值比最差值差,则对所有点进行压缩 x0=Xsorted(:,n); for i=1:n Xsorted(:,i)=x0+sita*(Xsorted(:,i)-x0); end end else %如果收缩后的值不符合边界 x0=Xsorted(:,n); for i=1:n Xsorted(:,i)=x0+sita*(Xsorted(:,i)-x0); X=Xsorted; %用压缩值代替原复合形 continue end end else %如果反射值比最差点还要差 x0=Xsorted(:,n); for i=1:n Xsorted(:,i)=x0+sita
13、*(Xsorted(:,i)-x0); X=Xsorted; %用压缩值代替原复合形 continue end end end end end X=Xsorted; end maxf=subs(f,var,x);二matlab工具箱求解命令如下:x0=1;1;VLB=-4;-4;VUB=4;4;x,fval=fmincon(fun,x0,VLB,VUB)X Y=meshgrid(-4:0.01:4,-4:0.01:4);Z=0.5-(sin(X.2+Y.2).0.5).2-0.5)./(1+0.001.*(X.2+Y.2).2;mesh(X,Y,Z);shading interp;function f=fun(x)f=-0.5+(sin(x(1)2+x(2)2).(1/2).2-0.5)/(1+0.001*(x(1)2+x(2)2)2;专心-专注-专业