lingo基础入门Day 4
lingo的背包问题的一般描述
- 背包问题可描述为:给定n个物品,每件物品重量价值以及背包最大载重已知的情况下,如果进行选择才能使背包的物品总价值最高
- 对于决策者,如果每件货物只有装或者不装两种选择,而不能拆开装一部分,那么这样的背包问题就是一个0-1的背包问题(0-1 Knapsack Problem)。
- 只考虑重量约束的是一维背包约束,还要考虑容积约束的就是二维背包问题。
- 但现实中考虑容积需要考虑长宽高,实际为三维背包问题。
- 一维二维都是对部分问题的合理简化。
背包问题实例即数学模型
有10件货物从甲到乙
物品 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |
---|---|---|---|---|---|---|---|---|---|---|
重量 | 6 | 3 | 4 | 5 | 1 | 2 | 3 | 5 | 4 | 2 |
利润 | 540 | 200 | 180 | 350 | 60 | 150 | 280 | 450 | 320 | 120 |
x | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | x10 |
只有一辆最大载重30T货车运送货物,只能选择部分货物运送。
运送哪些,使得总利润最大。(0-1背包问题)
用lingo建立模型并求解
- 定义集合
- 给常量赋值
- 目标函数的表达
- 约束条件的表达
- 模型求解
定义集合
ITEM/1 2 3 4 5 6 7 8 9 10/; (显式罗列)
ITEM/1…10/;(隐式罗列)
定义向量
向量与集合一起定义,在lingo中被称为集合的属性(Attribute)。
ITEM/1 2 3 4 5 6 7 8 9 10/: WEIGHT,PROFIT, X;(下表都是按/…/中的数据)
给常量赋值
DATA:
WEIGHT = 6 3 4 5 1 2 3 5 4 2 ;
PROFIT = 540 200 180 350 60 150 280 450 320 120;
ENDDATA
赋值了就是常量,没赋值就是变量
目标函数的表达
实现装在货物利润最大化
MAX = @SUM(ITEM(I):PROFIT(I)*x(I));//依次把对应变量相乘并相加
最大载重量的约束
@SUM(ITEM(I)): WEIGHT(I)*X(I))<=30;//计算该货物的重量以及总合小于等于30吨
变量取值范围的约束
xi只能0-1变量
@FOR(ITEM(I):@BIN(X(I)));//产生了I个0-1变量
完整模型
!Name: 背包问题模型
!Date: 2022-03-16
!Desc: 10件货物的背包问题
;
MODEL:
SETS:
ITEM/1 2 3 4 5 6 7 8 9 10/:WEIGHT, PROFIT,X;
ENDSETS
DATA:
WEIGHT = 6 3 4 5 1 2 3 5 4 2
PROFIT = 540 200 180 350 60 150 280 450 320 120;
ENDDATA
MAX = @SUM(ITEM(I):PROFIT(I)*x(I));
@SUM(ITEM(I)): WEIGHT(I)*X(I))<=30;
@FOR(ITEM(I):@BIN(X(I)));
END
运算结果:
Global optimal solution found.
Objective value: 2410.000
Objective bound: 2410.000
Infeasibilities: 0.000000
Extended solver steps: 0
Total solver iterations: 0
Elapsed runtime seconds: 0.19
Model Class: PILP
Total variables: 10
Nonlinear variables: 0
Integer variables: 10
Total constraints: 2
Nonlinear constraints: 0
Total nonzeros: 20
Nonlinear nonzeros: 0
Variable Value Reduced Cost
WEIGHT( 1) 6.000000 0.000000
WEIGHT( 2) 3.000000 0.000000
WEIGHT( 3) 4.000000 0.000000
WEIGHT( 4) 5.000000 0.000000
WEIGHT( 5) 1.000000 0.000000
WEIGHT( 6) 2.000000 0.000000
WEIGHT( 7) 3.000000 0.000000
WEIGHT( 8) 5.000000 0.000000
WEIGHT( 9) 4.000000 0.000000
WEIGHT( 10) 2.000000 0.000000
PROFIT( 1) 540.0000 0.000000
PROFIT( 2) 200.0000 0.000000
PROFIT( 3) 180.0000 0.000000
PROFIT( 4) 350.0000 0.000000
PROFIT( 5) 60.00000 0.000000
PROFIT( 6) 150.0000 0.000000
PROFIT( 7) 280.0000 0.000000
PROFIT( 8) 450.0000 0.000000
PROFIT( 9) 320.0000 0.000000
PROFIT( 10) 120.0000 0.000000
X( 1) 1.000000 -540.0000
X( 2) 1.000000 -200.0000
X( 3) 0.000000 -180.0000
X( 4) 1.000000 -350.0000
X( 5) 0.000000 -60.00000
X( 6) 1.000000 -150.0000
X( 7) 1.000000 -280.0000
X( 8) 1.000000 -450.0000
X( 9) 1.000000 -320.0000
X( 10) 1.000000 -120.0000
Row Slack or Surplus Dual Price
1 2410.000 1.000000
2 0.000000 0.000000
模型求解
物品 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |
---|---|---|---|---|---|---|---|---|---|---|
重量 | 6 | 3 | 4 | 5 | 1 | 2 | 3 | 5 | 4 | 2 |
利润 | 540 | 200 | 180 | 350 | 60 | 150 | 280 | 450 | 320 | 120 |
x | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 |
总利润=2410元
实际所装货物总量=30吨
总结
背包问题实例如果定义原始集合、给常量赋值、目标函数的表达约束条件的表达模型求解,整体解决了一个0-1规划问题并算出来了总利润。