ASSESSMENT 2: PROGRAMMING ASSIGNMENT

Week 10, November 7th

Due: End of Week 4, Sunday 11.59 pm   

Weighting: 40%

Purpose

The purpose of this assessment is to create a fully functional simulation of a more complex system. Building simulations is one of the key objectives of this course. You will need to be able to do this in an industry or government job working in decision sciences. Building a simulation is also the best way to absorb and gain a deep understanding of the ideas and topics that are discussed in this course. Even if you are just managing simulations projects, you should have some experience in creating the simulation itself.

This is quite a large and difficult task, but the assessment will provide considerable structure.

Outcomes

This Task addresses the following Course Learning Outcomes:

  1. Communicate how randomness and controlled variation can be used to model complex systems in a range of application domains such as industry, health, and transportation.
  2. Create a model of a real-world problem specified in words and implement it as a discrete-event simulation.
  3. Validate results from a discrete-event simulation.

Scenario

You will be simulating a factory production line that constructs lawnmowers to order.

The construction process involves a small number of main steps. Each is a series of tasks, but you will only model the main bottleneck task. Presume that the mower is built from a series of prefabricated parts (the engine, the blades, the frame and so on).

The bottleneck in this process is that, in this factory, there is only one machine that can properly fasten the blades to the motor as they have to be attached securely to make them safe.

Unfortunately, the blade-fitting machine is old and breaks down sometimes. If this happens, it is out of service while it is being repaired, and any orders will have to wait.

Assumptions

You should assume the following:

  • Orders for new lawnmowers are processed in a FIFO manner and there can be an unlimited number waiting.
  • Times: all times are independent and
    • the inter-arrival times between orders are independent and exponential with a mean of one hour.
    • the time to construct a lawnmower from parts is deterministic with a time of 45 minutes.
    • the time between breakdowns of the blade-fitting machine is exponential with a mean of two days as measured from the last time it was repaired.
    • the time to fix the machine when it breaks is exponential with a mean time of three hours.
  • There is an unlimited number of parts available to construct new lawnmowers.
  • If the blade-fitting machine breaks down while constructing a lawnmower, the work already completed on that lawnmower is interrupted but ‘saved’. That is, the total time to complete the lawnmower is the construction time, plus any repair times that interrupt construction (it is technically possible that more than one breakdown could occur during the same lawnmower build).

Questions

The factory owner wants to know how to improve their factory, the most obvious change would be to buy a replacement machine to attach the blades. The new machine would break down less often, so the mean time between breakdowns will be

longer. They would like to assess the business case for such a purchase, i.e., what would the reduction in waiting time for orders be, and what percentage of orders would be interrupted with the new machine. Therefore, the questions they would like to answer are:

  • How much production time is lost to repairs?
  • How many lawnmowers have their construction interrupted due to a breakdown and repair?
  • How long do orders wait in this system before being completed, and how much would this be improved if the time between breakdowns was extended?

Your Task

This assessment is scaffolded into three parts:

  • Part 1: Conceptual model (Module 2)
  • Part 2: Functionality (Module 3)
  • Part 3: Programming (Module 4)

The details of each part are outlined in Appendix 1–3 of this brief, and can also be found at the end of Module 2, Module 3 and Module 4 of this course.

Requirements

You will be assessed on three components of this work:

  • Component 1: Conceptual model—your ability to formulate the model.
  • Component 2: Functionality—your ability to write code to create a simulation, and ensure the sub-components of it work.
  • Component 3: Programming style—your ability to write your program according to the specifications and general style guidelines for good code.

You are required to submit:

  • a PDF document showing your schematic, state diagram, flow chart and any other documentation you created.
  • two .jl files with your code for implementing the discrete-event simulation.
  • a pair of data files (an entities and a state file) produced from your simulation with seed=1 and where the simulation was stopped at time T=1000.0.

Consult the assessment rubric when preparing your submission. Questions can be posted to the relevant assessment Discussion Board.

Grading Criteria

This assessment is worth 40% of your overall grade. Refer to the attached rubric for detailed information on the grading criteria for this assessment.

Rubric: Assessment 2: Programming Assignment

Component 1: Conceptual Model
CriteriaRatingsPoints
Task 1 Draw a schematic of the systemPoints: 2.0 Name: Full pointsPoints: 1.0 Name: Partial pointsPoints: 0.0 Name: No points2 pts
Your schematic correctly shows the standard queue components and the breakdown-repair cycle in some way.You have correctly shown either the standard queue components or the breakdown-repair cycle.Assessment requirements for this step have not been met.
Task 2 Describe the state(s) of the systemPoints: 2.0 Name: Full pointsPoints: 1.0 Name: Partial pointsPoints: 0.0 Name: No points2 pts
You have correctly described the state(s) of the system.You have partially described the state(s) of the system.Assessment requirements for this step have not been met.
Task 3 Determine the entities in the system in relation to the statePoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
You have correctly determined the entities in the system.Assessment requirements for this step have not been met.
Task 4 List the types ofPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
events in your model   
   
