Skip to content

Implementing a Distributed Queuing protocol as an alterenative to the ALOHA MAC Protocol.

Notifications You must be signed in to change notification settings

mahirjain25/Goodbye-Aloha

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

50 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Data Communications (CO250): Mini Project

Title:

Goodbye ALOHA!

Group Members:

Mahir Jain (16CO123) - [email protected]

Suraj Singh (16CO146) - [email protected]

Adwait Gautham (16CO203) - [email protected]

Abstract:

The vision of the Internet of Things (IoT) to interconnect and Internet-connect everyday people, objects, and machines poses new challenges in the design of wireless communication networks. The design of medium access control (MAC) protocols has been traditionally an intense area of research due to their high impact on the overall performance of wireless communications. The majority of research activities in this field deal with different variations of protocols somehow based on ALOHA, either with or without listen before talk, i.e., carrier sensing multiple access. These protocols operate well under low traffic loads and low number of simultaneous devices. However, they suffer from congestion as the traffic load and the number of devices increase. For this reason, unless revisited, the MAC layer can become a bottleneck for the success of the IoT. This paper describes the current limitations and envisioned challenges for the near future. Motivated by those, we identify a family of simple algorithms based on distributed queueing (DQ), which can operate for an infinite number of devices generating any traffic load and pattern. A description of the DQ mechanism is provided and most relevant existing studies of DQ applied in different scenarios are described in this paper. Finally, a description of the very first demo of DQ is also included in this paper.

Tools Used:

The ns2 software tool is being used to implement Pure and Slotted ALOHA. Python is being used to implement the concept mentioned in the chosen paper.

References:

A. Laya, C. Kalalas, F. Vazquez-Gallego, L. Alonso and J. Alonso-Zarate, "Goodbye, ALOHA!," in IEEE Access, vol. 4, pp. 2029-2044, 2016. Click Here

Directory and File Structure

  • Introduction.md - Description of the theoretical aspects of the project with the help of diagrams shown in the paper
  • Design.md - Designing the solution
  • Pure and Slotted Aloha - A folder with all files pertaining to pure and slotted ALOHA. It contains:
    1. pure_aloha.tcl - TCL file for pure ALOHA implementation
    2. slotted_aloha.tcl - TCL file for slotted ALOHA implementation
    3. pure_aloha.nam - Animation for pure ALOHA
    4. slotted_aloha.nam - Animation for slotted ALOHA
    5. pure_aloha.png - Screenshot of animation of pure ALOHA
    6. slotted_aloha.png - Screenshot of animation of slotted ALOHA
    7. pure_aloha.tr - Tracefile for pure ALOHA
    8. slotted_aloha.tr - Tracefile for slotted ALOHA
    9. analyze_any_aloha.awk - An awk script to calculate network metrics for either pure or slotted ALOHA.
  • Contention Resolution Implementation - A folder with all files pertaining to the new algorithm being implemented.
    1. dq.py - Python script that implements Distributed Queuing.
    2. resolution.py - A file that generates collisions, and prints resolved lists.
    3. tree_split.py - A python script that performs tree splitting algorithm
    4. tree_splitting.tcl - TCL script depicting tree splitting algorithm
    5. highdrop_aloha.nam - Animation for higher drop ALOHA file
    6. highdrop_aloha.tr - Tracefile for higher drop ALOHA file
    7. analyze_any_aloha.awk - An awk script to calculate network metrics from the .nam file.

About

Implementing a Distributed Queuing protocol as an alterenative to the ALOHA MAC Protocol.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •