排队论(Queuing Theory)

2023-11-19

目录

简介

一、基本概念

1.1 排队过程的一般表示

1.2 排队系统的组成和特征

1.2.1 输入过程

1.2.2 排队规则

1.2.3 服务过程

1.3 排队模型的符号表示

1.4 排队系统的运行指标

二、 输入过程与服务时间的分布

2.1 泊松流与指数分布

2.2 常用的几种概率分布

2.2.1 连续型随机变量分布

2.2.2 离散型随机变量分布

三、 生灭过程

四、 M/M/s 等待制排队模型

4.1 但服务台模型

4.1.1 队长的分布

4.1.2 几个主要数量指标

4.1.3 忙期和闲期

4.3 多服务台模型(​编辑)

十、 排队模型的计算机模拟

10.1 确定随机变量概率分布的常用方法

10.2 计算机模拟


简介

排队论起源于1909年丹麦电话工程师A.K.爱尔朗的工作,他对电话通过拥挤问题进行了研究。1917年,爱尔朗发表了他的著名文章——“自动电话交换中的概率论的几个问题的解决”。排队论已广泛应用于军事、运输、维修、生产、服务、库存、医疗卫生、教育、水利灌溉之类的问题,显示了强大的生命力。

排队是在日常生活中经常遇到的现象,如顾客到商店购买物品、病人到医院看病常需要排队。此时要求服务的数量超过服务机构(服务台,服务员等)的容量。也就是说,到达的顾客不能立即得到服务,因而出现了排队现象。这种现象不仅在个人日常生活中出现,电话局的占线问题,车站、码头等交通枢纽的车船堵塞喝疏导,故障机器的停机维修,水库的存贮调节等,都是有形或无形的排队现象。由于顾客到达喝服务时间的随机性。可以说排队现象几乎是不可避免的。

排队论也成为随机服务系统理论,就是为解决上述问题而发展的一门学科。它研究的内容有下列三部分:

  • 性态问题,即研究各种排队系统的概率规律性,主要是研究队长分布、等待时间分布和忙期分布,包括了瞬态和稳态两种情形。
  • 最优化问题,又分静态最优和动态最优,前者指最优设计,后者指现有排队系统的最优运营。
  • 排队系统的统计推断,即判断一个给定的排队系统符合与哪种模型,以便根据排队理论进行分析研究。

这里将介绍排队论的一些基本知识,分析几个常见的排队模型。

一、基本概念

1.1 排队过程的一般表示

 虚线包含的部分为排队系统。

凡要求服务的对象统称为顾客,为顾客服务的人或物称为服务员,由顾客和服务员组成服务系统。

服务机构过小,一直不能满足要求服务的顾客的需求;服务机构过大,相应消耗的财力和物力也增加。因此研究排队模型的目的就是要在顾客需要和服务机构的规模之间进行权衡决策,使其达到合理的平衡

1.2 排队系统的组成和特征

一般的排队过程都由输入过程、排队规则、服务过程三部分组成。

1.2.1 输入过程

输入过程是指顾客到来实践的规律性,可能有以下几种情况:

  • 顾客源是有限还是无限
  • 顾客是逐个到达还是成批到达
  • 顾客达到是相互独立还是相互影响
  • 输入过程是平稳还是非平稳。平稳输入过程即顾客相继到达的时间间隔分布,及其数学期望、方差等数字特征都与时间无关。

1.2.2 排队规则

排队规则指到达排队系统的顾客按怎样的规则排队,可分为损失制,等待制和混合制三种。

  • 损失制。当顾客到达时,所有的服务台均被占用,顾客离去。
  • 等待制。当顾客到达时,所有的服务台均被占用,顾客排队等待知道接受完服务。
  • 混合制。介于损失制和等待制两者之间。

1.2.3 服务过程

服务机构,单服务台;多服务台并联,多服务台串联;混合型。

服务规则:

  • 先到先服务,FCFS
  • 后到先服务,LCFS
  • 随即服务,RAND
  • 优先服务,PR

