汽车优化设计上机程序.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
1.黄金分割法 黄金分割法主函数 function [xmin,fmin,k]=Golden (f,a0,b0,epsilon) a=a0; b=b0; k=0; a1=b-0.618*(b-a); y1=f(a1); a2=a+0.618*(b-a); y2=f(a2); while abs((b-a)/b)=epsilon if y1=y2 a=a1;a1=a2;y1=y2; a2=a+0.618*(b-a);y2=f(a2); else b=a2;a2=a1;y2=y1; a1=b-0.618*(b-a);y1=f(a1); end k=k+1; end xmin=0.5*(a+b); fmin=f(xmin); end 黄金分割法问题函数 function [fun]=f0(x) fun=x*x-10*x+36; end 调用程序 [xmin,fmin,k]=Golden(@f0,2,7,0.0001) 2.牛顿法 syms x1 x2; f=x1*x1+36*x2*x2; x0=[3,8]; epsilon=1e-5; k=0; df=jacobian(f,[x1,x2]); df=df.; Hess=jacobian(df,[x1,x2]); df0=subs(df,{x1,x2},{x0(1,1),x0(2,1)}); Hess0=subs(Hess,{x1,x2},{x0(1,1),x0(2,1)}); while(norm(df0)epsilon) k=k+1; x0=x0-Hess0^-1*df0; df0=subs(df,{x1,x2},{x0(1,1),x0(2,1)}); Hess0=subs(Hess,{x1,x2},{x0(1,1),x0(2,1)}); end x0 fmin=subs(f,{x1,x2},{x0(1,1),x0(2,1)}) k 3.复合形法 syms x1 x2 ; g1=5-3/(x1*x2^2); g2=1-0.4*x1*x2; fx=25/(x1*x2^3); a1=2;b1=5;a2=0.5;b2=1;e=0.0001;K=5; r=[0.1 0.2 0.3 0.4 0.5]; for i=1:K X1(i)=a1+r(i)*(b1-a1); X2(i)=a2+r(i)*(b2-a2); end X1(1)=3;X2(1)=0.8; while 1 a=1.3; for i=1:K FX(i)=subs(fx,{x1,x2},[X1(i),X2(i)]); end FXh=FX(1); h=1; FXl=FX(1); l=1; for i=1:K if FXhFX(i) FXh=FX(i); h=i; else if FXlFX(i) FXl=FX(i); l=i; end end end Q=0; for i=1:K Q=Q+(FX(i)-FXl)^2; end E=(Q/(K-1))^0.5; if Ee break ; end R_flag=0; R_NUM=0; Xc1=(sum(X1)-X1(h))/(K-1); Xc2=(sum(X2)-X2(h))/(K-1); while(~R_flag) XR1=Xc1+a*(Xc1-X1(h)); XR2=Xc2+a*(Xc2-X2(h)); G1=subs(g1,{x1,x2},[XR1,XR2]); G2=subs(g2,{x1,x2},[XR1,XR2]); FXR=subs(fx,{x1,x2},[XR1,XR2]); FXC=subs(fx,{x1,x2},[Xc1,Xc2]); if XR1a1||XR1b1||XR2a2||XR2b2||G10||G20||FXR=FXh R_flag=0; a=0.7*a;

文档评论(0)

js1180 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档