mayavi 显示点云 检测结果

2024-01-17 16:04
文章标签 显示 检测 点云 mayavi

本文主要是介绍mayavi 显示点云 检测结果,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

可视化代码:


mayavi 显示点云 检测结果

输入文件格式是hdf5

字段:

f = h5py.File(args.filename, 'r')
pcls = f['point_cloud']
lidar_pose = f['lidar_pose']
vbbs = f['vehicle_boundingbox']
pbbs = f['pedestrian_boundingbox']

可视化代码:

import argparse
import numpy as np
import h5py
from mayavi import mlabdef getTransform(x, y, z, pitch, yaw, roll, degrees=True):'''Given location x,y,z and pitch, yaw, roll, obtain the matrix that convert from local to global CS using the left-handed system from UE4'''if degrees:pitch, yaw, roll = [np.radians(x) for x in [pitch, yaw, roll]]cy,sy = np.cos(yaw), np.sin(yaw)cr,sr = np.cos(roll), np.sin(roll)cp,sp = np.cos(pitch), np.sin(pitch)mat = np.array([cp * cy, cy * sp * sr - sy * cr, -cy * sp * cr - sy * sr, x, \cp * sy, sy * sp * sr + cy * cr, -sy * sp * cr + cy * sr, y, \sp,               -cp * sr,                 cp * cr, z, \0,                      0,                       0, 1], dtype=np.float).reshape(4,4)return matdef transformPoints(transformMatrix, pts, inverse=False):'''Given a transformation matrix [4,4] convert pts [N,3] or [N,4] (last coordinate is intensity)'''#Check if intensity is availableif pts.shape[1] == 4:#split intensity from 3D coordinates, add homogeneus coordinateintensity = pts[:,-1,np.newaxis].copy()pts[:,-1] = 1else:#add homogeneus coordinateintensity = Nonepts = np.concatenate([pts, np.ones((pts.shape[0],1))], axis=1)#perform transformationmat = np.array(transformMatrix)if inverse:mat = np.linalg.inv(mat)ptst = pts @ mat.Tptst = ptst[:,:3]#merge intensity backif intensity is not None:ptst = np.concatenate([ptst,intensity], axis=1)return ptstdef updateBoundingBox(x,y,z,yaw,pitch,w,l,h, vis_bb):#Create 8 corner pointscpts = 0.5*np.array([[-1,1,-1],[1,1,-1],[1,-1,-1],[-1,-1,-1],[-1,1,1],[1,1,1],[1,-1,1],[-1,-1,1]])cpts *= np.array([[w,l,h]])cpts = transformPoints(getTransform(x,y,z,pitch,yaw,0), cpts)#list of 16 points to create whole BBpts = cpts[[0,3,7,3,2,6,2,1,5,1,0,4,7,6,5,4],:]#update visvis_bb.mlab_source.reset(x=pts[:,0], y=pts[:,1], z=pts[:,2])def main(args):#Load file/dataf = h5py.File(args.filename, 'r')pcls = f['point_cloud']lidar_pose = f['lidar_pose']vbbs = f['vehicle_boundingbox']pbbs = f['pedestrian_boundingbox']nframes = pcls.shape[0]nvehicles = pcls.shape[1]npedestrians = pbbs.shape[1]#Create Mayavi Visualisationfig = mlab.figure(size=(960,540), bgcolor=(0.05,0.05,0.05))zeros = np.zeros(pcls.shape[1]*pcls.shape[2])vis = mlab.points3d(zeros, zeros, zeros, zeros, mode='point', figure=fig)zeros = np.zeros(16)vis_vbbs = [mlab.plot3d(zeros, zeros, zeros, zeros, color=(0,1,0), tube_radius=None, line_width=1, figure=fig) for i in range(nvehicles)]vis_pbbs = [mlab.plot3d(zeros, zeros, zeros, zeros, color=(0,1,1), tube_radius=None, line_width=1, figure=fig) for i in range(npedestrians)]#Iterate through frames@mlab.animate(delay=100)def anim():for frame in range(nframes):print(f'Frame {frame}')#Update pedestrian bounding boxesfor i in range(npedestrians):updateBoundingBox(*pbbs[frame, i].tolist(), vis_pbbs[i])fusedPCL = []for i in range(nvehicles):#Get PCL for the given vehicle in the global Coordinate Systempcl = pcls[frame,i]transform = getTransform(*lidar_pose[frame,i].tolist())pcl_global = transformPoints(transform, pcl)fusedPCL.append(pcl_global)#Update the vehicle BB visualisationupdateBoundingBox(*vbbs[frame,i].tolist(), vis_vbbs[i])#Update PCL visualisation with MayavifusedPCL = np.concatenate(fusedPCL, axis=0)vis.mlab_source.set(x=fusedPCL[:,0], y=fusedPCL[:,1], z=fusedPCL[:,2], scalars=fusedPCL[:,3])#Set top-view if first frameif frame == 0:mlab.gcf().scene.z_plus_view()yieldanim()mlab.show()if __name__ == '__main__':argparser = argparse.ArgumentParser()argparser.add_argument('filename',type=str,help='Path to snippet to be visualised')args = argparser.parse_args()try:main(args)except KeyboardInterrupt:passfinally:print('Finished visualisation!')

