资源描述:
《运筹学PPT 第五章 整数规划课件.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、Chapter5整数规划(IntegerProgramming)整数规划的特点及应用分支定界法割平面法0-1整数规划指派问题本章主要内容:在很多场合,我们建立最优化模型时,实际问题要求决策变量只能取整数值而非连续取值。此时,这类最优化模型就称为整数规划(离散最优化)模型。整数规划的求解往往比线性规划求解困难得多,而且,一般来说不能简单地将相应的线性规划的解取整来获得。整数规划的特点及应用整数规划(简称:IP)要求一部分或全部决策变量取整数值的规划问题称为整数规划。不考虑整数条件,由余下的目标函数和约束条件构成的规划问题称为该整数规划问题的松弛问题。若该松弛
2、问题是一个线性规划,则称该整数规划为整数线性规划。整数线性规划数学模型的一般形式:整数规划的特点及应用整数线性规划问题的种类:纯整数线性规划:指全部决策变量都必须取整数值的整数线性规划。混合整数线性规划:决策变量中有一部分必须取整数值,另一部分可以不取整数值的整数线性规划。0-1型整数线性规划:决策变量只能取值0或1的整数线性规划。整数规划的特点及应用整数规划的典型例子例5.1工厂A1和A2生产某种物资。由于该种物资供不应求,故需要再建一家工厂。相应的建厂方案有A3和A4两个。这种物资的需求地有B1,B2,B3,B4四个。各工厂年生产能力、各地年需求量、各
3、厂至各需求地的单位物资运费cij,见下表:工厂A3或A4开工后,每年的生产费用估计分别为1200万或1500万元。现要决定应该建设工厂A3还是A4,才能使今后每年的总费用最少。整数规划的特点及应用解:这是一个物资运输问题,特点是事先不能确定应该建A3还是A4中哪一个,因而不知道新厂投产后的实际生产物资。为此,引入0-1变量:再设xij为由Ai运往Bj的物资数量,单位为千吨;z表示总费用,单位万元。则该规划问题的数学模型可以表示为:整数规划的特点及应用混合整数规划问题整数规划的特点及应用例5.2现有资金总额为B。可供选择的投资项目有n个,项目j所需投资额和预
4、期收益分别为aj和cj(j=1,2,..,n),此外由于种种原因,有三个附加条件:若选择项目1,就必须同时选择项目2。反之不一定;项目3和4中至少选择一个;项目5,6,7中恰好选择2个。应该怎样选择投资项目,才能使总预期收益最大。整数规划的特点及应用解:对每个投资项目都有被选择和不被选择两种可能,因此分别用0和1表示,令xj表示第j个项目的决策选择,记为:投资问题可以表示为:整数规划的特点及应用例5.3指派问题或分配问题。人事部门欲安排四人到四个不同岗位工作,每个岗位一个人。经考核四人在不同岗位的成绩(百分制)如表所示,如何安排他们的工作使总成绩最好。整数
5、规划的特点及应用设数学模型如下:要求每人做一项工作,约束条件为:整数规划的特点及应用每项工作只能安排一人,约束条件为:变量约束:整数规划的特点及应用整数规划问题解的特征:整数规划问题的可行解集合是它松弛问题可行解集合的一个子集,任意两个可行解的凸组合不一定满足整数约束条件,因而不一定仍为可行解。整数规划问题的可行解一定是它的松弛问题的可行解(反之不一定),但其最优解的目标函数值不会优于后者最优解的目标函数值。整数规划的特点及应用例5.3设整数规划问题如下首先不考虑整数约束,得到线性规划问题(一般称为松弛问题)整数规划的特点及应用用图解法求出最优解为:x1=
6、3/2,x2=10/3,且有Z=29/6现求整数解(最优解):如用舍入取整法可得到4个点即(1,3),(2,3),(1,4),(2,4)。显然,它们都不可能是整数规划的最优解。x1x2⑴⑵33(3/2,10/3)按整数规划约束条件,其可行解肯定在线性规划问题的可行域内且为整数点。故整数规划问题的可行解集是一个有限集,如右图所示。其中(2,2),(3,1)点的目标函数值最大,即为Z=4。整数规划的特点及应用整数规划问题的求解方法:分支定界法和割平面法匈牙利法(指派问题)分支定界法1)求整数规划的松弛问题最优解;若松弛问题的最优解满足整数要求,得到整数规划的最
7、优解,否则转下一步;2)分支与定界:任意选一个非整数解的变量xi,在松弛问题中加上约束:xi≤[xi]和xi≥[xi]+1组成两个新的松弛问题,称为分枝。新的松弛问题具有特征:当原问题是求最大值时,目标值是分枝问题的上界;当原问题是求最小值时,目标值是分枝问题的下界。检查所有分枝的解及目标函数值,若某分枝的解是整数并且目标函数值大于(max)等于其它分枝的目标值,则将其它分枝剪去不再计算,若还存在非整数解并且目标值大于(max)整数解的目标值,需要继续分枝,再检查,直到得到最优解。分支定界法的解题步骤:分支定界法例5.4用分枝定界法求解整数规划问题解:首先
8、去掉整数约束,变成一般线性规划问题(原整数规划问题的松驰问题)LP