人脸检测——准备非人脸


简单粗暴,不多说,直接代码吧:

import os
import random
from PIL import Image
from PIL import ImageFile
ImageFile.LOAD_TRUNCATED_IMAGES = True
import cv2
import numpy as np


def random_crop(imagepath):

    # image = Image.open(imagepath)
    # len_rand = random.randint(0, min(image.size[0], image.size[1])-1)
    # x_rand = random.randint(0, image.size[0]-len_rand-1)
    # y_rand = random.randint(0, image.size[1]-len_rand-1)
    
    image = cv2.imread(imagepath)
    len_rand = random.randint(0, min(image.shape[1], image.shape[0])-1)
    x_rand = random.randint(0, image.shape[1]-len_rand-1)
    y_rand = random.randint(0, image.shape[0]-len_rand-1)

    box = (x_rand, y_rand, x_rand+len_rand, y_rand+len_rand)
    # return image.crop(box)
    return image[box[1]:box[3], box[0]:box[2], :]


save_dir = 'data_prepare/net_negative'

if os.path.exists(save_dir)==False:
    os.makedirs(save_dir)

neg_img_dir = 'imagenet_selected'
for file in os.walk(neg_img_dir):
    filenames = file[2]

for idx, filename in enumerate(filenames):

    filepath = neg_img_dir + '/' + filename

    for i in range(33):

        image_crop = random_crop(filepath)

        savepath = save_dir + '/' + str(i) + filename

        # image_crop_12 = image_crop.resize((15,15))
        if image_crop is None:
            continue
        if image_crop.shape[0]<10 and image_crop.shape[1]<10:
            continue
        image_crop = cv2.resize(image_crop, (12, 12))  

        # image_crop_12.save(savepath, 'jpeg')
        cv2.imwrite(savepath, np.array(image_crop))

    print (idx)


如果帮到你了,请赞赏支持:


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

MachineLP

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

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

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

打赏作者

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

抵扣说明:

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

余额充值