疫情肆虐下,程序员用代码告诉你为什么千万不要出门!

这是一个使用 Java 语言编写的肺炎仿真程序,从统计学的角度来说,能够从一定程度上模拟新冠肺炎病毒扩散及被控制的趋势。
现在,作者已经将代码开源到 GitHub 上,笔者特此 download 下来与诸君分享。
在这里插入图片描述
在代码中,我们假定一个城市是一个 600 x 600 的正方型。在这个城市中,每一个人为一个 3*3 大小的圆形的点。在每一个城市中,人口所在位置在统计学上都有相应的规律。在这里,假定城市中有 5000 个人,这 5000 个人以城市中心按照正态分布的方式,随机地分布在城市的各个角落。
在这里插入图片描述
城市中人口正态分布情况
代码如下:
Random random = new Random();
int x = (int) (100 * random.nextGaussian() + city.getCenterX());
int y = (int) (100 * random.nextGaussian() + city.getCenterY());
Person person = new Person(city, x, y);
在新型肺炎期间,根据肺炎的信息,我们可以知道,病毒存在潜伏期,医院会对患者进行收治。本文中我们对每一个人的状态进行简化,分为以下四个状态:

正常 潜伏期 确诊 在医院治疗中

其中三个状态中,人是可以自由活动的,当然,关于人的移动,此处的处理逻辑也是简化为一个正态分布的随机移动。以下代码为人随机移动到的目的地的位置:

// 根据流动意愿计算当前人是否需要流动
public boolean wantMove() {
double value = sig * new Random().nextGaussian() + Constants.u;
return value > 0;
}
// 计算人流动到的目标位置
double targetX = targetSig * new Random().nextGaussian() + targetXU;
double targetY = targetSig * new Random().nextGaussian() + targetYU;
moveTarget = new MoveTarget((int) targetX, (int) targetY);

除了处理分配位置和随机移动,还有一个被感染的函数。当我们在城市中移动的时候,当周围的人存在携带病毒的人,我们就有一定的概率被感染,以下代码描述了这个过程:

float random = new Random().nextFloat();
if (random < Constants.BROAD_RATE && distance(person) < SAFE_DIST) {
this.beInfected();
}

当然,医院和国家的响应,会让我们在感染数上升的同时,避免外出,所以在计算人移动的过程中,添加一个辅助变量来表示人外出移动的意愿,随着感染数的上升,人们的移动意愿就会逐渐降低,为了简化程序,笔者在此添加了一个线性变化的流动意愿修改。随着床位被占据得越来越多,人们的流动意愿就越来越低。

下列图片就是从最开始很小一部分感染群体在不断地流动中所带来的大规模扩散模拟,当政府进行管控,外出人员大幅减少之后,整个疫情得到了有效的控制的演示,我们可以明确地得出一个结论,那就是「不出门、不串门」是非常行之有效的举措。正如 UP 主在视频最后所说的那句话 —— 「对本次疫情起到主导作用的,恰恰就是我们普普通通的每一个人」。
在这里插入图片描述
———————————
版权声明:本文为CSDN博主「唐门教主」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/tangxiaoyin/article/details/104184300

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值