Prompt selector for Prompt Matrix script
This commit is contained in:
parent
0a8515085e
commit
7c53f81caf
1 changed files with 17 additions and 7 deletions
|
@ -10,7 +10,7 @@ from modules import images
|
||||||
from modules.processing import process_images, Processed
|
from modules.processing import process_images, Processed
|
||||||
from modules.shared import opts, cmd_opts, state
|
from modules.shared import opts, cmd_opts, state
|
||||||
import modules.sd_samplers
|
import modules.sd_samplers
|
||||||
|
from pprint import pprint
|
||||||
|
|
||||||
def draw_xy_grid(xs, ys, x_label, y_label, cell):
|
def draw_xy_grid(xs, ys, x_label, y_label, cell):
|
||||||
res = []
|
res = []
|
||||||
|
@ -44,16 +44,23 @@ class Script(scripts.Script):
|
||||||
def title(self):
|
def title(self):
|
||||||
return "Prompt matrix"
|
return "Prompt matrix"
|
||||||
|
|
||||||
def ui(self, is_img2img):
|
def ui(self, is_img2img):
|
||||||
put_at_start = gr.Checkbox(label='Put variable parts at start of prompt', value=False, elem_id=self.elem_id("put_at_start"))
|
put_at_start = gr.Checkbox(label='Put variable parts at start of prompt', value=False, elem_id=self.elem_id("put_at_start"))
|
||||||
different_seeds = gr.Checkbox(label='Use different seed for each picture', value=False, elem_id=self.elem_id("different_seeds"))
|
different_seeds = gr.Checkbox(label='Use different seed for each picture', value=False, elem_id=self.elem_id("different_seeds"))
|
||||||
|
# Radio buttons for selecting the prompt between positive and negative
|
||||||
|
prompt_type = gr.Radio(["positive", "negative"], label="Select prompt", elem_id=self.elem_id("prompt_type"), value="positive")
|
||||||
|
|
||||||
return [put_at_start, different_seeds]
|
return [put_at_start, different_seeds, prompt_type]
|
||||||
|
|
||||||
def run(self, p, put_at_start, different_seeds):
|
def run(self, p, put_at_start, different_seeds, prompt_type):
|
||||||
modules.processing.fix_seed(p)
|
modules.processing.fix_seed(p)
|
||||||
|
# Raise error if promp type is not positive or negative
|
||||||
|
if prompt_type not in ["positive", "negative"]:
|
||||||
|
raise ValueError(f"Unknown prompt type {prompt_type}")
|
||||||
|
|
||||||
original_prompt = p.prompt[0] if type(p.prompt) == list else p.prompt
|
prompt = p.prompt if prompt_type == "positive" else p.negative_prompt
|
||||||
|
original_prompt = prompt[0] if type(prompt) == list else prompt
|
||||||
|
positive_prompt = p.prompt[0] if type(p.prompt) == list else p.prompt
|
||||||
|
|
||||||
all_prompts = []
|
all_prompts = []
|
||||||
prompt_matrix_parts = original_prompt.split("|")
|
prompt_matrix_parts = original_prompt.split("|")
|
||||||
|
@ -73,9 +80,12 @@ class Script(scripts.Script):
|
||||||
|
|
||||||
print(f"Prompt matrix will create {len(all_prompts)} images using a total of {p.n_iter} batches.")
|
print(f"Prompt matrix will create {len(all_prompts)} images using a total of {p.n_iter} batches.")
|
||||||
|
|
||||||
p.prompt = all_prompts
|
if prompt_type == "positive":
|
||||||
|
p.prompt = all_prompts
|
||||||
|
else:
|
||||||
|
p.negative_prompt = all_prompts
|
||||||
p.seed = [p.seed + (i if different_seeds else 0) for i in range(len(all_prompts))]
|
p.seed = [p.seed + (i if different_seeds else 0) for i in range(len(all_prompts))]
|
||||||
p.prompt_for_display = original_prompt
|
p.prompt_for_display = positive_prompt
|
||||||
processed = process_images(p)
|
processed = process_images(p)
|
||||||
|
|
||||||
grid = images.image_grid(processed.images, p.batch_size, rows=1 << ((len(prompt_matrix_parts) - 1) // 2))
|
grid = images.image_grid(processed.images, p.batch_size, rows=1 << ((len(prompt_matrix_parts) - 1) // 2))
|
||||||
|
|
Loading…
Reference in a new issue