❓ How can I run multiple sensors concurrently with sick_scan_xd ?
✅ To support multiple sensors, sick_scan_xd has to be started multiple times, with one sick_scan-node for each sensor. By default, each sick_scan-node connects to "192.168.0.1" and publishes its pointcloud on topic "cloud". Therefore both the node name, the ip-address of the sensor and the pointcloud topic have to be configured differently for each node.
Node name, ip-address and pointcloud topic can be configured in the launch-file or by commandline argument:
-
Topic, nodename and ip configuration in a launch-file (example for TiM7xx):
<launch> <arg name="nodename" default="sick_tim_7xx"/> <arg name="hostname" default="192.168.0.1"/> <arg name="cloud_topic" default="cloud"/> <node name="$(arg nodename)" pkg="sick_scan" type="sick_generic_caller" respawn="false" output="screen"> <param name="scanner_type" type="string" value="sick_tim_7xx"/> <param name="nodename" type="string" value="$(arg nodename)"/> <param name="hostname" type="string" value="$(arg hostname)"/> <param name="cloud_topic" type="string" value="$(arg cloud_topic)"/>
-
Topic, node name and ip configuration by commandline (ROS1-example for TiM7xx):
roslaunch sick_scan sick_tim_7xx.launch nodename:=sick_tim_7xx_1 hostname:=192.168.0.1 cloud_topic:=cloud_1 roslaunch sick_scan sick_tim_7xx.launch nodename:=sick_tim_7xx_2 hostname:=192.168.0.2 cloud_topic:=cloud_2
-
Topic, node name and ip configuration by commandline (ROS2-example for TiM7xx):
ros2 run sick_scan sick_generic_caller ./src/sick_scan_xd/launch/sick_tim_7xx.launch nodename:=sick_tim_7xx_1 hostname:=192.168.0.1 cloud_topic:=cloud_1 ros2 run sick_scan sick_generic_caller ./src/sick_scan_xd/launch/sick_tim_7xx.launch nodename:=sick_tim_7xx_2 hostname:=192.168.0.2 cloud_topic:=cloud_2
Scripts run_linux_ros1_simu_tim7xx_twin.bash and run_linux_ros2_simu_tim7xx_twin.bash show a complete example with emulation of two TiM7xx sensors and two sick_scan nodes running concurrently using different nodenames and topics.
❓ The sick_scan_xd driver restarts again and again after an error message "sFA".
✅ The behaviour is intentional. The error message "sFA" can be caused by faulty configuration or errors in the lidar. Correct operation after this error message is not guaranteed. In this case, the driver restarts itself. It is recommended to identify and correct the error using its error number ("sFA<hexcode>
"). The SOPAS error codes are listed in the manual.
❓ The sick_scan_xd driver changes the communication protocol and restarts after a timeout error.
✅ The use of binary communication (Cola-B) is highly recommended due to better compatibility, lower network traffic and general support. Recommendation:
- Set parameter "use_binary_protocol" to "true" in the launch file, and
- Set the lidar communication mode with the SOPAS ET software to binary and save this setting in the scanner's EEPROM.
❓ roslaunch still uses an old version after modifying the launch-file.
✅ After modifying a launch-file, it has to be installed by running catkin_make_isolated --install --cmake-args -DROS_VERSION=1
to be located and used by roslaunch
.
❓ How can I create a ROS-2 node in python to run sick_generic_caller from a launch.py-file in ROS-2?
✅ Example to launch a TiM-7xx node in ROS-2:
sick_scan_pkg_prefix = get_package_share_directory('sick_scan')
tim_launch_file_path = os.path.join(sick_scan_pkg_prefix, 'launch/sick_tim_7xx.launch')
tim_top_node = Node(
package='sick_scan',
executable='sick_generic_caller',
output='screen',
arguments=[
tim_launch_file_path,
'nodename:=/lidars/tim_top',
'hostname:=192.168.0.110',
'cloud_topic:=/lidars/tim_top/cloud',
'frame_id:=tim_top'
]
)
Thanks to user JWhitleyWork.
❓ What timestamp is provided in the pointcloud and laserscan messages?
✅ Details about timestamps are given in timing.md and software_pll.md.
In a nutshell: The lidars do not work with absolute time stamps but with "ticks". There are two types of tick timestamps:
- Tick timestamps for the generation
- Tick timestamps for sending the message To match the tick timestamps against the system time, a straight line equation is estimated via the so-called software PLL, which can be used to calculate from the system time to the ticks in the lidar (and vice versa). The assumption is that the tick timestamp for sending the message corresponds to the system time when receiving the message. In reality there will be a tiny delay here. This delay can be ignored.
With the help of this straight line equation, one can now calculate the system time at which the data is generated in the lidar.
Summary:
- lidar: stamp with ticks the generation (first shot in the scan) (TICK_GEN)
- lidar: stamp with ticks the sending of the scan message (TICK_TRANSMIT)
- PC: Stamp with system time the receiving of the message
- PC: Calculate back to system time of generation: System time of generation = System time of receiving - (TICK_TRANSMIT - TICK_GEN)/TICK_FREQUENCY
❓ Compiler reports errors in file /opt/ros/<distro>/include/sick_scan
✅ If sick_scan was previously installed using apt-get install ros-<distro>-sick-scan
, you have to remove previous versions using apt-get purge ros-<distro>-sick-scan
. Run the following steps for a complete rebuild:
- Run
sudo apt-get purge ros-<distro>-sick-scan
(e.g.sudo apt-get purge ros-noetic-sick-scan
) to remove previously installed sick_scan-packages - Remove the folders sick_scan_xd/build, sick_scan_xd/build_isolated, sick_scan_xd/devel, sick_scan_xd/devel_isolated, sick_scan_xd/install and sick_scan_xd/install_isolated
- Rebuild
❓ cmake cannot find diagnostic_updater
✅ On ROS-2 foxy, package diagnostic_updater needs to be installed by
sudo apt-get update
sudo apt-get install ros-$ROS_DISTRO-diagnostic-updater # install diagnostic_updater
# E.g. to install diagnostic_updater on foxy, run
# sudo apt-get install ros-foxy-diagnostic-updater
❓ catkin gives me the following error message:
By not providing "FindSICKLDMRS.cmake" in CMAKE_MODULE_PATH this project ..., but CMake did not find one."
✅ One problem with ROS is that it doesn't automatically rebuild everything if you just append "-DLMRRS=0". If you accidentally did the following call before
catkin_make_isolated --install --cmake-args -DROS_VERSION=1
you must remove the build/devel/install-directories created by the ROS build process. For this please run the following commands to remove the directories, which holds the previous build results:
cd ~/ros_catkin_ws
rm -rf build_isolated
rm -rf devel_isolated
rm -rf install_isolated
rm -rf devel
It is possible that not all directories are present in this list. But that does not matter. The only subdirectory left should be "src". You can check this with the following command:
ls */ -d
The output should be:
src/
After doing this please rerun the command catkin_make_isolated --install --cmake-args -DROS_VERSION=1 -DLDMRS=0
❓ cmake cannot find header msgpack11.hpp
✅ You probably forgot to checkout https://github.com/SICKAG/msgpack11.git. Please clone the following repositories:
git clone https://github.com/SICKAG/libsick_ldmrs.git
git clone https://github.com/SICKAG/msgpack11.git
git clone https://github.com/SICKAG/sick_scan_xd.git
and rebuild. See the build instructions Build on Linux generic without ROS, Build on Linux ROS1, Build on Linux ROS2, Build on Windows or Build on Windows ROS2 for further details.
❓ rviz shows a grey point cloud. The size of points can be adjusted.
✅ Check in the launch file that the intensity flag is set to True.
❓ rviz shows a grey point cloud and the size of points can not be adjusted.
✅ Probably in this case you are running Linux in a virtual machine. In this case, OpenGL may not work correctly in the VM. rviz then chooses a kind of "fallback solution" and deactivates the colors. Also, changing the "Size" and "Style" display in rviz has no effect on the display of the pointcloud data.
The problem can be avoided by starting rviz with the following sequence:
export LIBGL_ALWAYS_SOFTWARE=1
rosrun rviz rviz
❓ The angular resolution/ number of shots is too small
✅ Possibly Mean or Median filters are activated. Use Sopas ET to deactivate them and store this settings permanent on the device, see picture. Further information can be found at http://wiki.ros.org/rviz/Troubleshooting.
❓ Independent of the configuration, the LMS1xxx pointcloud always displays 0.75 [deg] angular resolution
✅ Using higher resolutions, the LMS1xxx sends scan data interlaced. With configuration ang_res=0.75, the angular resolution of each scan is 0.75 [deg]. This means that each point cloud message also has a resolution of 0.75 [deg]. With configuration ang_res=0.375, the scan is generated interlaced: Each scan still has 0.75 [deg] resolution, but 2 consecutive scans are rotated by 0.375 [deg] against each other. I.e. 2 consecutive Pointcloud messages each have an angular resolution of 0.375 [deg] at half the frequency. Within a point cloud message the angular resolution is still 0.75 [deg].
With configuration ang_res=0.1875 the scan is generated quadruple interlaced, i.e. 4 consecutive scans are each rotated by 0.1875 [deg]. Each scan is resolved with 0.75 [deg]; 4 scans or 4 pointclouds together (accumulated) result in a resolution of 0.1875 [deg] at a quarter of the frequency.
You can see this in rviz by increasing the decay time to e.g. 4/75=0.054 or higher. The screenshot shows an example with the default setting ang_res=0.75:
The angular resolution is (just roughly measured) about atan(0.11/0.9) / 9 points = 0.77 [deg]. With ang_res=0.375 and decay=0.1 rviz shows twice the resolution:
Correspondingly, rviz shows four times the resolution with ang_res=0.1875 and decay=0.1:
To use the full angular resolution, the pointcloud must be accumulated by 2 resp. 4 messages.
The active configuration can be seen in the log output during scanner initialization, e.g.:
[ INFO] [1669294673.078608968]: sRA LMPscancfg: scan frequency = 75 Hz, angular resolution = 0.375 deg.
❓ Question: sick_generic_caller gives you an answer like:
"ERROR: Tcp::open: Failed to open TCP connection to 192.168.0.1, aborting."
✅ Answer:
-
Try to ping your device:
ping 192.168.0.1
-
Disconnect your scanner and retry ping
ping 192.168.0.1
The result of ping contains a pattern like
... Destination Host Unreachable
-
Reconnect your device and try to ping:
ping 192.168.0.1
If you do not know the ip address, try to find the ip address in your subnet:
apt-get install fping
scan your network (for example, subnet 192.168.10.0/24):
192.168.0.1/24
search for all ip addresses from 192.168.0.0 to 192.168.0.255
The result is similar to:
192.168.0.4 is alive
192.168.0.22 is alive
and a lot of unreachable entries. In the example the ip address 192.168.0.4 is the laserscanner MRS1104 and the ip address 192.168.0.22 is the computer running linux. Check this with
ifconfig|grep 192.168.0.22
❓ Question: My scanner does not use the default ip address. What shall I do?
✅ Answer: There are two options doing this:
- Permanently:
Replace the following entry with your ip address.
<param name="hostname" type="string" value="192.168.0.1" />
- Temporarily
Use a command line argument in addition to the launch file argument:
hostname:=192.168.0.2
❓ Question: During start phase the are warning/error message like
no answer received after 5000 ms. Maybe sopas mode is wrong.
and some more warning/error messages:
✅ Answer: In this case the driver tries to start the scanner in binary mode. If this is not possible, warnings and error messages are generated. The driver switches the scanner from ASCII mode to binary mode and then restarts communication. The messages can therefore be ignored. For a long-term solution, we recommend switching from ASCII to binary communication with SOPAS ET under Windows.
❓ Question: I would like to process data with my own methods.
✅ Answer: Search for keyword "PUBLISH_DATA:" in the code and replace the code for writing jpeg-files and CSV-files with your own source code.
❓ Question:
Occasionally, no scan data appear, but the scanner is still reachable using ping <ip-address>
or nc -z -v <ip-address> <port>
✅ Answer: This is likely to be a data capture issue. In any case it's recommend (if not already set) to use SOPAS-Binary instead of SOPAS-ASCII, because here the data rate is lower.
In addition, the following measures can help to determine the source of the problems: a) Exchange the cables to the lidar(s) incl. the network cables b) Exchange the power supply to the lidar(s) c) avoidance of interconnection of other components (like switch etc.) d) upgrade hardware and firmware of devices (if new versions available)
If it is not a hardware problem (e.g. cable), check if there are other software components using the network interface.
If there are still problems, use Wireshark to see if there are any communication problems reported. Wireshark can export the recorded network traffic as text (see screenshot). Search for entries like "LMDscandata" in the generated text file. This marks the beginning of a new scan message. You can then compare the order of the timestamps of these packets to see if there were any failures.
❓ Question: On Windows with ROS, cmake complains "python_d.exe not found" when running rosidl generator
✅ Answer: Workaround: Copy python.exe to python_d.exe in the python folder.
❓ Question: How can I debug sick_generic_caller on ROS-1?
✅ Answer:
Build with compiler option -g
and run sick_generic_caller as described using a launchfile. Stop sick_generic_caller (Ctrl-C or kill) and save the current ros parameter using rosparam dump <dumpfile>.yaml
. Load these parameter with rosparam load <dumpfile>.yaml
and restart sick_generic_caller in gdb or in your IDE.
❓ Question: The X,Y points of the lidar show a curved line even though the lidar is scanning a straight wall. How can this be?
✅ Answer: This effect occurs when the lidar has multiple planes that are tilted up or down. In this case, the laser beams of this plane do not lie on a flat plane. Rather, the beams lie on a cone. If the laser beams then hit a wall, the result is a curved course of the lidar points. If the lidar is horizontal and the wall is vertical, this is a hyperbola (see following figure):
This image is generated using the website https://www.intmath.com/plane-analytic-geometry/conic-sections-summary-interactive.php
Thus, the mathematical laws for a conic section apply, as they are explained e.g. at Wikipedia at https://en.wikipedia.org/wiki/Conic_section.
❓ Question: How should I interpret the scan rate and lidar resolution from the manual? What is the relationship between ROS point cloud publishing rate and scan frequency here?
✅ Answer:
The angular resolution and scan frequency is configurable in many lidars such as the LRS-4xxx or MRS-1xxx. Depending on the lidar type, angular resolution and scan frequency can be set in the launch file either via the parameter "scan_cfg_list_entry" or the parameters "ang_res" and "scan_freq". Angular resolution and scan frequency are not independent of each other. If no default settings are used, the values must be selected according to the manual for the respective lidar and set in launch file.
An increase in resolution is achieved by interlacing by a factor of N. This means that N consecutive scans are rotated by a constant angular offset. Each scan in itself still has the physically given angular resolution and frequency. By concatenating N interlaced scans, the angular resolution is increased by the factor N.
Example: The default setting of an MRS-1xxx is 0.25 degrees horizontal angular resolution at 50 Hz scan frequency without interlacing and an angular range of 275 degrees in total. I.e. each scan measures the distance at the hor. angles [ ..., 0.000, 0.250, 0.500, 0.750, ... ].
If 0.125 degrees horizontal angular resolution is configured at 25 Hz scan frequency, the scans are performed with 2 times interlacing (N=2). Every 2nd scan is horizontally shifted by 0.125 degrees. I.e. each scan measures alternately at the hor. angles [ ..., 0.000, 0.250, 0.500, 0.750, ... ] and [ ... , 0.125, 0.375, 0.625, 0.875 ... ]. 50 single scans per second resp. 25 interlaced scans per second are sent.
If 0.0625 degrees horizontal angular resolution at 12.5 Hz scan frequency is configured, the scans are performed with 4 times interlacing (N=4). Successive scans are shifted horizontally by 0.0625 degrees each. That is, each scan measures alternately at the hor. angles [ ..., 0.000, 0.250, 0.500, 0.750, ... ], [... , 0.0625, 0.3125, 0.5625, 0.8125 ... ], [... , 0.125, 0.375, 0.625, 0.875 ... ] and [... , 0.1875, 0.4375, 0.6875, 0.9375 ... ]. 50 single scans per second resp. 12.5 interlaced scans per second are sent.
In interlacing mode, laser scan and point cloud messages are published interlaced, too. In rviz, the higher angular resolution is clearly visible when the decay time is increased. If you check the publishing rate of the point cloud messages, you will measure 50 Hz, since 50 interlace messages are sent per second. But the resolution of each single message is 0.125 [deg]. Only by interleaving 4 consecutive messages you get the high resolution of 0.0625 [deg].