- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
机场航空管制模拟实验报告
实验题目
假设机场有一条跑道,每架飞机需花费一定时间着陆,花费一定时间起飞,飞机的起降满足一定的概率。一般来讲,机场存在两个队列,一个等待着陆的飞机队列和一个等待起飞 的飞机队列,同样等待时间下,等待着陆的飞机比准备起飞的飞机具有更高的优先级。试编 写程序模拟这个机场的运行。要求使用队列或优先队列实现;要求可以变换起飞和着陆频率 来模拟一天中的飞行高峰期和空闲期;要求可以改变着陆和起飞时间以模拟不同的效果。
实验内容分析
实验目的
实验模拟了机场的航空管制,通过程序,来模拟管理飞机的起飞与着陆。它要求我们考虑起飞与着陆的优先级不同,以及根据飞机起飞/着陆时间,起飞/着陆频率模拟机场一天的运营情况。并计算出跑道的繁忙程度、着陆飞机的总的等待时间和平均等待时间、起飞飞机的总的等待时间和平均等待时间, 计算每架飞机花费在一个队列中的平均时间。
内容分析
系统主要模拟了机场一天的运营。所以,需要一个计时器(以分钟计时)来计算机场的运营时间。同时,为了管理飞机的起飞与着陆,需要两个队列来存放着陆和起飞的飞机。
设计用户输入的数据为:机场开始、结束运营时间;高峰期开始、结束时间;空闲期开始、结束时间;着陆飞机最长等待时间;高峰期、空闲期以及一般时期每小时起飞、着陆的飞机数,飞机起飞、着陆需要的时间。
考虑到机场的高峰期,与空闲期,设计了 Workslot 类,设定不同时期的飞机起飞、着陆率。
设计 Timer 类,其主要方法是实现计时功能和返回当前工作时间。Plane 类主要功能是记录飞机开始等待时间,开始工作时间以及起飞、着陆所需时间。
飞机起飞/着陆都需要花费一定的时间,并不是马上就完成的。所以在起飞/着陆服务函数 中 , 不 仅 要 调 用 spend ( ), 还 需 要 判 断 takeoff/landing 是 否 结 束 。 当t.now-startworktimeworkTime 时, 说明飞机还在准备着陆/ 起飞, 占用了跑道。当t.now-startworktime==workTime 时,表示飞机着陆/起飞成功。调用 pop 方法,从队列中删除一架等待服务的飞机,并获取当前时间,减去飞机接受服务的时间,得到该飞机的等待服务时间。我们就可以计算出所有飞机的等待服务时间。
等待起飞/着陆队列总长度,等待服务总时间,以及服务起飞/着陆的飞机总数,我们就 可以得出起飞/着陆飞机的平均等待时间,平均等待队列长度。同时根据当天的的工作时间, 跑道的忙碌时间,可以计算得到跑道的繁忙程度。
程序基本流程
勒入相关数
勒入相关数招
设设起飞`若陆
率为忘峰期起
总、右陆率
设否起飞`蒂陆
率为空闲期起
从存陆率
设置起 总、若陆
率为一般则起
如荐陆率
起飞、若陆飞机
起飞、若陆飞机
进入起飞队列
起飞飞机起飞
图 1 实验基本流程
基本数据结构,类设计
类 Airport
输入 :
变量名
变量名
注释
Timer t;
计时器
Struct Busy b;
跑道是否忙碌
int takeoffTime;
飞机起飞所需时间
int landingTime;
飞机着陆所需时间
int startworkTime;
机场当天开始运营时间
int endworkTime;
机场当天结束运营时间
Class Workslot highslot;
高峰时间段
Class Workslot lowslot;
空闲时间段
Class Workslot otherslot;
一般时间段
dequePlane takeoffq;
等待起飞飞机队列
dequePlane landingq;
等待着陆飞机队列
int workTime;
跑道忙碌时间
int TwaitTime;
总起飞等待时间
int LwaitTime;
总着陆等待时间
int takeoffwaitTime;
所有起飞飞机总等待时间
int landingwaitTime;
所有着陆飞机总等待时间
int maxlandingwaitTime;
最大着陆等待时间
int intakeoffNum;
进入起飞队列飞机数
int inlandingNum;
进入着陆队列飞机数
int takeoffNum;
已经起飞飞机数
int landingNum;
已经着陆飞机数
int t_rate;
用来保存起飞速率
int l_rate;
用来保存着陆速率
输出
t.now
变量名
备注
当前时间
int takeoffNum int landingNum int intakeoffNum int inlandingNum
dequePlane takeoffq dequePlane landingq
double(workTime/(endworkT
原创力文档


文档评论(0)