系统模拟实验的三个案例Word文档下载推荐.docx
- 文档编号:19365005
- 上传时间:2023-01-05
- 格式:DOCX
- 页数:18
- 大小:63.61KB
系统模拟实验的三个案例Word文档下载推荐.docx
《系统模拟实验的三个案例Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《系统模拟实验的三个案例Word文档下载推荐.docx(18页珍藏版)》请在冰豆网上搜索。
0
5
10
0.7
0.2
0.1
28
30
32
34
0.3
0.4
为了模拟随机变量。
如果
为在
均匀分布的随机数,为了模拟随机变量
,可以通过如下方法。
其中,
分别用来模拟随机变量
1.1.5
模拟算法
变量说明:
k
临时变量,存储当前累计模拟次数
count
存储赶上火车的次数
第1步
输入模拟次数n
第2步
k=1,count=0
第3步
当k<
=n,执行第4步,否那么执行第12步
第4步
生成均匀分布随机数赋给r
第5步
由r及公式确定T1模拟火车出发时刻
第6步
生成均匀分布随机数赋给r;
第7步
由r及公式确定T3模拟人到达时刻
第8步
生成正态分布随机数T2模拟火车运行时间
第9步
IFT1+T2>
T3,count=count+1,END
第10步
k=k+1
第11步
执行第3步
第12步
输出赶上火车频率p=count/n
1.1.6
模拟程序
%sim_train.m
total=input('
输入模拟次数:
'
);
count=0;
fori=1:
total,
%模拟随机变量t1〔火车从A站出发的时刻〕
rt1=rand;
ifrt1<
0.7
T1=0;
elseifrt1>
=0.7&
rt1<
0.9
T1=5;
else
T1=10;
end
%模拟随机变量t2〔火车的运行时间〕
T2=30+randn*2;
%模拟随机变量t3〔他到达B站的时刻〕
rt3=rand;
ifrt3<
0.3
T3=28;
elseifrt3>
=0.3&
rt3<
T3=30;
T3=32;
T3=34;
end
ifT3<
T1+T2,%赶上了
count=count+1;
end%for
prob=count/total
1.1.7
模拟结果
命令行中输入以下语句:
sim_train
运行结果输出:
100
prob=
0.6302
此次运行结果显示赶上火车的近似概率为0.6左右。
下面列表给出屡次运行模拟程序的结果。
序号
模拟次数
近似概率p
1
500
0.6280
2
0.6920
3
1000
0.6530
4
0.6490
5000
0.6260
6
0.6288
1.1.8
评价与改良方向
为了计算赶上火车的概率,本文采用了随机系统模拟的方法。
如果能够从模型出发,对赶上火车的概率进展近似计算,然后与模拟结果进展比照,这样模拟会更有说明力。
1.1.9
思考题
请思考用其它方法计算赶上火车的概率或近似概率。
如果要使得他赶上火车的概率大于95%,你有什么方法?
结合上面的数学模型及模拟程序来思考。
〔3〕
通过该问题的建模求解,你能归纳出一般系统模拟的方法步骤么?
理发店模拟
1
实验案例1.1
案例:
理发店模拟
例子:
一个理发店有两位效劳员A和B,顾客们随机到达店内,其中60%的顾客仅需剪发,每位花5分钟时间,另外40%顾客既要剪发又要洗发,每位用时8分钟。
理发店是个含有多种随机因素的系统,请对该系统进展模拟,并对其进展评判。
〔准备怎么做〕
可供参考内容
“排队论〞,“系统模拟〞,“离散系统模拟〞,“事件调度法〞
问题分析
理发店系统包含诸多随机因素,为了对其进展评判就是要研究其运行效率,从理发店自身利益来说,要看效劳员工作负荷是否合理,是否需要增加员工等考虑。
从顾客角度讲,还要看顾客的等待时间,顾客的等待队长,如等待时间过长或者等待的人过多,那么顾客会离开。
理发店系统是一个典型的排队系统,可以用排队论有关知识来研究。
模型假设
1.
60%的顾客只需剪发,40%的顾客既要剪发,又要洗发;
2.
每个效劳员剪发需要的时间均为5分钟,既剪发又洗发那么花8分钟;
3.
顾客的到达间隔时间服从指数分布;
4.
效劳中效劳员不休息。
u:
剪发时间〔单位:
分钟〕,u=5m;
v:
既剪发又理发花的时间〔单位:
分钟〕,v=8m;
T:
顾客到达的间隔时间,是随机变量,服从参数为
的指数分布,〔单位:
分钟〕
T0:
顾客到达的平均间隔时间〔单位:
秒〕,T0=
;
由于该系统包含诸多随机因素,很难给出解析的结果,因此可以借助计算机模拟对该系统进展模拟。
考虑一般理发店的工作模式,一般是上午9:
00开场营业,晚上10:
00左右完毕,且一般是连续工作的,因此一般营业时间为13小时左右。
这里以每天运行12小时为例,进展模拟。
这里假定顾客到达的平均间隔时间T0服从均值3分钟的指数分布,
那么有
3小时到达人数约为
人,
6小时到达人数约为
10小时到达人数约为
这里模拟顾客到达数为60人的情况。
〔如何选择模拟的总人数或模拟总时间〕
系统模拟
根据系统模拟的一般方法,需要考虑系统的如下数据、参数。
1.
状态〔变量〕
〔1〕
等待效劳的顾客数;
〔2〕
A是否正在效劳;
〔3〕
B是否正在效劳;
2.
实体:
两名效劳员、顾客们
3.
事件:
一名新顾客的到达;
A开场效劳;
A完毕效劳;
〔4〕
B开场效劳;
〔5〕
B完毕效劳;
4.
活动:
顾客排队时间
顾客们到达的间隔时间
A的效劳时间
B的效劳时间;
在系统模拟时,为了研究系统的整体情况,这里考虑顾客到达后不离开,且等待队长不限。
要考虑如果效劳员均空闲时,顾客先选择谁效劳?
要考虑模拟的时间设置还有顾客数目。
模拟终止条件是根据顾客数目还是根据营业时间终止?
计算机模拟算法设计
自行设计
finished=0;
初始化运行时钟
whilefinished==0
if
产生的顾客数不到规定数目时then,
产生该顾客的有关数据;
将顾客参加等待队列;
else
运行时钟继续;
endif
处理效劳员的状态〔包括工作状态,空闲时间〕;
获得效劳员的效劳优先顺序;
根据效劳员优先顺序从等待队列中安排效劳;
endwhile
有无参考算法?
离散系统仿真算法:
事件调度法
计算机模拟程序
顾客到达的间隔时间T的计算机产生方法,利用T=
,
%理发店系统的模拟〔案例分析之一〕
%关键词:
面向事件的计算机模拟技术
clearall
curclock=0;
%当前时刻,动态变化
totalcustomer=0;
%总共效劳的顾客数
numsrv=2;
srvstatus=zeros(numsrv,5);
%效劳员有关数据
%srvstatus第1列:
效劳状态〔0空闲,1正在效劳〕;
第2列:
当前效劳顾客编号;
%
第3列:
当前效劳完毕时刻;
第4列:
效劳员空闲时间;
第5列:
效劳的顾客总数
endtime=0;
%完毕时间
waiting=[];
%等待队列数据
%waiting第1列:
顾客编号;
顾客到达时刻;
第3列:
顾客开场承受效劳时刻;
第4列:
承受效劳时间;
顾客完毕效劳时刻;
第6列:
间隔时间
cur=zeros(1,6);
%当前产生顾客的数据,对应关系同waiting
avgwaitlen=[];
%平均等待队长
avgwaittime=[];
%平均等待时间
ujiange=5;
%平均间隔时间
numsimucustumer=yesinput('
输入等待模拟的顾客数:
10,[101000]);
while
finished==0,
iftotalcustomer<
numsimucustumer
%产生一个顾客的到达及其有关性质的数据
totalcustomer=totalcustomer+1;
jiange=-log(rand)*ujiange;
%与上一个顾客的到达的间隔时间
curclock=curclock+jiange;
cur
(1)=totalcustomer;
%第1列:
顾客编号
cur
(2)=curclock;
%第2列:
顾客到达时刻
cur(6)=jiange;
第6列:
%下面产生承受效劳时间〔可改良模型〕
ifrand<
0.6,%产生顾客有关性质:
这里是产生承受效劳时间
cur(4)=5;
else
cur(4)=8;
%放入等待队列
ifisempty(waiting),
waiting=cur;
[m,n]=size(waiting);
waiting(m+1,:
)=cur;
curclock=curclock+(-log(rand)*ujiange);
end%iftotalcustomer<
%分配等待队列〔看是否有效劳员空闲,如果有那么分配;
否那么继续执行〕
%处理效劳员的效劳状态
fori=1:
numsrv,
ifsrvstatus(i,1)==1&
srvstatus(i,3)<
=curclock,
srvstatus(i,1)=0;
%设置为空闲状态
srvstatus(i,4)=curclock-srvstatus(i,3);
%目前已经空闲的时间
elseifsrvstatus(i,1)==1&
srvstatus(i,3)>
curclock,
srvstatus(i,4)=0;
%没有休息〔正在忙〕
%处理效劳员效劳的先后顺序〔依据空闲时间〕〔精细处理〕
tmp=srvstatus(:
4);
[value,id]=max(tmp);
b(i)=id;
tmp(id)=0;
%已经排序了
%此时等待队列必然不为空
forj=1:
i=b(j);
%确定效劳员的序号
if(srvstatus(i,1)==0)
%找一个顾客开场效劳,同时计算该顾客什么时候承受效劳,完毕效劳;
ifm==0,
break;
ifwaiting(1,5)==0,%还没有开场承受效劳
waiting(1,3)=curclock;
waiting(1,5)=waiting(1,3)+waiting(1,4);
%完毕时刻
srvstatus(i,1)=1;
%设置为忙状态
srvstatus(i,2)=waiting(1,1);
%顾客编号
srvstatus(i,3)=waiting(1,5);
srvstatus(i,5)=srvstatus(i,5)+1;
%又效劳了一个顾客
%计算等待时间
avgwaittime(end+1)=waiting(1,3)-waiting(1,2);
disp(sprintf('
间隔时间(%8.2f)顾客编号:
%5d承受效劳员〔%4d〕效劳(到达时刻%10.2f)'
waiting(1,6),waiting(1,1),i,waiting(1,2)))
endtime=max(endtime,waiting(1,5))
waiting(1,:
)=[];
%从等待队列中离开
end%if
end%for
%计算队长〔这里的计算式子可以参考排队论有关术语进展确定〕
avgwaitlen(end+1)=m;
ifsum(srvstatus(:
5))>
=numsimucustumer,%队列为空,完毕
finished=1;
end%while
disp('
效劳顾客数:
)
disp(srvstatus(:
5)'
平均队长'
disp(mean(avgwaitlen));
运行时间〔分钟,小时〕'
disp(sprintf('
%8.f%8.f'
curclock,curclock/60));
平均等待时间〔分钟〕'
disp(mean(avgwaittime));
完毕时间〔分钟〕'
disp(endtime);
figure
hist(avgwaitlen)
title('
hist(avgwaittime)
平均等待时间'
1.1.8
请运行模拟程序,并分析运行结果。
实验案例一个修理厂的模拟
实验案例
一个修理厂的模拟1.1.1
问题描述
某修理厂设有3个停车位置,其中一个位置供正在修理的汽车停放。
现以一天为一个时段,每天最多修好一辆车,每天到达修理站的汽车数有如下概率分布:
到达数
概率
0.6
0.2
假定在一个时段内一辆汽车能够修好的概率为0.7,本时段内未能完成修理的汽车于正在等待修理的汽车一起进入下一时段。
试问:
该停车厂有无必要增加停车位置,并说明理由。
模拟模型
这种排队论方面的问题采用固定时间增量法模拟。
模拟以一天为一个时段,模拟纵时间最好在1000天以上。
模拟汽车到达数量,根据概率分布:
产生在[0,1]上均匀分布的随机数t,如果
,那么认为当天到达的车辆数为0辆;
,那么认为当天到达的车辆数为1辆,如果
,那么认为当天到达的车辆数为2辆。
模拟修理情况:
由于一天最多修好一辆,而一个时段内一辆汽车修好的概率为0.7,那么模拟每两车的修理情况,如果这些车所能修好数目大于等于1辆,那么以当天修好1辆计。
本模拟程序编写了一个主函数queue,另外在函数queue中编写了2个子函数:
gete:
模拟车辆到来情况,返回当天到来的车辆数目
getrepaired:
模拟修理情况,返回修好的车辆数目
整个模拟程序如下:
〔2005/6/6新版本〕
functionqueue
%2005-6-6
%排队模拟主程序
%排队问题模拟
%
numdays=input('
请输入模拟天数:
numstay=0;
%假定最初修理站还没有待修理的汽车
LEN=6;
%定义常量
matfrequence=zeros(1,LEN);
%第i个元素表示当天末还有i-1辆车在没有修好的时段频数
leave_norepair=0;
%存储来到,但没有停车位置而离开的车辆数
fordays=1:
numdays%主循环,模拟numdays个时段
temp=gete;
ifnumstay+temp>
3,
leave_norepair=leave_norepair+(numstay+temp-3);
%nume=numstay+gete;
%2004-10-10:
这里有问题,受限制与停车位置数量
nume=min(3,numstay+temp);
%头一天还没有修好的车辆数+当天新到来的车辆数
%numstay表示当天末还没有修理好的车辆数目
numstay=max(0,nume-getrepaired(nume));
matfrequence(numstay+1)=matfrequence(numstay+1)+1;
end
matfrequence
prob=matfrequence/numdays
平均每天夜里停放在修理站的车辆数=%4.2f'
...
sum(matfrequence/numdays.*[0:
LEN-1])))
%sprintf('
=%.4f'
sum(matfrequence/numdays.*[0:
LEN-1]))
平均每天因位置而未修理而离开修理站的车辆数=%4.2f'
leave_norepair/numdays))
leave_norepair/numdays)
leave_norepair
functionnum=gete
%模拟车辆到来情况,返回当天到来的车辆数目
t=rand;
ift>
=0&
t<
0.6
num=0;
%当天到来车俩数为0辆
elseift>
=0.6&
0.8
num=1;
%当天到来车俩数为1辆
else
num=2;
%当天到来车俩数为2辆
functionr=getrepaired(num_cur)
%模拟修理情况,返回修好的车辆数目
%n为需要修理的车辆数目
%r为n辆车修好了r辆
%num_cur当前〔天〕车辆数
r=0;
ifnum_cur<
=0,%如果根本没有车,当然就没有修好车
return
%只考虑当前正在修的这辆车是否能够修好
ifrand<
0.7,%(0,0.7)认为修好,[0.7,1)认为没有修好
r=1;
模拟结果
程序运行结果如下:
(100):
10000
numdays=
matfrequence=
4230
2729
2375
666
0
0
prob=
0.4230
0.2729
0.2375
0.0666
平均每天夜里停放在修理站的车辆数=0.95
平均每天因位置而未修理而离开修理站的车辆数=0.09
leave_norepair=
883
模拟10000次的结果如下表所示:
留夜的车辆数
频数
4230
2729
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 系统 模拟 实验 三个 案例