可变成本问题
某公司生产A、B、C共3种产品,售价分别是12元、7元和6元。生产1件这些产品的技术服务、直接劳动、材料的消耗以及这些资源的限量如表所示。
产品\项目
技术服务(h)
直接劳动(h)
材料(kg)
售价(¥/件)
A
1
10
3
12
B
2
4
2
7
C
1
5
1
6
现有量
100
700
400
另外生产成本是产量的非线性函数,如下表。如何安排每种产品的产量,使得利润最大。
产品A
产量(件)
成本
(元/件)
0-40
10
41-100
9
101-150
8
150以上
7
产品B
产量(件)
成本
(元/件)
0-50
6
51-100
4
100以上
3
产品C
产量(件)
成本
(元/件)
0-100
5
100以上
4
【问题分析】
生产中,利润=收入-成本,收入=销量×单价,成本=产量×单位成本,只不过这里成本是产量的阶梯函数(折扣函数)。
【问题假设】
三类产品的产量都等于销售量;产量为0时,销售量也为0,成本为0,利润也会为0;三类产品的产量,都是按整数计件;【符号说明】
xi 分别表示A、B、C三类产品的产量(销售量),i=1,2,3;L 总利润;R 总收入;C 总成本。Ci 分别表示A、B、C三种产品的总生产成本;i=1,2,3;【建立模型】
总利润 L=R-C
总收入
生产成本
其中产品A的生产成本为
产品B的生产成本为
产品C的生产成本为
产量的资源约束
变量约束
【数学模型】
max L=R-C
lingo程序
max=R-C;
R=12*x1+7*x2+6*x3;
C=c1+c2+c3;
c1=@if(x1#le#40,10*x1,@if(41#ge#x1#and#x1#le#100,9*x1, @if(x1#le#150#and#x1#ge#101,8*x1,7*x1)));
c2=@if(x2#le#50,6*x2,@if(51#ge#x2#and#x2#le#100,4*x2,3*x2));
c3=@if(x3#le#100,5*x3,4*x3);
x1+2*x2+x3<100;
10*x1+4*x2+5*X3<700;
3*x1+2*x2+x3<400;
@gin(x1);@gin(x2);@gin(x3);
c1=@if(x1#le#40,10*x1,
@if(41#ge#x1#and#x1#le#100,9*x1,
@if(x1#ge#101#and#x1#ge#150,8*x1,7*x1)));
翻译为matlab条件循环语句,为
>> if x1<=40
c1=10*x1;
elseif (x1>=41)&(x1<=100)
c1=9*x1;
elseif (x1>=101)&(x1<=150)
c1=8*x1;
else
c1=7*x1;
end