算法高级(39)-坐电梯时情不自禁想起的电梯调度算法实现原理

一、引言

现代社会中,不管你是在北上广、北海道、新加坡,或者是三四五六七八线的小城市,凡是有点规模的地方,高楼大厦都是比比皆是的。而在上下楼的时候,不可避免的会跟电梯打交道。而一般情况你也很少能心平气和地等电梯,尤其是在赶时间的时候。

每天早上,那些还差5分钟就要迟到的程序员朋友们,在等电梯时,一般都会做两件事:

  1. 在心里不停骂电梯慢。
  2. 在心里暗算着电梯调度该如何优化。

前者可能是写字楼里上班族惯有的精神类疾病,但后者肯定是程序员的职业病。

说起电梯调度算法,我觉得还是可以给大家科普一下,好为大家在等电梯之余,打发时间而做出一点贡献。

二、概念

电梯调度算法,是一种计算电梯使用的方法。在工程上,电梯调度算法也指磁盘的扫描调度算法,是计算机磁盘驱动调度的一种方法。本文所指的电梯调度算法均参考各种硬盘换道算法(操作系统原理见)。

电梯按钮功能分析

电梯(升降盒)上下来回地运动,电梯内部有一些按钮,每一个按钮代表一层楼,当按下按钮时,按钮的灯亮。电梯沿某一方向运动,在将要到达某一层楼时,实时监控器判断电梯内是否有乘客要在此层楼下电梯,若有,则发送信号给电梯升降架,让其减速,同时让电梯在此层楼的电梯入口处平稳地停下,电梯停下后,实时监控器让电梯内相应的按钮灯灭,让乘客出电梯,然后关闭电梯门,而且继续朝原方向运动,直至到达当前运动方向上,有乘客要求到达的最后一层楼为止(即如:若该建筑物有50层,电梯当前正向上运动,若有乘客要求到达的最高楼层为30层,则电梯运动到30层之后,若30层以上没有乘客发出请求,则电梯可根据电梯内是否“有人”而向下运动或停止)。

除底层和顶层只有一个按钮外,每个楼层有两个按钮,分别指示上楼和下楼请求,当按下后,按钮灯亮,并向实时监控器发送请求,实时监控程序负责判断乘客的上下楼请求是否与电梯的当前运动方向一致,若不一致,则暂不受理此请求,此时按钮灯继续亮;若一致,则实时监控器将相应的上下请求按钮灯熄灭,并让电梯平稳地停在此层楼的电梯入口处,让相应的乘客入电梯,而后继续朝原方向运动。若同时有两层或两层以上的楼发出请求,产生了冲突,则实时监控器调用冲突处理器进行抉择,受理其中的一个请求,并负责将各请求上下楼的按钮灯熄灭。

三、基本的电梯调度算法

1.传统电梯调度算法

1.1 先来先服务算法(FCFS)

先来先服务(FCFS-First Come First Serve)算法,是一种随即服务算法,它不仅仅没有对寻找楼层进行优化,也没有实时性的特征,它是一种最简单的电梯调度算法。

它根据乘客请求乘坐电梯的先后次序进行调度。此算法的优点是公平、简单,且每个乘客的请求都能依次地得到处理,不会出现某一乘客的请求长期得不到满足的情况。

这种方法在载荷较轻松的环境下,性能尚可接受,但是在载荷较大的情况下,这种算法的性能就会严重下降,甚至恶化。

人们之所以研究这种在载荷较大的情况下几乎不可用的算法,有两个原因:

  • 任何调度算法在请求队列长度为1时,请求速率极低或相邻请求的间隔为无穷大时使用先来先服务算法既对调度效率不会产生影响,而且实现这种算法极其简单。

  • 先来先服务算法可以作为衡量其他算法的标准。

1.2 最短寻找楼层时间优先算法(SSTF)

最短寻找楼层时间优先(SSTF-Shortest Seek Time First)算法,它注重电梯寻找楼层的优化。

最短寻找楼层时间优先算法选择下一个服务对象的原则是最短寻找楼层的时间。

这样请求队列中距当前能够最先到达的楼层的请求信号就是下一个服务对象。

