Python-OpenCV单通道加噪(cv2.split通道分离+skimage+cv2.merge通道合并)

单通道加噪声实现过程

代码流程

  1. 使用opencv函数split,分割通道;
  2. 使用skimage的random_noise函数对某通道加噪声;
  3. 使用opencv函数merge ,合并通道

代码示范

def addNoiseByChannel(img_path):
    origin_img = cv2.imread(img_path)   # BGR
    # 分割通道
    (b, g, r) = cv2.split(origin_img)
    # 或者只需要取某个单独通道
    # b = cv2.split(origin_img)[0]
    # g = cv2.split(origin_img)[1]
    # g = cv2.split(origin_img)[2]

    # add gaussian noise in channel blue only 
    b_noise_img = skimage.util.random_noise(b, mode='gaussian', seed=None, clip=True)
    cv2.namedWindow('noise_img')
    cv2.imshow('b',b)
    cv2.imshow('b_noise_img',b_noise_img)
    # 在 skimage.util.random_noise中, 图像将会被转换为float64类型的
    # 因此在合并的时候,g和r通道的图像也应该转换为float64类型的,才能成功合并通道
    g = skimage.util.img_as_float(g)
    cv2.imshow('g',g)
    r = skimage.util.img_as_float(r)
    cv2.imshow('r',r)
    # print b_noise_img.dtype, g.dtype, r.dtype
    # 合并通道
    noise_img = cv2.merge([b_noise_img, g, r])
    cv2.imshow('noise_img',noise_img)
    cv2.waitKey()
    cv2.destroyAllWindows()

图示

  1. 原图:

timg

2.分割通道后图像:

B:
timg_b

G:
timg_g

R:
timg_r

3.b通道加上gaussian noise:

timg_b_noise

4.合并后 :

原图对比:

timg

合并后:

timg_noise

似乎看起来没什么不同,将合并后的图像,再把它的blue channel分割出来:

split_b_of_merge = cv2.split(noise_img)[0]

图示:

timg_split_b_of_merge

可以看出,在blue channel上确实加了噪声的!

另外,可以看出,cv2.split()函数分离得到各个通道的灰度值(单通道图像)。cv2.merge()函数是合并单通道成多通道(不能合并多个多通道图像)。而在cv2.split()分离出的图像基础上,扩展另外两个通道,但另外两个通道值为0, 就可以得到下面这样的图像。

代码如下:

origin_img = cv2.imread(img_path)   # BGR
(b, g, r) = cv2.split(origin_img)

zeros = np.zeros(origin_img.shape[:2], dtype = "uint8")
cv2.imshow("Blue", cv2.merge([b, zeros, zeros]))
cv2.imshow("Green", cv2.merge([zeros, g, zeros]))
cv2.imshow("Red", cv2.merge([zeros, zeros, r]))
cv2.waitKey()
cv2.destroyAllWindows()

Blue channel:
timg_blue

Green channel:
timg_green

Red channel:

timg_red

  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: `cv2.split()`是OpenCV中的一个函数,用于将一张图片分割成三个通道(B,G,R)的图像。该函数的语法格式如下: ```python b, g, r = cv2.split(img) ``` 其中,`img`是要分割的图像,`b`、`g`、`r`分别是分割后的三个通道图像。该函数返回一个包含三个分割后图像的元组。例如,可以使用以下代码将一张彩色图像分割成三个通道图像: ```python import cv2 img = cv2.imread("test.jpg") b, g, r = cv2.split(img) cv2.imshow("Blue Channel", b) cv2.imshow("Green Channel", g) cv2.imshow("Red Channel", r) cv2.waitKey(0) cv2.destroyAllWindows() ``` 这段代码会显示分割后的三个通道图像,分别是蓝色通道、绿色通道和红色通道图像。 ### 回答2: cv2.split函数是OpenCV库中用于将图像分割为多个颜色通道的函数。该函数可以将三通道的彩色图像分割为三个单独的颜色通道,分别是蓝色通道、绿色通道和红色通道。其语法格式为:dst = cv2.split(src)。 其中,dst是一个包含了三个颜色通道的列表,每个通道都是一个独立的numpy数组。src是一个三通道的彩色图像。 这个函数的作用是方便用户对每个颜色通道进行独立的处理和分析。例如,可以使用cv2.split来获取图像的红色通道,并对其进行亮度调整或者滤波操作。同时,也可以对图像的蓝色通道进行处理,例如调整对比度或者进行图像增强。 使用cv2.split函数,可以将图像的各个颜色通道分别提取出来,得到独立的通道数据,可以更方便地进行后续处理和分析。 ### 回答3: cv2.split() 是 OpenCV 库中的一个函数,用于将一个多通道图像分割成多个单通道图像。 函数的语法是:cv2.split(img) 其中,img 是待分割的多通道图像。 函数的返回值是一个包含各个通道图像的列表。列表的长度与图像通道数相等,每个元素都是一个单通道图像。 使用 cv2.split() 的优点是可以方便地访问和处理图像的各个通道。例如,可以对每个通道进行独立的图像处理操作,然后再将处理后的图像合并成多通道图像。 下面是一个示例代码: import cv2 # 读取多通道图像 img = cv2.imread('image.png') # 分割图像 channels = cv2.split(img) # 分别操作各个通道 for i in range(len(channels)): # 获取当前通道图像 channel = channels[i] # 对当前通道图像进行处理,例如增加对比度 # ... # 合并各个通道 result = cv2.merge(channels) # 显示结果图像 cv2.imshow('Result', result) cv2.waitKey(0) cv2.destroyAllWindows() 总之,cv2.split() 是一个非常有用的函数,可以方便地对多通道图像进行分割和处理。通过分割图像,可以对各个通道进行独立的操作,从而实现更加灵活和精细的图像处理

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值