Las与Laz点云文件格式的区别

2023-11-07 09:40

本文主要是介绍Las与Laz点云文件格式的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Las与Laz点云文件格式的区别

  • Las与Laz点云文件的读取
  • Las
  • Laz
  • 点集压缩
  • LASzip
  • 读取las与laz实验

Las与Laz点云文件的读取

最近研究了一下点云文件格式las与laz,读取方式的话调用的是LAStools库。编译方式没有什么特别的,可能Cmake生成后编译不通过,原来每个exe中的cpp文件有一行代码少了个括号,自行加上即可。通过对代码的调试与文献阅读,总体有以下两点结论:

  1. las与laz相比,其占用磁盘内存减少,大概在4倍左右;
  2. laz较las读取时间降低,测试了一个8个G的与一个6个G的文件,效率降低也在4倍左右。通过CloudCompare进行导入,也能够明显地感觉出来导入速度变慢。

文献主要是一篇Laszip对应的文章,详细讲述了las是如何压缩为laz的。但是我还在研究这篇文章,所以本文暂时不详细讲述具体压缩方法,只讲述自己所做实验与以上两点造成的原因,纯属个人理解,望评!这里附上文章下载链接:《LASzip: lossless compression of LiDAR data》不过好像需要翻墙,推荐使用翻墙软件PSIPHON。

Las

首先介绍一下Las格式的点云存储方式。对于每条扫描脉冲来说,扫描仪记录了返回波段。扫描仪脉冲可能有多个峰值,因为激光在到达地面之前可能撞击到多种表面,如电线或者天线、树叶甚至小鸟。每一个在一定阈值以上的峰值成为一个“返回”。这些带有反射强度,扫描角度,GPS时间,返回数值,飞行先ID等等的坐标信息是我们感兴趣的数据。为了在不同软件中实现数据格式交换,通常的做法是将坐标文件转换为ASCII格式,每一行代表一个“返回”的属性。这种方法虽然灵活病便于理解,但是用文本格式存储百万甚至千万级别的记录是十分笨拙的,更重要的是无法在文件中进行查找。

直到Las 1.3,每一个点记录有核心的20个bytes,其中12个bytes记录了整数形式的xyz坐标。LAS的头信息记录了对于整数坐标的缩放因子。剩下的8个bytes储存了反射强度信息,扫描角度,返回数量,分类信息等等。这些信息组成了基本的point type 0。另外point type 1和3添加了8 byte的GPS time,point type 2与3 增加了6 byte来存储RGB颜色信息。LAS 1.3引入了point type 4和5 允许附加对于每个“返回”的波形信息,但是很少使用。使用浮点数的表示形式意味着数字的精度取决于数字不同的值。越靠近0,精度越高。

从上述可以看出,LAS格式最大的特点就是在存储点坐标时使用缩放因子与平移量的方式。其实,很多人都认为浮点数比整数具有较高的精度,但这是错误的概念。论文里有具体的分析,大家可以仔细阅读。LiDAR坐标大多分布在x-y平面上,这是因为使用了大地坐标与高斯投影的缘故。

Las 1.0-1.3在实际的点数据之前存在一个头信息。前227 bytes的头信息定义了Las文件,包含了变长记录的数量,相对于第一个点的平移量,每个点的类型和大小,点云数量,整数点坐标的平移量和缩放因子以及点云的包围盒。在LAS 1.3中,每个点都附加了一个波形信息,共235 bytes。额外的8 bytes信息描述了波形数据的开始。如果这个字段为0,则波形数据存储在外部的WDP文件中。如果这个字段不为0,波形数据存储在LAS文件内。LASzip还不支持波形数据在LAZ文件内,总是把它写在外部的WDP文件。

Laz

Laz文件是Las文件的一种压缩格式,在LAStools中就有Laszip这个exe,可以直接调用。Laszip压缩器把Las数据中点类型看做四种不同的数据组成的:POINT10,GPSTIME10,RGB12和WAVEPACKET13,针对这个四种数据分别进行压缩。例如,点类型3是由POINT10后面跟着GPSTIME10和RGB12组成的。另外,每个点可能有一个“n”在最后,称作“额外的bytes”。

点集压缩

  1. 有损于无损
    有损压缩方案通过轻微的改变点的位置,即坐标,并且能够保证物体表面的基本形状即可。这种方案主要应用在只要求可视化效果的程序中。而无损压缩方案通过使用“uniform precision”把点坐标改成用缩放因子表示的数值,即修改量化点坐标的形式。
  2. progressive versus non-progressive (or single-rate)(我没理解这一部分)
  3. 流和非流
    流方案在读取一部分数据之后开始压缩点并输出压缩文件,反之,在在只读取一部分压缩文件后开始解压缩。非流方案在压缩与解压缩的时候都是将点全部读进内存。
  4. 点重排列与保持原始顺序
    点重排列方案不在文件中保持原始点顺序,它的压缩增益来源于将点重新排列成一种聪明的顺序。
    保持原始顺序则反之。
  5. 连续的和随机获取
    连续方案依照点在压缩文件中的编码方式解压缩。随机获取方案可以在压缩文件中搜索并且只解压一部分文件。

The LASzip compressor is lossless, non-progressive,
streaming, order-preserving, and provides random-access.

LASzip

