fanfuhan OpenCV 教學030 ~ opencv-030-自定義濾波器

fanfuhan OpenCV 教學030 ~ opencv-030-自定義濾波器

fanfuhan OpenCV 教學030 ~ opencv-030-自定義濾波器


資料來源: https://fanfuhan.github.io/

https://fanfuhan.github.io/2019/04/09/opencv-030/

GITHUB:https://github.com/jash-git/fanfuhan_ML_OpenCV


圖像卷積最主要功能有圖像模糊、銳化、梯度邊緣等,前面已經分享圖像卷積模糊的相關知識點,OpenCV除了支持上述的捲積模糊(均值與邊緣保留)還支持自定義卷積核,實現自定義的濾波操作。

自定義卷積核常見的主要是均值、銳化、梯度等算子。


均值模糊
1,1,1
1,1,1      
1,1,1      

銳化
0,-1,0        
-1,5,-1       
0,-1,0

梯度
1,0

0,-1


C++

#include <iostream>
#include <opencv2/opencv.hpp>

using namespace std;
using namespace cv;

/*
 * 自定义滤波
 */
int main() {
    Mat src = imread("../images/test.png");
    if (src.empty()) {
        cout << "could not load image.." << endl;
    }
    imshow("input", src);

    Mat dst1, dst2, dst3;

    // 均值模糊
    Mat kernel1 = Mat::ones(5, 5, CV_32F) / (float) (25);
    filter2D(src, dst1, -1, kernel1);

    // 锐化
    Mat kernel2 = (Mat_<char>(3, 3) << 0, -1, 0,
            -1, 5, -1,
            0, -1, 0);
    filter2D(src, dst2, -1, kernel2);

    // 梯度
    Mat kernel3 = (Mat_<int>(2, 2) << 1, 0, 0, -1);
    filter2D(src, dst3, CV_32F, kernel3);
    convertScaleAbs(dst3, dst3);  // 转换为字节类型,非常重要

    imshow("blur=5x5", dst1);
    imshow("shape=3x3", dst2);
    imshow("gradient=2x2", dst3);

    waitKey(0);
    return 0;
}

Python

import cv2 as cv
import numpy as np

src = cv.imread("D:/images/test.png")
cv.namedWindow("input", cv.WINDOW_AUTOSIZE)
cv.imshow("input", src)

blur_op = np.ones([5, 5], dtype=np.float32)/25.
shape_op = np.array([[0, -1, 0],
                   [-1, 5, -1],
                   [0, -1, 0]], np.float32)
grad_op = np.array([[1, 0],[0, -1]], dtype=np.float32)

dst1 = cv.filter2D(src, -1, blur_op)
dst2 = cv.filter2D(src, -1, shape_op)
dst3 = cv.filter2D(src, cv.CV_32F, grad_op)
dst3 = cv.convertScaleAbs(dst3)

cv.imshow("blur=5x5", dst1);
cv.imshow("shape=3x3", dst2);
cv.imshow("gradient=2x2", dst3);

cv.waitKey(0)
cv.destroyAllWindows()

發表迴響

你的電子郵件位址並不會被公開。 必要欄位標記為 *