1、整 数 规 划(Integer Programming),整数规划的模型,分支定界法,割平面法,01 整数规划,指派问题,(一)、整数规划问题实例,例一、合理下料问题设用某型号的圆钢下零件A1, A2,Am 的毛坯。在一根圆钢上下料的方式有B1,B2, Bn 种,每种下料方式可以得到各种零件的毛坯数以及每种零件的需要量,如表所示。问怎样安排下料方式,使得即满足需要,所用的原材料又最少?,一、整数规划的模型,设:xj 表示用Bj (j=1.2n) 种方式下料根数 模型:,例二、某公司计划在m个地点建厂,可供选择的地点有A1,A2Am ,他们的生产能力分别是a1,a2,am(假设生产同一产品)。第
2、i个工厂的建设费用为fi (i=1.2m),又有n个地点B1,B2, Bn 需要销售这种产品,其销量分别为b1.b2bn 。从工厂运往销地的单位运费为Cij。试决定应在哪些地方建厂,即满足各地需要,又使总建设费用和总运输费用最省?,设: xij 表示从工厂运往销地的运量(i=1.2m、j=1.2n), 1 在Ai建厂 又设 Yi (i=1.2m) 0 不在Ai建厂 模型:,例三、机床分配问题 设有m台同类机床,要加工n种零件。已知各种零件的加工时间分别为a1,a2,an ,问如何分配,使各机床的总加工任务相等,或者说尽可能平衡。,设: 1 分配第i台机床加工第j种零件; xij (i=1.2m
3、,j=1.2n) 0 相反。于是,第i台机床加工各种零件的总时间为:,又由于一个零件只能在一台机床上加工,所以有,因此,求xij ,使得,(二)、整数规划的数学模型,一般形式,依照决策变量取整要求的不同,整数规划可分为纯整数规划、全整数规划、混合整数规划、01整数规划。,纯整数规划:所有决策变量要求取非负整数(这时引进的松弛变量可以不要求取整数)。,全整数规划:除了所有决策变量要求取非负整数外,系数aij和常数bi也要求取整数(这时引进的松弛变量也必须是整数)。,混合整数规划:只有一部分的决策变量要求取非负整数,另一部分可以取非负实数。,01整数规划:所有决策变量只能取 0 或 1 两个整数。
4、,(三)、整数规划与线性规划的关系,从数学模型上看整数规划似乎是线性规划的一种特殊形式,求解只需在线性规划的基础上,通过舍入取整,寻求满足整数要求的解即可。但实际上两者却有很大的不同,通过舍入得到的解(整数)也不一定就是最优解,有时甚至不能保证所得到的解是整数可行解。举例说明。,例:设整数规划问题如下,首先不考虑整数约束,得到线性规划问题(一般称为松弛问题)。,用图解法求出最优解x13/2, x2 = 10/3且有Z = 29/6,x1,x2,3,3,(3/2,10/3),现求整数解(最优解):如用“舍入取整法”可得到4个点即(1,3) (2,3)(1,4)(2,4)。显然,它们都不可能是整数
5、规划的最优解。,按整数规划约束条件,其可行解肯定在线性规划问题的可行域内且为整数点。故整数规划问题的可行解集是一个有限集,如图所示。,因此,可将集合内的整数点一一找出,其最大目标函数的值为最优解,此法为完全枚举法。 如上例:其中(2,2)(3,1)点为最大值,Z=4。,目前,常用的求解整数规划的方法有: 分支定界法和割平面法; 对于特别的01规划问题采用隐枚举法和匈牙利法。,(一)、基本思路,考虑纯整数问题:,整数问题的松弛问题:,二、分枝定界法,1、先不考虑整数约束,解( IP )的松弛问题( LP ),可能得到以下情况之一: .若( LP )没有可行解,则( IP )也没有可行解,停止计算
6、。 .若( LP )有最优解,并符合( IP )的整数条件,则( LP )的最优解即为( IP )的最优解,停止计算。 .若( LP )有最优解,但不符合( IP )的整数条件,转入下一步。为讨论方便,设( LP )的最优解为:,2、定界: 记( IP )的目标函数最优值为Z* ,以Z(0) 作为Z* 的上界,记为 Z(0) 。再用观察法找的一个整数可行解 X,并以其相应的目标函数值 Z作为Z* 的下界,记为Z Z,也可以令Z,则有: Z Z* ,3、分枝: 在( LP )的最优解 X(0)中,任选一个不符合整数条件的变量,例如xr= (不为整数),以 表示不超过 的最大整数。构造两个约束条件
7、 xr 和xr 1,如此反复进行,直到得到ZZ* 为止,即得最优解 X* 。,将这两个约束条件分别加入问题( IP ) ,形成两个子问题( IP1)和( IP2 ) ,再解这两个问题的松弛问题( LP1)和( LP2) 。,4、修改上、下界:按照以下两点规则进行。 .在各分枝问题中,找出目标函数值最大者作为新的上界; .从已符合整数条件的分枝中,找出目标函数值最大者作为新的下界。,5、比较与剪枝 : 各分枝的目标函数值中,若有小于Z 者,则剪掉此枝,表明此子问题已经探清,不必再分枝了;否则继续分枝。,例一:用分枝定界法求解整数规划问题(用图解法计算),记为(IP),解:首先去掉整数约束,变成一
8、般线性规划问题,记为(LP),(二)、例题,用图解法求(LP)的最优解,如图所示。,x1,x2,3,3,(18/11,40/11),对于x118/111.64, 取值x1 1, x1 2对于x2 =40/11 3.64,取值x2 3 ,x2 4先将(LP)划分为(LP1)和(LP2),取x1 1, x1 2,x118/11, x2 =40/11 Z(0) =218/11(19.8)即Z 也是(IP)最小值的下限。,有下式:,现在只要求出(LP1)和(LP2)的最优解即可。,x1,x2,3,3,(18/11,40/11),先求(LP1),如图所示。此时B 在点取得最优解。x11, x2 =3,
9、Z(1)16找到整数解,问题已探明,此枝停止计算。,1,1,同理求(LP2) ,如图所示。在C 点取得最优解。即x12, x2 =10/3, Z(2) 56/318.7 Z2 Z116 原问题有比(16)更小的最优解,但 x2 不是整数,故利用 3 10/34 加入条件。,B,A,C,加入条件: x23, x24 有下式:,只要求出(LP3)和(LP4)的最优解即可。,x1,x2,3,3,(18/11,40/11),1,1,B,A,C,先求(LP3),如图所示。此时D 在点取得最优解。即 x112/52.4, x2 =3, Z(3)-87/5-17.4 Z(5),F,如对 Z(6) 继续分解,
10、其最小值也不会低于15.5 ,问题探明,剪枝。,至此,原问题(IP)的最优解为: x1=2, x2 =3, Z* = Z(5) 17以上的求解过程可以用一个树形图表示如右:,LP1x1=1, x2=3Z(1) 16,LPx1=18/11, x2=40/11Z(0) 19.8,LP2x1=2, x2=10/3Z(2) 18.5,LP3x1=12/5, x2=3Z(3) 17.4,LP4无可行解,LP5x1=2, x2=3Z(5) 17,LP6x1=3, x2=5/2Z(6) 15.5,x11,x12,x23,x24,x12,x13,练习:用分枝定界法求解整数规划问题 (图解法),x11,x12,
11、x22,x23,x22,x23,x12,x13,LP1x1=1, x2=7/3Z(1) 10/3,LPx1=2/3, x2=10/3Z(0) 29/6,LP2x1=2, x2=23/9Z(2) 41/9,LP3x1=33/14, x2=2Z(3) 61/14,LP4无可行解,LP7x1=2, x2=2Z(7) 4,LP8x1=3, x2=1Z(8) 4,x11,x12,x22,x23,x12,x13,解:用单纯形法解对应的(LP)问题,如表所示,获得最优解。,初始表,最终表,例二、用分枝定界法求解整数规划问题(单纯形法),x1=13/4 x2=5/2 Z(0) =59/414.75 选 x2
12、进行分枝,即增加两个约束,2 x2 3 有下式:,分别在(LP1)和(LP2)中引入松弛变量x5和x6 ,将新加约束条件加入上表计算。即 x2+ x5= 2 , x2+x6=3 得下表:,x1=7/2, x2=2 Z(1) =29/2=14.5继续分枝,加入约束 3 x1 4,LP1,LP2,x1=5/2, x2=3 Z(2) =27/2=13.5 Z(2) Z(1) 先不考虑分枝,接(LP1)继续分枝,加入约束 4 x1 3,有下式:,分别引入松弛变量x7 和 x8 ,然后进行计算。,x1=3, x2=2 Z(3) =13找到整数解,问题已探明,停止计算。,LP3,x1=4, x2=1 Z(
13、4) =14找到整数解,问题已探明,停止计算。,LP4,树形图如下:,LP1x1=7/2, x2=2Z(1)29/2=14.5,LPx1=13/4, x2=5/2Z(0) 59/4=14.75,LP2x1=5/2, x2=3Z(2)27/2=13.5,LP3x1=3, x2=2Z(3) 13,LP4x1=4, x2=1Z(4) 14,x22,x23,x13,x14,练习:用分枝定界法求解整数规划问题 (单纯形法),LP1x1=1, x2=3Z(1) 16,LPx1=18/11, x2=40/11Z(0) 19.8,LP2x1=2, x2=10/3Z(2) 18.5,LP3x1=12/5, x2
14、=3Z(3) 17.4,LP4无可行解,LP5x1=2, x2=3Z(5) 17,LP6x1=3, x2=5/2Z(6) 15.5,x11,x12,x23,x24,x12,x13,(一)、计算步骤:1、用单纯形法求解( IP )对应的松弛问题( LP ): .若( LP )没有可行解,则( IP )也没有可行解,停止计算。 .若( LP )有最优解,并符合( IP )的整数条件,则( LP )的最优解即为( IP )的最优解,停止计算。 .若( LP )有最优解,但不符合( IP )的整数条件,转入下一步。,三、割平面法,2、从(LP)的最优解中,任选一个不为整数的分量xr,将最优单纯形表中该
15、行的系数 和 分解为整数部分和小数部分之和,并以该行为源行,按下式作割平面方程:,3、将所得的割平面方程作为一个新的约束条件置于最优单纯形表中(同时增加一个单位列向量),用对偶单纯形法求出新的最优解,返回1。,的小数部分,的小数部分,例一:用割平面法求解整数规划问题,解:增加松弛变量x3和x4 ,得到(LP)的初始单纯形表和最优单纯形表:,此题的最优解为:X= (1 , 3/2)T Z = 3/2 但不是整数最优解,引入割平面。以x2 为源行生成割平面,由于 1/4=0+1/4, 3/2=1+1/2, 我们已将所需要的数分解为整数和分数,所以,生成割平面的条件为:,现将生成的割平面条件加入松弛
16、变量,然后加到表中:,此时,X1 (2/3, 1), Z=1,仍不是整数解。继续以x1为源行生成割平面,其条件为:,将生成的割平面条件加入松弛变量,然后加到表中:,至此得到最优表,其最优解为 X= (1 , 1) , Z = 1, 这也是原问题的最优解。,有以上解题过程可见,表中含有分数元素且算法过程中始终保持对偶可行性,因此,这个算法也称为分数对偶割平面算法。,例二:用割平面法求解整数规划问题,初始表,最优表,割平面方程:,引入松弛变量s1 后得到下式,将此约束条件加到上表中,继续求解。,得到整数最优解,即为整数规划的最优解,而且此整数规划有两个最优解: X= (0, 4), Z = 4, 或 X= (2, 2), Z = 4。,(2 ,3),01 整数规划是一种特殊形式的整数规划,这时的决策变量xj 只取两个值0或1,一般的解法为隐枚举法。,例一、求解下列01 规划问题,四、01 整数规划,