数值解单变量最优化.pptVIP

  1. 1、本文档共21页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
4.5.2 无约束最优化问题的数值解法 4.5.2.1 单变量最优化问题的数值解法(一维搜索) 一、消去法的基本概念 1 消去法的基本思想 利用单峰函数在可行域内只有一个极值点的特点,设法逐步缩小搜索最优点的区间,直至找到最优点,并达到允许的精度为止。消去法分为: 同时消去法:同时计算一批点的函数值,然后比较各函数值的大小,再消去一部分区间,直至达到精度要求。 序贯消去法:从第二个点起,每计算一个点的函数值,就与前一个点的函数值进行比较,消去部分区间后再安排下一个计算点,如此序贯进行,直至达到精度要求。 2 序贯法缩小搜索区间 设:一元函数y(x)在区间[a0,b0]内为单峰函数,若首先在[a0,b0]内任取两点x1,x2 (x1x2),并计算函数值y(x1),y(x2),这时可能的三种情况为: 根据上面分析,可将搜索区间缩小。在余下的区间内继续选择新点,比较新点的函数值,直至区间缩小到精度要求,找到最优点。 3 不定区间 当进行n次函数值的计算与比较后,可以得出这n个函数值中的最小值,f(xm)及最小点xm以及其左右的邻点xk、xr,而真正的最小点x*必落在xr与xk之内。 将xr与xk之间的区间称为不定区间ln,且ln=xr–xk 不定区间的影响因素: ①?与计算次数n有关;l0=b0–a0一定时,n ↑ ln ↓ ②与计算点的分布方式有关,即与xi的确定方法有关 显然, ln 越小,则xm与x*越接近,用xm近似x*越可靠,即精度越高。 4 区间缩短率 n次函数值的计算与比较后,不定区间与原始区间的比值 ①当l0一定时,En ↓ ln ↓ ②相同计算次数下,En越小的方案越好 二 对无约束函数的搜索——求单峰所在区间的进退算法 消去法的应用基础是目标函数f(x)在[a0,b0]内为单峰函数。 问题: (1)怎样确定f(x)为单峰函数 (2)怎样确定f(x)的单峰所在区间[a0,b0] 一般采用进退算法解决这两个问题。 据此,可以从某个给定的初始点出发,沿着函数值下降的方向逐步前进(或后退)直至发现函数值开始上升为止。由两边高中间低的三点函数值,就可以确定极小值所在的初始区间[a0,b0] 2、进退算法 (1) 选定初始点a0与步长h (2) 计算并比较y(a0)和y(a0+h),根据比较结果有前进和后退两种可能: ①?前进计算: ②后退运算: 若y(a0+h) ≥ y(a0+3h) ,令a0=a0+h,h=2h,重复上述前进运算。 例: 求函数 的极小所在区间 初始点a0=1,步长h=1 解: h =a0=1 * (1)??? y(x1) y(x2) 则 x*在[a0, x2]之内 (2)???? y(x1) y(x2) 则 x*在[x1, b0]之内 (3)y(x1) = y(x2) 则 x*在[x1, x2]之内 a0 b0 0 9 10 11 12 13 3 4 5 6 7 8 1 2 X1’ x1 ln=xr–xk 1、进退算法的基本思想 由单峰函数的性质可知,对于存在极小值的单峰函数,在极小点左边,函数值严格下降,而在极小点右边,函数值应严格上升。 前进计算:若y(a0)≥y(a0+h),则步长加倍,计算y(a0+3h)。 若y(a0+h)≤y(a0+3h),则令a0=a0,b0=a0+3h 后退运算:若y(a0)≤y(a0+h),则后退计算y(a0-h); 若y(a0-h)≥y(a0),则令a0=a0-h,b0=a0+h,停止运算。 否则继续后退。 *

文档评论(0)

smashing + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档