当前位置: 首页 > news >正文

巴中网站建设搜索引擎优化培训免费咨询

巴中网站建设,搜索引擎优化培训免费咨询,包头网站建设包头,福田网站建设推荐语义分割模型在训练时往往采用python脚本进行网络搭建和训练,并获得训练好的模型。为了提高效率方便整个工程项目部署,实际工程应用中通常希望使用C编程语言调用训练好的网络模型。查询大量网络资料并踩过无数坑后,经实际测试实现了在window1…

         语义分割模型在训练时往往采用python脚本进行网络搭建和训练,并获得训练好的模型。为了提高效率方便整个工程项目部署,实际工程应用中通常希望使用C++编程语言调用训练好的网络模型。查询大量网络资料并踩过无数坑后,经实际测试实现了在window11环境下调用pytorch语义分割模型,具体实现步骤记录如下。

一、系统环境参数

电脑系统:window11
VS版本:2019
pytorch版本:2.1
CUDA版本:cuda11
python版本:3.9.17

二、pytorch模型转换

在C++环境下调用pytorch网络模型,首先需要将其转换为能够识别和调用的网络模型(.pt格式)。新建python脚本实现模型转换。实现代码如下:

import torch
import torchvisiondevice = torch.device('cuda') if torch.cuda.is_available() else torch.device('cpu')filenameCheckpoint = '../checkpoints/checkpoint_end.pth.tar'checkpoint = torch.load(filenameCheckpoint)model = checkpoint['arg']model.load_state_dict(checkpoint['state_dict'])
model.cuda(device)input_img_rand = torch.rand(1, 3, 608, 608).cuda()
traced_script_module = torch.jit.trace(model, input_img_rand)
traced_script_module.save('forign_detect_model-gpu.pt')model.cpu()
input_img_rand_cpu = torch.rand(1, 3, 608, 608)
traced_script_module = torch.jit.trace(model, input_img_rand_cpu)
traced_script_module.save("forign_detect_model-cpu.pt")

三、libtorch库下载

这个库是实现模型调用的关键,进入pytorch官网即可下载,下载时参数选择如下图,本文下载的是release版本,下载链接如下:libtorch。下载完成后解压到固定目录即可。


 四、VS2019环境配置

打开vs2019,创建空项目,新建main.cpp。注意切换选择为x64模式。打开项目属性页进行环境配置。属性页中C/C++->常规->附件包含目录。添加头文件路径(根据libtorch实际的路径修改),如下图所示。后期会使用到opencv,需要进行 opencv环境配置
然后配置 链接器->常规->附加库目录,配置如下图:

 继续配置依赖项:链接器->输入->附加依赖项。如下图所示:

 为方便输入,依赖项如下:

asmjit.lib
c10.lib
c10_cuda.lib
caffe2_nvrtc.lib
clog.lib
cpuinfo.lib
dnnl.lib
fbgemm.lib
fbjni.lib
kineto.lib
libprotobuf.lib
libprotobuf-lite.lib
libprotoc.lib
nvfuser_codegen.lib
pthreadpool.lib
pytorch_jni.lib
torch.lib
torch_cpu.lib
torch_cuda.lib
XNNPACK.lib
opencv_world346.lib(根据OpenCV版本进行修改)

最后是调试的环境配置,如下图所示:
 配置如下:PATH=D:\CODES\forign_detectC++\libtorch\lib;E:\opencv\build\x64\vc15\bin(需要根据实际库的安装路径修改)。

值得注意的是由于我的pytorch版本较高为2.1,需要使用c++17才能编译成功。因此需要配置C++17,如下图所示。

 至此,环境配置环境,接下来开始模型调用实现。


五、pytorch模型调用

main.cpp中完整调用代码如下:输入一张测试图,调用语义分割模型,最后获得语义分割图像。
 

