Package Summary

Tags No category tags.
Version 0.7.0
License Apache-2.0, MIT
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/bosch-engineering/off_highway_sensor_drivers.git
VCS Type git
VCS Version humble-devel
Last Updated 2025-01-24
Dev Status MAINTAINED
CI status No Continuous Integration
Released RELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

The off_highway_can package

Additional Links

No additional links.

Maintainers

  • Robin Petereit

Authors

  • Robin Petereit
  • Marcus Huenerbein

off_highway_can

The off_highway_can package provides a C++ library to

  • receive can_msgs/Frame or socketcan_msgs/FdFrame ROS messages and decode their bytes into custom C++ message structures,
  • encode the bytes of can_msgs/Frame or socketcan_msgs/FdFrame ROS messages from custom C++ message structures and send them.

The list of message structures containing the definition of a CAN message and signals need to be filled by derived classes for CAN node specific functionality. The more generic handling of a cyclic redundancy check and a rolling message counter per message is provided by the library. Have a look directly into the CAN message structure definition for further information.

Classes

Receiver

The off_highway_can::Receiver is an abstract base class and needs to be derived for specific sensor types and behavior. It provides the functionality to process can_msgs/Frame or socketcan_msgs/FdFrame ROS messages and decode configured ones based on provided message definitions. The decoded signal values are forwarded to the derived class for user-defined processing of them.

The off_highway_can::Receiver allows to switch between normal and FD CAN frames via the constructor argument use_fd.

The processing chain is based completely on message callbacks and thus event-based. The needed processing time per message can be logged as ROS debug message at runtime with the compile time optionCOMPILE_DEBUG_LOG.

Furthermore, the off_highway_can::Receiver provides a watchdog which checks whether any configured message was received in the period of time defined by the parameter timeout and sends a diagnostic error on the /diagnostics topic when a timeout occurs.

Subscribed Topics

  • from_can_bus (can_msgs/Frame)
    • CAN frames to decode
    • Disabled by use_fd constructor argument
  • from_can_bus_fd (socketcan_msgs/FdFrame)
    • CAN FD frames to decode
    • Enabled by use_fd constructor argument

Published Topics

Parameters

See receiver_params.yaml.

Sender

The off_highway_can::Sender is an abstract base class and needs to be derived for specific behavior. It provides the functionality to send can_msgs/Frame or socketcan_msgs/FdFrame ROS messages by encoding configured CAN messages as bytes based on provided message definitions. The encoded signal values are published to the to_can_bus or to_can_bus_fd topic.

The off_highway_can::Sender allows to switch between normal and FD CAN frames via the constructor argument use_fd.

The encoding and publishing chain is just a method call and thus event-based. The needed processing time to encode and publish all configured messages can be logged as ROS debug message at runtime with the compile time optionCOMPILE_DEBUG_LOG.

Furthermore, the off_highway_can::Sender provides a watchdog which checks whether a ROS message was published in a defined by the parameter timeout and sends a diagnostic error on the /diagnostics topic when a timeout occurs.

Published Topics

  • to_can_bus (can_msgs/Frame)
    • Encoded CAN frames
    • Disabled by use_fd constructor argument
  • to_can_bus_fd (socketcan_msgs/FdFrame)
    • CAN FD frames to decode
    • Enabled by use_fd constructor argument
  • /diagnostics (diagnostic_msgs/DiagnosticArray)
    • Update Rate: normally 1 Hz, can be forced
    • Diagnostic status in base class only contains timeout status

Parameters

See sender_params.yaml.

Free and Open Source Software (FOSS)

This library uses the libcan-encode-decode library for encoding and decoding raw bytes into / from floating values. See the FOSS documentation for further information.

CHANGELOG

Changelog for package off_highway_can

0.7.0 (2024-12-04)

  • Update docs for CAN FD
  • Check matching lengths in decoding
  • Allow start bits in CAN FD range
  • Make CRC and message counter optional
  • Enable processing of CAN FD frames
  • Remove unused definitions
  • Do not force warnings as errors to fix rolling (#11)
  • Contributors: Robin Petereit, Tim Clephas

0.6.3 (2024-07-09)

0.6.2 (2024-06-13)

0.6.1 (2024-06-04)

  • Fix missing dependency that was find_packaged (#7)
    • Fix missing dependency that was find_packaged

    * Use ament_lint_common ---------

  • Contributors: Tim Clephas

0.6.0 (2024-05-14)

0.5.1 (2024-03-27)

  • Align Clang FP contraction to GCC for passing tests
  • Add virtual destructor for base class
  • Contributors: Robin Petereit

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged off_highway_can at Robotics Stack Exchange