- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章用Python制作在地图上模拟瘟疫扩散的Gif图由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
受杰森的《Almost Looks Like Work》启发,我来展示一些病毒传播模型。需要注意的是这个模型并不反映现实情况,因此不要误以为是西非可怕的传染病。相反,它更应该被看做是某种虚构的僵尸爆发现象。那么,让我们进入主题.
这就是SIR模型,其中字母S、I和R反映的是在僵尸疫情中,个体可能处于的不同状态.
上面的模型没有考虑S/I/R的空间分布,下面来修正一下! 。
一种方法是把瑞典和北欧国家分割成网格,每个单元可以感染邻近单元,描述如下:
其中对于单元,和是它周围的四个单元。(不要因为对角单元而脑疲劳,我们需要我们的大脑不被吃掉).
初始化一些东东。 。
1
2
3
4
5
6
7
8
9
10
|
import
numpy as np
import
math
import
matplotlib.pyplot as plt
%
matplotlib inline
from
matplotlib
import
rcParams
import
matplotlib.image as mpimg
rcParams[
'font.family'
]
=
'serif'
rcParams[
'font.size'
]
=
16
rcParams[
'figure.figsize'
]
=
12
,
8
from
PIL
import
Image
|
适当的beta和gamma值就能够摧毁大半江山 。
1
2
|
beta
=
0.010
gamma
=
1
|
还记得导数的定义么?当导数已知,假设Δt很小的情况下,经过重新整理,它可以用来近似预测函数的下一个取值,我们已经声明过u′(t).
初始化一些东东。 。
1
2
3
4
5
6
7
8
9
10
|
import
numpy as np
import
math
import
matplotlib.pyplot as plt
%
matplotlib inline
from
matplotlib
import
rcParams
import
matplotlib.image as mpimg
rcParams[
'font.family'
]
=
'serif'
rcParams[
'font.size'
]
=
16
rcParams[
'figure.figsize'
]
=
12
,
8
from
PIL
import
Image
|
适当的beta和gamma值就能够摧毁大半江山 。
1
2
|
beta
=
0.010
gamma
=
1
|
还记得导数的定义么?当导数已知,假设Δt很小的情况下,经过重新整理,它可以用来近似预测函数的下一个取值,我们已经声明过u′(t).
这种方法叫做欧拉法,代码如下: 。
1
2
|
def
euler_step(u, f, dt):
return
u
+
dt
*
f(u)
|
我们需要函数f(u)。友好的numpy提供了简洁的数组操作。我可能会在另一篇文章中回顾它,因为它们太强大了,需要更多的解释,但现在这样就能达到效果:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
def
f(u):
S
=
u[
0
]
I
=
u[
1
]
R
=
u[
2
]
new
=
np.array([
-
beta
*
(S[
1
:
-
1
,
1
:
-
1
]
*
I[
1
:
-
1
,
1
:
-
1
]
+
S[
0
:
-
2
,
1
:
-
1
]
*
I[
0
:
-
2
,
1
:
-
1
]
+
S[
2
:,
1
:
-
1
]
*
I[
2
:,
1
:
-
1
]
+
S[
1
:
-
1
,
0
:
-
2
]
*
I[
1
:
-
1
,
0
:
-
2
]
+
S[
1
:
-
1
,
2
:]
*
I[
1
:
-
1
,
2
:]),
beta
*
(S[
1
:
-
1
,
1
:
-
1
]
*
I[
1
:
-
1
,
1
:
-
1
]
+
S[
0
:
-
2
,
1
:
-
1
]
*
I[
0
:
-
2
,
1
:
-
1
]
+
S[
2
:,
1
:
-
1
]
*
I[
2
:,
1
:
-
1
]
+
S[
1
:
-
1
,
0
:
-
2
]
*
I[
1
:
-
1
,
0
:
-
2
]
+
S[
1
:
-
1
,
2
:]
*
I[
1
:
-
1
,
2
:])
-
gamma
*
I[
1
:
-
1
,
1
:
-
1
],
gamma
*
I[
1
:
-
1
,
1
:
-
1
]
])
padding
=
np.zeros_like(u)
padding[:,
1
:
-
1
,
1
:
-
1
]
=
new
padding[
0
][padding[
0
] <
0
]
=
0
padding[
0
][padding[
0
] >
255
]
=
255
padding[
1
][padding[
1
] <
0
]
=
0
padding[
1
][padding[
1
] >
255
]
=
255
padding[
2
][padding[
2
] <
0
]
=
0
padding[
2
][padding[
2
] >
255
]
=
255
return
padding
|
。
导入北欧国家的人口密度图并进行下采样,以便较快地得到结果 。
1
2
3
4
5
6
|
from
PIL
import
Image
img
=
Image.
open
(
'popdens2.png'
)
img
=
img.resize((img.size[
0
]
/
2
,img.size[
1
]
/
2
))
img
=
255
-
np.asarray(img)
imgplot
=
plt.imshow(img)
imgplot.set_interpolation(
'nearest'
)
|
北欧国家的人口密度图(未包含丹麦) 。
S矩阵,也就是易感个体,应该近似于人口密度。感染者初始值是0,我们把斯德哥尔摩作为第一感染源。 。
1
2
3
|
S_0
=
img[:,:,
1
]
I_0
=
np.zeros_like(S_0)
I_0[
309
,
170
]
=
1
# patient zero
|
因为还没人死亡,所以把矩阵也置为0. 。
1
|
R_0
=
np.zeros_like(S_0)
|
接着初始化模拟时长等。 。
1
2
3
4
5
6
7
8
9
10
|
T
=
900
# final time
dt
=
1
# time increment
N
=
int
(T
/
dt)
+
1
# number of time-steps
t
=
np.linspace(
0.0
, T, N)
# time discretization
# initialize the array containing the solution for each time-step
u
=
np.empty((N,
3
, S_0.shape[
0
], S_0.shape[
1
]))
u[
0
][
0
]
=
S_0
u[
0
][
1
]
=
I_0
u[
0
][
2
]
=
R_0
|
我们需要自定义一个颜色表,这样才能将感染矩阵显示在地图上。 。
1
2
3
4
5
|
import
matplotlib.cm as cm
theCM
=
cm.get_cmap(
"Reds"
)
theCM._init()
alphas
=
np.
abs
(np.linspace(
0
,
1
, theCM.N))
theCM._lut[:
-
3
,
-
1
]
=
alphas
|
下面坐下来欣赏吧… 。
1
2
|
for
n
in
range
(N
-
1
):
u[n
+
1
]
=
euler_step(u[n], f, dt)
|
。
让我们再做一下图像渲染,把它做成gif,每个人都喜欢gifs! 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
from
images2gif
import
writeGif
keyFrames
=
[]
frames
=
60.0
for
i
in
range
(
0
, N
-
1
,
int
(N
/
frames)):
imgplot
=
plt.imshow(img, vmin
=
0
, vmax
=
255
)
imgplot.set_interpolation(
"nearest"
)
imgplot
=
plt.imshow(u[i][
1
], vmin
=
0
, cmap
=
theCM)
imgplot.set_interpolation(
"nearest"
)
filename
=
"outbreak"
+
str
(i)
+
".png"
plt.savefig(filename)
keyFrames.append(filename)
images
=
[Image.
open
(fn)
for
fn
in
keyFrames]
gifFilename
=
"outbreak.gif"
writeGif(gifFilename, images, duration
=
0.3
)
plt.clf()
|
最后此篇关于用Python制作在地图上模拟瘟疫扩散的Gif图的文章就讲到这里了,如果你想了解更多关于用Python制作在地图上模拟瘟疫扩散的Gif图的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
有谁知道是否可以将多个 gif 或动画 gif 加入到一个动画 gif 中(即,将这些帧连接到一个主动画 gif 中)? 我想要一些服务器端功能来执行此操作。 文件的尺寸、模式等将相同,只是内容不同。
提前道歉,但这不是一个真正的photoshop问题。相反,我试图想出一些令人信服的东西,但尽可能地利用 gif 格式的压缩和特性来为动画生成尽可能小的文件。 一些限制: 它需要至少 20 或 30 帧
如何创建播放一次并在最后一帧卡住的 GIF 图像。 我已经将循环属性设置为 1,所以第一个问题解决了。 但是动画结束后,gif并不是在最后一帧卡住,而是回到第一帧。 最佳答案 您需要将 gif 的循环
我有两个不同大小的 GIF。我希望能够将一个动画 GIF 放在特定位置的静态背景 GIF 上,同时将文本添加到结果中。我是 ImageMagick 世界的新手,请帮忙。 我试图实现以下结果,其中狗贴纸
你好 stackoverflow 世界。(这是我第一次在这里真正发布问题。令人兴奋) 不久前,我从我公司的一个团队那里继承了一个已有 2 年历史的 MVC 网站。我现在知道这个解决方案的大部分来龙去脉
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 1 年前。
我想将我的处理草图之一导出为 gif 形式,并使用 extrapixel 的 Gif 动画库 ( http://extrapixel.github.io/gif-animation/ ) 来执行此操作
我正在寻找一个可以处理动画 gif 图像并在其上写入文本的函数。 工作解决方案可能由 Gif4j lib 提供,但我正在寻找开源解决方案或建议如何自行实现它。 如何在 Java 中将文本放在 gif
这个问题在这里已经有了答案: Change File Extension Using C# (6 个答案) 关闭 8 年前。 此代码将重命名所有文件名: static private void Re
我会保持简短; 有什么方法可以区分静态 GIF 图像和动画图像吗?我正在使用 C#。 谢谢 最佳答案 Here's an article about how to determine the numb
我试图在视频上重叠动画 gif,但没有成功。 我的目标是下一个: gif 动画必须循环播放,直到视频结束。 gif 被缩放以覆盖整个视频。 gif 保留透明度。 我在这方面取得的最大成就是 gif 使
在您的网站上放置网站图标时,您显然可以使用动画 gif,只需将 gif 文件的扩展名更改为 .ico . http://www.k-director.com/blog/how-to-add-an-an
所以我试图为一个充满 gif 的文件夹添加水印,但我收到一条错误消息,说我当时只能使用一个 GIF 流,有没有办法绕过这个问题? @echo off setlocal for %%G in ("%~d
我有大约 200 张 jpg 图像。我需要堆叠它们,以便我可以将它们转换为简单的动画 gif 图像。是否有任何免费工具可以完成这项工作?我的操作系统是windows。 我不太关心输出的质量。 最佳答案
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 8 年前。 Improve th
我想使用库显示 GIF WPF Animated GIF 。但是,当设置属性 PictureSource 时,进程内存会从 208MB 增加到 1GB。为什么? XAML
几天后我有话要说。我必须引用细胞原子。我想在显示元胞自动机进化的幻灯片中显示一个小 gif,所以我的问题是:如何将使用 golly game of life 创建的模式和进化转换为动画 gif? 最佳
看这段代码: $('#loader').show(); $.post( '/action.php', function( data ) { // do anything with data $('#
作为项目的一部分,我们需要以编程方式将多个动画 GIF 以网格的形式组合成一个主动画 GIF(一个 gif 文件)。 我们不关心它是在客户端(即带有 ios/android 的智能手机)还是在服务器端
我正在制作一个小游戏。这不是 Action 游戏,而是解谜游戏,因此性能并不是那么重要。现在,我有了主游戏区,一张背景图片。在某些情况下,我想在部分背景图像上绘制其他图像。我的问题是背景图片和叠加的图
我是一名优秀的程序员,十分优秀!