- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
MATLAB编程0-1规划问题,matlab解线性规划问题,matlab线性规划问题,matlab规划问题,matlab求解规划问题,matlab线性规划,matlab01规划,matlab二次规划,matlab整数规划,matlab非线性规划
MATLAB语言应用————最优化
MATLAB编程线性规划问题
第二章0-1规划
MATLAB的0-1规划函数bintprog是针对下述0-1规划:
(2.1)
解0-1规划(2.1)的0-1规划函数bintprog表述为
[x, fv, exitflag, output]= bintprog(f,A,b,aeq, beq) (2.2)
输入部分:
f为目标函数,实为目标函数的系数。
A为(2.1)中的不等式约束矩阵
b为(2.1)中的不等式约束向量
aeq为(2.1)中的等式约束矩阵
beq(2.1)中的等式约束向量
输出部分:
x为最优解 fval为最优值
exitflag为输出标志 exitflag=1,有最优解 exitflag=0,迭代次数超过设定次数
exitflag==-2,约束区域不可行 exitflag=-3,问题无解
output,表明算法和迭代情况
如果我们不需要了解迭代情况和存储情况,可将0-1规划函数bintprog写成
[x, fv, ex]= linprog(f,A,b,aeq, beq) (2.3)
在函数bintprog中,输入或输出元素的符号可以变更,如(2.3)中ex仍为输出标志,但元素的符号位置不能变更。在输出部分,如有缺者,可用[]号代替。
函数bintprog的使用要点与函数linprog的使用要点相同。
函数是为求目标函数的最小值而设置的,如要求函数的最大值,可先求出的最小值,则必为的最大值。
例一 用函数bintprog求解下列0-1规划
用MATLAB语言编程如下:
f=-[1,2,2,-6],-4
A=[3,2,-1,1,2;2,4,-2,-1,-2];
b=[5,5];
[x,fv,ex]=bintprog(f,A,b,[],[]);
X,-fv
求解如下
ex=1,fv=-5, x=[1,1,1,0,0]
例二 用函数bintprog求解下列0-1规划
用MATLAB语言编程如下:
f=[3,7,-1,1]
A=[-2,1,-1,1;-1,1,-6,-4];
A=[A;-5,-3,0,-1]
b=-[1,8,5];
[x,fv,ex]=bintprog(f,A,b,[],[]);
求解如下ex=1,fv=-3, x=[1,0,1,,1]
例三 用函数bintprog求解下列0-1规划
用MATLAB语言编程如下:
f=[15,18,21,19,23,22,26,17,16];
z2=zeros(1,2); z3=zeros(1,3);
z6=zeros(1,6); o3=zeros(1,3);
q=[o3,z6;z3,o3,z3;z6,o3];
q=[q;1,z2, 1,z2, 1,z2];
q=[q;0,1,z2,1,z2,1,0];
q=[q;z2,1, z2,1, z2,1];
bq=ones(6,1)
[x,fv,ex]=bintprog(f,[],[],q,bq);
求得
Ex=1,fv=53, x=[0,1,0,1,0,0,0,0,1]
3
文档评论(0)