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

一、基于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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

MySQL面试题-基础内容(答案版)

基础内容 1、MySQL的架构分层 (1)Serve层:负责建立连接、分析和执行 SQL。 MySQL 大多数的核心功能模块都在这实现,主要包括连接器,查询缓存、解析器、预处理器、优化器、执行器等。另外,所有的内置函数&…

Python给图片加水印

受到“手动给证件加文字太麻烦”的感触,想用Python来实现给图片加水印,这不方便多了。 这里使用PIL模块: from PIL import Image from PIL import ImageFont from PIL import ImageDrawimg_t Image.open(cat.jpg) img_size_t img_t.size…

15.Django总结

文章目录 1.Django创建项目的命令2.MVC,MVT的理解3.Django中间件的使用4.WSGI,uWSGI服务器 和 uwsgi协议5.nginx和uWISG 服务器之间如何配合工作的6.django开发中数据库做过什么优化7.Python中三大框架各自的应用场景8.django如何提升性能(高并发)9. 什么是restful api谈谈你的…

2.8k star! 用开源免费的edge-tts平替科大讯飞的语音合成服务

edge-tts是github上的一个开源项目,可以免费将文本转为语音,别看它只有2.8k star,替代科大讯飞的收费TTS服务完全没问题,因为这个项目实际是调用的微软edge的在线语音合成服务,支持40多种语言,300多种声音&…

TB-03F-Kit 基础AT指令的使用

文章目录 前言一、使用前准备1. 确保TB-03F-Kit已经连接到电脑,并且已经烧录好固件。2. 准备号调试助手,并且电脑上已经安装好了串口驱动3. 打开串口调试助手并复位模组 二、指令介绍三、基础指令1. 准备测试2. AT 测试指令3. ATHELP 查看指令4. ATRST 模…

我的NPI项目之Android 安全系列 -- Keymaster到底是个什么

最近因为一直在调研独立secure element集成的工作,不巧的是目前使用的高通平台只有NFC-eSE的方案。高通目前也并不支持独立的eSE集成,codebase中并无相对应的代码。举个例子,目前使用的STM的一款eSE,但是这款eSE的开发STM还没有完…

开发知识点-前端-jQuery

jquery $(xxxx) id #<script src"static/js/jquery.min.js?v2.1.4"></script>jQuery对象上面还定义了 Ajax方法&#xff08;$.ajax()&#xff09;&#xff0c;用来处理Ajax操作。调用该方法后&#xff0c;浏览器就会向服务器发出一个HTTP请求。$.ajax…

pytest-教程-14-fixture之yield关键字

领取资料&#xff0c;咨询答疑&#xff0c;请➕wei: June__Go 上一小节我们学习了pytest conftest.py文件的使用方法&#xff0c;本小节我们讲解一下fixture的yield关键字实现teardown后置操作。 当我们运行我们的测试时&#xff0c;我们会希望确保它们自己清理干净&#xf…

冒泡经典题

&#x1f4d1;前言 本文主要是【】——简单使用的文章&#xff0c;如果有什么需要改进的地方还请大佬指出⛺️ &#x1f3ac;作者简介&#xff1a;大家好&#xff0c;我是听风与他&#x1f947; ☁️博客首页&#xff1a;CSDN主页听风与他 &#x1f304;每日一句&#xff1a;狠…

【Redisson分布式锁】Redisson公平锁实现机制

欢迎关注公众号&#xff08;通过文章导读关注&#xff1a;【11来了】&#xff09;&#xff0c;及时收到 AI 前沿项目工具及新技术的推送&#xff01; 在我后台回复 「资料」 可领取编程高频电子书&#xff01; 在我后台回复「面试」可领取硬核面试笔记&#xff01; 文章导读地址…

python之双端队列deque

普通队列只能进行队尾插入和出队头的操作&#xff0c;双端队列可以对队头和队尾进行操作&#xff0c;而且相比于list实现的队更具有优越性&#xff0c;list实现在删除和插入时的时间复杂度大约为O(n)&#xff0c;而deque的时间复杂度是O(1) 队头操作&#xff1a;append()、pop(…

蓝桥杯练习系统(算法训练)ALGO-986 藏匿的刺客

资源限制 内存限制&#xff1a;256.0MB C/C时间限制&#xff1a;1.0s Java时间限制&#xff1a;3.0s Python时间限制&#xff1a;5.0s 问题描述 强大的kAc建立了强大的帝国&#xff0c;但人民深受其学霸及23文化的压迫&#xff0c;于是勇敢的鹏决心反抗。   kAc帝国防…

力扣刷题-82.删除排序链表中的重复元素

给定一个已排序的链表的头 head &#xff0c; 删除原始链表中所有重复数字的节点&#xff0c;只留下不同的数字 。返回 已排序的链表 。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,3,4,4,5] 输出&#xff1a;[1,2,5]示例 2&#xff1a; 输入&#xff1a;head [1,1,1,2…

计算机组成原理----数据的表示和运算

一&#xff1a;进位计数制 1、进制 B&#xff1a;二进制&#xff1a;0-1 逢二进一、借一当二 O&#xff1a;八进制&#xff1a;0-7 逢八进一 D&#xff1a;十进制&#xff1a;0-9 逢十进一 H&#xff1a;十六进制&#xff1a;0-9、A-F 逢十六进一 r进制2 2、…

第三百八十四回

【toc] 我们在上一章回中介绍了Visibility组件相关的内容&#xff0c;本章回中将介绍Flutter与原生平台通信相关的内容.闲话休提&#xff0c;让我们一起Talk Flutter吧。 概念介绍 在移动开发领域以Android和IOS SDK开发出的应用程序叫原生开发&#xff0c;开发同一个程序需要…

回溯算法01-组合(Java)

1.组合 题目描述 给定两个整数 n 和 k&#xff0c;返回范围 [1, n] 中所有可能的 k 个数的组合。 你可以按 任何顺序 返回答案。 示例 1&#xff1a; 输入&#xff1a;n 4, k 2 输出&#xff1a; [[2,4],[3,4],[2,3],[1,2],[1,3],[1,4]]示例 2&#xff1a; 输入&#x…

四平方和 刷题笔记

/* 四平方和 直接暴力搜索 可能会超时 使用二分辅助搜索 先枚举出 c*cd*d并存入数组 用式子算出 a*ab*b还剩下多少查找sum数组里面是否存在符合条件的数 查找方式使用二分搜索 当逼近答案后 检查一下是否为所需的数 如果是 直接输出 */ #include <cstring> #includ…

社交媒体的未来图景:探索Facebook的数字化之旅

社交媒体已经成为现代社会不可或缺的一部分&#xff0c;其影响力已经深入到人们生活的方方面面。而在众多社交媒体平台中&#xff0c;Facebook无疑是其中的巨头&#xff0c;其数字化之旅更是引领着整个社交媒体行业的发展方向。本文将深入探讨社交媒体的未来图景&#xff0c;以…

事务处理

Oracle从入门到总裁:https://blog.csdn.net/weixin_67859959/article/details/135209645 事务处理 事务是保证数据完整性的一种手段。 事务具备 ACID 原则&#xff08;包括原子性、一致性、独立性及持久性&#xff09;&#xff0c;保证一个人更新数据的时候&#xff0c;其他…

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

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