diff options
author | AUTOMATIC1111 <16777216c@gmail.com> | 2022-10-12 05:35:27 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-10-12 05:35:27 +0000 |
commit | 2e2d45b281cf3bafbf5034417dab34582a56787b (patch) | |
tree | 691b7aa7e02899f57b51c8818d4ebc45c41db7e6 /modules/textual_inversion/preprocess.py | |
parent | fec2221eeaafb50afd26ba3e109bf6f928011e69 (diff) | |
parent | f53f703aebc801c4204182d52bb1e0bef9808e1f (diff) | |
download | stable-diffusion-webui-gfx803-2e2d45b281cf3bafbf5034417dab34582a56787b.tar.gz stable-diffusion-webui-gfx803-2e2d45b281cf3bafbf5034417dab34582a56787b.tar.bz2 stable-diffusion-webui-gfx803-2e2d45b281cf3bafbf5034417dab34582a56787b.zip |
Merge pull request #2143 from JC-Array/deepdanbooru_pre_process
deepbooru tags for textual inversion preproccessing
Diffstat (limited to 'modules/textual_inversion/preprocess.py')
-rw-r--r-- | modules/textual_inversion/preprocess.py | 22 |
1 files changed, 20 insertions, 2 deletions
diff --git a/modules/textual_inversion/preprocess.py b/modules/textual_inversion/preprocess.py index 1a672725..113cecf1 100644 --- a/modules/textual_inversion/preprocess.py +++ b/modules/textual_inversion/preprocess.py @@ -3,11 +3,14 @@ from PIL import Image, ImageOps import platform
import sys
import tqdm
+import time
from modules import shared, images
+from modules.shared import opts, cmd_opts
+if cmd_opts.deepdanbooru:
+ import modules.deepbooru as deepbooru
-
-def preprocess(process_src, process_dst, process_width, process_height, process_flip, process_split, process_caption):
+def preprocess(process_src, process_dst, process_width, process_height, process_flip, process_split, process_caption, process_caption_deepbooru=False):
width = process_width
height = process_height
src = os.path.abspath(process_src)
@@ -25,10 +28,21 @@ def preprocess(process_src, process_dst, process_width, process_height, process_ if process_caption:
shared.interrogator.load()
+ if process_caption_deepbooru:
+ deepbooru.create_deepbooru_process(opts.interrogate_deepbooru_score_threshold, opts.deepbooru_sort_alpha)
+
def save_pic_with_caption(image, index):
if process_caption:
caption = "-" + shared.interrogator.generate_caption(image)
caption = sanitize_caption(os.path.join(dst, f"{index:05}-{subindex[0]}"), caption, ".png")
+ elif process_caption_deepbooru:
+ shared.deepbooru_process_return["value"] = -1
+ shared.deepbooru_process_queue.put(image)
+ while shared.deepbooru_process_return["value"] == -1:
+ time.sleep(0.2)
+ caption = "-" + shared.deepbooru_process_return["value"]
+ caption = sanitize_caption(os.path.join(dst, f"{index:05}-{subindex[0]}"), caption, ".png")
+ shared.deepbooru_process_return["value"] = -1
else:
caption = filename
caption = os.path.splitext(caption)[0]
@@ -83,6 +97,10 @@ def preprocess(process_src, process_dst, process_width, process_height, process_ if process_caption:
shared.interrogator.send_blip_to_ram()
+ if process_caption_deepbooru:
+ deepbooru.release_process()
+
+
def sanitize_caption(base_path, original_caption, suffix):
operating_system = platform.system().lower()
if (operating_system == "windows"):
|