/Token-Bucket-Algorithm

Token Bucket Algorithm with GUI interface

Primary LanguageJavaMIT LicenseMIT

Token Bucket Algorithm

Token bucket algorithm is one of the techniques for congestion control algorithms. When too many packets are present in the network it causes packet delay and loss of packet which degrades the performance of the system. This situation is called congestion.

The network layer and transport layer share the responsibility for handling congestions. One of the most effective ways to control congestion is trying to reduce the load that transport layer is placing on the network. To maintain this network and transport layers have to work together.

The Token Bucket Algorithm is diagrammatically represented as follows Token Bucket Algorithm

The leaky bucket algorithm enforces output patterns at the average rate, no matter how busy the traffic is. So, to deal with the more traffic, we need a flexible algorithm so that the data is not lost. One such approach is the Token Bucket Algorithm.

Let us understand this algorithm step wise as given below −

  1. In regular intervals tokens are thrown into the bucket f.
  2. The bucket has a maximum capacity f.
  3. If the packet is ready, then a token is removed from the bucket, and the packet is sent.
  4. Suppose, if there is no token in the bucket, the packet cannot be sent.

Simulations

Images

GUI Simulation Working Simulation Showing transmission of packets of data Working Simulation Showing the final Output of data transmission

Video

Token_Bucket_Algorithm.mp4