laszip不对Las的头信息或者任何变长记录进行压缩。变长记录如下图所示
在这里插入图片描述
它只是从las文件拷贝到laz文件中。然而它对当前的point type值加上128来防止标准的LAS读取器尝试读取压缩后的LAZ文件。另外增加了一个变长记录指明了压缩的点和使用的不同的压缩选项的构成。LASzip压缩器把不同的点类型看做由四部分组成:POINT10,GPSTIME10,RGB12和WAVEPACKET13。每一项都有自己的压缩器,并且它们自己具有版本号,使得压缩器模块化,并且易于扩展到其他点类型。

LASzip压缩器对点集进行分块压缩,这使得在压缩文件中可以进行查找。默认的块大小为50000个点。Chunking makes it possible to, for example, augment the produced LAZ files with spatial indexing LAX files [2] and support area of- interest queries that decompress only the relevant parts of a compressed LAZ file。因为每一个压缩的块都具有不同的大小,压压缩器在文件末尾存储了一个“chunk table”,指明每一块的开始byte位置。

当开始一个新的chunk时,Laszip把第一个点存储为原始的字节,作为后来的预测方案的初值。以下所有的点数据都按一项一项的压缩。这里的项就是上述的POINT10,GPSTIME10,RGB12和WAVEPACKET13。
文章中针对每一项的压缩方案做了具体介绍,我能力有限,还在研究。

读取las与laz实验

本文使用两个las点云文件进行实验,这里分别命名为#1与#2。在Lastools中使用laszip库进行压缩,得到压缩后的laz文件,命名为#1_laz与#2_laz。在实验中,对压缩前后,其所占磁盘内存大小与读取时间进行对比,得到以下结果。

  1. 磁盘内存占用大小
    在这里插入图片描述
  2. 读取时间
    在这里插入图片描述

这篇关于Las与Laz点云文件格式的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

Java中的String.valueOf()和toString()方法区别小结

《Java中的String.valueOf()和toString()方法区别小结》字符串操作是开发者日常编程任务中不可或缺的一部分,转换为字符串是一种常见需求,其中最常见的就是String.value... 目录String.valueOf()方法方法定义方法实现使用示例使用场景toString()方法方法

Java进行文件格式校验的方案详解

《Java进行文件格式校验的方案详解》这篇文章主要为大家详细介绍了Java中进行文件格式校验的相关方案,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、背景异常现象原因排查用户的无心之过二、解决方案Magandroidic Number判断主流检测库对比Tika的使用区分zip

分辨率三兄弟LPI、DPI 和 PPI有什么区别? 搞清分辨率的那些事儿

《分辨率三兄弟LPI、DPI和PPI有什么区别?搞清分辨率的那些事儿》分辨率这个东西,真的是让人又爱又恨,为了搞清楚它,我可是翻阅了不少资料,最后发现“小7的背包”的解释最让我茅塞顿开,于是,我... 在谈到分辨率时,我们经常会遇到三个相似的缩写:PPI、DPI 和 LPI。虽然它们看起来差不多,但实际应用

GORM中Model和Table的区别及使用

《GORM中Model和Table的区别及使用》Model和Table是两种与数据库表交互的核心方法,但它们的用途和行为存在著差异,本文主要介绍了GORM中Model和Table的区别及使用,具有一... 目录1. Model 的作用与特点1.1 核心用途1.2 行为特点1.3 示例China编程代码2. Tab

Nginx指令add_header和proxy_set_header的区别及说明

《Nginx指令add_header和proxy_set_header的区别及说明》:本文主要介绍Nginx指令add_header和proxy_set_header的区别及说明,具有很好的参考价... 目录Nginx指令add_header和proxy_set_header区别如何理解反向代理?proxy

Java中&和&&以及|和||的区别、应用场景和代码示例

《Java中&和&&以及|和||的区别、应用场景和代码示例》:本文主要介绍Java中的逻辑运算符&、&&、|和||的区别,包括它们在布尔和整数类型上的应用,文中通过代码介绍的非常详细,需要的朋友可... 目录前言1. & 和 &&代码示例2. | 和 ||代码示例3. 为什么要使用 & 和 | 而不是总是使

C++中函数模板与类模板的简单使用及区别介绍

《C++中函数模板与类模板的简单使用及区别介绍》这篇文章介绍了C++中的模板机制,包括函数模板和类模板的概念、语法和实际应用,函数模板通过类型参数实现泛型操作,而类模板允许创建可处理多种数据类型的类,... 目录一、函数模板定义语法真实示例二、类模板三、关键区别四、注意事项 ‌在C++中,模板是实现泛型编程

Spring中@RestController和@Controller的使用及区别

《Spring中@RestController和@Controller的使用及区别》:本文主要介绍Spring中@RestController和@Controller的使用及区别,具有很好的参考价... 目录Spring中@RestController和@Controller使用及区别1. 基本定义2. 使

Qt 中 isHidden 和 isVisible 的区别与使用小结

《Qt中isHidden和isVisible的区别与使用小结》Qt中的isHidden()和isVisible()方法都用于查询组件显示或隐藏状态,然而,它们有很大的区别,了解它们对于正确操... 目录1. 基础概念2. 区别清见3. 实际案例4. 注意事项5. 总结1. 基础概念Qt 中的 isHidd