一、参数指标:
ROC 300 是不止技术推出的单线激光雷达产品。该雷达使用脉冲飞行时间法(Pulsed ToF)进行距离测量,其内部结构采用转镜式设计,即通过高速旋转的反射镜面将测距模块发射的不可见红外激光偏转到不同的角度,从而实现对同一水平面 300°范围内环境轮廓的扫描测量。ROC 300 每秒可输出 20K 点云数据,同时可满足客户最大 50米测距需求;采用 905nm 红外激光,配合自研信号处理算法,整机防尘防水达到 IP65,满足户外应用场景需求。



与同类产品相比,ROC 300 具有如下特点:

远距离,高精度。由于采用脉冲测距原理并着力优化光电设计,ROC 300 对相同反射率的目标具有更远的测量距离,且全量程精度都可以保证在+/-3cm 以内,非常适于大空间场景使用。

高转速,低噪声。采用反射镜式旋转扫描,转动部件仅为一面极轻的反射镜片,所以可以达到 30HZ 的高转速,最高可扩展到 50HZ,且维持极低的噪声,人耳几乎听不到。

可靠性高,通配性强。转镜式设计使雷达内部的运动部件降至最少,提高了使用寿命并大大降低了机械振动对运行的影响;此外 ROC 300 采用 micro USB 接口设计,可灵活切换 UART 和以太网口。

体积小,重量轻。雷达主体高度不超过 7.5 厘米且底座边长仅为 5 厘米,便于在空间受限的场合安装。

1.1 主要参数指标
激光波长:905nm,class I

探测范围:0.1m~50m

重复精度:3cm

水平视场角:300°

扫描频率:10HZ~30HZ

水平角分辨率:0.18°(10HZ)~0.54°(30HZ)

抗强光:>80000LX

电源供电:5V/500mA

功耗:‹2.5w

外形尺寸:50mm _ 50mm _ 75mm

重量:150g

防护等级:IP65

接口:micro-USB、以太网口、RS232、NPN

工作环境温度:-10℃~55℃

存储环境温度:-30℃~75℃

二、资料及主要组件说明
官网下载中心:下载中心-深圳市不止技术有限公司-深圳市不止技术有限公司




2.1 开箱实物



此次我主要测试其网口模块,所以让厂家配置了USB转网口的转接模块,雷达本省是micro-USB接口。

2.2 网络转接板






三、NVISTAR 点云客户端(windows版本)使用(micro-USB)
3.1 获取工具软件


下载解压后,获得文件和使用说明:



软件是免安装版本,直接打开即可:



**备注:我们测试的是网口模式

3.2 雷达接入WIN电脑

将自己电脑的IP设置到1网段



可以ping通网络转接板



3.3 工具软件链接雷达




配置正确,即可以看到点云数据。

3.4 网络转接板参数配置
这个雷达其实网口是使用转接板,将串口转为了网口,所以修改IP之类的操作,其实是修改网口转接模块的IP,所以需要一个专用工具:




首先读取参数:



修改IP:



修改IP后,需要重启转接板



可以Ping通,新的IP已经生效。

四、ROS1环境显示点云(网口)

包获取,从官网下载页面可以找到。

4.1 建立工作空间

mkdir -p ~/SensorWS/Nvistar_ws/src
cd ~/SensorWS/Nvistar_ws/
catkin_make
source devel/setup.bash

4.2 拷贝代码

cd ~/SensorWS/Nvistar_ws/src
#将官网地址的代码包放置到这个目录解压

4.3 编译源码包

cd ~/SensorWS/Nvistar_ws
catkin_make --pkg nvilidar_ros


编译完成。

4.4 将雷达通过网口接入E100系统
先确保板子链接网口对应IP也是1网段,之前雷达已经确认是1网段了。



其次就是在板子上可以ping通雷达的IP:192.168.1.100



雷达和板子之前网络链接没有问题。

4.5 修改测试代码环境为网口模式
1、修改launch 文件

/home/nvidia/Nvistar_ws/src/nvilidar_ros/launch/lidar.launch 脚本内容

/home/nvidia/SensorWS/Nvistar_ws/src/nvilidar_ros/launch
vim lidar.launch

