基于laspy的点云数据存取及基于Open3D的点云数据可视化

news2024/11/19 1:27:04

一、基于laspy的点云数据存取

(一)激光雷达点云数据的LAS存储格式[1]

        LAS(LASer)格式是一种为激光雷达点云数据的交换和存档而设计的文件格式,是一种被American Society for Photogrammetry and Remote Sensing(ASPRS)指定的开放二进制格式。LAS格式被广泛使用并被视为激光雷达数据的行业标准。

        LAS文件存储的点数据的格式为LAS规范定义的点云数据记录格式之一,自LAS 1.4开始,LAS提供了11种可用点数据存储格式(0-10)。所有点数据记录在文件中必须具有相同的格式。各种提供的存储格式在某些可用数据属性字段不同,如GPS时间、RGB和NIR颜色、波包(局限在空间的某有限范围区域内的波动)等。LAS格式提供可用的11种点数据格式详见文末

图一  用于LAS定义格式的数据类型(图源LAS_1_4_r15)

        LAS 1.1-1.3文件以32位整数表示三维点X/Y/Z坐标(LAS 1.4文件改为64位)。因此,为了获得实际坐标,必须应用公共头中定义的缩放和偏移量。

        LAS格式的每个点数据记录所使用的字节数是在公共头块中明确给出的,因此可以在规范定义的点数据记录格式给出的字段中添加“额外字节”的用户定义字段。在LAS 1.4规范中,以特定EVLR的形式引入了解释此类额外字节的标准化方法。

图二  LAS点云数据存储格式的各部分描述(图源wikipedia)

(二)LAS 1.4公共文件头规范[2]

图三  LAS点云数据存储格式的文件头标准(图源wikipedia)

(三)基于laspy库的点云数据存取及文件头信息获取[3][7]

        基于laspy库包常规的.las文件存取例程已在使用文档中有良好说明。此处,对使用文档进行一种同时存取XYZ、RGB及类别标签点云数据方法的补充。

实验代码

1、对比LiDAR360、CloudCompare以及PCM(点云魔方)的LAS数据保存(基于同一TXT文件)

        依据坐标值计算公式(X/Y/Zcoordinate = X/Y/Zrecord*X/Y/Zscale+X/Y/Zoffset)和TXT记录值(288.500488 71.447800 -50.032101)对比实验结果,可以看出CloudCompare和PCM软件数据存储未改变点顺序,而LiDAR360可能改变了点的存储顺序或其他情况。

# d1-CloudCopare
# d2-LiDAR360
# d3-PCM
# d4-unknown

import laspy

las = laspy.read(d~)
print(list(las.point_format.dimension_names))
print(las.header.scales)
print(las.header.offsets)
print(las.x[0],las.y[0],las.z[0])

# 测试结果
# d1 
['X', 'Y', 'Z', 'intensity', 'return_number', 'number_of_returns', 'scan_direction_flag', 'edge_of_flight_line', 'classification', 'synthetic', 'key_point', 'withheld', 'scan_angle_rank', 'user_data', 'point_source_id', 'red', 'green', 'blue', 'Scalar field']
# point 288.50048799999996 71.4478 -50.032101 
# scale [1.e-06 1.e-06 1.e-06]
# offset [0. 0. 0.]

# d2 
['X', 'Y', 'Z', 'intensity', 'return_number', 'number_of_returns', 'synthetic', 'key_point', 'withheld', 'overlap', 'scanner_channel', 'scan_direction_flag', 'edge_of_flight_line', 'classification', 'user_data', 'scan_angle', 'point_source_id', 'gps_time', '79', '3']
# point -216.8319640507812 -115.86109550781251 -62.66590350854492
# scale [0.0001 0.0001 0.0001]
# offset [-288.87286405 -156.58259551  -70.20670351]

# d3 
['X', 'Y', 'Z', 'intensity', 'return_number', 'number_of_returns', 'scan_direction_flag', 'edge_of_flight_line', 'classification', 'synthetic', 'key_point', 'withheld', 'scan_angle_rank', 'user_data', 'point_source_id', 'gps_time', 'red', 'green', 'blue']
# point 288.500488 71.4478 -50.032101
# scale [0.001 0.001 0.001]
# offset [288.500488  71.4478   -50.032101]

# d4 
['X', 'Y', 'Z', 'intensity', 'return_number', 'number_of_returns', 'scan_direction_flag', 'edge_of_flight_line', 'classification', 'synthetic', 'key_point', 'withheld', 'scan_angle_rank', 'user_data', 'point_source_id', 'red', 'green', 'blue']
# point 704114.9195 2609265.6552 23.3599
# scale [0.0001 0.0001 0.0001]
# offset [ 700000. 2600000.       0.]

