matlab 黄金分割法_第1页
matlab 黄金分割法_第2页
matlab 黄金分割法_第3页
matlab 黄金分割法_第4页
matlab 黄金分割法_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、黄金分割法 东南大学机械学院*一 黄金分割法基本思路黄金分割法适用于a,b区间上的任何单谷函数求极小值问题,对函数除要求“单谷”外不做其他要求,甚至可以不连续。因此,这种方法的适应面非常广。黄金分割法也是建立在区间消去法原理基础上的试探方法,即在搜索区间a,b内适当插入两点a1,a2,并计算其函数值。a1,a2将区间分成三段,应用函数的单谷性质,通过函数值大小的比较,删去其中一段,是搜索区间得以缩小。然后再在保留下来的区间上作同样的处理,如此迭代下去,是搜索区间无限缩小,从而得到极小点的数值近似解。二 黄金分割法的基本原理一维搜索是解函数极小值的方法之一,其解法思想为沿某一已知方向求目标函数的

2、极小值点。一维搜索的解法很多,这里主要采用黄金分割法(0.618法)。该方法用不变的区间缩短率0.618代替斐波那契法每次不同的缩短率,从而可以看成是斐波那契法的近似,实现起来比较容易,也易于人们所接受。黄金分割法是用于一元函数f(x)在给定初始区间a,b内搜索极小点xmin的一种方法。它是优化计算中的经典算法,以算法简单、收敛速度均匀、效果较好而著称,是许多优化算法的基础,但它只适用于一维区间上的凸函数,即只在单峰区间内才能进行一维寻优,其收敛效率较低。其基本原理是:依照“去劣存优”原则、对称原则、以及等比收缩原则来逐步缩小搜索区间。具体步骤是:在区间a,b内取点:a1 ,a2 把a,b分为

3、三段。 如果f(a1)>f(a2),令a=a1,a1=a2,a2=a+0.618*(b-a); 如果f(a1)<f(a2) ,令b=a2,a2=a1,a1=b-0.618*(b-a);如果(b-a)/b和(y1-y2)/y2都大于收敛精度重新开始循环。因为a,b为单峰区间,这样每次可将搜索区间缩小0.618倍,处理后的区间都将包含极小点的区间缩小,然后在保留下来的区间上作同样的处理,如此迭代下去,将使搜索区a,b逐步缩小,直到满足预先给定的精度时,即获得一维优化问题的近似最优解。插入点原理图如下:三 实验程序框图四 程序运行结果例如:f=x2+2*x,给定搜索区间-3,5,求此函数

4、的极小点。1. 首先运行主程序:2.会提示你输入各个变量的值:2. 输完各个变量的值,以及所求函数后,再运行 :xmin=golden(f,a,b,e)系统调用m文件的内容,这时候matlab就会输出函数的最优值。即该函数的最小值点在x=-1,最小点的函数值fmin=-1,一共经过了29次迭代。五 实验心得 通过此次实验,加深了对黄金分割法的基本理论和算法框图及步骤的全面理解,掌握了matlab的使用方法。此方法适用于一维函数求最小值的问题。原理比较简单,稍微复杂一点的就是缩小区间的时候怎么进行换名,另外一个难点就是如何用matlab来实现,此次实验通过自学matlab的基本操作以及matla

5、b编程语言,最后完成了此次实验。 附录matlab程序代码主程序:syms x a b e; %定义变量a=input('搜索区间的第一点a='); %确定搜索区间b=input('搜索区间的第二点b=');e=input('搜索精度ne='); %收敛精度disp('需求的优化函数f=f(x),调用xmin=golden(f,a,b,e)');m文件:function xmin=golden(f,a,b,e)k=0;a1 =b-0.618*(b-a); %插入点的值a2 =a+0.618*(b-a);while b-a>e %循环条件 y1=subs(f,a1); y2=subs(f,a2);if y1>y2 %比较插入点的函数值的大小 a=a1; %进行换名 a1=a2; y1=y2; a2=a+0.618*(b-a);else b=a2; a2=a1; y2=y1; a1=b-0.618*(b-a);endk=k+1;end %迭代到满足条件

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论