<launch>
  <node name="nvilidar_node"  pkg="nvilidar_ros"  type="nvilidar_node" output="screen" respawn="false" >
    <param name="serialport_name"             type="string" value="/dev/nvilidar"/>
    <param name="serialport_baud"             type="int" value="512000"/>
    <param name="ip_addr"                     type="string" value="192.168.1.200"/>
    <param name="lidar_udp_port"              type="int" value="8100"/>
    <param name="config_udp_port"             type="int" value="8200"/>
    <param name="frame_id"                    type="string" value="laser_frame"/>
    <param name="resolution_fixed"            type="bool"   value="true"/>
    <param name="auto_reconnect"              type="bool"   value="true"/>
    <param name="reversion"                   type="bool"   value="false"/>
    <param name="inverted"                    type="bool"   value="false"/>
    <param name="angle_min"                   type="double" value="-180" />
    <param name="angle_max"                   type="double" value="180" />
    <param name="range_min"                   type="double" value="0.001" />
    <param name="range_max"                   type="double" value="64.0" />
    <param name="aim_speed"                   type="double" value="10.0"/>
    <param name="sampling_rate"               type="int" value="10"/>
    <param name="sensitive"                   type="bool" value="false"/>
    <param name="tailing_level"               type="int" value="6"/>
    <param name="angle_offset_change_flag"    type="bool" value="false"/>
    <param name="angle_offset"                type="double" value="0.0" />
    <param name="apd_change_flag"             type="bool" value="false"/>
    <param name="apd_value"                   type="int"  value="500"/>
    <param name="ignore_array_string"         type="string" value="" />
    <param name="filter_jump_enable"          type="bool"  value="true" />
    <param name="filter_jump_value_min"       type="int"  value="3" />
    <param name="filter_jump_value_max"       type="int"  value="50" />
​
  </node>
  <node pkg="tf" type="static_transform_publisher" name="base_link_to_laser"
    args="0.19 0.0 0.2 0.06 0.0  0.0 /base_footprint /laser_frame 40" />
</launch>

可根据你实际的硬件环境和需要,修改网口,扫描角度等参数。



2、修改nvilidar_node.cpp 文件
原始:



修改后:



4.6 重新编译和启动
上面我们改了原代码文件配置,所以需要重新编译工程

cd ~/SensorWS/Nvistar_ws
catkin_make --pkg nvilidar_ros


启动:

cd ~/SensorWS/Nvistar_ws
source devel/setup.bash 
roslaunch nvilidar_ros lidar.launch

打开一个新的终端,可以查询节点信息

rosnode list

/base_link_to_laser
/nvilidar_node
/rosout

rosnode info /nvilidar_node

Node [/nvilidar_node]
Publications:

  • /rosout [rosgraph_msgs/Log]
  • /scan [sensor_msgs/LaserScan]

    Subscriptions: None

    Services:
  • /nvilidar_node/get_loggers
  • /nvilidar_node/set_logger_level


    contacting node http://nvidia-desktop:43281/
    Pid: 10996
    Connections:
  • topic: /rosout
    • to: /rosout
    • direction: outbound (38203 - 127.0.0.1:44442) [11]
    • transport: TCPROS

4.7 启动RVIZ查看点云
打开终端,启动雷达节点

cd ~/SensorWS/Nvistar_ws
source devel/setup.bash 
roslaunch nvilidar_ros lidar.launch

打开新终端,启动rviz,在nomachine 终端桌面登录

rosrun rviz rviz


此时还没有任何信息,官方给我们提供好了rviz的配置文件,我们可以不用配置,直接打开使用。





五、ROS2-eloquent驱动测试(网口)
包获取,从官网下载页面可以找到。

5.1 建立工作空间目录

source /opt/ros/eloquent/setup.bash
mkdir -p ~/SensorWS/Nvistar_Ros2ws/src
cd ~/SensorWS/Nvistar_Ros2ws/

5.2 拷贝代码

cd ~/SensorWS/Nvistar_Ros2ws/src
#将官网地址的代码包放置到这个目录解压


5.3 解决依赖关系(Resolve dependencies)
在构建工作区之前,您需要解决包依赖关系。可能已经拥有所有依赖项,如果不希望构建在长时间等待后因为缺少依赖项而失败,最好做法是在每次检查依赖项。

cd ~/SensorWS/Nvistar_Ros2ws/
rosdep install -i --from-path src --rosdistro eloquent -y