describe howYou have correctly listed the types of events in your model.Assessment requirements for this step have not been met.
each event   
changes the   
state of the   
system   
describe the   
new events that   
may be created   
as a result of   
this event   
Task 5 Draw a flow chartillustrating yourPoints: 3.0 Name: Full pointsPoints: 2.0 Name: Partial pointsPoints: 1.0 Name: Partial pointsPoints: 0.0 Name: No points3 pts
     
     
simulation structureYour flow chart: (i) is a valid flow chart for this model, (ii) does not have any dead ends (except for the intended termination step); and (iii) includes vacation (machine breakdowns).You have successfully completed two of the following: (i) a valid flow chart, (ii) there are no dead ends (except for the termination step); and (iii) included vacation (machine breakdowns).You have successfully completed one of the following: (i) correctly drawn a valid flow chart, (ii) there are no dead ends (except for the termination step); and (iii) included vacation (machine breakdowns).Assessment requirements for this step have not been met.
Section total:9 pts
Component 2: Functionality
CriteriaRatingsPoints
Task 1 Refine your schematic of the system (see Component 1: Task 1 for marks) 
Task 2 Draw a state-diagram of the systemPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
Your state diagram shows the correct state transitions.Assessment requirements for this step have not been met.
Task 3 Write code to implement a discrete-event simulation of the system.
Output state file: InitialisationPoints: 2.0 Name: Full pointsPoints: 1.0 Name: Partial pointsPoints: 0.0 Name: No points2 pts
Your initialisation creates a valid starting state with an arrival at time 0.0 and a breakdown at time 150.0.You have done one of the following: (i) created a valid starting state with an arrival at time 0.0, and (ii) created a valid starting state with a breakdown at time 150.0.Assessment requirements for this step have not been met.
Output state file: run! InitialisationPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
Your run! function can be called with the prescribed inputs and does not crash.Assessment requirements for this step have not been met.
Output state file: Random number generatorsPoints: 4.0 Name: Full pointsPoints: 3.0 Name: Partial pointsPoints: 2.0 Name: Partial pointsPoints: 1.0 Name: Partial pointsPoints: 0.0 Name: No points4 pts
Your random number generators create suitable random numbers for: (i) inter-arrival times, (ii) construction times, (iii) breakdown times, and (iv) repair times.Your random number generators have created suitable random numbers for three of the following: (i) inter-arrival times, (ii) construction times, (iii) breakdown times, and (iv) repair times.Your random number generators have created suitable random numbers for two of the following: (i) inter-arrival times, (ii) construction times, (iii) breakdown times, and (iv) repair times.Your random number generators have created suitable random numbers for one of the following: (i) inter-arrival times, (ii) construction times, (iii) breakdown times, and (iv) repair times.Assessment requirements for this step have not been met.
Output state file: CSV format and metadataPoints: 2.0 Name: Full pointsPoints: 1.0 Name: Partial pointsPoints: 0.0 Name: No points2 pts
Your output state file conforms to the correct CSV format and contains satisfactory metadata.You have done one of the following: (i) created an output state file that conforms to the correct CSV format, (ii) created an output state file that contains satisfactory metadata.Assessment requirements for this step have not been met.
Output state file: StatesPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
Your output state file contains states that are sequentially ordered in increasing time.Assessment requirements for this step have not been met.
Output state file: Event IDsPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
Your output state file contains unique event IDs.Assessment requirements for this step have not been met.
Output state file: Arrival and breakdownPoints: 2.0 Name: Full pointsPoints: 1.0 Name: Partial pointsPoints: 0.0 Name: No points2 pts
Your output state file contains an arrival at time 0.0 and breakdown time at 0.0.You have done one of the following: (i) created an output state file that contains an arrival time at 0.0, and (ii) created an output state file that contains a breakdown time at 0.0.Assessment requirements for this step have not been met.
Output state file: QueuePoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
Your output state file shows that the queue grows during the breakdown.Assessment requirements for this step have not been met.
Output state file: EventsPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
Your output state file shows that the event list always has 1 or 2 events in it.Assessment requirements for this step have not been met.
Output state file: Machine statusPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
Your output state file shows that the machine status is 0 normally and 1 after the start of a breakdown up until a repair.Assessment requirements for this step have not been met.
Output entity file: CSV format and metadataPoints: 2.0 Name: Full pointsPoints: 1.0 Name: Partial pointsPoints: 0.0 Name: No points2 pts
Your output entity file conforms to the correct CSV format and contains satisfactory metadata.You have done one of the following: (i) created an output entity file that conforms to the correct CSV format, and (ii) created an output entity file that contains satisfactory metadata.Assessment requirements for this step have not been met.
Output entity file: TimesPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
Your output entity file contains arrival times, start service times and completion times that are in increasing order.Assessment requirements for this step have not been met.
Output state file: Event IDsPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
Your output entity file contains entities with unique IDs.Assessment requirements for this step have not been met.
Section total:21 pts
Component 3: Programming Style
CriteriaRatingsPoints
Specification 1 File names, functions and data structuresPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
Your file names are correct, and the correct code is in the correct place (functions and data structures in particular).Assessment requirements for this step have not been met.
Specification 2 PackagesPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
Your file names are correct, and the correct code is in the correct place (functions and data structures in particular).Assessment requirements for this step have not been met.
Specification 3 Data structuresPoints: 3.0 Name: Full pointsPoints: 2.0 Name: Partial pointsPoints: 1.0 Name: Partial pointsPoints: 0.0 Name: No points3 pts
You have three data structures declared in a valid manner with appropriate constructors.You have two of the three data structures declared in a valid manner with appropriate constructors.You have one of the three data structures declared in a valid manner with appropriate constructors.Assessment requirements for this step have not been met.
Specification 3 Event typesPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
You have included concrete event types.Assessment requirements for this step have not been met.
Specification 4 Machine breakdownsPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
You have included extra delays for machine breakdowns in the update function for breakdowns.Assessment requirements for this step have not been met.
Specification 5 Update functionsPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
You have included update functions for four types of events.Assessment requirements for this step have not been met.
Specification 6 ParametersPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
Your code has a data structure for passing parameters.Assessment requirements for this step have not been met.
Specification 7 ConstructorPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
You have included a random number generator constructor.Assessment requirements for this step have not been met.
Specification 7 SpecificationPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
You have included an initialise function matching specification.Assessment requirements for this step have not been met.
Specification 8 run! functionPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
You have included a run! function that runs the simulation.Assessment requirements for this step have not been met.
Specification 9 Entities filePoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
Your program writes an entities file.Assessment requirements for this step have not been met.
Specification 9 State filePoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
Your program writes a state file.Assessment requirements for this step have not been met.
Specification 10 VariablesPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
You have not included any global variables.Assessment requirements for this step have not been met.
Specification 10 Variable namesPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
You have used meaningful variable names, with the exception of local variables with small scope.Assessment requirements for this step have not been met.
Specification 10 CommentsPoints: 2.0 Name: Full pointsPoints: 1.0 Name: Partial pointsPoints: 0.0 Name: No points2 pts
You have used comments efficiently and effectively.You have partially used comments efficiently and effectively.Assessment requirements for this step have not been met.
Specification 10 White spacePoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
You have used correctly and consistently used indentation and space to separate important components and expressions.Assessment requirements for this step have not been met.
Specification 10 Inefficient approachesPoints: 1.0 Name: Full pointsPoints: 0.0 Name: No points1 pt
You have used correctly and consistently used indentation and space to separate important components and expressions.Assessment requirements for this step have not been met.
Section total:20 pts
Assessment total:50 pts

