如何使用 OpenCV 将偏导数高斯核应用于图像?

Bap*_*cht 6 opencv gaussian derivative

我正在尝试重现一篇论文的结果,其中他们将图像与高斯核的水平偏导数进行卷积。我还没有找到任何方法可以用 OpenCV 来实现这一点。那可能吗 ?

我是否必须获得高斯滤波器,然后手动计算偏导数?

Joã*_*cho 5

正如 @akarsakov 所说,OpenCV 没有为此提供内置函数。然而,我们仍然可以使用 OpenCV getGaussianKernel(),然后应用一个因子来获得导数。

由于高斯 2D 内核是可分离的,因此该函数将简单地返回一个 1D 内核,并假设您将沿 x 轴应用 1D 滤波器,然后沿 y 轴应用 1D 滤波器,这比应用 2D 内核更快直接地。

由于您想要水平高斯导数,ref

在此输入图像描述

您可以简单地乘以-x/sigma^2内核的每个点。

import cv2
import numpy as np
import matplotlib.pyplot as plt

kernel_size = 13
sigma = 0.5
kernel = cv2.getGaussianKernel(kernel_size, sigma, cv2.CV_64F)
print(kernel)

gaussian_first_deriv_x = np.zeros_like(kernel)
assert(kernel_size % 2 == 1) # I assume you are using an odd kernel_size
half_kernel_size = int(kernel_size / 2)
for i in range(kernel_size):
    x = - half_kernel_size + i
    factor = - x/ (sigma**2)
    gaussian_first_deriv_x[i] = kernel[i] * factor

print(gaussian_first_deriv_x)

plt.plot(kernel[:], 'b')
plt.plot(gaussian_first_deriv_x[:], 'r')
plt.show()
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

现在,您可以使用该内核进行卷积。

注意:如果您使用的是 Python,您也可以ndimage.gaussian_filter1d(data, sigma=1, order=1, mode='wrap')使用from scipy import ndimage.

OpenCV 默认使用以下内容:sigma = 0.3 * (kernel_size / 2.0 - 1) + 0.8.


aka*_*kov 4

OpenCV没有内置函数来计算高斯偏导数。但您可以使用cv::getGaussianKernelcv::filter2D来这样做。

例如:

  cv::Mat kernel = cv::getGaussianKernel(3, 0.85, CV_32F);
  kernel = kernel.reshape(1, 1);
  cv::filter2D(img, img, CV_8U, kernel);
Run Code Online (Sandbox Code Playgroud)

请注意,cv::getGaussianKernel返回列过滤器,因此您需要reshape使其水平。

  • @akarsakov 这些代码行实现了与高斯核或其导数的卷积?好像是前者 (5认同)