G-PCC安装与编解码过程——vs2017

2023-10-22 04:50

本文主要是介绍G-PCC安装与编解码过程——vs2017,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

参考文献:Khaled Mammou, Philip A. Chou et al.ISO/IEC JTC1/SC29/WG11 N18189.[S].International Organisation for Standardisation,January 2019.

源代码:https://github.com/MPEGGroup/mpeg-pcc-tmc13

一、环境安装:

1)系统: Windows

2)安装Visual Studio 2017:

参考:Visual Studio 2017安装使用方法_独孤过的博客-CSDN博客_visualstudio2017安装教程

下载 community版本 ,安装完成登陆账号即可

3)安装Cmake(工程所需环境、参数编译软件)

参考:windows下cmake的安装教程_向阳的博客-CSDN博客_windows下cmake的安装教程

4)安装Git(数据集编解码参数获得工具)

参考:Git下载、安装与环境配置_一笑生花-CSDN博客_git安装配置

安装完成即可,

5)安装MeshLab(查看点云软件)

官网:MeshLab

二、配置文件下载

1)编解码参数文件获得

打开mpeg-pcc-tmc13-master\cfg,在当前文件中右键打开git bash here,输入:

../sctipts/gen-cfg.sh

  然后会出现缺少文件,如下图:

 说明缺少List::Moreutils module,需要在C:\Program Files\Git\usr\share\perl5\core_perl(你安装GIT的路径)路径下添加缺少的module,在https://metacpan.org/author/REHSACK网站下下载需要的module

以上述缺少List::Moreutils module为例,根据以下操作步骤操作:

 

 下载后安装包打开找到如下

 将文件夹放入C:\Program Files\Git\usr\share\perl5\core_perl(安装GIT的路径)路径即可。接下来继续重复第四步,直到没有错误为止。需要注意的是,例如你要将Exporter文件夹复制到core_perl路径底下,但是路径底下已经有Exporter文件,那么要将你下载的Exporter底下文件复制到路径底下Exporter文件里面。

当输入../scripts/gen-cfg.sh没有错误后,然后执行../scripts/gen-cfg.sh --all,生成不同几何属性等配置文件

获得编解码文件

 2)cmake编译工程文件

在代码文件相同目录下创建工作文件夹,打开camke

 点击configure

 出现错误如下:

点击GIT_EXECUTABLE的Value,选择git安装目录文件中的git-cmd.exe即可,再次编译

点击generate ,open project

三、编解码(Debug模式和Release模式)

将一帧点云数据放入工作目录下,在cfg文件夹中找到对应编码文件encoder.cfg和解码文件decoder.cfg也放入工作目录下,例如:我用静态点云people中soldier数据集,选择有损几何和有损属性编解码,r5是QP=28的编解码参数文件(查看encoder.cfg可知QP值等参数,选择哪种参数文件根据需要所定)

Debug模式:在Visual Studio运行

1)编码

右键设置tmc3为启动项,右键属性

 

命令参数输入编码参数,工作目录输入创建的工作目录路径

例如:

       命令参数:-c encoder.cfg --uncompressedDataPath="Ford_01_vox1mm-0100.ply" --compressedStreamPath=compressed.bin

       工作目录:D:\Projects\G-PCC_test\workspace

点击调试,即编码完成,得到二进制码流文件compressed.bin

2)解码

将命令参数改为:-c decoder.cfg --compressedStreamPath=compressed.bin --reconstructedDataPath="chongjian.ply"

重复上述步骤,即可解码完成,得到重建点云

查看点云的话,可以用MeshLab查看

Release模式:在Windows PowerShell环境下运行

1)tmc3.exe生成

在Visual Studio打开工程文件,将Debug模式改成Release模式,右键tmc3生成解决方案,在输出框最后找到tmc3.exe路径

 2)编码

打开Windows PowerShell命令框,打开工作目录