Appendix 1

Part 1: Conceptual Model

In this part, you will consider the system model that you will be implementing.

The system

You will be simulating a factory production line that constructs lawnmowers to order.

The construction process involves a small number of main steps. Each is a series of tasks, but you will only model the main bottleneck task. You can presume that the mower is built from a series of prefabricated parts (the engine, the blades, the frame and so on).

The bottleneck in this process is that, in this factory, there is only one machine that can properly fasten the blades to the motor as they have to be attached securely to make them safe, so only one lawnmower can be made at once.

Unfortunately, the blade-fitting machine is old and breaks down sometimes. If this happens, it is out of service while it is being repaired, and any orders have to wait.

Assumptions

You should assume the following:

  • Orders for new lawnmowers are processed in a FIFO manner and there can be an unlimited number waiting.
  • Times: all times are independent and
    • the inter-arrival times between orders are independent and exponential with a mean of one hour
    • the time to construct a lawnmower from parts is deterministic with a time of 45 minutes
    • the time between breakdowns of the blade-fitting machine is exponential with a mean of two days as measured from the last time it was repaired
    • the time to fix the machine when it breaks is exponential with a mean of time three hours.
  • There is an unlimited number of parts available to construct new lawnmowers.
  • If the blade-fitting machine breaks down while constructing a lawnmower, the work already completed on that lawnmower is interrupted but ‘saved’. That is, the total time to complete the lawnmower is the construction time, plus any repair times that interrupt construction (it is technically possible that more

than one breakdown could occur during the same lawnmower build).

Questions

The factory owner wants to know how to improve their factory, the most obvious change would be to buy a replacement machine to attach the blades. The new machine would break down less often, so the mean time between breakdowns will be longer. They would like to assess the business case for such a purchase, i.e., what would the reduction in waiting time for orders be, and what percentage of orders would be interrupted with the new machine. Therefore, the questions they would like to answer are:

  • How much production time is lost to repairs?
  • How many lawnmowers have their construction interrupted due to a breakdown and repair?
  • How long do orders wait in this system before being completed, and how much would this be improved if the time between breakdowns was extended?

Tasks for Part 1

Your assessment will require you to write code to simulate the system. However, writing the code can wait until next week when you will have seen more examples and been taught more of the tools required.

This week, before you commence coding you should perform a series of modelling tasks. This week’s tasks will prepare you for Part 2. Some of this week’s tasks will be assigned marks but some will be part of a larger task assigned marks in Part 2 and 3.

  1. Draw a schematic of the system. (2 marks)
  2. Describe the state(s) of the system. (2 marks)

Hint: What state details are needed to answer factory owner’s questions?

  • Determine the entities in the system in relation to the state. (1 mark)
  • List the types of events in your model (1 mark):
    • describe how each event changes the state of the system.
    • describe the new events that may be created as a result of this event.
  • Draw a flow chart illustrating your simulation structure. (3 marks)

