- 58
- 0
- 约6.56千字
- 约 55页
- 2018-03-16 发布于北京
- 举报
运筹学-第五章-整数规划.ppt
Chapter5 整数规划( Integer Programming ) 整数规划的特点及应用 整数规划 要求一部分或全部决策变量取整数值的规划问题称为整数规划。不考虑整数条件,由余下的目标函数和约束条件构成的规划问题称为该整数规划问题的松弛问题。若该松弛问题是一个线性规划,则称该整数规划为整数线性规划。 整数规划的特点及应用 整数线性规划问题的种类: 整数规划的特点及应用 整数规划举例 整数规划的特点及应用 解:这是一个物资运输问题,特点是事先不能确定应该建A3还是A4中哪一个,因而不知道新厂投产后的实际生产物资。为此,引入0-1变量: 整数规划的特点及应用 整数规划的特点及应用 例5.2 现有资金总额为B。可供选择的投资项目有n个,项目j所需投资额和预期收益分别为aj和cj(j=1,2,..,n),此外由于种种原因,有三个附加条件: 若选择项目1,就必须同时选择项目2。反之不一定; 项目3和4中至少选择一个; 项目5,6,7中恰好选择2个。 应该怎样选择投资项目,才能使总预期收益最大。 整数规划的特点及应用 解:对每个投资项目都有被选择和不被选择两种可能,因此分别用0和1表示,令xj表示第j个项目的决策选择,记为: 整数规划的特点及应用 例5.3 指派问题或分配问题。人事部门欲安排四人到四个不同岗位工作,每个岗位一个人。经考核四人在不同岗位的成绩(百分制)如表所示,如何安排他们的工作使总成绩最好。 整数规划的特点及应用 整数规划的特点及应用 每项工作只能安排一人,约束条件为: 整数规划的特点及应用 例5.4 设整数规划问题如下 整数规划的特点及应用 用图解法求出最优解为:x1=3/2, x2 = 10/3,且有Z = 29/6 整数规划的特点及应用 整数规划问题的求解方法: 分支定界法 1)求整数规划的松弛问题最优解; 若松弛问题的最优解满足整数要求,得到整数规划的最优解,否则转2) 2)分支与定界: 任意选一个非整数解的变量xi,在松弛问题中加上约束: xi≤[xi] 和 xi≥[xi]+1 组成两个新的松弛问题,称为分枝。新的松弛问题具有特征:当原问题是求最大值时,目标值是分枝问题的上界;当原问题是求最小值时,目标值是分枝问题的下界。 检查所有分枝的解及目标函数值,若某分枝的解是整数并且目标函数值大于(max)等于其它分枝的目标值,则将其它分枝剪去不再计算,若还存在非整数解并且目标值大于(max)整数解的目标值,需要继续分枝,再检查,直到得到最优解。 分支定界法 例5.4 用分枝定界法求解整数规划问题 分支定界法 用图解法求松弛问题的最优解,如图所示。 分支定界法 分支: 分支定界法 先求LP1,如图所示。此时在B点取得最优解。 x1=1, x2 =3, Z(1)=-16 找到整数解,问题已探明,此枝停止计算。 分支定界法 在IP2中分别再加入条件: x2≤3, x2≥4 得下式两支: 分支定界法 分支定界法 在(LP21)的基础上继续分枝。加入条件3≤x1≤2有下式: 分支定界法 分支定界法 原整数规划问题的最优解为: x1=2, x2 =3, Z* =-17 以上的求解过程可以用一个树形图表示如右: 分支定界法 例5.5 用分枝定界法求解 分支定界法 分支定界法 分支定界法 分支定界法 分支定界法 上述分枝过程可用下图表示: 小结 0-1 整数规划 指派问题 一、指派问题的数学模型的标准形式: 指派问题 指派问题的数学模型为: 指派问题 二、指派问题的匈牙利法求解步骤: 指派问题 找独立0元素,常用的步骤为: 指派问题 指派问题 4) 变换矩阵(bij)以增加0元素 在没有被直线通过的所有元素中找出最小值,没有被直线通过的所有元素减去这个最小元素;直线交点处的元素加上这个最小值。新系数矩阵的最优解和原问题仍相同。转回第2步。 匈牙利法 例5.6 有一份中文说明书,需译成英、日、德、俄四种文字,分别记作A、B、C、D。现有甲、乙、丙、丁四人,他们将中文说明书译成不同语种的说明书所需时间如下表所示,问如何分派任务,可使总时间最少? 匈牙利法 解:1)变换系数矩阵,增加0元素。 匈牙利法 3)作最少的直线覆盖所有0元素 匈牙利法 匈牙利法 例4.7 已知四人分别完成四项工作所需时间如下表,求最优分配方案。 匈牙利法 解:1)变换系数矩阵,增加0元素。 匈牙利法 例4.8 已知五人分别完成五项工作耗费如下表,求最优分配方案。 匈牙利法 解:1)变换系数矩阵,增加0元素。 匈牙利法 匈牙利法 匈牙利法 匈牙利法 匈牙利法 匈牙利法 匈牙利法 课堂练习:用匈牙利法求解下列指派问题。 匈牙利法 LP0:X=(3.57,7.14),Z0=35.7 LP1:X=(3
原创力文档

文档评论(0)