打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
OpenCV-Python中没有Mat.convertTo函数怎么办?

重磅干货,第一时间送达

微信公众号:OpenCV学堂

函数说明

OpenCV C++的图像对象Mat有一个函数convertTo可以把图像数据在不同的精度类型之间来回切换比如从字节到浮点数之间来回切换。非常方便,该函数的官方说明如下:

其中参数alpha可以让数据放缩到指定的范围内,比如从字节到浮点数类型
CV_8U 转换为CV_32Falpha=1.0/255.0时表示从0~255切换到0~1之间
浮点数类型到字节类型
CV_32F 转换为CV_8Ualpha=255时表示从0~1切换到0~255之间
同时该函数还有另外一个功能就是对超过范围的数据进行最大最小极限取值,低于0的取值0,大于255取值255。

但是到了Python中之后,很多人就会认为convertTo函数只是一个数据精度类型转换函数,不会太过关心细节,然后直接使用它。这样的结果往往导致一些细数据差异跟输出不一致问题出现。

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, -110);
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, -110);
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))

然后再次运行,截图如下:

Python版本结果跟C++保持一致了!这个很多书上跟博文并没有人提到,所以我写出来分享一下,这个技术细节点!
下载1:OpenCV-Contrib扩展模块中文版教程
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
OpenCV-图像漫画效果
使用openCV与C++求图片特征值及特征向量并进行图片处理
OpenCV实战(1)
OpenCV
每个cver都应该知道的十大OpenCV函数
【图像处理】OpenCV+Python图像处理入门教程(三)色彩空间
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服