Visual Studio 2019 + libtorch(Pytorch C++库) 环境配置

Visual Studio 2019 + libtorch(Pytorch C++库) 环境配置

前言:

为了方便工程上对现有的深度学习算法进行运用部署,本文将在windows环境下进行深度学习框架libtorch(Pytorch的C++接口)配置。

一、个人环境

  • Windows10 64位
  • Visual Studio 2019
  • Cuda 10.2
  • libtorch1.10.0 GPU/CPU
  • OpenCV 3.4.3

二、环境安装

  1. Visual Studio 2019 的安装网上有大把教程,本文在此不再赘述。网上大多数教程为vs2017及以上才能安装Libtorch,但需要注意的是,若安装的Libtorch版本为V1.10.0及以上时,需要vs2019。

  2. CMake安装

    CMake官网下载地址:https://cmake.org/download/

在这里插入图片描述

安装的版本需要与操作系统相匹配,如windows 64位系统则可以选则 cmake-3.8.0-rc1-win64-x64.msi,进行下载安装,安装过程非常简单,此处忽略。

  1. libtorch安装

    libtorch官网下载地址:https://pytorch.org/

在这里插入图片描述

【注意】下载libtorch时需要选择Release还是Debug版本,并且libtorch的版本必须与Python输出的Pytorch训练模型xxx.pt相对应,否则无法进行推理。

下载解压之后文件格式如下:

在这里插入图片描述

  1. Visual Studio 2019 配置libtorch

    本人之前在VS2017中配置libtorch时,因为VS版本太低,对新的C++标准并不支持,所以报错较多,后续通过论坛博客交流之后发现,VS2019对libtorch比较支持,且一次便配置成功,故推荐。

    根据项目需求以及个人需要来安装库,通常根据CPU和GPU来进行选择,而调试模式一般选择Release版本进行安装,这样可以减小代码编译错误以及提高代码运行效率。

在这里插入图片描述

  1. 打开属性管理器,右键你选择的编译模式,新建属性表,这里以LibtorchRelease进行命名,当然也可以自定义。

在这里插入图片描述

  1. VC++ 包含目录、库目录

    通用属性->VC++目录->包含目录、库目录

在这里插入图片描述

  包含目录:

  ```apl
  path: xxx\libtorch\include\torch\csrc\api\include
  path: xxx\libtorch\include
  path: xxx\opencv\build\include
  path: xxx\opencv\build\include\opencv
  path: xxx\opencv\build\include\opencv2
  ```

  库目录:

  ```apl
  path: xxx\libtorch\lib
  path: xxx\opencv\build\x64\vc15\lib
  ```

  将之前文件夹里的**libtorch**和**OpenCV**的头文件目录放在包含目录,库文件放在库目录下即可。
  1. 链接器配置

    链接器->输入->附加依赖项

    c10.lib
    c10_cuda.lib
    torch_cpu.lib
    torch_cuda.lib
    

    至此,配置完成。

  2. 测试

    新建源文件main.cpp,将如下代码

    #include "torch/torch.h"
    #include "torch/script.h"
    #include <opencv2/core/core.hpp>  
    #include <opencv2/highgui/highgui.hpp>  
    #include <iostream>
    #include <string.h>
    int main() {
    	cv::Mat img = cv::imread("C:\\Users\\admin\\Desktop\\1.png");
    	cv::imshow("show", img);
    	cv::waitKey(3000);
    	torch::Tensor tensor = torch::rand({ 2, 3 });
    	if (torch::cuda::is_available()) {
    		std::cout << "CUDA is available! Training on GPU" << std::endl;
    		auto tensor_cuda = tensor.cuda();
    		std::cout << tensor_cuda << std::endl;	
    	}
    	else
    	{
    		std::cout << "CUDA is not available! Training on CPU" << std::endl;
    		std::cout << tensor << std::endl;
    	}
    
    
    	std::cin.get();
    }
    

    OpenCV调试与Libtorch调试结果如下时,调试成功!

在这里插入图片描述

  ### 二、BUG处理

  1. 直接运行,输出: `“cuda::is_available(): 0”`,GPU未调用起来。

     **解决方法**:

     - 使用VS2017及以上版本;

     - windows上装的cuda版本需要与下载的libtorch的cuda版本相对应;

     - 在“属性 --> 链接器 --> 命令行 --> 其他选项”中添加

       ```apl
       /INCLUDE:?warp_size@cuda@at@@YAHXZ
       ```

  2. 关于VS2017编译时,出现不支持或者大量错误,可以使用更高级的VS(如VS2019)进行编译。

  • 5
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用\[1\]:本文介绍了在Windows环境配置深度学习框架libtorchPyTorchC++接口)的步骤和要求。作者提供了个人环境和安装的详细说明。\[1\] 引用\[2\]:在配置完成后,可以使用Visual Studio创建一个新的源文件main.cpp,并在其中编写C++代码来使用libtorch进行深度学习任务。作者提供了一个示例代码,其中包括了引入必要的头文件、读取图像、使用GPU或CPU进行计算等操作。\[2\] 引用\[3\]:此外,如果你想在Jupyter Notebook中使用PyTorch进行深度学习任务,可以使用相应的代码进行测试和运行。作者提供了一个示例代码,其中包括了读取图像、加载预训练模型、进行推理和保存模型等操作。\[3\] 所以,如果你想在Visual Studio中使用PyTorchC++接口进行深度学习任务,你可以按照引用\[1\]中提供的步骤配置libtorch,并在新建的源文件中编写C++代码,参考引用\[2\]中的示例代码。如果你更喜欢在Jupyter Notebook中使用PyTorch,你可以参考引用\[3\]中的示例代码进行测试和运行。希望这些信息对你有帮助! #### 引用[.reference_title] - *1* *2* [Visual Studio 2019 + libtorch(Pytorch C++) 环境配置](https://blog.csdn.net/weixin_43912897/article/details/121740380)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [visual studio +libtorch +cuda 11.3 配置pytorch C++环境](https://blog.csdn.net/qq_41562735/article/details/125922729)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值