这篇关于mayavi 显示点云 检测结果的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

烟火目标检测数据集 7800张 烟火检测 带标注 voc yolo

一个包含7800张带标注图像的数据集,专门用于烟火目标检测,是一个非常有价值的资源,尤其对于那些致力于公共安全、事件管理和烟花表演监控等领域的人士而言。下面是对此数据集的一个详细介绍: 数据集名称:烟火目标检测数据集 数据集规模: 图片数量:7800张类别:主要包含烟火类目标,可能还包括其他相关类别,如烟火发射装置、背景等。格式:图像文件通常为JPEG或PNG格式;标注文件可能为X

2、PF-Net点云补全

2、PF-Net 点云补全 PF-Net论文链接:PF-Net PF-Net (Point Fractal Network for 3D Point Cloud Completion)是一种专门为三维点云补全设计的深度学习模型。点云补全实际上和图片补全是一个逻辑,都是采用GAN模型的思想来进行补全,在图片补全中,将部分像素点删除并且标记,然后卷积特征提取预测、判别器判别,来训练模型,生成的像

基于 YOLOv5 的积水检测系统:打造高效智能的智慧城市应用

在城市发展中,积水问题日益严重,特别是在大雨过后,积水往往会影响交通甚至威胁人们的安全。通过现代计算机视觉技术,我们能够智能化地检测和识别积水区域,减少潜在危险。本文将介绍如何使用 YOLOv5 和 PyQt5 搭建一个积水检测系统,结合深度学习和直观的图形界面,为用户提供高效的解决方案。 源码地址: PyQt5+YoloV5 实现积水检测系统 预览: 项目背景

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.

lvgl8.3.6 控件垂直布局 label控件在image控件的下方显示

在使用 LVGL 8.3.6 创建一个垂直布局,其中 label 控件位于 image 控件下方,你可以使用 lv_obj_set_flex_flow 来设置布局为垂直,并确保 label 控件在 image 控件后添加。这里是如何步骤性地实现它的一个基本示例: 创建父容器:首先创建一个容器对象,该对象将作为布局的基础。设置容器为垂直布局:使用 lv_obj_set_flex_flow 设置容器

C# dateTimePicker 显示年月日,时分秒

dateTimePicker默认只显示日期,如果需要显示年月日,时分秒,只需要以下两步: 1.dateTimePicker1.Format = DateTimePickerFormat.Time 2.dateTimePicker1.CustomFormat = yyyy-MM-dd HH:mm:ss Tips:  a. dateTimePicker1.ShowUpDown = t