.\tm3\Release\tmc3.exe -c encoder.cfg --uncompressedDataPath="Ford_01_vox1mm-0100.ply" --compressedStreamPath=compressed.bin

3)解码

将上述步骤的编码参数该成解码参数,运行得到重建点云

.\tm3\Release\tmc3.exe -c decoder.cfg --compressedStreamPath=compressed.bin --reconstructedDataPath="chongjian.ply"

这篇关于G-PCC安装与编解码过程——vs2017的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Redis中Hash从使用过程到原理说明

《Redis中Hash从使用过程到原理说明》RedisHash结构用于存储字段-值对,适合对象数据,支持HSET、HGET等命令,采用ziplist或hashtable编码,通过渐进式rehash优化... 目录一、开篇:Hash就像超市的货架二、Hash的基本使用1. 常用命令示例2. Java操作示例三

Redis中Set结构使用过程与原理说明

《Redis中Set结构使用过程与原理说明》本文解析了RedisSet数据结构,涵盖其基本操作(如添加、查找)、集合运算(交并差)、底层实现(intset与hashtable自动切换机制)、典型应用场... 目录开篇:从购物车到Redis Set一、Redis Set的基本操作1.1 编程常用命令1.2 集

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

k8s中实现mysql主备过程详解

《k8s中实现mysql主备过程详解》文章讲解了在K8s中使用StatefulSet部署MySQL主备架构,包含NFS安装、storageClass配置、MySQL部署及同步检查步骤,确保主备数据一致... 目录一、k8s中实现mysql主备1.1 环境信息1.2 部署nfs-provisioner1.2.

python依赖管理工具UV的安装和使用教程

《python依赖管理工具UV的安装和使用教程》UV是一个用Rust编写的Python包安装和依赖管理工具,比传统工具(如pip)有着更快、更高效的体验,:本文主要介绍python依赖管理工具UV... 目录前言一、命令安装uv二、手动编译安装2.1在archlinux安装uv的依赖工具2.2从github

MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决

《MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决》MyBatis默认开启一级缓存,同一事务中循环调用查询方法时会重复使用缓存数据,导致获取的序列主键值均为1,... 目录问题原因解决办法如果是存储过程总结问题myBATis有如下代码获取序列作为主键IdMappe

JDK8(Java Development kit)的安装与配置全过程

《JDK8(JavaDevelopmentkit)的安装与配置全过程》文章简要介绍了Java的核心特点(如跨平台、JVM机制)及JDK/JRE的区别,重点讲解了如何通过配置环境变量(PATH和JA... 目录Java特点JDKJREJDK的下载,安装配置环境变量总结Java特点说起 Java,大家肯定都

linux部署NFS和autofs自动挂载实现过程

《linux部署NFS和autofs自动挂载实现过程》文章介绍了NFS(网络文件系统)和Autofs的原理与配置,NFS通过RPC实现跨系统文件共享,需配置/etc/exports和nfs.conf,... 目录(一)NFS1. 什么是NFS2.NFS守护进程3.RPC服务4. 原理5. 部署5.1安装NF

MySQL使用EXISTS检查记录是否存在的详细过程

《MySQL使用EXISTS检查记录是否存在的详细过程》EXISTS是SQL中用于检查子查询是否返回至少一条记录的运算符,它通常用于测试是否存在满足特定条件的记录,从而在主查询中进行相应操作,本文给大... 目录基本语法示例数据库和表结构1. 使用 EXISTS 在 SELECT 语句中2. 使用 EXIS

oracle 11g导入\导出(expdp impdp)之导入过程

《oracle11g导入导出(expdpimpdp)之导入过程》导出需使用SEC.DMP格式,无分号;建立expdir目录(E:/exp)并确保存在;导入在cmd下执行,需sys用户权限;若需修... 目录准备文件导入(impdp)1、建立directory2、导入语句 3、更改密码总结上一个环节,我们讲了