数学建模python matlab 编程(疾病传播模型)
例12:一只游船上有800(1000)人,一名游客不慎患传染病,12(10)小时后有3人发病,由于船上不能及时隔离,问经过60(30)小时,72小时,患此病的人数。(与人口模型和Logistic模型类似)
先用python和matlab模拟
我的python代码
# -*- coding: utf-8 -*-
import numpy as np
import random
import matplotlib
matplotlib.rcParams['font.sans-serif']=[u'simHei']
matplotlib.rcParams['axes.unicode_minus']=False
import pandas as pd
import matplotlib.pyplot as plt p_size=10000
get_ill_p = 0.1 is_ill = np.zeros(p_size)
is_ill[0]=1
ill_n =1
x=[]
y=[]
for time in range(100):
x.append(time)
y.append(ill_n)
# 遍历每一个交往的人数
for i in range(ill_n):
# 交往的人数再0-2个人内
renshu = np.random.randint(0,2)
for j in range(renshu):
# 随机挑一个人
p = np.random.randint(0,p_size)
# 如果p没患病
if is_ill[p]==0 and random.random()<0.5:
is_ill[p]=1
ill_n += 1
plt.plot(x,y)
我的matlab代码
clear;
p_size=10000;
get_ill_p = 0.1; is_ill = zeros(1,p_size);
is_ill(1)=1;
ill_n =1;
y(1)=1;
for time =1:150
y(time)=ill_n;
% 遍历每一个交往的人数
for i =1:ill_n
% 交往的人数再0-2个人内
renshu = randperm(2,1); % 产生0到2内的随机整数
for j =1:renshu
% 随机挑一个人
p = randperm(p_size,1); % 产生0到p_size内的随机整数
% 如果p没患病
if is_ill(p)==0 && rand(1)<get_ill_p
is_ill(p)=1;
ill_n = ill_n+ 1;
end
end
end
end
plot(y,'o');
老师的matlab代码1
clear
d=800; %%%总的患病人数。
y=ones(1,d);%%%“1”表示健康的人。
y(1)=0; %%%第1个人患病了。 for n=1:240 %%%考虑200个时间单位后的情况。
y=y(randperm(d)); %%%将y的顺序打乱。
z=[y(2:d)];z(d)=y(1); %%%考虑 y 后面一个人, 最后一个人的后面拟定为第一个人。
%%%每一个人可随机与另一个人接触,在一维中足够可表达这个意思.
R=find((y==0)&z==1); %%%找出患者即将传染的人。只有健康的人才会成为新的患者。
for k=1:size(R,2) %%%size(R,2)为第 n 个单位时间的总的“传播机会”.
w=randperm(15);p=(w(1)>=2); %%%不是只要一个健康的人接触患者就会成为病人的。传染病有感染程度的不同。
z(R(k))=1.*p;
end
y=z; %%%经过一个时段后新的分布产生了。
s(n)=numel(find(z==0)); %%%计算总的患病人数。
end
s;plot(s) %%%画出患病人数曲线图。
老师的matlab代码2
clear
t=1:240;
y=800./(1+799.*exp(-0.09176.*t));
plot(y)
老师的matlab代码3
clear
d=800; %%%总的患病人数。
y=ones(1,d);%%%“1”表示健康的人。
y(1)=0; %%%第1个人患病了。 for n=1:240 %%%考虑200个时间单位后的情况。
y=y(randperm(d)); %%%将y的顺序打乱。
z=[y(2:d)];z(d)=y(1); %%%考虑 y 后面一个人, 最后一个人的后面拟定为第一个人。
%%%每一个人可随机与另一个人接触,在一维中足够可表达这个意思.
R=find((y==0)&z==1); %%%找出患者即将传染的人。只有健康的人才会成为新的患者。
for k=1:size(R,2) %%%size(R,2)为第 n 个单位时间的总的“传播机会”.
w=randperm(15);p=(w(1)>=2); %%%不是只要一个健康的人接触患者就会成为病人的。传染病有感染程度的不同。
z(R(k))=1.*p;
end
y=z; %%%经过一个时段后新的分布产生了。
s(n)=numel(find(z==0)); %%%计算总的患病人数。
end
s;plot(s) %%%画出患病人数曲线图。
s(72)
老师的matlab代码4
clear
d=800; %%%总的患病人数。
y=ones(1,d);%%%“1”表示健康的人。
y(1)=0; %%%第1个人患病了。 for n=1:240 %%%考虑200个时间单位后的情况。
y=y(randperm(d)); %%%将y的顺序打乱。
z=[y(2:d)];z(d)=y(1); %%%考虑 y 后面一个人, 最后一个人的后面拟定为第一个人。
%%%每一个人可随机与另一个人接触,在一维中足够可表达这个意思.
R=find((y==0)&z==1); %%%找出患者即将传染的人。只有健康的人才会成为新的患者。
for k=1:size(R,2) %%%size(R,2)为第 n 个单位时间的总的“传播机会”.
w=randperm(11);p=(w(1)>=2); %%%不是只要一个健康的人接触患者就会成为病人的。传染病有感染程度的不同。
z(R(k))=1.*p;
end
y=z; %%%经过一个时段后新的分布产生了。
s(n)=numel(find(z==0)); %%%计算总的患病人数。
end
s;plot(s) %%%画出患病人数曲线图。
s(72)
数学建模python matlab 编程(疾病传播模型)的更多相关文章
- 数学建模python matlab 编程(指派问题)
指派授课问题 现有A.B.C.D四门课程,需由甲.乙.丙.丁四人讲授,并且规定: 每人只讲且必须讲1门课:每门课必须且只需1人讲. 四人分别讲每门课的费用示于表中: 课 费用 人 A B C D 甲 ...
- 数学建模python matlab 编程(随机游走问题)
1 (1). 随机游走问题.在-10到10的一维线段上,质点以1/5的概率用左运动1单位,以2/5的概率停止不动,以2/5的概率向右运动2单位,且碰到-10时向右运动3单位,碰到10时向左运动4单位. ...
- 数学建模python matlab 编程(喷泉模拟)
在无风情况下的喷泉模拟 我的python代码 import numpy as np import random import matplotlib matplotlib.rcParams['font. ...
- 数学建模python matlab 编程(椭圆声学原理画图证明,解析几何)
证明,在椭圆形的音乐厅内,从一个椭圆的一个焦点发出声音,则另一个焦点听到的声音是最大的. 分析:证明,从椭圆的一个焦点任意发射的直线经过反射后,并经过另一个焦点. 画图,过一个焦 ...
- 在数学建模中学MATLAB
为期三周的数学建模国赛培训昨天正式结束了,还是有一定的收获的,尤其是在MATLAB的使用上. 1. 一些MATLAB的基础性东西: 元胞数组的使用:http://blog.csdn.net/z1137 ...
- 【数学建模】MatLab 数据读写方法汇总
1.读入 txt 文件数据. load xxx.txt A=load(‘xxx.txt’) A=dlmread(‘xxx.txt’) A=importdata(‘xxx.txt’) 例:将身高体重的 ...
- python网络编程——网络IO模型
1 网络IO模型介绍 服务器端编程经常需要构造高性能的IO模型,常见的IO模型有四种: (1)同步阻塞IO(Blocking IO):即传统的IO模型. (2)同步非阻塞IO(Non-bl ...
- Python网络编程(OSI模型、网络协议、TCP)
前言: 什么是网络? 网络是由节点和连线构成,表示诸多对象及其相互联系. 在数学上,网络是一种图,一般认为专指加权图. 网络除了数学定义外,还有具体的物理含义,即网络是从某种相同类 型的实际问题中抽象 ...
- 【数学建模】MATLAB语法
一.向量.矩阵的表示和使用 format long %小数很多format short %默认4位小数format rat %显示最近的分数format short e %指数格式的数 尾数多少 e ...
随机推荐
- java实战(一)-------jdk环境在windows安装及配置
1.jdk官方下载 http://www.oracle.com/technetwork/java/javase/downloads/index.html 点击下载windows的版本:jdk-13.0 ...
- jquery 选择器能否查找display:none的元素
jQuery可以用可见性“:hidden”查找“display:none”的元素. 1.新家html文档,在head标签中引入本地jQuery文件,也可以引入cdn文件: 2.在body标签中添加一些 ...
- 那些吓人的 Linux 命令
本文转载于其它网站,原作者如有问题,请您及时联系我,及时删除! 哪些Linux命令会让人联想到妖魔鬼怪?不妨好好瞧一瞧! 每年一度的万圣节马上就要到来,是时候稍微关注一下Linux那吓人的一面了.哪些 ...
- dpkg: error processing package XXX (--configure) 解决方法 (ubuntu右上角红色警告)
在 Ubuntu 执行 sudo apt-get upgrade 时,出现了如下的报错: Setting up bluez (4.101-0ubuntu13.1) ... reload: Job is ...
- [Google Guava] 1.2-前置条件
原文链接 译文链接 译者: 沈义扬 前置条件:让方法调用的前置条件判断更简单. Guava在Preconditions类中提供了若干前置条件判断的实用方法,我们强烈建议在Eclipse中静态导入这些方 ...
- 分页控件Webdiyer.MvcPager
MVC 1.安装控件 install-package Webdiyer.MvcPager 2.Cotroller using System; using System.Collections.Gene ...
- ES6-12.Symbol
Symbol是ES6新增的原始类型数据,引入的初衷是为了对象可以有永不重复的属性名. 所以属性名可以是字符串外,还可以是Symbol值: const a = Symbol("a") ...
- Bzoj 1208: [HNOI2004]宠物收养所(splay)
1208: [HNOI2004]宠物收养所 Time Limit: 10 Sec Memory Limit: 162 MB Description 最近,阿Q开了一间宠物收养所.收养所提供两种服务:收 ...
- 【线性代数】6-4:对称矩阵(Symmetric Matrices)
title: [线性代数]6-4:对称矩阵(Symmetric Matrices) categories: Mathematic Linear Algebra keywords: Eigenvalue ...
- sigprocmask , sigpending 和 sigsuspend函数
转自 http://blog.csdn.net/elbort/article/details/7594772 sigprocmask函数:功能描述:设定对信号屏蔽集内的信号的处理方式(阻塞或不阻塞). ...