mirror of
https://github.com/lllyasviel/stable-diffusion-webui-forge.git
synced 2026-02-09 01:19:58 +00:00
cleanup codes
This commit is contained in:
@@ -23,30 +23,32 @@ class ScriptRefiner(scripts.ScriptBuiltinUI):
|
||||
with InputAccordion(False, label="Refiner", elem_id=self.elem_id("enable")) as enable_refiner:
|
||||
gr.Markdown('Refiner is currently under maintenance and unavailable. Sorry for the inconvenience.')
|
||||
|
||||
with gr.Row():
|
||||
refiner_checkpoint = gr.Dropdown(label='Checkpoint', elem_id=self.elem_id("checkpoint"), choices=["", *sd_models.checkpoint_tiles()], value='', tooltip="switch to another model in the middle of generation", interactive=False, visible=False)
|
||||
# create_refresh_button(refiner_checkpoint, sd_models.list_models, lambda: {"choices": sd_models.checkpoint_tiles()}, self.elem_id("checkpoint_refresh"))
|
||||
#
|
||||
# with gr.Row():
|
||||
# refiner_checkpoint = gr.Dropdown(label='Checkpoint', elem_id=self.elem_id("checkpoint"), choices=["", *sd_models.checkpoint_tiles()], value='', tooltip="switch to another model in the middle of generation", interactive=False, visible=False)
|
||||
# # create_refresh_button(refiner_checkpoint, sd_models.list_models, lambda: {"choices": sd_models.checkpoint_tiles()}, self.elem_id("checkpoint_refresh"))
|
||||
#
|
||||
# refiner_switch_at = gr.Slider(value=0.8, label="Switch at", minimum=0.01, maximum=1.0, step=0.01, elem_id=self.elem_id("switch_at"), tooltip="fraction of sampling steps when the switch to refiner model should happen; 1=never, 0.5=switch in the middle of generation", interactive=False, visible=False)
|
||||
#
|
||||
# def lookup_checkpoint(title):
|
||||
# info = sd_models.get_closet_checkpoint_match(title)
|
||||
# return None if info is None else info.title
|
||||
#
|
||||
# self.infotext_fields = [
|
||||
# PasteField(enable_refiner, lambda d: 'Refiner' in d),
|
||||
# PasteField(refiner_checkpoint, lambda d: lookup_checkpoint(d.get('Refiner')), api="refiner_checkpoint"),
|
||||
# PasteField(refiner_switch_at, 'Refiner switch at', api="refiner_switch_at"),
|
||||
# ]
|
||||
|
||||
refiner_switch_at = gr.Slider(value=0.8, label="Switch at", minimum=0.01, maximum=1.0, step=0.01, elem_id=self.elem_id("switch_at"), tooltip="fraction of sampling steps when the switch to refiner model should happen; 1=never, 0.5=switch in the middle of generation", interactive=False, visible=False)
|
||||
return [enable_refiner] # , refiner_checkpoint, refiner_switch_at
|
||||
|
||||
def lookup_checkpoint(title):
|
||||
info = sd_models.get_closet_checkpoint_match(title)
|
||||
return None if info is None else info.title
|
||||
|
||||
self.infotext_fields = [
|
||||
PasteField(enable_refiner, lambda d: 'Refiner' in d),
|
||||
PasteField(refiner_checkpoint, lambda d: lookup_checkpoint(d.get('Refiner')), api="refiner_checkpoint"),
|
||||
PasteField(refiner_switch_at, 'Refiner switch at', api="refiner_switch_at"),
|
||||
]
|
||||
|
||||
return enable_refiner, refiner_checkpoint, refiner_switch_at
|
||||
|
||||
def setup(self, p, enable_refiner, refiner_checkpoint, refiner_switch_at):
|
||||
# the actual implementation is in sd_samplers_common.py, apply_refiner
|
||||
|
||||
if not enable_refiner or refiner_checkpoint in (None, "", "None"):
|
||||
p.refiner_checkpoint = None
|
||||
p.refiner_switch_at = None
|
||||
else:
|
||||
p.refiner_checkpoint = refiner_checkpoint
|
||||
p.refiner_switch_at = refiner_switch_at
|
||||
def setup(self, p, enable_refiner):
|
||||
pass
|
||||
# # the actual implementation is in sd_samplers_common.py, apply_refiner
|
||||
#
|
||||
# if not enable_refiner or refiner_checkpoint in (None, "", "None"):
|
||||
# p.refiner_checkpoint = None
|
||||
# p.refiner_switch_at = None
|
||||
# else:
|
||||
# p.refiner_checkpoint = refiner_checkpoint
|
||||
# p.refiner_switch_at = refiner_switch_at
|
||||
|
||||
@@ -168,9 +168,9 @@ class CFGDenoiser(torch.nn.Module):
|
||||
x = x * (((real_sigma ** 2.0 + real_sigma_data ** 2.0) ** 0.5)[:, None, None, None])
|
||||
sigma = real_sigma
|
||||
|
||||
if sd_samplers_common.apply_refiner(self, x):
|
||||
cond = self.sampler.sampler_extra_args['cond']
|
||||
uncond = self.sampler.sampler_extra_args['uncond']
|
||||
# if sd_samplers_common.apply_refiner(self, x):
|
||||
# cond = self.sampler.sampler_extra_args['cond']
|
||||
# uncond = self.sampler.sampler_extra_args['uncond']
|
||||
|
||||
cond_composition, cond = prompt_parser.reconstruct_multicond_batch(cond, self.step)
|
||||
uncond = prompt_parser.reconstruct_cond_batch(uncond, self.step) if uncond is not None else None
|
||||
|
||||
@@ -161,44 +161,45 @@ replace_torchsde_browinan()
|
||||
|
||||
|
||||
def apply_refiner(cfg_denoiser, x):
|
||||
completed_ratio = cfg_denoiser.step / cfg_denoiser.total_steps
|
||||
refiner_switch_at = cfg_denoiser.p.refiner_switch_at
|
||||
refiner_checkpoint_info = cfg_denoiser.p.refiner_checkpoint_info
|
||||
|
||||
if refiner_switch_at is not None and completed_ratio < refiner_switch_at:
|
||||
return False
|
||||
|
||||
if refiner_checkpoint_info is None or shared.sd_model.sd_checkpoint_info == refiner_checkpoint_info:
|
||||
return False
|
||||
|
||||
if getattr(cfg_denoiser.p, "enable_hr", False):
|
||||
is_second_pass = cfg_denoiser.p.is_hr_pass
|
||||
|
||||
if opts.hires_fix_refiner_pass == "first pass" and is_second_pass:
|
||||
return False
|
||||
|
||||
if opts.hires_fix_refiner_pass == "second pass" and not is_second_pass:
|
||||
return False
|
||||
|
||||
if opts.hires_fix_refiner_pass != "second pass":
|
||||
cfg_denoiser.p.extra_generation_params['Hires refiner'] = opts.hires_fix_refiner_pass
|
||||
|
||||
cfg_denoiser.p.extra_generation_params['Refiner'] = refiner_checkpoint_info.short_title
|
||||
cfg_denoiser.p.extra_generation_params['Refiner switch at'] = refiner_switch_at
|
||||
|
||||
sampling_cleanup(sd_models.model_data.get_sd_model().forge_objects.unet)
|
||||
|
||||
with sd_models.SkipWritingToConfig():
|
||||
sd_models.reload_model_weights(info=refiner_checkpoint_info)
|
||||
|
||||
if not cfg_denoiser.p.disable_extra_networks:
|
||||
extra_networks.activate(cfg_denoiser.p, cfg_denoiser.p.extra_network_data)
|
||||
|
||||
cfg_denoiser.p.setup_conds()
|
||||
cfg_denoiser.update_inner_model()
|
||||
|
||||
sampling_prepare(sd_models.model_data.get_sd_model().forge_objects.unet, x=x)
|
||||
return True
|
||||
# completed_ratio = cfg_denoiser.step / cfg_denoiser.total_steps
|
||||
# refiner_switch_at = cfg_denoiser.p.refiner_switch_at
|
||||
# refiner_checkpoint_info = cfg_denoiser.p.refiner_checkpoint_info
|
||||
#
|
||||
# if refiner_switch_at is not None and completed_ratio < refiner_switch_at:
|
||||
# return False
|
||||
#
|
||||
# if refiner_checkpoint_info is None or shared.sd_model.sd_checkpoint_info == refiner_checkpoint_info:
|
||||
# return False
|
||||
#
|
||||
# if getattr(cfg_denoiser.p, "enable_hr", False):
|
||||
# is_second_pass = cfg_denoiser.p.is_hr_pass
|
||||
#
|
||||
# if opts.hires_fix_refiner_pass == "first pass" and is_second_pass:
|
||||
# return False
|
||||
#
|
||||
# if opts.hires_fix_refiner_pass == "second pass" and not is_second_pass:
|
||||
# return False
|
||||
#
|
||||
# if opts.hires_fix_refiner_pass != "second pass":
|
||||
# cfg_denoiser.p.extra_generation_params['Hires refiner'] = opts.hires_fix_refiner_pass
|
||||
#
|
||||
# cfg_denoiser.p.extra_generation_params['Refiner'] = refiner_checkpoint_info.short_title
|
||||
# cfg_denoiser.p.extra_generation_params['Refiner switch at'] = refiner_switch_at
|
||||
#
|
||||
# sampling_cleanup(sd_models.model_data.get_sd_model().forge_objects.unet)
|
||||
#
|
||||
# with sd_models.SkipWritingToConfig():
|
||||
# sd_models.reload_model_weights(info=refiner_checkpoint_info)
|
||||
#
|
||||
# if not cfg_denoiser.p.disable_extra_networks:
|
||||
# extra_networks.activate(cfg_denoiser.p, cfg_denoiser.p.extra_network_data)
|
||||
#
|
||||
# cfg_denoiser.p.setup_conds()
|
||||
# cfg_denoiser.update_inner_model()
|
||||
#
|
||||
# sampling_prepare(sd_models.model_data.get_sd_model().forge_objects.unet, x=x)
|
||||
# return True
|
||||
pass
|
||||
|
||||
|
||||
class TorchHijack:
|
||||
|
||||
Reference in New Issue
Block a user