数学建模社区-数学中国
标题:
数学建模(一)对变化进行建模及其解
[打印本页]
作者:
杨利霞
时间:
2021-7-9 17:04
标题:
数学建模(一)对变化进行建模及其解
4 }6 X3 o' b ~
数学建模(一)对变化进行建模及其解
% m4 l7 k6 \9 C5 U. j0 m! F0 I
1.1用差分方程对变化进行建模
, F- N V5 M( S {6 C: A# k* c
人们常常用数学(使用函数或方程)来描述世界中的某种现象:数学模型,就是对现实世界现象的理想化,但从不是完全精确的表示,任何数学模型都有其局限性,模型没有最好只有最适合,适合的模型可以提供有价值的结论和结果,本次学习内容将主要为:对变化进行建模。
& R, P3 f# V- u' D
数学模型:人们在对对象进行建模时,常常是为了预测未来某个时刻变量的值,例如模型的对象可能是人口、房价、传染病人数等,数学模型常常能帮助人们更好地了解对象地变化趋势以及内在属性,对于未来地分析与应对具有更好地辅助性。
6 {3 O8 E; _6 f7 {. [9 L! R
) L9 p) N6 {/ D# B; \, k3 r
5 N1 S3 o& V) h" `
对变化进行建模:
( Z* @3 n( m& O4 b6 y+ H0 h1 c; C
未来值=现在值+变化;
1 O, E7 q0 n; U! L- `. P% O! o. i1 e
变化=未来值-变化;
8 q' a. U3 S! g7 y
因此我们想要预测未来值就需要先研究变化。通过一段时间中实际问题所产生的数据,将该数据画成图形,通过对图形的研究,我们常常可以识别出能够抓住这种变化趋势的模式。如果这中行为是在离散时间段上发生的,那么就主要采用差分方程的方法进行建模;若该行为是在连续时间上发生的,就可以采用微分方程进行建模。
0 {; G( u- {4 V) S, `
5 B9 A: Y5 a0 x1 |% Q0 j/ a
4 U6 \7 u1 M6 `4 o) E" G& s
1.1用差分方程对变化进行建模
" P. x' j. b" i! K) C- o9 S
在本节中主要通过差分方程方法以了解变化发生的原因和形式,分析不同的条件对行为的影响并且去预测未来值。
" u' I$ Z! a x! ]& x9 i+ K& h
定义:
$ M& }5 E6 m8 _2 K d5 [
4 X% W6 m! k; b. z" S" L
( e$ d) O/ \4 v ~& m2 f
例1:储蓄存款类问题
* b* c) X& r: x( {0 g& l
假设本金为1000元的储蓄存单在月利率1%的条件下进行增值,下面的数值表示在该利率下每月的价值:
/ D( U4 ~- {# }
A={1000,1010,1020.10,1030.30,}其一阶差分为:
% G8 `; P: ~, f5 s/ S
% l3 G5 M( E6 M! d
5 X! z& B# w! V# Y) Z' d- S9 i
注:一阶差分表示在一个时间周期里数列的变化,在该例子中表示的就是所得利息。在对发生在离散时间段上的变化的建模是有很大帮助的,在此例子中,从本月到下一个月变化的仅仅是所得的利息,如果n是月数而an是n个月后存储的总价值,那么每个月价值的变化由第n个分差:
) M$ F! H- d( B' p
4 f; G% P9 N: e
/ @$ R) w, j3 D0 u/ d
这其中an是n个月后利息累计总值,上述方程可以表示为无穷个代数方程,称为动力系统*,动力系统可以描述从一个周期到下一个周期的变化,如果已知该序列中的某一项,就可以通过差分方程算出下一项。
4 ~0 w1 i; b8 m1 k
如果再对该例子进行变化,在上述例子中,如果每月从账户中提取50元,那么一个周期里的变化就应该是该周期里利息减去存款:
2 G F) N1 d3 x- B) v8 M+ | x
( T. n+ @$ b( P |* d9 @! u2 n
( Q) P0 Q! V) [
在大多数例子中,用这种数学方式描述变化不会像这种例子一样准确,常常需要画出变化,观察模式,然后用数学术语来描述变化:变化=Δan=某个函数f;或者是变化=Δan=an+1-an=f;用这种方式进行变化建模,就需要决定或者近似决定表示该变化的函数f。
0 l4 V! I& n- u7 {
举例:抵押贷款
6 j. T7 k$ h# \5 Q! r
小明贷款80000以月利率1%,每月还款880.87元共还20年的方式买了一套房,已经还了72个月,问还欠多少贷款?
5 a# V `* T- v3 p, x5 N
解:分析欠款随着利息而增加而又随着每月还款而减少,所以可以给出下列动力系统模型:
! S U1 [6 Q" K3 a$ c# ?
设b(n)为n个月后的欠款总额。则有;
. t! g: s: S3 k8 I3 o H
b(n+1)=b(n)+0.01b(n)-880.87,b(0)=80000;
/ j6 W9 }* K9 r! y
所以b(1)=80000+0.0180000-880.87=79919.13;
" t u; Y- m4 J' [3 T. w d
所以b(2)=79919.13+0.0179919.13-880.87=79837.45;
. ~' p3 f: J; k8 p9 U# B
从而得到b(72)=71523.11元,所以还了72个月之后还需要还款71523.11元。
7 b3 _# p+ }7 ?2 y# y; I% [ v1 c
总结:
: W* M" c4 A- l2 ?6 Z# A1 q
序列:定义域为全体非负整数集合上的一个函数,其值域为实数的一个子集;
2 E7 S$ |; W$ b. T7 Y9 n/ p1 Z
动力系统:序列各项之间的一种关系;
% \+ y) D2 l% g* M1 P
数值解:满足该动力系统的一张数值表。
& Z. C: L; M" O* }" m. k @
3 f/ s0 C/ ^7 I1 ~
2 U: f7 X8 @+ c/ ~" q
1.2用差分方程近似描述变化
7 e5 T' I2 K% f4 v- s6 W2 K
在我们构建变化模型时,需要区别出这些变化是在离散时间(例如存款利息)上发生的还是在连续时间(物品温度变化)上发生的。
2 e% |7 {/ X; T( k0 n9 Y: }
差分方程:表示在离散时间区间的变化,下面将考察自离散时间区间上的数据近似描述连续变化。
0 w* F* o& ~( G
例题1:酵母菌培养物的增长,下图的数据表示的是在一个受限制的区域内,随时间增长而发生的酵母菌培养的数量变化:
9 Q j( l$ [; x% Q+ N9 b& Q
! ~" w `. n$ p0 S
* }8 l% f+ W7 N
从图中可以发现起初酵母菌的增长方式很快,但到达该容器的极限时,就增长很慢了,所以可以假设该容器内的容量为665,该值并不是一个准确值只是在该值附近,变化几乎不变了。通过分析我们可以用以下数学模型:
* v9 x* v& K' e2 c5 j
△P(n)=P(n+1)-P(n)=k(665-P(n))*P(n):
4 N! \ D* s0 U* [& ~( C
因此我们可以以P(n+1)-P(n)为因变量,以(665-P(n))*P(n)为自变量构成一个线性函数:
* y) a% K8 \5 D" Z9 K7 X, L2 s
" Q( D% P: W+ P. {, ^* }
M, Z8 i' w1 M9 \5 C0 O
可以求出k=0.00082,所以可以得到动力系统方程:P(n+1)-P(n)=0.00082(665-P(n))*P(n),这是二次非线性的模型。
G9 `% N3 q4 m' V6 O) o
4 @5 e( i/ G4 ~
" M0 U% J. K* W4 m
1.3动力系统的解法
, o" E" V4 P! t$ b& k
建立某些动力系统解法,从一个初值开始,并对后面的值迭代充分多次,以确定相关模式,动力系统预测的行为是由该系统的数学结构表征的,有时行为极大的变化只是由于动力系统很小的初值引起的,同时还要考虑很小的比例常数变化会造成极大的预测值的变动。
4 F; H4 d+ p! F" w! q
方法:猜测法:
, v6 v; I. N7 m0 b
步骤:
# ^8 Z! A( n9 ? `* O
1.观察模式:
9 c5 v" a4 K1 g) y! }' `
2.猜测动力系统解的形式:
4 H) p; ~ c6 F: i k2 E& h' D% N6 O
3.用代入法测试该猜测:
5 ~2 ]- P- p: s g, D* m( U1 o' P
4.接收或者拒绝该猜测取决于在代入和代数运算后结果是否满足该动力系统。
y1 I' ~6 y& {5 ]4 x6 }
例如1: 有一款存单,开始存有1000元,然后按每月利率1%给利息,不再存取钱:
$ Y! i2 S8 k' Z s/ `4 B
解;可以给出如下动力方程:b(n+1)=b(n)+0.01b(n),也就是b(n+1)=1.01b(n),从而b(n)=1.01(k)1000;
8 u" A% |4 A8 P; e( J. ]3 R
例如2: 污水处理中,每小时去除掉剩余污水的12%的污水,问多长时间可以把污水量减少一半?
& o' o" i/ G1 S P- Q6 _5 D4 }# P
解:可以给出如下动力方城:b(n+1)=b(n)-0.12b(n)=0.88b(n),所以b(n)=0.88(k)b(0),所以0.5b(0)=0.88(k)b(0);
3 J. a, w3 H$ U1 B2 |: y/ {
所以0.88(k)=0.5,所以用k=ln(0.5)/ln(0.88),所以k=5.42;
6 A8 m" A4 r# ]
总结:
; G! Q; ?. z! S7 ]! O4 q7 e
以上两种例题都是可以写成:**b(n+1)=rb(n)**的形式,对于不同的r将会有不同的变化趋势:
- d. Y* H0 [6 O
同时还有另一种形式:**b(n+1)=rb(n)+b**,其中r和b为常数;
# g, |, w( ]/ L; m+ H L
定义:对于b(0)=d,任意k=a,a+1,有b(k)=c,则称c为在初始情景b(0)=d下的平衡点。
* t( N& ^/ B7 J5 c
**例如3:**当初始存入多少金额时,按照每月1%的利率同时每月取1000元可以使得初始金额不减少。
( r( C# |) C1 C, f
**解:**可以列出如下差分方程:b(n+1)=1.01b(n)-1000;可以算出当b(0)=100000时,金额不会减少。
! s6 T z6 l+ y9 \$ U1 Q
求平衡点并对其进行分类:
5 u; }* {6 Y& R
对于b(n+1)=rb(n)+b,当其存在平衡点时,会存在如下关系:b(n)=rb(n)+b,则有:b(n)=b/(1-r),(r不为1和0,r和b为常数);
2 h* s$ T7 M2 j
定义:对于动力方程:b(n)=r*b(n)+b,其平衡点为:b(n)=b/(1-r),如果r=1而b=0,则每个点都是平衡点,若r=1,b不为0则不存在平衡点。当|r|<1,时有稳定的平衡点,当|r|>1时有不稳定平衡点,当r=1时,没有平衡点,是一条直线。
; R* L/ ~. _+ o' a: v
同时对于上述解我们可以发现结果为:b(n)=r(k)*c+b/(1-r),其中c为初始值,b/(1-r)为平衡值。
5 V# t) y W' Y$ {) P u
**例如4:**对于例3问题中,问初始存多少钱,可以在20年后刚好用完?
6 {; W6 N& c6 c' b) k2 k: m1 i* n; O
解:b(240)=1.01(240)c+100000=0,可以得到c=90819.42.所以如果初始存90819.42,那么在20年后能刚好取完。
) G# L1 y# o/ o; n o! e# ~
1.4差分方程组
! C3 G: B' p( @) G4 g' U
上面一节中,平衡点时因变量的一种取值,一旦达到了平衡点,系统就不会再发生变化,而本节则是先求出平衡点,然后对平衡点附近的起始值进行探究,从一个靠近平衡点的初始值开始,变化并观察其:
- f% s/ g- t0 M" I; ~
1.系统是否仍然靠近该平衡点;
( _, v& a: H! e9 _' N8 {9 X
2.趋近该平衡点;
. J$ C3 d2 b/ v: H+ Y
3.不再靠近平衡点;
) Q4 q. B3 u6 c; F+ N. M6 }% w
从而探究其是否有周期性的行为或者振荡行为;或者动力系统对于初始条件或者比例常数的微小变化敏感吗?
. r/ e& j! e f! t* d% o
例如5:一家汽车租赁公司在A与B设立了两个公司,都可以租还车,从A地开车可以到B地还,也可以从B地开车在A地还,公司需要知道应该在两地各投放多少辆车,可以很好的满足使用。已知每天在A地租的车有60%还到A地,有40%还到B地,而在B地租的车有70%还到了B地,30%还到了A地。
1 u' f, b& e9 L4 L5 w, M9 T
0 J% f- E5 ] R! \5 O" {) @6 s
1 a0 s o. h# Q, T; ~( c- c
若初始投入车辆不是3000和4000,但是总数仍然是7000,则有:
* T! r. U( J2 j
" m% W3 F* a9 c8 a+ v
+ d& P/ F4 C6 U9 ] U
可以发现一周内都是会区域平衡点,说明平衡点时稳定的而且对初始值是不敏感的,所以我们可以较为确定的倾向于总数3/7的车放在A地,总数4/7的车放在B地。
& O3 Z4 F! A# C; i6 k) M" R
例如6:
5 p: A, \ Y1 @ d; Y" J: G( L
竞争猎兽模型: 斑点猫头鹰和隼,这两个种群在没有其他种群存在时,每个都可以单独的无限增长,但是如果将二者放在一个区间内,则二者将会存在竞争关系,其增长率会发生变化,假设这种增长率的减少和两个种群之间的相互之间的关系成正比。
/ M" V# V, a u4 F
6 }+ F! g8 i* |: a0 c
7 E0 b4 T: l9 u
0 m' i3 m) @1 x0 C# p/ s
: R+ A7 O# m7 r5 ?! }7 J0 q
对初始条件的敏感性和长期行为:可以发现当(150,200)时不改变,但是当在该平衡点附近时,都将会有一种将灭绝,也就是该模型对初始条件是及其敏感的。
( E+ Q0 L) K+ F7 x
例如7:
/ O1 T4 N( S7 A
离散流行病模型:
) J G" Q$ R" P$ a$ }) a$ V; j9 h" \
考虑一种流行病毒会在人群中传染,我们把人群分为三种:易感染者、已感染者、移除者,同时考虑一下前提条件:
) {6 R' B- q l G9 J
1.每个人都是易感染者S(都能感染这种流感),已感染者I(当前已经感染这种疾病、并且具有传播性),移除者R(得过这种病毒已经不会再感染的人)
. R8 l# t6 _4 ]( G# x6 a
2.一开始,每个人都是S或者I;
% w- Z% S* }; J, J
3.这种流感的持续时间为(1+2/3)周,在这期间是容易传染的;
/ v) |- W' q2 g3 X% z
4.该模型按照时间周期周记;
, i. V; T2 t5 H2 L% Y
7 k) l! `, m4 V3 m' o; ]& ]5 ]5 u8 T
5 z: K9 X; C+ `0 |% U8 C3 P% j
8 y. c$ P0 @# b" r( b9 O
$ T# R+ q+ a( e6 r
————————————————
$ _. \7 O- Q( p
版权声明:本文为CSDN博主「两个鼻孔的猪」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
1 P8 W* Y( s X' p) r) y2 F8 r6 g
原文链接:https://blog.csdn.net/DOUBLE121PIG/article/details/93375834
9 c& l' Y* |* \* j: W
) I( ~, |; ?6 G7 Q
0 C+ q4 j7 j5 V! V; j# M, X2 N& o" R
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5