如果出现如下错误,继续使用之前安装的时候提示使用的小鱼一键安装。



解决错误

wget http://fishros.com/install -O fishros && . fishros


完成后继续之前的建立依赖的命令,就可以成功了。备注:我由于同时安装了ROS1和ROS2,所以后面才会多选一步。
继续建立依赖

cd ~/SensorWS/Nvistar_Ros2ws/
rosdep install -i --from-path src --rosdistro eloquent -y


5.4 使用colcon 编译工程

cd ~/SensorWS/Nvistar_Ros2ws/
#编译
colcon build


报警先不管,可以编译通过。
#colcon build还可以带一些参数,这个做个分享:
—packages-up-to 只编译指定包,其所有依赖项,但不构建整个工作区(节省时间)
—symlink-install避免每次调整python脚本时都需要重新构建
—event-handlers console_direct+ 显示生成时的控制台输出(否则可以在“log”目录中找到)



编译完,记得生效,类似ROS1中的source

cd ~/SensorWS/Nvistar_Ros2ws/src/nvilidar_ros2/params
vim nvilidar.yaml

5.5 修改代码,使用网口模式

cd ~/SensorWS/Nvistar_Ros2ws/src/nvilidar_ros2/params
vim nvilidar.yaml


原始:



修改后:



修改nvilidar_ros2_node.cpp 文件



修改后:


因为修改了代码,记得重新编译

cd ~/SensorWS/Nvistar_Ros2ws/
#编译
colcon build


有报警,可以不用管。
5.6 运行测试节点,查看点云

cd ~/SensorWS/Nvistar_Ros2ws/
#执行覆盖
. install/local_setup.bash
#启动脚本文件
ros2 launch nvilidar_ros2 nvilidar_launch.py


可以看到,程序已经起来,并且开始扫描
我们可以打开一个新的窗口,查看一下节点和话题这些基本信息

cd ~/SensorWS/Nvistar_Ros2ws/
#执行覆盖
. install/local_setup.bash

ros2 node list

/launch_ros_15285
/nvilidar_ros2_node
/static_tf_pub_laser

ros2 node info /nvilidar_ros2_node

/nvilidar_ros2_node
  Subscribers:
    /parameter_events: rcl_interfaces/msg/ParameterEvent
  Publishers:
    /parameter_events: rcl_interfaces/msg/ParameterEvent
    /rosout: rcl_interfaces/msg/Log
    /scan: sensor_msgs/msg/LaserScan
  Service Servers:
    /nvilidar_ros2_node/describe_parameters: rcl_interfaces/srv/DescribeParameters
    /nvilidar_ros2_node/get_parameter_types: rcl_interfaces/srv/GetParameterTypes
    /nvilidar_ros2_node/get_parameters: rcl_interfaces/srv/GetParameters
    /nvilidar_ros2_node/list_parameters: rcl_interfaces/srv/ListParameters
    /nvilidar_ros2_node/set_parameters: rcl_interfaces/srv/SetParameters
    /nvilidar_ros2_node/set_parameters_atomically: rcl_interfaces/srv/SetParametersAtomically
  Service Clients:


Action Servers:

Action Clients:

查看点云,我们可以直接用官方已经提供好的脚本文件,直接运行节点加打开查看电云,会简单很多。记得关闭之前已经打开的节点。

nomachine 的终端中运行如下命令

cd ~/SensorWS/Nvistar_Ros2ws/
#执行覆盖
. install/local_setup.bash
#启动脚本文件
ros2 launch nvilidar_ros2 nvilidar_launch_view.py


六、总结
这是我第一次完整的用ROS2 eloquent 测试一个硬件设备,所以再测试过程中,其实我自己也是翻看了很多之前的记录,发现还是一个实际操作的完成流程,更能加深自己对ROS2的理解,熟悉其操作和常用指令。
ROC 300 其ROS2和ROS1的驱动支持还是很不错了,这个必须给个好评。其次就是雷达,我支持在测试环境驱动起来,准备跑一个晚上,看看其稳定性。
这个雷达的性价比,还是很适合做教育级和商业级的机器人产品的,轻巧,尤其是USB接口的设计,可以看出来,设计师还是为实际稳定可靠使用画了心思的,给个好评。