mirror of https://github.com/vladmandic/automatic
61 lines
3.6 KiB
Python
61 lines
3.6 KiB
Python
import modules.scripts
|
|
from modules import sd_samplers, shared, processing
|
|
from modules.generation_parameters_copypaste import create_override_settings_dict
|
|
from modules.ui import plaintext_to_html
|
|
from modules.memstats import memory_stats
|
|
|
|
|
|
def txt2img(id_task: str, prompt: str, negative_prompt: str, prompt_styles, steps: int, sampler_index: int, restore_faces: bool, tiling: bool, n_iter: int, batch_size: int, cfg_scale: float, clip_skip: int, seed: int, subseed: int, subseed_strength: float, seed_resize_from_h: int, seed_resize_from_w: int, seed_enable_extras: bool, height: int, width: int, enable_hr: bool, denoising_strength: float, hr_scale: float, hr_upscaler: str, hr_second_pass_steps: int, hr_resize_x: int, hr_resize_y: int, override_settings_texts, *args): # pylint: disable=unused-argument
|
|
|
|
shared.log.debug(f'txt2img: id_task={id_task}|prompt={prompt}|negative_prompt={negative_prompt}|prompt_styles={prompt_styles}|steps={steps}|sampler_index={sampler_index}|restore_faces={restore_faces}|tiling={tiling}|n_iter={n_iter}|batch_size={batch_size}|cfg_scale={cfg_scale}|clip_skip={clip_skip}|seed={seed}|subseed={subseed}|subseed_strength={subseed_strength}|seed_resize_from_h={seed_resize_from_h}|seed_resize_from_w={seed_resize_from_w}|seed_enable_extras={seed_enable_extras}|height={height}|width={width}|enable_hr={enable_hr}|denoising_strength={denoising_strength}|hr_scale={hr_scale}|hr_upscaler={hr_upscaler}|hr_second_pass_steps={hr_second_pass_steps}|hr_resize_x={hr_resize_x}|hr_resize_y={hr_resize_y}|override_settings_texts={override_settings_texts}args={args}')
|
|
if sampler_index is None:
|
|
shared.log.warning('Selected sampler is not enabled')
|
|
sampler_index = 0
|
|
override_settings = create_override_settings_dict(override_settings_texts)
|
|
|
|
if shared.sd_model is None:
|
|
shared.log.warning('Model not loaded')
|
|
return [], '', '', 'Error: model not loaded'
|
|
|
|
p = processing.StableDiffusionProcessingTxt2Img(
|
|
sd_model=shared.sd_model,
|
|
outpath_samples=shared.opts.outdir_samples or shared.opts.outdir_txt2img_samples,
|
|
outpath_grids=shared.opts.outdir_grids or shared.opts.outdir_txt2img_grids,
|
|
prompt=prompt,
|
|
styles=prompt_styles,
|
|
negative_prompt=negative_prompt,
|
|
seed=seed,
|
|
subseed=subseed,
|
|
subseed_strength=subseed_strength,
|
|
seed_resize_from_h=seed_resize_from_h,
|
|
seed_resize_from_w=seed_resize_from_w,
|
|
seed_enable_extras=True,
|
|
sampler_name=sd_samplers.samplers[sampler_index].name,
|
|
batch_size=batch_size,
|
|
n_iter=n_iter,
|
|
steps=steps,
|
|
cfg_scale=cfg_scale,
|
|
clip_skip=clip_skip,
|
|
width=width,
|
|
height=height,
|
|
restore_faces=restore_faces,
|
|
tiling=tiling,
|
|
enable_hr=enable_hr,
|
|
denoising_strength=denoising_strength if enable_hr else None,
|
|
hr_scale=hr_scale,
|
|
hr_upscaler=hr_upscaler,
|
|
hr_second_pass_steps=hr_second_pass_steps,
|
|
hr_resize_x=hr_resize_x,
|
|
hr_resize_y=hr_resize_y,
|
|
override_settings=override_settings,
|
|
)
|
|
p.scripts = modules.scripts.scripts_txt2img
|
|
p.script_args = args
|
|
processed = modules.scripts.scripts_txt2img.run(p, *args)
|
|
if processed is None:
|
|
processed = processing.process_images(p)
|
|
p.close()
|
|
generation_info_js = processed.js()
|
|
shared.log.debug(f'Processed: {len(processed.images)} Memory: {memory_stats()} txt')
|
|
return processed.images, generation_info_js, processed.info, plaintext_to_html(processed.comments)
|