数学建模社区-数学中国

标题: 【数学建模】线性规划 [打印本页]

作者: 佛自业障    时间: 2018-10-30 10:06
标题: 【数学建模】线性规划

1.线性规划简介

线性规划(LP)是数学规划的一个分支。


& @, }% N! ]1 X5 d. E5 _- g) V1 U  H
x1,x2为决策变量,约束条件记为s.t.(subject to)。8 ~: b& H. M1 |  G

2.线性规划的matlab标准形式

线性规划的目标函数可以求最大值也可以求最小值,约束条件的不等号可以是小于号也可以是大于号,因此在matlab中给出了统一形式

: k+ W5 D, z+ D7 h9 `0 j3 _

  `, u5 a+ d: p其中c和x均为n维列向量,A、Aeq为适当维数(列数与x维数相同,行数与约束条件数相同),b、beq为适当维数的列向量(维数与约束条件数相同)。! [5 m: K6 {6 N% V$ W

; d7 s7 K: |3 E& l$ r9 U0 e6 V3 j6 n例如:
5 B$ w/ h" ]/ Y% a  u2 ]' r5 gmax  cTx  s.t.   Ax≥b max  cTx  s.t.   Ax≥b
2 e' g3 u3 E8 gmatlab中为:
, y  j: \, ~* E+ Wmin  −cTx  s.t.   −Ax≤b min  −cTx  s.t.   −Ax≤b 3 u7 v- A8 D( Q' o6 L& K
3.线性规划中解的概念
4 t- F) b' A! Z& u$ Y3 C6 g6 n$ Z' s9 \& V! O3 J& e2 ?
可行解:满足约束条件的 解x = (x1,x2…xn),称为线性规划问题的可行解,从而使目标函数达到最大值或者最小值的可行解称为最优解。
5 k! _" _0 A7 J) [+ s* T可行域:所有可行解构成的集合称为问题的可行域,记为R。
( |& F# H5 C4 Q/ D$ d2 J  f9 b( K$ K8 h" F) {2 i
4.一般的线性规划问题6 |3 v4 N7 x. Z8 i

5 d& ]# a6 r+ h0 ~3 h在一般的n维空间中,满足 ∑ni=1aixi = b∑i=1naixi = b 的点集称为一个超平面,而满足 ∑ni=1aixi ≥ b∑i=1naixi ≥ b (或者∑ni=1aixi ≤ b∑i=1naixi ≤ b )的点集称为一个半平面,若干个半平面的交集称为多胞形,有界的多胞形称为多面体。因此线性规划的可行域必定为多胞形(空集也视为多胞形)。若该区域R为凸集,则凸集中的任意两点的连线必然在该凸集中,若x为区域R的极点,则x不能位于R中的任意两点的连线上。
- o  Z+ f- T8 Y8 Z; ~7 x- D% o
. o8 O9 W7 O0 Y/ I" ]3 E( U7 f5.matlab中线性规划求解过程& z: B/ M: N7 |! O" Z

' p/ W2 {/ T1 z; p9 D① 利用linprog函数返回最小值解向量。 # E) a5 n- Y, D( s- c, j/ `
② value = c’ * x求最小值。! ]+ ]6 A  ?( {9 u( {  c
9 {2 C. D& }0 I0 I5 i: d! y6 T
基本函数形式是 linprog(c,A,b) , c用于确定等值线(列向量),返回值为向量x。 " `5 ~: j3 l# ~: X
其他的函数形式: % f- V/ _8 T9 [1 l+ X# o3 ?
[x,fval]=linprog(c,A,b,Aeq,beq,LB,UB,x0,OPTIONS) 1 i) c+ F) B$ ^5 r/ r  d
x0为向量x的初始值,一般使用zeros()函数 初始化,LB和UB分别是向量x的下界向量和上界向量。返回值为fval(目标函数c’ * x的值)。5 U" R* C6 V0 ]* L9 [

5 R( W5 k) y4 h) O8 F6 E0 L: }6.常见技巧+ ~( U% K2 Y( ]- G6 a3 m

+ Z+ h# K2 Y* `9 U问题为:
  \5 S* E* m' c& b' z% E( K: @, ]' c$ S
min|x1|+|x2|+…+|xn|  s.t.  Ax≤b min|x1|+|x2|+…+|xn|  s.t.  Ax≤b  ) K) {& n4 E( n, z
事实上,对于任意的xixi,存在ui,viui,vi满足: . c. w" o  B5 @9 n$ f7 D
xi=ui−vi  ,  |xi|=ui+vixi=ui−vi  ,  |xi|=ui+vi 4 K) J6 X( S, c# Q+ l- B
令 ui=(xi+|xi|2),vi=(|xi|−xi2)ui=(xi+|xi|2),vi=(|xi|−xi2)即可满足。
- G2 u! r- O# o/ U  P/ n$ J& m* }6 P4 L/ s: {$ Y8 ~+ }
转换为: & X4 F: r* U0 }3 j* \/ R7 b! p
min  ∑ni=1(ui+vi)min  ∑i=1n(ui+vi) 4 H/ ~$ h# h2 E- H' e
s.t.{A(ui−vi)≤b,u,v≥0,s.t.{A(ui−vi)≤b,u,v≥0,
' @# S, e; V$ B/ H' r, K+ G7.运输问题(产销平衡)
7 a# C' v+ T2 t' a* z/ w: `9 ]- U6 k( F; `- e" ?# r% b
& G: q* K1 J+ I- T" E# w5 A0 _

8.指派问题

1.数学模型
: d* B7 `7 p6 l! X7 h9 C

, I& |1 L; N, H0 j

: e" N# N# r/ @! Z$ N2.利用匈牙利算法   A% |2 q9 H. }9 ~! i2 D( N2 R0 U
算法主要思想:如果系数矩阵中C=(cijcij)一行(或一列)中每一个元素都加上或减去同一个数,得到新矩阵B,则以B或C为系数矩阵的指派问题具有相同的最优指派。 1 w( A6 i! [' @3 I
最优指派的结果是一个2行n列的行列式,第一行为第i人,第二行为被指派的地点。 4 V- s# @4 ]' V
求解中心:变换出n个不同行不同列的零元素。
' X* A  v, c# @, W" k3 I; m$ W8 P9 B. P$ h$ a

" K% q/ z* Z6 H! D# {7 V
% Y5 Y8 L, ?! r6 _7 x) T- g




欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5