VTM工程配置libtorch环境

2023-10-10 02:10

本文主要是介绍VTM工程配置libtorch环境,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

VTM配置libtorch

首先下载libtorch库,可以百度搜索下载地址.下载完成之后将其解压到文件夹中,如下图所示,

 其中include文件夹下是libtorch库的头文件;
lib文件夹下是libtorch库的静态库(lib)和动态链接库(dll);
share文件夹下有之后cmake配置时要find的.cmake文件,用于在cmake时让项目链接到libtorch库;

之后配置环境变量,如下图所示,将如下几个目录加入到环境变量中

 配置完成之后,就可以在VTM工程中的CMakeLists.txt中添加如下语句,用于cmake时链接到libtorch库

find_package(Torch REQUIRED)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${TORCH_CXX_FLAGS}")

 最后使用cmake进行编译即可。

问题:

在编译完成后,打开VTM工程,运行时会出现重定义的错误,这是由于在libtorch库和VTM中存在几个相同名称的变量,可以将VTM中同名称的变量重命名,或者可以将libtorch中同名的变量注释掉(亲测可用)。

libtorch的简单使用:

1. 加载模型

定义torch::jit::script::Module类型的变量用于加载模型

  torch::jit::script::Module m_lumaModuleISlice[3];torch::jit::script::Module m_chromaModuleISlice[3];torch::jit::script::Module m_lumaModuleBSlice[5];torch::jit::script::Module m_chromaModuleBSlice[5];

 通过torch::jit::load函数加载模型

void CNNFilter::initISlice(int qp)
{if (m_modelInitFlagISlice)return;at::set_num_threads(1);at::set_num_interop_threads(1);for (int i = 0; i < 3; i++){std::string sLumaModelName = "E:/VTM/models/JVET_W_EE_LumaCNNFilter_IntraSlice_qp" + sQp[i] + ".pt";std::string sChromaModelName = "E:/VTM/models/JVET_W_EE_ChromaCNNFilter_IntraSlice_qp" + sQp[i] + ".pt";m_lumaModuleISlice[i] = torch::jit::load(sLumaModelName); // 加载模型m_chromaModuleISlice[i] = torch::jit::load(sChromaModelName);}}

2. 创建模型的输入

 torch::Tensor张量类型,libtorch和pytorch中许多api一致,以产生全1张量为例,通过torch::ones({1, 1, blockSizeVer, blockSizeHor})产生尺寸为{1, 1, blockSizeVer, blockSizeHor}的四维张量,注意libtorch是使用{}表示尺寸。

定义好张量以后,可以通过调用data_ptr()函数获得指针,通过指针直接修改数据。

  torch::NoGradGuard no_grad_guard用于不计算梯度,和pytorch中的with torch.no_grad()等效

  torch::Tensor imageBatch = torch::ones({1, 1, blockSizeVer, blockSizeHor});float *pImageBatch = imageBatch.data_ptr<float>(); // 指向imageBatch的指针torch::Tensor predBatch = torch::ones({1, 1, blockSizeVer, blockSizeHor});float *pPredBatch = predBatch.data_ptr<float>(); // 指向predBatch 的指针// Create a vector of inputs. 创建vector用于模型输入std::vector<torch::jit::IValue> input; input.push_back(imageBatch);input.push_back(predBatch);int idx = 0;int blockSize = blockSizeVer * blockSizeHor;torch::NoGradGuard no_grad_guard;torch::globalContext().setFlushDenormal(true);//at::init_num_threads();for (int yy = 0; yy < blockSizeVer; yy++){for (int xx = 0; xx < blockSizeHor; xx++){// 通过指针给tensor赋值idx = yy * strideRec + xx;pImageBatch[yy*blockSizeHor+xx] = pRec[idx] / maxValue;  idx = yy * stridePred + xx;pPredBatch[yy*blockSizeHor+xx] = pPred[idx] / maxValue;}}

3. 模型推理

module->forward(): 模型前向传播的函数,输入值建议使用vector类型

  // Execute the model and turn its output into a tensor. 推理模型并将输出转换为tensorat::Tensor output = m_lumaModuleISlice[modelIdx].forward(input).toTensor();float *pOutput = output.data_ptr<float>(); // 输出tensor的指针

模型返回值

如果模型只有一个返回值,那么常用如下语句toTensor转换成张量

at::Tensor result = module.forward({tensor_image}).toTensor();

如果模型有多个返回值,那么则需要转换成Tuple.

auto result = module.forward({tensor_image}).toTuple();
at::Tensor loc= result->elements()[0].toTensor();
at::Tensor conf = result->elements()[1].toTensor();


 

这篇关于VTM工程配置libtorch环境的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

mybatis映射器配置小结

《mybatis映射器配置小结》本文详解MyBatis映射器配置,重点讲解字段映射的三种解决方案(别名、自动驼峰映射、resultMap),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定... 目录select中字段的映射问题使用SQL语句中的别名功能使用mapUnderscoreToCame

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

MySQL8 密码强度评估与配置详解

《MySQL8密码强度评估与配置详解》MySQL8默认启用密码强度插件,实施MEDIUM策略(长度8、含数字/字母/特殊字符),支持动态调整与配置文件设置,推荐使用STRONG策略并定期更新密码以提... 目录一、mysql 8 密码强度评估机制1.核心插件:validate_password2.密码策略级

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

QT Creator配置Kit的实现示例

《QTCreator配置Kit的实现示例》本文主要介绍了使用Qt5.12.12与VS2022时,因MSVC编译器版本不匹配及WindowsSDK缺失导致配置错误的问题解决,感兴趣的可以了解一下... 目录0、背景:qt5.12.12+vs2022一、症状:二、原因:(可以跳过,直奔后面的解决方法)三、解决方