批量数据增强(扩充):目标检测系列(2)亮度、色域、对比度、噪声

简述

1.亮度

1)效果

原图:
原图
降低亮度后:
在这里插入图片描述

2)代码分析

1.导入图片和标注文件路径

imgs_p="../aug_test_dataset/imgs/"
anns_p="../aug_test_dataset/anns/"
imgs_save_p="../aug_test_dataset/imgs_ed/"
anns_save_p="../aug_test_dataset/anns_ed/"

2.初始化(读取)

a, b = os.path.splitext(i)  #.splitext方法将文件路径以.分隔开
    img = cv2.imread(imgs_p + a + '.jpg')
    tree = ET.parse(anns_p + a + '.xml')
    root = tree.getroot()
    flag = 1.4 # 将图像调暗,大于1为暗,小于1为亮

3.调用函数降低亮度

    img = exposure.adjust_gamma(img, flag)

4.批量保存

    cv2.imwrite(imgs_save_p + a + '_' + 'lit_d' + '.jpg',img)
    tree.write(anns_save_p + a + '_'+ 'lit_d' +'.xml')

3)源码

import glob
import xml.dom.minidom
import cv2
import os,sys
import numpy as np
import random
from skimage.util import random_noise
import xml.etree.ElementTree as ET
from skimage import exposure

imgs_p="../aug_test_dataset/imgs/"
anns_p="../aug_test_dataset/anns/"
imgs_save_p="../aug_test_dataset/imgs_ed/"
anns_save_p="../aug_test_dataset/anns_ed/"

for i in os.listdir(imgs_p):
    a, b = os.path.splitext(i)
    img = cv2.imread(imgs_p + a + '.jpg')
    tree = ET.parse(anns_p + a + '.xml')
    root = tree.getroot()
    flag = 1.4 # 将图像调暗,大于1为暗,小于1为亮
    
    img = exposure.adjust_gamma(img, flag)
    
    cv2.imwrite(imgs_save_p + a + '_' + 'lit_d' + '.jpg',img)
    tree.write(anns_save_p + a + '_'+ 'lit_d' +'.xml')

2.色域

1)效果

原图:
原图
更改色域后:
在这里插入图片描述

2)代码分析

1.调用函数更改图片色域(其余部分同上)

    perms = (2,1,0) # r和b通道互换
    img = img[:, :, perms]

3.对比度

1)效果

更改对比度后(调高为原来的1.5倍):
在这里插入图片描述

2)代码分析

调用函数将图像对比度调高(其余部分同上):

    alpha = 1.5
    img = img * alpha
    img = img.clip(min=0, max=255)

4.添加噪声

1)效果

添加高斯噪声后:

在这里插入图片描述

2)代码分析

其余部分同上

    img = random_noise(img, mode='gaussian', clip=True)*255

5. 源代码

源代码

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

事多做话少说

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值