#include <torch/script.h>
#include <opencv2/opencv.hpp>
#include <iostream>
#include <torch/torch.h>int main()
{torch::DeviceType device_type;if (torch::cuda::is_available()) {std::cout << "CUDA available! Predicting on GPU." << std::endl;device_type = torch::kCUDA;}else {std::cout << "Predicting on CPU." << std::endl;device_type = torch::kCPU;}torch::Device device(device_type);//模型加载std::string model_pb = "D:\\CODES\\forign_detectC++\\testPro\\forign_detect_model-gpu.pt";auto module = torch::jit::load(model_pb);module.to(at::kCUDA);
//测试图像加载auto image = cv::imread("testimg.png", cv::ImreadModes::IMREAD_COLOR);cv::Mat image_transfomed;cv::resize(image, image_transfomed, cv::Size(image.rows, image.cols));cv::cvtColor(image_transfomed, image_transfomed, cv::COLOR_BGR2RGB);//转为适合训练的张量维度torch::Tensor tensor_image = torch::from_blob(image_transfomed.data,{ image_transfomed.rows, image_transfomed.cols,3 }, torch::kByte);tensor_image = tensor_image.permute({ 2,0,1 });tensor_image = tensor_image.toType(torch::kFloat);tensor_image = tensor_image.div(255);tensor_image = tensor_image.unsqueeze(0);tensor_image = tensor_image.to(at::kCUDA);torch::Tensor output = module.forward({ tensor_image }).toTensor();
//获取预测结果torch::Tensor pred_out = output[0];//std::tuple<torch::Tensor, torch::Tensor> img_reverse_one_hot = torch::max(pred_out, 0);//类别的最大值torch::Tensor img_max_value = std::get<0>(img_reverse_one_hot);
//类别最大值索引torch::Tensor img_max_index = std::get<1>(img_reverse_one_hot);img_max_index = img_max_index.to(torch::kU8);img_max_index = img_max_index.to(torch::kCPU);//tensor 转cv::Matcv::Mat img_max_index_mat(image_transfomed.rows, image_transfomed.cols, CV_8U);std::memcpy((void*)img_max_index_mat.data, img_max_index.data_ptr(), sizeof(torch::kU8) * img_max_index.numel());//给预测结果赋值颜色cv::Mat coloredImg(image_transfomed.rows, image_transfomed.cols, CV_8UC3);const cv::Vec3b colorMap[] ={cv::Vec3b(0,0,0),cv::Vec3b(255,0,0)};for (int x = 0; x < coloredImg.rows; x++){for (int y = 0; y < coloredImg.cols; y++){int label = img_max_index_mat.at<uchar>(x, y);coloredImg.at<cv::Vec3b>(x, y) = colorMap[label];}}
//转BGRcv::cvtColor(coloredImg, coloredImg, cv::COLOR_RGB2BGR);
//与原图合并cv::bitwise_or(image, coloredImg, coloredImg);cv::imwrite("output.png", coloredImg);return 0;
}

 六、调试过程中遇到的坑

1.vs版本问题,之前使用vs2017,编译一直有问题,即便主函数什么都没有,仅包含头文件也会报错,折腾好几天,换成vs2019就没问题。

2.libtorch的版本问题,由于我当时下载的是release版本,但vs里面却设置了debug版本,导致程序一运行就会出现debug error abort has been called。因此,需要注意libtorch的版本和vs运行时的模式保持一致。同样注意vs里设置x64模式。
3.c++17问题:pytorh2.1必须使用c++17才能顺利编译,否则会报C++无法编译pytorch的问题,因此需要在vs中的“语言”模块中配置c++17。

http://www.shuangfujiaoyu.com/news/23163.html

相关文章:

  • 网站客户端制作互联网营销的五个手段
  • 北京北京网站建设优化大师有必要安装吗
  • 千图网素材免费搜索引擎seo如何优化
  • wordpress重新安装博客怎么搬家厦门seo推广公司
  • 不用网站做淘宝客网店代运营收费
  • 杭州市富阳区建设局网站靠谱的代写平台
  • 珠海哪家做企业网站公司好网络营销的概念及特点
  • 内网电脑做网站seo工作是什么意思
  • 电影网站是怎么做的全球网络营销公司排名
  • 网站开发功能简介广州网站排名优化公司
  • 惠州做棋牌网站建设有哪些公司seo优化包括
  • 菜鸟建网站网络推广网站的方法
  • 国外企业建站深圳搜索引擎优化收费
  • 400电话单页网站51趣优化网络seo工程师教程
  • wordpress 云储存插件苏州seo安严博客
  • 怎么做网站seo优化军事新闻最新24小时
  • 做复刻手表的网站世界互联网峰会
  • 华茂达建设集团网站广东的seo产品推广服务公司
  • 做房产的网站排名seo首页关键词优化
  • 竹子建站下载友情链接论坛
  • 贴吧做网站网上商城推广13种方法
  • 网站制作网页制作百度快照推广一年要多少钱
  • 企业网站建设要多久正规接单赚佣金的app
  • 建站之星网站建设下载版cpv广告联盟
  • 为什么网站要域名南宁seo网络推广
  • 页面设计模板素材栾城seo整站排名
  • 如何更新网站缓存企业网站制作需要多少钱
  • 简述跨境电商网站的平台建设刚刚突发1惊天大事
  • 大连网站建设公司哪家好微信营销平台
  • 灯具做外贸的网站有哪些seo网站关键词优化方式