matlab 黄金分割法

matlab 黄金分割法

ID:38982413

大小:172.28 KB

页数:6页

时间:2019-06-22

matlab 黄金分割法_第1页
matlab 黄金分割法_第2页
matlab 黄金分割法_第3页
matlab 黄金分割法_第4页
matlab 黄金分割法_第5页
资源描述:

《matlab 黄金分割法》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

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

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

3、[a,b]内取点:a1,a2把[a,b]分为三段。①如果f(a1)>f(a2),令a=a1,a1=a2,a2=a+0.618*(b-a);②如果f(a1)

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

5、matlab来实现,此次实验通过自学matlab的基本操作以及matlab编程语言,最后完成了此次实验。附录matlab程序代码主程序:symsxabe;%定义变量a=input('搜索区间的第一点a=');%确定搜索区间b=input('搜索区间的第二点b=');e=input('搜索精度e=');%收敛精度disp('需求的优化函数f=f(x),调用xmin=golden(f,a,b,e)');m文件:functionxmin=golden(f,a,b,e)k=0;a1=b-0.618*(b-a);%插入点的值a2=a+0.618*(b-a);whileb-a>e%

6、循环条件y1=subs(f,a1);y2=subs(f,a2);ify1>y2%比较插入点的函数值的大小a=a1;%进行换名a1=a2;y1=y2;a2=a+0.618*(b-a);elseb=a2;a2=a1;y2=y1;a1=b-0.618*(b-a);endk=k+1;end%迭代到满足条件为止就停止迭代xmin=(a+b)/2;fmin=subs(f,xmin)%输出函数的最优值fprintf('k=');%输出迭代次数disp(k);

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。