2、以LAS格式同时保存XYZ、RGB以及类别标签Label属性值

        若已读取的是LAS格式数据,便可以直接获取其文件头创建同样文件头的LAS文件。否则,需要自行创建并设置文件头。通过实验还发现,LAS版本文档(LAS_1_4_r15)与实际laspy的文件头生成具有一定差异,需要具体情况具体分析。

import numpy as np
import laspy

# 创造模拟数据
XYZRGB = np.asarray([[1,1,1,2,2,2],[3,3,3,4,4,4]])
label = np.asarray([1,3])
# LAS文件存储(包含XYZ、RGB、label)
new_header = laspy.LasHeader(version="1.4",point_format=7)
new_header.scales = np.array([1.0,1.0,1.0])
new_header.offsets = np.array([0.0,0.0,0.0])
new_las = laspy.LasData(new_header)
new_las.x = XYZRGB[...,0]
new_las.y = XYZRGB[...,1]
new_las.z = XYZRGB[...,2]
new_las.red = XYZRGB[...,3]
new_las.green = XYZRGB[...,4]
new_las.blue = XYZRGB[...,5]
new_las.classification = label
# 保存LAS文件
new_las.write("Output/LAS_testDATA.las")

# 测试存储结果
las = laspy.read("Output/LAS_testDATA.las")
print(list(las.point_format.dimension_names))
print(las.header.scales)
print(las.header.offsets)
print(las.header.point_count)
print(las.xyz[0],las.red[0],las.classification[0])
print(las.xyz[1],las.red[1],las.classification[1])
图四 LAS数据自定义保存实验结果

二、基于Open3D的点云数据可视化

      基于Open3D函数o3d.visualization.draw_geometries([PCD])可视化的点云,其依据PCD.colors属性值(该属性值范围应为[0,1])附色。高阶自定义可视化具体实现代码及RGB颜色配色表详见参考资料[4][5][6]。

三、LAS提供的11种点数据存储格式[2]

        通过对比可以得到如下信息(bit-位 / byte-字节):

        1、Format 0是基础格式,其所有属性字段是其它版本的基本属性字段;

        2、自Format 6以后(Format 6-10),属性字段添加Classification Flags;

        3、Format 7、 Format 8、Format 10同时拥有XYZ、RGB、Classification Flags属性字段;

        4、Format 6、 Format 7、Format 8、Format 9、Format 10同时拥有XYZ、Classification Flags属性字段(无RGB属性字段)。

四、ASPRS点云数据类别标签统一规范

参考资料:

[1] https://en.wikipedia.org/wiki/LAS_file_format

[2] https://www.asprs.org/wp-content/uploads/2019/07/LAS_1_4_r15.pdf

[3] Basic Manipulation — laspy 2.5.0 documentation

[4] Customized visualization - Open3D 0.18.0 documentation

[5] 【Open3d】使用open3d可视化-CSDN博客

[6] RGB颜色对照表_高级的金色rgb-CSDN博客

[7] A Complete Example — laspy 2.5.0 documentation

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1492112.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Claude 3正式发布,超越GPT-4,一口气读15万单词,OpenAI最强的大对手!

