ImageVerifierCode 换一换
格式:DOC , 页数:14 ,大小:297.50KB ,
资源ID:117882      下载积分:12 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/117882.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(自由模板最优化方法课程论文.doc)为本站会员(b****9)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

自由模板最优化方法课程论文.doc

1、四川理工学院最优化方法课程论文题目:线性规划的单纯形算法姓 名:专 业:统计学班 级:2011级1班学 号:完成日期:2014年6月27日 四川理工学院理学院二O一 四 年 六 月摘 要线性规划是运筹学中研究较早、发展较快、应用广泛、方法较成熟的一个重要分支,它是辅助人们进行科学管理的一种数学方法。是研究线性约束条件下线性目标函数的极值问题的数学理论和方法。为了得到线性目标函数的极值,我们有多重方法。本文采用单纯性算法求解线性规划问题,并通过Matlab软件编写程序进行求解。关键词:线性规划 单纯性算法 Matlab编程 目 录一、 单纯性方法简介11.1 单纯性方法提出11.2单纯性方法的基

2、本思想和步骤11.2.1基本思想11.2.2计算步骤1二、问题的提出与分析12.1问题提出12.2问题分析2三、程序设计23.1算法设计23.2算法框图33.3程序编制4四、结果分析64.1设计结果64.2 进一步讨论和验证8五、结束语85.1设计的优缺点85.2 收获与总结9参考文献10附 录11一、 单纯性方法简介1.1 单纯性方法提出单纯形法,求解线性规划问题的通用方法。单纯形是美国数学家G.B.丹齐克于1947年首先提出来的,这是20世纪数学界最重大的成果之一。由于这一方法的有效性,几十年来一直在几乎所有的领域得到广泛应用。它的理论根据是:线性规划问题的可行域是 n维向量空间Rn中的多

3、面凸集,其最优值如果存在必在该凸集的某顶点处达到。顶点所对应的可行解称为基本可行解。1.2单纯性方法的基本思想和步骤1.2.1基本思想单纯形法的基本思想是:先找出一个基本可行解,对它进行鉴别,看是否是最优解;若不是,则按照一定法则转换到另一改进的基本可行解,再鉴别;若仍不是,则再转换,按此重复进行。因基本可行解的个数有限,故经有限次转换必能得出问题的最优解。如果问题无最优解也可用此法判别。 1.2.2计算步骤 1、对于一般的的线性规划,将其化为标准型; 2、求出初始基本可行解; 3、先检验其最优性; 4、如果不是最优的,则从取负值的非基变量中选取一个最负确定为入基变量; 5、选好入基变量后,再

4、在基变量中选取一个出基变量; 6、选好入基变量和出基变量后,进行高斯消去,得到新的可行解; 7、重复以上过程,直至找到最优解。、 二、问题的提出与分析2.1问题提出本文运用单纯性算法求解下列问题:Max s.t 并编写MATLAB程序求解。2.2问题分析在用单纯性算法解决现行规划问题时,我们通常考察标准形现行规划问题,其标准形如下: 现在将本文所讨论的线性规划化为标准线性规划的形式:Min S.t. 其中 A=2 3 0 1 0 0 0 2 4 0 1 0 3 2 5 0 0 1 , 三、程序设计3.1算法设计1、 解,求得,令,计算目标函数值,以记的第i个分量;2、 计算单纯性乘子w,,得到

5、,对于非基变量,计算判别系数,令,R为非基变量集合,若判别系数,则得到一个最基本可行解,运算结束;否则,转到下一步3、 解,得到;若,即的每一个分量均非正数,则停止计算,问题不存在有限最优解,否则,进行步骤4;4、 确定下标r,使,为出基变量,为入基变量,用替换,得到新的基矩阵B,返回步骤1。3.2算法框图开始 初始可行解令计算单纯形乘子,计算判别数(非基变量)令是得到最优解解方程,得到。否是不存在有限最优解确定下标,是否为进基变量,用替换,得到新的基矩阵3.3程序编制A=input(A=);b=input(b=);c=input(c=);format rat m,n=size(A);E=1:

6、m;E=E; F=n-m+1:n;F=F;D=E,F; X=zeros(1,n); if(nm) fprintf(不符合要求需引入松弛变量) flag=0;else flag=1; B=A(:,n-m+1:n); cB=c(n-m+1:n); while flag w=cB/B; panbieshu=w*A-c z,k=max(panbieshu); fprintf(b./(BA(:,%d)为,k); b./(BA(:,k) if(z0.000000001) flag=0; fprintf( 已找到最优解!n); xB=(Bb); f=cB*xB; for i=1:n mark=0; for

7、j=1:m if (D(j,2)=i) mark=1; X(i)=xB(D(j,1); end end if mark=0 X(i)=0; end end fprintf(基向量为:); X fprintf(目标函数值为:) ; f else if(BA(:,k)0) & (b1(i)/(A(i,k)+eps)temp ) temp=b1(i)/A(i,k); r=i; end end fprintf(x(%d)进基,x(%d)退基n,k,D(r,2); B(:,r)=A(:,k); cB(r)=c(k); D(r,2)=k; end end endend四、结果分析4.1设计结果在命令窗口中

8、输入: A=2,3,0,1,0,0;0,2,4,0,1,0;3,2,5,0,0,1 b=1200,800,2000 得到如下结果:我们可以看到,程序经过4次换基迭代,得到目标函数的最优值为-2600,即目标函数的最小值为-2600。从而,原问题的最大值为2600。4.2 进一步讨论和验证 对于MATLAB程序的正确性与软件运行的可行性。由于计算量并不是很大,我们通过单纯性表进行手工计算。经过几次换基迭代,我们选取的入基变量和出基变量与以上软件运行过程得到的结果完全相同。由此,我们可以认定目标函数的最小值为-2600,即原问题的最大值为2600。 五、结束语5.1设计的优缺点设计优点:1、 设计

9、的程序是根据课本的步骤编写的;2、 程序的编制能得到正确结果;3、 编制的程序得到的结果中具体体现每一步的出基变量与入基变量,清晰明了;设计缺点:1、 不能直观的反应迭代步数,如若迭代次数过多,则想要了解迭代步数则比较麻烦;2、 不能给出完整的单纯性表。5.2 收获与总结 通过本次课程论文设计,让我对单纯性法有了进一步的了解,明确了它的具体思想理论,算法步骤。此外,通过此次课程设计,初次接触了MATLAB软件,让我对MATLAB软件有了初步的了解,此次论文的完成,主要是通过根据算法设计,编制MATLAB程序,通过MATLAB软件对模型求解。因此,此次设计的最大问题在于怎样设计算法程序,但这对于我们来说难度还是比较大,所以,此次的单纯性算法程序直接利用网上给出的算法程序进行设计。但网上的很多程序也存在很多问题,需要在一次一次的错误中不断的更正问题,直到最后得到模型正确的结果。由于对MATLAB软件的不了解,对于程序设计的优缺点不是很明白。而对于以后,还是希望能多学习一下软件的知识,能够深入了解一下软件的程序设计以及问题分析。 参考文献1 精通MATLAB最优化计算(第二版) 龚纯等2

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1