/Producer-Consumer

Producer/Consumer Simulation Program developed using Angular Framework and Spring Boot

Primary LanguageTypeScript

Producer-Consumer

Producer/Consumer Simulation Program developed using Angular Framework and Spring Boot

Contents:


Contributers:


Frameworks and technology used:

  • For the frontend part (view part), we used HTML, CSS, and typescript through angular framework.
  • For the backend (model and controller), we used Java language through spring framework.

How to run:

  • Note: Make sure you have downloaded NodeJs and Angular-CLI.
  • Extract the compressed project folder.

Back-end part:

  • Open the Producer-Consumer-Backend folder using IntelliJ IDE, and run the ProducerConsumerBackendApplication.java class on port 9080. you can change the port from the project resources at application.properties (server.port = …..) if the 9080 port was already used in your device but in this case, you will need to change it in all http requests in the angular folder.

Front-end part:

  • open the “producer-consumer-frontend” folder using visual studio IDE, then open the terminal of the IDE, and write:
  • npm install in the terminal.
  • ng serve --open in the terminal to open the project, on port “http://localhost:4200/”. Note: if you needed to change port 4200 as it was already in use then you will need to change it in the Producer-Consumer-Backend folder in the controller class

Used design patterns:

1- Observer Design Pattern:

The intent of this design pattern is to define a one-to-many dependency between objects so that when one object changes state, all its dependents are notified and updated automatically. In our code, we implement it by creating the Interface called “IObserver”. Then, two classes called Machine Observer and Queue Observer are the concrete classes that implement the “IObserver” interface. There is a class called “Manager” which observes the changes on the machine and queues, then by calling the function “notify” the queues are notified and updated automatically. The goal of this is that we want to notify and update the state of the machines in the network once the state of any queue has changed and vice versa, and here’s the UML for that DP.

image

2- Producer Consumer Design Pattern:

The intent is to organize the communication between the producer and consumer objects (the queues and machines here in our context) and control the multithreaded flow in the network. Briefly, we used it by creating two classes which are “Queue” and “Machine”. The Network contains a list of machines and queues in a certain order. There may be a multi-level of machines and queues the process started by queuing the products to be produced in “Q0”, then each machine takes a single product only and the rest wait in the queue until any of the machines finished, then the first product in the queue will enter the first available machine and, the second entered the next machine and so on in all levels until all products gathered in the “Qn”(i.e. Last level of the network) and here’s the UML for that DP.

image

3- SnapShot:

We use this design pattern in order to restore(keep a memento or in other words take a snapshot) of the network each time a change of the state occurs to help us replay the simulation from the beginning until the exact moment we’ve stopped at. The class “Generator”, “CareTaker” and “SnapShot” are the main elements to apply this design pattern. “Generator” communicates with “SnapShot” either to store the current states of the network or get the previous states of the current network. “CareTaker” is our storage for the networks it keeps a list of mementos and supports the different operations on this list like adding a memento to the list getting all mementos etc.

image

4- Singleton:

we used it in order to create a single instance from “Manager” Class to reuse it after creation-because it’s kind of a huge class so it costs a lot creating a new instance every now and then-to be able to manage the resources such as “AddingObserver”, ”RemovingObserver” and also notify the whole network if there is any change in the states.


How the system works

  • The number of products is random and initially the default queue gets a random input rate of the products and through this queue, the products are distributed over the first level of machine(s).
  • Each machine in the network has a random service time that remains the same till the process ends.
  • Each machine serves one product at a time and the speed of service is according to the machine’s service time.
  • And from the first level machine(s) the products are transferred along the network up to the second level and so on until the products are completely serviced and then they’re stored in the final buffer.
  • The Observer DP is used to for notifying the network elements each state change and according to that other states are updated.
  • The memento DP is used to keep a memento of the network each state change for the replay feature.
  • The concurrency DP is used to control the multi-threaded flow along the network.

UML class diagram:


Snapshots of our UI and a user guide:

image

The queue Q0 is added by default initially.

  • Machine button: to add a new machine.
  • +Queue button: to add a new queue.
  • Connect items: to connect a queue to a machine in any direction. To connect between a queue and a machine first press the button and click on the start shape and hold, dragging the arrow to the destination shape.
  • Run button: to start the simulation.
  • Each M has a random service time and can serve one product at a time.
  • Each M changes its color to the color of the product being processed.
  • Each Q displays the number of products waiting.
  • Stop button: to stop the simulation.
  • Replay button: to replay the simulation.
  • Stop input button: to stop products arriving at Q0.
  • Clear all button: to clear all the network in order to add a new network.
  • In case a machine is not connected to at least one queue at both directions this error message appears.

image image image image


Demo Video for using the app:

Producer-Consumer-Simulation.mp4