欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > PPT文档下载  

    整数线性规划-第1-4节.ppt

    • 资源ID:6365052       资源大小:676KB        全文页数:65页
    • 资源格式: PPT        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    整数线性规划-第1-4节.ppt

    第5章 整数规划,第1节 整数规划问题的提出第2节 分支定界解法(选讲)第3节 割平面解法(选讲)第4节 0-1型整数规划第5节 指 派 问 题,第1节 整数线性规划问题的提出,在前面讨论的线性规划问题中,有些最优解可能是分数或小数,但对于某些具体问题,常有要求解答必须是整数的情形(称为整数解)。例如,所求解是机器的台数、完成工作的人数或装货的车数等,分数或小数的解答就不合要求。为了满足整数解的要求,初看起来,似乎只要把已得到的带有分数或小数的解经过“舍入化整”就可以了。但这常常是不行的,因为化整后不见得是可行解;或虽是可行解,但不一定是最优解。因此,对求最优整数解的问题,有必要另行研究。我们称这样的问题为整数规划(integer linear programming),简称ILP.,整数线性规划中如果所有的变量都限制为(非负)整数,就称为纯整数线性规划(pure integer linear programming)或称为全整数线性规划(all integer linear programming);如果仅一部分变量限制为整数,则称为混合整数规划(mixed integer linear programming)。整数线性规划的一种特殊情形是0-1规划,它的变数取值仅限于0或1。本章最后讲到的指派问题就是一个0-1规划问题。,第1节 整数线性规划问题的提出,现举例说明用前述单纯形法求得的解不能保证是整数最优解。例1某厂拟用集装箱托运甲乙两种货物,每箱的体积、重量、可获利润以及托运所受限制如表5-1所示。问两种货物各托运多少箱,可使获得利润为最大?表5-1,第1节 整数线性规划问题的提出,现在我们解这个问题,设x1,x2分别为甲、乙两种货物的托运箱数(当然都是非负整数)。这是一个(纯)整数线性规划问题,用数学式可表示为:max z=20 x1+10 x2 5x1+4x224 2x1+5x213(5.1)x1,x20 x1,x2整数,第1节 整数线性规划问题的提出,它和线性规划问题的区别仅在于最后的条件。现在我们暂不考虑这一条件,即解(以后我们称这样的问题为与原问题相应的线性规划问题),也称为其松弛问题。,很容易求得最优解为:x1=4.8,x2=0,max z=96,但x1是托运甲种货物的箱数,现在它不是整数,所以不合条件的要求。是不是可以把所得的非整数的最优解经过“化整”就可得到合于条件的整数最优解呢?如将(x1=4.8,x2=0)凑整为(x1=5,x2=0),这样就破坏了条件(关于体积的限制),因而它不是可行解;如将(x1=4.8,x2=0)舍去尾数0.8,变为(x1=4,x2=0),这当然满足各约束条件,因而是可行解,但不是最优解,因为当x1=4,x2=0,时z=80.非整数的最优解在C(4.8,0)点达到。,第1节 整数线性规划问题的提出,但当x1=4,x2=1(这也是可行解)时,z=90。,图中画(+)号的点表示可行的整数解。凑整的(5,0)点不在可行域内,而C点又不合于条件。为了满足题中要求,表示目标函数的z的等值线必须向原点平行移动,直到第一次遇到带“+”号B点(x1=4,x2=1)为止。这样,z的等值线就由z=96变到z=90,它们的差值z=96-90=6 表示利润的降低,这是由于变量的不可分性(装箱)所引起的。,第1节 整数线性规划问题的提出,由上例看出,将其相应的线性规划的最优解“化整”来解原整数线性规划,虽是最容易想到的,但常常得不到整数线性规划的最优解,甚至根本不是可行解。因此有必要对整数线性规划的解法进行专门研究。,第1节 整数线性规划问题的提出,返回,第2节 分支定界解法,在求解整数线性规划时,如果可行域是有界的,首先容易想到的方法就是穷举变量的所有可行的整数组合,就像在图5-1中画出所有“+”号的点那样,然后比较它们的目标函数值以定出最优解。对于小型的问题,变量数很少,可行的整数组合数也是很小时,这个方法是可行的,也是有效的。,在例1中,变量只有x1和x2,由条件,x1所能取的整数值为0、1、2、3、4共5个;由条件,x2所能取的整数值为0、1、2共3个,它的组合(不都是可行的)数是35=15个,穷举法还是勉强可用的。对于大型的问题,可行的整数组合数是很大的。例如在本章第5节的指派问题(这也是整数线性规划)中,将n项任务指派n个人去完成,不同的指派方案共有n!种,当n=10,这个数就超过300万;当n=20,这个数就超过21018,如果一一计算,就是用每秒百万次的计算机,也要几万年的功夫,很明显,解这样的题,穷举法是不可取的。所以我们的方法一般应是仅检查可行的整数组合的一部分,就能定出最优的整数解。分支定界解法(branch and bound method)就是其中的一个.,分支定界法可用于解纯整数或混合的整数线性规划问题。在20世纪60年代初由Land Doig和Dakin等人提出。由于这方法灵活且便于用计算机求解,所以现在它已是解整数线性规划的重要方法。设有最大化的整数线性规划问题A,与它相应的线性规划为问题B,从解问题B开始,若其最优解不符合A的整数条件,那么B的最优目标函数必是A的最优目标函数z*的上界,记作;而A的任意可行解的目标函数值将是z*的一个下界。分支定界法就是将B的可行域分成子区域(称为分支)的方法,逐步减小和增大,最终求到z*。现用下例来说明:,第2节 分支定界解法,例 2,求解A max z=40 x1+90 x2 9x1+7x256 7x1+20 x270(5.2)x1,x20 x1,x2整数,解 先不考虑条件,即解相应的线性规划B,(见图5-2),得最优解x1=4.81,x2=1.82,z0=356,可见它不符合整数条件。这时z0是问题A的最优目标函数值z*的上界,记作z0=。而在x1=0,x2=0时,显然是问题A的一个整数可行解,这时z=0,是z*的一个下界,记作=0,即0z*356。,分支定界法的解法,首先注意其中一个非整数变量的解,如x1,在问题B的解中x1=4.81。于是对原问题增加两个约束条件x14,x15可将原问题分解为两个子问题B1和B2(即两支),给每支增加一个约束条件,如图5-3所示。这并不影响问题A的可行域,不考虑整数条件解问题B1和B2,称此为第一次迭代。得到最优解为:,图5-3,x14,x15,显然没有得到全部变量是整数的解。因z1z2,故将 改为349,那么必存在最优整数解,得到z*,并且0z*349继续对问题B1和B2进行分解 因z1z2,故先分解B1为两支。增加条件x22者,称为问题B3;增加条件x23者称为问题B4。在图5-3中再舍去x22与x33之间的可行域,再进行第二次迭代。,分支定界法的解法,分支定界法的解法,继续对问题B2进行分解,解题的过程都列在图5-4中。,图5-4,从以上解题过程可得到,用分支定界法求解整数线性规划(最大化)问题的步骤为:,将要求解的整数线性规划问题称为问题A,将与它相应的线性规划问题称为问题B。(1)解问题B,可能得到以下情况之一。B没有可行解,这时A也没有可行解,则停止。B有最优解,并符合问题A的整数条件,B的最优解即为A的最优解,则停止。B有最优解,但不符合问题A的整数条件,记它的目标函数值为,(2)用观察法找问题A的一个整数可行解,一般可取xj=0,j=1,n,试探,求得其目标函数值,并记作。以z*表示问题A的最优目标函数值;这时有,第一步:分支,在B的最优解中任选一个不符合整数条件的变量xj,其值为bj,以bj表示小于bj的最大整数。构造两个约束条件xjbj和xjbj+1将这两个约束条件,分别加入问题B,求两个后继规划问题B1和B2。不考虑整数条件求解这两个后继问题。定界,以每个后继问题为一分支标明求解的结果,与其他问题的解的结果中,找出最优目标函数值最大者作为新的上界。从已符合整数条件的各分支中,找出目标函数值为最大者作为新的下界,若无可行解,,分支定界法的解法,第二步:比较与剪支,各分支的最优目标函数中若有小于 者,则剪掉这支(用打表示),即以后不再考虑了。若大于,且不符合整数条件,则重复第一步骤。一直到最后得到z*为止,得最优整数解xj*,j=1,n。用分支定界法可解纯整数线性规划问题和混合整数线性规划问题。它比穷举法优越。因为它仅在一部分可行解的整数解中寻求最优解,计算量比穷举法小。若变量数目很大,其计算工作量也是相当可观的。,第3节 割平面解法,整数线性规划问题的可行域是整数点集(或称格点集),割平面解法的思路是:首先不考虑变量xi是整数这一条件,仍然是用解线性规划的方法去解整数线性规划问题,若得到非整数的最优解,然后增加能割去非整数解的线性约束条件(或称为割平面)使得由原可行域中切割掉一部分,这部分只包含非整数解,但没有切割掉任何整数可行解。这个方法就是指出怎样找到适当的割平面(不见得一次就找到),使切割后最终得到这样的可行域,它的一个有整数坐标的极点恰好是问题的最优解。这个方法是提出来的,所以又称为Gomory的割平面法。以下只讨论纯整数线性规划的情形,现举例说明。,例3 求解,目标函数 max z=x1+x2 约束条件:-x1+x21 3x1+x24(5-3)x1,x20 x1,x2 整数,如不考虑条件,容易求得相应的线性规划的最优解:x1=34,x2=74,max z=104,它就是图5-5中域R的极点A,但不合于整数条件。,现设想,如能找到像CD那样的直线去切割域R(图5-6),去掉三角形域ACD,那么具有整数坐标的C点(1,1)就是域R的一个极点,,如在域R上求解,而得到的最优解又恰巧在C点就得到原问题的整数解,所以解法的关键就是怎样构造一个这样的“割平面”CD,尽管它可能不是唯一的,也可能不是一步能求到的。下面仍就本例说明:,在原问题的前两个不等式中增加非负松弛变量x3、x4,使两式变成等式约束:-x1+x2+x3=1 3x1+x2+x4=4 不考虑条件,用单纯形表解题,见表5-2。,第3节 割平面解法,表5-2,从表5-2的最终计算表中,得到非整数的最优解:x1=3/4,x2=7/4,x3=x4=0,max z=5/2,不能满足整数最优解的要求。为此考虑将带有分数的最优解的可行域中分数部分割去,再求最优解。就可以得到整数的最优解。,可从最终计算表中得到非整数变量对应的关系式:,为了得到整数最优解。将上式变量的系数和常数项都分解成整数和非负真分数两部分之和,(1+0)x1+(-1+3/4)x3+1/4x4=0+3/4 x2+(3/4)x3+(1/4)x4=1+3/4 然后将整数部分与分数部分分开,移到等式左右两边,得到:,现考虑整数条件,要求x1、x2都是非负整数,于是由条件、可知x3、x4也都是非负整数,这一点对以下推导是必要的,如不都是整数,则应在引入x3、x4之前乘以适当常数,使之都是整数。在上式中(其实只考虑一式即可)从等式左边看是整数;等式右边也应是整数。但在等式右边的()内是正数;所以等式右边必是非正数。就是说,右边的整数值最大是零。于是整数条件可由下式所代替;,即-3x3-x4-3 这就得到一个切割方程(或称为切割约束),将它作为增加约束条件,再解例3。引入松弛变量x5,得到等式-3x3-x4+x5=-3将这新的约束方程加到表5-2的最终计算表,得表5-3。,表5-3,从表5-3的b列中可看到,这时得到的是非可行解,于是需要用对偶单纯形法继续进行计算,选择x5为换出变量,计算,将x3做为换入变量,再按原单纯形法进行迭代,得表5-4。,注意:新得到的约束条件-3x3-x4-3,如用x1、x2表示,由、式得3(1+x1-x2)+(4-3x1-x2)3x21这就是(x1,x2)平面内形成新的可行域,即包括平行于x1轴的直线x2=1和这直线下的可行区域,整数点也在其中,没有切割掉。直观地表示在图5-7中。但从解题过程来看,这一步是不必要的。,图5-7,现把求一个切割方程的步骤归纳为:,(1)令xi是相应线性规划最优解中为分数值的一个基变量,由单纯形表的最终表得到,其中iQ(Q指构成基变量号码的集合)K kK(K指构成非基变量号码的集合),(2)将bi和ik都分解成整数部分N与非负真分数f之和,即,bi=Ni+fi,其中0fi1ik=Nik+fik,其中0fik1(5-5)而N表示不超过b的最大整数。例如:若b=2.35,则N=2,f=0.35若b=-0.45,则N=-1,f=0.55代入(5-4)式得,(3)现在提出变量(包括松弛变量,参阅例3的注)为整数的条件(当然还有非负的条件).,这时,上式由左边看必须是整数,但由右边看,因为0fi1,所以不能为正,即,这就是一个切割方程。,由(5-4)式,(5-6)式,(5-7)式可知:切割方程(5-7)式真正进行了切割,至少把非整数最优解这一点割掉了。没有割掉整数解,这是因为相应的线性规划的任意整数可行解都满足(5-7)式的缘故。,返回,第4节 0-1型整数规划,0-1型整数线性规划是整数线性规划中的特殊情形,它的变量xi仅取值0或1。这时xi称为0-1变量,或称二进制变量.xi仅取值0或1这个条件可由下述约束条件所代替。xi1,xi0,整数 它和一般整数线性规划的约束条件形式是一致的。在实际问题中,如果引入0-1变量,就可以把有各种情况需要分别讨论的线性规划问题统一在一个问题中讨论了。在本节我们先介绍引入0-1变量的实际问题,再研究解法。,注:,如果变量xi不是仅取值0或1,而是可取其他范围的非负整数,这时可利用二进制的记数法将它用若干个0-1变量来代替。例如,在给定的问题中,变量x可任取0与10之间的任意整数时,令x=20 x0+21x1+22x2+23x3.这时,x就可用4个0-1变量x0,x1,x2,x3来代替。,4.1 引入0-1变量的实际问题,1.投资场所的选定相互排斥的计划例4 某公司拟在市东、西、南三区建立门市部。拟议中有7个位置(点)Ai(i=1,2,7)可供选择。规定:在东区,由A1,A2,A3三个点中至多选两个;在西区,由A4,A5两个点中至少选一个;在南区,由A6,A7两个点中至少选一个。如选用Ai点,设备投资估计为bi元,每年可获利润估计为ci元,但投资总额不能超过B元。问应选择哪几个点可使年利润为最大?,解题时先引入0-1变量xi(=1,2,7),于是问题可列成:,2.相互排斥的约束条件,在本章开始的例1中,关于运货的体积限制为5x1+4x224(5-9)今设运货有车运和船运两种方式,上面的条件系用车运时的限制条件,如用船运时关于体积的限制条件为 7x1+3x245(5-10)这两条件是互相排斥的。为了统一在一个问中,引入0-1变量y,令,于是(5-9)式和(5-10)式可由下述的条件(5-11)式和(5-12)式来代替:5x1+4x224+yM(5-11)7x1+3x245+(1-y)M(5-12),其中M是充分大的数。读者可以验证,当y=0时,(5-11)式就是(5-9)式,而(5-12)式自然成立,因而是多余的。当y=1时(5-12)式就是(5-10)式,而(5-11)式是多余的。引入的变量y不必出现在目标函数内,即认为在目标函数式内y的系数为0。如果有m个互相排斥的约束条件(型):i1x1+i2x2+inxnbi,i=1,2,,m,为了保证这m个约束条件只有一个起作用,我们引入m个0-1变量yi(i=1,2,,m)和一个充分大的常数M,而下面这一组m+1个约束条件i1x+i2x2+inxnbi+yiM,i=1,2,,m(5-13)y1+y2+ym=m-1(5-14)就合于上述的要求。这是因为,由于(5-14)式,m个yi中只有一个能取0值,设yi*=0,代入(5-13)式,就只有i=i*的约束条件起作用,而别的式子都是多余的。,3.关于固定费用的问题,在讨论线性规划时,有些问题是要求使成本为最小。那时总设固定成本为常数,并在线性规划的模型中不必明显列出。但有些固定费用(固定成本)的问题不能用一般线性规划来描述,但可改变为混合整数线性规划来解决,见下例。,例5 某工厂为了生产某种产品,有几种不同的生产方式可供选择,如选定投资高的生产方式(选购自动化程度高的设备),由于产量大,因而分配到每件产品的变动成本就降低;反之,如选定投资低的生产方式,将来分配到每件产品的变动成本可能增加,所以必须全面考虑。今设有三种方式可供选择,令 xj表示采用第j种方式时的产量;cj表示采用第j种方式时每件产品的变动成本;kj表示采用第j种方式时的固定成本。为了说明成本的特点,暂不考虑其他约束条件。采用各种生产方式的总成本分别为,第4节 0-1型整数规划,在构成目标函数时,为了统一在一个问题中讨论,现引入0-1变量yj,令,于是目标函数min z=(k1y1+c1x1)+(k2y2+c2x2)+(k3y3+c3x3),(5-15)式这个规定可由以下3个线性约束条件表示:,xjyjM,j=1,2,3(5-16)其中M是个充分大的常数。(5-16)式说明,当xj0时yj必须为1;当xj=0时只有yj为0时才有意义,所以(5-16)式完全可以代替(5-15)式,4.2 0-1型整数线性规划的解法,解0-1型整数线性规划最容易想到的方法,和一般整数线性规划的情形一样,就是穷举法,即检查变量取值为0或1的每一种组合,比较目标函数值以求得最优解,这就需要检查变量取值的2n个组合。对于变量个数n较大(例如n10),这几乎是不可能的。因此常设计一些方法,只检查变量取值的组合的一部分,就能求到问题的最优解。这样的方法称为隐枚举法(implicit enumeration),分枝定界法也是一种隐枚举法。当然,对有些问题隐枚举法并不适用,所以有时穷举法还是必要的。,下面举例说明一种解0-1型整数线性规划的隐枚举法,例6 目标函数 max z=3x1-2x2+3x3约束条件:x1+2x2-x32 x1+4x2+x34(5-17)x1+x23 4x1+x36 x1,x2,x3=0或1,解题时先通过试探的方法找一个可行解,容易看出(x1,x2,x3)=(1,0,0)就是合于条件的,算出相应的目标函数值z=3。,我们求最优解,对于极大化问题,当然希望z3,于是增加一个约束条件:3x1-2x2+5x33 后加的条件称为过滤的条件(filtering constraint)。这样,原问题的线性约束条件就变成5个。用全部枚举的方法,3个变量共有23=8个解,原来4个约束条件,共需32次运算。现在增加了过滤条件,如按下述方法进行,就可减少运算次数。将5个约束条件按顺序排好(表5-5),对每个解,依次代入约束条件左侧,求出数值,看是否适合不等式条件,如某一条件不适合,同行以下各条件就不必再检查,因而就减少了运算次数。,本例计算过程如表5-5,实际只作24次运算。于是求得最优解(x1,x2,x3)=(1,0,1),max z=8在计算过程中,若遇到z值已超过条件右边的值,应改变条件,使右边为迄今为止最大者,然后继续作。例如,当检查点(0,0,1)时因z=5(3),所以应将条件换成3x1-2x2+5x35 这种对过滤条件的改进,更可以减少计算量。,4.2 0-1型整数线性规划的解法,表5-5,注意:,一般常重新排列xi的顺序使目标函数中xi的系数是递增(不减)的,在上例中,改写 z=3x1-2x2+5x3=-2x2+3x1+5x3因为-2,3,5是递增的序,变量(x2,x1,x3)也按下述顺序取值:(0,0,0),(0,0,1),(0,1,0),(0,1,1),这样,最优解容易比较早的发现。,再结合过滤条件的改进,更可使计算简化,在上例中max z=-2x2+3x1+5x3-2x2+3x1+5x33 2x2+x1-x32 4x2+x1+x34(5-18)x2+x13 4x2+x36 解题时按下述步骤进行(见表5-6):,表5-6(a)(b),改进过滤条件,用-2x2+3x1+5x35 代替,继续进行。再改进过滤条件,用2x2+3x1+5x38 代替,再继续进行。至此,z值已不能改进,即得到最优解,解答如前,但计算已简化。,4.2 0-1型整数线性规划的解法,表5-6(c),返回,

    注意事项

    本文(整数线性规划-第1-4节.ppt)为本站会员(牧羊曲112)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开