- 1、本文档共28页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第10章 Matlab在最优化成绩中的应用
第10章 Matlab在最优化问题中的应用
优化理论是一门实践性很强的学科,广泛应用于生产管理、军事指挥和科学试验等各种领域,Matlab优化工具箱提供了对各种优化问题的一个完整的解决方案。
在数学上,所谓优化问题,就是求解如下形式的最优解:
Min fun (x)
Sub. to [C.E.]
[B.C.]
其中fun (x)称为目标函数,“Sub. to”为“subject to”的缩写,由其引导的部分称为约束条件。[C.E.]表示Condition Equations,即条件方程,可为等式方程,也可为不等式方程。[B.C.]表示Boundary Conditions,即边界条件,用来约束自变量的求解域,以lb≤x≤ub的形式给出。当[C.E.]为空时,此优化问题称为自由优化或无约束优化问题;当[C.E.]不空时,称为有约束优化或强约束优化问题。
在优化问题中,根据变量、目标函数和约束函数的不同,可以将问题大致分为:
·线性优化 目标函数和约束函数均为线性函数。
·二次优化 目标函数为二次函数,而约束条件为线性方程。线性优化和二次优化统称为简单优化。
·非线性优化 目标函数为非二次的非线性函数,或约束条件为非线性方程。
·多目标优化 目标函数并非一个时,称为多目标优化问题。
本章将对以上几类优化问题在Matlab中的实现作比较详细的讲解。另外还将介绍两个利用优化方法解非线性方程的函数。
通过本章的介绍,用户可以不必掌握艰涩的各种优化算法而轻易地解决一些常用的最优化问题了。
10.1 线性规划问题
线性规划问题即目标函数和约束条件均为线性函数的问题。
其标准形式为:
min C’x
sub. To Ax = b
x≥0
其中C, b, 0∈Rn,A∈Rmn,均为数值矩阵,x∈Rn。
若目标函数为:max C’x,则转换成:min –C’x。
标准形式的线性规划问题简称为LP(Linear Programming)问题。其它形式的线性规划问题经过适当的变换均可以化为此种标准形。线性规划问题虽然简单,但在工农业及其他生产部门中应用十分广泛。
在Matlab中,线性规划问题由linprog函数求解。
函数:linprog %求解如下形式的线性规划问题:
such that
其中f, x, b, beq, lb, ub为向量,A, Aeq为矩阵。
格式:x = linprog(f,A,b)
x = linprog(f,A,b,Aeq,beq)
x = linprog(f,A,b,Aeq,beq,lb,ub)
x = linprog(f,A,b,Aeq,beq,lb,ub,x0)
x = linprog(f,A,b,Aeq,beq,lb,ub,x0,options)
[x,fval] = linprog(...)
[x,fval,exitflag] = linprog(...)
[x,fval,exitflag,output] = linprog(...)
[x,fval,exitflag,output,lambda] = linprog(...)
说明:
x = linprog(f,A,b) 求解问题 min f’*x,约束条件为A*x=b。
x = linprog(f,A,b,Aeq,beq) 求解上面的问题,但增加等式约束,即Aeq*x = beq。若没有不等式存在,则令A = [ ]、b = [ ]。
x = linprog(f,A,b,Aeq,beq,lb,ub) 定义设计变量x的下界lb和上界ub,使得x始终在该范围内。若没有等式约束,令Aeq = [ ]、beq = [ ]。
x = linprog(f,A,b,Aeq,beq,lb,ub,x0) 设置初值为x0。该选项只适用于中型问题,默认时大型算法将忽略初值。
x = linprog(f,A,b,Aeq,beq,lb,ub,x0,options) 用options指定的优化参数进行最小化。
[x,fval] = linprog(...) 返回解x处的目标函数值fval。
[x,fval,exitflag] = linprog(...) 返回exitflag值,描述函数计算的退出条件。
[x,fval,exitflag,output
您可能关注的文档
最近下载
- 120万吨_年煤矸石(制砂)综合利用项目环评报告书.pdf VIP
- GB50421-2007 有色金属矿山排土场设计规范.docx
- 浙江工业大学2023-2024学年《马克思主义基本原理概论》期末考试试卷(B卷)含参考答案.docx
- 肠梗阻(共31张课件).pptx VIP
- 2023年喀什大学汉语言文学专业《现代汉语》期末试卷A(有答案).docx VIP
- 2123S01007-卫生毒理学-课程教学大纲J21公共卫生学院 2023版人才培养方案课程教学大纲.doc VIP
- 浙江工业大学2021-2022学年《马克思主义基本原理概论》期末考试试卷(B卷)含参考答案.docx
- 2024年医师资格考试报名表格.doc
- 专题 17 英美文化阅读理解专项:愚人节+母亲节- (原创)2024年高考英语常考英美文化阅读专练+素材积累.docx VIP
- 专题 15 英美文化阅读理解专项:美国人的独立观+美国人眼神交流+美式友谊- (原创)2024年高考英语常考英美文化阅读专练+素材积累.docx VIP
文档评论(0)