1.将/scan数据转化为PointCloud数据

背景:采用中科大ros初学教程中的机器人仿真进行slam学习,里面有个/scan topic,保存的是单线激光雷达扫描一圈获得的距离数据,为了方便对数据进行处理,需要将其转成PointCloud2。这里采用的方法是创建一个ros节点,订阅/scan,将其转化为pointcloud2,再对外发布/laserPointCloud

说明:此方法为之前在网上所看,但是忘记了链接,如果是原创作者请联系我(lizhouliao@cqu.edu.cn)

步骤:
一、创建功能包
创建一个新的终端

cd catkin_ws/src
catkin_create_pkg laser2PC rospy sensor_msgs laser_geometry

二、创建python文件

cd laser2PC/src
vim laser2pc.py

将下面的代码复制进去

#!/usr/bin/env python
#-*- coding:UTF-8 -*-
import rospy
from sensor_msgs.msg import PointCloud2 as pc2
from sensor_msgs.msg import LaserScan
from laser_geometry import LaserProjection

class Laser2PC():
    def __init__(self):
        self.laserProj = LaserProjection()
        self.pcPub = rospy.Publisher("/laserPointCloud", pc2, queue_size=1)
        self.laserSub = rospy.Subscriber("/scan", LaserScan, self.laserCallback) #topic名称可能不同,请根据实际情况进行修改。可以在终端输入rostopic list查看

    def laserCallback(self,data):

        cloud_out = self.laserProj.projectLaser(data)

        self.pcPub.publish(cloud_out)

if __name__ == '__main__':
    rospy.init_node("laser2PointCloud")
    l2pc = Laser2PC()
    rospy.spin()

三.编译python文件

然后将以下内容添加到CMakeLists.txt文件。这样可以确保正确安装Python脚本,并使用合适的Python解释器。

catkin_install_python(PROGRAMS src/ laser2pc.py
DESTINATION ${CATKIN_PACKAGE_BIN_DESTINATION}

然后

cd ~/catkin_ws && catkin_make

四、运行

1、运行roscore
2、在laser2pc.py所在目录创建一个新的终端,输入
rosrun laser2PC laser2pc.py
3、发布/scan
使用中科大ros初学教程中的机器人仿真工具
roslaunch robot_sim_demo sample_robot_spawn.launch
机器人仿真

4、使用rosbag record录制所发布的topic
rosbag record /laserPointCloud /transform_odom_laser
数据则被保存在了一个.bag文件中

五、Matlab对bag文件的读取

bag = rosbag('text01_2021-03-03-20-51-41.bag');
matlab读取文件后的数据结构

在ROS 2 (Robot Operating System) 中,`sensor_msgs::msg::LaserScan` 类型的数据表示的是激光雷达扫描信息,包含了一系列的测量数据,如角度、强度等。而 `pcl::PointCloud<pcl::PointXYZ>` 是 Point Cloud Library (PCL) 提供的一个结构体,用于存储三维空间中的点云数据,每个点由 x、y 和 z 坐标组成。 要从 `LaserScan` 转换为 `pcl::PointCloud<pcl::PointXYZ>`,你需要对激光雷达的数据进行解析,并将其映射到三维坐标上。以下是一个简化版的步骤: 1. 首先,确保已经包含了所需的库头文件,例如: ```cpp #include <ros/ros.h> #include <sensor_msgs/LaserScan.h> #include <pcl_conversions/pcl_conversions.h> #include <pcl/point_cloud.h> #include <pcl/point_types.h> ``` 2. 创建一个函数,接收 `sensor_msgs::msg::LaserScan` 数据: ```cpp void laserScanToPointCloud(const sensor_msgs::msg::LaserScan& scan, pcl::PointCloud<pcl::PointXYZ>& lidar_cloud) { // 获取激光扫描范围内的点数 int num_points = scan.ranges.size(); // 初始化点云 lidar_cloud.resize(num_points); for (size_t i = 0; i < num_points; ++i) { double angle = scan.angle_min + i * (scan.angle_increment); double distance = scan.ranges[i]; // 将角度转换为x,y坐标(假设激光雷达垂直于地面) float x = distance * cos(angle); float y = distance * sin(angle); // 添加z坐标通常为0,因为激光雷达水平扫描 float z = 0; // 将点添加到点云中 lidar_cloud.points[i].x = x; lidar_cloud.points[i].y = y; lidar_cloud.points[i].z = z; } } ``` 这个函数简单地将激光雷达的线性距离和角度转换为笛卡尔坐标,并放入 `lidar_cloud` 中。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值