测试 opencv-python 中的 mat 和 Umat 处理图像的差异(GPU加速)

简介: 测试 opencv-python 中的 mat 和 Umat 处理图像的差异(GPU加速)

前言


  近期探讨到了使用GPU加速Opencv处理图像的过程,相必大家在日常处理非深度学习任务图像数据的过程中使用的绝大多数是CPU进行处理的数据,例如对图像进行灰度化、添加噪声、滤波等操作。这里我们采用实验数据比较mat和Umat的特点说明Umat的优势




实验


实验准备


PC端配置:CPU:11400F - i5 GPU: GTX1660ti


常见图像像素尺寸例举:


img0.shape = 237 x 250 x 3


img1.shape = 512 x 384 x 3   (标清)


img2.shape = 640 x 352 x 3   (DVD)


img3.shape = 640 x 480 x 3  (数字电视RTSP)


img4.shape = 800 x 480 x 3  (数字电视RTSP)


img5.shape = 1024x 534 x 3  (数字电视RTSP)


img6.shape = 1280x 720 x 3  (直播)


img7.shape = 1280x 960 x 3  (工业相机)


img8.shape = 1920x 1080 x 3 (监控相机)



实验步骤


图像处理步骤:


  1. 读取图像


  1. 图像灰度话


  1. 添加高斯噪声


  1. Canny边缘检测




统计方式:


  计算循环100次的处理FPS均值,通过比较处理不同像素大小的图像进而比较在何时使用 mat 何时使用 Umat



处理结果:


512x384:


GPU: 302.8824480662899


CPU: 304.31073670160845



640X480


GPU: 204.14862846096017


CPU: 207.01862159693542


1024X543


GPU: 117.21923353899794


CPU: 131.77444173577712


1280X960


GPU: 61.402272955890474


CPU: 64.44232134963245


1920X1080


GPU: 31.742890957261825


CPU: 30.31974624205707




总结:


  mat2Umat的过程中也会耗费一定的时间,如果在工程应用中处理的是小尺寸图像&Opencv的计算量不大的情况下建议使用mat格式数据进行操作即可(这样避免了 mat2Umat过程的时间损耗);如果处理的是大尺寸图像并且需要大量使用opencv内置函数进行处理数据的话,大家可以使用mat2Umat进行转换数据到GPU上去进行 提速运算




demo


import cv2
import time
FpsList = []
for i in range(100):
    t1 = time.time()
    img = cv2.UMat(cv2.imread("512384.jpg", cv2.IMREAD_COLOR))
    # img = cv2.imread("512384.jpg", cv2.IMREAD_COLOR)
    gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
    gray = cv2.GaussianBlur(gray, (7, 7), 1.5)
    gray = cv2.Canny(gray, 0, 50)
    t2 = time.time()
    FPS = 1 / (t2 - t1)
    FpsList.append(FPS)
    cv2.putText(img, "FPS= %.2f" % FPS, (0, 40), cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 0, 255), 2)
    cv2.imshow("edges", img)
    cv2.waitKey(1)
print(sum(FpsList) / len(FpsList))




相关实践学习
部署Stable Diffusion玩转AI绘画(GPU云服务器)
本实验通过在ECS上从零开始部署Stable Diffusion来进行AI绘画创作,开启AIGC盲盒。
相关文章
|
1月前
|
计算机视觉
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
这篇文章详细介绍了OpenCV库中的图像二值化函数`cv2.threshold`,包括二值化的概念、常见的阈值类型、函数的参数说明以及通过代码实例展示了如何应用该函数进行图像二值化处理,并展示了运行结果。
332 0
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
|
2月前
|
机器学习/深度学习 算法 TensorFlow
动物识别系统Python+卷积神经网络算法+TensorFlow+人工智能+图像识别+计算机毕业设计项目
动物识别系统。本项目以Python作为主要编程语言,并基于TensorFlow搭建ResNet50卷积神经网络算法模型,通过收集4种常见的动物图像数据集(猫、狗、鸡、马)然后进行模型训练,得到一个识别精度较高的模型文件,然后保存为本地格式的H5格式文件。再基于Django开发Web网页端操作界面,实现用户上传一张动物图片,识别其名称。
93 1
动物识别系统Python+卷积神经网络算法+TensorFlow+人工智能+图像识别+计算机毕业设计项目
|
2月前
|
算法 计算机视觉
opencv图像形态学
图像形态学是一种基于数学形态学的图像处理技术,它主要用于分析和修改图像的形状和结构。
49 4
|
9天前
|
机器学习/深度学习 TensorFlow 算法框架/工具
利用Python和TensorFlow构建简单神经网络进行图像分类
利用Python和TensorFlow构建简单神经网络进行图像分类
29 3
|
1月前
|
存储 JSON API
Python| 如何使用 DALL·E 和 OpenAI API 生成图像(1)
Python| 如何使用 DALL·E 和 OpenAI API 生成图像(1)
42 7
Python| 如何使用 DALL·E 和 OpenAI API 生成图像(1)
|
2月前
|
机器学习/深度学习 人工智能 算法
植物病害识别系统Python+卷积神经网络算法+图像识别+人工智能项目+深度学习项目+计算机课设项目+Django网页界面
植物病害识别系统。本系统使用Python作为主要编程语言,通过收集水稻常见的四种叶片病害图片('细菌性叶枯病', '稻瘟病', '褐斑病', '稻瘟条纹病毒病')作为后面模型训练用到的数据集。然后使用TensorFlow搭建卷积神经网络算法模型,并进行多轮迭代训练,最后得到一个识别精度较高的算法模型,然后将其保存为h5格式的本地模型文件。再使用Django搭建Web网页平台操作界面,实现用户上传一张测试图片识别其名称。
121 22
植物病害识别系统Python+卷积神经网络算法+图像识别+人工智能项目+深度学习项目+计算机课设项目+Django网页界面
|
2月前
|
机器学习/深度学习 人工智能 算法
鸟类识别系统Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+ResNet50算法模型+图像识别
鸟类识别系统。本系统采用Python作为主要开发语言,通过使用加利福利亚大学开源的200种鸟类图像作为数据集。使用TensorFlow搭建ResNet50卷积神经网络算法模型,然后进行模型的迭代训练,得到一个识别精度较高的模型,然后在保存为本地的H5格式文件。在使用Django开发Web网页端操作界面,实现用户上传一张鸟类图像,识别其名称。
108 12
鸟类识别系统Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+ResNet50算法模型+图像识别
|
2月前
|
存储 计算机视觉
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
本文介绍了使用OpenCV进行图像读取、显示和存储的基本操作,以及如何绘制直线、圆形、矩形和文本等几何图形的方法。
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
|
3月前
|
机器学习/深度学习 人工智能 TensorFlow
使用Python和TensorFlow实现图像识别
【8月更文挑战第31天】本文将引导你了解如何使用Python和TensorFlow库来实现图像识别。我们将从基本的Python编程开始,逐步深入到TensorFlow的高级功能,最后通过一个简单的代码示例来展示如何训练一个模型来识别图像。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息。
155 53
|
1月前
|
JSON API 数据格式
Python| 如何使用 DALL·E 和 OpenAI API 生成图像(2)
Python| 如何使用 DALL·E 和 OpenAI API 生成图像(2)
48 0
Python| 如何使用 DALL·E 和 OpenAI API 生成图像(2)