opencv灰度图转彩色怎样做,有什么要注意的

Admin 2022-09-06 群英技术资讯 312 次浏览

这篇文章给大家分享的是opencv灰度图转彩色怎样做,有什么要注意的。小编觉得挺实用的,因此分享给大家做个参考,文中的介绍得很详细,而要易于理解和学习,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。


内容介绍
  • opencv灰度图和彩色图互相转换
  • 注意:
  • 附:python将灰度图转换为RGB彩色图
  • 总结

opencv灰度图和彩色图互相转换

如果摄像头本来就得到3维度红外图那就不用处理直接可以用:

import cv2
cap = cv2.VideoCapture(0)
ret, image_np = cap.read()

直接转成单通道的灰度图看看能不能用:

    #如果后面不写0,那就是默认彩色的
    # 第一种方式
    image = cv2.imread('***/timg4.jpg',0)
    #第二种方式
    #dst=cv2.cvtColor(src,cv2.COLOR_BGR2GRAY)
    detecotr = TOD()
    detecotr.detect(image)
    # 或者视频转换方式如下
    ret, image_np = cap.read()
    image_np=cv2.cvtColor(image_np,cv2.COLOR_BGR2GRAY)

上面两种方式得到的数据是不完全相同的,网上尚未查找到具体原因,通过对读取到的ndArray数据对比,发现存在不完全相同的数据。

观察直接转成1通道的图像:

直接转成了1通道灰度图喂进去神经网络不行,因为只有1通道,必须经过如下的处理;

image_np=cv2.cvtColor(image_np,cv2.COLOR_GRAY2BGR)

上面代码可以得到3通道灰度图,就是把灰度图的1通道复制三遍,然后就可以喂进网络了:

红外图像和灰度图像本身就不是在同一分类标准下得到的概念。

红外图像是红外成像设备采集目标在红外波段的辐射形成的影像,这个图像可专以是灰度图像,也可以彩色图像。同样的道理,可见光图像可以是灰度属图像,也可以彩色图像。

灰度图像是相对彩色图像而言的。灰度图像没有颜色,灰度值由0变化至255时,图像由黑变白。

再将上述的3通道灰度值转换为伪彩图,观察结果:

ret, image_np = cap.read()
image_np=cv2.cvtColor(image_np,cv2.COLOR_BGR2GRAY)
#image_np=cv2.cvtColor(image_np,cv2.COLOR_GRAY2BGR)
image_np = cv2.applyColorMap(image_np, cv2.COLORMAP_JET)

对于伪彩图有不同的伪彩图方式,各个函数如下:

# COLORMAP_AUTUMN = 0,
# COLORMAP_BONE = 1,
# COLORMAP_JET = 2,
# COLORMAP_WINTER = 3,
# COLORMAP_RAINBOW = 4,
# COLORMAP_OCEAN = 5,
# COLORMAP_SUMMER = 6,
# COLORMAP_SPRING = 7,
# COLORMAP_COOL = 8,
# COLORMAP_HSV = 9,
# COLORMAP_PINK = 10,
# COLORMAP_HOT = 11

注意:

在使用模型框架的时候,如果是使用tensorflow object detection API,需要将1通道的灰度图转成3通道(唯一通道复制三遍)来训练和检测;

为什么不直接使用者通道的灰度图来做呢,这样是不是能提高性能呢?

不是,因为这样对于提高性能和速度没有意义,它只影响了卷积神经网络的第一层而已,后续层的计算量和参数量没有丝毫影响,这样的影响等同于没有,如果真的考虑性能和速度,直接更改模型更可靠。

附:python将灰度图转换为RGB彩色图

from PIL import Image
import os

path = r'图片存储的路径'
newpath = r'转换后存储图片的路径'


def RGBtoGray(path):
    files = os.listdir(path)
    for file in files:
        imgpath = path + '/' + file
        #print(imgpath)
        #
        im = Image.open(imgpath).convert('RGB')
        #resize将图像像素转换成自己需要的像素大小
        img = im.resize((512, 512))
        dirpath = newpath
        file_name, file_extend = os.path.splitext(f)
        dst = os.path.join(os.path.abspath(dirpath), file_name + '.jpg')
        img.save(dst)
if __name__ == "__main__":
    RGBtoGray(path)

总结


以上就是关于“opencv灰度图转彩色怎样做,有什么要注意的”的介绍了,感谢各位的阅读,如果大家想要了解更多相关的内容,欢迎关注群英网络,小编每天都会为大家更新不同的知识。
群英智防CDN,智能加速解决方案
标签: opencv 灰度图

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

猜你喜欢

成为群英会员,开启智能安全云计算之旅

立即注册
专业资深工程师驻守
7X24小时快速响应
一站式无忧技术支持
免费备案服务
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
在线客服
微信公众号
返回顶部
返回顶部 返回顶部
在线客服
在线客服