Answered step by step
Verified Expert Solution
Link Copied!

Question

1 Approved Answer

Airport has one runway, which each airplane takes landingTime minutes to land and takeOffTime minutes to take off, and that on the average, takeOffRate planes

Airport has one runway, which each airplane takes landingTime minutes to land and takeOffTime minutes to take off, and that on the average, takeOffRate planes take off and landingRate planes land each hour.

Assume that the planes arrive at random instants of time. Delays make the assumption of randomness quite reasonable.

There are 2 types of queues: a queue of airplanes waiting to land AND

a queue of airplanes waiting to take off.

Since it is more expensive to keep a plane airborne than to have one waiting on the ground, we assume that the airplanes in the landing queue have priority over those in the takeoff queue.

Write Java program to simulate Airport's operation. You might assume a simulated clock that advances in one-minute intervals. For each minute, generate 2 random numbers: If the first is less thanlandingRate/60, a "landing arrival" has occurred and is added to the landing queue; and if the second is less than takeOffRate/60, a "takeoff arrival" has occurred and is added to the takeoff queue.

Next, check whether the runway is free. If it is free, first check whether the landing queue is nonempty, and if so, allow the first airplane to land; otherwise, consider the takeoff queue.

Have the program calculate the average queue length and the average time that an airplane spends in a queue. You should also consider the effect of varying arrival and departure rates to simulate the prime and slack times of day, or what happens if the amount of time to land or take off is increased or decreased.

CSC 236 Queue Lab Instructions - do an array-based implementation of a queue

Create class ArrayQueue

default constructor

isEmpty( )

count( )

peek( )

dequeue( )

enqueue( )

Create class MCCAirport

final double LANDING_TIME = 3;

final double TAKE_OFF_TIME = 2;

final double LANDING_RATE= 10;

final double TAKE_OFF_RATE = 10;

final int ITERATIONS = 1440;

//use a random generator

import java.util.Random;

Random generator = new Random(System.currentTimeMillis( ));

Print out the following:

values should be 6 places to the right of the decimal

Average landing queue length:

Average take off queue length:

Average landing queue time:

Average take off queue time:

Step by Step Solution

There are 3 Steps involved in it

Step: 1

blur-text-image

Get Instant Access to Expert-Tailored Solutions

See step-by-step solutions with expert insights and AI powered tools for academic success

Step: 2

blur-text-image_2

Step: 3

blur-text-image_3

Ace Your Homework with AI

Get the answers you need in no time with our AI-driven, step-by-step assistance

Get Started

Recommended Textbook for

Introduction to Wireless and Mobile Systems

Authors: Dharma P. Agrawal, Qing An Zeng

4th edition

1305087135, 978-1305087132, 9781305259621, 1305259629, 9781305537910 , 978-130508713

Students also viewed these Programming questions