OpenCV算法库

numba

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

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

numba的使用方法

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

python 复制代码
from numba import jit
@jit
def f(a, b):
    return a + b

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

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

python 复制代码
from math import sqrt
@jit
def hypot(a, b):
    return sqrt(square(a) + square(b))
python 复制代码
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加速

python 复制代码
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中可直接进行图像的平移。

python 复制代码
translated = imutils.translate(img,x,y)
  • img:要移动的图像
  • x:沿x轴方向移动的像素个数
  • y: 沿y轴方向移动的像素个数

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

python 复制代码
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()

图像旋转

python 复制代码
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),越小需要处理的时间越长。

python 复制代码
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模块可以加载预训练的深度学习模型,并使用这些模型对新数据进行推断或预测。
  2. 性能优化:OpenCV在加载模型时会使用自己的DNN模块对模型进行重写,以提高模型的运行效率。
  3. 通用性:DNN模块不局限于特定的深度学习框架,它能够处理多种框架训练出的模型,这使得开发者可以自由选择适合自己的框架进行模型训练。
  4. 实用性: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

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

python 复制代码
readNet(model, config=None, framework=None)
相关推荐
hsling松子1 小时前
使用PaddleHub智能生成,献上浓情国庆福
人工智能·算法·机器学习·语言模型·paddlepaddle
dengqingrui1232 小时前
【树形DP】AT_dp_p Independent Set 题解
c++·学习·算法·深度优先·图论·dp
C++忠实粉丝2 小时前
前缀和(8)_矩阵区域和
数据结构·c++·线性代数·算法·矩阵
ZZZ_O^O2 小时前
二分查找算法——寻找旋转排序数组中的最小值&点名
数据结构·c++·学习·算法·二叉树
CV-King3 小时前
opencv实战项目(三十):使用傅里叶变换进行图像边缘检测
人工智能·opencv·算法·计算机视觉
代码雕刻家3 小时前
数据结构-3.9.栈在递归中的应用
c语言·数据结构·算法
雨中rain3 小时前
算法 | 位运算(哈希思想)
算法
jndingxin5 小时前
OpenCV视频I/O(14)创建和写入视频文件的类:VideoWriter介绍
人工智能·opencv·音视频
Kalika0-05 小时前
猴子吃桃-C语言
c语言·开发语言·数据结构·算法
sp_fyf_20245 小时前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-02
人工智能·神经网络·算法·计算机视觉·语言模型·自然语言处理·数据挖掘