当前位置:   article > 正文

【EHub_tx1_tx2_E100】 ROS_ Melodic + Astra S(如何在该环境下打开摄像机获取rgb/深度图/点云)_astra pro深度相机的点云数据如何保存

astra pro深度相机的点云数据如何保存

        简介:介绍奥比中光 Astra S 深度相机 在EHub_tx1_tx2_E100载板,TX1核心模块环境(Ubuntu18.04)下测试ROS驱动,打开摄像头RGB图像和查看深度图和点云图,本文的前提条件是你的TX1里已经安装了ROS版本:Melodic。

关于测试硬件EHub_tx1_tx2_E100载板请查看:EdgeBox_EHub_tx1_tx2_E100 开发板评测_机器人虎哥的博客-CSDN博客

目录

一、什么是深度相机

二、深度相机在机器人中的两个使用场景

1、机械臂精准二次定位:

2、人员跟随:

三、奥比中光 Astra S相机介绍

四、奥比中光官方资料链接

五、 ROS_ Melodic环境安装相机驱动

5.1 安装依赖

5.2 建立工作空间

5.3 克隆代码

5.4 Create astra udev rule

5.5 编译源码包

5.6 【附件】编译中错误解决:

5.7 奥比中光深度相机ros架构

5.8 修改astrapro.launch

5.9 启动rqt_image_view 查看

5.10 启动rviz查看深度图和RGB图

六. 使用点云数据

2.1 新建rviz文件

2.2 编辑rviz文件

2.3 在rviz中显示点云


一、什么是深度相机

        深度相机是近几年兴起的新技术,相比较传统的相机,深度相机在功能上添加了一个深度测量,从而更方便准确的感知周围的环境及变化。

        深度相机有很多的应用场景,在我们日常生活中有很多深度相机的影子。那它可以用来做什么?三维建模、无人驾驶、机器人导航、手机人脸解锁、体感游戏等都用到了深度相机来实现其功能。

目前从实现深度相机这个功能的技术层面去分析,有以下几种主流方案:双目,结构光,tof。

二、深度相机在机器人中的两个使用场景

        移动机器人面临的3个基本问题,一是“我在哪”,二是“要去哪”,三是“怎么去”。各种相机和雷达的作用是感知和搜集机器人周边的环境信息,对环境进行建图(mapping),最后让机器人知道自己在哪,怎么去目的地,从而完成导航。例如,深度相机能通过“结构光”和“飞时”获取目标的距离信息,普通相机能获取目标“RGB”信息。由于深度相机存在视野小、噪声大、易受日光干扰、无法测量透射材质等问题,所以一般要附加激光雷达以弥补其弱点。

        激光雷达导航用于远距离导航定位,深度相机一般用于10米内更精确的物体定位,结合了RGB的深度相机可以更好地对物体进行识别和深度训练。深度相机比多线激光雷达价格更有优势,所以低速、近距离的环境也用来替代激光雷达,做避障使用。

        我们在机器人的开发中,深度相机主要有三个方面的使用:机械臂精准二次定位、人员跟随、避障。下面简单介绍其中两种:

1、机械臂精准二次定位:

        机器人在进行工作的过程中,需要机器人准确的定位到某一个点,再通过机械臂控制,使机械臂末端的相机拍出稳定的图片来实现算法识别。在机器人定位的过程中会存在误差问题,包括机器人面对机柜距离误差以及角度误差。精准二次定位则解决了这一问题。具体实现是利用深度相机的景深数据来感知机器人和机柜的位置,通过算法运算控制机械臂实现稳定抓拍功能。

算法思路:通过深度数据识别机柜边缘特征,再截取机柜平面判断机柜和机器人相对方位,根据实际测量距离值调整机械臂达到想要的最佳拍摄位置。

2、人员跟随:

        机器人有时候具有人员跟随的功能,跟随功能的技术实现结合了普通相机和深度相机的数据进行算法实现。通过普通相机数据进行人员判别,然后深度数据感知机器人和人员的距离及方位,从而控制机器人跟随目标人员。

算法思路:通过普通相机数据使用算法实现人员识别,获取对应人员的相应三维数据,从三维数据的组成形态判断人员和机器人的相对位置及方向。

因此深度相机提供三维信息,基于三维数据算法识别更为简单精确。

三、奥比中光 Astra S相机介绍

官方链接:https://developer.orbbec.com.cn/product_details.html?id=4

硬件结构特点:

系列参数:

 

四、奥比中光官方资料链接

Github 官方SDK ROS wiki

五、 ROS_ Melodic环境安装相机驱动

5.1 安装依赖

  1. # Assuming you have sourced the ros environment, same below
  2. sudo apt install libgflags-dev ros-$ROS_DISTRO-image-geometry ros-$ROS_DISTRO-camera-info-manager \
  3. ros-$ROS_DISTRO-image-transport ros-$ROS_DISTRO-image-publisher libgoogle-glog-dev libusb-1.0-0-dev libeigen3-dev
  4. sudo apt install ros-$ROS_DISTRO-rgbd-launch ros-$ROS_DISTRO-libuvc ros-$ROS_DISTRO-libuvc-camera ros-$ROS_DISTRO-libuvc-ros
 

