【Py调用C++】使用使用python调用C++生成dll处理图像(OPENCV)

简介: 【Py调用C++】使用使用python调用C++生成dll处理图像(OPENCV)

前言

  最近在项目中遇到了一些问题,在这里记录一下。起因是这样的:有部分功能在python中处理的较慢,而在C++中使用相同的逻辑则使用的较快。面对这种困境的话我想到了C++可以制作dll文件或SO文件供python端调用,于是便有了本文中的记录。

需求

  现有一使用python调用opencv库读取的图像文件需要交付C++进行处理后返回结果,在这里我们简化一下流程:

image.png


  在上述的流程里我们参考VS的官方资料可以得到使用c++生成dll的步骤与例子,我就不过多阐述了;关于python调用dll的例子大家在python的官网上也可查阅到。我也不过过阐述了。在这里我主要记录一下难点:如何把一张三维图传递给dll

数据的传入与接收

  在python端我们可通过numpy将cv2读取的图像数据转为指针的形式,然后再c++中将指针转三维图像。

python

python

复制代码

import cv2
from ctypes import *
import numpy as np
def Mat2Uchar(matImg):
    Mat = np.asarray(matImg, dtype=np.uint8)
    Uchar = Mat.ctypes.data_as(c_char_p)
    return Uchar

C++

ini

复制代码

// pch.cpp: 与预编译标头对应的源文件
#include <iostream>
#include "opencv2/opencv.hpp"
#include "opencv2/ml/ml.hpp"
// change uchar* to mat Uchar2Mat
cv::Mat Uchar2Mat(uchar* frame_data, int width, int height) {
   cv::Mat img(height, width, CV_8UC3);
   uchar* ptr = img.ptr<uchar>(0);
   int count = 0;
   int channels = 3;
   for (int row = 0; row < height; row++) {
      ptr = img.ptr<uchar>(row);
      for (int col = 0; col < width; col++) {
         for (int c = 0; c < channels; c++) {
            ptr[col * channels + c] = frame_data[count];
            count++;
         }
      }
   }
   return img;
}

  在调用的时候我们需要定义dll函数的输入类型以及输出类型

ini

复制代码

mydll = CDLL("C:/Users/kiven/Desktop/v56c/Dll1/x64/Debug/Dll1.dll")
mydll.SaveImg.argtypes = [c_char_p]  # 定义输入值类型
mydll.SaveImg.restype = c_int  # 定义返回值类型

py的对比C++的缺点

  上述的两段代码我们已经实现了python调用c++生成的处理图像的dll函数。回过头来总结一下python相较于C++的缺点:

性能较低

  Python 是解释型语言,因此相较于编译型语言 C++,Python 的执行速度要慢一些。Python 需要将代码翻译成机器语言,这个过程需要花费一定的时间。尤其是在进行大量的数值计算时,Python 的性能表现较差。

GIL 的存在

  Python 的全局解释器锁(Global Interpreter Lock,GIL)是一种限制 Python 多线程并行性能的机制。GIL 只允许 Python 解释器执行同一时刻只有一个线程的代码。这意味着 Python 在多线程应用中无法充分利用多核 CPU 的性能

资源占用较多

  Python 在执行代码时需要占用较多的内存资源,这可能会导致在处理大型数据集时出现内存不足的问题。此外,Python 的一些库和框架可能会占用大量的磁盘空间。

  由于面对上述的明显缺点,我们可逆推一下:当我们的python任务面对:大量的数值计算任务、 需要充分利用多核CPU、处理大型数据集时内存不足时可利用好C++生成dll供python调用

结尾

  Python 调用 C++ 生成的 DLL 函数可以实现 Python 与 C++ 之间的数据交换和函数调用。通过 ctypes 模块,Python 可以动态链接 DLL 文件,并调用其中的函数。同时,使用 C++ 生成 DLL 文件的过程中需要注意一些问题,如函数声明需要添加 __declspec(dllexport) 关键字等。此外,对于 C++ 中一些复杂的数据类型,需要使用 ctypes 提供的相关类型进行转换。最后,需要注意在使用 ctypes 调用 DLL 函数时,需要指定函数的返回类型和参数类型。通过正确使用 ctypes 模块,Python 可以与 C++ 相结合,实现更加强大的功能和更高效的计算。


相关文章
|
16天前
|
机器学习/深度学习 算法 TensorFlow
动物识别系统Python+卷积神经网络算法+TensorFlow+人工智能+图像识别+计算机毕业设计项目
动物识别系统。本项目以Python作为主要编程语言,并基于TensorFlow搭建ResNet50卷积神经网络算法模型,通过收集4种常见的动物图像数据集(猫、狗、鸡、马)然后进行模型训练,得到一个识别精度较高的模型文件,然后保存为本地格式的H5格式文件。再基于Django开发Web网页端操作界面,实现用户上传一张动物图片,识别其名称。
46 1
动物识别系统Python+卷积神经网络算法+TensorFlow+人工智能+图像识别+计算机毕业设计项目
|
15天前
|
机器学习/深度学习 人工智能 算法
植物病害识别系统Python+卷积神经网络算法+图像识别+人工智能项目+深度学习项目+计算机课设项目+Django网页界面
植物病害识别系统。本系统使用Python作为主要编程语言,通过收集水稻常见的四种叶片病害图片('细菌性叶枯病', '稻瘟病', '褐斑病', '稻瘟条纹病毒病')作为后面模型训练用到的数据集。然后使用TensorFlow搭建卷积神经网络算法模型,并进行多轮迭代训练,最后得到一个识别精度较高的算法模型,然后将其保存为h5格式的本地模型文件。再使用Django搭建Web网页平台操作界面,实现用户上传一张测试图片识别其名称。
65 21
植物病害识别系统Python+卷积神经网络算法+图像识别+人工智能项目+深度学习项目+计算机课设项目+Django网页界面
|
15天前
|
机器学习/深度学习 人工智能 算法
鸟类识别系统Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+ResNet50算法模型+图像识别
鸟类识别系统。本系统采用Python作为主要开发语言,通过使用加利福利亚大学开源的200种鸟类图像作为数据集。使用TensorFlow搭建ResNet50卷积神经网络算法模型,然后进行模型的迭代训练,得到一个识别精度较高的模型,然后在保存为本地的H5格式文件。在使用Django开发Web网页端操作界面,实现用户上传一张鸟类图像,识别其名称。
60 12
鸟类识别系统Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+ResNet50算法模型+图像识别
|
2月前
|
机器学习/深度学习 人工智能 TensorFlow
使用Python和TensorFlow实现图像识别
【8月更文挑战第31天】本文将引导你了解如何使用Python和TensorFlow库来实现图像识别。我们将从基本的Python编程开始,逐步深入到TensorFlow的高级功能,最后通过一个简单的代码示例来展示如何训练一个模型来识别图像。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息。
138 53
|
20天前
|
存储 计算机视觉 C++
在C++中实现Armadillo库与OpenCV库之间的数据格式转换
在C++中实现Armadillo库与OpenCV库之间的数据格式转换是一项常见且实用的技能。上述步骤提供了一种标准的方法来进行这种转换,可以帮助开发者在两个库之间高效地转移和处理数据。虽然转换过程相对直接,但开发者应留意数据类型匹配和性能优化等关键细节。
25 11
|
21天前
|
存储 计算机视觉 C++
在C++中实现Armadillo库与OpenCV库之间的数据格式转换
在C++中实现Armadillo库与OpenCV库之间的数据格式转换是一项常见且实用的技能。上述步骤提供了一种标准的方法来进行这种转换,可以帮助开发者在两个库之间高效地转移和处理数据。虽然转换过程相对直接,但开发者应留意数据类型匹配和性能优化等关键细节。
17 3
|
6天前
|
Python Windows
Python:执行py命令,提示: Can‘t find a default Python.
Python:执行py命令,提示: Can‘t find a default Python.
|
2月前
|
机器学习/深度学习 人工智能 TensorFlow
利用Python和TensorFlow实现简单图像识别
【8月更文挑战第31天】在这篇文章中,我们将一起踏上一段探索人工智能世界的奇妙之旅。正如甘地所言:“你必须成为你希望在世界上看到的改变。” 通过实践,我们不仅将学习如何使用Python和TensorFlow构建一个简单的图像识别模型,而且还将探索如何通过这个模型理解世界。文章以通俗易懂的方式,逐步引导读者从基础到高级,体验从编码到识别的整个过程,让每个人都能在AI的世界中看到自己的倒影。
|
2月前
|
存储 编解码 API
python多种方法压缩图片,opencv、PIL、tinypng、pngquant压缩图片
python多种方法压缩图片,opencv、PIL、tinypng、pngquant压缩图片
47 1
|
2月前
|
移动开发 Java 编译器
什么是pyc文件,把python的py文件编译成pyc文件,把pyc文件反编译成py文件。以及python编译的如何设置不生成pyc文件
什么是pyc文件,把python的py文件编译成pyc文件,把pyc文件反编译成py文件。以及python编译的如何设置不生成pyc文件
31 1
下一篇
无影云桌面