Skip to main content

CANopen stack implementation

Project description

A Python implementation of the CANopen standard.

Features

  • NMT master

  • SDO client

  • PDO producer/consumer

  • SYNC producer

  • EMCY consumer

Installation

Install from PyPI using pip:

$ pip install canopen

Documentation

Documentation can be found on Read the Docs:

http://canopen.readthedocs.io/

It can also be generated locally using Sphinx:

$ python setup.py build_sphinx

Hardware support

This library support multiple hardware and drivers through the python-can package. At the time of writing this includes:

  • Kvaser

  • Peak CAN

  • IXXAT

  • USB2CAN

  • Anything supported by socketcan on Linux

It is also possible to integrate this library with a custom backend.

Examples

Here are some quick examples:

import canopen

# Start with creating a network representing one CAN bus
network = canopen.Network()

# Add some nodes with corresponding Object Dictionaries
network.add_node(6, '/path/to/object_dictionary.eds')
network.add_node(7, '/path/to/object_dictionary.eds')

# Connect to the CAN bus
# Arguments are passed to a python-can bus
# (see https://python-can.readthedocs.io/en/latest/bus.html).
network.connect(channel=0, bustype='kvaser', bitrate=250000)

# Read a variable using SDO
device_name = network[6].sdo['ManufacturerDeviceName'].raw
vendor_id = network[6].sdo[0x1018][1].raw

# .phys takes factor into consideration (if supported)
network[6].sdo['ApplicationCommands']['CommandSpeed'].phys = 1502.3

# Accessing value descriptions as strings (if supported)
network[6].sdo['ApplicationCommands']['RequestedControlMode'].desc = 'Speed Mode'

# Accessing individual bits
network[6].sdo['ApplicationCommands']['CommandAll'].bits[2:3] = 2

# Change state to operational (NMT start)
network[6].nmt.state = 'OPERATIONAL'
network[7].nmt.state = 'OPERATIONAL'

# Disconnect from CAN bus
network.disconnect()

TODO

There are a lot of things that still needs implementing and fixing. Pull requests are most welcome!

  • Documentation (docs + API)

  • Unit tests

  • SDO block transfer

  • TIME

  • XDD support

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

canopen-0.3.0.dev5.tar.gz (15.9 kB view details)

Uploaded Source

Built Distribution

canopen-0.3.0.dev5-py2.py3-none-any.whl (21.0 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file canopen-0.3.0.dev5.tar.gz.

File metadata

File hashes

Hashes for canopen-0.3.0.dev5.tar.gz
Algorithm Hash digest
SHA256 414746082882228491fb36e3b504679f2b52986e547257f5ae9be02fd324f45f
MD5 0ba6e2f4e961d980c2f5dba262ffc4d9
BLAKE2b-256 9cdcf2405da634865b16262ddcd8b734c5d26755bf2955f625b136ba30c1e6d9

See more details on using hashes here.

File details

Details for the file canopen-0.3.0.dev5-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for canopen-0.3.0.dev5-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 8bb85879cfdce404c87d169fd964f85fb892568b13678d25c991d168a833810d
MD5 b6e145db068433ce45975793bf4f2e9e
BLAKE2b-256 8b263a53fdbbcf43c6b8256a2982118bc54677b26374f52ab3c0d260a59f4a80

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page