matlab线性规划问题Word下载.docx

上传人:b****3 文档编号:6874173 上传时间:2023-05-07 格式:DOCX 页数:12 大小:47.95KB
下载 相关 举报
matlab线性规划问题Word下载.docx_第1页
第1页 / 共12页
matlab线性规划问题Word下载.docx_第2页
第2页 / 共12页
matlab线性规划问题Word下载.docx_第3页
第3页 / 共12页
matlab线性规划问题Word下载.docx_第4页
第4页 / 共12页
matlab线性规划问题Word下载.docx_第5页
第5页 / 共12页
matlab线性规划问题Word下载.docx_第6页
第6页 / 共12页
matlab线性规划问题Word下载.docx_第7页
第7页 / 共12页
matlab线性规划问题Word下载.docx_第8页
第8页 / 共12页
matlab线性规划问题Word下载.docx_第9页
第9页 / 共12页
matlab线性规划问题Word下载.docx_第10页
第10页 / 共12页
matlab线性规划问题Word下载.docx_第11页
第11页 / 共12页
matlab线性规划问题Word下载.docx_第12页
第12页 / 共12页
亲,该文档总共12页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

matlab线性规划问题Word下载.docx

《matlab线性规划问题Word下载.docx》由会员分享,可在线阅读,更多相关《matlab线性规划问题Word下载.docx(12页珍藏版)》请在冰点文库上搜索。

matlab线性规划问题Word下载.docx

15

10

8

12

由于某种原因,决定用于项目A的投资不大于其他各项投资之和而用于项目B和C的投资要大于项目D的投资。

试确定全文该公司收益最大的投资分配方案。

设x1、x2、x3、x4分别代表用于项目A、B、C、D的投资百分数。

maxf=0.15x1+0.1x2+0.08x3+0.12x4

s.tx1-x2-x3-x4≤0

x2+x3-x4≥0

x1+x2+x3+x4=1

xj≥0j=1,2,3,4

实例3:

运输问题

有A、B、C三个食品加工厂,负责供给甲、乙、丙、丁四个市场。

三个厂每天生产食品箱数上限如下表:

工厂

生产数

60

40

50

四个市场每天的需求量如下表:

市场

需求量

20

35

33

34

从各厂运到各市场的运输费(元/每箱)由下表给出:

市场

2

1

3

4

求在基本满足供需平衡的约束条件下使总运输费用最小。

设aij为由工厂i运到市场j的费用,xij是由工厂i运到市场j的箱数。

bi是工厂i的产量,dj是市场j的需求量。

 

b=(604050)d=(20353334)

s.t

xij≥0

当我们用MATLAB软件作优化问题时,所有求maxf的问题化为求min(-f)来作。

约束gi(x)≥0,化为–gi≤0来作。

上述实例去掉实际背景,归结出规划问题:

目标函数和约束条件都是变量x的线性函数。

形如:

(1)minfTX

s.tAX≤b

AeqX=beq

lb≤X≤ub

其中X为n维未知向量,fT=[f1,f2,…fn]为目标函数系数向量,小于等于约束系数矩阵A为m×

n矩阵,b为其右端m维列向量,Aeq为等式约束系数矩阵,beq为等式约束右端常数列向量。

lb,ub为自变量取值上界与下界约束的n维常数向量。

二.线性规划问题求最优解函数:

调用格式:

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)返回值x为最优解向量。

x=linprog(f,A,b,Aeq,beq)作有等式约束的问题。

若没有不等式约束,则令A=[]、b=[]。

x=linprog(f,A,b,Aeq,beq,lb,ub,x0,options)中lb,ub为变量x的下界和上界,x0为初值点,options为指定优化参数进行最小化。

Options的参数描述:

Display显示水平。

选择’off’不显示输出;

选择’iter’显示每一步迭代过程的输出;

选择’final’显示最终结果。

MaxFunEvals函数评价的最大允许次数

Maxiter最大允许迭代次数

TolXx处的终止容限

[x,fval]=linprog(…)左端fval返回解x处的目标函数值。

[x,fval,exitflag,output,lambda]=linprog(f,A,b,Aeq,beq,lb,ub,x0)的输出部分:

exitflag描述函数计算的退出条件:

若为正值,表示目标函数收敛于解x处;

若为负值,表示目标函数不收敛;

若为零值,表示已经达到函数评价或迭代的最大次数。

output返回优化信息:

output.iterations表示迭代次数;

output.algorithm表示所采用的算法;

outprt.funcCount表示函数评价次数。