5.2 建立工作空间

  1. mkdir -p ~/AstraS_ws/src
  2. cd ~/AstraS_ws/
  3. catkin_make
  4. source devel/setup.bash

5.3 克隆代码

  1. cd ~/AstraS_ws/src
  2. git clone https://github.com/orbbec/ros_astra_camera

5.4 Create astra udev rule

roscd astra_camera

5.5 编译源码包

  1. cd ~/AstraS_ws
  2. catkin_make --pkg astra_camera

5.6 【附件】编译中错误解决:

1、CMake Error at /opt/ros/melodic/share/cv_bridge/cmake/cv_bridgeConfig.cmake:113 (message):

 这是由于我升级了opencv ,只有opencv4了,所以将文件目录中的opencv修改为opencv4,即可。

 2、CMake Error at /opt/ros/melodic/share/image_geometry/cmake/image_geometryConfig.cmake:113 (message):

这是由于我升级了opencv ,只有opencv4了,所以将文件目录中的opencv修改为opencv4,即可。

3、/usr/bin/ld: cannot find -luvc

sudo apt install libuvc-dev

5.7 奥比中光深度相机ros架构

5.8 修改astrapro.launch

首先查看相机接口:

lsusb

其中:

修改Astrapro.launch

  1. cd ~/AstraS_ws/src/ros_astra_camera/launch/
  2. gedit astra.launch

原始内容:

不用改什么,直接启动

5.9 启动rqt_image_view 查看

  1. source ~/AstraS_ws/devel/setup.bash
  2. roslaunch astra_camera astra.launch

 这个没有关系,新的刚打开,没有进行校准,这个有个双目的结构光

启动rqt_image_view

rosrun rqt_image_view rqt_image_view 

深度图:

5.10 启动rviz查看深度图和RGB图

打开新终端,启动rviz

rosrun rviz rviz

Rviz中点击左下角Add

依次进行以下操作:Add -> By topic -> 选择对应的image即可

 

六. 使用点云数据

2.1 新建rviz文件

  1. cd ~/AstraS_ws/src
  2. mkdir rviz
  3. cd rviz
  4. touch depth_camera.rviz

2.2 编辑rviz文件

使用gedit编辑rviz文件

  1. cd ~/AstraS_ws/src/rviz
  2. sudo gedit depth_camera.rviz