1.3 排队模型的符号表示

排队模型的一般表示方法,X/Y/Z/A/B/C

  • X代表顾客到达流或者顾客到达时间间隔的分布
    • M-(Markov)指数分布
    • D-确定型分布
    • E_k-k阶爱尔朗Erlang分布
    • G-一般服务时间分布
    • GI-一般相互独立的时间间隔分布
  • Y代表服务时间的分布
    • 表示的字母所代表的分布与X相同
  • Z代表服务台数目
  • A代表系统容量限制
  • B代表顾客源数目
  • C代表服务规则

1.4 排队系统的运行指标

平均队长L_s:指系统内的顾客数(包括正在被服务以及正在排队的顾客)

平均排队长L_q:只指系统内正在排队的顾客数

平均逗留时间W_s:指顾客从进入排队系统到离开排队系统的时间,包括排队时间和被服务时间

平均等待时间W_q:指顾客排队的时间

平均忙期T_b:指顾客到达空闲机构起,到服务机构再次空闲的时间间隔长度的数学期望。

计算这些指标的基础是表达系统状态的概率,所谓系统的状态即指系统中顾客数。如果系统中有n个顾客就说系统的状态是n,它有如下几种表示方法及其代表含义:

  • n=1,2,3...队长没有限制。
  • n=1,2,3,...,N,队长有限制,且最大数为N。
  • n=1,2,3,...,c,损失制且服务台个数为c时。

需注意排队系统的状态是时间t的函数,所以在时刻t、系统状态为n的概率用P_n(t)表示。稳态,即与不随时间t改变时,系统状态记为P_n

二、 输入过程与服务时间的分布

排队系统中的事件流包括顾客到达流和服务时间流,由于顾客到达的间隔时间和服务时间不可能是负值,因此分布是非负随机变量的分布。常用的分布有泊松分布,确定型分布,指数分布和爱尔朗分布。

2.1 泊松流与指数分布

输入过程是泊松流时,顾客相继到达的时间间隔T必服从指数分布。详细推到略去。

2.2 常用的几种概率分布

2.2.1 连续型随机变量分布

  • 均匀分布
  • 正态分布
  • 指数分布
  • Gamma分布
  • Weibull分布
  • Beta分布

2.2.2 离散型随机变量分布

  • 均匀分布
  • Bernoulli分布
  • Poisson分布
  • 二项分布

三、 生灭过程

一类非常重要且广泛存在的排队系统时生灭过程排队系统。生灭过程是一类特殊的随机过程,在生物学、物理学、运筹学中有广泛的应用。在排队论中,如果N(t)表示在t时刻,系统中的顾客数,则\{N(t),t>0\}就构成了一个随机过程。如果用”生“代表示顾客的到来,”灭“表示顾客的离去。则对于许多排队过程来说,\{N(t),t>0\}就是一类特殊的随机过程——生灭过程。

\{N(t),t>0\}为一个随机过程。若N(t)的概率分布具有以下性质:

  • 假设N(t)=n,则从时刻t起到下一个顾客到达时刻止的时间服从参数为\lambda_n的负指数分布,n=0,1,2...
  • 假设N(t)=n,则从时刻t起到下一个顾客离去时刻止的时间服从参数为\mu_n的负指数分布,n=0,1,2,...
  • 同一时刻只有一个顾客到达或离去。

则称\{N(t),t>0\}为生灭过程。

四、 M/M/s 等待制排队模型

4.1 但服务台模型

M/M/1/\infty表示顾客相机到达时间服从参数为\lambda的负指数分布,服务时间V服从参数为\mu的负指数分布,系统空间无限,允许无限排队,这是一类最简单的排队系统。

4.1.1 队长的分布

p_n=P\{N=n\},(n=0,1,2,3,...)为系统达到平衡状态后队长的概率分布。记\rho=\frac{\lambda}{\mu},并设其小于1(否则队长无穷)。则队长分布为p_n=(1-\rho)\rho ^n, (n=1,2,3...)

