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)
相关推荐
天天扭码4 分钟前
LeetCode 题解 | 1.两数之和(最优解)
前端·javascript·算法
亿佛8 分钟前
(Matlab)自动驾驶仿真 设计驾驶场景、配置传感器并生成合成 数据
人工智能·算法·机器学习·自动驾驶·测试用例
胡乱儿起个名24 分钟前
《高阶函数:把函数当玩具传来传去》
开发语言·c++·算法
0502081040 分钟前
各种排序算法
数据结构·算法·排序算法
不会弹吉他的布鲁克1 小时前
25 年最新大佬 Paper,Transformers再也不需要归一化,这届AI学会“自我管理”了!
算法
小美爱刷题1 小时前
力扣DAY52-54 | 热100 | 图论:腐烂的橘子、课程表、前缀树
算法·leetcode·图论
南梦也要学习2 小时前
STM32江科大----------PID算法
stm32·嵌入式硬件·算法
.普通人2 小时前
算法基础(以acwing讲述顺序为主,结合自己理解,持续更新中...)
c++·算法
brzhang2 小时前
为什么 A2A 和 MCP 缺一不可?
前端·后端·算法
strive-debug2 小时前
上篇:《排序算法的奇妙世界:如何让数据井然有序?》
数据结构·算法·排序算法