在重载荷的情况下,最短寻找楼层时间优先算法的平均响应时间较短,但响应时间的方差较大,原因是队列中的某些请求可能长时间得不到响应,出现所谓的“饿死”现象。

1.3 扫描算法(SCAN)

扫描算法(SCAN) 是一种按照楼层顺序依次服务请求,它让电梯在最底层和最顶层之间连续往返运行,在运行过程中响应处在于电梯运行方向相同的各楼层上的请求。

它进行寻找楼层的优化,效率比较高,但它是一个非实时算法。扫描算法较好地解决了电梯移动的问题,在这个算法中,每个电梯响应乘客请求使乘客获得服务的次序是由其发出请求的乘客的位置与当前电梯位置之间的距离来决定的。

所有的与电梯运行方向相同的乘客的请求在一次电向上运行或向下运行的过程中完成,免去了电梯频繁的来回移动。

扫描算法的平均响应时间比最短寻找楼层时间优先算法长,但是响应时间方差比最短寻找楼层时间优先算法小,从统计学角度来讲,扫描算法要比最短寻找楼层时间优先算法稳定。

1.4 LOOK 算法

LOOK 算法是扫描算法(SCAN)的一种改进。对LOOK算法而言,电梯同样在最底层和最顶层之间运行。但当 LOOK 算法发现电梯所移动的方向上不再有请求时立即改变运行方向,而扫描算法则需要移动到最底层或者最顶层时才改变运行方向。

1.5 SATF 算法

SATF(Shortest Access Time First)算法与 SSTF 算法的思想类似,唯一的区别就是 SATF 算法将 SSTF 算法中的寻找楼层时间改成了访问时间。这是因为电梯技术发展到今天,寻找楼层的时间已经有了很大地改进,但是电梯的运行当中等待乘客上梯时间却不是人为可以控制。SATF 算法考虑到了电梯运行过程中乘客上梯时间的影响。

2.实时电梯调度算法

2.1 最早截止期优先调度算法

最早截止期优先(EDF-Earliest Deadline First)调度算法是最简单的实时电梯调度算法,它的缺点就是造成电梯任意地寻找楼层,导致极低的电梯吞吐率。它与 FCFS 调度算法类似,EDF 算法是电梯实时调度算法中最简单的调度算法。它响应请求队列中时限最早的请求,是其它实时电梯调度算法性能衡量的基准和特例。

2.2 SCAN-EDF 算法

SCAN-EDF 算法是 SCAN 算法和 EDF 算法相结合的产物。SCAN-EDF 算法先按照 EDF 算法选择请求列队中哪一个是下一个服务对象,而对于具有相同时限的请求,则按照 SCAN 算法服务每一个请求。它的效率取决于有相同 deadline  的数目,因而效率是有限的。

2.3 PI 算法

PI(Priority Inversion)算法将请求队列中的请求分成两个优先级,它首先保证高优先级队列中的请求得到及时响应,再搞优先级队列为空的情况下在相应地优先级队列中的请求。

2.4 FD-SCAN 算法

FD-SCAN(Feasible Deadline SCAN)算法首先从请求队列中找出时限最早、从当前位置开始移动又可以买足其时限要求的请求,作为下一次 SCAN 的方向。并在电梯所在楼层向该请求信号运行的过程中响应处在与电梯运行方向相同且电梯可以经过的请求信号。这种算法忽略了用 SCAN 算法相应其它请求的开销,因此并不能确保服务对象时限最终得到满足。

四、电梯调度算法进阶及优化

但是并不是说目前电梯调度只发展到这个层次。目前电梯的控制技术已经进入了电梯群控的时代。随着微机在电梯系统中的应用和人工智能技术的发展,智能群控技术得以迅速发展起来。

由此,电梯的群控方面陆续发展出了一批新方法,包括:基于专家系统的电梯群控方法、基于模糊逻辑的电梯群控方法、基于遗产算法的电梯群控方法、基于胜景网络的电梯群控方法和基于模糊神经网络的电梯群控方法。

甚至于我在知网还找到一篇研究电梯调度算法的硕士论文:新一代电梯的调度算法研究。看看人家写一篇电梯算法就研究生毕业了哦。