At the end of Week 4, you will be required to submit a PDF document showing your schematic, flow chart and responses to these tasks.

Hint: You can create flow charts with the free diagram drawing tool Inkscape, but there are many other tools available for drawing connected series of boxes. Find a

tool you like. Also, your boxes and links don’t have to look exactly the same as mine, but they have to be: (i) clear and readable, and (ii) consistent.

Appendix 2

Part 2

In this part, you will start to program the model.

Reminder

The system to be modelled is described in Part 1.

Tasks for Part 2

  1. Refine your schematic of the system (see Part 1).
  2. Draw a state-diagram of the system. (see Part 1) (1 mark)
  3. Write code to implement a discrete-event simulation of the system.
    • The code will follow the style of the code presented in this module, used to implement the car park model. Use that code as a starting point, but make sure to customise it to this problem or you will get zero marks. (20 marks)
    • The process you need to follow is outlined below under the heading ‘Specification’. (20 marks)

By the end of this part, you should have a working simulation that can output results. In Part 3 you will test it and use it to create some data with a simulation harness.

At the end of Week 4, you will be required to submit a PDF document showing your schematic and state diagram, along with the flow chart from Part 1 and responses to these tasks. You will also be required to submit two .jl files with your code for implementing the discrete-event simulation from Task 3 above.

Specification

This week you will start coding your simulation. I will provide a good deal of the structure for this code because:

  • I want to help. There is a lot written below, but by following it carefully you will get a big start towards developing your simulation.
  • I want to make sure that everyone has a common starting point.
  • I want to make it easier to review and assess your progress by ensuring that everyone adopts the same basic structure for their implementation.

The last point is important. Part of your mark may be based on automated testing of your code. Hence you must set up your code in the manner given. Otherwise, you may lose marks for reasons that could be fixed with little effort.

Here are the required specification details:

  1. Your code must be included in a two stand-alone .jl files. These should be named:
    • factory_simulation.jl
    • factory_simulation_run.jl

The first file should contain all of your data structures and functions. The second file should initialise all variables to values you choose and run the main event loop.

Note that the second file is a temporary file. The second is for your own benefit, for the moment, to test your code. It will be replaced in Part 3 of this assessment with a simulation harness.

(1 mark)

  • You should use the standard packages that you have been using in this course. These include:
    • DataStructures
    • Distributions
    • StableRNGs

You may wish to use a small set of additional packages such as Dates or Printf. Do not use any packages other than these or those that have been discussed in the course.

(1 mark)

  • Your code must specify three data structures:
abstract type Event end mutable struct Entity … mutable struct State …”>

Each will contain fields as required. The state structure should contain any queues or lists required, for instance, the event list.

  • The Event type is an abstract type, which will have more sub-types for each event in your simulation, for instance: Arrival and Breakdown events.
    • The Entity event should contain fields to record important event times in the lifetime of the entity.
    • The State event will, as in the car park simulations, contain a time, event list (queue) and queues for all resources in the system. It will contain other details as needed, such as the state of repair of the machine and the number of events so far.

You should create convenience constructor functions for each of these types, that allow you to create an object when not all of its fields are known. For instance, a function State() that returns an initial system State variable with any required queues or lists created, but empty, and the clock time set to 0.0.

(4 marks)

Note that when the machine breaks down, the time of completion of the current lawnmower will be extended. That is, you need to change the time, i.e. the priority, of the corresponding departure event. You can modify the priority of an object in a priority queue in Julia as follows:

Note that the order of the two items in the queue has swapped. However, be careful if you also store the time of an event in the Event structure because that would not be updated in the code above.

(1 mark)

  • Your factory_simulation.jl code must have a set of update! functions with signatures:

function update!( S::State, R::RandomNGs, E::SomeEvent )

Each update function should process one of your event types so you will need one function per event type.

Each update function should modify the state S appropriately, including

  • adding any new events created from this one
  • moving any entities from queues to servers and so on.

These functions must not have side effects. That is, they should not write out any information to files, or interact with global variables. However, your functions may throw an error if the input is invalid.

These functions need not return anything, but sometimes it is useful for them to return a customer/order entity to the main loop in order to write out information about that.

(1 mark)

  • Your code should have a data structure for passing parameters:

(1 mark)

  • Your factory_simulation.jl code should have an initialise function that takes as input the parameters of the system and returns an initial system state and creates the random number generators you are going to use. In order to make your code easy to extend or modify, you will encapsulate these random number generators into structures that are easy to pass around.
struct RandomNGs rng::StableRNGs.LehmerRNG interarrival_time::Function construction_time::Function interbreakdown_time::Function

Your code will use four random number generators. Store these in another data structure:

rng = StableRNG(P.seed) interarrival_time() = rand(rng, Exponential(P.mean_interarrival)) construction_time() = P.mean_construction_time interbreakdown_time() = rand(rng, Exponential(P.mean_interbreakdown_time)) repair_time() = rand(rng, Exponential(P.mean_repair_time))

Your initialise function should create a set of random number generators to populate the above structure. Create an initialisation constructor function for RandomNGs using code similar to that below (the parameters used here to create these should come from variable P::Parameters).

