激光雷达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

相关文章

golang内存对齐的项目实践

《golang内存对齐的项目实践》本文主要介绍了golang内存对齐的项目实践,内存对齐不仅有助于提高内存访问效率,还确保了与硬件接口的兼容性,是Go语言编程中不可忽视的重要优化手段,下面就来介绍一下... 目录一、结构体中的字段顺序与内存对齐二、内存对齐的原理与规则三、调整结构体字段顺序优化内存对齐四、内

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

C语言中自动与强制转换全解析

《C语言中自动与强制转换全解析》在编写C程序时,类型转换是确保数据正确性和一致性的关键环节,无论是隐式转换还是显式转换,都各有特点和应用场景,本文将详细探讨C语言中的类型转换机制,帮助您更好地理解并在... 目录类型转换的重要性自动类型转换(隐式转换)强制类型转换(显式转换)常见错误与注意事项总结与建议类型

Python给Excel写入数据的四种方法小结

《Python给Excel写入数据的四种方法小结》本文主要介绍了Python给Excel写入数据的四种方法小结,包含openpyxl库、xlsxwriter库、pandas库和win32com库,具有... 目录1. 使用 openpyxl 库2. 使用 xlsxwriter 库3. 使用 pandas 库

SpringBoot定制JSON响应数据的实现

《SpringBoot定制JSON响应数据的实现》本文主要介绍了SpringBoot定制JSON响应数据的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录前言一、如何使用@jsonView这个注解?二、应用场景三、实战案例注解方式编程方式总结 前言

使用Python在Excel中创建和取消数据分组

《使用Python在Excel中创建和取消数据分组》Excel中的分组是一种通过添加层级结构将相邻行或列组织在一起的功能,当分组完成后,用户可以通过折叠或展开数据组来简化数据视图,这篇博客将介绍如何使... 目录引言使用工具python在Excel中创建行和列分组Python在Excel中创建嵌套分组Pyt

MySQL 缓存机制与架构解析(最新推荐)

《MySQL缓存机制与架构解析(最新推荐)》本文详细介绍了MySQL的缓存机制和整体架构,包括一级缓存(InnoDBBufferPool)和二级缓存(QueryCache),文章还探讨了SQL... 目录一、mysql缓存机制概述二、MySQL整体架构三、SQL查询执行全流程四、MySQL 8.0为何移除查

在Rust中要用Struct和Enum组织数据的原因解析

《在Rust中要用Struct和Enum组织数据的原因解析》在Rust中,Struct和Enum是组织数据的核心工具,Struct用于将相关字段封装为单一实体,便于管理和扩展,Enum用于明确定义所有... 目录为什么在Rust中要用Struct和Enum组织数据?一、使用struct组织数据:将相关字段绑

在Mysql环境下对数据进行增删改查的操作方法

《在Mysql环境下对数据进行增删改查的操作方法》本文介绍了在MySQL环境下对数据进行增删改查的基本操作,包括插入数据、修改数据、删除数据、数据查询(基本查询、连接查询、聚合函数查询、子查询)等,并... 目录一、插入数据:二、修改数据:三、删除数据:1、delete from 表名;2、truncate