mosaic.py 3.9 KB
Newer Older
HypoX64's avatar
preview  
HypoX64 已提交
1 2 3 4
import cv2
import numpy as np
import os
import random
HypoX64's avatar
HypoX64 已提交
5
from .image_processing import resize,ch_one2three,mask_area
HypoX64's avatar
preview  
HypoX64 已提交
6

H
hypox64 已提交
7 8 9 10 11 12 13 14
def addmosaic(img,mask,opt):
    if opt.mosaic_mod == 'random':
        img = addmosaic_random(img,mask)
    elif opt.mosaic_size == 0:
        img = addmosaic_autosize(img, mask, opt.mosaic_mod)
    else:
        img = addmosaic_normal(img,mask,opt.mosaic_size,opt.output_size,model = opt.mosaic_mod)
    return img
HypoX64's avatar
preview  
HypoX64 已提交
15

H
hypox64 已提交
16
def addmosaic_normal(img,mask,n,out_size = 0,model = 'squa_avg'):
H
hypox64 已提交
17
    n = int(n)
HypoX64's avatar
preview  
HypoX64 已提交
18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39
    if out_size:
        img = resize(img,out_size)      
    h, w = img.shape[:2]
    mask = cv2.resize(mask,(w,h))
    img_mosaic=img.copy()

    if model=='squa_avg':
        for i in range(int(h/n)):
            for j in range(int(w/n)):
                if mask[int(i*n+n/2),int(j*n+n/2)] == 255:
                    img_mosaic[i*n:(i+1)*n,j*n:(j+1)*n,:]=img[i*n:(i+1)*n,j*n:(j+1)*n,:].mean(0).mean(0)

    elif model == 'squa_random':
        for i in range(int(h/n)):
            for j in range(int(w/n)):
                if mask[int(i*n+n/2),int(j*n+n/2)] == 255:
                    img_mosaic[i*n:(i+1)*n,j*n:(j+1)*n,:]=img[int(i*n-n/2+n*random.random()),int(j*n-n/2+n*random.random()),:]

    elif model == 'squa_avg_circle_edge':
        for i in range(int(h/n)):
            for j in range(int(w/n)):
                img_mosaic[i*n:(i+1)*n,j*n:(j+1)*n,:]=img[i*n:(i+1)*n,j*n:(j+1)*n,:].mean(0).mean(0)
HypoX64's avatar
HypoX64 已提交
40 41
        mask = cv2.threshold(mask,127,255,cv2.THRESH_BINARY)[1]
        mask = ch_one2three(mask)
HypoX64's avatar
preview  
HypoX64 已提交
42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
        mask_inv = cv2.bitwise_not(mask)
        imgroi1 = cv2.bitwise_and(mask,img_mosaic)
        imgroi2 = cv2.bitwise_and(mask_inv,img)
        img_mosaic = cv2.add(imgroi1,imgroi2)

    elif model =='rect_avg':
        rect_ratio=1+0.6*random.random()
        n_h=n
        n_w=int(n*rect_ratio)
        for i in range(int(h/n_h)):
            for j in range(int(w/n_w)):
                if mask[int(i*n_h+n_h/2),int(j*n_w+n_w/2)] == 255:
                    img_mosaic[i*n_h:(i+1)*n_h,j*n_w:(j+1)*n_w,:]=img[i*n_h:(i+1)*n_h,j*n_w:(j+1)*n_w,:].mean(0).mean(0)
    
    return img_mosaic

H
hypox64 已提交
58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
def addmosaic_autosize(img,mask,model):
    h,w = img.shape[:2]
    mask = cv2.resize(mask,(w,h))
    alpha = np.min((w,h))/512
    try:
        area = mask_area(mask)
    except:
        area = 0
    area = area/(alpha*alpha)
    if area>50000:
        img_mosaic = addmosaic_normal(img,mask,alpha*((area-50000)/50000+16),model = model)
    elif 20000<area<=50000:
        img_mosaic = addmosaic_normal(img,mask,alpha*((area-20000)/30000+12),model = model)
    elif 5000<area<=20000:
        img_mosaic = addmosaic_normal(img,mask,alpha*((area-5000)/20000+8),model = model)
    elif 0<=area<=5000:
        img_mosaic = addmosaic_normal(img,mask,alpha*((area-0)/5000+4),model = model)
HypoX64's avatar
preview  
HypoX64 已提交
75
    else:
H
hypox64 已提交
76 77
        pass
    return img_mosaic
HypoX64's avatar
preview  
HypoX64 已提交
78

H
hypox64 已提交
79
def addmosaic_random(img,mask):
H
hypox64 已提交
80
    # img = resize(img,512)
HypoX64's avatar
preview  
HypoX64 已提交
81 82
    h,w = img.shape[:2]
    mask = cv2.resize(mask,(w,h))
H
hypox64 已提交
83
    alpha = np.min((w,h))/512
HypoX64's avatar
preview  
HypoX64 已提交
84 85
    #area_avg=5925*4
    try:
HypoX64's avatar
HypoX64 已提交
86
        area = mask_area(mask)
HypoX64's avatar
preview  
HypoX64 已提交
87 88
    except:
        area = 0
H
hypox64 已提交
89
    area = area/(alpha*alpha)
HypoX64's avatar
preview  
HypoX64 已提交
90
    if area>50000:
H
hypox64 已提交
91
        img_mosaic = random_mod(img,mask,alpha*random.uniform(16,28))
HypoX64's avatar
preview  
HypoX64 已提交
92
    elif 20000<area<=50000:
H
hypox64 已提交
93
        img_mosaic = random_mod(img,mask,alpha*random.uniform(12,20))
HypoX64's avatar
preview  
HypoX64 已提交
94
    elif 5000<area<=20000:
H
hypox64 已提交
95
        img_mosaic = random_mod(img,mask,alpha*random.uniform(8,15))
HypoX64's avatar
preview  
HypoX64 已提交
96
    elif 0<=area<=5000:
H
hypox64 已提交
97
        img_mosaic = random_mod(img,mask,alpha*random.uniform(4,10))
HypoX64's avatar
preview  
HypoX64 已提交
98 99 100
    else:
        pass
    return img_mosaic
H
hypox64 已提交
101 102 103 104 105 106 107 108 109 110 111 112

def random_mod(img,mask,n):
    ran=random.random()
    if ran < 0.1:
        img = addmosaic_normal(img,mask,n,model = 'squa_random')
    if 0.1 <= ran < 0.3:
        img = addmosaic_normal(img,mask,n,model = 'squa_avg')
    elif 0.3 <= ran <0.5:
        img = addmosaic_normal(img,mask,n,model = 'squa_avg_circle_edge')
    else:
        img = addmosaic_normal(img,mask,n,model = 'rect_avg')
    return img