整数规划的两种数学模型解法
整数规划解法与实际案例分析

整数规划解法与实际案例分析整数规划是运筹学中的一个重要分支,它在实际问题中有着广泛的应用。
整数规划问题是指决策变量被限制为整数的线性规划问题,通常用于需要做出离散决策的情况。
在本文中,我们将介绍整数规划的基本概念和解法,并结合一个实际案例进行分析,以帮助读者更好地理解整数规划的应用。
### 整数规划的基本概念整数规划是一种特殊的线性规划问题,其决策变量被限制为整数。
一般来说,整数规划可以分为纯整数规划和混合整数规划两种情况。
纯整数规划要求所有的决策变量都是整数,而混合整数规划则允许部分决策变量为整数,部分为连续变量。
整数规划可以用数学模型来描述,通常形式如下:$$\begin{aligned}\text{Maximize} \quad & c^Tx \\\text{Subject to} \quad & Ax \leq b \\& x \in \mathbb{Z}^n\end{aligned}$$其中,$c$、$x$、$b$ 分别为目标函数系数向量、决策变量向量和约束条件右端常数向量,$A$ 为约束条件系数矩阵,$x \in\mathbb{Z}^n$ 表示 $x$ 是一个整数向量。
### 整数规划的解法整数规划问题的求解相对复杂,因为整数约束使得问题的解空间不再是连续的,而是离散的。
针对整数规划问题,通常有以下几种解法:1. **穷举法**:穷举法是最直接的方法,即枚举所有可能的整数解,然后逐一计算目标函数值,找出最优解。
然而,穷举法在问题规模较大时会变得非常低效。
2. **分支定界法**:分支定界法是一种常用的整数规划求解方法。
它通过不断将整数规划问题分解为子问题,并对子问题进行求解,直到找到最优解为止。
3. **割平面法**:割平面法是一种基于线性规划的整数规划求解方法。
它通过不断添加线性不等式约束(割平面)来逼近整数解,直到找到最优解为止。
4. **分支定价法**:分支定价法是一种高级的整数规划求解方法,通常用于解决混合整数规划问题。
整数线性规划

分枝定界法的理论基础:
1 2 k , i j (1) max cx max (max cx, max cx, , max cx)
x x1 x 2 x k
(2) 若 i j ,则 max cx max cx
xi xi x
分 枝
给定整数规划问题IP max z C T X
若x 的某个分量 xi 不是整数,
0
0
则将 IP分解为两个子问题
max z C X AX b X 0 X为整数向量 xi [ xi0 ]
T max z C X AX b X 0 X为整数向量 xi [ xi0 ] 1
记 z0 z
x1 4, x1 5
将问题B0分解为两个子问题B1和B2(分枝), 分别解B1,B2得 B1: x1=4, x2=2.10, z1=349 B2: x1=5, x2=1.57, z2=341
max z 40 x1 90 x2 max z 40 x1 90 x2 9 x1 7 x2 56 7 x 20 x 70 1 2 x1 4 B1 x1 , x2 0 9 x1 7 x2 56 7 x 20 x 70 1 2 x1 5 B2 x1 , x2 0
4、几点说明 (1)、如果要求目标的最大值
max z cij xij
令
bij M cij
i
j
其中
M max{ cij }
效率矩阵可变为B,将分配问题转换为一个极 小化问题
min z
'
b x
ij i j
ij
(2)、如果分配问题中,人员数 m 不等于工作数 n 时,可以类似于不平衡运输问题建立模型的 方法,增加虚拟人员或虚拟工作。
整数规划

