深度学习-数据增强.py

import cv2
import numpy as np
import os.path
import shutil


#椒盐噪声
def SaltAndPepper(src, percetage):
    SP_NoiseImg = src.copy()
    SP_NoiseNum = int(percetage * src.shape[0] * src.shape[1])
    for i in range(SP_NoiseNum):
        randR = np.random.randint(0, src.shape[0] - 1)
        randG = np.random.randint(0, src.shape[1] - 1)
        randB = np.random.randint(0, 3)
        if np.random.randint(0, 1) == 0:
            SP_NoiseImg[randR, randG, randB] = 0
        else:
            SP_NoiseImg[randR, randG, randB] = 255
    return SP_NoiseImg


# 高斯噪声
def addGaussianNoise(image, percetage):
    G_Noiseimg = image.copy()
    w = image.shape[1]
    h = image.shape[0]
    G_NoiseNum = int(percetage * image.shape[0] * image.shape[1])
    for i in range(G_NoiseNum):
        temp_x = np.random.randint(0, h)
        temp_y = np.random.randint(0, w)
        G_Noiseimg[temp_x][temp_y][np.random.randint(3)] = np.random.randn(1)[0]
    return G_Noiseimg


# 亮度
def brightness(image, percetage):
    image_copy = image.copy()
    w = image.shape[1]
    h = image.shape[0]
    # get brighter
    for xi in range(0, w):
        for xj in range(0, h):
            image_copy[xj, xi, 0] = np.clip(int(image[xj, xi, 0] * percetage), a_max=255, a_min=0)
            image_copy[xj, xi, 1] = np.clip(int(image[xj, xi, 1] * percetage), a_max=255, a_min=0)
            image_copy[xj, xi, 2] = np.clip(int(image[xj, xi, 2] * percetage), a_max=255, a_min=0)
    return image_copy


if __name__ == '__main__':
    # 图片文件夹路径
    input_jpg = 'D:/copy/1'
    input_xml = 'D:/copy/1_xml'
    output_jpg = 'D:/copy/new'
    output_xml = 'D:/copy/new_xml'

    for img_name in os.listdir(input_jpg):
        name = img_name.split('.')[0]
        print(name)
        print(img_name)
        img_path = os.path.join(input_jpg, img_name)
        img = cv2.imread(img_path)
        xml_src_path = os.path.join(input_xml, name + '.xml')
        xml_dst_path = os.path.join(output_xml, name)

        # 增加噪声
        img_gauss = addGaussianNoise(img, 0.3)
        cv2.imwrite(os.path.join(output_jpg, name + '_noise.jpg'), img_gauss)
        shutil.copyfile(xml_src_path, xml_dst_path + '_noise.xml')
        print("Save " + os.path.join(output_jpg, name + '_noise.jpg') + " Successfully!")

        # 变暗
        img_darker = brightness(img, 0.6)
        cv2.imwrite(os.path.join(output_jpg, name + '_darker.jpg'), img_darker)
        shutil.copyfile(xml_src_path, xml_dst_path + '_darker.xml')
        print("Save " + os.path.join(output_jpg, name + '_darker.jpg') + " Successfully!")

        # 变亮
        img_brighter = brightness(img, 1.5)
        cv2.imwrite(os.path.join(output_jpg, name + '_brighter.jpg'), img_brighter)
        shutil.copyfile(xml_src_path, xml_dst_path + '_brighter.xml')
        print("Save " + os.path.join(output_jpg, name + '_brighter.jpg') + " Successfully!")

        blur = cv2.GaussianBlur(img, (7, 7), 1.5)
        #      cv2.GaussianBlur(图像,卷积核,标准差)
        cv2.imwrite(os.path.join(output_jpg, name + '_blur.jpg'), blur)
        shutil.copyfile(xml_src_path, xml_dst_path + '_blur.xml')
        print("Save " + os.path.join(output_jpg, name + '_blur.jpg') + " Successfully!")

  • 6
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值