OpenCV算法库

简介: numba是一个用于编译Python数组和数值计算函数的编译器,这个编译器能够大幅提高直接使用Python编写的函数的运算速度。

numba


numba是一个用于编译Python数组和数值计算函数的编译器,这个编译器能够大幅提高直接使用Python编写的函数的运算速度。

Numba是一个用于Python的即时(Just-in-time, JIT)编译器。将面向数组和使用大量数学的python代码优化到与c,c++和Fortran类似的性能,而无需改变Python的解释器。

numba的使用方法


numba对代码进行加速时,给要优化的函数加上@jit优化器


from numba import jit
@jit
def f(a, b):
    return a + b


numba将在调用期间推断参数类型,然后基于这个信息生成优化后的代码。


Numba编译的函数可以调用其他编译函数。


from math import sqrt
@jit
def hypot(a, b):
    return sqrt(square(a) + square(b))


import numpy as np
import time
 
# 创建一个1000x1000的随机数组
arr = np.random.rand(1000, 1000)
 
# 记录开始时间
start_time = time.time()
 
# 计算数组元素之和
sum_result = np.sum(arr)
 
# 记录结束时间
end_time = time.time()
 
# 计算运算时间
elapsed_time = end_time - start_time
 
print("未使用Numba加速时的运算时间:", elapsed_time)


使用Numba加速


import numpy as np
import time
from numba import jit
 
# 创建一个1000x1000的随机数组
arr = np.random.rand(1000, 1000)
 
# 定义一个使用Numba加速的函数
@jit(nopython=True)
def sum_array(arr):
    return np.sum(arr)
 
# 记录开始时间
start_time = time.time()
 
# 调用加速后的函数计算数组元素之和
sum_result = sum_array(arr)
 
# 记录结束时间
end_time = time.time()
 
# 计算运算时间
elapsed_time = end_time - start_time
 
print("使用Numba加速时的运算时间:", elapsed_time)


imutils


imutils是一个专为OpenCV设计的Python封装库,它极大地简化了图像处理的过程


imutils提供了一系列的工具函数,使得在Python中使用OpenCV进行图像处理变得更加快捷和简便。这些功能涵盖了图像的显示、平移、旋转、缩放以及骨架化等多种操作。由于imutils是基于OpenCV构建的,它可以与OpenCV无缝集成,为开发者提供了一个更加友好的接口来进行日常的图像处理任务。要安装imutils,可以使用pip命令pip install imutils。不过,需要注意的是,在使用imutils之前,需要确保已经安装了NumPy和OpenCV库,如果需要使用到将OpenCV图像转换为Matplotlib图像的功能,还需要安装Matplotlib库。


imutils的使用方法


OpenCV中提供了图像平移的实现,要先计算平移矩阵,然后利用仿射变换实现平移,在imutils中可直接进行图像的平移。


translated = imutils.translate(img,x,y)


  • img:要移动的图像
  • x:沿x轴方向移动的像素个数
  • y: 沿y轴方向移动的像素个数


图片的缩放在imutils中自动保持原有图片的宽高比,只指定宽度weight和Height即可。


img = cv.imread("a.jpeg")
resized = imutils.resize(img,width=200)
print("原图像: ", img.shape)
print("缩放后:",resized.shape)
plt.figure(figsize=[10, 10])
plt.subplot(1,2,1)
plt.imshow(cv.cvtColor(img, cv.COLOR_BGR2RGB))
plt.title('原图')
plt.axis("off")
plt.subplot(1,2,2)
plt.imshow(cv.cvtColor(resized, cv.COLOR_BGR2RGB))
plt.title('缩放结果')
plt.axis("off")
plt.show()


图像旋转


import cv2
import imutils
 
image = cv2.imread('a.jpeg')
rotated = imutils.rotate(image, 90)                                                                                      
rotated_round = imutils.rotate_bound(image, 90)                                 
 
plt.figure(figsize=[10, 10])
plt.subplot(1,3,1)
plt.imshow(img[:,:,::-1])
plt.title('原图')
plt.axis("off")
plt.subplot(1,3,2)
plt.imshow(rotated[:,:,::-1])
plt.title('逆时针旋转90度')
plt.axis("off")
plt.subplot(1,3,3)
plt.imshow(rotated_round[:,:,::-1])
plt.title('顺时针旋转90度')
plt.axis("off")
plt.show()


骨架提取,是指对图片中的物体进行拓扑骨架(topological skeleton)构建的过程。imutils提供的方法是skeletonize(),第二个参数是结构参数的尺寸(structuring element),越小需要处理的时间越长。


import cv2
import imutils
image = cv2.imread('a.jpg')
 
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)                                  
 
skeleton = imutils.skeletonize(gray, size=(3, 3))  
plt.figure(figsize=(10,8),dpi=100)
plt.subplot(121),plt.imshow(img[:,:,::-1]),plt.title('原图')
plt.xticks([]), plt.yticks([])
plt.subplot(122),plt.imshow(skeleton,cmap="gray"),plt.title('骨架提取结果')
plt.xticks([]), plt.yticks([])
plt.show()


在使用OPenCV时,应检查当前正在使用哪个版本的OpenCV,然后使用适当的函数或方法。在imutils中的is_cv2()、is_cv3()和is_cv4()是可用于自动确定当前环境的OpenCV的版本简单的功能。


