优化设计方法大作业.docx

上传人:太** 文档编号:35623579 上传时间:2022-08-22 格式:DOCX 页数:6 大小:128.26KB
返回 下载 相关 举报
优化设计方法大作业.docx_第1页
第1页 / 共6页
优化设计方法大作业.docx_第2页
第2页 / 共6页
点击查看更多>>
资源描述

《优化设计方法大作业.docx》由会员分享,可在线阅读,更多相关《优化设计方法大作业.docx(6页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、优化设计方法第一次大作业(一维搜寻问题)学 院:航空制造工程学院专业名称:机械制造及其自动化班级学号:12学号2022xx同学姓名: 严XX指导老师: 孙xx (教授)三年四月二十八号黄金分割法的基本原理与步骤一维搜寻是解函数微小值的方法之一,其解法思想为沿某一方向求目标 函数的微小值点。一维搜寻的解法很多,这里主要采纳黄金分割法(0.618法)。 该方法用不变的区间缩短率0. 618代替斐波那契法每次不同的缩短率,从而可以 看成是斐波那契法的近似,实现起来比拟简洁,也易于人们所接受。黄金分割法是用于一元函数f (x)在给定初始区间a, b内搜寻微小点Xmin的一 种方法。它是优化计算中的经典

2、算法,以算法简洁、收敛速度匀称、效果较好而 著称,是很多优化算法的基础,但它只适用于一维区间上的凸函数,即只在单峰 区间内才能进行一维寻优,其收敛效率较低。其基本原理是:依照“去劣存优” 原那么、对称原那么、以及等比收缩原那么来逐步缩小搜寻区间。详细步骤是:在区间 a, b内取点:al , a2把a, b分为三段。黄金分割法是用于一元函数f (x)在给定初始区间a, b内搜寻微小点Xmin 的一种方法。它是优化计算中的经典算法,以算法简洁、收敛速度匀称、效果较 好而著称,是很多优化算法的基础,但它只适用于一维区间上的凸函数,即只在 单峰区间内才能进行一维寻优,其收敛效率较低。其基本原理是:依照

3、“去劣存 优”原那么、对称原那么、以及等比收缩原那么来逐步缩小搜寻区间。详细步骤是:在 区间a, b内取点:al , a2把a, b分为三段。a 假如 f (al) f (a2),令 a=al, al=a2, a2=a+0. 618* (b-a);b 假如 f (al) e)printf(nal=%f a2=%fa3=%Ann,al,a2,a3);printf(nfl=%f f2=%ff3=%Ann,fl,f2,f3);printf(Hap=%f fp=%inrT,ap,fp);if(ap-a2)*(a3-al)0)if(f2=fp)a 1 =a2;fl=f2;a2=ap;f2=fp;else

4、 a3=ap;a3=ap;)elseif(f2=fp)al=ap;fl=fp; printf(Mal=%f printf(nfl=%f printf(Hap=%f if(f2fp) printf(a*=%f )a3=a2;f3=f2;a2=ap;f2=fp; elsea2=%fa3=%fnal,a2,a3);f2=%ff3=%nn”,fl,f2,f3);fp=%fnn”,ap,fp);#=%fn”,a2,f2);else printf(a*=%f f*=%An”,ap,fp); 黄金分割法应用举例依据0.618算法编写程序,求函数 f(x)=6*xA2-48*x+38在区间的极大值。解:#in

5、clude #include double f(double x) (double f;f=6x*x-48*x+38;return(f);)void main() double al;double a2;double a3;double fl;double f2;double f3;double e;double ap;double fp;double S1;double S2;e=0.001;al=l;a2=2;a3=3;fl =f(al );f2=f(a2);f3=f(a3);Sl=(f3-fl)/(a3-al);S2=(f2-fl)/(a2-al)-Sl)/(a2-a3);ap=0.5*

6、(al+a3-Sl/S2);fp=f(ap);while(fabs(ap-a2)e)printf(nal=%f a2=%fa3=%fnn,al,a2,a3);printf(nfl=%f f2=%ff3=%fn”,fl,f2,f3);printf(nap=%f fp=%fnnn,ap,fp);if(ap-a2)*(a3-al)0)if(f2=fp)al =a2;fl =I2;a2=ap;f2=fp;else a3=ap;a3=ap; else a3=a2;f3=f2;a2=ap;f2=fp; elsea2=%fa3=%An”,al,a2,a3);f2=%ff3=%An;fl,f2,f3);fp=

7、%fnnn,ap,fp);a2=%fa3=%An”,al,a2,a3);f2=%ff3=%An;fl,f2,f3);fp=%fnnn,ap,fp);al=ap;fl=fp; ) printf(nal=%f printf(nfl=%f printf(nap=%f if(f2fp)printf(na*=%f )elseprintf(ua*=%f)运算结果:Output:f*二%fnap,fp);1 al=l. 000000a2=2. 000000a3=3. 0000002 fl=-4.0000003ap=4. 00000045al=2.0000006 fl=-34.0000007ap=4.00000089 a*=4. 000000由结果可知:x=4.f2=-34. 000000f3=-52. 000000fp=-58. 000000a2=4.000000a3=3. 000000f2=-58. 000000f3=-52. 000000fp=-58. 000000f*=-58. 000000000000时取得最大值:-58. 000000

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 应用文书 > 解决方案

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