CL关于ORB_SLAM的那些事(System)

本文深入解析ORBSLAM视觉里程计框架,涵盖系统初始化、数据流、关键帧管理、闭环检测及地图更新机制。详细介绍System.cc构造函数初始化过程,传感器模型设定,以及跟踪、局部地图和闭环检测线程的启动流程。

System部分的学习和总结

这一篇博客是对整个ORB SLAM整个框架的描述以及数据流动的过程,包括关跟踪部分,关键帧的维护,闭环检测以及地图的维护。这也就意味着关于ORB SLAM部分的学习也将进入尾声,进入实操魔改阶段。https://www.dogedoge.com/
在这里插入图片描述
对于这张图太熟了,每个了解过ORB SLAM的人都看过这张图,今天我们来通过这张图来学习整个系统的框架。
System.cc的文件里,涉及到了构造函数的初始化。
输出系统的一些信息
输出当前输入的传感器模型(双目、单目和深度图)
打开配置文件
加载词袋模型
创建关键帧数据集,传入词袋指针
创建地图指针,new分配内存
创建可视化的画帧和画地图的指针,new分配内存
初始化跟踪线程
初始化局部地图
定义局部地图的线程(mptLocalMapping = new thread(&ORB_SLAM2::LocalMapping::Run,mpLocalMapper)
初始化闭环检测(new thread(&ORB_SLAM2::LoopClosing::Run, mpLoopCloser))
定义闭环检测的线程

  • 如果需要使用可视化窗口
    • 初始化可视化
    • 定义可视化的线程
    • 在跟踪的线程中设置可视化

在跟踪中设置局部地图的指针
在跟踪中设置闭环检测的指针
在局部地图中设置跟踪的指针
在局部地图中设置闭环检测的指针
在闭环检测中设置跟踪的指针
在闭环检测中设置局部地图的指针

再往下就对应了三种不同的传感器(单目、双目和深度相机)的Track函数
单目
在这里插入图片描述
在这里插入图片描述
其余两个传感器的顺序都和单目的差不多,就是Grab函数这边不一样,这个后面我们也会重点看!
System里的其它函数:
各种保存轨迹的函数
设置两种模式(主动定位和停止定位)的函数
判断地图是否发生变化(获取最后一次大变化的索引,如果索引值大于0,地图就是有变化)
设置重启模式的函数
获取跟踪状态
获取跟踪的MapPoint
获取跟踪的关键点(去畸变)

时间:2019年09月20日
作者:hhuchen
机构:河海大学机电工程学院

<think>好的,我现在需要回答用户关于如何在香橙派设备上利用GPU加速ROS程序的运行的问题。首先,我需要了解用户的具体需求和他们使用的硬件环境。根据用户提供的引用,他们使用的是OrangePi5Max或OrangePi AIpro,这两款设备都配备了ARM Mali-G610 GPU。用户可能在安装Ubuntu Server后安装了桌面环境,并希望在此配置下使用GPU加速ROS程序。 首先,我需要确认香橙派设备的GPU驱动是否已经正确安装。因为GPU加速需要相应的驱动支持,尤其是对于ARM架构的设备来说,驱动安装可能和x86平台有所不同。用户提到他们安装了Ubuntu 20.04的服务器版并自行安装了桌面,这可能意味着驱动需要手动安装或者通过特定仓库获取。Rockchip RK3588的Mali-G610驱动可能需要从Rockchip的官方源获取,或者使用社区维护的版本。我需要检查是否有适用于Ubuntu 20.04的Mali驱动,并确保用户正确安装了这些驱动。 接下来,ROS(Robot Operating System)本身并不直接支持GPU加速,但某些ROS的包或节点可以利用GPU进行计算,例如使用OpenGL、CUDA(如果是NVIDIA GPU)或者Vulkan等图形API。不过,由于香橙派使用的是ARM Mali GPU,CUDA可能不可行,需要考虑其他加速方式,比如OpenCL或者通过GPU加速的库如TensorFlow Lite、PyTorch等,或者使用ROS中的特定包,如使用GPU加速的SLAM算法或图像处理节点。 用户可能需要安装支持GPU加速的ROS包,或者自行开发节点,利用GPU进行运算。例如,在ROS中处理摄像头数据时,使用GPU加速图像处理;或者在导航算法中使用GPU进行并行计算。这需要确保相关的库和工具链在香橙派上可用。 此外,用户可能需要配置ROS环境,确保在编译相关包时链接到正确的GPU库。例如,在编译使用OpenCV的ROS节点时,需要确保OpenCV编译时启用了GPU支持,并链接到Mali的驱动库。这可能涉及到从源代码编译OpenCV,并设置相应的编译选项。 我还需要考虑用户提到的OrangePi AIpro是否支持昇腾(Ascend)AI处理器,这可能需要使用华为的CANN(Compute Architecture for Neural Networks)工具链,这可能与普通的GPU加速不同。如果用户使用的是AIpro,可能需要参考昇腾社区的文档,利用NPU而不是GPU进行加速,这需要不同的配置和代码调整。 总结步骤可能包括: 1. 确认GPU驱动安装正确,并验证GPU是否可用。 2. 安装支持GPU加速的库,如OpenCL、Mali OpenGL ES等。 3. 配置ROS环境,确保相关包能够使用这些库。 4. 编译或安装已支持GPU加速的ROS包,或自行开发节点。 5. 测试和验证GPU加速是否生效。 同时,需要提醒用户注意香橙派的架构(ARM64)可能导致某些ROS包或库的兼容性问题,可能需要寻找ARM兼容的版本或自行编译。例如,某些ROS包可能没有预编译的ARM版本,需要从源码构建。 另外,用户可能需要参考昇腾社区的示例程序,如引用[2]中提到的,运行官方的示例来测试NPU的性能,这可能与GPU加速不同,但同样可以提升AI相关的任务处理速度。 在回答过程中,我需要确保提到的步骤具体且可行,可能需要分步骤说明如何检查驱动、安装必要库、配置ROS等。同时,需要指出可能的陷阱,例如驱动安装失败、库版本不兼容等,并提供解决方案或参考链接。 最后,生成相关问题,例如询问如何安装Mali驱动、如何在ROS中使用OpenCL加速,或者如何优化ROS节点以利用NPU等。</think>### 如何在香橙派设备上利用GPU加速ROS程序的运行? #### 1. **确认GPU驱动与硬件支持** - **检查GPU驱动状态** 香橙派设备(如OrangePi5Max)的Rockchip RK3588处理器搭载ARM Mali-G610 GPU,需确保已安装官方或社区维护的GPU驱动。 通过以下命令查看驱动状态: ```bash dmesg | grep Mali # 检查内核日志中GPU初始化信息 glxinfo -B # 验证OpenGL渲染器是否为Mali-G610 ``` 若未正确识别,需从Rockchip官网或香橙派社区获取驱动[^1]。 - **安装依赖库** Mali GPU加速通常依赖OpenGL ES、Vulkan或OpenCL库。安装基础开发包: ```bash sudo apt install mesa-utils libgles2-mesa-dev vulkan-utils ocl-icd-opencl-dev ``` #### 2. **配置ROS环境与GPU加速支持** - **安装ROS版本选择** 推荐使用ROS Noetic(Ubuntu 20.04)或ROS2 Foxy/Humble(Ubuntu 22.04),需确保ARM架构兼容性。 例如,安装ROS Noetic: ```bash sudo sh -c 'echo "deb http://packages.ros.org/ros/ubuntu focal main" > /etc/apt/sources.list.d/ros-latest.list' sudo apt-key adv --keyserver 'hkp://keyserver.ubuntu.com:80' --recv-key C1CF6E31E6BADE8868B172B4F42ED6FBAB17C654 sudo apt update && sudo apt install ros-noetic-desktop-full ``` - **编译支持GPU加速的ROS包** 某些ROS包(如`cv_bridge`、`image_transport`)依赖OpenCV的GPU加速功能。需从源码编译OpenCV并启用Mali支持: ```bash git clone https://github.com/opencv/opencv.git cd opencv && mkdir build && cd build cmake -D WITH_OPENGL=ON -D WITH_VULKAN=ON -D WITH_OPENCL=ON .. make -j4 && sudo make install ``` #### 3. **实现GPU加速的ROS节点示例** - **使用OpenCL加速图像处理** 编写ROS节点调用OpenCL进行图像处理(如边缘检测): ```python #!/usr/bin/env python3 import rospy from sensor_msgs.msg import Image import pyopencl as cl import cv2 import numpy as np def image_callback(msg): # 将ROS Image转换为OpenCV格式 img = np.frombuffer(msg.data, dtype=np.uint8).reshape(msg.height, msg.width, 3) # OpenCL初始化 ctx = cl.create_some_context() queue = cl.CommandQueue(ctx) ... # GPU加速处理(伪代码) gpu_output = cl.Buffer(ctx, ...) program = cl.Program(ctx, opencl_kernel_code).build() program.edge_detection(queue, img.shape, None, ...) # 发布处理后的图像 pub.publish(msg) rospy.init_node('gpu_image_processor') rospy.Subscriber('/camera/image_raw', Image, image_callback) pub = rospy.Publisher('/gpu_processed_image', Image, queue_size=1) rospy.spin() ``` - **调用Vulkan加速的SLAM算法** 若使用支持Vulkan的SLAM库(如ORB-SLAM3),需在编译时启用Vulkan后端: ```bash cd ORB_SLAM3 mkdir build && cd build cmake -DUSE_VULKAN=ON .. make -j4 ``` #### 4. **验证GPU加速效果** - **性能监控工具** 使用`htop`、`nvtop`(需适配Mali)或`clinfo`监控GPU利用率: ```bash sudo apt install clinfo clinfo # 查看OpenCL设备信息 sudo apt install mali-bifrost-wayland-dkms # Mali性能计数器(若支持) ``` - **基准测试对比** 对比CPU与GPU处理同一任务的耗时,例如使用OpenCV的`DNN`模块加载模型: ```python net = cv2.dnn.readNetFromTensorflow("model.pb") net.setPreferableBackend(cv2.dnn.DNN_BACKEND_OPENCV) net.setPreferableTarget(cv2.dnn.DNN_TARGET_CPU) # 切换为DNN_TARGET_OPENCL ``` #### 5. **针对OrangePi AIpro的昇腾NPU加速** - **安装CANN工具链** 若使用OrangePi AIpro,需配置昇腾NPU的AscendCL库: ```bash wget https://ascend-repo.obs.cn-east-2.myhuaweicloud.com/CANN/6.3.1/.../Ascend-cann-toolkit_6.3.1_linux-aarch64.run chmod +x Ascend-*.run ./Ascend-*.run --install ``` - **集成NPU加速至ROS节点** 调用昇腾AI接口实现目标检测加速: ```python from hiai import ModelManager model = ModelManager.load_model("yolov5.om") # 昇腾离线模型 results = model.infer(image_data) ``` --- ### 相关问题
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值