Giter Site home page Giter Site logo

kittyhawkcorp / libsbp Goto Github PK

View Code? Open in Web Editor NEW

This project forked from swift-nav/libsbp

0.0 3.0 0.0 15.73 MB

Swift Binary Protocol client libraries

License: GNU Lesser General Public License v3.0

Makefile 0.57% CMake 0.50% C 29.75% C++ 0.08% Python 18.02% Haskell 9.21% TeX 0.61% M4 0.14% Java 13.55% JavaScript 27.56%

libsbp's Introduction

Specification and Bindings for Swift Binary Protocol

Build status

The Swift Navigation Binary Protocol (SBP) is a fast, simple, and minimal binary protocol for communicating with Swift devices. It is the native binary protocol used by the Piksi GPS receiver to transmit solutions, observations, status and debugging messages, as well as receive messages from the host operating system, such as differential corrections and the almanac.

This project provides language-agnostic specification and documentation for messages used with SBP, a compiler for generating message bindings, and client libraries in a variety of languages. This repository is organized into the following directory structure:

  • docs: Protocol documentation and message definitions.
  • spec: Machine readable protocol specification in YAML.
  • generator: Simple, template-based generator for different languages.
  • python: Python client and examples.
  • c: C client library and examples.
  • haskell: Haskell client and examples.
  • java: Java client library and examples.
  • javascript: JavaScript client library and examples.

Except for the generator, all of the above are generated and should not be modified directly.

Building / installing

Installing from package managers

Some bindings are available on package managers:

Installing from source

You can build one binding at a time or update all at once:

make python

or

make all

are both valid. To see a list of all valid targets, run make help.

SBP Protocol Specification

SBP consists of two pieces: (i) an over-the-wire message framing format and (ii) structured payload definitions. As of Version 1.0, the packet consists of a 6-byte binary header section, a variable-sized payload field, and a 16-bit CRC value. SBP uses the CCITT CRC16 (XMODEM implementation) for error detection.

Please see the docs for a full description of the packet structure and the message types. Developer documentatation for the language-specific sbp libraries is here.

LICENSE

Copyright © 2015 Swift Navigation

Distributed under LGPLv3.0.

libsbp's People

Contributors

mfine avatar mookerji avatar denniszollo avatar joshuagross avatar fnoble avatar ljbade avatar gsmcmullin avatar dt-exafore avatar jacobmcnamee avatar mbavaro avatar ungureanuvladvictor avatar jck avatar margaret avatar pmiettinen avatar nsirola avatar benjamin0 avatar adel-mamin avatar peddie avatar ejconlon avatar paulbouchier avatar kovach avatar sashamitelman avatar cbeighley avatar flixr avatar wltr avatar axlan avatar lbara avatar valeri-atamaniouk avatar

Watchers

Kosuke July Hata avatar James Cloos avatar Robert Preissl avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.