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

相关文章

Spring Boot Interceptor的原理、配置、顺序控制及与Filter的关键区别对比分析

《SpringBootInterceptor的原理、配置、顺序控制及与Filter的关键区别对比分析》本文主要介绍了SpringBoot中的拦截器(Interceptor)及其与过滤器(Filt... 目录前言一、核心功能二、拦截器的实现2.1 定义自定义拦截器2.2 注册拦截器三、多拦截器的执行顺序四、过

C# Semaphore与SemaphoreSlim区别小结

《C#Semaphore与SemaphoreSlim区别小结》本文主要介绍了C#Semaphore与SemaphoreSlim区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录一、核心区别概览二、详细对比说明1.跨进程支持2.异步支持(关键区别!)3.性能差异4.API 差

Java中自旋锁与CAS机制的深层关系与区别

《Java中自旋锁与CAS机制的深层关系与区别》CAS算法即比较并替换,是一种实现并发编程时常用到的算法,Java并发包中的很多类都使用了CAS算法,:本文主要介绍Java中自旋锁与CAS机制深层... 目录1. 引言2. 比较并交换 (Compare-and-Swap, CAS) 核心原理2.1 CAS

MySQL中VARCHAR和TEXT的区别小结

《MySQL中VARCHAR和TEXT的区别小结》MySQL中VARCHAR和TEXT用于存储字符串,VARCHAR可变长度存储在行内,适合短文本;TEXT存储在溢出页,适合大文本,下面就来具体的了解... 目录一、VARCHAR 和 TEXT 基本介绍1. VARCHAR2. TEXT二、VARCHAR

python中getsizeof和asizeof的区别小结

《python中getsizeof和asizeof的区别小结》本文详细的介绍了getsizeof和asizeof的区别,这两个函数都用于获取对象的内存占用大小,它们来自不同的库,下面就来详细的介绍一下... 目录sys.getsizeof (python 内置)pympler.asizeof.asizeof

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Go之errors.New和fmt.Errorf 的区别小结

《Go之errors.New和fmt.Errorf的区别小结》本文主要介绍了Go之errors.New和fmt.Errorf的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考... 目录error的基本用法1. 获取错误信息2. 在条件判断中使用基本区别1.函数签名2.使用场景详细对

Redis中哨兵机制和集群的区别及说明

《Redis中哨兵机制和集群的区别及说明》Redis哨兵通过主从复制实现高可用,适用于中小规模数据;集群采用分布式分片,支持动态扩展,适合大规模数据,哨兵管理简单但扩展性弱,集群性能更强但架构复杂,根... 目录一、架构设计与节点角色1. 哨兵机制(Sentinel)2. 集群(Cluster)二、数据分片

一文带你迅速搞懂路由器/交换机/光猫三者概念区别

《一文带你迅速搞懂路由器/交换机/光猫三者概念区别》讨论网络设备时,常提及路由器、交换机及光猫等词汇,日常生活、工作中,这些设备至关重要,居家上网、企业内部沟通乃至互联网冲浪皆无法脱离其影响力,本文将... 当谈论网络设备时,我们常常会听到路由器、交换机和光猫这几个名词。它们是构建现代网络基础设施的关键组成

redis和redission分布式锁原理及区别说明

《redis和redission分布式锁原理及区别说明》文章对比了synchronized、乐观锁、Redis分布式锁及Redission锁的原理与区别,指出在集群环境下synchronized失效,... 目录Redis和redission分布式锁原理及区别1、有的同伴想到了synchronized关键字