Spaces:
Running
on
Zero
Running
on
Zero
Update app.py
Browse files
app.py
CHANGED
@@ -202,19 +202,23 @@ def remove_lora_2(selected_indices, loras_state):
|
|
202 |
return selected_info_1, selected_info_2, selected_indices, lora_scale_1, lora_scale_2, lora_image_1, lora_image_2
|
203 |
|
204 |
def randomize_loras(selected_indices, loras_state):
|
205 |
-
|
206 |
-
|
207 |
-
|
208 |
-
|
209 |
-
|
210 |
-
|
211 |
-
|
212 |
-
|
213 |
-
|
214 |
-
|
215 |
-
|
216 |
-
|
217 |
-
|
|
|
|
|
|
|
|
|
218 |
|
219 |
def add_custom_lora(custom_lora, selected_indices, current_loras):
|
220 |
if custom_lora:
|
@@ -566,42 +570,52 @@ def infer_upscale(
|
|
566 |
controlnet_conditioning_scale,
|
567 |
progress=gr.Progress(track_tqdm=True),
|
568 |
):
|
569 |
-
|
570 |
-
|
571 |
-
|
572 |
-
|
573 |
-
|
574 |
-
|
|
|
|
|
|
|
|
|
575 |
|
576 |
-
|
577 |
-
|
578 |
-
|
579 |
-
|
580 |
-
generator = torch.Generator().manual_seed(seed)
|
581 |
-
|
582 |
-
gr.Info("Upscaling image...")
|
583 |
-
image = pipe_upscale(
|
584 |
-
prompt="",
|
585 |
-
control_image=control_image,
|
586 |
-
controlnet_conditioning_scale=controlnet_conditioning_scale,
|
587 |
-
num_inference_steps=num_inference_steps,
|
588 |
-
guidance_scale=3.5,
|
589 |
-
height=control_image.size[1],
|
590 |
-
width=control_image.size[0],
|
591 |
-
generator=generator,
|
592 |
-
).images[0]
|
593 |
|
594 |
-
|
595 |
-
|
596 |
-
|
597 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
598 |
|
599 |
-
|
600 |
-
|
601 |
-
|
602 |
-
|
603 |
-
return [true_input_image, image, seed]
|
604 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
605 |
|
606 |
|
607 |
with gr.Blocks(theme="Nymbo/Nymbo_Theme", css=css, delete_cache=(60, 3600)) as app:
|
|
|
202 |
return selected_info_1, selected_info_2, selected_indices, lora_scale_1, lora_scale_2, lora_image_1, lora_image_2
|
203 |
|
204 |
def randomize_loras(selected_indices, loras_state):
|
205 |
+
try:
|
206 |
+
if len(loras_state) < 2:
|
207 |
+
raise gr.Error("Not enough LoRAs to randomize.")
|
208 |
+
selected_indices = random.sample(range(len(loras_state)), 2)
|
209 |
+
lora1 = loras_state[selected_indices[0]]
|
210 |
+
lora2 = loras_state[selected_indices[1]]
|
211 |
+
selected_info_1 = f"### LoRA 1 Selected: [{lora1['title']}](https://huggingface.co/{lora1['repo']}) ✨"
|
212 |
+
selected_info_2 = f"### LoRA 2 Selected: [{lora2['title']}](https://huggingface.co/{lora2['repo']}) ✨"
|
213 |
+
lora_scale_1 = 1.15
|
214 |
+
lora_scale_2 = 1.15
|
215 |
+
lora_image_1 = lora1['image']
|
216 |
+
lora_image_2 = lora2['image']
|
217 |
+
random_prompt = random.choice(prompt_values)
|
218 |
+
return selected_info_1, selected_info_2, selected_indices, lora_scale_1, lora_scale_2, lora_image_1, lora_image_2, random_prompt
|
219 |
+
except Exception as e:
|
220 |
+
print(f"Error in randomize_loras: {str(e)}")
|
221 |
+
return "Error", "Error", [], 1.15, 1.15, None, None, ""
|
222 |
|
223 |
def add_custom_lora(custom_lora, selected_indices, current_loras):
|
224 |
if custom_lora:
|
|
|
570 |
controlnet_conditioning_scale,
|
571 |
progress=gr.Progress(track_tqdm=True),
|
572 |
):
|
573 |
+
try:
|
574 |
+
if input_image is None:
|
575 |
+
raise ValueError("No input image provided")
|
576 |
+
|
577 |
+
if randomize_seed:
|
578 |
+
seed = random.randint(0, MAX_SEED)
|
579 |
+
true_input_image = input_image
|
580 |
+
input_image, w_original, h_original, was_resized = process_input(
|
581 |
+
input_image, upscale_factor
|
582 |
+
)
|
583 |
|
584 |
+
# rescale with upscale factor
|
585 |
+
w, h = input_image.size
|
586 |
+
control_image = input_image.resize((w * upscale_factor, h * upscale_factor))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
587 |
|
588 |
+
generator = torch.Generator(device=device).manual_seed(seed)
|
589 |
+
|
590 |
+
gr.Info("Upscaling image...")
|
591 |
+
# 모든 텐서를 동일한 디바이스로 이동
|
592 |
+
pipe_upscale.to(device)
|
593 |
+
control_image = control_image.to(device)
|
594 |
+
|
595 |
+
image = pipe_upscale(
|
596 |
+
prompt="",
|
597 |
+
control_image=control_image,
|
598 |
+
controlnet_conditioning_scale=controlnet_conditioning_scale,
|
599 |
+
num_inference_steps=num_inference_steps,
|
600 |
+
guidance_scale=3.5,
|
601 |
+
height=control_image.size[1],
|
602 |
+
width=control_image.size[0],
|
603 |
+
generator=generator,
|
604 |
+
).images[0]
|
605 |
|
606 |
+
if was_resized:
|
607 |
+
gr.Info(
|
608 |
+
f"Resizing output image to targeted {w_original * upscale_factor}x{h_original * upscale_factor} size."
|
609 |
+
)
|
|
|
610 |
|
611 |
+
# resize to target desired size
|
612 |
+
image = image.resize((w_original * upscale_factor, h_original * upscale_factor))
|
613 |
+
image.save("output.jpg")
|
614 |
+
# convert to numpy
|
615 |
+
return [true_input_image, image, seed]
|
616 |
+
except Exception as e:
|
617 |
+
print(f"Error in infer_upscale: {str(e)}")
|
618 |
+
return [None, None, seed]
|
619 |
|
620 |
|
621 |
with gr.Blocks(theme="Nymbo/Nymbo_Theme", css=css, delete_cache=(60, 3600)) as app:
|