数学建模社区-数学中国

标题: 动态规划 [打印本页]

作者: 浅夏110    时间: 2020-5-28 15:00
标题: 动态规划
1.1 动态规划的发展及研究内容0 m. L3 t8 R! X4 H) I( X
动态规划(dynamic programming)是运筹学的一个分支,是求解决策过程(decision process)最优化的数学方法。20 世纪 50 年代初 R. E. Bellman 等人在研究多阶段决策过 程(multistep decision process)的优化问题时,提出了著名的最优性原理(principle of optimality),把多阶段过程转化为一系列单阶段问题,逐个求解,创立了解决这类过程 优化问题的新方法—动态规划。1957 年出版了他的名著《Dynamic Programming》,这 是该领域的第一本著作。 动态规划问世以来,在经济管理、生产调度、工程技术和最优控制等方面得到了广 泛的应用。例如最短路线、库存管理、资源分配、设备更新、排序、装载等问题,用动态规划方法比用其它方法求解更为方便。 虽然动态规划主要用于求解以时间划分阶段的动态过程的优化问题,但是一些与时间无关的静态规划(如线性规划、非线性规划),只要人为地引进时间因素,把它视为多阶段决策过程,也可以用动态规划方法方便地求解。 应指出,动态规划是求解某类问题的一种方法,是考察问题的一种途径,而不是一种特殊算法(如线性规划是一种算法)。因而,它不象线性规划那样有一个标准的数学表达式和明确定义的一组规则,而必须对具体问题进行具体分析处理。因此,在学习 时,除了要对基本概念和方法正确理解外,应以丰富的想象力去建立模型,用创造性的 技巧去求解。4 ~2 t, r# I0 o( `" F

$ q# ?. H  t' j9 a% p0 L! O例 1 最短路线问题
2 ^5 ^( G3 e; q0 d) |. p9 n图 1 是一个线路网,连线上的数字表示两点之间的距离(或费用)。试寻求一条由 A 到G 距离最短(或费用最省)的路线。' c3 Z% Z  l( F, F

0 k& u0 \: A4 a+ P6 v4 z& j) z% a4 e6 ~5 }  o- w# e  p, ]

$ I' j+ B5 J; ]: X例 2 生产计划问题
- I3 O- w" ~9 ]! v; W0 m工厂生产某种产品,每单位(千件)的成本为 1(千元),每次开工的固定成本为 3 (千元),工厂每季度的最大生产能力为 6(千件)。经调查,市场对该产品的需求量第 一、二、三、四季度分别为 2,3,2,4(千件)。如果工厂在第一、二季度将全年的需 求都生产出来,自然可以降低成本(少付固定成本费),但是对于第三、四季度才能上 市的产品需付存储费,每季每千件的存储费为 0.5(千元)。还规定年初和年末这种产品 均无库存。试制定一个生产计划,即安排每个季度的产量,使一年的总费用(生产成本 和存储费)最少。3 G" q7 C( c' f' P0 Q/ V; E
9 x& C7 s2 t& s1 |0 o) H& J: N
1.2 决策过程的分类- f  r; M$ u( |1 X
; N4 a, ]* d9 N- Z- m# w5 i: C$ n
根据过程的时间变量是离散的还是连续的,分为离散时间决策过程(discrete-timedecision process)和连续时间决策过程(continuous-time decision process);根据过程的演变是确定的还是随机的,分为确定性决策过程(deterministic decision process)和随机性决策过程(stochastic decision process),其中应用最广的是确定性多阶段决策过程。
' e+ a5 O! `& Q4 Z2 V* Y8 f2 {" h2 C! m. B7 v. i& S5 f& Q
2 基本概念、基本方程和计算方法
8 G2 h; ^- H" X2 f3 L2.1 动态规划的基本概念和基本方程
* e0 G5 b) z% V& n- d一个多阶段决策过程最优化问题的动态规划模型通常包含以下要素。
3 `- K* y4 U4 e% x
/ M5 c2 Z+ ?3 B, W2.1.1 阶段
# x: G# S! f3 _. Q) Q1 }, L. ~阶段(step)是对整个过程的自然划分。通常根据时间顺序或空间顺序特征来划分阶段,以便按阶段的次序解优化问题。阶段变量一般用k = 1,2,...,n 表示。
! v( s1 h$ s2 Y! F2 T* N, O7 d/ W4 d' k1 R/ J( G  g- ]$ N
在例 1 中由 A 出发为 k = 1,由   (i = 1,2)  出发为 k = 2 ,依此下去从   (i = 1,2) 出发为 k = 6 ,共 n = 6个阶段。在例 2 中按照第一、二、三、四季度分为k = 1,2,3,4,共四个阶段。, s2 @: B1 Z$ Q9 [0 _' o1 H

0 s4 K" ^5 T! e/ l. Z# y2 k2.1.2 状态
$ }! h4 i8 v1 g$ z" U  D状态(state)表示每个阶段开始时过程所处的自然状况。它应能描述过程的特征并 且无后效性,即当某阶段的状态变量给定时,这个阶段以后过程的演变与该阶段以前各 阶段的状态无关。通常还要求状态是直接或间接可以观测的。
, _4 p* X5 L3 s, o0 l, p6 c2 f9 s/ Y7 ]. b7 [, o
/ m2 Z+ @! O2 _

3 _; V: \1 g1 O2 ]0 g" ~/ v 根据过程演变的具体情况,状态变量可以是离散的或连续的。为了计算的方便有时 将连续变量离散化;为了分析的方便有时又将离散变量视为连续的。 状态变量简称为状态。
! i0 L2 p0 F. c% A4 [/ z1 l: ^# n  b5 V8 `# g  J
2.1.3 决策* o) c' `3 l; x
当一个阶段的状态确定后,可以作出各种选择从而演变到下一阶段的某个状态,这 种选择手段称为决策(decision),在最优控制问题中也称为控制(control)。. j* o+ @' ]6 n  J' L# K, L