一些优化:

这两年,我发现电梯还是越来越智能了,也有了一些更骚的操作,分享如下:

  1. 电梯分奇偶数楼层停。
  2. 不同的电梯分高低层停。
  3. 业主、酒店刷卡到自己楼层。不刷卡还按不了按钮呢!

经过我的体验,以上几种优化,电梯的运行效率还是提升了很多的呢。还能防火防盗防隔壁老王,一举多得。

当然,真正的人工智能AI电梯控制算法,需要人脸识别:识别领导等电梯。那就非我等凡人能触及的了。再说大部分时候,领导都是走专梯的,平时你也碰不到。

五、一道面试题

有一个写字楼有 28 层,每层有 4 个区,每个区有 8 个办公室,有 7 个电梯,每天早高峰有 1 万人上班。怎么做能以最快的速度将早高峰的人送到他们的楼层?(20 分) 1.请做出一些假设 2.请描述你的算法 3.请仿真并实现你的算法 4.请计算出需要的时间。

还来一道生活小常识:住在一楼的住户要不要交电梯维护费呢?此题与编程无关,纯粹考你生活常识。

据说电梯程序完全搞懂 可以做到码农顶尖了,够硬核!


我的微信公众号:架构真经(关注领取免费资源)

参考文章

  1. https://blog.csdn.net/gitchat/article/details/80202416
  2. https://blog.csdn.net/li4951/article/details/7486092
  3. https://baike.baidu.com/item/%E7%94%B5%E6%A2%AF%E8%B0%83%E5%BA%A6%E7%AE%97%E6%B3%95/1046772
  4. http://xuewen.cnki.net/CMFD-2010187172.nh.html
  5. http://d.old.wanfangdata.com.cn/Periodical/dzgcs199908008
  6. https://exp.newsmth.net/topic/70ca4df7e734b5f422bdd768978e3ca0
  7. https://www.v2ex.com/t/383855

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/252652.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

电梯调度

在像芝加哥,纽约,东京,新加坡,香港等大城市里,每天都会有上百万的人通过电梯离开他们的大楼。但是我们却很少考虑电梯是如何调度来提供服务的,尤其是在人流高峰期,这个时候办公楼里的大多数人都…

电梯调度算法

磁盘是一种高速、大容量、旋转型、可直接存取的存储设备。它作为计算机系统的辅助存储器,担负着繁重的输入输出任务、在多道程序设计系统中,往往同时会有若干个要求访问磁盘的输入输出请求等待处理,这时我们就需要采用一种合适的调度算法来使…

苹果主屏幕按钮怎么设置_苹果手机屏幕变大怎么恢复

如果苹果手机屏幕放大起来,其实只要同时使用三个手指快速连续点击手机屏幕两次,手机界面就会恢复正常。还可以在【设置】-【通用】-【辅助功能】中将【缩放】开关关闭。在【辅助功能】中【更大字体】选项中可以调整字体的大小。具体介绍如下:…

苹果主屏幕按钮怎么设置_Mac小技巧 Mac屏幕旋转怎么设置

相信不少的Mac用户在躺下看电子书或者电影的时候,都希望可以将Mac的电脑屏幕进行旋转!其实,这个操作是可以实现的呢!那么,你知道Mac屏幕旋转怎么设置吗?想要知道答案的话就快来阅读下面的文章吧&#xff01…

苹果屏幕旋转怎么设置_iPhone12屏幕供应商是谁 苹果12屏幕怎么查看是哪家

苹果iPhone12系列手机在10月份正式发售上市,今年的iPhone12全系列都使用了OLED屏幕,官方将这块屏幕称之为超视网膜 XDR 显示屏,那么今年的iPhone12系列屏幕供应商有哪些,怎么分辨自己手上的iPhone12屏幕来自哪家公司呢&#xff0c…

苹果手机投屏软件_苹果手机怎样投屏到笔记本?

注:本文转载自网络,不代表本平台立场,仅供读者参考,著作权属归原创者所有。我们分享此文出于传播更多资讯之目的。如有侵权,请在后台留言联系我们进行删除,谢谢! 经常用手机的小伙伴都知道&am…

