强wolfe非线性搜索 dfp实验报告剖析Word文档下载推荐.docx
- 文档编号:14726437
- 上传时间:2022-10-24
- 格式:DOCX
- 页数:8
- 大小:132.75KB
强wolfe非线性搜索 dfp实验报告剖析Word文档下载推荐.docx
《强wolfe非线性搜索 dfp实验报告剖析Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《强wolfe非线性搜索 dfp实验报告剖析Word文档下载推荐.docx(8页珍藏版)》请在冰豆网上搜索。
特别是当迭代点原理最优点时,精确搜索通常不是十分有效和合理的,对于许多优化算法,其收敛速度并不依赖于精确搜索过程。
因此,既能保证目标函数具有可接受的下降量又能使最终形成的迭代序列收敛的非精确搜索变得越来越流行,本次实验主要介绍里面的强wolfe准则。
wolfe准则是指,给定,求使得下面两个不等式同时成立:
其中,而当(1.11)改成另一个条件时这样当充分小时,可保证(1.12)变成近似精确线搜索。
(1.10)和(1.12)称强wolfe准则。
强wolfe准则表明,由该准则到新的迭代点在的某一邻域内且使目标函数值有一定的下降量。
由于,可以证明wolfe准则的有限终止性,即步长的存在性,有定理:
设有下界且,令,则存在一个区间【a,b】,0ab,使每个均满足(1.10)和(1.12)DFP算法:
变尺度法是在牛顿法的基础上发展起来的,它和梯度法亦有密切关系.变尺度法避免了Newton法在每次迭代都要计算目标函数的Hesse矩阵和它的逆矩阵而导致随问题的维数增加计算量迅速增加.DFP算法是变尺度法中一个非常好的算法.DFP算法首先是1959年由Davidon提出的后经Fletcher和Powell改进,故名之为DFP算法,它也是求解无约束优化问题最有效的算法之一.
(1)变尺度法基本原理在Newton法中,基本迭代公式,其中,于是有
(1)其中是初始点,和分别是目标函数在点的梯度和Hesse矩阵.为了消除这个迭代公式中的Hesse逆矩阵,可用某种近似矩阵来替换它,即构造一个矩阵序列去逼近Hesse逆矩阵序列此时式
(1)变为事实上,式中无非是确定了第k次迭代的搜索方向,为了取得更大的灵活性,我们考虑更一般的的迭代公式
(2)其中步长因子kt通过从出发沿作直线搜索来确定.式
(2)是代表很长的一类迭代公式.例如,当(单位矩阵)时,它变为最速下降法的迭代公式.为使确实与近似并且有容易计算的特点,必须对附加某些条件:
第一,为保证迭代公式具有下降性质,要求中的每一个矩阵都是对称正定的.理由是,为使搜索方向是下降方向,只要成立即可,即成立.当对称正定时,此公式必然成立,从而保证式
(2)具有下降性质.第二,要求之间的迭代具有简单形式.显然,(3)是最简单的形式了.其中称为校正矩阵,式(3)称为校正公式.第三,必须满足拟Newton条件.即:
(4)为了书写方便也记于是拟Newton条件可写为(5)由式(3)和(5)知,必须满足或(6)
(2)DFP算法DFP校正是第一个拟牛顿校正是1959年由Davidon提出的后经Fletcher和Powell改进故名之为DFP算法它也是求解无约束优化问题最有效的算法之一.DFP算法基本原理考虑如下形式的校正公式(7)其中是特定n维向量,,是待定常数.这时,校正矩阵是.现在来确定.根据拟Newton条件,必须满足(6),于是有或.满足这个方程的待定向量和有无穷多种取法,下面是其中的一种:
,注意到和都是数量,不妨取,同时定出,。
.将这两式代回(5.32)得(8)这就是DFP校正公式.1.DFP算法迭代步骤在拟Newton算法中,只要把第五步改为计算式(8)而其他不变,该算法就是DFP算法了.但是由于计算中舍去误差的影响,特别是直线搜索不精确的影响,可能要破坏迭代矩阵的正定性,从而导致算法失效.为保证的正定性,采取以下重置措施:
迭代次后,重置初始点和迭代矩阵,即,以后重新迭代.已知目标函数及其梯度,问题的维数n,终止限.
(1)选定初始点.计算.
(2)置.(3)作直线搜索;
计算.(4)判别终止准则是否满足:
若满足,则打印,结束;
否转(5).(5)若,则置,转
(2);
否则转(6).(6)计算,置,转(3).【实验环境】Windowsxp,matlab2007二、实验内容:
【实验方案】1:
根据强wolfe准则和dfp算法建立wolfe.m文件编写matlab程序代码。
调用函数,带入不同的初始点,规定精确度,计算结果。
【实验过程】
(实验步骤、记录、数据、分析)1:
代入目标函数为f=(x
(1)2-x
(2)2+(x
(1)-1)2;
选取初始点0,0,2,2,2,0.精确度分别为1e4,1e5.【实验结论】
(结果)得到最优点是1.0000,1.0000最优值和迭代次数:
精确度|初始点0,02,22,01e48.3532e-013|72.9957e-014|132.8877e-013|151e58.3532e-013|72.9957e-014|132.8877e-013|15分析:
DFP算法只需计算一阶偏导数,无需计算二阶偏导数及其逆矩阵,对目标函数的初始点选择均无严格要求,收敛速度快。
【实验小结】
(收获体会)运用强wolfe准则和dfp算法解决无约束问题方便快捷,步骤不用太繁琐。
解决高维函数也是不错的选择。
三、指导教师评语及成绩:
评语评语等级优良中及格不及格1.实验报告按时完成,字迹清楚,文字叙述流畅,逻辑性强2.实验方案设计合理3.实验过程(实验步骤详细,记录完整,数据合理,分析透彻)4实验结论正确.成绩:
指导教师签名:
批阅日期:
附录1:
源程序functionx,val,k=dfp(fun,gfun,x0)%功能:
用DFP算法求解无约束问题:
minf(x)%输入:
x0是初始点,fun,gfun分别是目标函数及其梯度%输出:
x,val分别是近似最优点和最优值,k是迭代次数maxk=1e8;
%给出最大迭代次数rho=0.55;
sigma=0.4;
epsilon=1e-5;
k=0;
n=length(x0);
Hk=eye(n);
while(kmaxk)gk=feval(gfun,x0);
%计算梯度if(norm(gk)epsilon),break;
end%检验终止准则dk=-Hk*gk;
%解方程组,计算搜索方向m=0;
mk=0;
while(m20)%用Armijo搜索求步长if(feval(fun,x0+rhom*dk)0)Hk=Hk-(Hk*yk*yk*Hk)/(yk*Hk*yk)+(sk*sk)/(sk*yk);
endk=k+1;
x0=x;
endval=feval(fun,x0);
functionf=fun(x)f=(x
(1)2-x
(2)2+(x
(1)-1)2;
functiongf=gfun(x)gf=4*x
(1)*(x
(1)2-x
(2)+2*(x
(1)-1),-2*(x
(1)2-x
(2);
clearx0=0,0;
x,val,k=dfp(fun,gfun,x0)附录2:
实验报告填写说明1实验项目名称:
要求与实验教学大纲一致。
2实验目的:
目的要明确,要抓住重点,符合实验教学大纲要求。
3实验原理:
简要说明本实验项目所涉及的理论知识。
4实验环境:
实验用的软、硬件环境。
5实验方案(思路、步骤和方法等):
这是实验报告极其重要的内容。
概括整个实验过程。
对于验证性实验,要写明依据何种原理、操作方法进行实验,要写明需要经过哪几个步骤来实现其操作。
对于设计性和综合性实验,在上述内容基础上还应该画出流程图、设计思路和设计方法,再配以相应的文字说明。
对于创新性实验,还应注明其创新点、特色。
6实验过程(实验中涉及的记录、数据、分析):
写明具体实验方案的具体实施步骤,包括实验过程中的记录、数据和相应的分析。
7实验结论(结果):
根据实验过程中得到的结果,做出结论。
8实验小结:
本次实验心得体会、思考和建议。
9指导教师评语及成绩:
指导教师依据学生的实际报告内容,给出本次实验报告的评价。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 强wolfe非线性搜索 dfp实验报告剖析 wolfe 非线性 搜索 dfp 实验 报告 剖析