zoukankan      html  css  js  c++  java
  • matlab实现M/M/1排队系统

    Matlab实现。

    分为主函数 MyLine 和被调用函数 Func。

    主函数 MyLine 实现在 Func 函数的基础上实现序贯法, 将平均等待队长作为每次模拟的 X,求出置信区间。
    Func 函数实现单次模拟排队系统,返回向量 vector。向量vector分别包括仿真平均排队时间Cus_Queue_avg,仿真平均等待时间Cus_Wait_avg,仿真系统中平均等待队长 Cus_Wait_Queue_avg,仿真系统中平均顾客数 Cus_Wait_CusNum_avg。

    主函数 MyLine:

     1 clear;
     2 clc;
     3 Alpha=0.1; %置信水平
     4 Gama=0.1; %相对精度
     5 Beta=0.1;
     6 Lambda=0.2; %到达率 Lambda
     7 Mu=0.25; %服务率 Mu
     8 time=50; %单回模拟次数
     9 %序贯法实现
    10 All_vector=Func( Lambda,Mu );%函数返回的向量
    11 for i=2:time
    12 All_vector=[All_vector;Func( Lambda,Mu )];
    13 end
    14 vect=sum(All_vector)/time;%各列求和取平均
    15 %下面系统中平均等待队长作为每次模拟的 X,用来评估运行结果
    16 S=sum((All_vector(3)-vect(3)).*(All_vector(3)-vect(3)))/(ti
    17 me-1);%后面假设 S 不变
    18 Betan=sqrt(S/time)*tinv(1-Alpha/2,time-1);
    19 Gaman=Betan/vect(3);
    20 while(Gaman>=Gama) %Betan>=Beta||
    21 time=time+1;
    22 All_vector=[All_vector;Func( Lambda,Mu )];
    23 vect=sum(All_vector)/time;
    24 S=sum((All_vector(3)-vect(3)).*(All_vector(3)-vect(3)))/(ti
    25 me-1);%后面假设 S 不变
    26 Betan=sqrt(S/time)*tinv(1-Alpha/2,time-1);
    27 Gaman=Betan/vect(3);
    28 end
    29 time
    30 disp(['系统中平均等待队长的置信区间下界
    31 =',num2str(vect(3)-Betan)]);
    32 disp(['系统中平均等待队长的置信区间上界
    33 =',num2str(vect(3)+Betan)]);

    Func 函数:

     1 function [ vector ] = Func( Lambda,Mu )
     2 %单次的排队模拟,样本数 CusTotal
     3 CusTotal=10000; %仿真顾客总数%=input('请输入仿真顾客
     4 总数 CusTotal=');
     5 Cus_Arrive=zeros(1,CusTotal);%到达时刻
     6 Cus_Leave=zeros(1,CusTotal);%离开时刻
     7 IntervaCus_Arrive=-log(rand(1,CusTotal))/Lambda;%到达时间间
     8  9 Cus_Arrive=cumsum(IntervaCus_Arrive); %每列
    10 累加,形成到达初始时刻;如果只有一行,该行向后叠加
    11 Interval_Serve=-log(rand(1,CusTotal))/Mu; %服务时间间隔
    12 %为事件调度法做准备
    13 Cus_Leave(1)=Cus_Arrive(1)+Interval_Serve(1);%顾客离开时间
    14 for i=2:CusTotal
    15 if Cus_Leave(i-1)<Cus_Arrive(i)
    16 Cus_Leave(i)=Cus_Arrive(i)+Interval_Serve(i);
    17 else
    18 Cus_Leave(i)=Cus_Leave(i-1)+Interval_Serve(i);
    19 end
    20 end
    21 Cus_Wait=Cus_Leave-Cus_Arrive; %各顾客在系统中的等待时间
    22 %mean:如果是 n*m 的矩阵,mean 对各列分别进行求平均;当 n=1 时,
    23 对一行求平均
    24 Cus_Wait_avg=mean(Cus_Wait); %平均等待时间
    25 Cus_Queue=Cus_Wait-Interval_Serve;%各顾客在系统中的排队时间
    26 Cus_Queue_avg=mean(Cus_Queue); %平均排队时间
    27 %TimePoint 系统调度时间
    28 TimePoint=[Cus_Arrive,Cus_Leave];%系统中顾客数随时间的变化
    29 TimePoint=sort(TimePoint);
    30 CusNum=zeros(size(TimePoint));
    31 temp=2; %指向事件表
    32 CusNum(1)=1;
    33 %统计 dt 时间内的排队人数——事件调度法
    34 %截止到 i,还有多少个事件
    35 for i=2:length(TimePoint)
    36 %后一事件的结束时间晚于前一事件的结束时间
    37 %所以只要第 temp-1 个事件没有结束, 后面的事件到了发生时间
    38 (事件仿真钟<=系统仿真钟),都要加入 CusNum 中计数
    39 if
    40 (temp<=length(Cus_Arrive))&&(TimePoint(i)==Cus_Arrive(temp)
    41 )
    42 CusNum(i)=CusNum(i-1)+1;
    43 temp=temp+1;
    44 else
    45 CusNum(i)=CusNum(i-1)-1;
    46 end
    47 end
    48 %系统中平均顾客数计算
    49 Time_interval=zeros(size(TimePoint));
    50 Time_interval(1)=Cus_Arrive(1);
    51 for i=2:length(TimePoint)
    52 Time_interval(i)=TimePoint(i)-TimePoint(i-1);
    53 end
    54 %这里画一下图即可.i 时间段*(i-1)时刻统计的事件数量。类似于向
    55 后积分
    56 CusNum_fromStart=[0 CusNum];
    57 Cus_Wait_CusNum_avg=sum(CusNum_fromStart.*[Time_interval
    58 0] )/TimePoint(end);
    59 %系统平均等待队长
    60 QueLength=zeros(size(CusNum));
    61 for i=1:length(CusNum)
    62 if CusNum(i)>=2
    63 %还有等待事件(满足事件仿真钟<=系统仿真钟,但没有发
    64 生)
    65 QueLength(i)=CusNum(i)-1;
    66 else
    67 QueLength(i)=0;
    68 end
    69 end
    70 Cus_Wait_Queue_avg=sum([0 QueLength].*[Time_interval
    71 0] )/TimePoint(end);
    72 %仿真值与理论值比较
    73 row=Lambda/Mu;
    74 QueLength_avg=row*row/(1-row);%Q
    75 CusNum_avg=row/(1-row);%L
    76 Queue_avg=QueLength_avg/Lambda;%d
    77 Wait_avg=CusNum_avg/Lambda;%w
    78 %返回的向量
    79 vector=[Cus_Queue_avg,Cus_Wait_avg,Cus_Wait_Queue_avg,Cus_W
    80 ait_CusNum_avg];
    81 end

    基本代码都在了,报告自己写吧。

  • 相关阅读:
    存储过程分页,前台应用范例repeater分页
    引用真正分页控件(与存储过程联合使用)页面
    分页存储过程repeater分页
    查找DetailsView1数据控件中的数据
    c#读取文件
    SQL触发器实例讲解
    TreeView节点选中问题
    C# 实现版本自动更新
    .Net那点事儿系列:C#操作Xml:通过XmlDocument读写Xml文档
    Linq学习笔记
  • 原文地址:https://www.cnblogs.com/Deribs4/p/4986817.html
Copyright © 2011-2022 走看看