黄金分割法-进退法-原理及流程图.pdf
《黄金分割法-进退法-原理及流程图.pdf》由会员分享,可在线阅读,更多相关《黄金分割法-进退法-原理及流程图.pdf(11页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、1黄金分割法的优化问题1 1黄金分割法基本思路:黄金分割法基本思路:黄金分割法适用于a,b区间上的任何单股函数求极小值问题,对函数除要求“单谷”外不做其他要求,甚至可以不连续。因此,这种方法的适应面非常广。黄金分割法也是建立在区间消去法原理基础上的试探方法,即在搜索区间a,b内适当插入两点 a1,a2,并计算其函数值。a1,a2 将区间分成三段,应用函数的单谷性质,通过函数值大小的比较,删去其中一段,是搜索区间得以缩小。然后再在保留下来的区间上作同样的处理,如此迭代下去,是搜索区间无限缩小,从而得到极小点的数值近似解。2 2 黄金分割法的基本原理黄金分割法的基本原理一一维搜索是解函数极小值的方
2、法之一,其解法思想为沿某一已知方向求目标函数的极小值点。一维搜索的解法很多,这里主要采用黄金分割法法。该方法用不变的区间缩短率代替斐波那契法每次不同的缩短率,从而可以看成是斐波那契法的近似,实现起来比较容易,也易于人们所接受。黄金分割法是用于一元函数 f(x)在给定初始区间a,b内搜索极小点*的一种方法。它是优化计算中的经典算法,以算法简单、收敛速度均匀、效果较好而著称,是许多优化算法的基础,但它只适用于一维区间上的凸函数6,即只在单峰区间内才能进行一维寻优,其收敛效率较低。其基本原理是:依照“去劣存优”原则、对称原则、以及等比收缩原则来逐步缩小搜索区间7。具体步骤是:在区间a,b内取点:a1
3、,a2 把a,b分为三段。如果 f(a1)f(a2),令a=a1,a1=a2,a2=a+r*(b-a);如果 f(a1)f(a2),令 b=a2,a2=a1,a1=b-r*(b-a),如果(b-a)/b和(y1-y2)/y2都大于收敛精度重新开始。因为a,b为单峰区间,这样每次可将搜索区间缩小倍或倍,处理后的区间都将包含极小点的区间缩小,然后在保留下来的区间上作同样的处理,如此迭代下去,将使搜索区a,b逐步缩小,直到满足预先给定的精度时,即获得一维优化问题的近似最优解。黄金分割法原理如图所示,3 3 程序流程如下:程序流程如下:4 4 实验所编程序框图实验所编程序框图给定 a=-3,b=5,收
4、敛精度开始a*=(a+b)/2是(b-a)/b和 y2-y1/y2=y2a1=b-r*(b-a)y1=f(a1)a2=a+r*(b-a)y2=f(a2)否结束#include#include#define f(x)x*x+2*xdouble calc(double*a,double*b,double e,int*n)double x1,x2,s;if(fabs(*b-*a)f(x2)*a=x1;else*b=x2;*n=*n+1;s=calc(a,b,e,n);return s;main()double s,a,b,e;int n=0;scanf(%lf%lf%lf,&a,&b,&e);s=c
5、alc(&a,&b,e,&n);printf(a=%lf,b=%lf,s=%lf,n=%dn,a,b,s,n);5 5 程序运行结果如下列图:程序运行结果如下列图:2 2 进退法进退法1 1算法原理算法原理进退法是用来确定搜索区间包含极小值点的区间的算法,其理论依据是:f(x)为单谷函数只有一个极值点,且a,b为其极小值点的一个搜索区间,对于任意如果fx1 fx2,则a,x2为极小值的搜索区间,如果fx1 fx2,x1,x2a,b,则x1,b为极小值的搜索区间。因此,在给定初始点x0,及初始搜索步长h的情况下,首先以初始步长向前搜索一步,计算fx0h。(1)如果fx0 fx0h则可知搜索区间为
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 黄金分割 进退 原理 流程图
限制150内