前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >OpenCV-Python中没有Mat.convertTo函数怎么办?

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

作者头像
OpenCV学堂
发布2022-07-06 18:41:17
1.7K0
发布2022-07-06 18:41:17
举报

点击上方蓝字关注我们

微信公众号:OpenCV学堂 关注获取更多计算机视觉与深度学习知识

函数说明

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

其中参数alpha可以让数据放缩到指定的范围内,比如从字节到浮点数类型

代码语言:javascript
复制
CV_8U 转换为CV_32Falpha=1.0/255.0时表示从0~255切换到0~1之间

浮点数类型到字节类型

代码语言:javascript
复制
CV_32F 转换为CV_8Ualpha=255时表示从0~1切换到0~255之间

同时该函数还有另外一个功能就是对超过范围的数据进行最大最小极限取值,低于0的取值0,大于255取值255。

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

C++/Python对比

对一张输入图像完成Sobel滤波操作,C++实现的代码如下:

代码语言:javascript
复制
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对应的代码如下:

代码语言:javascript
复制
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做归一化然后再显示

这个时候只需添加一行代码即可获得正确结果,把代码:

代码语言:javascript
复制
m2 = np.uint8(gradx * 255)

替换为:

代码语言:javascript
复制
cv.normalize(gradx, gradx, 0, 1.0, cv.NORM_MINMAX)m2 = np.uint8(gradx * 255)

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

但是实际结果与C++并不一致,这个时候正确修改方式如下:

代码语言:javascript
复制
m2 = np.uint8(gradx * 255)

替换为:

代码语言:javascript
复制
m2 = np.uint8(np.clip(gradx * 255, 0, 255))

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

Python版本结果跟C++保持一致了!这个很多书上跟博文并没有人提到,所以我写出来分享一下,这个技术细节点!

扫码查看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推理

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-07-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 OpenCV学堂 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
人脸识别
腾讯云神图·人脸识别(Face Recognition)基于腾讯优图强大的面部分析技术,提供包括人脸检测与分析、比对、搜索、验证、五官定位、活体检测等多种功能,为开发者和企业提供高性能高可用的人脸识别服务。 可应用于在线娱乐、在线身份认证等多种应用场景,充分满足各行业客户的人脸属性识别及用户身份确认等需求。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档