The RoboSense Lidar may work in unicast/multicast/broadcast mode, with VLAN layer and with user layers.
This document illustrates how to configure the driver in each case.
Before reading this document, please be sure that you have read Decode online Lidar.
The simplest way is broadcast mode.
The Lidar sends MSOP/DIFOP packets to the host machine (The driver runs on it). For simplicity, the DIFOP port is ommited here.
255.255.255.255
: 6699
, and the host binds to port 6699
.Below is how to configure RSDriverParam variable.
RSDriverParam param; ///< Create a parameter object
param.input_type = InputType::ONLINE_LIDAR; ///< get packet from online lidar
param.input_param.msop_port = 6699; ///< Set the lidar msop port number, the default is 6699
param.input_param.difop_port = 7788; ///< Set the lidar difop port number, the default is 7788
param.lidar_type = LidarType::RS32; ///< Set the lidar type.
To reduce the network load, the Lidar is suggested to work in unicast mode.
192.168.1.102
: 6699
, and the host binds to port 6699
.Below is how to configure the RSDriverParam variable. In fact, it is same with the broadcast case.
RSDriverParam param; ///< Create a parameter object
param.input_type = InputType::ONLINE_LIDAR; ///< get packet from online lidar
param.input_param.msop_port = 6699; ///< Set the lidar msop port number, the default is 6699
param.input_param.difop_port = 7788; ///< Set the lidar difop port number, the default is 7788
param.lidar_type = LidarType::RS32; ///< Set the lidar type.
The Lidar may also works in multicast mode.
224.1.1.1
:6699
6699
. And it makes local NIC (Network Interface Card) join the multicast group 224.1.1.1
. The local NIC's IP is 192.168.1.102
.Below is how to configure the RSDriverParam variable.
RSDriverParam param; ///< Create a parameter object
param.input_type = InputType::ONLINE_LIDAR; ///< get packet from online lidar
param.input_param.group_address = "224.1.1.1"; ///< Set the multicast group address.
param.input_param.host_address = "192.168.1.102"; ///< Set the host address.
param.input_param.msop_port = 6699; ///< Set the lidar msop port number, the default is 6699
param.input_param.difop_port = 7788; ///< Set the lidar difop port number, the default is 7788
param.lidar_type = LidarType::RS32; ///< Set the lidar type. Make sure this type is correct
If you have two Lidars, it is suggested to set different remote ports.
192.168.1.102
:6699
, and the first driver instance binds to 6699
.192.168.1.102
:5599
, and the second driver instance binds to 5599
.Below is how to configure the RSDriverParam variables.
RSDriverParam param1; ///< Create a parameter object for Lidar 192.168.1.200
param1.input_type = InputType::ONLINE_LIDAR; ///< get packet from online lidar
param1.input_param.msop_port = 6699; ///< Set the lidar msop port number
param1.input_param.difop_port = 7788; ///< Set the lidar difop port number
param1.lidar_type = LidarType::RS32; ///< Set the lidar type.
RSDriverParam param2; ///< Create a parameter object for Lidar 192.168.1.201
param2.input_type = InputType::ONLINE_LIDAR; ///< get packet from online lidar
param2.input_param.msop_port = 5599; ///< Set the lidar msop port number
param2.input_param.difop_port = 6688; ///< Set the lidar difop port number
param2.lidar_type = LidarType::RS32; ///< Set the lidar type.
An alternate way is to set different remote IPs.
192.168.1.102
and 192.168.1.103
.192.168.1.102
:6699
, and the first driver instance binds to 192.168.1.102:6699
.192.168.1.103
:6699
, and the second driver instance binds to 192.168.1.103:6699
.Below is how to configure the RSDriverParam variables.
RSDriverParam param1; ///< Create a parameter object for Lidar 192.168.1.200
param1.input_type = InputType::ONLINE_LIDAR; ///< get packet from online lidar
param1.input_param.host_address = "192.168.1.102"; ///< Set the host address.
param1.input_param.msop_port = 6699; ///< Set the lidar msop port number
param1.input_param.difop_port = 7788; ///< Set the lidar difop port number
param1.lidar_type = LidarType::RS32; ///< Set the lidar type.
RSDriverParam param2; ///< Create a parameter object for Lidar 192.168.1.201
param2.input_type = InputType::ONLINE_LIDAR; ///< get packet from online lidar
param2.input_param.host_address = "192.168.1.103"; ///< Set the host address.
param2.input_param.msop_port = 6699; ///< Set the lidar msop port number
param2.input_param.difop_port = 7788; ///< Set the lidar difop port number
param2.lidar_type = LidarType::RS32; ///< Set the lidar type.
In some user cases, The Lidar may work on VLAN. Its packets have a VLAN layer.
The driver cannot parse this packet. Instead, it depends on a virtual NIC to strip the VLAN layer.
Below is an example.
80
. It sends packets to 192.168.1.102
: 6699
. The packet has a VLAN layer.eno1
on the host. It receives packets with VLAN layer.To strip the VLAN layer, create a virtual NIC eno1.80
on eno1
, and assign IP 192.168.1.102
to it.
sudo apt-get install vlan -y
sudo modprobe 8021q
sudo vconfig add eno1 80
sudo ifconfig eno1.80 192.168.1.102 up
Now the driver may take eno1.80
as a general NIC, and receives packets without VLAN layer.
RSDriverParam param; ///< Create a parameter object
param.input_type = InputType::ONLINE_LIDAR; ///< get packet from online lidar
param.input_param.msop_port = 6699; ///< Set the lidar msop port number, the default is 6699
param.input_param.difop_port = 7788; ///< Set the lidar difop port number, the default is 7788
param.lidar_type = LidarType::RS32; ///< Set the lidar type.
In some user cases, User may add extra layers before or after the MSOP/DIFOP packet.
These extra layers are parts of UDP data. The driver can strip them.
To strip them, just give their lengths in bytes.
In the following example, USER_LAYER is 8 bytes, and TAIL_LAYER is 4 bytes.
RSDriverParam param; ///< Create a parameter object
param.input_type = InputType::ONLINE_LIDAR; ///< get packet from online lidar
param.input_param.msop_port = 6699; ///< Set the lidar msop port number, the default is 6699
param.input_param.difop_port = 7788; ///< Set the lidar difop port number, the default is 7788
param.input_param.user_layer_bytes = 8; ///< user layer bytes. there is no user layer if it is 0
param.input_param.tail_layer_bytes = 4; ///< tail layer bytes. there is no user layer if it is 0
param.lidar_type = LidarType::RS32; ///< Set the lidar type.