1.线性规划的概念" C* o( r6 r a+ X0 m( h
线性规划(Linear Programming 简记 LP)是了运筹学中数学规划的一个重要分支。自从 1947 年 G. B. Dantzig 提出 求解线性规划的单纯形法以来,线性规划在理论上趋向成熟,在实用中由于计算机能处理成千上万个约束条件和决策变量的线性规划问题之后,线性规划现代管理中经常采用的基本方法之一。 在解决实际问题时,需要把问题归结成一个线性规划数学模型,关键及难点在于选适当的决策变量建立恰当的模型,这直接影响到问题的求解。+ V( c- ], e) D" X+ h1 @; n- v
' k/ T0 Q) b' w9 ^& v2 ^' k 线性规划问题的目标函数及约束条件均为线性函数;约束条件记为 s.t.(即 subject to)。目标函数可以是求最大值,也可以是求最小值,约束条件的不等号可以 是小于号也可以是大于号。: V7 l/ \/ O7 |3 _( \
9 ?6 g* Z+ f- t, n) n X/ U3 K
一般线性规划问题的(数学)标准型为 1 {4 M" Q: V* z0 ~3 d
0 e0 F, @* Z! Q+ T
! u) x: o' I0 \( m, n
. I" V& f) ?: Z2 G( A9 |6 l线性规划的实例
' p J: U6 N6 h( I- _" T4 A- ]![]()
2 f) C0 ~( S2 B/ C/ x' h9 r l0 t: J! } B' P
; s- b. P/ v: N0 [2.线性规划问题的解的概念 :可行解、可行域、图解法: }, p' T. C3 ]; c: n( q9 j0 x
可行解 满足约束条件(4)的解 称为线性规划问题的可行解, 而使目标函数(3)达到最大值的可行解叫最优解。3 g2 h0 s& x7 n, t, S) g1 z& p2 a
. w* _) q* F8 ^! f# e! J* b# p可行域 所有可行解构成的集合称为问题的可行域,记为R 。! E- n }, O- t* z4 O P9 y+ f
# M* ?6 v# o& U
图解法 简单直观,适用于二维决策变量,它有助于了解线性规划问题求解的基本原理。。对于每一固定的值z,使目标函数值等于z的点构成的直线称为目标函数等位线,当z变动时,我们得到一族平行直线。
3 ]5 g' N$ Y0 G+ E$ H. _2 P4 Y/ d, X
, v. T2 x u3 x5 ^' [ ( Y5 E/ a( q, l# o) ~
* y/ N: n0 f# t
2.1. 推广到多维空间的线性规划:超平面、多胞形、多面体; j. v" ~( R& H: A( E
以下结论可以推广到一般的线性规划问题,区别只在于空间的维数:
, a9 ~, F; @2 L# V
& q- w" i1 c1 A0 I7 s' R% `6 ?(1)可行域R 可能会出现多种情况。R 可能是空集也可能是非空集合,当R 非空 时,它必定是若干个半平面的交集(除非遇到空间维数的退化) 。R 既可能是有界区域, 也可能是无界区域。( q d& Z) A. W) |" X! }
# x: r9 B% Q8 N# @: w' _7 L(2)在R 非空时,线性规划既可以存在有限最优解,也可以不存在有限最优解(其 目标函数值无界)。
, n" T5 }' R" \8 i7 z
1 m9 V" Z! _8 P3 F; }(3)若线性规划存在有限最优解,则必可找到具有最优目标函数值的可行域R 的 “顶点” 。
) ?, e( m8 J; z7 Q( C
& `/ Y9 O7 ]6 w在一般的n维 空间中,满足线性等式 的点集被称为一个超平面;% z' @3 o2 {' Y0 C( |
d2 b; O: N4 m1 a0 x" i3 e6 U1 h 或的点集被称为一个半空间,其中为一个n维行向量,b为一个实数。# j. S9 Y# @! q6 y$ V
4 L3 _. L# W% g! I: W若干个半空间的交集被称为多胞形,有界的多胞形又被称为多面体。易见,线性规划的可行域必为多胞形(为统一起见,空集Φ也被视为多胞形)。 在一般n维空间中,要直接得出多胞形“顶点”概念还有一些困难。二维空间中的顶点可以看成为边界直线的交点,但这一几何概念的推广在一般n维空间中的几何意义并不十分直观。为此,我们将采用另一途径来定义它。 - b8 Q. w( V9 n- v
: {6 j) b+ Y+ e' o; H 9 n4 W4 a9 B+ y! L5 K+ H
4 F9 c0 U3 [4 [% O5 E" d
单纯形法是求解线性规划问题的最常用、最有效的算法之一 ,此处不作介绍。这里我们就不介绍 单纯形法,有兴趣的读者可以参看其它线性规划书籍。下面我们介绍线性规划的 Matlab 解法。
$ k" Y0 ?& y* X( B9 q# a% n* _( z- L( E4 V
3.求解线性规划的 Matlab 解法
! X* F- g3 n7 Q/ j- `3 h9 h; ^Matlab 中规定线性规划的标准形式为
( d; ^+ `$ @; E. K7 j, u2 b! k* b& P# d' f
) t. r8 a2 l, F( W/ v" f$ }
3 K" r3 y$ U+ k1 v; o其中c和 x为n 维列向量, A、 Aeq 为适当维数的矩阵,b 、beq为适当维数的列向量。 (Aeq 对应约束条件中等式约束的系数矩阵,A为约不等式约束的系数矩阵)。6 e4 `. B7 F* ]8 S/ H7 {
. ^/ |* l2 K4 q: G/ _![]()
/ F3 ?7 V# [- S0 H0 G! }% s1 q5 M. N* Y
基本函数形式为 linprog(c,A,b),它的返回值是向量 x的值。还有其它的一些函数调用形 式(在 Matlab 指令窗运行 help linprog 可以看到所有的函数调用形式),如:
* i% R' ]( F9 P. O) P# b S) R" [0 j$ k2 G r7 e
[x,fval]=linprog(c,A,b,Aeq,beq,LB,UB,X0,OPTIONS) 1 }" {! H( X- D; q( a
5 s4 Y& B3 P& ]3 a' A _" G
这里 fval 返回目标函数的值,LB 和 UB 分别是变量 x的下界和上界, 0 x 是x的初始值, OPTIONS 是控制参数。 例题例如求解下列线性规划问题 ![]()
解 (i)编写 M 文件
. x) C C9 m0 T( R; b' e: h: r3 j0 Bc=[2;3;-5]; 4 u1 A1 l- a5 z
a=[-2,5,-1;1,3,1];
9 ~3 ^! C8 |" E8 x5 v: S0 Cb=[-10;12]; ! P6 ~& V p/ \9 j
aeq=[1,1,1]; ; i6 N/ @# b" e, C0 {, c$ W
beq=7;
) @. q5 z6 `% V1 s ? [x=linprog(-c,a,b,aeq,beq,zeros(3,1)) ) N0 y; u( Y) ^: E) \5 n
value=c'*x
5 L, H" K8 A% M- Y+ o: q5 l f5 e* }# u
1 z+ R8 D4 ~+ R( L9 I5 c# W
(ii)将M文件存盘,并命名为example1.m。 (iii)在Matlab指令窗运行example1即可得所求结果。 例3 求解线性规划问题 ![]()
解 编写Matlab程序如下: % X5 `7 q, a' G+ M8 |0 B
c=[2;3;1];
$ I! Q1 b+ b4 Wa=[1,4,2;3,2,0]; 0 G% C- G5 `) a4 \9 A
b=[8;6]; . Q& F1 F0 R: A4 H
[x,y]=linprog(c,-a,-b,[],[],zeros(3,1))
0 @. i. X2 l d+ e$ v |
9 s- ?7 H' b4 m7 j6 m& m. U, z' g, W! x- D
- n; P) F* w. B, Z6 x9 q" E7 D# N————————————————
7 R" g& u L5 W* L版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。, F R# `) c7 {' b# B, }2 X
原文链接:https://blog.csdn.net/qq_29831163/article/details/888932347 t2 i. M+ p1 H- Q' a" M
0 W5 [; k2 |, W r
, T2 A$ |% E h! `9 \: l2 q |