lambda返回x处的拉格朗日乘子。

它有以下属性:

lambda.lower-lambda的下界;

lambda.upper-lambda的上界;

lambda.ineqlin-lambda的线性不等式;

lambda.eqlin-lambda的线性等式。

在使用linprog()命令时,系统默认它的参数至少为3个,但如果我们需要给定第6个参数,则第4个参数、第5个参数也必须给出,否则系统无法认定给出的是第6个参数。

遇到无法给出时,则用空矩阵“[]”替代。

三.举例

例1:

求解线性规划问题:

maxf=2x1+5x2

s.t

先将目标函数转化成最小值问题:

min(-f)=-2x1-5x2

程序:

f=[-2-5];

A=[10;

01;

12];

b=[4;

3;

8];

[x,fval]=linprog(f,A,b)

f=fval*(-1)

结果:

x=23

fval=-19.0000

maxf=19

例2:

minf=5x1-x2+2x3+3x4-8x5

s.t–2x1+x2-x3+x4-3x5≤6

2x1+x2-x3+4x4+x5≤7

0≤xj≤15j=1,2,3,4,5

f=[5-123-8];

A=[-21-11-3;

21-141];

b=[6;

7];

lb=[00000];

ub=[1515151515];

[x,fval]=linprog(f,A,b,[],[],lb,ub)

x=

0.0000

0.0000

8.0000

15.0000

minf=

-104

例3:

minf=5x1+x2+2x3+3x4+x5

s.t–2x1+x2-x3+x4-3x5≤1

2x1+3x2-x3+2x4+x5≤-2

0≤xj≤1j=1,2,3,4,5

f=[51231];

A=[-21-11-3;

23-121];

b=[1;

-2];

lb=[00000];

ub=[11111];

[x,fval,exitflag,output,lambda]=linprog(f,A,b,[],[],lb,ub)运行结果:

Exiting:

Oneormoreoftheresiduals,dualitygap,ortotalrelativeerror

hasgrown100000timesgreaterthanitsminimumvaluesofar:

theprimalappearstobeinfeasible(andthedualunbounded).

(Thedualresidual<

TolFun=1.00e-008.)

x=0.0000

0.0000

1.1987

fval=

2.3975

exitflag=

-1

output=

iterations:

7

cgiterations:

0

algorithm:

'

lipsol'

lambda=

ineqlin:

[2x1double]

eqlin:

[0x1double]

upper:

[5x1double]

lower:

显示的信息表明该问题无可行解。

所给出的是对约束破坏最小的解。

例4:

求解实例1的生产计划问题

将其转换为标准形式:

minf=-70x1-120x2

程序:

f=[-70-120];

A=[94;

45;

310];

b=[3600;

2000;

3000];

lb=[00];

ub=[];

[x,fval,exitflag]=linprog(f,A,b,[],[],lb,ub)

maxf=-fval

结果:

x=

200.0000

240.0000

-4.2800e+004

1

maxf=

4.2800e+004

例5:

求解实例2

建立数学模型:

maxf=0.15x1+0.1x2+0.08x3+0.12x4

xj≥0j=1,2,3,4

minz=-0.15x1-0.1x2-0.08x3-0.12x4

-x2-x3+x4≤0

f=[-0.15;

-0.1;

-0.08;

-0.12];

A=[1-1-1-1;

0-1-11];

b=[0;

0];

Aeq=[1111];

beq=[1];

lb=zeros(4,1);

[x,fval,exitflag]=linprog(f,A,b,Aeq,beq,lb)

f=-fval

结果:

0.5000

0.2500

-0.1300

1

f=

0.1300

即4个项目的投资百分数分别为50%,25%,0,25%时可使该公司获得最大的收益,其最大收益可到达13%。

过程正常收敛。

例6:

求解实例3

b=(604050)Td=(20353334)T

A=[2132;

1321;

3411];

f=A(:

);

B=[100100100100

010010010010

001001001001];

D=[111000000000

000111000000

000000111000

000000000111];

b=[60;

40;

50];

d=[20;

35;

33;

34];

lb=zeros(12,1);

[x,fval,exitflag]=linprog(f,B,b,D,d,lb)

20.0000

35.0000

33.0000

18.4682

15.5318

122.0000

即运输方案为:

甲市场的货由B厂送20箱;

乙市场的货由A厂送35箱;

丙商场的货由C厂送33箱;

丁市场的货由B厂送18箱,再由C厂送16箱。

最低总运费为:

122元。

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > PPT模板 > 商务科技

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2