Spaces:
Running
on
Zero
Running
on
Zero
tori29umai
commited on
Commit
·
31877a7
1
Parent(s):
00c86c6
app.py
Browse files- app.py +7 -7
- utils/dl_utils.py +6 -43
app.py
CHANGED
@@ -6,7 +6,7 @@ from PIL import Image
|
|
6 |
import os
|
7 |
import time
|
8 |
|
9 |
-
from utils.dl_utils import
|
10 |
from utils.image_utils import resize_image_aspect_ratio, base_generation
|
11 |
|
12 |
from utils.prompt_utils import execute_prompt, remove_color, remove_duplicates
|
@@ -22,10 +22,10 @@ os.makedirs(cn_dir, exist_ok=True)
|
|
22 |
os.makedirs(tagger_dir, exist_ok=True)
|
23 |
os.makedirs(lora_dir, exist_ok=True)
|
24 |
|
25 |
-
|
26 |
-
|
27 |
-
|
28 |
-
|
29 |
|
30 |
def load_model(lora_dir, cn_dir):
|
31 |
device = "cuda" if torch.cuda.is_available() else "cpu"
|
@@ -35,8 +35,8 @@ def load_model(lora_dir, cn_dir):
|
|
35 |
pipe = StableDiffusionXLControlNetImg2ImgPipeline.from_pretrained(
|
36 |
"cagliostrolab/animagine-xl-3.1", controlnet=controlnet, vae=vae, torch_dtype=torch.float16
|
37 |
)
|
38 |
-
pipe.load_lora_weights(lora_dir, weight_name="
|
39 |
-
pipe.set_adapters(["
|
40 |
pipe.fuse_lora()
|
41 |
pipe = pipe.to(device)
|
42 |
return pipe
|
|
|
6 |
import os
|
7 |
import time
|
8 |
|
9 |
+
from utils.dl_utils import dl_cn_model, dl_cn_config, dl_tagger_model, dl_lora_model
|
10 |
from utils.image_utils import resize_image_aspect_ratio, base_generation
|
11 |
|
12 |
from utils.prompt_utils import execute_prompt, remove_color, remove_duplicates
|
|
|
22 |
os.makedirs(tagger_dir, exist_ok=True)
|
23 |
os.makedirs(lora_dir, exist_ok=True)
|
24 |
|
25 |
+
dl_cn_model(cn_dir)
|
26 |
+
dl_cn_config(cn_dir)
|
27 |
+
dl_tagger_model(tagger_dir)
|
28 |
+
dl_lora_model(lora_dir)
|
29 |
|
30 |
def load_model(lora_dir, cn_dir):
|
31 |
device = "cuda" if torch.cuda.is_available() else "cpu"
|
|
|
35 |
pipe = StableDiffusionXLControlNetImg2ImgPipeline.from_pretrained(
|
36 |
"cagliostrolab/animagine-xl-3.1", controlnet=controlnet, vae=vae, torch_dtype=torch.float16
|
37 |
)
|
38 |
+
pipe.load_lora_weights(lora_dir, weight_name="sdxl_BW_Line.safetensors")
|
39 |
+
pipe.set_adapters(["sdxl_BW_Line"], adapter_weights=[1.4])
|
40 |
pipe.fuse_lora()
|
41 |
pipe = pipe.to(device)
|
42 |
return pipe
|
utils/dl_utils.py
CHANGED
@@ -8,7 +8,7 @@ from PIL import Image, ImageOps
|
|
8 |
import numpy as np
|
9 |
import cv2
|
10 |
|
11 |
-
def
|
12 |
folder = model_dir
|
13 |
file_name = 'diffusion_pytorch_model.safetensors'
|
14 |
url = " https://huggingface.co/2vXpSwA7/iroiro-lora/resolve/main/test_controlnet2/CN-anytest_v3-50000_fp16.safetensors"
|
@@ -24,7 +24,7 @@ def load_cn_model(model_dir):
|
|
24 |
else:
|
25 |
print(f'{file_name} already exists.')
|
26 |
|
27 |
-
def
|
28 |
folder = model_dir
|
29 |
file_name = 'config.json'
|
30 |
file_path = os.path.join(folder, file_name)
|
@@ -32,7 +32,7 @@ def load_cn_config(model_dir):
|
|
32 |
config_path = os.path.join(os.getcwd(), file_name)
|
33 |
shutil.copy(config_path, file_path)
|
34 |
|
35 |
-
def
|
36 |
model_id = 'SmilingWolf/wd-swinv2-tagger-v3'
|
37 |
files = [
|
38 |
'config.json', 'model.onnx', 'selected_tags.csv', 'sw_jax_cv_config.json'
|
@@ -56,11 +56,11 @@ def load_tagger_model(model_dir):
|
|
56 |
print(f'{file} already exists.')
|
57 |
|
58 |
|
59 |
-
def
|
60 |
-
file_name = '
|
61 |
file_path = os.path.join(model_dir, file_name)
|
62 |
if not os.path.exists(file_path):
|
63 |
-
url = "https://huggingface.co/tori29umai/lineart/resolve/main/
|
64 |
response = requests.get(url, allow_redirects=True)
|
65 |
if response.status_code == 200:
|
66 |
with open(file_path, 'wb') as f:
|
@@ -70,40 +70,3 @@ def load_lora_model(model_dir):
|
|
70 |
print(f'Failed to download {file_name}')
|
71 |
else:
|
72 |
print(f'{file_name} already exists.')
|
73 |
-
|
74 |
-
|
75 |
-
def resize_image_aspect_ratio(image):
|
76 |
-
# 元の画像サイズを取得
|
77 |
-
original_width, original_height = image.size
|
78 |
-
|
79 |
-
# アスペクト比を計算
|
80 |
-
aspect_ratio = original_width / original_height
|
81 |
-
|
82 |
-
# 標準のアスペクト比サイズを定義
|
83 |
-
sizes = {
|
84 |
-
1: (1024, 1024), # 正方形
|
85 |
-
4/3: (1152, 896), # 横長画像
|
86 |
-
3/2: (1216, 832),
|
87 |
-
16/9: (1344, 768),
|
88 |
-
21/9: (1568, 672),
|
89 |
-
3/1: (1728, 576),
|
90 |
-
1/4: (512, 2048), # 縦長画像
|
91 |
-
1/3: (576, 1728),
|
92 |
-
9/16: (768, 1344),
|
93 |
-
2/3: (832, 1216),
|
94 |
-
3/4: (896, 1152)
|
95 |
-
}
|
96 |
-
|
97 |
-
# 最も近いアスペクト比を見つける
|
98 |
-
closest_aspect_ratio = min(sizes.keys(), key=lambda x: abs(x - aspect_ratio))
|
99 |
-
target_width, target_height = sizes[closest_aspect_ratio]
|
100 |
-
|
101 |
-
# リサイズ処理
|
102 |
-
resized_image = image.resize((target_width, target_height), Image.LANCZOS)
|
103 |
-
|
104 |
-
return resized_image
|
105 |
-
|
106 |
-
|
107 |
-
def base_generation(size, color):
|
108 |
-
canvas = Image.new("RGBA", size, color)
|
109 |
-
return canvas
|
|
|
8 |
import numpy as np
|
9 |
import cv2
|
10 |
|
11 |
+
def dl_cn_model(model_dir):
|
12 |
folder = model_dir
|
13 |
file_name = 'diffusion_pytorch_model.safetensors'
|
14 |
url = " https://huggingface.co/2vXpSwA7/iroiro-lora/resolve/main/test_controlnet2/CN-anytest_v3-50000_fp16.safetensors"
|
|
|
24 |
else:
|
25 |
print(f'{file_name} already exists.')
|
26 |
|
27 |
+
def dl_cn_config(model_dir):
|
28 |
folder = model_dir
|
29 |
file_name = 'config.json'
|
30 |
file_path = os.path.join(folder, file_name)
|
|
|
32 |
config_path = os.path.join(os.getcwd(), file_name)
|
33 |
shutil.copy(config_path, file_path)
|
34 |
|
35 |
+
def dl_tagger_model(model_dir):
|
36 |
model_id = 'SmilingWolf/wd-swinv2-tagger-v3'
|
37 |
files = [
|
38 |
'config.json', 'model.onnx', 'selected_tags.csv', 'sw_jax_cv_config.json'
|
|
|
56 |
print(f'{file} already exists.')
|
57 |
|
58 |
|
59 |
+
def dl_lora_model(model_dir):
|
60 |
+
file_name = 'sdxl_BW_Line.safetensors'
|
61 |
file_path = os.path.join(model_dir, file_name)
|
62 |
if not os.path.exists(file_path):
|
63 |
+
url = "https://huggingface.co/tori29umai/lineart/resolve/main/sdxl_BW_Line.safetensors"
|
64 |
response = requests.get(url, allow_redirects=True)
|
65 |
if response.status_code == 200:
|
66 |
with open(file_path, 'wb') as f:
|
|
|
70 |
print(f'Failed to download {file_name}')
|
71 |
else:
|
72 |
print(f'{file_name} already exists.')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|