Thanks to visit codestin.com
Credit goes to Github.com

Skip to content

jaimebw/arinc429

Repository files navigation

PyArinc429

PyPI version Build Status License: MIT Python Versions Downloads

Note: The API is subject to change. Encoding is stable; decoding is available for BNR and BCD.

PRs accepted!

How to install

pip install arinc429

This lib has zero dependecies (and it will stay this way!)

How to use

Encoder

from arinc429 import Encoder 
a429 = Encoder()
det= {
        "label":0o205,
        "value":100,
        "ssm": 0x03,
        "sdi":0,
        "encoding":"BNR"
        }
a429.encode(**det)
word = a429.word # uint32_t word
bin_vals = a429.bword # binary word
# Multiple words
a429 = Encoder()
w1= {
        "label":0o205,
        "value":100,
        "ssm": 0x03,
        "sdi":0,
        "msb":29,
        "lsb":12
        "encoding":"BNR"
        }
w2= {
        "value":1, 
        "msb":11, # Bit position
        }
a429.encode(**det)
a429.add_dsc(**w2)
word = a429.word # uint32_t word

If you want to encode another label using the same encoder, you need to reset the encoder before.

from arinc429 import Encoder 
a429 = Encoder()
det= {
        "label":0o205,
        "value":100,
        "ssm": 0x03,
        "sdi":0,
        "encoding":"BNR"
        }
a429.encode(**det)
det2= {
        "label":0o206,
        "value":100,
        "ssm": 0x03,
        "sdi":0,
        "encoding":"BNR"
        }
a429.reset() # If you dont do this, it will raise an exception 
a429.encode(**det)

In case you wan to encode a DSC value into a BNR word, you can do it like this:

from arinc429 import Encoder 
a429 = Encoder()
det= {
        "label":0o205,
        "value":100,
        "ssm": 0x03,
        "sdi":0,
        "encoding":"BNR",
        "msb":28,
        }
a429.add_dsc(1,29) # Add a DSC value to the word

Same applies for BNU encoding with the add_bnu method and with BNR with the add_bnr method.

The encoder takes care so you dont shoot your foot while encoding and loosing information, it wont let you encode something into a value that is already being used.

If you were to try use a different msb in the add_dsc method, it would raise an exception as all the bits are already being used.

You can also acces the state of the word by slicing the objects:

a429[0].word # will return the words first value when the first value was encoded
a429[-1].word # will return the words last value when the last value was encoded

Container class

There is a container class that allows you to easily work with the Arinc429 words.

from arinc429 import Arinc429Word

word = Arinc429Word(
    byte1=0x00,
    byte2=0x20,
    byte3=0x00,
    byte4=0xe1
)

It accepts multiple input formats and some cool helper functions like the visualize() method that will output a string with a bit formatting of the word. Check src/common.py for more info.

Decoder

Decoder supports BNR and BCD.

from arinc429 import Decoder
a429 = Decoder()
word = a429.decode(
            b"\xa0\x01\xa4\x61",
            encoding="BNR",
            )
assert(word.label== 0o206)
assert(word.ssm== 0x01)
assert(word.sdi== 0)
assert(word.value == 105)

Roadmap

  • Encode BNR

  • Encode BCD

  • Encode DSC

  • Encode BNU

  • Raw encoding ( label + value)

  • Mixed encoding (DSC + BNR)

  • Mixed encoding (BNU+ BNR)

  • Mixed encoding (DSC + DSC)

  • Mixed encoding (DSC + BNU)

  • Mixed encoding (BNR+ BNR)

  • Encoding values with using the SDI/SSM as usable fields (Fun encodings)

  • Decode BNR

  • Decode BCD

  • Decode DSC

  • Implement in C

I dont really follow a specific roadmap; I just add features as I need them.

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

Docs

Docs are generated with Sphinx from docstrings and live in docs/.

Changelog

See CHANGELOG.md.

Technical Overview

This library provides comprehensive support for encoding and decoding ARINC 429 data words. ARINC 429 is a widely used avionics data bus specification that defines how avionics systems communicate in aircraft. If you want a high-level explainer, see https://www.jaimebw.com/2024-11-11-encoding-arinc429/.

Supported Encodings

The library currently supports or plans to support the following encoding formats:

  • Binary (BNR)
  • Binary Coded Decimal (BCD)
  • Discrete (DSC)
  • Binary Unsigned (BNU)
  • Hybrid formats (e.g., BNR + DSC combinations)
  • Raw encoding (custom label + value pairs)

Flexible Implementation

The library is designed to be flexible and extensible, allowing for:

  • Standard ARINC 429 word formats
  • Custom data encoding schemes
  • Direct manipulation of label and data fields
  • Support for various SSM (Sign/Status Matrix) configurations

For specific encoding requirements or custom implementations, please refer to the examples section above.

License

MIT License. See LICENSE.

"I steal fire not with torches, but with code. Not for men — but for the machines that do not dream yet."

About

Arinc429 encoding and decoding

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages