Resources: Fast Broadcast Modules for NS-2 Simulator
Applications such as online gaming and alert message propagation are sensitive to per-packet delivery delays. Consider a Vehicular Ad-hoc Network (VANET); in this context, the quick propagation of multi-hop broadcast messages generated by the aforementioned applications requires the deployment of specific solutions able to avoid redundant transmissions and other sources of message propagation delays.
To this aim, we have developed a solution that allows vehicles in a car platoon to dynamically estimate their transmission range and to exploit this information to efficiently propagate a broadcast message with as few hops (and transmissions) as possible. In essence, the farthest vehicle in the transmission range of a message sender/forwarder will be statistically privileged in becoming the next (and only) forwarder.
A more detailed explanation of the problem and of the solution can be found in [C14], [J19],(see the references at bottom of page or in the publications webpage).
Implementation in NS-2
To implement the solution, we have created some new modules for the well known Network Simulator (version ns-2.29, altough it may work also with other versions).
Specifically, we have created the following modules:
- bbcast-packet.h includes the definition of the new packet header;
- bbcast-packet.cc includes the implementation of the functions to access the packet header;
- BroadcastbaseAgent.h includes the prototypes of the functions related to the broacast agent;
- BroadcastbaseAgent.cc includes the implementation of the functions of the broadcast agent;
- BroadcastbaseApp.h includes the definition of our application's class and, in general, the definition of the data structures utilized by our application;
- BroadcastbaseApp.cc includes the implementation of our application's class and, in general, all the functional components of our application (as described in [C14], [J19]).
All these files, scripts, instructions to install and use our files, and a simulative configuration example (broadcast.tcl, representing a car platoon engaged in an online gaming application) can be found altogether in fastbroadcast.zip.
References:
[C14] C. E. Palazzi, S. Ferretti, M. Roccetti, G. Pau, M. Gerla, "How Do You Quickly Choreograph Inter-Vehicular Communications? A Fast Vehicle-to-Vehicle Multi-Hop Broadcast Algorithm, Explained", in Proc. of IEEE CCNC 2007, Las Vegas, NV, USA, IEEE Communications Society, Jan 2007.
[J19] C. E. Palazzi, M. Roccetti, S. Ferretti, "An Inter-Vehicular Communication Architecture for Safety and Entertainment", IEEE Transactions on Intelligent Transportation Systems, 11(1), pp. 90-99, 2010.