激光雷达LiDAR和相机的.bag数据解析与对齐

2024-02-13 11:38

本文主要是介绍激光雷达LiDAR和相机的.bag数据解析与对齐,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

LiDAR数据解析

Ubuntu18.04 系统,已安装ROS

  1. 查看bag信息,在相应文件夹下打开终端
rosbag info xxx.bag

获得对应的topics

topics:      /velodyne_points                          940 msgs    : sensor_msgs/PointCloud2/zed2i/zed_node/left/image_rect_color     822 msgs    : sensor_msgs/Image      /zed2i/zed_node/right/image_rect_color   1111 msgs    : sensor_msgs/Image

可以看到我这有三个topic,并且每一个对应的帧数是不一样的,在数据录录制过程中存在这丢帧的现象,希望能够对解析后输出的图片带有时间戳方便对齐

  1. 提取点云数据
rosrun pcl_ros bag_to_pcd <your_bag_name> <choose_topic> <output_directory>
// for example
rosrun pcl_ros bag_to_pcd t1.bag /velodyne_points /home/data/output_t1

相机数据解析

可以直接用下面的python代码进行解析,解析后的每张图片以时间戳命名

# coding:utf-8
# get_image.pyimport roslib;
import rosbag
import rospy
import cv2
from sensor_msgs.msg import Image
from cv_bridge import CvBridge
from cv_bridge import CvBridgeError# 存放解析输出图片的位置
path = '/home/summer/MarineData/t6/picture/'  class ImageCreator():def __init__(self):self.bridge = CvBridge()# 要读取的bag文件;with rosbag.Bag('t6.bag', 'r') as bag:  for topic, msg, t in bag.read_messages():# 图像的topic;if topic == "/zed2i/zed_node/right/image_rect_color":  try:cv_image = self.bridge.imgmsg_to_cv2(msg, "bgr8")except CvBridgeError as e:printetimestr = "%.6f" % msg.header.stamp.to_sec()# %.6f表示小数点后带有6位,可根据精确度需要修改;image_name = timestr + ".jpg"  # 图像命名:时间戳.jpgcv2.imwrite(path + image_name, cv_image)  # 保存;if __name__ == '__main__':# rospy.init_node(PKG)try:image_creator = ImageCreator()except rospy.ROSInterruptException:pass

将这个pyhton文件和bag文件放在同一个目录下面,在该目录下打开终端,运行:

python2 get_image.py

因为我电脑中安装了python2 和python3 ,而这个python文件需要用到的是ros中自带的python2, ros中自带的pyhton2有用来解析图片的相关库,就不需要另外安装.故在此指定python2.

数据对齐

# align_data.pyimport os
from shutil import copy#初步解析后点云和图片的存放地址
Lpath='/home/summer/MarineData/t6/pointcloud/'
Cpath='/home/summer/MarineData/t6/picture/'# 存在对齐后的点云图片
New_L_path ='/home/summer/MarineData/t6/alignment/point/'
New_C_path ='/home/summer/MarineData/t6/alignment/picture/'jpg_appendix='.jpg'
pcd_appendix='.pcd'def file2txt(file_path,txt_path):names = os.listdir(file_path)image_ids = open(txt_path,'w')for name in names:image_ids.write('%s\n'%(name))image_ids.close()def changename(filepath,appendix):flist=os.listdir(filepath)n=0for i in flist:oldname=filepath+flist[n]#取时间戳的前0-11位,重新命名newname=filepath+flist[n][:12]+appendixos.rename(oldname,newname)n+=1#print(oldname,'---->',newname)def find_timestap(Lidar_path,Camera_path):Lidar_list = os.listdir(Lidar_path)Camera_list = os.listdir(Camera_path)Both_list=list()for n,name in enumerate(Lidar_list):Lidar_list[n]=name.rstrip('.pcd')n+=1for n,name in enumerate(Camera_list):Camera_list[n]=name.rstrip('.jpg')n+=1n=0# 利用图片的索引去点云中找,一般以帧数少的作为索引for i in Camera_list:current_time = Camera_list[n]if current_time in Lidar_list:Both_list.append(current_time)Lidar_list.remove(current_time)n+=1return Both_listdef copy_file(old_path,new_path,appendix,item_list):for name in item_list:name=name+appendixfrom_path=os.path.join(old_path,name)to_path=new_pathcopy(from_path,to_path)#按照指定位数时间戳重新命名
changename(Lpath,pcd_appendix)
changename(Cpath,jpg_appendix)
#寻找时间戳对齐的点云和图片,返回所有文件名的list
Both_list=find_timestap(Lpath,Cpath)
#从原文件夹复制到对齐文件夹中
copy_file(Lpath,New_L_path,pcd_appendix,Both_list)
copy_file(Cpath,New_C_path,jpg_appendix,Both_list)

这篇关于激光雷达LiDAR和相机的.bag数据解析与对齐的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/705437

相关文章

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,

Python实现将实体类列表数据导出到Excel文件

《Python实现将实体类列表数据导出到Excel文件》在数据处理和报告生成中,将实体类的列表数据导出到Excel文件是一项常见任务,Python提供了多种库来实现这一目标,下面就来跟随小编一起学习一... 目录一、环境准备二、定义实体类三、创建实体类列表四、将实体类列表转换为DataFrame五、导出Da

Python实现数据清洗的18种方法

《Python实现数据清洗的18种方法》本文主要介绍了Python实现数据清洗的18种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录1. 去除字符串两边空格2. 转换数据类型3. 大小写转换4. 移除列表中的重复元素5. 快速统

Python数据处理之导入导出Excel数据方式

《Python数据处理之导入导出Excel数据方式》Python是Excel数据处理的绝佳工具,通过Pandas和Openpyxl等库可以实现数据的导入、导出和自动化处理,从基础的数据读取和清洗到复杂... 目录python导入导出Excel数据开启数据之旅:为什么Python是Excel数据处理的最佳拍档

在Pandas中进行数据重命名的方法示例

《在Pandas中进行数据重命名的方法示例》Pandas作为Python中最流行的数据处理库,提供了强大的数据操作功能,其中数据重命名是常见且基础的操作之一,本文将通过简洁明了的讲解和丰富的代码示例,... 目录一、引言二、Pandas rename方法简介三、列名重命名3.1 使用字典进行列名重命名3.编

使用Python实现批量访问URL并解析XML响应功能

《使用Python实现批量访问URL并解析XML响应功能》在现代Web开发和数据抓取中,批量访问URL并解析响应内容是一个常见的需求,本文将详细介绍如何使用Python实现批量访问URL并解析XML响... 目录引言1. 背景与需求2. 工具方法实现2.1 单URL访问与解析代码实现代码说明2.2 示例调用

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南

《Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南》在日常数据处理工作中,我们经常需要将不同Excel文档中的数据整合到一个新的DataFrame中,以便进行进一步... 目录一、准备工作二、读取Excel文件三、数据叠加四、处理重复数据(可选)五、保存新DataFram

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加