第三章线性规划问题的计算机求解如何求解?“管理运筹学”的软件包本章将介绍如何使用计算机软件包求解线性规划问题。解决线性规划问题的软件包分两种,一种是大规模的软件包,它可以用来解决复杂的包含数千个决策变量和数千个约束条件的大型的线性规划的问题,重点掌握国内外常用软件:由芝加哥大学LinusE.Schrage开发的lindo6.1软件,此软件包可解决32000个变量(3200整型变量)16000个约束方程的运筹学问题。另一种是用于微机的软件包,它们有很好的界面,使用方便,由科研机构和小软件公司为解决包含数百个决策变量的线性规划问题而开发的。本章介绍的是与本书配套的名为“管理运筹学”2.0软件包就是属于这种软件,此软件包可解决100个变量50个约束方程的管理运筹学问题。本章的重点放在如何读懂“管理运筹学”软件包的计算机输出结果——关于线性规划问题的求解和灵敏度分析的信息,解决工商管理中的实际问题。§3.1“管理运筹学”软件的操作方法下面用运筹学软件2.0来解决例1的线性规划问题。从开始→程序→管理运筹学2.0,这样就打开此软件,如下图:然后就根据需要选择运筹学的各个分枝1.输入的系数可以是整数、小数,但不能是分数,要把分数先化为小数再输入。2.输入前先要合并同类项。3、此软件的一个最大缺点是变量只有一组X,不能有Y和Z等,而且下标不能是二维下标如:X12是错的(看作是一维)。还有X1A等也是错误的,其次模型的修改比较麻烦。下面以第二章的例1为例说明此软件的用法maxZ=50x1+100x2,约束条件:x1+x2≤300,2x1+x2≤400,x2≤250,x1≥0,x2≥0.选择了线性规划后,就出现的界面,然后点新建。得到如下对话框:然后新建清零,下面就可以输入模型了。先输入变量个数、约束个数和MAX或Min,然后点确定后,才能输入模型。输入目标函数系数一般地变量的非负性不必修改。在这输入约束条件,在输入约束条件时注意清0,还要注意不等号的方向。输完模型后就可以选择要进行的操作,如:保存、解决(求解)等。下面是例1的输入结果。输完模型后,苦要修改模型点这里解决后得到如下结果。如果选择保存,就弹出保存路径的对话框。输入文件名,然后点保存即可,以后可以点打开调出模型。从上面变量、最优解、相差值一栏中,知道例1的最优解为生产Ⅰ产品50单位;生产Ⅱ产品250单位。相差值的数值表示相应的决策变量的目标系数需要改进的数量,使得该决策变量有可能取正数值,一般地,当决策变量已取正数值时则相差值为零。如果决策变量取0值,则相差值可能不为0。对例1来说由于x1=50,x2=250,都是正值,所以它们的相差值都为零。如果x1的值为0;x1的相差值为20;则就知道,只有当产品I的利润再提高20元,即达到50+20=70元时(这里的50是表示X1的利润,不是X1的最优解),产品I才可能生产,即x1才可能大于零。对于目标函数求最小值的线性规划问题,那么所谓的改进就应该使其对应的决策变量的系数减少其相差值。这在以后还要说明。如何读懂输出结果?§3.2软件输出信息分析喂!相差值是什么意思?我知道:如果决策变量取正数值,则相差值一般为零。则此时目标函数的系数无法再改变使目标函数值变得更好。如果决策变量取0值,则相差值可能不为0(比如说相差值为正a,也有可能为0)。则此时目标函数的系数可以在原来基础上增加a(而当目标函数是求最小值时,减少a),则可能才能使此决策变量变为非零(即生产该种产品),才有可能使目标函数值变得更好。也可以这样理解:在相差值内,价值系数增加就不会影响原来的最优基,但当价值系数增加大于等于相差值时,最优基就会发生变化。满足约束条件:x1+x2≤300,(台时数)2x1+x2≤400,(原料A)x2≤250,(原料B)在约束条件、松弛/剩余变量、对偶价格这栏中,可知设备的台时数全部使用完,每个设备台时的对偶价格为50元,即增加了一个台时数就可使总利润增加50元;原料A还有50千克没有使用,原料A的对偶价格当然为零,即增加1千克A原料不会使总利润有所增加;原料B全部使用完,原料B的对偶价格为50元,即增加一千克原料B就可使总利润增加50元。设备原料A原料B在目标函数系数范围一栏中,所谓的当前值是指在目标函数中决策变量的当前系数值。如x1的系数值为50,x2的系数值为100。所谓的上限与下限值是指目标函数的决策变量的系数(其它决策变量的系数固定在当前值)在此范围内变化时,其线性规划的最优解不变。例如当c1=80时,因为0≤80≤100,在x1的系数变化范围内,所以其最优解不变(此时要固定c2=100),也即当x1=50,x2=250时,有最大利润。当然由于产品Ⅰ的单位利润由50变为80了,其最大利润也增加了(最优值变了),变为80×50+100×250=29000(元)。但是如果c1=110元时,由于110100,所以原来的最优解就可能不再是最优解了。同样从上图可知,当c2在50与+∞之间变化时(此时要固定c1=50),原来的最优解依然是其最优解。所谓当前值是指约束条件右边值的现在值,可知b1=300;b2=400,b3=250。所谓上限值与下限值是指当约束条件的右边值在此范围内变化时,则与其对应的约束条件的对偶价格不变,不能保证最优解不变。从可由对偶价格判断增加某约束条件的常数项值是否能使目标函数值变得更好(前提条件是其它常数项保持不变)。当设备台时数在250→325的范围内,其对偶价格都为50元,说明增加设备台时数可使目标函数值变大,每增加1个台时数可增加利润50元。当原料A的公斤数在350到+∞范围内,其对偶价格都为零;增加原料A对目标函数值无影响。当原料B的千克数在200到300的范围内,其对偶价格都为50元。例如设备台时数和原料A的数量不变,即b1=300;b2=400,原料B变为280千克,由于200≤280≤300,原料B的对偶价格仍为50元,故新的最大利润值应为:27500+(280-250)×50=29000元。这里50是对偶价格。设备原料A原料B如果所有的右端常数项同时在变,对偶价格是否变啊?以上关于目标函数系数及约束条件右边值的灵敏度分析都是基于这样一个重要假设:只有一个系数在变化,而其他的系数值保持不变。所有以上的目标函数系数及约束条件右边值的变化范围只适合于单个系数变化的情况。如果两个或更多或者说所有约束条件右边常数项同时变动,就不能用上面方法来判断对偶价格是否变了。要用下面方法来判断。百分之一百法则:先以例1为例看一看如何用百分之一百法则对两个目标函数系数同时变化进行灵敏度分析。例1中原来每件Ⅰ产品和Ⅱ产品的利润分别为50元和100元,现在由于市场情况的变化每件Ⅰ产品和Ⅱ产品的利润分别变为74元和78元,最优解发生变化吗?为了解决这个问题我们首先来定义“允许增加值”和“允许减少值”这两个术语,对一个目标函数的决策变量系数,所谓允许增加值是该系数在上限范围内的最大增加量,所谓的允许减少量是该系数在下限范围内的最大的减少量。这样可以计算出C1的允许增加量百分比为:(74-50)/50=48%;C2的允许减少百分比为(100-78)/50=44%,C1允许增加百分比与C2的允许减少百分比之和为:48%+44%=92%。变量下限当前值上限x1050100x250100无上限从上面可知目标函数中X1的系数的上限为100,故C1允许增加量为:上限-现在值=100-50=50;而X2的下限为50,故C2的允许减少量为:现在值-下限=100-50=50。定义Ci的允许增加(减少)百分比为:Ci的增加量(减少量)除以Ci的允许增加量(允许减少量)的值。目标函数决策变量系数的百分之一百法则:对于所有变化的目标函数决策变量系数,当其所有允许增加百分比和允许减少百分比之和不超过百分之一百时(含百分百),最优解不变。在上题中C1的允许增加百分比与C2的允许减少百分比之和为92%不超过100%,所以当每件产品Ⅰ利润从50元增加到74元,每件产品Ⅱ利润从100元减少到78元时,此线性规划最优解仍然为Ⅰ产品生产50件,Ⅱ产品生产250件(即x1=50,x2=250),此时有最大利润为:74×50+78×250=3700+19500=23200(元)。注意最大利润已变。同样有约束条件右边常数值的百分之一百法则:对于所有变化的约束条件右边常数值,当其所有允许增加百分比和允许减少百分比之和不超过百分之一百时,则其对偶价格不变。其中bj的允许增加(减少)百分比的定义同Ci的允许增加(减少)百分比一样:为bj的增加量(减少量)除以bj的允许增加量(减少量)的值。并不难仍以例1为例来说明如何用约束条件右边常数值的百分之一百法则进行灵敏度分析。不妨设设备台时数从300台时增加为315台时,而原料A从400千克减少到390千克,原料B从250千克减少到240千克,这样可以得到它们的允许增加(减少)百分比。因为:约束下限当前值上限12503003252350400无上限3200250300设备台时数:(315-300)/(325-300)=15/25=60%,原料A:(400-390)/(400-350)=10/50=20%,原料B:(250-240)/(250-200)=10/50=20%。所以它们的允许增加百分比与允许减少百分比之和为60%+20%+20%=100%,从以上约束条件右边常数值的百分之一百法则可知此线性规划的对偶价格不变。因为设备台时数从300台时增加为315台时,而原料A从400千克减少到390千克,原料B从250千克减少到240千克,所以从对偶价格可知50×15+0×(-10)+50×(-10)=250(元),则最大利润增加了250元,为27750元。在使用百分之一百的法则进行灵敏度分析时,要注意以下四点:1)、当允许增加量(减少量)为无穷大时,则对于任一个增加量(减少量),其允许增加(减少)百分比都看成零。例如,在表3-4中,约束条件2的常数项变动范围为350至+∞,如果原料A从400增加到410,则相当于(410-400)/(无穷大-400)=0.2)、当允许增加量(减少量)为0时,则对于任一个增加量(减少量),其允许增加(减少)百分比都看成无穷大(相当于该变量不能增加或减少)。要打开思路!3)、百分之一百法则是判断最优解或对偶价格变不变的充分条件,但不是必要条件,也就是说当其允许增加和减少百分比之和不超过100%时,其最优解或对偶价格不变,但是当其允许增加和减少百分比之和超过100%时,我们并不知道其最优解或对偶价格变还是不变。4)、百分之一百法则不能应用于目标函数决策变量系数和约束条件右边常数值同时变化的情况,在这种情况下,只有重新求解。下面把例2输入计算机来分析此线性规划的计算机输出,例2的数学模型如下:目标函数:min2x1+3x2约束条件:x1+x2≥350,①x1≥125,②2x1+x2≤600③x1≥0,x2≥0上机计算得到如下结果:从上面结果知道,当购进A原料250吨(X1=250),B原料100吨(X2=100)时,使得购进成本最低为800万元。在松弛/剩余栏中,约束条件②的值为125,约束条件②表示对原料A的最低需求,由于此约束为大于等于,这样可知原料A的剩余变量值为125(因为x1=250)。同样可知约束条件①(对所有原料的总需要量)的剩余变量值为零,约束条件③(加工时数的限制)的松弛变量值为零。约束松弛/剩余变量对偶价格10-421250301在对偶价格一栏中,可知约束条件①的对偶价格为-4万元,也就是说如果把购进原料A+原料B的下限从350吨增加到351吨,那么总成本将加大(因为对偶价格为负值),由800万元增加到800+4=804(万元)了。当然如果减少对原料A+原料B的下限,如把原料A+原料B的下限从350吨减少到349吨,那么总成本将得到改进,由800万元减少到800-4=796万元了。可知约束条件③(加工时数)的对偶价格为1万元,也就是说如果把加工时数从600小时增加到601小时,则总成本将得到改