|
Package Summary
Tags | No category tags. |
Version | 0.7.0 |
License | Apache-2.0 |
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
Additional Links
Maintainers
- Robin Petereit
Authors
- Robin Petereit
- Marcus Huenerbein
off_highway_uss
The off_highway_uss package provides a receiver node to receive and decode CAN frames of the Bosch
Ultrasonic Sensor System (USS) Off-Highway into ROS messages - it implements an
off_highway_can::Receiver
. Furthermore, the package provides a sender node to encode and send
needed USS input data as CAN frames - an implementation of an off_highway_can::Sender
.
Further information on the Bosch USS Off-Highway, it’s inputs, outputs and how they can be interpreted can be found in the corresponding Technical Customer Documentation (TCD) of the sensor system.
Supported devices
Device name | Part Number | Description |
---|---|---|
Ultrasonic Sensor System OHW Premium | - F037.000.125 (series) - F037.B00.672-01 (sample) both of it from software version SW2.0.0 |
- Ultrasonic sensor system with up to 12 sensors - Up to 20 objects and up to 36 distances - Object and distance output on automotive CAN is supported |
Ultrasonic Sensor System OHW Entry | - F037.000.145 (series) - F037.000.105 (series - 12V version) both of it from software version SW2.0.0 |
- Ultrasonic sensor system with up to 12 sensors - Up to 36 distances - Distance output on automotive CAN is supported |
Further information: Ultrasonic system variants and sensors
Contact: off-highway.beg@bosch.com
Nodes
Receiver
The USS receiver decodes CAN frames into an object list and a direct echo list, manages the current lists and publishes them cyclically.
The parameter use_j1939
defines whether automotive CAN or J1939 messages are expected. J1939
support has the following limitations:
- A fixed source address for the USS ECU must be configured. The dynamic assignment of source addresses is not supported.
- The receiver expects the parameter group numbers (PGNs) to be arranged as in the default DBC. A rearrangement is only supported as a shift of the entire block. Moving individual PGNs is not supported. Be aware that the PGN is only bit 8 to 23 of the extended CAN ID.
All received messages are checked for their cyclic redundancy check (CRC), rolling message counter
and age (message not older than parameter allowed_age
). If any of these checks do not succeed the
received message is not further processed and skipped.
The relevant USS CAN frame IDs to process (object_base_id
, direct_echo_base_id
,
max_detection_range_id
and info_id
) are calculated from the id_offset
(automotive CAN) or
pgn_offset
(J1939) parameter with constant offsets. It should correspond to the value configured
in the USS ECU and needs to be adapted for the specific bus setup. When using J1939, the receiver
also checks whether the source address contained in the message matches the value of the
source_address
parameter. If multiple USS systems need to be decoded on the same bus just launch
multiple receiver nodes with individual id_offset
(automotive CAN) or pgn_offset
and
source_address
(J1939) parameters.
The object data is published as a list of objects or as a point cloud and contains up to 20 objects
(sensor limit). Only valid objects in the list are published (type not TYPE_NONE
). Line objects in
the point cloud format are sampled between their first and second position into individual points
based on the line_sample_distance
parameter. If this parameter is zero, only the end points of the
line segment are put in the point cloud.
An object CAN frame is multiplexed by the USS, so that the same CAN frame ID is used for two
objects. Thus, for uniqueness, the id
fields of an object in both published list formats are
computed by adding the multiplexor value times ten to the the enumeration the CAN frame IDs starting
from the object_base_id
as zero. This results in an object id
in the range [0, 20).
The direct echo data is published as a list of direct echos and contains up to 12 direct echos
(fills up at start till one set is received). The echo’s id
field is the enumeration of the CAN
frame IDs starting from the direct_echo_base_id
as zero. This results in an echo id
in the range
[0, 12).
The echo data list is accompanied by the max_detection_range
message, which contains the current
maximum detection range for all 12 individual ultrasonic sensors as array.
If the receiver node does not receive anything within a configured period (parameter timeout
), it
will publish a diagnostic error on /diagnostics
. Also, the sensor information CAN frame is
published and checked as diagnostic status of the USS. On error, the node publishes a diagnostic
error.
Subscribed Topics
-
from_can_bus
(
can_msgs/Frame
)- USS CAN frames to decode
Published Topics
-
objects
(
off_highway_uss_msgs/Objects
)- Update Rate: configurable with
publish_frequency
- Contains current object list of USS as custom message containing the same information as each
object’s CAN frame. Mapping to the respective CAN frame and multiplexor value is done via the
id
field.
- Update Rate: configurable with
-
objects_pcl
(
sensor_msgs/PointCloud2
)- Update Rate: configurable with
publish_frequency
- Contains current object list of USS as point cloud. Line objects are sampled with
line_sample_distance
to equidistant points along the first and second position. Mapping to the respective CAN frame and multiplexor value is done via theid
field.
- Update Rate: configurable with
-
direct_echos
(
off_highway_uss_msgs/DirectEchos
)- Update Rate: configurable with
publish_frequency
- Contains current direct echo list of USS as custom message containing the same information as
each echo’s CAN frame. Mapping to the respective CAN frame is done via the
id
field.
- Update Rate: configurable with
-
maximum_detection_range
(
off_highway_uss_msgs/MaxDetectionRange
)- Update Rate: On each sensor maximum detection range CAN frame
- Contains the current maximum detection range of USS as custom message containing the same information as the respective CAN frame.
-
info
(
off_highway_uss_msgs/Information
)- Update Rate: On each sensor information CAN frame
- Contains current sensor information message containing the same information as the respective CAN frame.
-
/diagnostics
(
diagnostic_msgs/DiagnosticArray
)- Update Rate: On each sensor information CAN frame or if receiver timed out periodically with timeout period
- Diagnostic status contains statuses from the latest received sensor information and timeout status.
Parameters
See receiver_params.yaml.
Sender
The USS sender listens for ROS ambient temperature messages as input and encodes and publishes these as CAN frame.
In the case that there is no ambient temperature reading available, the USS can be configured with a fixed value (see TCD) and this sender node is not needed.
The CAN temperature signal can only encode the range of [-40°C, 87°C], ROS messages
containing temperature values outside of this range are discarded and not encoded / published.
Furthermore, if the ROS temperature message is too old (parameter allowed_age
) it is discarded,
too.
The relevant USS CAN frame ID to publish the temperature is specified by the
outside_temperature_id
parameter. This parameter needs to correspond to the vehicle data ID for
the specific bus setup. If multiple USS systems are connected on the same bus, a single USS sender
is sufficient as long as these USS systems expect the vehicle data frame on the same ID (in contrast
to multiple receivers).
If the sender node does not receive anything valid within a configured period (parameter timeout
),
it will publish a diagnostic error on /diagnostics
.
Subscribed Topics
-
temperature
(
sensor_msgs/Temperature
)- Ambient temperature is sent to the USS for compensating readings
Published Topics
-
to_can_bus
(
can_msgs/Frame
)- Encoded USS CAN frames
-
/diagnostics
(
diagnostic_msgs/DiagnosticArray
)- Update Rate: 1 Hz or if sender timed out periodically with timeout period
- Diagnostic status only contains timeout status
Parameters
See sender_params.yaml.
Launch files
-
receiver_launch: Starts the receiver with the given parameters.
- Arguments:
- params: Path to ROS YAML parameter file to load for receiver. If not provided, default parameters from this package are loaded.
- Arguments:
-
sender_launch: Starts the sender with the given parameters.
- Arguments:
- params: Path to ROS YAML parameter file to load for sender. If not provided, default parameters from this package are loaded.
- Arguments:
Changelog for package off_highway_uss
0.7.0 (2024-12-04)
- Add object type SNA and filter such objects
- Do not force warnings as errors to fix rolling (#11)
- Contributors: Robin Petereit, Tim Clephas
0.6.3 (2024-07-09)
- Add missing dependency on PCL headers (#9) When I try to build this package on jazzy with rosdep, the PCL headers are missing. This package uses [find_package(PCL)]{.title-ref} and includes it in the headers. Therefore I think it would be best to add it to the [build_depend]{.title-ref} and [build_export_depend]{.title-ref} tags of the [package.xml]{.title-ref} files. In the buildfarm this is technically not needed because the PCL headers are a [build_export_depend]{.title-ref} of [pcl_conversions]{.title-ref}, but rosdep ignores this dependency so it misses the PCL headers.
- Contributors: Ramon Wijnands
0.6.2 (2024-06-13)
0.6.1 (2024-06-04)
0.6.0 (2024-05-14)
- Switch from deprecated signature to const shared_ptr reference while still supporting efficient intra-process communication See https://github.com/ros2/rclcpp/pull/1598.
- Convert USS driver from node to component
- Add launch argument for parameters and unify launch file names
- Contributors: Robin Petereit, Sarah Huber
0.5.1 (2024-03-27)
- Include what you use
- Remove unused variable
- Properly include rclcpp/executors.hpp when using spin_some
- Disable irrelevant warnings for Clang Anonymous structs are used in PCL for type punning: https://github.com/PointCloudLibrary/pcl/issues/2303 Subobject braces are not needed: https://bugs.llvm.org/show_bug.cgi?id=21629 https://gcc.gnu.org/bugzilla/show_bug.cgi?id=25137
- Contributors: Ramon Wijnands, Robin Petereit
Wiki Tutorials
Package Dependencies
Deps | Name |
---|---|
ament_cmake | |
ament_lint_auto | |
ament_lint_common | |
ament_cmake_ros | |
rclcpp | |
rclcpp_components | |
sensor_msgs | |
can_msgs | |
off_highway_can | |
off_highway_uss_msgs | |
pcl_conversions | |
pcl_ros |
System Dependencies
Dependant Packages
Name | Deps |
---|---|
off_highway_sensor_drivers |