数学建模社区-数学中国

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

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

1.线性规划简介

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

+ ?, @4 B3 }$ J% W
" e+ Z3 L/ T/ s+ d! k
x1,x2为决策变量,约束条件记为s.t.(subject to)。, |  S7 l, Q+ t

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

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

1 l+ ^1 L9 V; L* D& O. L9 @9 C$ h

6 f& _& f9 c0 Z# @% W其中c和x均为n维列向量,A、Aeq为适当维数(列数与x维数相同,行数与约束条件数相同),b、beq为适当维数的列向量(维数与约束条件数相同)。
0 s- X- }6 y$ Y4 n
  L5 {% S9 t$ w+ Q5 S7 A0 {例如: 3 R! N6 h" O& v6 {6 n& S2 L
max  cTx  s.t.   Ax≥b max  cTx  s.t.   Ax≥b
( f' a' k3 o: `9 @0 d  T$ \matlab中为: ' [+ c% q, k& a! T
min  −cTx  s.t.   −Ax≤b min  −cTx  s.t.   −Ax≤b
, b" P7 G" }" x7 D7 X& u% `3.线性规划中解的概念
: G8 N( m/ f1 }5 L; u# }+ J4 H6 _! h5 |
可行解:满足约束条件的 解x = (x1,x2…xn),称为线性规划问题的可行解,从而使目标函数达到最大值或者最小值的可行解称为最优解。
2 S, d# S7 {5 r. o$ C6 x1 L, A可行域:所有可行解构成的集合称为问题的可行域,记为R。
4 x; c; T! J0 @4 F. Q
  i5 f' Q, T' o( B( n' U8 S- b4.一般的线性规划问题' i) U$ E+ V" Q2 {6 _

% N$ i% O$ o/ Z3 W5 ?6 p在一般的n维空间中,满足 ∑ni=1aixi = b∑i=1naixi = b 的点集称为一个超平面,而满足 ∑ni=1aixi ≥ b∑i=1naixi ≥ b (或者∑ni=1aixi ≤ b∑i=1naixi ≤ b )的点集称为一个半平面,若干个半平面的交集称为多胞形,有界的多胞形称为多面体。因此线性规划的可行域必定为多胞形(空集也视为多胞形)。若该区域R为凸集,则凸集中的任意两点的连线必然在该凸集中,若x为区域R的极点,则x不能位于R中的任意两点的连线上。
! F: X" x( I. D0 h' [' x5 A! s! s4 q3 N
5.matlab中线性规划求解过程
4 T1 ^/ E/ @8 \5 C5 u+ E" n
7 `) ]3 c5 C' @9 N9 j① 利用linprog函数返回最小值解向量。 . C. i0 H6 A- Z3 J( F! {
② value = c’ * x求最小值。
; F9 Y( Q" W6 L* p  q! C8 N. F. d3 u. `" H5 Y8 C
基本函数形式是 linprog(c,A,b) , c用于确定等值线(列向量),返回值为向量x。
+ R: K6 D& ?8 {* F; P( M其他的函数形式:
6 [% |. E2 p# t; v4 d[x,fval]=linprog(c,A,b,Aeq,beq,LB,UB,x0,OPTIONS) . m/ L- [6 w% W, D' a
x0为向量x的初始值,一般使用zeros()函数 初始化,LB和UB分别是向量x的下界向量和上界向量。返回值为fval(目标函数c’ * x的值)。
  C- n& l2 B0 `3 U" X; r2 H. \0 G# V9 j6 x3 u
6.常见技巧
: q  y- x4 ^7 x' n/ f  E0 x
% P0 D9 T4 y, {8 B; j( Z8 m- `问题为:
/ _' E1 D5 J& E  z( U0 f% b* {4 z) Z1 T, F
min|x1|+|x2|+…+|xn|  s.t.  Ax≤b min|x1|+|x2|+…+|xn|  s.t.  Ax≤b  1 D  q; l  y7 F, M! R- p6 l& `
事实上,对于任意的xixi,存在ui,viui,vi满足: % f. r  m+ X: U/ n! d3 A
xi=ui−vi  ,  |xi|=ui+vixi=ui−vi  ,  |xi|=ui+vi
5 W3 w  w' p! E; v7 C0 u4 r9 r! N令 ui=(xi+|xi|2),vi=(|xi|−xi2)ui=(xi+|xi|2),vi=(|xi|−xi2)即可满足。$ s  O9 G3 U  C& n! H$ k2 b, [

4 l' ~# @) Y- Q* K8 ~% k$ e6 E% P9 r转换为:
0 x+ ?! P% V& H( f3 ^min  ∑ni=1(ui+vi)min  ∑i=1n(ui+vi)
5 ]6 t/ ~7 `( Q  Ys.t.{A(ui−vi)≤b,u,v≥0,s.t.{A(ui−vi)≤b,u,v≥0,8 K! s3 S+ G5 D2 H
7.运输问题(产销平衡)  O/ |. q2 W1 @# f

6 f4 ]1 m% J+ Q2 a
6 Z& @( u# {/ {3 ?% R. v

8.指派问题

1.数学模型 / }7 W/ M1 \0 K$ ~; _( |

" I% \, T4 V; P3 Z1 W$ R

+ x. k4 Z, t; R' W: k2.利用匈牙利算法 # t! j9 V* G7 }( k, [
算法主要思想:如果系数矩阵中C=(cijcij)一行(或一列)中每一个元素都加上或减去同一个数,得到新矩阵B,则以B或C为系数矩阵的指派问题具有相同的最优指派。 $ D1 J0 @1 A/ I, G1 D2 Q
最优指派的结果是一个2行n列的行列式,第一行为第i人,第二行为被指派的地点。
  E& F4 M( @0 B, d( o6 Q8 k/ p求解中心:变换出n个不同行不同列的零元素。
4 n) _: H7 d+ H" s' y9 N7 q  S" L8 `0 M# p! C

" }$ f, g/ J. x8 ^
$ ]- u0 f# v* w1 ^& w3 |1 ?5 D. R




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