Skip to content
forked from yeliqseu/streamc

An implementation of streaming codes, also known as elastic-window random linear network coding

Notifications You must be signed in to change notification settings

adney11/streamc

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

This project implements packet-level forward-erasure correction (FEC) codes called streaming codes, which encode packets in a convolutional manner to address packet erasures. The codes are also referred to as sliding-window linear codes in the literature. The key characteristic of the codes is that the packets at the destination would be recovered and delivered to upper layers in a smoothly in-order manner, instead of all-together as in conventional block codes which incurs block coding delay.

The FEC code can be compiled as a shared library libstreamc.so, and accessed via APIs defined in streamcodec.h. A python wrapper is also provided as pystreamc.py. The following APIs are typically called to use the code in an application.

On the encoder side:

  1. Create an encoder using initialize_encoder()
  2. Enqueue data packets into the encoder by calling enqueue_packet()
  3. Send a source packet from the encoder by calling output_source_packet(). Note that the encoder will bookkeep internally and the source packets are output in a first-in-first-out (FIFO) manner, i.e., in order as they were enqueued into the encoder.
  4. Send a repair packet from the encoder by calling output_repair_packet() or output_repair_packet_short(). The former encodes a repair packet across a full encoding window (EW) that includes all the source packets that have been sent from the queue, whereas the latter encodes across a short EW with a given width.

On the decoder side:

  1. Create a decoder using initialize_decoder()
  2. When a packet is received, input it to the decoder by calling receive_packet(). The received packet will be processed internally and the source packets will be made available to be accessed in the same FIFO manner as on the encoder side. This most recent in-order source packet's ID is indicated by the decoder's inorder variable. The corresponding packet is accessed via the recovered array, indexed at inorder % DEC_ALLOC, where DEC_ALLOC is a macro in the API header for specifying the decoder buffer size.

Note that it is the application's responsibility to determine when to send a source or repair packet, and whether send a full or short repair packet. This affects the end-to-end delay and computational cost. A proper choice would consitute a well-designed coded transmission scheme, which is an attractive research topic.

The library also provides several other auxiliary functions, such as for searializing data packets to byte string and vice versa, flushing certain packets earlier than an ID from the encoder (e.g. based on ACK), and free the encoder/decoder context, etc. To adopt the FEC code, it is highly recommended to read through streamcodec.h, and the examples provided in examples folder. A full application that uses this library via the python wrapper, which is a TCP performance enhancing proxy enhanced by the streaming FEC, can also be found at https://github.com/yeliqseu/pepesc.

Note: if you find the codes useful, please cite the following paper whenever appropriate.

Y. Li, X. Chen, Y. Hu, R. Gao, J. Wang and S. Wu, "Low-Complexity Streaming Forward Erasure Correction for Non-Terrestrial Networks," in IEEE Transactions on Communications, 2023. (Early Access: https://ieeexplore.ieee.org/document/10246292)

Y. Li, F. Zhang, J. Wang, T. Q. S. Quek and J. Wang, "On Streaming Coding for Low-Latency Packet Transmissions Over Highly Lossy Links," in IEEE Communications Letters, vol. 24, no. 9, pp. 1885-1889, Sept. 2020 (https://ieeexplore.ieee.org/document/9075270).

About

An implementation of streaming codes, also known as elastic-window random linear network coding

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 89.7%
  • Python 7.7%
  • Makefile 2.6%