DNN模块


DNN模块是指OpenCV中的深度神经网络(Deep Neural Networks)模块


OpenCV的DNN模块是一个强大的工具,它允许开发者在计算机视觉应用中利用深度学习模型进行分类、分割、检测和跟踪等任务。这个模块支持加载和使用由不同深度学习框架训练的模型,包括但不限于Caffe、TensorFlow和Torch/PyTorch等。


  1. 模型加载与推断:DNN模块可以加载预训练的深度学习模型,并使用这些模型对新数据进行推断或预测。


  1. 性能优化:OpenCV在加载模型时会使用自己的DNN模块对模型进行重写,以提高模型的运行效率。


  1. 通用性:DNN模块不局限于特定的深度学习框架,它能够处理多种框架训练出的模型,这使得开发者可以自由选择适合自己的框架进行模型训练。


  1. 实用性:DNN模块的应用非常广泛,可以用于实时目标检测等复杂的计算机视觉任务。例如,可以使用Caffe框架下的MobileNet-SSD模型进行高效的目标检测。


dnn.blobFromImage


  • 根据输入图像,创建维度N,通道数C,高H和宽W次序的blobs


blobFromImage(image, 
                  scalefactor=None, 
                  size=None, 
                  mean=None, 
                  swapRB=None, 
                  crop=None, 
                  ddepth=None):


dnn.NMSBoxes


根据给定的检测boxes和对应的scores进行NMS(非极大值抑制)处理


NMSBoxes(bboxes, 
             scores, 
             score_threshold, 
             nms_threshold, 
             eta=None, 
             top_k=None)


dnn.readNet


加载深度学习网络及其模型参数


readNet(model, config=None, framework=None)
相关文章
|
3天前
|
算法 安全 数据安全/隐私保护
Crypto++库支持多种加密算法
【10月更文挑战第29天】Crypto++库支持多种加密算法
17 4
|
4月前
|
机器学习/深度学习 人工智能 算法
Python在计算机视觉(CV)中扮演重要角色,得益于其丰富的库如OpenCV、Pillow和Scikit-image。
【7月更文挑战第5天】Python在计算机视觉(CV)中扮演重要角色,得益于其丰富的库如OpenCV、Pillow和Scikit-image。CV涉及图像处理、模式识别和机器学习,用于图像理解和生成。Python的跨平台特性和活跃社区使其成为CV的理想工具。基本流程包括图像获取、预处理、特征提取、分类识别及图像生成。例如,面部识别通过预处理图像,使用如`cv2.CascadeClassifier`进行检测;物体检测类似,但需适应不同目标;图像生成则利用GAN创造新图像。
63 4
|
2月前
|
存储 算法 安全
超级好用的C++实用库之sha256算法
超级好用的C++实用库之sha256算法
72 1
|
24天前
|
算法 计算机视觉 Python
圆形检测算法-基于颜色和形状(opencv)
该代码实现了一个圆检测算法,用于识别视频中的红色、白色和蓝色圆形。通过将图像从RGB转换为HSV颜色空间,并设置对应颜色的阈值范围,提取出目标颜色的区域。接着对这些区域进行轮廓提取和面积筛选,使用霍夫圆变换检测圆形,并在原图上绘制检测结果。
62 0
|
2月前
|
存储 计算机视觉 C++
在C++中实现Armadillo库与OpenCV库之间的数据格式转换
在C++中实现Armadillo库与OpenCV库之间的数据格式转换是一项常见且实用的技能。上述步骤提供了一种标准的方法来进行这种转换,可以帮助开发者在两个库之间高效地转移和处理数据。虽然转换过程相对直接,但开发者应留意数据类型匹配和性能优化等关键细节。
60 11
|
2月前
|
存储 计算机视觉 C++
在C++中实现Armadillo库与OpenCV库之间的数据格式转换
在C++中实现Armadillo库与OpenCV库之间的数据格式转换是一项常见且实用的技能。上述步骤提供了一种标准的方法来进行这种转换,可以帮助开发者在两个库之间高效地转移和处理数据。虽然转换过程相对直接,但开发者应留意数据类型匹配和性能优化等关键细节。
23 3
|
2月前
|
存储 算法 安全
超级好用的C++实用库之国密sm4算法
超级好用的C++实用库之国密sm4算法
49 0
|
2月前
|
算法 安全 Serverless
超级好用的C++实用库之国密sm3算法
超级好用的C++实用库之国密sm3算法
41 0
|
2月前
|
算法 数据安全/隐私保护 C++
超级好用的C++实用库之MD5信息摘要算法
超级好用的C++实用库之MD5信息摘要算法
59 0
|
3月前
|
算法 定位技术 vr&ar
一文了解PnP算法,python opencv中的cv2.solvePnP()的使用,以及使用cv2.sovlePnP()方法标定相机和2D激光雷达
一文了解PnP算法,python opencv中的cv2.solvePnP()的使用,以及使用cv2.sovlePnP()方法标定相机和2D激光雷达
416 0
一文了解PnP算法,python opencv中的cv2.solvePnP()的使用,以及使用cv2.sovlePnP()方法标定相机和2D激光雷达