-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun.py
78 lines (55 loc) · 2.26 KB
/
run.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
import cv2
from PIL import Image
import numpy as np
import os
from animeinsseg import AnimeInsSeg, AnimeInstances
from animeinsseg.anime_instances import get_color
ckpt = r'models/AnimeInstanceSegmentation/rtmdetl_e60.ckpt'
mask_thres = 0.3
instance_thres = 0.3
refine_kwargs = {'refine_method': 'refinenet_isnet'} # set to None if not using refinenet
# refine_kwargs = None
imgp = 'examples/haruka.png'
img = cv2.imread(imgp)
img_name = os.path.basename(imgp).split('.')[0]
net = AnimeInsSeg(ckpt, mask_thr=mask_thres, refine_kwargs=refine_kwargs)
instances: AnimeInstances = net.infer(
img,
output_type='numpy',
pred_score_thr=instance_thres
)
x = 0.5 ## 取りたい画像の大きさによって変える
drawed = img.copy()
im_h, im_w = img.shape[:2]
img_with_alpha = cv2.cvtColor(img, cv2.COLOR_BGR2BGRA)
# instances.bboxes, instances.masks will be None, None if no obj is detected
nb_object = len(list(zip(instances.bboxes, instances.masks)))
for ii, (xywh, mask) in enumerate(zip(instances.bboxes, instances.masks)):
print(ii)
color = get_color(ii)
mask_alpha = 0.5
linewidth = max(round(sum(img.shape) / 2 * 0.003), 2)
# draw bbox
p1, p2 = (int(xywh[0]), int(xywh[1])), (int(xywh[2] + xywh[0]), int(xywh[3] + xywh[1]))
# cv2.rectangle(drawed, p1, p2, color, thickness=linewidth, lineType=cv2.LINE_AA)
threshold_w = x * (int(im_w)/nb_object)
threshold_h = x * (int(im_h)/nb_object)
if int(xywh[2]) < threshold_w and int(xywh[3]) < threshold_h:
print("too small")
continue
## draw mask and cutout
mask_uint8 = mask.astype(np.uint8) * 255
# masked_img = cv2.bitwise_and(img, img, mask = mask)##アルファチャンネル使わないときはこれ
img_with_alpha[:, :, 3] = mask_uint8
cv2.imwrite(f'output_images/masked_seg_{ii}_{img_name}.png', img_with_alpha)
# draw mask
p = mask.astype(np.float32)
blend_mask = np.full((im_h, im_w, 3), color, dtype=np.float32)
alpha_msk = (mask_alpha * p)[..., None]
alpha_ori = 1 - alpha_msk
drawed = drawed * alpha_ori + alpha_msk * blend_mask
###元実装
drawed = drawed.astype(np.uint8)
# Image.fromarray(drawed[..., ::-1]).show()
# # save
Image.fromarray(drawed[..., ::-1]).save(f'output_images/seg_{img_name}.png')