


版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、第二章整数规划 1 概论1.1定义规划中的变量(部分或全部)限制为整数时,称为整数规划。若在线性规划模型中,变量限制为整数, 则称为整数线性规划。 目前所流行的求解整数规划的方法, 往往只适用于整数线性规划。目前还没有一种方法能有效地求解一切整数规划。1.2整数规划的分类如不加特殊说明,一般指整数线性规划。对于整数线性规划模型大致可分为两类:o2o 变量部分限制为整数的,称混合整数规划。1.2整数规划特点( i ) 原线性规划有最优解, 当自变量限制为整数后, 其整数规划解出现下述情况:原线性规划最优解全是整数,则整数规划最优解与线性规划最优解一致。整数规划无可行解。例 1 原线性规划为m i
2、 n zx1 x22x14x25,x1 0, x 20x10, x255 。其最优实数解为:, min z44有可行解(当然就存在最优解),但最优解值变差。例 2原线性规划为m i n zx1x22x14x26,x10, x 20x10, x233其最优实数解为:2, min z。2若限制整数得:x11, x 21, min z2 。( ii ) 整数规划最优解不能按照实数最优解简单取整而获得。1.3求解方法分类:( i )分枝定界法可求纯或混合整数线性规划。( ii )割平面法可求纯或混合整数线性规划。( iii )隐枚举法求解“0-1 ”整数规划:过滤隐枚举法;分枝隐枚举法。( iv )匈
3、牙利法解决指派问题(“ 0-1 ”规划特殊情形)。( v)蒙特卡洛法求解各种类型规划。下面将简要介绍常用的几种求解整数规划的方法。 2 分枝定界法对有约束条件的最优化问题 (其可行解为有限数) 的所有可行解空间恰当地进行系统搜索, 这就是分枝与定界内容。 通常,把全部可行解空间反复地分割为越来越小的子集,称为分枝;并且对每个子集内的解集计算一个目标下界(对于最小值问题),这称为定界。在每次分枝后,凡是界限超出已知可行解集目标值的那些子集不再进一步分枝,-11-这样,许多子集可不予考虑,这称剪枝。这就是分枝定界法的主要思路。分枝定界法可用于解纯整数或混合的整数规划问题。在本世纪六十年代初由Lan
4、dDoig 和 Dakin 等人提出的。由于这方法灵活且便于用计算机求解,所以现在它已是解整数规划的重要方法。目前已成功地应用于求解生产进度问题、旅行推销员问题、工厂选址问题、背包问题及分配问题等。设有最大化的整数规划问题A ,与它相应的线性规划为问题B ,从解问题B 开始,若其最优解不符合A 的整数条件,那么 B 的最优目标函数必是A 的最优目标函数z * 的上界,记作z ;而 A 的任意可行解的目标函数值将是z* 的一个下界z 。分枝定界法就是将 B 的可行域分成子区域的方法。逐步减小z 和增大z ,最终求到z* 。现用下例来说明:例 3 求解下述整数规划Maxz40x 190x 29x
5、17x2567x 120x 270x1 , x 2 0且为整数解 ( i)先不考虑整数限制,即解相应的线性规划B ,得最优解为:x14.8092, x 21.8168, z355.8779可见它不符合整数条件。这时z 是问题A 的最优目标函数值z* 的上界,记作z 。而x120显然是问题A 的一个整数可行解,这时 z 0,是 z* 的一个下界,记作z,0, x即 0z*356 。( ii )因为 x1, x2当前均为非整数,故不满足整数要求,任选一个进行分枝。设选 x1进行分枝,把可行集分成2 个子集:x1 4.80924, x14.8092 1 5因为 4 与 5 之间无整数,故这两个子集的
6、整数解必与原可行集合整数解一致。这一步称为分枝。这两个子集的规划及求解如下:问题 B1: Maxz40x190x 29x 17x 2567x 120 x 2700x14, x20最优解为:x14.0, x22.1, z 1349 。问题 B2:Maxz40x190x 29x17x2567x120x270x15, x 20最优解为:x15.0, x 21.57, z 1341.4 。再定界: 0z*349 。( iii )对问题B1 再进行分枝得问题B 11 和 B12 ,它们的最优解为-12-B11 : x 14, x22, z11 340B12: x 11.43,x2 3.00, z1232
7、7.14再定界: 340z*341 ,并将 B12剪枝。( iv )对问题B2 再进行分枝得问题B21 和 B22 ,它们的最优解为B21: x15.44,x2 1.00, z 22308B22无可行解。将B21, B22 剪枝。于是可以断定原问题的最优解为:x14, x 22, z*340从以上解题过程可得用分枝定界法求解整数规划(最大化)问题的步骤为:开始,将要求解的整数规划问题称为问题A ,将与它相应的线性规划问题称为问题 B 。( i )解问题 B 可能得到以下情况之一:(a) B 没有可行解,这时A 也没有可行解,则停止( b ) B 有最优解,并符合问题A 的整数条件,B 的最优解
8、即为A 的最优解,则停止。(c) B 有最优解,但不符合问题A 的整数条件,记它的目标函数值为z 。( ii )用观察法找问题A 的一个整数可行解,一般可取x j0, j1,n ,试探,求得其目标函数值,并记作z 。以 z*表示问题 A 的最优目标函数值;这时有z z*z进行迭代。第一步:分枝,在B 的最优解中任选一个不符合整数条件的变量x j,其值为 bj,以 b j 表示小于 bj 的最大整数。构造两个约束条件x j b j 和 x j bj 1将这两个约束条件,分别加入问题B ,求两个后继规划问题B1和 B2。不考虑整数条件求解这两个后继问题。定界,以每个后继问题为一分枝标明求解的结果,
9、与其它问题的解的结果中,找出最优目标函数值最大者作为新的上界z 。从已符合整数条件的各分支中,找出目标函数值为最大者作为新的下界z ,若无作用z 0 。第二步:比较与剪枝,各分枝的最优目标函数中若有小于z 者,则剪掉这枝,即以后不再考虑了。若大于z ,且不符合整数条件,则重复第一步骤。一直到最后得到z*z 为止。得最优整数解*x j , j 1, , n 。3 0 1 型整数规划0 1 型整数规划是整数规划中的特殊情形,它的变量x j 仅取值 0 或 1。这时 x j 称为 01 变量,或称二进制变量。x j 仅取值 0 或 1 这个条件可由下述约束条件:0x j1,整数-13-所代替,是和一
10、般整数规划的约束条件形式一致的。在实际问题中,如果引入01 变量,就可以把有各种情况需要分别讨论的线性规划问题统一在一个问题中讨论了。我们先介绍引入01 变量的实际问题,再研究解法。3.1引入01 变量的实际问题投资场所的选定相互排斥的计划例4某公司拟在市东、西、南三区建立门市部。拟议中有7 个位置(点)Ai (i 1,2, ,7)可供选择。规定在东区。由A1, A 2 , A 3 三个点中至多选两个;在西区。由A4, A 5两个点中至少选一个;在南区,由A6, A 7两个点中至少选一个。如选用Ai 点,设备投资估计为bi 元,每年可获利润估计为ci 元,但投资总额不能超过 B 元。问应选择哪
11、几个点可使年利润为最大?解题时先引入01 变量 xi (i1,2,7)令1,当A点被选中 ,xiii1,2,7 .0, 当 A 点没被选中 .于是问题可列写成:i7Maxzci xii 17bi xiBi 1x1x2x32x4x51或x6x71,xi01相互排斥的约束条件有两个相互排斥的约束条件5x1 4x224或 7x 13x245。为了统一在一个问题中,引入0 1变量 y ,则上述约束条件可改写为:5x 14x 224yM7x 13x 245 (1y) My0 或 1其中 M 是充分大的数。约束条件x10或 500x1800可改写为500yx1800yy0 或 1-14-如果有 m 个互相
12、排斥的约束条件:a xi11ain xn b ii1,2, m为了保证这 m 个约束条件只有一个起作用,我们引入m 个 01 变量 yi (i 1,2, m)M ,而下面这一组m1 个约束条和一个充分大的常数件a xa xbiyi Mi1,2, m(1)i11in ny1ymm 1(2)就合于上述的要求。这是因为,由于(2), m 个 yi 中只有一个能取0 值,设 yi *0 ,代入( 1),就只有i i * 的约束条件起作用,而别的式子都是多余的。3.1.3 关于固定费用的问题(Fixed Cost Problem)在讨论线性规划时,有些问题是要求使成本为最小。那时总设固定成本为常数,并在
13、线性规划的模型中不必明显列出。但有些固定费用(固定成本)的问题不能用一般线性规划来描述,但可改变为混合整数规划来解决,见下例。例 5 某工厂为了生产某种产品,有几种不同的生产方式可供选择,如选定的生产方式投资高(选购自动化程度高的设备),由于产量大,因而分配到每件产品的变动成本就降低; 反之,如选定的生产方式投资低, 将来分配到每件产品的变动成本可能增加。所以必须全面考虑。今设有三种方式可供选择,令xj 表示采用第cj 表示采用第kj 表示采用第jjj种方式时的产量;种方式时每件产品的变动成本;种方式时的固定成本。为了说明成本的特点,暂不考虑其它约束条件。采用各种生产方式的总成本分别为kic
14、i xi , 当 xPi当 x0,jj0j1,2,3 .0在构成目标函数时,为了统一在一个问题中讨论,现引入001 变量 y j ,令1,jx j当采用第种生产方式,即时,y j当不采用第种生产方式,即x j时(3)于是目标函数0,j0 .min z (k yc1x1)(k2ycx2)(k3yc3x3)11223( 3 )式这个规定可表为下述3 个线性约束条件:x jy j M ,j 1,2,3( 4)其中 M 是个充分大的常数。( 4)式说明,当 x j0 时 y j必须为1;当 x j0 时只有 y j为 0 时才有意义,所以(4)式完全可以代替(3)式。3.201 型整数规划解法之一(过
15、滤隐枚举法)解 01 型整数规划最容易想到的方法,和一般整数规划的情形一样,就是穷举法,即检查变量取值为0 或 1的每一种组合,比较目标函数值以求得最优解,这就需要检查变量取值的2n 个组合。对于变量个数n 较大(例如n10 ),这几乎是不可能的。因此常设计一些方法,只检查变量取值的组合的一部分,就能求到问题的最优解。这样的方法称为隐枚举法( Implicit Enumeration),分枝定界法也是一种隐枚举法。当然,对有-15-些问题隐枚举法并不适用,所以有时穷举法还是必要的。下面举例说明一种解0 1 型整数规划的隐枚举法。例 6 M a x z 3x 12x2 5x 3x12x2x32x
16、14x2x34x1x234x2x36x1, x2 , x 30 或 1求解思路及改进措施:( i) 先试探性求一个可行解,易看出( x1 , x 2 , x3 ) (1,0,0)满足约束条件,故为一个可行解,且 z 3 。( ii ) 因为是求极大值问题,故求最优解时,凡是目标值z 3的解不必检验是否满足约束条件即可删除, 因它肯定不是最优解,于是应增加一个约束条件(目标值下界):( iii ) 改进过滤条件。z 大的组( iv )由于对每个组合首先计算目标值以验证过滤条件,故应优先计算目标值合,这样可提前抬高过滤门槛,以减少计算量。 4 蒙特卡洛法(随机取样法)前面介绍的常用的整数规划求解方
17、法,主要是针对线性整数规划而言,而对于非线性整数规划目前尚未有一种成熟而准确的求解方法,因为非线性规划本身的通用有效解法尚未找到,更何况是非线性整数规划。然而,尽管整数规划由于限制变量为整数而增加了难度; 然而又由于整数解是有限个,于是为枚举法提供了方便。当然,当自变量维数很大和取值范围很宽情况下,企图用显枚举法 (即穷举法) 计算出最优值是不现实的,但是应用概率理论可以证明,在一定的计算量的情况下,完全可以得出一个满意解。例 7 已知非线性整数规划为:Maxzx223x24 x22x21x25348x12x23x3 x42 x50xi99(i1,5)x1x2x3x4x 5400x12 x22
18、x3x46 x5 8002x 1x26x3200x3x45x 5200对该题,目前尚无有效方法求出准确解。如果用显枚举法试探,共需计算(100) 51010 个点,其计算量非常之大。然而应用蒙特卡洛去随机计算106 个点,便可找到满意解,那么这种方法的可信度究竟怎样呢?下面就分析随机取样采集106 个点计算时,应用概率理论来估计一下可信度。不失一般性,假定一个整数规划的最优点不是孤立的奇点。假设目标函数落在高值区的概率分别为0.01 ,0.00001 ,则当计算 10 6个点后,有-16-任一个点能落在高值区的概率分别为10.99 10000000.9999(100 多位) ,10.99999
19、 10000000.999954602。解( i)首先编写M 文件 mente.m 定义目标函数f 和约束向量函数g ,程序如下:functionf,g=mengte(x);f=x(1)2+x(2)2+3*x(3)2+4*x(4)2+2*x(5)-8*x(1)-2*x(2)-3*x(3).-x(4)-2*x(5);g(1)=sum(x)-400;g(2)=x(1)+2*x(2)+2*x(3)+x(4)+6*x(5)-800;g(3)=2*x(1)+x(2)+6*x(3)-200;g(4)=x(3)+x(4)+5*x(5)-200;( ii )编写如下程序求问题的解:rand( state ,s
20、um(clock);p0=0;ticfori=1:105x=99*rand(5,1);x1=floor(x);x2=ceil(x);f,g=mengte(x1);ifsum(g=0)=4ifp0=fx0=x1;p0=f;endendf,g=mengte(x2);ifsum(g=0)=4ifp0=fx0=x2;p0=f;endendendx0,p0toc 5 整数规划的计算机解法整数规划问题的求解可以使用Lingo 等专用软件。对于一般的整数规划规划问题,无法直接利用Matlab的函数,必须利用Matlab 编程实现分枝定界解法和割平面解法。但对于指派问题等特殊的0 1 整数规划问题或约束矩阵A 是幺模矩阵时
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 《2025智能设备采购委托项目管理合同》
- 2025合同范本食品供应合同
- 2025年委托借款合同模板
- 2025便利店店面转让合同范本
- 2025标准化的苗木购销合同
- 2025版商品房购买合同范本
- 2025年上海市农产品买卖合同示范文本
- 《年级魅力》课件
- 2025授权合同范本(标准)
- 《金融市场概述》课件
- 电动葫芦出厂检验报告
- 挖机大中斗油封资料,液压泵资料
- 技术开发部个人技能矩阵图
- Hillstone设备密码与配置恢复方法
- 二年级下册语文教案第六单元部编版
- 废气处理工程施工方案模板
- 境外所得个税新政解析PPT课件
- 组织环境、相关方分析及措施一览表
- 中考物理专题43 纯电阻电路与非纯电阻电路电热计算(解析版)
- 百家姓全文带拼音——完美打印版
- 《不定期船营运管理模拟系统》实验指导书
评论
0/150
提交评论