比如下面的例子:
例1.某厂拟用集装箱托运甲乙两种货物,每箱 的体积、重量、可获利润以及托运所受限制如 下表:
货物 体积(每 箱M3) 5 甲 4 乙 托运限制 24 重量(每箱 50kg) 2 5 13 利润(每 箱百元) 20 10
问两种货物各托运多少箱,可使利润最大?
为了满足整数解得要求,初看,似乎只要把已得到的分 数或小数, “舍入化整”就可以了。但是,这常常是不行的, 因为化整后,不一定是可行解,或者虽是可行解,但不一定 是最优解。
整数规划
§1 整数规划及其解法 §2 0-1型整数规划 §3 指派问题
整数规划
1、理解整数规划、0-1规划和指派问题的数学 模型 2、理解整数规划模型的类型 3、理解整数规划的求解方法:分支定界法和割 平面法、0-1规划的隐枚举法和指派问题的 匈牙利法的思想和步骤
求解方法
1、分支定界法 2、割平面法
a x
i 1 ij
n
j
bi yi M (i 1,, m)
y1 + y2 + „ + ym = m –1, yi = 0 或 1 (i=1,„,m)
3、关于固定费用问题
• 在讨论线性规划时,有些问题是要求使 成本最少的方案,那时总设固定成本为 常数,并在线性规划的模型中不必明显 列出。但有些固定成本的问题不能用一 般线性规划来描述,但可改为混合整数 规划来解决。
aj
值最大?
解:设 x j 为决策变量,且 x j 满足如下限制
xj {
1,携带第j件物品 0,不携带第j件物品
,j 1,2, n
则问题的数学模型为
x c j x j max
j 1
n
运筹学整数规划

运筹学整数规划运筹学是研究在资源有限的条件下,如何进行决策和优化的一门学科。
整数规划是运筹学中的一个重要分支,它解决的是决策变量必须为整数的问题。
整数规划在实际问题中具有广泛的应用,如生产计划、设备配置、选址问题等。
整数规划问题的数学模型可以表示为:max/min c^T xs.t. Ax ≤ bx ≥ 0x ∈ Z其中,c是目标函数的系数矩阵,x是决策变量的向量,A是约束条件的系数矩阵,b是约束条件的向量,Z表示整数集合。
整数规划问题与线性规划问题相似,但整数规划问题的约束条件多了一个整数限制,使得问题的解空间变得更为复杂。
由于整数规划问题的NP-hard性质,求解整数规划问题是一项困难的任务。
求解整数规划问题的常用方法有分支定界法、割平面法和启发式算法等。
分支定界法是一种穷举搜索的方法,它通过将整数规划问题不断分割成更小的子问题,从而逐步搜索解空间,直到找到最优解。
分支定界法对于规模较小的问题比较有效,但对于大规模复杂问题,效率较低。
割平面法是一种通过添加新的约束条件来减少解空间的方法。
它利用线性松弛问题(将整数约束条件放宽为线性约束条件)的解来构造有效的割平面,从而逐步缩小解空间,找到最优解。
割平面法通常比分支定界法更有效,但对于某些问题,可能需要添加大量的割平面才能收敛到最优解。
启发式算法是一种基于经验和启发式搜索的方法。
它通过设置初始解、搜索策略和邻域搜索等步骤,来快速找到近似最优解。
常见的启发式算法有遗传算法、模拟退火算法和禁忌搜索算法等。
启发式算法虽然不能保证找到全局最优解,但能够在可接受的时间内找到较优解。
综上所述,整数规划作为运筹学中的重要分支,解决的是决策变量必须为整数的问题。
整数规划问题具有广泛的应用,但由于其NP-hard性质,求解过程较为困难。
常用的求解方法包括分支定界法、割平面法和启发式算法等。
这些方法各有优劣,根据具体问题的特点选择合适的方法进行求解。
整数规划(整数规划)

在生产管理和经营活动中若要求解:
• 安排上班的人数 • 运输车辆台数
第八章
整数规划(IP)
(Integer Programming)
主要内容: §1 整数规划的模型(掌握) §2 整数规划的计算机求解(掌握) §3 整数规划的应用(掌握)
(补充指派问题的匈牙利解法)
一、整数规划的模型
(一)整数规划实例 例1:某公司拟用集装箱托运甲、乙两种货物, 这两种货物每件的体积、重量,可获利润以及 托运所受限制如表所示:
用 图 解法求出最优解 x1=3/2, x2 = 10/3 且有MaxZ = 29/6
x2
3
⑴
⑵
(3/2,10/3)
现求整数解(最优解): 如用“舍入取整法”可得 到4个点即(1,3) (2,3) (1,4)(2,4)。显然,它们 都不可能是整数规划的最 优解。
3
x1
按整数规划约束条件,其可行解肯定在线性规划问题 的可行域内且为整数点。故整数规划问题的可行解集 是一个有限集,如图所示。
工作 人
B1 a11 a21 a31
B2 a12 a22 a32
B3 a13 a23 a33
A1 A2 A3
要求:1.将此分配问题的求解转化为一个网络图中求始点 与终点之间的最短路问题,画出该网络图,注明 节点和边的含义,并标明每一条边的aij值; 2.以上述网络图为基础,利用0-1变量建立该最短 路问题的0-1整数规划模型,列出该模型的数学 表达式。
设决策变量
xij =
1
0
分配第i 个人去做第j 件工作
相反
n
( I,j=1.2. …n )
min Z 其数学模型为:
c
数学规划模型——整数规划问题

数学规划模型——整数规划问题title: 数学规划模型——整数规划问题date: 2020-02-27 00:37:35categories: 数学建模tags: [MATLAB, 数学规划模型]整数规划整数规划:线性整数规划 - Matlab可进⾏求解(线性的意思在线性规划的基础上 , 加⼊决策变量取整数的条件)⾮线性整数规划→⽆特定算法, 只能⽤近似算法 , 如蒙特卡罗模拟、智能算法 ( 后续会讲到)特例: 特殊的整数规划 , Matlab中也只能求解线性01规划, 对于⾮线性 0-1规划也只能近似求解 。
(数模⽐赛中常出现)Matlab整数规划求解线性整数规划求解[x ,fval] = linprog [ c, A, b, Aeq, beq, lb, ub, X0] -> 线性规划的函数[x ,fval] = intlinprog [ c, intconA, b, Aeq, beq, lb, ub]→ 线性整数规划的求解注 :intlinpng 不能指定初始值 ;加⼊了 inton 参数可以指定哪些决策变量是整数。
例如决策变量有三个 : x1,x2,x3 ; 若x1和x3,是整数 , 则 intcon= [1 , 3] 。
线性 0-1规划求解仍然使⽤intlinprog 函数 , 只不过在 lb和ub上作⽂章 。
例如决策变量有三个 : x1,x2,x3 ; 若x1和x3是0-1变量,x2不限制, 则 intcon= [1 , 3] ,lb=[0 -inf 0]',ub=[1,+inf,1]。
⼩例题%% 线性整数规划问题%% 例1c=[-20,-10]';intcon=[1,2]; % x1和x2限定为整数A=[5,4;2,5];b=[24;13];lb=zeros(2,1);[x,fval]=intlinprog(c,intcon,A,b,[],[],lb)fval = -fval%% 例2c=[18,23,5]';intcon=3; % x3限定为整数A=[107,500,0;72,121,65;-107,-500,0;-72,-121,-65];b=[50000;2250;-500;-2000];lb=zeros(3,1);[x,fval]=intlinprog(c,intcon,A,b,[],[],lb)%% 例3c=[-3;-2;-1]; intcon=3; % x3限定为整数A=ones(1,3); b=7;Aeq=[4 2 1]; beq=12;lb=zeros(3,1); ub=[+inf;+inf;1]; %x(3)为0-1变量[x,fval]=intlinprog(c,intcon,A,b,Aeq,beq,lb,ub)整数规划的典型例题背包问题%% 背包问题(货车运送货物的问题)c = -[540 200 180 350 60 150 280 450 320 120]; % ⽬标函数的系数矩阵(最⼤化问题记得加负号)intcon=[1:10]; % 整数变量的位置(⼀共10个决策变量,均为0-1整数变量)A = [6 3 4 5 1 2 3 5 4 2]; b = 30; % 线性不等式约束的系数矩阵和常数项向量(物品的重量不能超过30)Aeq = []; beq =[]; % 不存在线性等式约束lb = zeros(10,1); % 约束变量的范围下限ub = ones(10,1); % 约束变量的范围上限%最后调⽤intlinprog()函数[x,fval]=intlinprog(c,intcon,A,b,Aeq,beq,lb,ub)fval = -fval指派问题%% 指派问题(选择队员去进⾏游泳接⼒⽐赛)clear;clcc = [66.8 75.6 87 58.6 57.2 66 66.4 53 78 67.8 84.6 59.4 70 74.2 69.6 57.2 67.4 71 83.8 62.4]'; % ⽬标函数的系数矩阵(先列后⾏的写法)intcon = [1:20]; % 整数变量的位置(⼀共20个决策变量,均为0-1整数变量)% 线性不等式约束的系数矩阵和常数项向量(每个⼈只能⼊选四种泳姿之⼀,⼀共五个约束)A = [1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0;0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0;0 0 0 0 0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 0;0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1 0 0 0 0;0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1];% A = zeros(5,20);% for i = 1:5% A(i, (4*i-3): 4*i) = 1;% endb = [1;1;1;1;1];% 线性等式约束的系数矩阵和常数项向量(每种泳姿有且仅有⼀⼈参加,⼀共四个约束)Aeq = [1 0 0 0 1 0 0 0 1 0 0 0 1 0 0 0 1 0 0 0;0 1 0 0 0 1 0 0 0 1 0 0 0 1 0 0 0 1 0 0;0 0 1 0 0 0 1 0 0 0 1 0 0 0 1 0 0 0 1 0;0 0 0 1 0 0 0 1 0 0 0 1 0 0 0 1 0 0 0 1];% Aeq = [eye(4),eye(4),eye(4),eye(4),eye(4)]; % 或者写成 repmat(eye(4),1,5)% Aeq=zeros(4,20);% for i = 1:4% for j =1:20% if mod(j,4)==i% Aeq(i,j)=1;% end% if i==4% if mod(j,4)==0% Aeq(i,j)=1;% end% end% end% endbeq = [1;1;1;1];lb = zeros(20,1); % 约束变量的范围下限ub = ones(20,1); % 约束变量的范围上限%最后调⽤intlinprog()函数[x,fval] = intlinprog(c,intcon,A,b,Aeq,beq,lb,ub)% reshape(x,4,5)'% 0 0 0 1 甲⾃由泳% 1 0 0 0 ⼄蝶泳% 0 1 0 0 丙仰泳% 0 0 1 0 丁蛙泳% 0 0 0 0 戊不参加钢管切割问题%% 钢管切割问题%% (1)枚举法找出同⼀个原材料上所有的切割⽅法for i = 0: 2 % 2.9m长的圆钢的数量for j = 0: 3 % 2.1m长的圆钢的数量for k = 0:6 % 1m长的圆钢的数量if 2.9*i+2.1*j+1*k >= 6 & 2.9*i+2.1*j+1*k <= 6.9disp([i, j, k])endendendend%% (2) 线性整数规划问题的求解c = ones(7,1); % ⽬标函数的系数矩阵intcon=[1:7]; % 整数变量的位置(⼀共7个决策变量,均为整数变量)A = -[1 2 0 0 0 0 1;0 0 3 2 1 0 1;4 1 0 2 4 6 1]; % 线性不等式约束的系数矩阵b = -[100 100 100]'; % 线性不等式约束的常数项向量lb = zeros(7,1); % 约束变量的范围下限[x,fval]=intlinprog(c,intcon,A,b,[],[],lb)。
整数规划

5 2 C = 0 0
0 2 0 3 0 0 0 6 7 8 0 0
步骤3: 若 n ,作最少直线覆盖当前零元素。 已知例12中的系数矩阵为 ⒈变换系数矩阵
4 7 C = 6 6 6
8 7 15 12 9 17 14 7 9 12 6 10 7 14 8 10 9 6 10 8
最多有3个独立0元素!
5 2 C = 0 4
0 2 0 3 0 0 5 6 7 8 0 0
5 2 C = 0 4
0 2 0 3 0 7 5 6 0 8 0 3
至于如何找覆盖零元素的最少直线,通过例子来说明。 例1 现有一个4×4的指派问题,其效率矩阵为:
整数线性规划数学模型的一般形式为:
max(or min) z = ∑ c j x j n ∑ aij x j ≤ (or =, ≥)bi , i = 1, 2,L , m s.t j =1 x j ≥ 0, x j 中部分或全部为整数, = 1, 2,L , n j
j =1
n
整数线性规划类型
B1 B2 B3 B4 B5
C=
A1 4 A2 7 A3 6 A4 6 A5 6
8 7 15 12 9 17 14 10 9 12 8 7 7 14 6 10 9 12 10 6
这是一个标准的指派问题。若设0-1变量
1 xij = 0
例12:某商业公司计划开办五家新商店。为了尽早建成 营业,商业公司决定由5家建筑公司分别承建。已知建筑 公司 Ai (i = 1,2, L ,5) 对新商店B j ( j = 1,2, L,5) 的建造 报价(万元)为 cij (i, j = 1,2, L ,5) , 见矩阵C。商业公 司应当对5家建筑公司怎样分配建筑任务,才能使总的建 筑费用最少?
转载整数规划求解方法

转载整数规划求解方法整数规划整数规划的数学模型及解的特点解纯整数规划的割平面法分支定界法0-1型整数规划指派问题与匈牙利法整数规划的数学模型及解的特点整数规划IP(integerprogramming):在许多规划问题中,如果要求一部分或全部决策变量必须取整数。
例如,所求的解是机器的台数、人数、车辆船只数等,这样的规划问题称为整数规划,简记IP。
松弛问题(slackproblem):不考虑整数条件,由余下的目标函数和约束条件构成的规划问题称为该整数规划问题的松弛问题。
若松弛问题是一个线性规化问题,则该整数规划为整数线性规划(integerlinearprogramming)。
一、整数线性规划数学模型的一般形式整数线性规划问题可以分为以下几种类型1、纯整数线性规划(pureintegerlinearprogramming):指全部决策变量都必须取整数值的整数线性规划。
有时,也称为全整数规划。
2、混合整数线性规划(mixedintegerlinerprogramming):指决策变量中有一部分必须取整数值,另一部分可以不取整数值的整数线性规划。
3、0-1型整数线性规划(zero-oneintegerlinerprogramming):指决策变量只能取值0或1的整数线性规划。
二、整数规划的解的特点相对于松弛问题而言,二者之间既有联系,又有本质的区别(1)整数规划问题的可行域是其松弛问题的一个子集(2)整数规划问题的可行解一定是其松弛问题的可行解(3)一般情况下,松弛问题的最优解不会刚好满足变量的整数约束条件,因而不是整数规划的可行解,更不是最优解(4)对松弛问题的最优解中非整数变量简单的取整,所得到的解不一定是整数规划问题的最优解,甚至也不一定是整数规划问题的可行解(5)求解还是要先求松弛问题的最优解,然后用分支定界法或割平面法。
解纯整数规划的割平面法基本思路:通过增加新的约束来切割可原问题伴随规划的可行域,使它在不断缩小的过程中,将原问题的整数最优解逐渐暴露且趋于可行域极点的位置,这样就有可能用单纯形法求出。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
规划模型求解指导老师:组员:组员分工实际的内容:1·简要介绍线性规划的历史线性规划是运筹学中最基本、应用最广泛的分支。
规划模型是一类有着广泛应用的确定性的系统优化模型,1939年,苏联数学家康托洛维奇出版《生产组织和计划中的数学方法》一书.1947年,美国数学家丹兹格提出了线性规划问题的单纯形求解方法.1951年,美国经济学家库普曼斯(J.C.Koopmans,1910—1985)出版《生产与配置的活动分析》一书.1950~1956年,线性规划的对偶理论出现.1960年,丹兹格与沃尔夫(P.Wolfe)建立大规模线性规划问题的分解算法.1975年,康托洛维奇与库普曼斯因“最优资源配置理论的贡献”荣获诺贝尔经济学奖.1978年,苏联数学家哈奇扬(L.G.Khachian)提出求解线性规划问题的多项式时间算法(内点算法),具有重要理论意义.1984年,在美国贝尔实验室工作的印度裔数学家卡玛卡(N.Karmarkar)提出可以有效求解实际线性规划问题的多项式时间算法——Karmarkar算法.线性规划的基本点就是在满足一定约束条件下,使预定的目标达到最优. 现在线性规划已不仅仅是一种数学理论和方法,而且成了现代化管理的重要手段,是帮助管理者与经营者做出科学决策的一个有效的数学技术.历史表明,重要数学概念对数学发展的作用是不可估量的,函数概念对数学发展的影响,可以说是贯穿古今、旷日持久、作用非凡,回顾函数概念的历史发展,看一看 函数概念不断被精炼、深化、丰富的历史过程,是一件十分有益的事情,它不仅有助于我们提高对函数概念来龙去脉认识的清晰度,而且更能帮助我们领悟数学概念 对数学发展,数学学习的巨大作用。
2·线性规划的原理:线性规划是合理利用、调配资源的一种应用数学方法。
它的基本思路就是在满足一定的约束条件下,使预定的目标达到最优。
它的研究内容可归纳为两个方面:一是系统的任务已定,如何合理筹划,精细安排,用最少的资源(人力、物力和财力)去实现这个任务;二是资源的数量已定,如何合理利用、调配,使任务完成的最多。
前者是求极小,后者是求极大。
线性规划是在满足企业内、外部的条件下,实现管理目标和极值(极小值和极大值)问题,就是要以尽少的资源输入来实现更多的社会需要的产品的产出。
因此,线性规划是辅助企业“转轨”、“变型”的十分有利的工具,它在辅助企业经营决策、计划优化等方面具有重要的作用。
其一般形式为:n n n n nn b x a x a x a b x a x a x a x c x c x c x f =+++=+++→+++= 22222121112121112211min )(3·整数规划的原理整数规划IP (integer programming):在许多规划问题中,如果要求一部分或全部决策变量必须取整数。
例如,所求的解是机器的台数、人数、车辆船只数等,这样的规划问题称为整数规划,简记IP 。
松弛问题(slack problem):不考虑整数条件,由余下的目标函数和约束条件构成的规划问题称为该整数规划问题的松弛问题。
若松弛问题是一个线性规化问题,则该整数规划为整数线性规划(integer linear programming)。
整数线性规划数学模型的一般形式∑==n j cjxjz 1min(max)n i x i ,,2,10 =≥中部分或全部取整数n j n j ij ijx x x m j ni x b x a t s ,...,,...2,1,...,2,10),(.211==≥=≥≤∑=∑==nj jj x c Z 1min)max(或4·处理的方法和背景:整数规划又分为:(1)割平面法通过增加新的约束来切割可原问题伴随规划的可行域,使它在不断缩小的过程中,将原问题的整数最优解逐渐暴露且趋于可行域极点的位置,这样就有可能用单纯形法求出。
(2)分支定界法分支定界法的主要思路是首先求解整数规划的伴随规划,如果求得的最优解不符合整数条件,则增加新约束——缩小可行域;将原整数规划问题分支——分为两个子规划,再解子规划的伴随规划……,最后得到原整数规划的伴随规划。
这就是所谓的“分支”。
所谓“定界”,是在分支过程中,若某个后继问题恰巧获得整数规划问题的一个可行解,那么,它的目标函数值就是一个“界限”,可以作为衡量处理其它分支的一个依据。
“分支”为整数规划最优解的出现创造了条件,而“定界”则可以提高搜索的效率线性规划的步骤:1.根据影响所要达到目的的因素找到决策变量;2.由决策变量和所在达到目的之间的函数关系确定目标函数;3.由决策变量所受的限制条件确定决策变量所要满足的约束条件。
当我们得到的数学模型的目标函数为线性函数,约束条件为线性等式或不等式时称此数学模型为线性规划模型。
应用举例某厂每日八小时的产量不低于1800件。
为了在进行质量控制,计划聘请两种不同水平的检验员。
一级检验员的标准为:速度25件/小时,正确率98%,计时工资4元/小时;二级检验员的标准为:速度15件/小时,正确率95%,计时工资3元/小时。
检验员每错检一次,工厂要损失2元。
现有可供厂方聘请的检验员人数为一级8人和二级10人,伪是总检验费用最省,该工厂应聘请一级、二级检验员各多少名?一·摘要创新教育是以发掘人的创造潜能、弘扬人的主体精神、促进人的个性和谐发展为宗旨的一种深层教育。
创新是一个民族进步和发展的灵魂,是国家兴旺发达的不竭动力。
大学作为培养高素质创新人才的摇篮,肩负着艰巨的使命。
1.创新能力的培养是创新教育的首要任务2.创新性实验计划的实施过程就是对创新潜力不断挖掘的过程,3.老师的指导是对创新思维的诱导和激发。
本文通过此厂工作量的大致估计计算,运用整数规划的方法建立数学模型,对模型的数学的高度化,高度简化,再灵活运用c++这一强悍的数学软件编程求解,任意的输入此厂的生产量即可精确求解出最佳的检验员人数和级别人数,从而使此厂损失最少,总花费最少,达到检验员的合理聘请。
模型(一)一·问题的分析本问题是最优解问题,可用matlab优化工具包求解,涉及到线性规划,数学软件,数学模型等知识.通过对线性规划的学习,线性规划如上所讲,本题可以理解成每天检验员工作8小时,对一二级检验员的聘请最终达到厂得花费最少的最优模型二·模型的假设1.假设每天生产的产品都要检验员检验完。
2.排除在工作时间内检验员因某些事情而耽误检验产品。
如检验员突然生病,检验机器突然坏掉等不良事故发生。
3.每一个检验员都愿意为本厂工作。
4.每个一级检验员的检验速度都为25件/小时,正确率都为98%,每个二级检验员的检验速度都为15/小时,正确率都为95%。
三.符号说明M:每天生产的产品量x1:聘请的一级检验员人数x2:聘请的二级检验员人数c1:工人每天的工资额c2:检验员错检,工厂每日损失额z:此厂聘请检验员的总花费金额四·模型建立工厂每天应付工资为:c1=32*x1+24*x2由于检验员错检,工厂每日损失:c2=[(25*8)*0.02*x1+(15*8)*0.05*x2]*2=8*x1+12*x2工厂每天总检验费为:z=c1+c2=40*x1+36*x2故目标函数为:min z=40*x1+36*x2约束条件:200*x1+120*x2>=1800200*x1<=1800120*x2<=1800x1>=0x2>=0模型化简:min z=40*x1+36*x2 得到c=[40;36]s.t.-5*x1-3*x2<=-45 A=[-5 -3]和b=[-45]x1<=9 推出vlb=[0;0] vub=[9;15] x2<=15x2>=0五·模型的计算机求解%%f=[-3;2;-5];A=[1 2 -1;1 4 1;1 1 0;4 0 1];b=[2;4;3;6]%%[x,fval,exitflag]=IntLP(f,A,b,[],[],zeros(3,1),[1;1;1])function [x,fval,exitflag]=BranchLP(f,A,b,Aeq,beq,lower,upper) %%Aeq=[-5,-3];beq=[-45];lower=[0,0];upper=[9,15];UB=inf; exitflag=-2;len=length(f);k=int32(1);lb=lower;ub=upper;if isempty(lb)for i=1:lenlb(i)=-Inf;endendif isempty(ub)for i=1:lenub(i)=Inf;endheap(k,1)={lb}; %%heap是堆栈数组,UB为已经获得整数解最优值heap(k,2)={ub};while k>0 %%堆栈数组为空,则退出lb=heap{k,1}; ub= heap{k,2};k=k-1; %%取出堆栈数据[x1,f1,exit]=linprog(f,A,b,Aeq,beq,lb,ub);if (exit==1) & (f1<UB)flag=true;for i=1:lenif abs(x1(i)-round(x1(i)))>1e-7flag=false; %%压入堆栈数据k=k+1;tmp=lb;tmp(i)=max(lb(i),fix(x1(i))+1);heap(k,1)={tmp};heap(k,2)={ub};k=k+1;tmp=ub;tmp(i)=min(ub(i),fix(x1(i)));heap(k,1)={lb};heap(k,2)={tmp};break;endendif flagx= x1;UB= f1;exitflag=1;endendendif exitflag==1x=round(x);fval=f'*x;elsex=[];fval=Inf;end还在找运行结果六·模型的评价本模型通过线性规划的方法,灵活运用matlab对最优化的求解的优点对本题做出一系列的分析与解释,巧妙的对本题做出一系列的假设,运算方便便捷,只需小小的一个matlab程序即可输出最优模型解,再回到现实生活中对模型的检测得出了本题得现实解,不足之处是本题做出了对检验员在工作中因为一些不可预测的原因导致无法工作的现象做出了不能发生的假设,但实际生活中是可以发生的,所以也与现实生活也有一些差距。
七·参考文献【1】《数学建模导论》作者陈理荣北京邮电大学出版社【2】《数学建模》作者:陈义华重庆大学出版社【3】《数学建模与数学实验》作者:赵静但琦高等教育出版社【4】《数学建模与数学实验》作者:刘来福增文艺北京师范大学出版社模型(二)一·问题的重述某厂每日八小时的产量不低于1800件。