削减库存问题:Solver-Based
这个例子展示了如何解决削减库存的问题使用线性规划和整数线性规划子例程。这个例子使用了Solver-Based优化问题设置的方法。具体问题具体分析的方法,请参阅削减库存问题:具体问题具体分析。
问题概述
一个木材厂始于树已经削减到固定长度的记录。指定日志长度固定。
logLength = 40;
机然后削减登录固定长度适合进一步处理。问题是如何让削减,使磨机满足一组订单最少的日志。
指定这些固定长度和长度的订单数量。
lengthlist = [8;12;16;20);数量= (90;111;55;30);nLengths =长度(lengthlist);
假设没有物质损失进行削减,削减成本。
线性规划公式
几个作者,包括福特和Fulkerson[1]和吉尔摩Gomory[2],显示下列程序,实现在接下来的部分。切割模式是一组,一个日志可以被削减。
而不是生成所有可能的切割模式,更有效的生成切割模式作为子问题的解决方案。从一组基础的切割模式,解决线性规划问题的减少使用的日志数量削减受到约束,使用现有的模式,满足要求。
解决这个问题后,生成一个新的模式通过求解整数线性规划子问题。子问题是找到最好的新模式,意味着削减的数量从每个长度lengthlist
,加起来可能不超过总长度logLength
。量优化是降低成本的新模式,这是一个负的和拉格朗日乘数法对当前解决方案*新模式。如果这个数量是负数,然后将这种模式引入线性规划将提高其目标。如果不是,然后更好的切割模式不存在,到目前为止使用的模式给最优线性规划解决方案。这个结论的原因是完全平行的原因当停止原始单纯形法:该方法终止当没有变量-降低成本。这个问题在这个例子中终止当没有模式-降低成本。和一个示例的详细信息,请参见列生成算法和它的引用。
在这种方式解决线性规划问题之后,你可以有noninteger解决方案。万博 尤文图斯因此,解决这一问题,使用生成的模式和约束变量整数值。
MATLAB Solver-Based配方
一个模式,在这个配方,是一个整数向量包含每个长度的削减的数量lengthlist
。安排一个矩阵命名模式
存储模式,每个列的矩阵给出了模式。例如,
第一个模式(列)表示两个削减长度8和一个切长度20。第二种模式代表了两个削减长度12和一个切长度16。每个是一个可行的模式,因为减税总额不超过logLength
= 40。
在这个公式中,如果x
是一个列向量的整数包含每个模式的次数,然后呢* x模式
是一个列向量的数量给每个类型的削减。会议需求的约束模式* x > =数量
。例如,使用前面的模式
矩阵,假设
。(这x使用101日志)。然后
代表一个可行的解决方案,因为结果超过需求吗
有一个初始可行的切割模式,使用最简单的模式,它只有一个切割的长度。使用尽可能多的削减长度可行的日志。
模式=诊断接头(地板(logLength. / lengthlist));nPatterns =大小(模式2);
产生新模式从现有的基于当前的拉格朗日乘数法,解决部分问题。在一个循环中调用子问题来生成模式,直到没有进一步改善。子问题的目标只取决于当前的拉格朗日乘数法。变量非负整数表示的数量削减的长度。唯一的限制是,削减的长度之和不超过日志模式长度。创建一个下界向量lb2
和矩阵A2
和b2
代表这些范围和线性约束。
lb2 = 0 (nLengths, 1);A2 = lengthlist ';b2 = logLength;
为了避免不必要的反馈解决,设置显示
选项“关闭”
外循环和内子问题的解决方案。
lpopts = optimoptions (“linprog”,“显示”,“关闭”);ipopts = optimoptions (“intlinprog”,lpopts);
初始化变量的循环。
reducedCost =无穷;reducedCostTolerance = -0.0001;exitflag = 1;
所谓的循环。
而reducedCost < reducedCostTolerance & & exitflag > 0磅= 0 (nPatterns, 1);f =磅+ 1;一个=模式;b =数量;(价值观、nLogs exitflag ~,λ)= linprog (f, A, b,[],[],磅,[],lpopts);如果exitflag > 0流(“使用% g日志\ n”,nLogs);%现在生成一个新的模式,如果可能的话f2 = -lambda.ineqlin;(价值观、reducedCost pexitflag) = intlinprog (f2, 1: nLengths, A2, b2, [], [], lb2, [], ipopts);reducedCost = 1 + reducedCost;%如果这继续reducedCost是负的newpattern =圆(值);如果pexitflag > 0 & & reducedCost < reducedCostTolerance模式= (newpattern模式);nPatterns = nPatterns + 1;结束结束结束
使用97.5日志使用92日志使用89.9167日志使用88.3日志
你现在有线性规划问题的解决方案。完成解决方案,解决这个问题的最终模式,使用intlinprog
所有的变量是整数。同时,计算浪费,这是未使用的日志(英尺)的数量为每个模式和问题作为一个整体。
如果exitflag < = 0 disp (的错误在列生成阶段)其他的(价值观、logsUsed exitflag) = intlinprog (f, 1:长度(磅),A, b,[],[],磅,[],[],ipopts);如果exitflag > 0值=圆(值);logsUsed =圆(logsUsed);流(“最佳解决方案使用% g日志\ n”,logsUsed);totalwaste =总和(数量)(模式*值。* lengthlist);由于生产过剩%浪费为j = 1:尺寸(值)如果值(j) > 0流(“减少% \ n g日志模式”值(j));为w = 1:尺寸(模式1)如果模式(w, j) > 0流(' % d切割长度(s) % d \ n”、模式(w, j), lengthlist (w));结束结束wastej = logLength -点(模式(:,j), lengthlist);%浪费由于模式效率低下totalwaste = totalwaste + wastej;流(这种模式的“浪费是% g \ n ',wastej);结束结束流(总浪费在这个问题上是% g。\ n”,totalwaste);其他的disp (“最终优化错误”)结束结束
最优解使用89日志
减少15日志模式
2减少20 (s)的长度
这种模式的浪费是0
减少18日志模式
1切的长度8 2把(s) 16
这种模式的浪费是0
削减37日志模式
2减少长度(s) 8 2减少长度(s) 12
这种模式的浪费是0
减少19日志模式
2减少(s)的长度12 1切长度(s) 16
这种模式的浪费是0
浪费在这个问题上是28。
创建一个表显示长度,数量要求的长度,和每个长度的数量生产。
表(lengthlist、数量、模式*值,“VariableNames”,(“长度”“所需数量”“数量”])
ans =4×3表长度数量所需的数量产生______售予售予8 90 92 12 111 112 16 55 55 20 30 30
解决方案产生两个额外的长度8和一个额外的块长度12,总生产过剩28英尺。
引用
[1]福特,l·R。,Jr. and D. R. Fulkerson.建议计算最大多种商品网络流。管理科学,1958年,页97 - 101。
[2]吉尔摩,p . C。,和R. E. Gomory.线性规划方法削减股票问题——第二部分。6号运筹学11日,1963年,页863 - 888。
版权2012 - 2022 MathWorks公司。