- 1、本文档共86页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
7.2.2 基于MATLAB的数值解法 例: f=inline((x(1)^2-2*x(1))*exp(-x(1)^2-x(2)^2-x(1)*x(2)),x); x0=[0; 0]; ff=optimset; ff.Display=iter; x=fminsearch(f,x0,ff) Iteration Func-count min f(x) Procedure 1 3 -0.000499937 initial 2 4 -0.000499937 reflect 72 137 -0.641424 contract outside Optimization terminated successfully: x = 0.6111 -0.3056 x=fminunc(f,[0;.0],ff) Directional Iteration Func-count f(x) Step-size derivative 1 2 -2e-008 0.001 -4 2 9 -0.584669 0.304353 0.343 3 16 -0.641397 0.950322 0.00191 4 22 -0.641424 0.984028 -1.45e-008 x = 0.6110 -0.3055 比较可知 fminunc()函数效率高于fminsearch()函数,但 当所选函数高度不连续时,使用fminsearch效果较好。故 若安装了最优化工具箱则应调用fminunc()函数。 7.2.3 全局最优解与局部最优解 例: f=inline(exp(-2*t).*cos(10*t)+exp(-3*(t+2)) .*sin(2*t),t); % 目标函数 t0=1; [t1,f1]=fminsearch(f,t0); [t1 f1] ans = 0.9228 -0.1547 t0=0.1; [t2,f2]=fminsearch(f,t0); [t2 f2] ans = 0.2945 -0.5436 syms t; y=exp(-2*t)*cos(10*t)+exp(-3*(t+2))*sin(2*t); ezplot(y,[0,2.5]); set(gca,‘Ylim’,[-0.6,1]) % 在t[0,2.5]内的曲线 ezplot(y,[-0.5,2.5]); set(gca,‘Ylim’,[-2,1.2]) %在[-0.5,2.5]曲线 t0=-0.2; [t3,f3]=fminsearch(f,t0); [t3 f3] ans = -0.3340 -1.9163 7.2.4 利用梯度求解最优化问题 例: [x,y]=meshgrid… (0.5:0.01:1.5); … z=100*(y.^2-x).^2… +(1-x).^2; contour3(x,y,z,100), set(gca,zlim,[0,310]) %测试算法的函数 f=inline(100*(x(2)-x(1)^2)^2+(1-x(1))^2,x); ff=optimset; ff.TolX=1e-10; ff.TolFun=1e-20; ff.Display=iter; x=fminunc(f,[0;0],ff) Warning: Gradient must be provided for trust-region method; using line-search method instead. Dir
文档评论(0)