-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathcomp_inpaint.py
90 lines (69 loc) · 3.31 KB
/
comp_inpaint.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
79
80
81
82
83
84
85
86
87
88
89
90
import torch
import PIL.Image as Image
from diffusers import DDIMScheduler, DDIMInverseScheduler
from diffusers import StableDiffusionInstructPix2PixPipeline
from diffusers import StableDiffusionInpaintPipeline
import PIL.Image as Image
from diffusers.utils import pt_to_pil, numpy_to_pil
import numpy as np
import argparse
import os
import copy
def arguments():
parser = argparse.ArgumentParser()
parser.add_argument('--input_image', type=str, default=None)
parser.add_argument('--results_folder', type=str, default=None)
parser.add_argument('--results_folder_edit', type=str, default=None)
parser.add_argument('--seg_dirs', type=str, default=None)
parser.add_argument('--num_ddim_steps', type=int, default=50)
parser.add_argument('--model_path', type=str, default='runwayml/stable-diffusion-inpainting')
parser.add_argument('--use_float_16', action='store_true')
parser.add_argument('--prompt_str', type=str, default=None)
parser.add_argument('--prompt_file', type=str, default=None)
parser.add_argument('--original_words', nargs='+', type=str, default=None)
parser.add_argument('--replace_words', nargs='+', type=str, default=None)
args = parser.parse_args()
return args
if __name__=="__main__":
args = arguments()
print(args)
torch_dtype = torch.float32
pipe = StableDiffusionInpaintPipeline.from_pretrained(
"runwayml/stable-diffusion-inpainting", torch_dtype=torch.float16
)
pipe.enable_model_cpu_offload()
# pipe = pipe.to("cuda")
generator = torch.manual_seed(0)
raw_image = Image.open(args.input_image).convert("RGB").resize((512,512))
args.prompt_file=os.path.join(args.results_folder, f"prompt.txt")
if os.path.isfile(args.prompt_file):
caption_list = open(args.prompt_file).read().strip().split(' ')
caption=' '.join(caption_list)
### NOTE: get the edit caption
if args.original_words is not None:
edit_caption_list=copy.deepcopy(caption_list)
print('replace the old word with new word')
for replace_id in range(len(args.original_words)):
org_word = args.original_words[replace_id]
if org_word in caption_list:
org_word_id = caption_list.index(org_word)
else:
continue
edit_caption_list[org_word_id] = args.replace_words[replace_id]
edit_caption=' '.join(edit_caption_list)
else:
raise NotImplementedError
### NOTE: read the mask image
object_name = args.original_words[0]
if os.path.isfile(os.path.join(args.seg_dirs, f"{object_name}.png")):
seg_image_path = os.path.join(args.seg_dirs, f"{object_name}.png")
else:
seg_image_path = os.path.join(args.seg_dirs, f"{object_name}.jpg")
seg_image = Image.open(seg_image_path).resize((512,512))
print(f'read segmentation map from {seg_image_path}')
prompt=f"{args.replace_words[0]}"
generator = torch.manual_seed(0)
image = pipe(prompt=prompt, image=raw_image, mask_image=seg_image, generator=generator).images[0]
method_name='inpaint'
os.makedirs(f'{args.results_folder_edit}/{method_name}/', exist_ok=True)
image.save(f'{args.results_folder_edit}/{method_name}/{edit_caption}_edit.png')