微信公众号:OpenCV学堂
关注获取更多计算机视觉与深度学习知识
函数说明
CV_8U 转换为CV_32F
alpha=1.0/255.0时表示从0~255切换到0~1之间
CV_32F 转换为CV_8U
alpha=255时表示从0~1切换到0~255之间
C++/Python对比
对一张输入图像完成Sobel滤波操作,C++实现的代码如下:
Mat image = imread("D:/images/dannis1.png", IMREAD_GRAYSCALE);
imshow("input", image);
Mat m1, m2;
image.convertTo(m1, CV_32F, 1.0 / 255.0);
Mat gradx;
Sobel(m1, gradx, -1, 1, 0);
gradx.convertTo(m2, CV_8U, 255);
imshow("sobel", m2);
运行结果如下:
Python对应的代码如下:
import cv2 as cv
import numpy as np
image = cv.imread("D:/images/dannis1.png", cv.IMREAD_GRAYSCALE)
cv.imshow("input", image)
m1 = np.float32(image) / np.float(255)
gradx = cv.Sobel(m1, -1, 1, 0);
m2 = np.uint8(gradx * 255)
cv.imshow("sobel", m2)
cv.waitKey(0)
cv.destroyAllWindows()
运行结果如下:
以往的经验处理方式是先对gradx做归一化然后再显示
这个时候只需添加一行代码即可获得正确结果,把代码:
m2 = np.uint8(gradx * 255)
替换为:
cv.normalize(gradx, gradx, 0, 1.0, cv.NORM_MINMAX)
m2 = np.uint8(gradx * 255)
然后再次运行,截图如下:
但是实际结果与C++并不一致,这个时候正确修改方式如下:
m2 = np.uint8(gradx * 255)
替换为:
m2 = np.uint8(np.clip(gradx * 255, 0, 255))
然后再次运行,截图如下:
扫码查看OpenCV+OpenVIO+Pytorch系统化学习路线图
推荐阅读
CV全栈开发者说 - 从传统算法到深度学习怎么修炼
2022入坑深度学习,我选择Pytorch框架!
Pytorch轻松实现经典视觉任务
教程推荐 | Pytorch框架CV开发-从入门到实战
OpenCV4 C++学习 必备基础语法知识三
OpenCV4 C++学习 必备基础语法知识二
OpenCV4.5.4 人脸检测+五点landmark新功能测试
OpenCV4.5.4人脸识别详解与代码演示
OpenCV二值图象分析之Blob分析找圆
OpenCV4.5.x DNN + YOLOv5 C++推理
OpenCV4.5.4 直接支持YOLOv5 6.1版本模型推理
OpenVINO2021.4+YOLOX目标检测模型部署测试
比YOLOv5还厉害的YOLOX来了,官方支持OpenVINO推理