1 R4 O6 H2 p/ N0 h; m3 E8 G! m3 O+ }" w' m1 ^! V

' W+ ^! Q  W! l1 n; ]决策变量简称决策。- v9 F! N* W' h
! x& a1 p; \' ?) K. p6 u8 R
2.1.4 策略; Q" b8 y% b8 i- B5 t' @& W$ G& ]8 j
1 d* N) r2 |3 ~' @. ]
/ C3 l1 m7 ]# @; C! r
1 n2 Y5 @+ N- S! j# T( L. Q
9 r) P4 L! U( ]. |' K1 x
; A/ g6 X$ n( R: [) S, M8 C) Y# K& W
% q: Y: L) F3 t5 e& p
2.1.5. 状态转移方程3 K5 S2 g7 ]4 D4 V3 {
在确定性过程中,一旦某阶段的状态和决策为已知,下阶段的状态便完全确定。用 状态转移方程(equation of state transition)表示这种演变规律,写作
4 `4 D. M; i2 y. X
5 @7 `  p1 c% V1 }" ~$ l. X% c
$ d9 I7 e7 ~; D% K1 d9 S2 k
2.1.6. 指标函数和最优值函数9 b. b5 y' A0 v4 \. E% H+ W

8 r. ?3 M  Y4 b2 h; {+ t1 l5 V' N  P
1 I0 s$ r) @* I: V
  y2 y5 r$ o9 g# K& s2.1.7 最优策略和最优轨线