怎么设置苹果手机的小圆点_苹果屏幕旋转怎么设置?关于苹果手机设置的一些小技巧...

苹果屏幕旋转怎么设置?在平常使用手机观看视频的时候,很多人希望手机屏幕可以自己旋转为横屏状态,在使用微信聊天的时候再自动转为竖屏,这种切换可以直接利用控制中心的一个功能来实现。 如何开启苹果手机的屏幕旋转?首…

苹果屏幕使用时间怎么设置_苹果手机屏幕不能旋转怎么办

很多刚刚接触苹果手机的人,可能不知道怎么使用苹果手机。那么苹果手机屏幕不能旋转怎么办呢?下面就让小编来告诉大家吧,欢迎阅读。 1、苹果手机页面未锁定的情况下从屏幕底端向上滑动,弹出小界面窗口。 2、可以看到小窗口顶部左端…

linux屏幕旋转后触控不准,手机重力感应失效解决方法 不能自动旋转屏幕怎么设置...

如今手机已经成为人们生活中必不可少的一个工具了,在使用过程也常常会遇到各种各样的问题,比如当手机重力感应失效的时候应该怎么解决呢,手机不能自动旋转屏幕要怎么设置,针对这个问题下面就为大家带来最新解决方法,希…

苹果6怎样打开html,苹果6屏幕旋转怎么设置 怎么开启和关闭【图文】

手机在使用的过程中,通常都会有两种状态,横屏与竖屏,大家的使用习惯不一样,所喜欢的状态也不一样,而且手机都会有屏幕自动旋转的情况,它会根据手机的摆放状态自己切换,比较方便大家使用&#xf…

会员管理系统,建议收藏!

你见过会员管理系统吗?在一些线下的美容院,健身房,理发店,往往会有办理会员这样的需求,所以会员管理系统应运而生。那会员管理系统有哪些作用呢? 会员卡:无需填写信息、无需实体会员卡&#xf…

会员卡系统的管理运营

下面的是会员系统的源代码和DOS命令的运行

会员卡应用管理系统源码 支持收银+积分管理+商城营销功能 含详细搭建教程

分享一个会员卡应用管理系统源码,收银积分管理商城营销系统源码,含完整的程序包和搭建教程。 系统功能一览: 1、精简强悍,会员卡,积分,在线充值,商家核销,在线下单,优惠…

C语言:会员管理系统

会员信息包括:会员号(6位数,唯一),姓名,身份证号,联系电话,状态(1表示正常,0表示挂失)。 会员管理包括:会员的添加、删除、修改&#…

云上铺会员管理系统支持什么类型会员卡?

最近很多打算购买我们系统的客户都在问我们,云上铺到底支持什么会员卡,今天趁这个机会专门给大家讲一下。 云上铺会员管理系统,作为一款独立开发设计的SAAS会员管理系统,广泛适用于美容美发,汽车美容,服装…

C语言 会员管理系统

大一上学期期末项目设计; 思路参考:【千锋教育新版C语言程序设计视频教程(适合自学,c语言初学者入门教程)】 https://www.bilibili.com/video/BV1id4y1375a/?p119&share_sourcecopy_web&vd_sourcea6401c9820…

微信会员卡管理系统会员充值说明

云上铺微信会员卡管理系统会员充值即会员卡储值进行余额消费一种操作。 基础操作:点击【消费收银】→【会员充值】,显示有【会员充值/扣款/转账/提现】等业务,如下图所示: 会员充值必须先选择会员信息,输入会员卡号,或…

超市VIP卡管理系统

好久没有碰VS了。。。只好自己找个项目练手。 今天找了个练习的项目,超市VIP卡管理系统。 拿到手的项目需求就这么点。 (1) 会员卡使用磁卡,允许手工输入卡号和扫描器输入两种方式。会员卡号的长度为10位,前两位是各分…

自己开店怎么办会员卡-云上铺会员管理系统

现在的生意是越来越不好做,很多实体商家为了增加门店人气策划了很多引流活动。刚开始人气虽然上涨得很快,但客户的流失率也非常的高。因此,实体商家希望通过会员卡来留住消费的客户,但开店办会员的会员卡怎么办呢? ​ …