Skip to content

Faster AIS decoder (multi-threaded and hopefully GPU enabled)

Notifications You must be signed in to change notification settings

aduvenhage/ais_beast

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

29 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ais_beast

Next (Experimental) version of AIS decoder (multi-threaded and hopefully GPU enabled)

While the previous version focused on extensibility and also on support for different formats, the intent with this verion is to focus on speed. The decoder is broken into stages:

  • input (nmea raw sentence decoding)
  • fragment CRC checks and multi-line support
  • payload de-armouring
  • message decoding

Features:

  • each stage is connected to the next through a thread safe queue
  • stages can essentially run in parallel
  • each stage also consumes and produces data in chunks (groups of messages)
  • WIP support for processing on GPU

The goal is to get to 20M+ messages per second (NMEA processed from disk, decoded and saved back to disk in a application/binary format).

Current stats:

  • Debug build: 5M+ messages per second
  • Release build: 17M+ messages per second

DONE:

  • decoding structures (fragments, messages, payloads)
  • basic nmea sentence decoding
  • crc checks
  • payload de-armouring
  • lock-free producer/consumer queue
  • overloaded memory operators for memory structures, so that we can reuse objects
  • multi-sentence fragment decoding
  • replace lock-free queue with a locking and blocking queue (using condition variables)

TODO:

  • support cuda

About

Faster AIS decoder (multi-threaded and hopefully GPU enabled)

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published