2021年高教杯数学建模国赛C题的解题过程附全部代码以及参赛论文(百度网盘)* ]: t( i* J7 q: z( R7 G8 g- u" [
% M8 D+ S* U- j- h2 R+ ~: ^
我们小组参加了2021年数学建模,本人负责代码方面,此文仅为自己的思考理解+代码分析+题目分析 5 A6 Z% Z* E9 E9 y) s, v题目:1 x# P6 d7 X m0 c( s- P* f
注:试题完整版和对应的附件在我另一篇文章里面 ' ?( e0 l6 Y0 H X0 V, E# G3 { ( F6 n9 A ?) W9 D* @! e; |! R某建筑和装饰板材的生产企业所用原材料主要是木质纤维和其他植物素纤维材料,总体可分为 A,B,C 三种类型。该企业每年按 48 周安排生产,需要提前制定 24 周的原材料订购和转运计划,即根据产能要求确定需要订购的原材料供应商(称为“供应商”)和相应每周的原材料订购数量(称为“订货量”),确定第三方物流公司(称为“转运商”)并委托其将供应商每周的原材料供货数量(称为“供货量”)转运到企业仓库。 6 ]* j$ i' a2 I7 ^, i8 c+ |该企业每周的产能为 2.82 万立方米,每立方米产品需消耗 A 类原材料0.6 立方米,或 B 类原材料 0.66 立方米,或 C 类原材料 0.72 立方米。由于原材料的特殊性,供应商不能保证严格按订货量供货,实际供货量可能多于或少于订货量。为了保证正常生产的需要,该企业要尽可能保持不少于满足两周生产需求的原材料库存量,为此该企业对供应商实际提供的原材料总是全部收购。在实际转运过程中,原材料会有一定的损耗(损耗量占供货量的百分比称为“损耗率”),转运商实际运送到企业仓库的原材料数量称为“接收量”。每家转运商的运输能力为 6000 立方米/周。通常情况下,一家供应商每周供应的原材料尽量由一家转运商6 H5 {4 S4 b" {5 L+ v
运输。原材料的采购成本直接影响到企业的生产效益,实际中 A 类和 B 类原材料的采购单价分别比 C 类原材料高 20%和 10%。三类原材料运输和储存的单位费用相同。附件 1 给出了该企业近 5 年 402 家原材料供应商的订货量和供货量数据。附件 2 给出了 8 家转运商的运输损耗率数据。请你们团队结合实际情况,对相关数据进行深入分析,研究下列问题: - y( V: l/ W$ ~. n3 w/ e7 w. Q1.根据附件 1,对 402 家供应商的供货特征进行量化分析,建立反映保障企业生产重要性的数学模型,在此基础上确定 50 家最重要的供应商,并在论文中列表给出结果。 ) S+ u6 R+ ]& n1 t( i2 w2.参考问题 1,该企业应至少选择多少家供应商供应原材料才可能满足生产的需求?针对这些供应商,为该企业制定未来 24 周每周最经济的原材料订购方案,并据此制定损耗最少的转运方案。试对订购方案和转运方案的实施效果进行分析。 ! b9 [5 G' A, G- u4 t1 z x3.该企业为了压缩生产成本,现计划尽量多地采购 A 类和尽量少地采购 C 类原材料,以减少转运及仓储的成本,同时希望转运商的转运损耗率尽量少。请制定新的订购方案及转运方案,并分析方案的实施效果。 " G; O: a- z( [: [. L9 m2 a& q4.该企业通过技术改造已具备了提高产能的潜力。根据现有原材料的供应商和转运商的实际情况,确定该企业每周的产能可以提高多少,并给出未来 24 周的订购和转运方案。; Q: Z2 o* L0 l5 e7 n
2 J' P2 x& B" e. _( r
第一问:( k5 x1 A! q( B+ |1 y
理论分析:' j% g. j# j! G j: n" P+ C
该企业每周的产能为 2.82 万立方米,按照每立方米产品需消耗 A 类原材料 0.6 立方米,或 B 类原材料 0.66 立方米,或 C 类原材料 0.72 立方米。按原材料的最小需求量算是2.82万✖0.6=16920,按原材料的最大需求量算是2.82万✖0.72=20304。而我们根据excel表格计算402家每周所有的供应量仅仅只有40+周是肯定能满足要求的(即是该周供应量超过20304),有50+周是不一定能满足的(即是该周供应量在16920到20304之间),还有140周是一定不能满足要求的,既然402家供应商全部供应量加起来都不一定能达到所需产能,那选择最重要的50家企业就需要以这个供应量为标准,然后我们又考虑到了有些供应商的数据非常奇怪(连续几周供应量非常低,然后突然供应量达到最大值),如图; K O* z6 G. `5 ?$ w0 i9 o8 ]
/ f/ T0 K0 |0 v7 B( w
像这种我们就需要考虑他的方差,我们需要把这两个因素考虑进去,从而在402家供应商里面挑选50家最重要供应商,我们把每周的供应量进行排序,给每一家供应商一个排名,如果遇到供应量相同的供应商,给一个相同的排名,某家企业240周每周的排名的平均值即是以权值相等去同时考虑供应量和方差。以这个平均值去排序得到前50家供应商就是我们需要的最重要50家供应商。 * w, L4 b D! _. q& O代码分析: ! Y% y4 `, L* V C3 Y D: b( A! J首先需要从excel表格中读取402家供应商的240周的数据, - |' y5 e3 M6 b' K" } `; c/ B0 W0 p. i+ Bimport xlrd 8 R3 O) T0 J) nfile_location = "C:/Users/95870/Desktop/数学建模代码/a.xlsx"#这个位置需要更改,否则不能运行 7 c7 V8 p$ O) A! M2 Ldata = xlrd.open_workbook(file_location)7 e: f% L* H* {9 A: h0 u
. _! W5 _/ E z4 Y' ~1 G
sheet = data.sheet_by_index(1) # 引用第二个表 4 D+ h1 M$ t8 vsheet2=data.sheet_by_index(0) # 引用第一个表 , M+ e# c, `- P# r2 C0 ?3 d' d2 a( \
v' l9 e; J% O4 e1 H) @8 o- ^ " o& g, _- X/ V7 B, ]data = [[sheet.cell_value(r,c) for c in range(sheet.ncols)] for r in range(sheet.nrows)] #读取该表1中所有的数据 9 h4 A }' a/ W% S! C% J: d5 \7 ~$ s7 W6 Zdata_d=[[sheet2.cell_value(r,c) for c in range(sheet2.ncols)] for r in range(sheet2.nrows)] #读取该表2中所有的数据1 C; H" h6 z, B" R1 P- W
1 $ b/ j9 n$ f; A& v7 b2 s& M# D% K2 ! l) i) f. a( i* u0 P9 C2 P3 5 f# K; [. j5 d5 ~' ]5 U8 g4 3 \& i, o! P$ c1 u; R% y5 ! x" G' L$ _8 C }6! Q6 E; r- h, H# k4 i
7 n2 F" ^1 t, g$ z0 G* f7 _1 l# o% F4 l87 U5 i' m2 N ?0 o* @7 d& k4 |
9 & `% {3 W! x% }5 e/ U" c) f10: C2 h$ ]5 D1 W+ x
114 X/ x; W' q8 t# n
定义了一个列表,num_list(402✖240),用以存放每家供应商每周的排名(这个排名是没有并序的,就是数据相同的按照供应商号码进行排序),然后用冒泡法把402家供应商240周的供应量进行排序,并根据供应商号有一个对应关系,然后将排名进行并行排序,然后算排名的平均值,根据平均值再进行排序,前50家就是我们需要的50家最重要供应商(结果如图)。 $ |. R$ c$ T8 j8 D2 p& w4 `( m6 {. Y- n* E* T/ |& x" e
代码如下: ; I* T% Z2 ^9 | 4 m$ X o" C5 w- B; ` f3 x, ] s! q# E# -*- coding: utf-8 -*- T" p7 c& z1 c8 V" j
import xlrd . Y4 B* |* \) a0 W$ ?, a. g
file_location = "C:/Users/95870/Desktop/数学建模代码/a.xlsx" 3 j/ q- y: G! z, |2 m3 F; R% ~) ~data = xlrd.open_workbook(file_location), F3 e* S9 K# R4 D0 z4 r
, k' O% G% I! a2 J7 \- |' ]
sheet = data.sheet_by_index(1), c$ y: |4 }- N8 O/ @/ h. o9 M
sheet2=data.sheet_by_index(0). ?) P! o, s. x' `& D/ R
: |; y7 `- b% r! b
5 Z7 k' i4 _2 G; S* a. @ R6 p- J
; W8 I* k# \+ }5 @% N7 d
data = [[sheet.cell_value(r,c) for c in range(sheet.ncols)] for r in range(sheet.nrows)]5 E2 p$ e4 e$ q( [/ ~
# N M; z w: W0 v#排名 ( o6 i* Y( o: Z- Aimport numpy' v7 M* B ?6 t$ m6 r S
num_list = numpy.zeros((402,240)); P k( i6 l' B5 o/ e6 a" v' g" g
for i in range(0,402):+ h7 F2 s: `. M2 G( U# ~4 l% i4 O
for j in range(0,240):6 d ~, C, I9 U2 v% U
num_list[i][j] = i+1* N7 s% y, i; m- \" t6 l0 ^
- I' q6 q g7 c; L3 i$ b% P# j8 t# [1 T: S7 m% i
#把数据按每周进行排序 6 D& P1 W; b8 \' w$ k8 dfor k in range (240):% G- _2 _. M$ R
for i in range (0,402): * r3 Z7 I7 L0 g7 U. Z8 f% w0 X for j in range(0,401-i): 6 |1 ?4 J0 ^/ X" x if data[j+1][k+2]<data[j+2][k+2]:6 B3 W8 f; r/ x0 E/ T
(data[j+1][k+2],data[j+2][k+2])=(data[j+2][k+2],data[j+1][k+2])4 i" d; _2 u0 V" S4 V( ?
(num_list[j][k],num_list[j+1][k])=(num_list[j+1][k],num_list[j][k]) " y; p) `+ z5 r ( ^( d: s6 |" I5 w2 ?1 N3 }+ l: {$ ]" l O
#排名相同的同一个排名(进行并序排名): G% z, h: T5 B$ F
5 y. S. n* `9 ^% z+ r' D- w$ v9 xy = numpy.zeros((402,240)); R7 B; p! H( |( A
for i in range (0,240):4 v c0 j& ?4 b, k
a=1 / ^. ~$ V* q! T1 Z& F y[0][i]=16 ]1 a& V: o6 J" J! Z% G
n=1 - P' L& r% o5 |* ` for j in range(0,401): , K0 P" x3 S% l6 x# l if data[j+1][i+2]==data[j+2][i+2]: : \9 _, J6 [7 q5 W y[j+1][i]=y[j][i] - @2 o2 y; F+ m1 O% h n=n+1 3 p( m: J# t; Y5 J) x else :, @! \( o' S M+ f6 y6 U
y[j+1][i]=a+n( f. z$ t, T3 t" k
a=a+n 3 e1 l5 F N; T0 T4 ? n=12 T" K/ N; J$ R$ O- w
- s2 n0 ~; U8 |+ Z#算每家供应商每周排名的平均值 5 v2 p Y( g/ Y, o8 u
list = numpy.zeros((402,2)) ) k2 G" a' y8 ^+ l2 O
for k in range(1,403): ( [3 P/ W- M( n$ l# k sum=0.0 ) C( S8 _9 X% t! ]0 `) ?- v for i in range(0,402): ( Z* b% w% K1 S! a% a, a for j in range (0,240): 9 M: [: t9 y9 x! B9 u' Y& b5 S* i: W if num_list[i][j]==k: 8 W3 @1 z. n: D, K: m) ? sum=sum+y[i][j] 2 W! o7 B- O1 ~ sum=sum/240 9 n% l0 @3 g' i l' M* w4 { list[k-1][0]=sum4 l6 ?( c+ k1 w! F. T6 F- B
list[k-1][1]=k ! U _1 a: Y6 o1 m & R8 S7 |* |, R- u& |$ }7 Y5 Y/ z+ ?, l* ?! e1 k% _+ T* {+ o" j/ S
# _- k6 v9 K) |( ~/ z* P& s6 s
# 对每周排名的平均值进行排序 * q6 o8 H/ i9 A3 O# Ffor i in range (0,402):& \5 l a0 C0 W, l2 M+ I, S/ N3 S
for j in range(0,401-i): ' x% V. h& ~2 M if list[j][0]>list[j+1][0]:- }" j* I. p5 F9 P2 s* O
(list[j][0],list[j+1][0])=(list[j+1][0],list[j][0])0 s9 w" _, L9 q, R; u
(list[j][1],list[j+1][1])=(list[j+1][1],list[j][1]) ! \8 R1 S0 l: C1 z3 u # p$ L+ s& Z* }6 ]. c4 q) K( I2 y4 d0 a9 b
#输出结果 7 e# h1 z9 h9 ]5 b* V9 F
for i in range(0,50): + F4 h8 `) ]6 G4 i% ]9 B6 a print(list[i][1]) / K1 Q u8 n$ _, {: N' D" L6 @8 g5 X5 Y7 ]8 c
18 ^) S" t: Z4 c: P& B; v' e& E
2 6 k! g& E8 h9 c3 n# s3 2 Q9 N9 Q. C+ E1 z4 - m& z. t0 R+ `/ e( J" {0 h- @5) }& D, j7 J+ g" [0 f U! E
6 ( s% n5 \" W7 Y; W/ A* {4 p: `75 s( T0 C0 m% V# M& e6 J" a4 ?
8 ' o( _! g8 @ V+ Q3 S9* I' y0 G1 M) Z. _' }- z O/ s& P
10 ( Y, N( r/ F# U0 [) {11* \; L) d" F% v- N% ]) W3 I
120 |0 m/ C1 }+ z7 I
13) t9 A, ~3 t( |2 N
147 ]* k8 l% n# G
15 & m- _( {( ]+ |16* S( T) {0 h) L+ Y# `
17 & z9 Z9 W% r0 p, M; `. \2 g18 ) b" O; f. V" t G( z0 ~1 a; T8 O, E7 S191 J* e% v q; ~9 R
20! _/ G K. {# O) Y- W# v/ r$ y) ]
217 }9 q' ^! U2 A4 V
220 ~: R5 {6 I/ v" q/ I0 {5 Q
23 : ^, ?4 W% ]5 ^9 x$ E24 1 f! G9 z% ~: s: f9 r ]25 ! F3 \& M3 m8 G4 l0 @: E26 9 Z" M9 v6 m$ K& L3 E @4 I27) `. S! M$ ? ?! w' @+ Z: m
28 & I) Q" [8 Y# N29 3 D6 y9 u5 x o: ~) F1 j30 ' O" D {' k: l5 f31 + H7 z o" I8 _) P3 b- P. ?324 ^0 C/ U, p- G5 d
33 I; [! R& p7 \
34! o! W3 V; p% K8 v9 N* u% N$ g- P
35! f( z3 ~0 V' |8 r- C4 s8 h
36: ^- o9 w2 ~7 n6 O
370 S. ?. W \/ t5 l" ?
38 ) O, Z- ]7 z* q( z$ E39 1 o* s& f4 P+ d% q40$ Y, v+ w, {- }- b* q. @- O
41* K' M) v) r; G m1 v$ p
42; K, {2 m) n" E: b% B: T
43* l4 Q2 L& r. `1 X l! O, Z
44% A- z( b& X' `% O
45 / ^+ [- d( f( T1 `46" r5 U5 U9 `: j S9 F
475 {, j# U* e" n% \6 P" Y [8 ?5 F
48' K4 d$ G; w. H! z* E9 E
49 ( R7 L5 s1 N3 M. c3 J; a50 , \* q- u* z3 S$ \* u4 P51 9 |5 ~. {8 j, m3 L52 7 W; u7 i- s! z# u# O; N% J- n53 1 F/ e' O5 S$ U! c$ T; }54, A+ o* A9 K* M+ r- w% z8 y4 F5 D& l
55% f# p6 V' w/ g) m$ s5 N
56 4 {3 o6 ]/ M- v* _2 k/ m$ H6 g/ y57 i# _( T" H. l; D
58 ! M0 N2 V$ E( j) O5 X% K' o* G1 f591 N* X. Z' R( `; K; U4 e
60 - H' b: r' \: Q& {' z" O& o d61 9 R, B& W! \/ s62 ! a7 f& _8 G, W; p* m- v639 q9 o- T& e. R5 R- l, J
64 . h4 p+ @* f/ N$ H0 H) i65. m0 u% H8 D, ]* `8 u a7 R; ^
66 3 f8 Y# _& b6 |/ j3 o! z) w8 H67 ! r- o( t+ N$ O d8 k$ y686 R1 [$ B O3 x k" e- u
69 # b1 d4 r8 @# y s/ s70# A$ u8 H L' p: d& {- n1 G
改进:6 W- ~; ?9 z5 q9 u; e7 H4 A
最重要这个有三个因素去影响它,第一个是方差,第二个是供应量,第三个是供应量和订购量的差值,函数:f = 供应量-方差-差值(供应量和方差,差值不是一个数量级,可以用供应量除以最大供应量,还可以根据这三个因素的重要程度设置权值) + S( H1 F+ }! G. Q7 G2 F P1 F4 ~当时我们小组因为时间不够,没有完善这个。 ; G0 H/ _ h6 b7 I# L+ `3 B; |' E, I
第二问: 8 J( f8 [' T" d. q6 @. b: H% [思路:(具体分析可见论文)2 C8 m1 ~- }4 {7 |8 s' ]: B
对 402 家企业近 5 年的总产能进行排序,在总产能误差为 0.3%的限定条件下筛选,最终选择 37 家供应商。 + l7 J2 i1 N2 s- M" j : ]8 |7 T% h* g: P7 d) G7 N4 r将 240 周 402 企业的订货量与供货量的差取绝对值,依次对上述连续两周所求的绝对值求均值后从小到大排序,选取位于前 12 位的连续两周,即选定 24 周,并得到订购方案: H. D" [4 U" }# Y" C( A$ i