Note that, although construction times are deterministic, you can use the same functional form to be consistent.

  • The initialisation function should also create a new system state and inject an initial arrival at time 0.0 and initial breakdown at time 150.0 minutes. The function should return the system state and the random number structure.

Therefore, your initialisation function should look like:

function initialise( P::Parameters ) R = RandomNGs( P ) # create the RNGs system = State() # create the initial state structure # add an arrival at time 0.0 t0 = 0.0 system.n_events += 1 # your system state should keep track of # events enqueue!( system.event_queue, Arrival(0,t0), t0) # add a breakdown at time 150.0 t1 = 150.0 system.n_events += 1 enqueue!( system.event_queue, Breakdown(system.n_events, t1 ), t1 ) return (system, R) end

This code presumes you have created appropriate constructors for the random number generators and system state as described above.

(2 marks)

  • Your code should include a run!(state::State, R::RandomNGs, T::Float64, fid_state::IO, fid_entities::IO) function. The inputs are:
    • state: a structure containing the system state;
    • R: a structure of type RandomNGs that contains your random variable generators;
    • T: a floating-point number stating how long to run the simulation
    • fid_state: a file-ID (an IO variable) for the file to which to output your event- based output; and
    • fid_entities: a file-ID (an IO variable) for the file to which to output your entity- based output.

The function should run the main simulation loop for time T. It should remove an event from the event list, call the appropriate function(s) to update the state and write any required output. This should be the function that writes any output when the code is performing correctly, but you may create some utility functions for writing data that are called by run! to make the run! function more readable.

