层次分析,已知某工厂要生产7种产品,以I,II,III,IV,V,VI.doc
第一部分 问题重述与分析1.1 问题重述已知某工厂要生产7种产品,以I,II,III,IV,V,VI,VII来表示,但每种产品的单件利润随市场信息有明显波动,现只能给出大约利润,依次为:100,60,80,40,110,90,30,同时该厂有4台磨床、2台立钻、3台水平钻、1台镗床和1台刨床可以用来生产上述产品。已知生产单位各种产品所需的有关设备台时如表1。产品单位所需台时设备IIIIIIIVVVIVII磨床立钻0.3水平钻镗床刨床从1月到6月,维修计划如下:1月1台磨床,2月2台水平钻,3月1台镗床,4月1台立钻,5月1台磨床和1台立钻,6月1台刨床和1台水平钻,被维修的设备当月不能安排生产。又知从16月市场对上述7中产品最大需求量如表2所示。IIIIIIIVVVIVII1月50010003003008002001002月60050020004003001503月300600005004001004月20030040050020001005月0100500100100030006月500500100300110050060每种产品当月销售不了的每件每月存储费为5元,但规定任何时候每种产品的存储量均不能超过100件。1月初无库存,要求6月末各种产品各储存50件。若该工厂每月工作24天,每天两班,每班8小时,要求(1) 该厂如何安排生产,使总利润最大;(2) 若对设备维修只规定每台设备在16月份内均需安排1个月用于维修(其中4台磨床只需安排2台在上半年维修),时间可灵活安排。重新为该厂确定一个最优的设备维修计划。1.2 问题分析A. 对于问题(1),我们所要解决的是在生产设备有限并得知产品最大需求量的情况下,牟求最大的利润。通过分析问题(1),我们从以下两条思路着手,即每件产品需多少台不同设备台时,然后建立线性规划模型,其目标函数是根据总利润=各产品的销售数量×各产品的单件利润库存费用,最后,通过仔细分析题中所含条件,再一一列举出约束条件,据此我们制定出了最优生产方案。此问题得到解决的关键如下:1.目标函数的确立:由总利润=各产品的销售数量×各产品的单件利润库存费用,得到目标函数;2.找出约束条件:此线性规划模型,是在考虑到每种产品都需要多种设备加工的基础上,另外由于生产设备有限,所以各生产产品的生产量受设备的可用台时的限制,同时还已知了各产品的最大需求量,据此可得出台时约束方程与需求约束方程;另外,题中还规定了任何时候每种产品的存储量不超过100件,一月初无库存,6月末各产品各存储50件,由此可得出3个约束方程;最后,根据各月各产品生产数量各月各产品库存量=各月各产品最大需求量,可得另一约束方程;在模型(2)中,是在考虑每种产品都需要各种设备加工的基础上建立起来的,约束条件为库存量的限制,生产量、销售量及库存量之间的关系,工作时间的限制,同样也是线性规划模型。3.模型求解:编写程序,尽量简洁有效,用Lingo软件进行求解;4.结果分析:讨论分析模型的优缺点,找出模型可改进的方向。B. 对于问题(2),要求重新为该厂确定一个最优的设备维修计划,规定每台设备在16月份内均需安排1个月用于维修(其中4台磨床只需安排2台在上半年维修),这是一个最优排序问题,现在我们考虑的问题化为如何维修9台设备,确定出最优维修次序,使得在六个月里得到的总利润最大,这一问题的解决只需在问题(1)的解决方案上稍加分析,创新,便可得到。第二部分 模型假设及符号说明2.1 模型假设1.假设题目所给的数据真实可靠; 2.为了研究方便,忽略设备维修成本所造成的损失; 3假设当月运行的设备不发生故障,不存在人为破坏因素使之不能正常运行;4.假设每台设备维修的时间不超过一个月,一个月之后,立即投入生产运行; 2.2 定义与符号说明题中给出的五种设备,分别为磨床、立钻、水平钻、镗床和刨床,对应符号为i,根据排列顺序,分别取i=1,2,3,4,5;月份对应符号为t,分别取t=1,2,3,4,5,6;同时,该工厂生产的产品种类符号为j,依次取j=1,2,3,4,5,6,7。具体符号定义如下: : 总利润 :第t个月对第j种产品的最大需求量; :第j种产品的单件利润; :第i种设备生产单件第j种产品消耗的时间; :第t月份第i种工作设备台数(下文中称为工作矩阵); :第t个月生产第j种产品的数量; :第t个月第j种产品的库存量; :第t个月售出第j种产品的数量; :第j种产品的单件库存费用; :第t个月机器的维修;第三部分 模型的建立与求解3.1 针对问题(1):3.1.1 模型的建立1) 目标函数此目标函数的确立采用了先确定影响变量,再确定影响变量和总利润之间的关系的思路,让问题的模型具有条理性和简洁性。根据总利润=生产各产品的数量×各产品的单件利润库存费用就可写出该函数方程。2) 约束条件i. 由于该工厂每月只工作24天,每天两班,每班8小时,同时,每月工作设备工作的台时不同,则该工厂第t个月第i种设备生产各产品所需时间等于小时 ,约束条件如下:(1)ii. 由于已知该工厂生产的各种产品的最大需求量,因此,各产品的销售量需不超过各产品的最大需求量:(2)iii. 由于题中规定,任何时候每种产品的存储量均不能超过100件,1月无库存,6月末各种产品各存储50件,所得公式如下:(j=1,2,3,4,5)(3)(4)iv. 另外,根据生产量,销售量及货存量之间的关系,可得数学表达式如下:当t=1时(j=1,2,3,7)(5)当时(6)3.1.2 模型的求解由题中从1月到6月的维修计划可知工作矩阵:,由表一数据可知第i种设备生产单件第j种产品消耗的台时矩阵:,由表二可知,第t个月对第j种产品的最大需求量矩阵由七种产品的单件利润可得到: ,根据已得出的目标函数,以及各约束条件,用lingo软件求解该线性规划模型,具体公式如下:用lingo软件编程,程序见附表一,求得最大利润为937115元,其各产品的生产计划表,库存量表,销售量表如下:表3:六个月的各产品生产计划产品月份15008883833008002000270060011705003002503000004000420030040050020001005010060010011003001006550550035005500(例如表中第一个数500表示:安排第一个月生产第一种产品500件)表4:六个月的各产品库存量产品月份 1 0 0 83 0 0 0 0 2 100 100 0 0 100 0 100 3 0 0 0 0 0 0 0 4 0 0 0 0 0 0 0 5 0 0 100 0 100 0 100 6 50 50 50 50 50 50 50表5:六个月的各产品销售量产品月份150010003003008002001002600500200040030015031001000010040010042003004005002000100501005001001000300065005005030050500503.2 针对问题(2):1)方法一:由分析可知,问题(2)只是将问题(1)中的维修矩阵由已知变成未知,不过有一点没变的是维修台数不变,要求我们安排最优的维修计划,这里我们先不考虑维修,将设备看成都能在每个月进行生产,得到未维修矩阵记作,则=,由于维修各种设备的台数不变,我们不妨将问题(1)中的维修矩阵拿下来进行比较观察,我们不难发现维修矩阵的每一列之和等于未维修矩阵每一列之和减去此列所代表的设备需要维修的设备台数。下面根据这个条件对在问题(1)中建立的模型进行适当的改进即可得到最优维修矩阵。目标函数不变:;利用lingo编程,程序在附表二,由运行结果可得到最大利润为1088550元,得到的最优维修矩阵每个月每种产品在最优维修矩阵下的生产量1月2月3月4月5月6月5006004000055010005007000100550300200100050015030001000100350800400600010001150200300400030055010015020000110这种解法虽然没有确定要维修两台的设备两次维修的是不是同一台,但是我们可以从最优维修矩阵中得出要维修的设备在哪个月维修,在实际中注意便可避免维修同一台,所以这种解法可行。2)方法二:题目分析f(i)表示不同机器,y(tm)表示表示在t月份要修理的机器ni=(1,2,3,4,5) t=(1,2,3,4,5,6) n=(1,2,3,4,5,6,7,8,9)其中y机器来自f,其中f1有(y1、y2);f2有(y3、y4);f3有(y5、y6、y7);f4有y8;f5有y9;见下表磨床立钻水平钻镗床刨床 ft1 ft2ft3ft4ft5M123456789一月y11y12y13y14y15y16y17y18y19二月y21y22y23y24y25y26y27y28y29三月y31y32y33y34y35y36y37y38y39四月y41y42y43y44y45y46y47y48y49五月y51y52y53y54y55y56y57y58y59六月y61y62y63y64y65y66y67y68y69设y(tm)是0、1变量0表示不要修理,1表示需要修理.因为每台设配在16月份均需安排一个月维修所以;y(tn)f(t1)=y(t1)+y(t2);f(t2)=y(t3)+y(t4);f(t3)=y(t5)+y(t6)+y(t7);f(t4)=y(t8);f(t5)=y(t9);设一个矩阵;=,所以d(ti)= d全-f(ti)目标函数不变:由lingo编程,得出最大利润仍为1088550元,得出每月安排生产各种产品的数量如下表:1月2月3月4月5月6月5006004000055010005007000100550300200100050015030001000100350800400600010001150200300400030055010015020000110得出最优维修矩阵为:比较方法一和方法二,由两种方法的求得的每月生产某种产品的数量并没有变,不过最优维修矩阵改变了,而且总利润不变,说明最优维修矩阵不唯一,观察到上述两种维修安排,在某些月份并没有设备维修,若是要求使每月都有设备维修,进行模型扩展。3)模型扩展1,只需对方法二加一个约束令表示能够保证每个月都至少有一台需修理在附表三编程基础上增加语句如下:for(month(t):sum(xiuji(n):y(n,t)>=1);由lingo编程,得出最大利润仍为1088550元,,每月安排生产某种产品的数量不变,得到最优维修矩阵: 第四部分 模型的误差分析文中基本假设合理,所建模型数学推导严谨,理论可靠,逻辑严密,而且易于理解,但由于市场的不稳定性,产品的利润及需求量存在着不确定性,故可能产生一些误差,误差大小与市场经济的稳定性有关,另外,软件和计算机的精度也会导致产生误差。第五部分 模型的评价及改进方向5.1 模型的优点我们的模型有以下优点:1. 易于推广。当今社会的各个领域,都存在着不同类型的优化问题,而在企业生产中,在一定条件下,最大利润生产方案和最优设备维修方案显得尤为重要,根据现实条件调整该模型对企业生产、设备维修将有很大的帮助;2. 基本模型对问题的描述精确,合理,推导严谨,理论性强;3. 通过合理的数据处理,将题中表格的数据及所需数据转换为矩阵形式,便于理解、分析和求解。4. 解决问题(2)的方法一简洁,通过认真观察未维修矩阵与维修矩阵之间的联系,颇具匠心,方法二从常规出发引入0-1变量。5. 适当在原有模型基础进行扩展,使工厂安排更加合理。5.2 模型的缺点及改进方向当然,模型也存在着一些缺点:主要是没有很好地联系经济来讨论,模型中涉及的单件产品利润只是个大概,存在着一定的误差,另外,本题没有考虑维修各台设备的成本,及设备是否在规定的时间里能完全修好等等。要建立较好的能适应于社会生产和设备维修的模型,应考虑诸多因素,以及一些其它的细节,能做到这些,所建立的模型将更适应现实社会。第六部分 附录u 附表一:model:sets:product/1.7/:b,m;month/1.6/;machine/1.5/;link1(product,month):a,h,x,s;link2(machine,month):d;link3(product,machine):c;endsetsdata:b=100 60 80 40 110 90 30;m=5;a=500 600 300 200 0 500 1000 500 600 300 100 500 300 200 0 400 500 100 300 0 0 500 100 300 800 400 500 200 1000 1100 200 300 400 0 300 500 100 150 100 100 0 60;d=1152 1536 1536 1536 1152 1536 768 768 768 384 384 768 1152 384 1152 1152 1152 768 384 384 0 384 384 384 384 384 384 384 384 0;c=0.5 0.1 0.2 0.05 0 0.7 0.2 0 0.03 0 0 0 0.8 0 0.01 0 0.3 0 0.07 0 0.3 0 0 0.1 0.05 0.2 0.6 0 0 0 0.5 0 0.6 0.08 0.05; enddatamax=sum(product(j):b(j)*sum(month(t):s(j,t)-sum(link1(j,t):h(j,t)*m(j);for(product(j):h(j,1)=x(j,1)-s(j,1);for(link1(j,t)|t#gt#1:h(j,t)=h(j,t-1)+x(j,t)-s(j,t);for(link1(j,t):h(j,t)<=100);for(link1(j,t)|t #eq# 6:h(j,t)=50);for(link2(i,t):sum(product(j):x(j,t)*c(j,i)<=d);for(link1(j,t):s(j,t)<=a(j,t);for(link1:gin(x);endu 附表二:model:sets:product/1.7/:b,m;month/1.6/;machine/1.5/;link1(product,month):a,h,x,s;link2(machine,month):d;link3(product,machine):c;endsetsdata:b=100 60 80 40 110 90 30;m=5;a=500 600 300 200 0 500 1000 500 600 300 100 500 300 200 0 400 500 100 300 0 0 500 100 300 800 400 500 200 1000 1100 200 300 400 0 300 500 100 150 100 100 0 60;c=0.5 0.1 0.2 0.05 0 0.7 0.2 0 0.03 0 0 0 0.8 0 0.01 0 0.3 0 0.07 0 0.3 0 0 0.1 0.05 0.2 0.6 0 0 0 0.5 0 0.6 0.08 0.05; enddatamax=sum(product(j):b(j)*sum(month(t):s(j,t)-sum(link1(j,t):h(j,t)*m(j);for(product(j):h(j,1)=x(j,1)-s(j,1);for(link1(j,t)|t#gt#1:h(j,t)=h(j,t-1)+x(j,t)-s(j,t);for(link1(j,t):h(j,t)<=100);for(link1(j,t)|t #eq# 6:h(j,t)=50);for(link2(i,t):sum(product(j):x(j,t)*c(j,i)<=384*d(i,t);sum(month(t):d(1,t)=22;sum(month(t):d(2,t)=10;sum(month(t):d(3,t)=15;sum(month(t):d(4,t)=5;sum(month(t):d(5,t)=5;for(link1(j,t):s(j,t)<=a(j,t);for(month(t):bnd(2,d(1,t),4);for(month(t):bnd(0,d(2,t),2);for(month(t):bnd(0,d(3,t),3);for(month(t):bnd(0,d(4,t),1);for(month(t):bnd(0,d(5,t),1);for(link2:gin(d);endu 附表三model:sets:xiuji/1.9/:;product/1.7/:b,m;month/1.6/;machine/1.5/;link1(product,month):a,h,x,s;link2(machine,month):e,d,f;link3(product,machine):c;link4(xiuji,month):y;endsetsdata:e=4 4 4 4 4 4 2 2 2 2 2 2 3 3 3 3 3 3 1 1 1 1 1 1 1 1 1 1 1 1;b=100 60 80 40 110 90 30;m=5 5 5 5 5 5 5;a=500 600 300 200 0 500 1000 500 600 300 100 500 300 200 0 400 500 100 300 0 0 500 100 300 800 400 500 200 1000 1100 200 300 400 0 300 500 100 150 100 100 0 60;c=0.5 0.1 0.2 0.05 0 0.7 0.2 0 0.03 0 0 0 0.8 0 0.01 0 0.3 0 0.07 0 0.2 0.6 0 0 0 0.5 0 0.6 0.08 0.05; enddatafor(link4(n,t):y(n,t)<=1);for(month(t):f(1,t)=y(1,t)+y(2,t);for(month(t):f(2,t)=y(3,t)+y(4,t);for(month(t):f(3,t)=y(5,t)+y(6,t)+y(7,t);for(month(t):f(4,t)=y(8,t);for(month(t):f(5,t)=y(9,t);for(link2(i,t):e(i,t)=d(i,t)+f(i,t);for(xiuji(n):sum(month(t):y(n,t)=1);!for(month(t):sum(xiuji(n):y(n,t)>=1);(扩展增加语句)max=sum(product(j):b(j)*sum(month(t):s(j,t)-sum(link1(j,t):h(j,t)*m(j);for(product(j):h(j,1)=x(j,1)-s(j,1);for(link1(j,t)|t#gt#1:h(j,t)=h(j,t-1)+x(j,t)-s(j,t);for(link1(j,t):h(j,t)<=100);for(link1(j,t)|t #eq# 6:h(j,t)=50);for(link2(i,t):sum(product(j):x(j,t)*c(j,i)<=384*d(i,t);for(link1(j,t):s(j,t)<=a(j,t);for(link1:gin(x);for(link2:gin(d);for(link4:gin(y);end15