- j5 _- e: @5 I( r8 y1 _# F- f' R3 |, N
# i$ f5 I" W, Y) i" F
9 n( O4 B- ^2 Y2 i% K
2.1.8 递归方程9 Z( s0 n* \3 {1 M' [5 {2 R
! ]! p  a: L' Q

" _( Q8 n% b3 [& j; b: b) q5 L/ y+ s& u& o+ J! Y: O; m$ e6 V" g
例 3  用 lingo 求解例 1 最短路线问题。! C% ^# X' W) e8 ]9 u

. ?3 h% V+ g; d. L; r8 r$ D# @model:
$ ?' h7 q1 k, CTitle Dynamic Programming;
/ j3 z9 O/ X' m0 x: w- X) n+ ksets:6 e, U' n2 K: A
vertex/A,B1,B2,C1,C2,C3,C4,D1,D2,D3,E1,E2,E3,F1,F2,G/;4 ~( G6 I% l6 [/ W: x
road(vertex,vertex)/A B1,A B2,B1 C1,B1 C2,B1 c3,B2 C2,B2 C3,B2 C4,/ l, c, r5 G2 w: d
C1 D1,C1 D2,C2 D1,C2 D2,C3 D2,C3 D3,C4 D2,C4 D3,' Q- u  {: U1 D/ \/ F* q
D1 E1,D1 E2,D2 E2,D2 E3,D3 E2,D3 E3,
; m2 a* l0 r* [# s8 M0 dE1 F1,E1 F2,E2 F1,E2 F2,E3 F1,E3 F2,F1 G,F2 G/;
( H7 B* s2 b" Z7 ?# V3 |, l* Cendsets8 Z( ~4 n! e1 m/ x% M
data:' \0 }; M9 f& Z! b/ T* y
D=5 3 1 3 6 8 7 6
$ e% t; P% `0 q9 k3 E5 ~6 8 3 5 3 3 8 4
6 Y: V) g1 p' ]7 _) B" d: M2 2 1 2 3 3
0 {6 l7 B( D$ k) I. @3 5 5 2 6 6 4 3;
% T' W; ~0 g. O4 i/ x( d; y. |% CL=0,,,,,,,,,,,,,,,;+ t$ o; a1 C# ~4 J6 \
enddata
- J) {& E4 \. @( g0 S@for(vertex(i)|i#GT#1(i)=@min(road(j,i)(j)+D(j,i)));
0 F5 i+ K. E, g, {. uend 8 i9 ?. C: @9 t  j
, @5 M& Z; ?" }4 A5 v  A
动态规划模型的建模步骤7 l2 f1 u9 e6 w" e
纵上所述,如果一个问题能用动态规划方法求解,那么,我们可以按下列步骤,首先建立起动态规划的数学模型:% K9 q4 T0 P; E6 k3 v# ^
8 H" K; C8 P* F9 z
(i)将过程划分成恰当的阶段。
6 z9 q/ a& M$ t2 t: \0 h* z
8 z. d" d) N, ?2 R( w(ii)正确选择状态变量  ,使它既能描述过程的状态,又满足无后效性,同时确 定允许状态集合  。
8 b4 i% m- i2 Y7 l& f+ O  n. o+ j1 ]9 G5 V# N$ Q7 J" [
(iii)选择决策变量  ,确定允许决策集合  。4 R; i: ]# R  J  J! h

' ?- ?. t3 x' m! I' c(iv)写出状态转移方程。
; S# u/ `/ O$ V& C! G5 I9 ]% H" m% P, S$ Y3 v, i
(v)确定阶段指标  及指标函数  的形式(阶段指标之和,阶段指标之 积,阶段指标之极大或极小等)。) I( \/ g. U0 H; D9 Z+ ~) ~

5 r( Y+ @6 S. |+ I4 i, B0 E3 _9 U) }(vi)写出基本方程即最优值函数满足的递归方程,以及端点条件。
" l6 f. N7 D0 I# K8 p2 [: h' _$ f3 ]- k! K5 q0 O
! t: p: D9 i. I

( p( B4 E& ^; D; m3 I  V- C3 逆序解法的计算框图
9 }* v" |: S8 r- n2 Q/ h以自由终端、固定始端、指标函数取和的形式的逆序解法为例给出计算框图,其它 情况容易在这个基础上修改得到。
/ R1 Y: L- T3 \( N0 l0 E$ l' @. i& v9 b
一般化的自由终端条件为7 \" e; i, C& x( x, V
" D7 P' x6 u  Q4 r9 N/ a# j
7 s1 C( ~1 ^& o: Y: ?. U* n

% X8 ~6 W4 k( s$ o6 R
, ?; U& K0 X- D' g+ \1 c; p3 K, X& i  `" ~
' c( Q. j  f2 f  u  w$ M
3 P6 N' b& H! r7 A7 T& Y% m
§4 动态规划与静态规划的关系
- d4 @; M) p+ p; @动态规划与静态规划(线性和非线性规划等)研究的对象本质上都是在若干约束条 件下的函数极值问题。两种规划在很多情况下原则上可以相互转换。4 Q% s; n* v( Q. v3 F& R  r
: [6 T7 y/ T8 o, `! v! h6 O
          动态规划可以看作求决策 使指标函数  达到最优 (最大或最小)的极值问题,状态转移方程、端点条件以及允许状态集、允许决策集等 是约束条件,原则上可以用非线性规划方法求解。 一些静态规划只要适当引入阶段变量、状态、决策等就可以用动态规划方法求解。 下面用例子说明。
$ s! r) u8 i5 I  H2 c. [
" G* {$ g  [" ?, A' e例 4 用动态规划解下列非线性规划
" b$ ]- Z4 j1 J. `( i
. _% ^* B4 L( q
+ @' S9 j& w' x) }7 I
; e# Z3 f& z" ?: x与静态规划相比,动态规划的优越性在于:' W/ W% Z" X$ d0 F  o, c/ I
* J/ \) c% I7 A5 m8 T
(i)能够得到全局最优解。由于约束条件确定的约束集合往往很复杂,即使指标 函数较简单,用非线性规划方法也很难求出全局最优解。而动态规划方法把全过程化为一系列结构相似的子问题,每个子问题的变量个数大大减少,约束集合也简单得多,易 于得到全局最优解。特别是对于约束集合、状态转移和指标函数不能用分析形式给出的 优化问题,可以对每个子过程用枚举法求解,而约束条件越多,决策的搜索范围越小, 求解也越容易。对于这类问题,动态规划通常是求全局最优解的唯一方法。+ m6 ^- `# a3 J- ^0 n
- b+ [# z. u) U  E
(ii)可以得到一族最优解。与非线性规划只能得到全过程的一个最优解不同,动 态规划得到的是全过程及所有后部子过程的各个状态的一族最优解。有些实际问题需要 这样的解族,即使不需要,它们在分析最优策略和最优值对于状态的稳定性时也是很有 用的。当最优策略由于某些原因不能实现时,这样的解族可以用来寻找次优策略。$ Z( }9 W% i. ~
4 P0 x& h+ E) P" v: v
(iii)能够利用经验提高求解效率。如果实际问题本身就是动态的,由于动态规划 方法反映了过程逐段演变的前后联系和动态特征,在计算中可以利用实际知识和经验提 高求解效率。如在策略迭代法中,实际经验能够帮助选择较好的初始策略,提高收敛速 度。
  a. s- _, p9 L7 S4 t6 f/ Y3 Z; ?$ B. D1 @* i
动态规划的主要缺点是:* q0 O3 K/ Q7 @3 y8 x: `9 k

1 s' m6 F0 E( @6 N- l$ y8 l* m$ Y, S(i)没有统一的标准模型,也没有构造模型的通用方法,甚至还没有判断一个问 题能否构造动态规划模型的准则。这样就只能对每类问题进行具体分析,构造具体的模 型。对于较复杂的问题在选择状态、决策、确定状态转移规律等方面需要丰富的想象力 和灵活的技巧性,这就带来了应用上的局限性。
) \$ l( f$ O: A1 R5 O+ T. z& B
9 s3 K* R3 E1 b$ S(ii)用数值方法求解时存在维数灾(curse of dimensionality)。若一维状态变量有m 个取值,那么对于n 维问题,状态 就有  个值,对于每个状态值都要计算、存储函 数  ,对于n 稍大的实际问题的计算往往是不现实的。目前还没有克服维数灾的 有效的一般方法。
4 e& c4 Y. x4 w. v/ j0 G6 \& I- d+ G* K' N6 }
§5 若干典型问题的动态规划模型1 q: }+ V: T  X5 {/ V7 H
5.1 最短路线问题
) S" e  }  t. A. d1 C0 t* S) r. n& {( W! \5 T& o

4 |! M$ a6 F/ M5 c6 Y; G8 Y4 G' j) o/ g
5.2 生产计划问题
/ q3 v# @+ g) x% N
5 A0 Y& D, B. L: A3 |5 k9 i6 Y% H
* N/ u" L0 L  N9 S3 `( L( R, C5 b' c& y9 U

% J" j8 u8 O: O, F9 D, L6 ]  j9 e* C& B- H. ]

9 Y& q. _3 _; B5 m! _5.3 资源分配问题1 D; H) z" q6 E! ^& t
一种或几种资源(包括资金)分配给若干用户,或投资于几家企业,以获得最大的 效益。资源分配问题(resource allocating Problem)可以是多阶段决策过程,也可以是 静态规划问题,都能构造动态规划模型求解。下面举例说明。* j. Y& f4 F0 I. u: T+ ~  }

- }( y$ Q' s' M8 s2 d; S/ N$ }/ ]: A

9 }3 R. O7 J, ^% s( z
$ T+ Q" T$ `6 \
9 d! {, a9 k' p( E  A, Q3 Y
4 ^3 Q, ~- V5 A
! a2 `2 Q4 S% d/ g7 k————————————————
% z4 k: G* r; k1 l版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
" Q% _$ W3 e* |5 w$ f4 V8 ]( \. F( [原文链接:https://blog.csdn.net/qq_29831163/article/details/896765708 n- k( c/ L2 {# @+ H! L
# U+ z' h% d& u) e0 z. `3 H
3 q; I. k( }, b9 I





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