目录 多模态AI大模型Claude 3(https://www.anthropic.com/news/claude-3-family)Claude 3 的三个版本新增功能,chatgpt没有的使用成本总结 多模态AI大模型Claude 3(https://www.anthropic.com/news/claude-3-family) …

C# 中 TryParse 将字符串转换为特定类型的方法

在 C# 中,TryParse 是一个用于将字符串转换为特定类型的方法。它用于尝试解析字符串并将其转换为指定类型的值,而不会引发异常。如果解析成功,它将返回 true 并将解析结果存储在输出参数中;如果解析失败,它将返回 fals…

分析开源机器学习框架TensorFlow

TensorFlow是一个开源的机器学习框架,由Google开发和维护。它提供了一个灵活的编程环境,可用于构建和训练各种机器学习模型。TensorFlow的基本概念和使用场景如下: 张量(Tensor):在TensorFlow中&#xff0c…

FairTune:优化参数高效微调以实现医学图像分析的公平性

paper:https://arxiv.org/abs/2310.05055 code: https://github.com/Raman1121/FairTune 摘要和介绍 人工智能在医疗健康应用中的应用正在迅速增长。然而,人工智能模型一再被证明对不同的人口统计学亚群体表现出不必要的偏见——AI模型在由…

《 前端挑战与未来:如何看待“前端已死”》

在技术领域,时常会有一些激进的言论引发热议,比如近年来不少人声称“前端已死”。这样的言论引发了广泛的讨论和反思。本文将从几个方向探讨这个话题:为什么会出现“前端已死”的言论、如何看待这种说法、前端技术的未来发展趋势以及前端人如何应对这场职位突围战。 为什么会…

超级副业SOP,各行各业,太全了!

最近收集到一份资料,包含了几乎各行各业的SOP,实在是太全了,这里准备分享给大家 这里可能有一些朋友还不知道,SOP是个什么东西呢 百度说法:所谓SOP,是 Standard Operating Procedure三个单词中首字母的大写…

Spring Cloud 面试题及答案整理,最新面试题

Spring Cloud中断路器的原理及其作用是什么? Spring Cloud断路器的原理和作用基于以下几个关键点: 1、故障隔离机制: 在微服务架构中,断路器作为一种故障隔离机制,当某个服务实例出现问题时,断路器会“断…

浏览器发出一个请求到收到响应步骤详解

前言 在网络通信中,浏览器向Web服务器发送HTTP请求消息的过程是一个复杂而精密的环节,涉及到URL解析、DNS解析、数据拆分、路由表规则和MAC头部添加等一系列步骤。本文将深入探讨这一过程的每个环节,帮助读者更全面地了解浏览器与Web服务器之…

Python实现MACD工具判断信号:股票技术分析的工具系列(1)

Python实现MACD工具判断信号:股票技术分析的工具系列(1) 介绍代码rolling函数介绍核心代码计算指数移动平均值计算MACD指标 完整代码 介绍 先看看官方介绍: MACD (平滑异同平均线) 指标说明 DIF线:收盘价短…

上传文件,页面loading显示文件上传进度

做项目时,弹窗上传文件时,上传动作无法停止,需要加一个蒙层,阻止上传文件过程中的用户操作,并显示文件上传进度,效果如图。 页面上传文件函数 /** 上传文件函数*/ uploadFile(){let config {onUploadProgr…

全网公开!!苍穹外卖或吉瑞外卖等外卖购物项目如何拓展?简历如何写?已经经过不同公司多轮面试。项目中会问到哪些问题?以及问题如何解决?

文章末尾联系作者,免费获取外卖项目的拓展和讲解资料,祝你面试成功 !!! 文章问题的解答,以及作者的规划进步历程,尽在作者的知识库。 想要加入并查阅作者的知识库可以联系作者 不要白嫖&#…

微信报修小程序源码

源码获取方式: 1、搜一搜 万能工具箱合集 然后点击资料库,即可获取资源 一、先看Demo(已更新至4.0.0) 想看界面图片的,辛苦你爬一下楼,点击下方查看资源,进入官方demo 二、功能介绍 1、当前版…

关于跨境电商知识产权的英语翻译

随着全球化的发展,跨境电商逐渐成为国际贸易的重要组成部分。在这个领域中,知识产权的保护显得尤为重要。那么,对于跨境电商知识产权英语翻译,怎样做比较好,北京哪个翻译公司比较权威? 业内人士指出&#x…

网络工程师笔记8

华为VRP系统 设备管理方式 web管理方式 命令行管理方式 修改命令:undo 基础配置命令

线上问题——学习记录幂等判断失效问题分析

一、业务流程 上图是对save和saveScore两个接口的流程抽象,save是上传答题数据,saveScore则是上传答题分数,为保证幂等和防止并发调用,这两个接口都加了分布式锁(还是两层哦)。第一层使用的是不同的锁&…

Nginx使用—基础知识

Nginx简介 Nginx优点 高性能、高并发 支持很高的并发,在处理大量并发的情况下,比其他web服务器要高效 轻量且高扩展 功能模块少(源代码仅保留http与核心模块代码,其余不够核心代码会作为插件来安装) 代码模块化(易读&#xff0…

【开源】SpringBoot框架开发固始鹅块销售系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 鹅块类型模块2.3 固始鹅块模块2.4 鹅块订单模块2.5 评论管理模块 三、系统设计3.1 用例设计3.2 数据库设计3.2.1 鹅块类型表3.2.2 鹅块表3.2.3 鹅块订单表3.2.4 鹅块评论表 四、系统展示五、核心代码5.…

计算文件大小时容易忽略的问题

计算文件大小时容易忽略的问题 1、概述2、问题背景3、解决方案4、结论 1、概述 大家好,我是欧阳方超,可以关注我的公众号“欧阳方超”,后续内容将在公众号首发。 在处理文件大小时,经常需要将其转换为KB并进行适当处理。然而&…

cuda python torch 虚拟环境配置

以下是Pytorch和CUDA对应的版本 以下是Pytorch和Python对应的版本 检查cuda与Python版本是否匹配 import torch print(torch.__version__) print(torch.cuda.is_available()) print(torch.empty(3,4,devicecuda))cuda 删除cuda conda uninstall cudatoolkit --forceconda u…

稀碎从零算法笔记Day5-LeetCode:轮转数组

题型:数组、数学、双指针 前言:LC说你得用三种方法做出来(悲) 链接:189. 轮转数组 - 力扣(LeetCode) 来源:LeetCode 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。 …