下面来介绍一下如何在MATLAB中实现对某超市一定时间段内的顾客排队的模拟,具体如下:
假设计算机分別在顾客人数为10、100、500、1000、5000、10000、20000、50000、100000、500000等10种不同情况时,模拟收银系统的工作强度和顾客平均逗留时间,并且每一种情况都模拟进行100次,避免随机因素的存在,具体代码如下:
1、在MATLAB的主界面编辑器中写入下列代码:
clc;close all;clear all;
disp('计算机大概需要两分钟的运行时间,请等待……');
p=zeros(10,100);avert=zeros(10,100);
%分别在顾客人数为10、100、500等情况时,模拟系统工作强度和顾客平均逗留时间
nn=[10 100 500 1000 5000 10000 20000 50000 100000 500000];
for d=1:10 %length(nn)=10
for s=1:100 %每种情况重复模拟100次以便消除随机因素
n=nn(d);%模拟顾客数目
dt=exprnd(10,1,n);%到达时间间隔
st=normrnd(6.5,1.2,1,n);%服务台服务时间
a=zeros(1,n);%每个顾客到达时刻
b=zeros(1,n);%每个顾客开始接受服务时刻
c=zeros(1,n);%每个顾客离开时刻
a(1)=0;
for i=2:n
a(i)=a(i-1)+dt(i-1);%第i顾客到达时刻
end
b(1)=0;%第一个顾客开始接受服务的时刻是其到达的时刻
c(1)=b(1)+