The run! function should return the system state when the simulation finishes. (1 mark)

  • Your code must output two CSV files. The files should both commence with metadata (you can include this using comments preceded with a #).
time,event_id,event_type,length_event_list,length_queue,in_servi ce,machine_status

The first file should contain a time-ordered list of all events that are processed in the simulation. This should be written from the point of view before the event, for instance, you should report the system that an arriving customer sees immediately prior to their arrival. The CSV file should have columns titled:

  • The second file should contain a list of all entities that have completed service. The CSV file should have columns titled:

id,arrival_time,start_service_time,completion_time,interrupted                                                     

You will need to write and construct these CSV files line by line, but you can do this using either the CSV or the Printf package or using raw print statements.

(2 marks)

  • Your code must be written with good style. See Julia’s style guidelines for information, but in particular:
    • avoid global variables wherever possible (1 mark)
    • choose good variable names (1 mark)
    • use comments efficiently and effectively (2 marks)
    • use white space well (1 mark)
    • avoid very inefficient approaches (1 mark).

You should use your factory_simulation_run.jl to run this code and construct some tests. More detail of running the code and testing it will follow in Part 3.

Appendix 3

Part 3

In this part, you will test your implementation and make sure it can output results.

Reminder

The system to be modelled is described in Part 1 and builds on the code written in Part 2.

At the end this week, you will be required to submit:

  • a PDF document showing your schematic, state diagram, flow chart and responses to tasks in Part 1 and Part 2
  • two .jl files with your code for implementing the discrete-event simulation
  • a pair of data files (an entities and a state file) that you have produced from your simulation with seed=1 and where the simulation was stopped at time T=1000.0. Your tutor will check that these files came from your simulation.

When marking your assessment, your tutor will check the output of your code by running the code that you submit. This is the code you created in Part 2 and which you will now refine by completing the tasks outlined here.

Tasks for Part 3

Although you might not need to modify the code in factory_simulation.jl, you may need to modify it in response to bugs found in testing. The main tasks will be to verify that your code works correctly (as described in Module 3: Verification), and to construct a small simulation harness in which to run a set of comparison simulations (as described in Module 4: Tools to Automate Simulation). Following these steps will help ensure you get the maximum number of marks for the code you have written.

  • Test and verify your code.

When I run my version of this code with seed=1 for T=1000.0 minutes, I get the following sort of output:

  • The start of the state file showing the event-based output is as follows:
# file created by code in factory_simulation.jl
# file created on 2021-07-28 at 14:54:36
# parameter seed = 1
# parameter mean_interarrival = 60.0
# parameter mean_construction_time = 25.0
# parameter mean_interbreakdown_time = 2880.0
# parameter mean_repair_time = 180.0
40.499,3,Arrival,1,0,0,0
51.694,6,Arrival,2,0,1,0
65.499,7,Departure,2,1,1,0
90.499,10,Departure,2,0,1,0
117.235,8, Arrival,1,0,0,0
142.235,13,Departure,2,0,1,0
150.000,2,Breakdown,1,0,0,0
182.987,12, Arrival,1,0,0,1
# file created by code in factory_simulation.jl
# file created on 2021-07-28 at 14:54:36
# parameter seed = 1
# parameter mean_interarrival = 60.0
# parameter mean_construction_time = 25.0
# parameter mean_interbreakdown_time = 2880.0
# parameter mean_repair_time = 180.0 id,arrival_time,start_service_time,completion_time,interrupted 1,0.0,0.0,25.0,0 2,40.49940643026974,40.49940643026974,65.49940643026974,0 3,51.69359364153775,65.49940643026974,90.49940643026974,0 4,117.2350182717608,117.2350182717608,142.2350182717608,0

o The start of the entity file showing a list of entities with information output on departure is as follows:

  • Create a test harness that will:
    • run your code for 100 different seed values ranging from 1–100
    • run your code for a set of parameters specified in the following CSV file:
# parameters mean_interarrival,mean_construction_time,mean_interbreakdown_tim e,mean_repair_time 60.0,25.0,2880.0,180.0 “>

From these outputs, you would be able to inform the factory owner about their questions. Although you won’t need to answer these questions specifically, this next stage that you would take in the process will be addressed in Assessment 3.

Test Data

In order to help you test your program, I have provided some example output files.

  • state.csv
  • entities.csv
  1. If you have implemented your code exactly as I have specified, and used the same seed and random number generation, your output should look very, very similar (the only differences should be in details such as numbers of decimal points, white-spacing, or units such as hours or minutes).
  2. However, your code may result in some differences. Some are important and others less so. You need to be quite analytical to understand which. That is, what differences occur because of a minor change in the order of actions, and what differences are caused by bugs. If there are differences, you should create some of your own tests to understand what is different from my code.

Note that you can see the metadata in the files, and from that determine any parameters used.

Order Now

Get expert help for ASSESSMENT 2: PROGRAMMING ASSIGNMENT and many more. 24X7 help, plag-free solution. Order online now!

Universal Assignment (June 3, 2025) ASSESSMENT 2: PROGRAMMING ASSIGNMENT. Retrieved from https://universalassignment.com/assessment-2-programming-assignment/.
"ASSESSMENT 2: PROGRAMMING ASSIGNMENT." Universal Assignment - June 3, 2025, https://universalassignment.com/assessment-2-programming-assignment/
Universal Assignment October 18, 2022 ASSESSMENT 2: PROGRAMMING ASSIGNMENT., viewed June 3, 2025,<https://universalassignment.com/assessment-2-programming-assignment/>
Universal Assignment - ASSESSMENT 2: PROGRAMMING ASSIGNMENT. [Internet]. [Accessed June 3, 2025]. Available from: https://universalassignment.com/assessment-2-programming-assignment/
"ASSESSMENT 2: PROGRAMMING ASSIGNMENT." Universal Assignment - Accessed June 3, 2025. https://universalassignment.com/assessment-2-programming-assignment/
"ASSESSMENT 2: PROGRAMMING ASSIGNMENT." Universal Assignment [Online]. Available: https://universalassignment.com/assessment-2-programming-assignment/. [Accessed: June 3, 2025]

Please note along with our service, we will provide you with the following deliverables:

Please do not hesitate to put forward any queries regarding the service provision.

We look forward to having you on board with us.

Most Frequent Questions & Answers

Universal Assignment Services is the best place to get help in your all kind of assignment help. We have 172+ experts available, who can help you to get HD+ grades. We also provide Free Plag report, Free Revisions,Best Price in the industry guaranteed.

We provide all kinds of assignmednt help, Report writing, Essay Writing, Dissertations, Thesis writing, Research Proposal, Research Report, Home work help, Question Answers help, Case studies, mathematical and Statistical tasks, Website development, Android application, Resume/CV writing, SOP(Statement of Purpose) Writing, Blog/Article, Poster making and so on.

We are available round the clock, 24X7, 365 days. You can appach us to our Whatsapp number +1 (613)778 8542 or email to info@universalassignment.com . We provide Free revision policy, if you need and revisions to be done on the task, we will do the same for you as soon as possible.

We provide services mainly to all major institutes and Universities in Australia, Canada, China, Malaysia, India, South Africa, New Zealand, Singapore, the United Arab Emirates, the United Kingdom, and the United States.

We provide lucrative discounts from 28% to 70% as per the wordcount, Technicality, Deadline and the number of your previous assignments done with us.

After your assignment request our team will check and update you the best suitable service for you alongwith the charges for the task. After confirmation and payment team will start the work and provide the task as per the deadline.

Yes, we will provide Plagirism free task and a free turnitin report along with the task without any extra cost.

No, if the main requirement is same, you don’t have to pay any additional amount. But it there is a additional requirement, then you have to pay the balance amount in order to get the revised solution.

The Fees are as minimum as $10 per page(1 page=250 words) and in case of a big task, we provide huge discounts.

We accept all the major Credit and Debit Cards for the payment. We do accept Paypal also.

Popular Assignments

NUR1120 | Burden of Disease and Health Equity

Assessment Item Task SheetCourse code andnameNUR1120 | Burden of Disease and Health Equity Assessment itemand nameAssessment Three | ReportDue date and time Week 11 | 22/04/2025 at 2359 hours AESTLength 1400 words (+/- 10% in each section) – includes in-text references, but not reference list.Marks out of:Weighting:80 Marks50%Assessed CourseLearning Outcomes(CLO)CLO1,

Read More »

PSY1040 Portfolio: Cultural Responsiveness & Self-Awareness

Course Code and NamePSY1040: An Introduction to Cultural Safety in PracticeAssessment Item Number and NameAssessment 2: PortfolioAssessment Item TypePortfolio PSY1040 Portfolio: Cultural Responsiveness & Self-AwarenessDue Date & TimeTuesday, 29 April 2025 (Week 12), 11:59pmLength2000 words – an average of 400 words per task.Marks and WeightingMarked out of: 100Weighting: 50%Assessed Course

Read More »

Innovative Digital App Development Report

OVERALL DESCRIPTION OF TYPE OF ASSIGNMENT Assessment 1- Type of Assignment Individual Written Report Details Individual Written Report 3,000 words (500 words of the Report is Contextualisation) Weighting of Assessment : 70% INDIVIDUAL MARK Learning outcomes assessed by Assessment: 1, 2, 3 and 4 – See Module Listings of Learning

Read More »

Tourism Trends and Investment Decisions: A Comparative Study

Assignment TaskYou are a strategist working for a major hospitality group based in Australia. The company is planninginternational expansion, and the board has asked you to compile a report to identify the most suitablelocation for the project. The board has shortlisted two international locations (which will be allocatedto you by

Read More »

EC502 Language and Literacy in the Early Years

EC502 Language and Literacy in the Early Years Unit Code/Description EC502 Language and Literacy in the Early Years Course/Subject Bachelor of Early Childhood Education Semester March 2025 Assessment Overview   Unit Learning Outcomes Addressed 1, 2, 3 Assessment Objective Assessment 1: Poster Including an Invigilated stage in Week 3. Due

Read More »

EC501 Early Childhood Learning and Development

Unit Code/Description EC501 Early Childhood Learning and Development Course/Subject Graduate Diploma in Education (early childhood) Semester S 1, 2025 Assessment Overview   Unit Learning Outcomes Addressed 1, 2, 3 Assessment Objective In this assessment, student are required to select one of the case studies provided and critically analyze the child’s

Read More »

JSB172: Professional Academic Skills

JSB172: Professional Academic SkillsAssessment: Workplace Report and Presentation Weight: 50%Due date: Friday 30th May 11:59pm Length: 1,750 words (+/- 10 %) / 5minutesPurpose/Learning Objectives:This assessment relates to Learning Outcomes 1, 2, 3, and 4: Task:Your task is to write a Workplace Report identifying how to address the topic/issue chosen or

Read More »

2015PSY Developmental Psychology Assignment

2015PSY Developmental Psychology Assignment 2025 2015PSY Developmental Psychology Assignment Assignment MaterialsAssignment Information Sheet & Marking Criteria.pdf (this document)Assignment Template.docx (template)Example Assignment.pdf (HD exemplar)Due Date: Friday 16 May, 11:59PM (Week 10)Weighting: Marked out of 100 (worth 30% of course grade)Word Count: 1,500 words maximum(inclusive of main text, headings, in-text citations; excluding

Read More »

Principles of Economics Federal Budget

Principles of Economics Short-answer Assignment V1 (20% of final mark) The assignment consists of four questions.  You should allocate at least half a page (or 250 words) to each answer or 1000 words for all four answers depending on the nature of and/or marks allocated for the question/s. You may

Read More »

LML6003 – AUSTRALIA’S VISA SYSTEM 1 (FAMILY AND OTHERVISAS)

Graduate Diploma in Migration Law LML6003 – AUSTRALIA’S VISA SYSTEM 1 (FAMILY AND OTHER VISAS) Assessment Task 2 – Semester 1, 2025 LML6003 – AUSTRALIA’S VISA SYSTEM 1 (FAMILY AND OTHERVISAS) Instructions: 1. Students must answer all questions as indicated. Make certain all answers are clearly labelled. 2. Make certain

Read More »

Construction Cadetships in the Australian Construction Industry

REPORT TOPICPrepare an Academic Report on the following:‘Construction Cadetships in the Australian Construction Industry’.The report should encompass the following: Your personal evaluation and critique of the key findings in your report including your evaluation of construction cadetships, yourfindings in relation to potential issues/problems with cadetships and your recommendations to improve

Read More »

Assessing Corporate Governance and its Significance

Assessing Corporate Governance and its Significance: A Case Study Analysis Overview: Accounting irregularities have cost investors millions of dollars and, most importantly, adversely impacted their confidence in the financial system. While there have been remarkable improvements in regulatory supervision, auditing framework and reporting transparency, young graduates must assess major corporate

Read More »

Master of Professional Accounting and Accounting Advanced

Assessment 2 – Business Case (CVP) AnalysisUnit Code/Description ACC901 Accounting for Managerial DecisionsCourse/Subject Master of Professional Accounting and Master of Professional Accounting AdvancedSemester S1 2025 Assessment Overview Unit Learning OutcomesAddressed1,2,3,4 and 5Assessment Objective The primary objective of this assessment is to assess the students’ ability to apply CVPanalysis and relevant

Read More »

Urban Design Theory Essay writing

Essays are a major form of assessment at university. Through essays, you develop your understanding of discipline-specific content, strengthen your critical thinking, and develop your ability to translate that thinking into a persuasive written form. This assignment assesses your understanding of the following Unit Learning Outcomes: 1) understand the historic

Read More »

Statutory Interpretation of Disability Discrimination in NSW Law

Foundations of Law 70102 – Assessment Task 3 – Autumn 2025Statutory Interpretation and Research ExerciseDue: Thursday 22 May 2025 by 23.59Length: 2000 words (excluding the headings Part A, Part B and Part C, footnotes andbibliography. Any additional headings that you decide to use will be included in the wordcount)Weighting: 40%Task

Read More »

Engineering Career Readiness: Sustainability & Reflection

Objectives: The purpose of this assignment is to: Apply your learning in this unit to your development as an engineering graduate and your future career.Develop the ability to communicate yourself professionally.Develop an ability to reflect on your professional development, and identify any gaps in your capabilities.Unit Learning Outcomes: This task

Read More »

Child Study Report: Saif’s Development Across Key Domains

Child Study Report: Saif’s Development Across Key Domains Introduction This Child Study Report focuses on Saif, a 4-year and 6-month-old boy attending our childcare centre. Saif is an active, curious, and sociable child who engages enthusiastically in various activities. Over three weeks, multiple observations were conducted in different settings—such as

Read More »

2500 Words Insurance Case Study Analysis

Assessing Corporate Governance and its Significance: A Case Study Analysis Overview: Accounting irregularities have cost investors millions of dollars and, most importantly, adversely impacted their confidence in the financial system. While there have been remarkable improvements in regulatory supervision, auditing framework and reporting transparency, young graduates must assess major corporate

Read More »

Critical Reflections: Arts, Play & Mental Health

Peer Learning and DiscussionTask type Discussion Contribution Task description Contribute constructively to the formal weekly online discussions under the guidance of your moderator, in peer-to-peer learning. The purpose of the discussions is for students to explore and share ideas linked to the material being studied that week, and develop skills

Read More »

Indo-Pacific Health Challenge: Community Practice in Kiribati

Task type Indo-Pacific health challenge scenario Task description You will be presented with a real-world case scenario of a health challenge confronting an Indo-Pacific community that directly relates to the current climate emergency. You will analyse the scenario, exploring how community practice principles are being applied. You will then provide

Read More »

Assessment Task 1– SQL Report – Individual Assessment

MIS202 –Managing Data and Information – Trimester 1 2025Assessment Task 1– SQL Report – Individual AssessmentDUE DATE: Friday, 4 April, by 8:00pm (Melbourne time)PERCENTAGE OF FINAL GRADE: 30%WORD COUNT: Maximum 2000 wordsDescriptionPurposeThis task provides you with opportunities to learn the knowledge (GLO1 & ULO1) and skills (GLO 3 & ULO2;GLO4

Read More »

Assessment Category Infographic

Assessment # Title Assessment 1Assessment Category InfographicWeight 50%Length / Duration 500 words (excluding reference list)Individual / Group IndividualLearning OutcomesThis assessment evaluates your achievement of the following Unit Learning Outcomes:

Read More »

STM1001: Assignment 3 for Science/Health Stream Students

STM1001: Assignment 3 Science/Health Stream Students Only Academic Integrity Information In submitting your work, you are consenting that it may be copied and transmitted by the University for the detection of plagiarism. If you are unsure of your academic integrity responsibilities, please check the information provided in the Assessment Overview

Read More »

ACCG1000 Accounting for Decision Making Xero Assignment

1ACCG1000Accounting for Decision MakingXero AssignmentInformation packSession 2 2024Due Date: Friday 18th October 2024 at 11.55pm2Xero AssignmentIntroductionThe Xero assignment is designed to provide introductory accounting students with an overview of the Xero Accounting Software by completing a one-month accounting cycle for a fictional business. This is an online assignment worth 20%

Read More »

WRIT1001 Assessment Notification 2

6Final Essay: Rhetorical analysisDue: Friday 18 October 2024 at 23:59 (Sydney time)Length: 1500 words, worth 40% of the overall grade for the unitSubmit: as a Word document or PDF, via Canvas AssignmentMain question:● Present a scholarly essay that analyses the rhetoric used in arguments about thecontentious topic you have been

Read More »

WRIT1000 Assessment Four

Title: Self-ReflectionDue: Friday October 18 by 11:59PM.Length: 500 words (+/- 10%)Weight: 10% of the total gradeFormat: Times New Roman, double-spaced, 12pt. Your project should have the title“WRIT1000 Assessment Four – Self Reflection for xxxxxxx” where “xxxxxxxx” is yourstudent number. Please only submit Word documents (.doc or .docx). Turnitin doesnot recognise

Read More »

Written Assessment – Psychosocial Research Perspectives

Written Assessment – Psychosocial Research Perspectives TRIGGER WARNING: This is a case study of a real person. Katherine Knight was the first woman in Australia to receive a life sentence without parole after she decapitated and cooked her lover. If you think that you will have problems reading about this

Read More »

RES800 Assessment 1 – Research Question and Literature Review

Subject Title Business Research Subject Code RES800 Assessment Title Assessment 1 – Research Question and Literature Review Learning Outcome/s     Utilise critical thinking to analyse managerial problems and formulate relevant research questions and a research design   Apply research theories and methodologies to assist in developing a business research

Read More »

Can't Find Your Assignment?