CV2对图像做渐变模糊

一段小代码,供参考,在CV2中做一些边缘渐变的功能。
主要流程:

  1. 生成一个随机的mask,并归一化,使其作为另一张图片的权重。
  2. 对mask做高斯模糊,实现边缘渐变。
  3. 将加权mask与原始图片相乘。

在这里插入图片描述

import os
import cv2
import glob
import random
import numpy as np

class FakeMask:
    def __init__(self, prop=0.99):
        self.prop = prop  # 做数据增强的概率

    # 获取一个随机的mask,归一化后作为权重。
    def _get_random_mask(self, angle=np.random.randint(45, 80), center=None, scale=1.3):
        height = 100
        width = 100
        image = np.ones((height, width, 3), dtype=np.float32) * 255
        (h, w) = image.shape[:2]
        if center is None:
            center = (w // 2, h // 2)
        M = cv2.getRotationMatrix2D(center, angle, scale)
        h = int(random.randint(12, 18) * h * 0.1)
        random_mask = cv2.warpAffine(image, M, (h, int(w * 1)))
        # random horizontal flip
        if random.random() > 0.5:
            random_mask = cv2.flip(random_mask, 1)
        random_mask = random_mask / 255
        return random_mask

    # 对mask进行高斯模糊,使其边缘渐变
    def _encode_mask(self, mask, imgw, imgh):
        kh = imgh // 8  # 高斯核越小,mask边缘越明显
        kw = imgw // 8
        kh = kh + 1 if kh % 2 == 0 else kh
        kw = kw + 1 if kw % 2 == 0 else kw
        mask = cv2.GaussianBlur(mask, (kw, kh), 0)  # 对mask进行高斯模糊,
        mask = cv2.GaussianBlur(mask, (kw, kh), 0)
        mask = cv2.resize(mask, (imgw, imgh))
        return mask

    # 数据增强
    def transform(self, img):
        if random.random() < self.prop:
            imgh, imgw, _ = img.shape
            random_mask = self._get_random_mask()
            random_mask = self._encode_mask(random_mask, imgw, imgh)
            for _ in range(2):
                img = img * random_mask
        return img

if __name__ == "__main__":
    imgs_dir = "/data1/gy77/code/demo/aug/imgs"
    save_dir = "/data1/gy77/code/demo/aug/imgs_aug"
    fake_mask = FakeMask()
    imgs_path = glob.glob(imgs_dir + "/*.jpg")
    for img_path in imgs_path:
        img_basename = os.path.basename(img_path)
        img_savepath = os.path.join(save_dir, img_basename)
        imgcv = cv2.imread(img_path)
        imgcv = fake_mask.transform(imgcv)
        cv2.imwrite(img_savepath, imgcv)

当然了,你可以微调上面参数,实现更丰富的效果。例如:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

gy-7

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

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

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

打赏作者

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

抵扣说明:

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

余额充值