数学建模C题论文资料(工件加工排序)

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
gj_value=8,4,16,3,7,20,17,11,7,12,5,18;
enddata
end
模型结果:
导出列表:
工件顺序
车床加工时间
规定的完工时间
各工件价值
0
0
0
0
0
0
1
2.8
9
8
5
1.7
7
7
12
4.7
11
18
10
2.5
18
12
3
1.2
15
16
6
0.9
22
20
7
2.5
17
17
2
4
23
3
11
3.6
问题(一)题目要求:12种工件都要求在车床上加工,车床一次只能加工一种工件。设i工件车床加工时间为A ,规定完工时间为B ,工件价值为C
1)不考虑工件的完工时间和工件的价值,安排工件加工的次序,使得完成这批工件加工任务所需的总时间最省。
分析:引入0/1变量,利用目标函数最优化工件排序。
设 为i工件实际完工时间,所以完成这批工件的总时间为T= ,而 =A +A =A +A +A =A +A +………+ =
@for(shunxu(I):
@sum(gongjian(J): note(I,J))=1;
);
!每个工件只能排在一个顺序位上;
@for(gongjian(J):
@sum(shunxu(I): note(I,J))=1;
);
!定义0/1变量;
@for(links:@bin(note));
data:
!输出数据到Excel文档;
有一个工厂现在有12种工件(编号为工件1,工件2,…,工件12)需要在车床,钻床,铣床几种不同的设备上加工。考虑下面的工件加工的排序问题:
(一)这12种工件都要求在车床上加工,车床一次只能加工一种工件,这12种工件加工所需时间,每个工件的完工时间和每个工件的价值如表(1)所示:
工件
加工时间(h)
完工时间(h)
.
.
.
x +x +…….+x =1
x +x +x +……+x +x =1
x +x +x +……+x +x =1
.
.
.
x +x +x +……+x +x =1
Lingo程序:(附wenti(1).lg4文件)
model:
!不考虑完工时间和工件价值的排序问题;
sets:
gongjian/g1..g12/:shijian;!属性为原始排序下各个工件的机床加工时间;
25
5
8
3.3
33
11
总价值:117
表1-2
由上表可知,最优方案是选择工件1-5-12-10-3-6-7-2-11-8,并按此顺序进行加工。从而获得最大的工件总价值为117.
关于问题(二),(三),(四)
分析:问题(二)要求:如果这12种工件都要求先在车床上加工,然后再在钻床上加工(即工件在钻床加工之前必须先在车床上加工过),每种机器一次只能加工一种工件,求工件加工的最优排序,使得完成这批工件加工任务所需的总时间最省。根据总时间的定义,某工件从任务开始时刻起到完成钻床工序止所需要的总时间包括该工件完成车工序的时间,等待上一个工件加工完的时间(即从该工件在车床加工完毕时刻起到其上一个工件在钻床上加工完毕这一段时间),该工件在钻床上加工的时间。我们假设 工件在车床 加工所需时间为 ,在钻床上 加工所需时间为 ; 工件完成在车床 加工的总时间为 ;( )工件完成在钻床 加工的总时间为 ,( )。这里要分两种情况进行分析:
引入0-1变量,若选择i工件加工,则记Y =1.否则记Y =0;
工件的排序算法同问题1),但约束条件有所不同。在本题中,12种工件不一定都可以入选到最优加工序列中(即目标排序中可能出现工件空缺),所以 ( =1, 2, ….12),且 ( =1, 2, ….12), 为0-1变量。用Lingo进行编程,工件集加入原始排序下车床加工时间,完工时间和工件价值属性;顺序集加入重新排序后车床加工时间,完工时间和工件价值属性;因此该模型为:
2)由于工件必须在它们要求的时间内完工,按照表(1)的数据,为该工厂安排选择加工工件的种类及加工的次序,使得整个选择加工的工件价值最大。建立数学模型并给出相应的算法。
(二)如果这12种工件都要求先在车床上加工,然后再在钻床上加工(即工件在钻床加工之前必须先在车床上加工过),每种机器一次只能加工一种工件,这12种工件加工所需时间如表(2)所示:
(三)如果这12种工件都要求先在车床上加工,然后再在钻床上加工,最后再在铣床上加工,每种机器一次只能加工一种工件,这12种工件加工所需时间如表(三)所示:
工件
车床加工时间(h)
钻床加工时间(h)
铣床加工时间(h)
1
2.8
4
3
2
3.2
1.3
1
3
1.2
1.8
2.5
4
4
2.2
1.3
5
2.7
3
1.8
6
0.9
data:
!原始排序下各个工件的机床加工时间;
shijian= 2.8,3.2,1.2,4,2.7,0.9,2.5,3.3,1.7,2.5,3.6,4.7;
!原始排序下各个工件的完工时间;
endtime=9,7.5,15,23,10,22,17,33,7,18,25,11;
!原始排序下各个工件的工件价值;
解题正文:
C题:工件加工排序
(建模小组成员:AP0308306陈运标AP0308307邓风仪AP0206311黄深泉)
摘要
本题根据已知数据,结合问题中的具体要求,我们引入0/1变量建立工件排序的数学规划模型。借助Lingo软件进行求解运算,得出其中的最优排序方案。使得完成这批工件加工任务所需要的总时间最省。在这里,我们通过对各个工件(排序后)完成某项特定工序所需总时间进行求和得到整个加工任务所需要的总时间。而各工件的总时间包括其机床加工时间和加工其他零件时的等待时间。
4.5
2
7
2.5
1.7
3.6
8
3.3
2.5
0.8
9
1.7
4.5
1
10
2.5
2.5
1.1
11
3.6
0.9
1.3
12
4.7
1.9
0.7
表(3)
为该工厂安排工件加工的次序,使得完成这批工件加工任务所需的总时间最省。建立数学模型并给出相应的算法。
(四)对于上述问题你做出的数学模型和相应的算法给出评价。并将模型推广到n个工件在m台机器上加工的一般的工件排序问题,给出你的想法和解决问题的思路。
shunxu/s1..s12/:time,overtime,fin_value;!属性为重新排序后各个工件的机床加工时间,完工时间,工件价值;
links(shunxu,gongjian): note;
endsets
!目标函数;
max=@sum(shunxu(I):fin_value(I));
!从新排序后各工件的机床加工时间(可能为零,即表示未选中工件);
因此:建立问题(1)的目标函数即数学模型为Min=
定义x ,x ……x 为0/1变量, , ,… 为原始工件序列下i工件的车床加工时间;所以
A =x a +x a +……..+x a
A =x a +x a +……..+x a
.
.
A =x a +x a +……..+x a
x +x +…….+x =1
x +x +…….+x =1
工件价值
1
2.8
9
8
2
3.2
7.5
4
3
1.2
15
16
4
4
23
3
5
2.7
10
7
6
0.9
22
20
7
2.5
17
17
8
3.3
33
11
9
1.7
7
7
10
2.5
18
12
11
3.6
25
5
12
4.7
11
18
表(1)
1)不考虑工件的完工时间和工件的价值,为该工厂安排工件加工的次序,使得完成这批工件加工任务所需的总时间最省。建立数学模型并给出相应的算法。
工件
车床加工时间(h)
钻床加工时间(h)
1
2.8
4
2
3.2
1.3
3
1.2
1.8
4
4
2.2
5
2.7
3
6
0.9
4.5
7
2.5
1.7
8
3.3
2.5
9
1.7
4.5
10
2.5
2.5
11
3.6
3.8
12
4.7
1.9
表(2)
为该工厂安排工件加工的次序,使得完成这批工件加工任务所需的总时间最省。建立数学模型并给出相应的算法。
目标函数: Max= (在排序算法及程序中已隐含有 )
工件选择: ( =1, 2, ….12), ( =1, 2, ….12)
完工时间约束: ( =1, 2, ….12)
Lingo程序:(wenti(2).lg4文件)
model:
!考虑完工时间和工件价值的排序问题;
sets:
gongjian/g1..g12/:shijian,endtime,gj_value;!属性为原始排序下各个工件的机床加工时间,完工时间,工件价值;
1).当 时,即 工件完成车工序的总时间大于或等于( )工件完成钻工序的总时间,此时 工件不需要等待( )工件而立即就进入钻工序,因此 工件完成钻床工序的总时间表达式为 + ;
@OLE('D:\liebiao.XLS')=time,fin_time;
!原始排序下各个工件的机床加工时间;
shijian= 2.8,3.2,1.2,4,2.7,0.9,2.5,3.3,1.7,2.5,3.6,4.7;
enddata
end
结果数据:
工件
加工时间
完成时间T
6
0.9
0.9
3
1.2
2.1
9
1.7
3.8
10
2.5
6.3
7
2.5
8.8
5
2.7
11.5
1
2.8
14.3
2
3.2
17.5
8
3.3
20.8
11
3.6
24.4
4
4
28.4
12
4.7
33.1
总计:171.9
表1-1
所以最优排序是6-3-9-10-7-5-1-2-8-11-4-12
完成这批工件加工任务所需的最省总时间为171.9
2)分析:由于工件必须在它们要求的时间内完工,即某工件在任务开始起到该工件加工完毕之间所用的总时间应少于该工件的规定完工时间。所以要使整个加工任务的工件总价值最大,必须合理选择加工工件的种类及其加工的次序。
命题人:邹祥福审批人:试卷分类(A卷或B卷)A
数学建模竞赛试题:
C题:工件加工排序
计划排序问题中的车间作业问题,研究n个工件在m台机器上有序的加工问题,每个工件都有完工的日期(DD,Due date),加工的时间(PT,Processing time)和工件的价值(VAL,Value if job is selected).现研究一个工厂生产工序的计划和安排,需要计划与合理安排各个工件在这些机器上加工的先后次序,即拟订加工工序,通过各个工件在各种机器上加工次序的合理安排,使得完成这批工件加工任务所需的总时间最省(注:总时间即为各个零件的加工时间和加工其他零件时它们等待时间之和)或要求整个选择加工的工件价值最大。
模型的假设:在后面的模型中,我们都假定了忽略工件在转换工序时的运输时间。即将整个工件加工过程简化为一个连续的过程,只考虑机床在加工工件时其他工件的等待时间。
模型的建立:我们的思路是引入0/1变量对工件进行动态排序,根据问题要求得出排序后的目标函数(即数学模型)。根据题目的约束条件,利用Lingo软件算出模型的最优解,从而获得工件的最优排序。
shunxu/s1..s12/:time,fin_time;!属性为重新排序后各工件的机床加工时间和完成车工序的时间;
links(shunxu,gongjian): note;
endsets
!目标函数:求各个工件的加工总时间和最小;
min=@sum(shunxu(I):fin_time(I));
!重新排序后各工件的机床加工时间;
!每个工件只能排在一个顺序位上;
@for(gongjian(J):
@sum(shunxu(I): note(I,J))<=1);
!各工件的完工时间约束;
@for(shunxu(I):
@sum(shunxu(J)|J#le#I:time(J))<=overtime(I);
);
!定义0/1变量;
@for(links:@bin(note));
);
!从新排序后各工件的工件价值(可能为零,即表示未选中工件);
@for(shunxu(I):
fin_value(I)=@sum(gongjian(J):gj_value(J)*note(I,J));
);
!每个顺序位只能有一个工件或者没有工件;
@for(shunxu(I):
@sum(gongjian(J): note(I,J))<=1);
@for(shunxu(J):
time(J)=@sum(gongjian(I):shijian(I)*note(I,J));
);
!排序后各个工件的加工总时间;
@for(shunxu(I):
fin_time(I)=@sum(shunxu(J)|J#le#I:time(J));
);
!每个顺序位只能有一个工件;
@for(shunxu(I):
time(I)=@sum(gongjian(J):shijian(J)*note(I,J)));
!从新排序后各工件的完工时间(可能为零,即表示未选中工件);
@for(shunxu(I):
overtime(I)=@sum(gongjian(J):endtime(J)*note(I,J));
相关文档
最新文档