函数说明
OpenCV C++的图像对象Mat有一个函数convertTo可以把图像数据在不同的精度类型之间来回切换比如从字节到浮点数之间来回切换。非常方便,该函数的官方说明如下:其中参数alpha可以让数据放缩到指定的范围内,比如从字节到浮点数类型
浮点数类型到字节类型CV_8U 转换为CV_32F
alpha=1.0/255.0时表示从0~255切换到0~1之间
同时该函数还有另外一个功能就是对超过范围的数据进行最大最小极限取值,低于0的取值0,大于255取值255。 但是到了Python中之后,很多人就会认为convertTo函数只是一个数据精度类型转换函数,不会太过关心细节,然后直接使用它。这样的结果往往导致一些细数据差异跟输出不一致问题出现。CV_32F 转换为CV_8U
alpha=255时表示从0~1切换到0~255之间
C++/Python对比
对一张输入图像完成Sobel滤波操作,C++实现的代码如下:
Matimage=imread("D:/images/dannis1.png",IMREAD_GRAYSCALE);
imshow("input",image);
Matm1,m2;
image.convertTo(m1,CV_32F,1.0/255.0);
Matgradx;
Sobel(m1,gradx,-1,1,0);
gradx.convertTo(m2,CV_8U,255);
imshow("sobel",m2);
Python对应的代码如下:
importcv2ascv
importnumpyasnp
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))
Python版本结果跟C++保持一致了!这个很多书上跟博文并没有人提到,所以我写出来分享一下,这个技术细节点!
审核编辑:何安
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。
举报投诉
-
函数
+关注
关注
3文章
4284浏览量
62333 -
python
+关注
关注
55文章
4772浏览量
84382
原文标题:OpenCV-Python中没有Mat.convertTo函数怎么办?
文章出处:【微信号:CVSCHOOL,微信公众号:OpenCV学堂】欢迎添加关注!文章转载请注明出处。
发布评论请先 登录
相关推荐
opencv-python和opencv一样吗
不一样。OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习软件库,它提供了大量的图像和视频处理功能。OpenCV-Python
STM32MP135如何使用opencv-python或v4l2-ctl打开摄像头,并保存为图片?
行。
但是官方的例程中,直接用v4l推送到media上,直接显示的又是可以的。
请问我该如何使用opencv-python 或v4l2-ctl打开摄像头,并保存为图片?
发表于 05-30 06:16
请问STM32_ImageProcessingLibrary中有类似于opencv中的findContours函数吗?
STM32_ImageProcessingLibrary中有类似于opencv中的findContours函数吗?
发表于 03-07 07:17
python中计算排列组合的函数有哪些
在Python中,有多种可以用于计算排列组合的函数和模块。下面将详细介绍一些常用的函数和模块,并提供详实和细致的说明。 math模块:
不属于python的内置函数
Python是一种高级编程语言,它提供了许多内置函数,可以帮助开发人员更轻松地处理各种任务。但是,在Python中并非所有的函数都是内置
python中各种函数的用法
Python中有很多种不同类型的函数,它们在解决各种问题和完成不同任务时起着重要的作用。下面我将详细介绍几种常用的函数,包括内置函数、自定义函数
python调用math函数的方法
在Python编程中,数学函数是非常重要的工具,我们可以使用它们进行各种数值计算、几何运算和统计分析等操作。Python的标准库中内置了很多
python的format函数怎么用
Python中的format()函数是用于格式化字符串的内置函数。它允许我们将变量的值插入到字符串中,并对字符串进行格式化以满足特定的需求。
python函数返回多个参数
函数是程序设计中的一个重要概念,在很多编程语言中都存在。函数可以接受输入数据,并且根据输入数据进行一系列操作,最后可以返回一个或多个结果。Python是一种非常流行的编程语言,也支持
sort函数python用法
sort()函数是Python中的内置函数之一,用于对可迭代对象进行排序。可迭代对象包括列表、元组和字符串等。sort()函数是一个灵活而强
range()函数的用法是什么
range()函数是Python中的内置函数,用于生成一个整数序列,可以用于循环或创建列表。 range()函数的基本语法是: range(
python中insert函数的用法
Python中的insert()函数用于在列表中的指定位置插入元素。它的基本语法如下: list .insert(index, element) 其中,index表示要插入元素的位置,
python如何定义一个函数
一、Python3 函数 函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段。 函数能提高应用的模块性,和代码的重复利用率。你已经知道
评论