python-canfix is a Python package that abstracts the details of the CAN-FIX communication protocol.
CAN-FIX is the CAN bus implementation of a set of protocols and specifications known as FIX. FIX stands for Flight Information eXchange and is an attempt to standardize communication among aircraft systems in small aircraft.
The project is hosted on GitHub at...
https://github.com/birkelbach/python-canfix
Install canfix
with pip
: :
$ pip install python-canfix
You can also install directly from the source directory by running: :
$ python setup.py install
The only dependency is python-can, which should be automatically installed by the above commands.
You should be familiar with the CANFIX protocol specification before using this library. CANFIX has several different message types. Each of these types is representd by a class in this library.
The constructor can take one named parameter. msg
can be assigned a python-can Message
and the instantiated object will be initialized with the correct information.
Properties
NoneAlarm.node
- Sets or returns the node address of the node that sent (or will send) the Alarm Message. Should be an integer between 1 and 254
NodeAlarm.alarm
- Sets or returns the alarm type. The meaning of this data is dependent on the individual node type. Should be an integer between 0 and 65,535.
NodeAlarm.data
- Sets or returns a list that represents the data for this alarm. What the data represents is dependent on the specific type of node and the alarm type. It should be a list of bytes of up to 6 bytes in length.
NodeAlarm.msg
- Sets or returns a can.Message class that is suitable for use with a python-can bus. If this property is set with a message received from the can bus then the message will be parsed and the node, alarm and data properties will be set accordingly. If it is read then the message will be constructed with the node, alarm and data properties that should have been previously set.
Example Usage:
>>> na = canfix.NodeAlarm()
>>> na.node = 12
>>> na.alarm = 45321
>>> na.data = [4,5,6,7]
>>> na.msg
>>> na.msg
can.Message(timestamp=0.0, is_remote_frame=False, is_extended_id=False, is_error_frame=False, arbitration_id=0xc, dlc=0,
data=[0x9, 0xb1, 0x4, 0x5, 0x6, 0x7])
>>> msg = bus.recv() # Assume we read the same message that we created above
>>> na = canfix.NodeAlarm(msg)
>>> print(na)
[12] Node Alarm 45321 Data 04050607
The constructor can take one named parameter. msg
can be assigned a python-can Message
and the instantiated object will be initialized with the correct information.
Properties
Parameter.node
- Sets or returns the node address of the node that sent (or will send) the Parameter. Should be an integer between 1 and 254
Parameter.identifier
- Sets or returns the CAN bus identifier for this parameter. If the identifier is out of of range for Parameter messages a ValueError exception will be raised. Setting this will also cause protocol specific information to be set in the object. This includes the data type, the engineering units, name etc.
Parameter.name
- Sets or returns the name of the parameter. i.e. "Indicated Airspeed" If the name is not found in the protocol ValueError exception will be raised. Setting this will also cause protocol specific information to be set in the object. This includes the data type, the engineering units, identifier etc.
Parameter.index
- Sets or returns the index of the parameter. Should be an integer between 0 and 255.
Parameter.failure
- Sets or returns the flag that indicates data failure. Should be True
or False
Parameter.quality
- Sets or returns the flag that indicates data quality. Should be True
or False
Parameter.annunciate
- Sets or returns the flag that indicates the paramter should be annunciated. Should be True
or False
Parameter.meta
- Sets or returns the meta data index for the Parameter. Should be an integer between 0 and 15
Parameter.value
- Sets or returns the value for the parameter. It can be a list of multiple values if the particular parameter is expecting multiple values. It can also be a string
Parameter.msg
- Sets or returns a can.Message class that is suitable for use with a python-can bus. If this property is set with a message received from the can bus then the message will be parsed and the properties will be set accordingly. If it is read then the message will be constructed with properties that should have been previously set.
Parameter.fullName
- Returns a string that represents the parameter that includes the index and the index name. This property is read only.
Parameter.units
- Read only property that returns a string indicating the engineering units for this Parameter. This is a protocol specific piece of information and should not change.
Parameter.type
- Read only property that returns a string indicating the datatype for the Parameter. This is a protocol specific piece of information and should not change.
Parameter.min
- Read only property that returns a value that indicates the minimum value for the Parameter. This is a protocol specific piece of information and should not change.
Parameter.max
- Read only property that returns a value that indicates the maximum value for the Parameter. This is a protocol specific piece of information and should not change.
Parameter.format
- Read only property that returns the format of the data in the Parameter value. This is typically used to indicated what WORD and BYTE type data means. This is a protocol specific piece of information and should not change.
Parameter.remarks
- Read only property that returns a list of remarks that are associated with this Parameter in the protocol specification. This is a protocol specific piece of information and should not change.
Parameter.indexName
- Read only property that retuns he name of what the index represents. i.e. Cylinder This is a protocol specific piece of information and should not change.
Parameter.multiplier
- Read only property that returns the multiplier for the Parameter. Some paramters use an integer with a multiplier as the value in the message. For example if we had a Parameter value of 123.4 and the multiplier is 0.1 then the data that would be communicated on the bus would be 1234. The receiver would then multiply by 0.1 to get the original value of 123.4. The python-canfix
library handles these details for you so you don't need to concern yourself with this detail. It is a part of the protocol and is included here for applications that want to display protocol specific information to the user. This is a protocol specific piece of information and should not change.
Example Usage:
>>> pa = canfix.Parameter()
>>> pa.node = 2
>>> pa.value = 123.4
>>> print(pa)
[2] Indicated Airspeed: 123.4 knots
>>> pa.msg
can.Message(timestamp=0.0, is_remote_frame=False, is_extended_id=False, is_error_frame=False, arbitration_id=0x183,
dlc=0, data=[0x2, 0x0, 0x0, 0xd2, 0x4])
The constructor can take one named parameter. msg
can be assigned a python-can Message
and the instantiated object will be initialized with the correct information.
Properties
TwoWayMsg.channel
- Sets the channel that this message will be sent on. There are 16 channels numbered 0-15
TwoWayMsg.type
- Set to either 'Request' or 'Response' This determines which side of the channel to use.
TwoWayMsg.data
- Up to eight bytes
The constructor can take one named parameter. msg
can be assigned a python-can Message
and the instantiated object will be initialized with the correct information.
Properties
NodeSpecific.destNode
- Represents the node address of the node that this message is addressed to. Should be an integer between 1 and 254.
NodeSpecific.controlCode
- The control code for the messge. Currently, valid values are 0-10. Future versions of the CAN-FIX specification may use 11-127 and values from 128 to 255 are reserved for user defined functions. The control code is basically the function of the message. See the CAN-FIX specification for details.
NodeSpecific.data
- Up to 8 bytes of data that is dependent on which type of message that is being sent.
parseMessage(msg)
- When passed a Message
this function figures out what the message type is, instantiates the correct object type and returns that object. This function would be used for most all received messages.
Example Usage:
>>> msg = bus.recv()
>>> msg
can.Message(timestamp=0.0, is_remote_frame=False, is_extended_id=False,
is_error_frame=False, arbitration_id=0x183, dlc=5,
data=[0xc, 0x0, 0x0, 0xd2, 0x4])
>>> p = canfix.parseMessage(msg)
>>> p
<canfix.Parameter object at 0x7f6984fe9c10>
>>> print(p)
[12] Indicated Airspeed: 123.4 knots