谷歌draco
Draco 由谷歌 Chrome 媒体团队设计,旨在大幅加速 3D 数据的编码、传输和解码。因为研发团队的 Chrome 背景,这个开源算法的首要应用对象是浏览器。但既然谷歌把它开源,现在全世界的开发者可以去探索 Draco 在其他场景的应用,比如说非网页端。目前,谷歌提供了它的两个版本: JavaScript 和 C++。
Draco 可以被用来压缩 mesh 和点云数据。它还支持压缩点( compressing points),连接信息,纹理协调,颜色信息,法线( normals)以及其他与几何相关的通用属性。下面是谷歌官方发布的 Draco Mesh 文件压缩率,可以看出,它大幅优于 ZIP。
Draco 的算法既支持有损模式,也支持无损。这给普通消费者带来的好处还不太明显——毕竟大多数人对分辨率并没有强迫症,有损压缩带来的轻微画质改变完全在承受范 围之内。但对专业应用和科研应用的意义就很大了。这就好比 JPEG 之于 PNG。后者用于游戏和 VR 应用完全没有问题,降低的画质很难用肉眼察觉。但在科研点云数据中,任何信息都不能丢失。
如何使用draco?
github上简介:
Draco is a library for compressing and decompressing 3D geometric meshes and point clouds. It is intended to improve the storage and transmission of 3D graphics.
(1)下载源码
git clone https://github.com/google/draco.git
(2) cd dracs
mkdir build
cmake ..
如果提示你cmake的版本太低了,则需要升级cmake ,命令如下
sudo add-apt-repository ppa:george-edison55/cmake-3.x
sudo apt-get update
如果你从来没装过cmake 则sudo apt-get install cmake(经过测试 即使装过还是用这个命令直接升级比较好)
如果你装过cmake 则sudo apt-get upgrade
安装完后,用命令:cmake --version 查看当前的cmake版本,可以看到现在cmake的版本为3.2.2
之后就可以编译通过,make 一下傻等片刻就安装成功
那么就可以使用查看一下效果,为了可视化以下,所以还是使用强大的PCL库来对比以下,在PCL库中读取PLY文件也是有对应的函数的
class pcl::PCDReader()与class pcl::FLYReader() 分别是PCD,和FLY文件格式的接口的实现
class pcl::PCDWriter()与class pcl::FLYWriter()分别是对PCD,FLY文件写入接口的实现
查看发现它们的其他函数基本都是一样的,就是把PCD 换成FLY即可
所以我们就可以使用draco来编码FLY格式的点云数据,然后在解码生成FLY文件,再在点云库中可视化一下,并且查看编码前后编码后文件的大小,可以看看编码的效率
首先我们查看原始的文件以及它的大小3M
原始文件大小
对原文件编码 生成了out.drc文件并查看文件大小113.KB的大小
编码命令
编码后的文件大小
并可视化原始点云,如下图:
然后为了在可视化编码后再解码的效果,所以再查看解压后的大小为431.5KB
解码命令
解码后的文件的大小
可视化的效果和之前的是一样的,同时为了查看有没有丢失点数,打印出来看一下,发现点云数目没有变化都是35947 data points
总结以下,原来的文本是3M,编码后是113.KB文件,文件很小,压缩的效率非常高,为了再可视化,所以再解压,可视化的效果与原点云效果是一样的,
原始文件可视化并输出点云的大小
解码后的点云可视化并打印点云数目
结合PCL库可视化的代码如下:
#include <iostream> //标准C++库中的输入输出的头文件
#include <pcl/io/pcd_io.h> //PCD读写类相关的头文件
#include <pcl/point_types.h> //PCL中支持的点类型的头文件
#include <pcl/io/ply_io.h>#include <boost/thread/thread.hpp>
#include <pcl/visualization/pcl_visualizer.h>
int main (int argc, char** argv) { //创建一个PointCloud<pcl::PointXYZ> boost共享指针并进行实例化 pcl::PointCloud<pcl::PointXYZ>::Ptr cloud (new pcl::PointCloud<pcl::PointXYZ>); //打开点云文件 if (pcl::io::loadPLYFile<pcl::PointXYZ> ("bun_zipper.ply", *cloud) == -1) { PCL_ERROR ("Couldn't read file bun_zipper.ply \n"); return (-1); }std::cout << "Loaded " << cloud->width * cloud->height << " data points from bun_zipper.ply with the following fields: " << std::endl;boost::shared_ptr<pcl::visualization::PCLVisualizer> viewer(new pcl::visualization::PCLVisualizer("cloud")); viewer->addPointCloud<pcl::PointXYZ>(cloud,"cloud");while(!viewer->wasStopped()) { viewer->spinOnce(100); boost::this_thread::sleep(boost::posix_time::microseconds(1000000)); } return (0); }
对于draco的算法以及代码都没有详细的研究,这里只是看看它的压缩效率,同时我们在编码的时候,那几条命令时可以设置参数的,也可以设置编码的等级,所以还需要更加深入的研究,
如有问题可以与我交流,谢谢,同时有感兴趣者可以扫描二维码与我交流