南邮运筹与优化实验报告.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文档。上传文档
查看更多
南邮运筹与优化实验报告

实 验 报 告 黄金分割法求的最小值,初始区间[a,b]=[-1,1], 实验过程 #include math.h #include stdio.h #define f(x) 2*x*x-x-1 double hj(double *a,double *b,double e,int *n) { double x1,x2,s; if(fabs(*b-*a)=e) s=f((*b+*a)/2); else { x1=*a+0.382*(*b-*a); x2=*a+0.618*(*b-*a); if(f(x1)f(x2)) *a=x1; else *b=x2; *n=*n+1; s=hj(a,b,e,n); } return s; } main() { double s,a,b,e; int n=0; scanf(%lf %lf %lf,a,b,e); // 输入区间[a,b]和精度e的值 s=hj(a,b,e,n); //调用hj函数,其中n代表迭代次数 printf(a=%lf,b=%lf,s=%lf,n=%d\n,a,b,s,n); } 实验结果 相应输入a、b、e的值-1、1、0.16,得出结果:区间为【0.167232,0.278651】一共迭代6次 实验二:共轭梯度法 实验目的 掌握并运用共轭梯度法 能在计算机上完成算法的实现,并解决最优化问题 实验题目 用共轭梯度法求解: (1) 实验过程 function [ x,g ] = Untitled1( Q,b,x,c,m) a=0; f=Q*x+b; s=sqrt(f(1)^2+f(2)^2); while sm, d=-f+a*d; t=-f*d/(d*Q*d); x=x+t*d; f=Q*x+b; a=f*Q*d/(d*Q*d); s=sqrt(f(1)^2+f(2)^2); end g=0.5*x*Q*x+b*x+c; Q=[2,-1;-1,2]; b=[2;-4]; x=[0;0]; c=0; m=0.001; [X,U]=getd(Q,b,x,c,m) 实验结果 利用Matlab作出上述结果,最优解为x=(0,2)T 实验三:内外惩罚函数 一、实验目的 通过内外点法的学习让我们掌握利用罚函数解决线性规划为解决相应问题的一种思路与策略。 二、实验题目 分别用外点法和内点法求解下列问题: 三、实验过程 【实验编译程序】 1、内点法 clc m=zeros(1,50);a=zeros(1,50);b=zeros(1,50);f0=zeros(1,50); syms x1 x2 e; %e为罚因子。 m(1)=1;c=10;a(1)=0;b(1)=0; %c为递增系数。赋初值。 f=x1^2+x2^2+e*(1-x1)^2;f0(1)=1; fx1=diff(f,x1);fx2=diff(f,x2);fx1x1=diff(fx1,x1);fx1x2=diff(fx1,x2);fx2x1=diff(fx2,x1);fx2x2=diff(fx2,x2);%求偏导、海森元素。 for k=1:100 %外点法e迭代循环。 x1=a(k);x2=b(k);e=m(k); for n=1:100 %梯度法求最优值。 f1=subs(fx1); %求解梯度值和海森矩阵。 f2=subs(fx2); f11=subs(fx1x1); f12=subs(fx1x2); f21=subs(fx2x1); f22=subs(fx2x2); if(double(sqrt(f1^2+f2^2))=0.001) %最优值收敛条件。 a(k+1)=double(x1);b(k+1)=double(x2);f0(k+1)=double(subs(f)); break; else X=[x1 x2]-inv([f11 f12;f21 f22])*[f1 f2]; x1=X(1,1);x2=X(2,1); end end if(double(sqrt((a(k+1)-a(k))^2+(b(k+1)-b(k))^2))=0.001)(double(abs((f0(k+1)-f0(k))/f0(k)))=0.001) %罚因子迭代收敛条件。 a(k+1) %输出最优点坐标,罚因子迭代次数,最优值。 b(k+1) k f0(k+1) break; else m(k+1)=c*m(k); end end 2、外点法 clc m=zeros(1,50);a=zeros(1,50);b=zeros(1,50);f0=zeros(1,50); syms d x1 x2 e; m(1)=1;c=10;a(1)=0;b(1)=0; f=x1^2

文档评论(0)

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

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

1亿VIP精品文档

相关文档