填写代码如下

  1. Panels:
  2.  - Class: rviz/Displays
  3.    Help Height: 88
  4.    Name: Displays
  5.    Property Tree Widget:
  6.      Expanded:
  7.        - /Global Options1
  8.        - /Status1
  9.        - /Grid1
  10.        - /PointCloud21
  11.      Splitter Ratio: 0.5
  12.    Tree Height: 453
  13.  - Class: rviz/Selection
  14.    Name: Selection
  15.  - Class: rviz/Tool Properties
  16.    Expanded:
  17.      - /2D Pose Estimate1
  18.      - /2D Nav Goal1
  19.      - /Publish Point1
  20.    Name: Tool Properties
  21.    Splitter Ratio: 0.588679016
  22.  - Class: rviz/Views
  23.    Expanded:
  24.      - /Current View1
  25.    Name: Views
  26.    Splitter Ratio: 0.5
  27.  - Class: rviz/Time
  28.    Experimental: false
  29.    Name: Time
  30.    SyncMode: 0
  31.    SyncSource: PointCloud2
  32. Visualization Manager:
  33.  Class: ""
  34.  Displays:
  35.    - Alpha: 0.5
  36.      Cell Size: 1
  37.      Class: rviz/Grid
  38.      Color: 159; 147; 147
  39.      Enabled: true
  40.      Line Style:
  41.        Line Width: 0.0299999993
  42.        Value: Lines
  43.      Name: Grid
  44.      Normal Cell Count: 0
  45.      Offset:
  46.        X: 0
  47.        Y: 0
  48.        Z: 0
  49.      Plane: XZ
  50.      Plane Cell Count: 10
  51.      Reference Frame: camera_depth_optical_frame
  52.      Value: true
  53.    - Alpha: 1
  54.      Autocompute Intensity Bounds: true
  55.      Autocompute Value Bounds:
  56.        Max Value: 8.875
  57.        Min Value: 1.28500009
  58.        Value: true
  59.      Axis: X
  60.      Channel Name: intensity
  61.      Class: rviz/PointCloud2
  62.      Color: 255; 255; 255
  63.      Color Transformer: AxisColor
  64.      Decay Time: 0
  65.      Enabled: true
  66.      Invert Rainbow: false
  67.      Max Color: 255; 255; 255
  68.      Max Intensity: 4096
  69.      Min Color: 0; 0; 0
  70.      Min Intensity: 0
  71.      Name: PointCloud2
  72.      Position Transformer: XYZ
  73.      Queue Size: 10
  74.      Selectable: true
  75.      Size (Pixels): 3
  76.      Size (m): 0.00999999978
  77.      Style: Squares
  78.      Topic: /camera/depth/points
  79.      Unreliable: false
  80.      Use Fixed Frame: true
  81.      Use rainbow: true
  82.      Value: true
  83.  Enabled: true
  84.  Global Options:
  85.    Background Color: 48; 48; 48
  86.    Default Light: true
  87.    Fixed Frame: camera_depth_frame
  88.    Frame Rate: 30
  89.  Name: root
  90.  Tools:
  91.    - Class: rviz/Interact
  92.      Hide Inactive Objects: true
  93.    - Class: rviz/MoveCamera
  94.    - Class: rviz/Select
  95.    - Class: rviz/FocusCamera
  96.    - Class: rviz/Measure
  97.    - Class: rviz/SetInitialPose
  98.      Topic: /initialpose
  99.    - Class: rviz/SetGoal
  100.      Topic: /move_base_simple/goal
  101.    - Class: rviz/PublishPoint
  102.      Single click: true
  103.      Topic: /clicked_point
  104.  Value: true
  105.  Views:
  106.    Current:
  107.      Class: rviz/Orbit
  108.      Distance: 7.51409006
  109.      Enable Stereo Rendering:
  110.        Stereo Eye Separation: 0.0599999987
  111.        Stereo Focal Distance: 1
  112.        Swap Stereo Eyes: false
  113.        Value: false
  114.      Focal Point:
  115.        X: 2.80641723
  116.        Y: -0.0263374168
  117.        Z: -0.295807391
  118.      Focal Shape Fixed Size: true
  119.      Focal Shape Size: 0.0500000007
  120.      Invert Z Axis: false
  121.      Name: Current View
  122.      Near Clip Distance: 0.00999999978
  123.      Pitch: 0.305203468
  124.      Target Frame: <Fixed Frame>
  125.      Value: Orbit (rviz)
  126.      Yaw: 3.89040422
  127.    Saved: ~
  128. Window Geometry:
  129.  Displays:
  130.    collapsed: false
  131.  Height: 744
  132.  Hide Left Dock: false
  133.  Hide Right Dock: true
  134.  QMainWindow State: 000000ff00000000fd00000004000000000000016a0000025efc0200000009fb0000001200530065006c0065006300740069006f006e00000001e10000009b0000006100fffffffb0000001e0054006f006f006c002000500072006f0070006500720074006900650073020000019b000001b500000185000000a3fb000000120056006900650077007300200054006f006f02000001df000002110000018500000122fb000000200054006f006f006c002000500072006f0070006500720074006900650073003203000002880000011d000002210000017afb000000100044006900730070006c00610079007301000000280000025e000000d700fffffffb0000002000730065006c0065006300740069006f006e00200062007500660066006500720200000138000000aa0000023a00000294fb00000014005700690064006500530074006500720065006f02000000e6000000d2000003ee0000030bfb0000000c004b0069006e0065006300740200000186000001060000030c00000261fb0000000a0049006d00610067006500000001a9000001430000000000000000000000010000010f000002c4fc0200000003fb0000001e0054006f006f006c002000500072006f00700065007200740069006500730100000041000000780000000000000000fb0000000a005600690065007700730000000028000002c4000000ad00fffffffb0000001200530065006c0065006300740069006f006e010000025a000000b200000000000000000000000200000490000000a9fc0100000001fb0000000a00560069006500770073030000004e00000080000002e10000019700000003000005150000003efc0100000002fb0000000800540069006d00650100000000000005150000030000fffffffb0000000800540069006d00650100000000000004500000000000000000000003a50000025e00000004000000040000000800000008fc0000000100000002000000010000000a0054006f006f006c00730100000000ffffffff0000000000000000
  135.  Selection:
  136.    collapsed: false
  137.  Time:
  138.    collapsed: false
  139.  Tool Properties:
  140.    collapsed: false
  141.  Views:
  142.    collapsed: true
  143.  Width: 1301
  144.  X: 65
  145.  Y: 24

2.3 在rviz中显示点云

  1. #第一个终端打开相机驱动节点
  2. source ~/AstraS_ws/devel/setup.bash
  3. roslaunch astra_camera astra.launch
  4. #第二个终端打开
  5. rosrun rviz rviz
  6. #按照5.10的内容,打开可见光和深度
​左上角:File -> Open config,打开刚刚新建的rviz文件即可

按照上节方法打开加入深度图和可见光图

以上就是我简单做的全部测试,一些内容和叙事顺序参考了以下内容,在此说明和答谢:

在ROS中使用奥比中光Orbbec Astra Pro深度相机_十啵的博客-CSDN博客

ROS下使用乐视RGB-D深度相机/Orbbec Astra Pro显示图像和点云 - 古月居

纠错,疑问,交流: 911946883@qq.com

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/你好赵伟/article/detail/250720
推荐阅读
相关标签
  

闽ICP备14008679号