mosaic.py 4.2 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
def addmosaic_autosize(img,mask,model,area_type = 'normal'):
H
hypox64 已提交
59 60 61 62
    h,w = img.shape[:2]
    mask = cv2.resize(mask,(w,h))
    alpha = np.min((w,h))/512
    try:
H
hypox64 已提交
63 64 65 66 67
        if area_type == 'normal':
            area = mask_area(mask)
        elif area_type == 'bounding':
            w,h = cv2.boundingRect(mask)[2:]
            area = w*h
H
hypox64 已提交
68 69 70 71 72 73 74 75 76 77 78
    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 已提交
79
    else:
H
hypox64 已提交
80 81
        pass
    return img_mosaic
HypoX64's avatar
preview  
HypoX64 已提交
82

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

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