数据量\rho是服务系统中至少有一个顾客的概率,也就是服务台处于忙的状态的概率,因而\rho

也称为服务强度,反映了系统繁忙的程度。 

4.1.2 几个主要数量指标

由于队长的概率分布已知,可以计算出该模型中的其他运行指标

平均队长L_s=\frac{\rho}{1-\rho}=\frac{\lambda}{\mu-\lambda}

平均排队长L_q=\frac{\lambda^2}{\mu(\mu-\lambda)}

平均逗留时间W_s=\frac{1}{\mu-\lambda}

平均等待时间W_q=\frac{\lambda}{\mu(\mu-\lambda)}

显然有L_s=\lambda W_sL_q=\lambda W_q

4.1.3 忙期和闲期

平均忙期\bar{B}=\frac{1}{\mu-\lambda}

平均闲期\bar{I}=\frac{1}{\lambda}

4.3 多服务台模型(M/M/s/\infty

设顾客单个到达,相机达到时间间隔服从参数为\lambda的负指数分布,系统中有s个服务台,每个服务台的服务时间相互独立,且服从参数为\mu的负指数分布。且为等待制,队长无限长,等待时间无限。

p_n=P\{N=n\}(n=0,1,2,3....)为系统达到平稳状态后,队长N的概率分布。

则队长的分布为\left\{\begin{matrix} \frac{\rho^n}{n!}p_0,n=1,2,3,...,s\\ \frac{\rho^n}{s!s^{n-s}}p_0,n\geq s \end{matrix}\right.,其中p_0=[\sum_{n=0}^{s-1}\frac{\rho^n}{n!}+\frac{\rho^s}{s!(1-\rho_s)}]^{-1}\rho_s=\frac{\lambda}{s\mu},称为多服务台系统的服务强度。

对于多服务台系统,记c(s,\rho)=\sum_{n=s}^{\infty}p_n=\frac{\rho^s}{s!(1-\rho_s)}p_0为在系统顾客达到系统时需要等待的概率。

平均排队长L_q=\frac{p_0\rho^s}{s!}\sum_{n=s}^{\infty}(n-s)\rho_s^{n-s}=\frac{\rho_s}{1-\rho_s}c(s,\rho)

平均队长L_s=L_q+\rho

平均逗留时间W_s=\frac{L_s}{\lambda}

平均排队时间W_q=\frac{L_q}{\lambda}=W_s-\frac{1}{\mu}

十、 排队模型的计算机模拟

10.1 确定随机变量概率分布的常用方法

根据一般知识和经验,假定概率分布的形式,然后由实际数据估计分布的参数。

直接由大量的实际数据作直方图,得到经验分布,再通过假设检验,拟合分布函数。

确实先验知识以及实验数据时,对于区间(a,b)内变化的随机变量,可选用beta分布和均匀分布。现根据经验确定随机变量的均值\mu和频率最高的数值m,则beta分布最终端参数\mu=a+\frac{\alpha_1(b-a)}{\alpha_1+\alpha_2},m=a+\frac{(\alpha_1-1)(b-a)}{\alpha_1+\alpha_2-2}

10.2 计算机模拟

当排队系统的到达间隔时间和服务时间的概率分布很复杂时,就需要使用随机模拟法求解。

随机模拟法要求事件能够按历史的概率分布规律出现。

 设a1表示生成的随机数,a2表示到达的车辆,a3表示需要卸货的车数,a4表示实际卸货车数,a5表示推迟卸货车数。

n=50000; %模拟50000天
m=2;
a1=rand(n,1);
%% 模拟实际达到的车数
a2=a1;
a2(find(a1<0.23))=0;
a2(find(a1>=0.2&&a1<0.53))=1;
a2(find(a1>=0.53&&a1<0.83))=2;
a2(find(a1>=0.83&&a1<0.93))=3;
a2(find(a1>=0.93&&a1<0.98))=4;
a2(find(a1>=0.98))=5;

%% 模拟卸货车数
a3=zeros(n,1);
a4=a3;
a5=a3;
a3(1)=a2(1);
if a3(1)<=m
    a4(1)=a3(1);
    a5(1)=0;
else 
    a4(1)=m;
    a5(1)=a2(1)-m;
end
for i=2:n
    a3(i)=a2(i)+a5(i-1);
    if a3(i)<=m
        a4(i)=a3(i);
        a5(i)=0;
    else
        a4(i)=m;
        a5(i)=a3(i)-m;
    end
end
%%求平均
a=[a1 a2 a3 a4 a5];
sum(a)/n;


 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

排队论(Queuing Theory) 的相关文章

  • hibernate 异常

    1 异常 org hibernate AnnotationException No identifier specified for entity异常 entity类是必须要主键的 否则就会报出这个异常 Id GeneratedValue
  • 布隆过滤器的简单介绍与实例(Bloom Filter)

    转载https blog csdn net leeafay article details 78681534 布隆在1970年提出了布隆过滤器 Bloom Filter 是一个很长的二进制向量 可以想象成一个序列 和一系列随机映射函数 ha
  • TensorFlow.js - 使用 CNN(卷积神经网络) 识别手写数字

    目录 index html data js script js 备注 参考文献 index html
  • ChatGPT是免费的吗?

    ChatGPT并非由单个实体或公司所拥有和控制 而是由OpenAI推出和维护的人工智能技术 其可以被免费使用 OpenAI提供API服务和开发者工具 可以让开发者和用户将ChatGPT集成到自己的应用程序中 虽然使用ChatGPT本身是免费

随机推荐

  • Nginx配置整合:基本概念、命令、反向代理、负载均衡、动静分离、高可用

    一 基本概念 1 什么是Nginx Nginx是一个高性能的HTTP和反向代理服务器 也是一个IMAP POP3 SMTP代理server 其特点是占有内存少 并发能力强 其并发能力确实在同类型的网页server中表现较好 http服务器
  • 飞腾D2000 UOS下安装KVM虚拟机

    其他的和x86环境都差不多 开了开发者模式后 virt manager qemu efi aarch64 qemu system 几个包补齐 启动libvirtd服务 查看日志 报以下日志 4月 09 21 13 34 actionchen
  • JAVA虚拟机灵魂之问:Xmx和Xms不一致对虚拟机性能有何影响

    使用jvisualVM查看idea进程 发现其关于堆大小的参数设置如下 并发现随着idea加载项目 其实际使用的内存会自动增大 加载项目前和加载项目后 堆大小是不一样的 有一个大幅提升的阶段 随着所需要的内存的增多 虚拟机会多次向操作系统申
  • FreeBSD配置ip和开启SSH

    首先ifconfig a 看下网卡名称 然后vi etc rc conf 我先贴下我的图吧 主要是 ifconfig le0这个的 set ip ifconfig le0 inet 192 168 1 213 netmask 255 255
  • openEuler操作系统及其安装使用

    文章目录 1 目标 2 openEuler操作系统介绍 2 1 发布件 2 2 最小硬件要求 2 3 硬件兼容性 2 4 关键特性 2 4 1 openEuler 22 03 LTS基于 Linux Kernel 5 10 内核构建 在进程
  • obsidian上手使用

    前言 我之前一直使用的是typora typora付费后就没有使用过了 后面就一直找markdown编辑器 在一次网课中我发现了老师用的网页富文本编辑器非常不错 这样我认识了语雀 语雀的文本编辑体验确实非常的不错 还可以在笔记里添加思维导图
  • 使用 SpringBoot 访问 MySQL 数据库

    一 目标 创建一个 MySQL 数据库 构建一个 Spring 应用程序 并将其连接到新创建的数据库 二 准备工作 1 最喜欢的文本编辑器或 IDE 2 Java 17或更高版本 3 Gradle 7 5 或Maven 3 5 三 初始化项
  • 使用Python制作酷炫的二维码

    参考 https www cnblogs com zhuwjwh p 11401312 html 制作动图二维码只需要原始图像是动图就可以哦 制作动图可以参考我之前的博客
  • 量化编程环境python库安装包

    必装工具包 1 ccxt conda没有 2 pandas 3 pathos 并发计算 conda没有 4 websocket 获取实时数据 conda没有 5 ntplib 用于时间校对 conda没有 6 cryptography 加密
  • Qt中 gui 模块和 widgets 模块的区别

    作者 billy 版权声明 著作权归作者所有 商业转载请联系作者获得授权 非商业转载请注明出处 简述 在Qt5下 QWidget系列从QtGui中被剥离出去 成为单独的QtWidget模块 随着Qt Quick2的引入 QtDeclarat
  • 【JavaScript】js继承

    es6 extends继承 原型式继承 构造函数继承 组合式继承 一 es6 extends继承 scala复制代码 class Child extends Parent constructor super this name 张三 let
  • Java课程设计之学习成绩管理系统

    package System import java awt import java awt event import java io import javax swing import javax swing table Abstract
  • JavaScript的slice()方法最详解

    JavaScript slice 方法怎么用 最详尽最易懂的讲解 1 JavaScript slice 方法的定义 slice 方法可提取字符串的某个部分 并以新的字符串返回被提取的部分 2 1 JavaScript slice 方法的语法
  • 基于LLMs的多模态大模型(Flamingo, BLIP-2,KOSMOS-1,ScienceQA)

    前一篇博客已经整理了不训练视觉模型的文章们 基于LLMs的多模态大模型 Visual ChatGPT PICa MM REACT MAGIC 本篇文章将介绍一些需要训练视觉编码器来适配多模态大模型的工作们 这也是目前最为流行的研究思路 其实
  • 2022 如何在 GitHub 上搭建个人网站(github.io)

    前言 目前 想要搭建自己的项目演示 又想要免费的服务 这时就可以使用 GitHub 提供的免费Pages服务 github io 前置 有GitHub账号 熟练使用git版本管理 成果展示 步骤 第一步 新建仓库 在GitHub上 创建一个
  • 下一步准备给自研引擎换皮

    抄完osg osgearth 鬼火引擎最低版本 以及ogre的大部分后 看到消息处理都通过窗口 突然顿悟 引擎都是类似的 下一步给自研引擎换皮 全换成ogre的皮 渲染流程类似osg的 多线程渲染 无非就是在哪个线程wglMakeCurre
  • 云原生热门话题|什么是可观测性-Observability

    code杂坛 关注一线大厂 互联网时讯 各技术栈 产品 开源社区 等最新讯息 1 可观测性引入 可观测性 术语源于几十年前的控制理论 在许多实际问题中 控制系统的状态变量不是由直接测量得到的 而是通过某种观测方法得到的 由某种观测系统所得到
  • 深大自考本科所需课程

    自考本科需要通过课程 网络经济与企业管理 数据结构导论 运筹学基础 信息资源管理 中国近代史纲要 计算机原理 马克思主义基本原理概论 数据库系统原理 管理经济学 软件开发工具 C 程序设计 英语2 操作系统概论 管理信息系统 计算机网络原理
  • 【OpenCV学习笔记】【编程实例】五 (霍夫圆检测)

    GetCircle cpp 定义控制台应用程序的入口点 圆形检测代码demo 载入数张包含各种形状的图片 检测出其中的圆形 include cv h include highgui h include
  • 排队论(Queuing Theory)

    目录 简介 一 基本概念 1 1 排队过程的一般表示 1 2 排队系统的组成和特征 1 2 1 输入过程 1 2 2 排队规则 1 2 3 服务过程 1 3 排队模型的符号表示 1 4 排队系统的运行指标 二 输入过程与服务时间的分布 2