QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2015|回复: 0
打印 上一主题 下一主题

numpy 实现Lesile 模型

[复制链接]
字体大小: 正常 放大

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-17 16:43 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
Leslie 模型是一种经典的人口增长模型,用于描述一个有性别、有年龄结构的人口在不同年龄段的增长和变化。它是由生态学家 Patrick H. Leslie 在 1945 年提出的,被广泛应用于人口生态学和种群生态学领域。9 J) _( x7 v' c5 g6 R% [' ]- J
Leslie 模型通常假设以下几点:
! P5 J9 v) \& y7 K7 {0 S
# M( K# J* Q! I/ g  {0 q! d+ ~1.人口结构: 人口被划分为不同的年龄组或年龄段。
* b8 X2 D1 |% n% F) d: u3 m2.增长率: 每个年龄段的人口增长率可以不同。
; R7 _! U" w* O% d8 u# u3.繁殖率: 不同年龄段的个体具有不同的繁殖率。
: M" t) i$ z1 Z4 I4 a$ N5 u4.死亡率: 不同年龄段的个体具有不同的死亡率。
! s7 D' E) `: T* f% J' eLeslie 模型的主要应用包括人口预测、资源管理、生态系统稳定性分析等。通过调整繁殖率和存活率等参数,可以模拟不同情景下人口的增长和变化趋势,为人口政策和资源规划提供科学依据。' N$ r- N( L7 N6 v% A
8 Y- F# t2 T; [( M
接线来我们来实现Leslie模型+ `4 v5 z9 k0 i" E
1.定义数据:
( B) u* V6 {- M; @7 s' D* v4 |4 K; m$ P. x# t2 ~  s0 r; K- Q9 l
   alpha = np.array([0, 4, 3])
: b/ y7 y* b; J  y* C3 \- I   beta = np.array([.5, .25])
+ ~1 V( \6 d5 m# b2 p7 N. S
; S3 r: K" d, H" f9 F   L = np.zeros((len(alpha), len(alpha)))9 X* N* b3 k9 {' b7 u7 a
   L[0, :] = alpha6 U5 a! m( L6 d- M% F- \2 B
   for index, each in enumerate(beta):
/ {  D2 ]8 h. S9 r4 T% ]       L[index+1, index] = each7 G9 g. G1 y% J2 I( K( a
$ n2 I! N9 w6 h0 N0 f" ^
   x0 = np.array([1000, 1000, 1000])
+ u9 t: S- n) s: ?0 f! z3 G3 d
5 X+ n) ^2 E3 [7 n( d1 Z- N# @/ p) w, q  Q6 `  ~
2.定义了初始条件 alpha、beta 和初始状态向量 x0。
0 l0 z# G2 D! |( @+ O7 m3.创建了一个转移矩阵 L,其中第一行为 alpha,其余为 beta。
7 D! `$ _0 {% l, s9 X! A( x: r7 Q& `: [8 ^9 a( Q2 J
) W. t, c" P, v8 K! J1 G' m
4.迭代求解:
& L( A; B; v  ~+ h) y6 |3 v% x# \- A: \; u* ~6 p3 n
   x_list = [x0]
: c2 o6 y1 z7 i% X- B3 Z   for i in range(5):9 E7 X6 }% G6 D  t
       x_list.append(L.dot(x_list[-1].T))
. `. q: C4 m9 d: G
3 j& \2 y  V) T- T2 v$ P' q6 c% u0 Y
" E8 f! z2 E& k5.使用迭代方法计算了未来 5 年的状态,并将结果存储在 x_list 中。
+ o7 i' J5 P1 ]) ]
. `1 z/ |# I! |8 l1 {
6 W1 W8 ^+ k* j7 g. B7 Y6.打印结果:& B; T. `& @( j
. ?+ H4 p4 o+ ~" u1 W
   for index, x in enumerate(x_list):
- m* Q0 s3 b% p- e& U& P       print('the {}th year: 1y: {}, 2y: {}, 3y: {}'.format(
% i* a+ W$ X; q4 C: \           index, x[0], x[1], x[2]))
; R8 X; N3 }, K+ P, @9 }  E  u$ t5 z, D
! H' ~3 V. n6 d, n1 ?8 {
7.打印了每一年的状态向量。
/ I! m8 N: [* P: ]
! i, r; k, m9 W! f2 g4 ^
  a, @) m7 q: S3 i8.绘制图形:+ T2 X0 J' }9 m1 n% r

1 s5 J6 P$ {8 w   year_list = np.array(range(len(x_list)))
2 `) c. b2 f6 s1 ~   y1,y2,y3 = [],[],[]. i$ Y! x# Y& ?7 Q% @2 ^- m
   for year in year_list:9 F* n1 R2 M5 \3 ]  B$ H0 y7 ]  M) K
       y1.append(x_list[year][0])
0 Z6 F2 W$ _3 A6 N1 H  z2 l! ~5 n       y2.append(x_list[year][1])
; J( Q7 U: t6 w0 M, N       y3.append(x_list[year][2])
5 @% P. F! }3 h  I- K
0 ?1 e" r; l# \3 k6 d, [- Y  ~   w = .39 ?2 r- b& h/ |2 \9 a1 ?
   plt.bar(year_list-w,y1, width=w, label='1y')5 v6 e1 f  d9 }7 f1 u* N
   plt.bar(year_list,y2, width=w, label='2y')% q% u! [. r4 h" q2 v+ ?
   plt.bar(year_list+w,y3, width=w, label='3y')
1 e3 g- B. M! z- c, I. [" b( X- @% I   plt.legend()6 m7 j' {7 ^" k" \2 R

& H/ B3 U$ E  Z$ o) C& e5 T$ H: R2 Y4 ?+ e! c  G3 |1 s
9.使用 Matplotlib 绘制了每一年不同状态的柱状图,并添加了图例。
- ]2 K2 j! Q; F$ Z! _- o6 Y$ _$ |* l* A5 @1 B, }5 C
这段代码的主要目的是模拟了基于给定的转移矩阵和初始状态的系统状态随时间的演变,并通过图形化展示了模拟结果。8 [7 F6 Z% b# y+ |  p
4 @! e! R. k' }$ e. u' g

  _" |! T  l6 ?/ Q* O8 J
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-4-13 16:29 , Processed in 0.423084 second(s), 51 queries .

回顶部