2022-09-26 16:02:48 +03:00
# This file is part of stable-diffusion-webui (https://github.com/sd-webui/stable-diffusion-webui/).
# Copyright 2022 sd-webui team.
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
# You should have received a copy of the GNU Affero General Public License
2022-10-01 21:14:32 +03:00
# along with this program. If not, see <http://www.gnu.org/licenses/>.
2022-09-14 14:19:24 +03:00
# base webui import and utils.
2022-09-14 00:08:40 +03:00
from sd_utils import *
2022-09-14 14:19:24 +03:00
# streamlit imports
2022-09-14 00:08:40 +03:00
from streamlit import StopException
2022-09-29 13:29:44 +03:00
#from streamlit.elements import image as STImage
2022-10-02 01:40:50 +03:00
import streamlit . components . v1 as components
from streamlit . runtime . media_file_manager import media_file_manager
from streamlit . elements . image import image_to_url
2022-09-14 00:08:40 +03:00
2022-09-14 14:19:24 +03:00
#other imports
2022-10-02 01:40:50 +03:00
import uuid
2022-09-14 00:08:40 +03:00
from typing import Union
from ldm . models . diffusion . ddim import DDIMSampler
from ldm . models . diffusion . plms import PLMSSampler
2022-10-06 11:45:47 +03:00
# Temp imports
2022-09-14 14:19:24 +03:00
# end of imports
#---------------------------------------------------------------------------------------------------------------
2022-09-14 00:08:40 +03:00
try :
2022-09-15 03:17:07 +03:00
# this silences the annoying "Some weights of the model checkpoint were not used when initializing..." message at start.
from transformers import logging
2022-09-14 00:08:40 +03:00
2022-09-15 03:17:07 +03:00
logging . set_verbosity_error ( )
2022-09-14 00:08:40 +03:00
except :
2022-09-15 03:17:07 +03:00
pass
2022-09-14 00:08:40 +03:00
2022-10-02 01:40:50 +03:00
#
# Dev mode (server)
# _component_func = components.declare_component(
# "sd-gallery",
# url="http://localhost:3001",
# )
# Init Vuejs component
_component_func = components . declare_component (
" sd-gallery " , " ./frontend/dists/sd-gallery/dist " )
def sdGallery ( images = [ ] , key = None ) :
component_value = _component_func ( images = imgsToGallery ( images ) , key = key , default = " " )
return component_value
def imgsToGallery ( images ) :
urls = [ ]
for i in images :
# random string for id
random_id = str ( uuid . uuid4 ( ) )
url = image_to_url (
image = i ,
image_id = random_id ,
width = i . width ,
clamp = False ,
channels = " RGB " ,
output_format = " PNG "
)
# image_io = BytesIO()
# i.save(image_io, 'PNG')
# width, height = i.size
# image_id = "%s" % (str(images.index(i)))
# (data, mimetype) = STImage._normalize_to_bytes(image_io.getvalue(), width, 'auto')
# this_file = media_file_manager.add(data, mimetype, image_id)
# img_str = this_file.url
urls . append ( url )
return urls
2022-09-14 00:08:40 +03:00
class plugin_info ( ) :
2022-09-15 16:29:41 +03:00
plugname = " txt2img "
description = " Text to Image "
isTab = True
displayPriority = 1
2022-10-16 01:37:04 +03:00
#@logger.catch
def stable_horde ( outpath , prompt , seed , sampler_name , save_grid , batch_size ,
n_iter , steps , cfg_scale , width , height , prompt_matrix , use_GFPGAN , GFPGAN_model ,
use_RealESRGAN , realesrgan_model_name , use_LDSR ,
LDSR_model_name , ddim_eta , normalize_prompt_weights ,
save_individual_images , sort_samples , write_info_files ,
jpg_sample , variant_amount , variant_seed , api_key ,
nsfw = True , censor_nsfw = False ) :
st . session_state [ " progress_bar_text " ] . info ( " Generating image with Stable Horde. " )
# start time after garbage collection (or before?)
start_time = time . time ( )
# We will use this date here later for the folder name, need to start_time if not need
run_start_dt = datetime . datetime . now ( )
mem_mon = MemUsageMonitor ( ' MemMon ' )
mem_mon . start ( )
os . makedirs ( outpath , exist_ok = True )
sample_path = os . path . join ( outpath , " samples " )
os . makedirs ( sample_path , exist_ok = True )
params = {
" sampler_name " : " k_euler " ,
" toggles " : [ 1 , 4 ] ,
" cfg_scale " : cfg_scale ,
" seed " : str ( seed ) ,
" width " : width ,
" height " : height ,
" seed_variation " : variant_seed if variant_seed else 1 ,
" steps " : int ( steps ) ,
" n " : int ( n_iter )
# You can put extra params here if you wish
}
final_submit_dict = {
" prompt " : prompt ,
" params " : params ,
" nsfw " : nsfw ,
" censor_nsfw " : censor_nsfw ,
" trusted_workers " : True ,
" workers " : [ ]
}
headers = { " apikey " : api_key }
logger . debug ( final_submit_dict )
horde_url = " https://stablehorde.net "
submit_req = requests . post ( f ' { horde_url } /api/v2/generate/async ' , json = final_submit_dict , headers = headers )
if submit_req . ok :
submit_results = submit_req . json ( )
logger . debug ( submit_results )
req_id = submit_results [ ' id ' ]
is_done = False
while not is_done :
chk_req = requests . get ( f ' { horde_url } /api/v2/generate/check/ { req_id } ' )
if not chk_req . ok :
logger . error ( chk_req . text )
return
chk_results = chk_req . json ( )
logger . info ( chk_results )
is_done = chk_results [ ' done ' ]
time . sleep ( 1 )
retrieve_req = requests . get ( f ' { horde_url } /api/v2/generate/status/ { req_id } ' )
if not retrieve_req . ok :
logger . error ( retrieve_req . text )
return
results_json = retrieve_req . json ( )
# logger.debug(results_json)
results = results_json [ ' generations ' ]
output_images = [ ]
comments = [ ]
prompt_matrix_parts = [ ]
if not st . session_state [ ' defaults ' ] . general . no_verify_input :
try :
check_prompt_length ( prompt , comments )
except :
import traceback
logger . info ( " Error verifying input: " , file = sys . stderr )
logger . info ( traceback . format_exc ( ) , file = sys . stderr )
all_prompts = batch_size * n_iter * [ prompt ]
all_seeds = [ seed + x for x in range ( len ( all_prompts ) ) ]
for iter in range ( len ( results ) ) :
b64img = results [ iter ] [ " img " ]
base64_bytes = b64img . encode ( ' utf-8 ' )
img_bytes = base64 . b64decode ( base64_bytes )
img = Image . open ( BytesIO ( img_bytes ) )
sanitized_prompt = slugify ( prompt )
prompts = all_prompts [ iter * batch_size : ( iter + 1 ) * batch_size ]
#captions = prompt_matrix_parts[n * batch_size:(n + 1) * batch_size]
seeds = all_seeds [ iter * batch_size : ( iter + 1 ) * batch_size ]
if sort_samples :
full_path = os . path . join ( os . getcwd ( ) , sample_path , sanitized_prompt )
sanitized_prompt = sanitized_prompt [ : 200 - len ( full_path ) ]
sample_path_i = os . path . join ( sample_path , sanitized_prompt )
#print(f"output folder length: {len(os.path.join(os.getcwd(), sample_path_i))}")
#print(os.path.join(os.getcwd(), sample_path_i))
os . makedirs ( sample_path_i , exist_ok = True )
base_count = get_next_sequence_number ( sample_path_i )
filename = f " { base_count : 05 } - { steps } _ { sampler_name } _ { seeds [ iter ] } "
else :
full_path = os . path . join ( os . getcwd ( ) , sample_path )
sample_path_i = sample_path
base_count = get_next_sequence_number ( sample_path_i )
filename = f " { base_count : 05 } - { steps } _ { sampler_name } _ { seed } _ { sanitized_prompt } " [ : 200 - len ( full_path ) ] #same as before
save_sample ( img , sample_path_i , filename , jpg_sample , prompts , seeds , width , height , steps , cfg_scale ,
normalize_prompt_weights , use_GFPGAN , write_info_files , prompt_matrix , init_img = None ,
denoising_strength = 0.75 , resize_mode = None , uses_loopback = False , uses_random_seed_loopback = False ,
save_grid = save_grid ,
sort_samples = sampler_name , sampler_name = sampler_name , ddim_eta = ddim_eta , n_iter = n_iter ,
batch_size = batch_size , i = iter , save_individual_images = save_individual_images ,
model_name = " Stable Diffusion v1.4 " )
output_images . append ( img )
# update image on the UI so we can see the progress
if " preview_image " in st . session_state :
st . session_state [ " preview_image " ] . image ( img )
if " progress_bar_text " in st . session_state :
st . session_state [ " progress_bar_text " ] . empty ( )
#if len(results) > 1:
#final_filename = f"{iter}_{filename}"
#img.save(final_filename)
#logger.info(f"Saved {final_filename}")
else :
if " progress_bar_text " in st . session_state :
st . session_state [ " progress_bar_text " ] . error ( submit_req . text )
logger . error ( submit_req . text )
mem_max_used , mem_total = mem_mon . read_and_stop ( )
time_diff = time . time ( ) - start_time
info = f """
{ prompt }
Steps : { steps } , Sampler : { sampler_name } , CFG scale : { cfg_scale } , Seed : { seed } { ' , GFPGAN ' if use_GFPGAN else ' ' } { ' , ' + realesrgan_model_name if use_RealESRGAN else ' ' }
{ ' , Prompt Matrix Mode. ' if prompt_matrix else ' ' } """ .strip()
stats = f '''
Took { round ( time_diff , 2 ) } s total ( { round ( time_diff / ( len ( all_prompts ) ) , 2 ) } s per image )
Peak memory usage : { - ( mem_max_used / / - 1_048_576 ) } MiB / { - ( mem_total / / - 1_048_576 ) } MiB / { round ( mem_max_used / mem_total * 100 , 3 ) } % '''
for comment in comments :
info + = " \n \n " + comment
#mem_mon.stop()
#del mem_mon
torch_gc ( )
return output_images , seed , info , stats
2022-09-14 00:08:40 +03:00
#
2022-10-16 01:37:04 +03:00
#@logger.catch
2022-10-02 17:54:56 +03:00
def txt2img ( prompt : str , ddim_steps : int , sampler_name : str , n_iter : int , batch_size : int , cfg_scale : float , seed : Union [ int , str , None ] ,
2022-09-15 03:17:07 +03:00
height : int , width : int , separate_prompts : bool = False , normalize_prompt_weights : bool = True ,
save_individual_images : bool = True , save_grid : bool = True , group_by_prompt : bool = True ,
2022-10-02 17:54:56 +03:00
save_as_jpg : bool = True , use_GFPGAN : bool = True , GFPGAN_model : str = ' GFPGANv1.3 ' , use_RealESRGAN : bool = False ,
2022-10-06 11:45:47 +03:00
RealESRGAN_model : str = " RealESRGAN_x4plus_anime_6B " , use_LDSR : bool = True , LDSR_model : str = " model " ,
2022-10-14 22:09:47 +03:00
fp = None , variant_amount : float = 0.0 ,
2022-10-16 01:37:04 +03:00
variant_seed : int = None , ddim_eta : float = 0.0 , write_info_files : bool = True ,
use_stable_horde : bool = False , stable_horde_key : str = ' ' ) :
2022-09-15 03:17:07 +03:00
2022-10-02 19:46:14 +03:00
outpath = st . session_state [ ' defaults ' ] . general . outdir_txt2img
2022-09-15 03:17:07 +03:00
seed = seed_to_int ( seed )
2022-10-01 21:14:32 +03:00
2022-10-16 01:37:04 +03:00
if not use_stable_horde :
if sampler_name == ' PLMS ' :
sampler = PLMSSampler ( server_state [ " model " ] )
elif sampler_name == ' DDIM ' :
sampler = DDIMSampler ( server_state [ " model " ] )
elif sampler_name == ' k_dpm_2_a ' :
sampler = KDiffusionSampler ( server_state [ " model " ] , ' dpm_2_ancestral ' )
elif sampler_name == ' k_dpm_2 ' :
sampler = KDiffusionSampler ( server_state [ " model " ] , ' dpm_2 ' )
elif sampler_name == ' k_euler_a ' :
sampler = KDiffusionSampler ( server_state [ " model " ] , ' euler_ancestral ' )
elif sampler_name == ' k_euler ' :
sampler = KDiffusionSampler ( server_state [ " model " ] , ' euler ' )
elif sampler_name == ' k_heun ' :
sampler = KDiffusionSampler ( server_state [ " model " ] , ' heun ' )
elif sampler_name == ' k_lms ' :
sampler = KDiffusionSampler ( server_state [ " model " ] , ' lms ' )
else :
raise Exception ( " Unknown sampler: " + sampler_name )
def init ( ) :
pass
def sample ( init_data , x , conditioning , unconditional_conditioning , sampler_name ) :
samples_ddim , _ = sampler . sample ( S = ddim_steps , conditioning = conditioning , batch_size = int ( x . shape [ 0 ] ) , shape = x [ 0 ] . shape , verbose = False , unconditional_guidance_scale = cfg_scale ,
unconditional_conditioning = unconditional_conditioning , eta = ddim_eta , x_T = x ,
img_callback = generation_callback if not server_state [ " bridge " ] else None ,
log_every_t = int ( st . session_state . update_preview_frequency if not server_state [ " bridge " ] else 100 ) )
return samples_ddim
if use_stable_horde :
output_images , seed , info , stats = stable_horde (
prompt = prompt ,
seed = seed ,
outpath = outpath ,
sampler_name = sampler_name ,
save_grid = save_grid ,
batch_size = batch_size ,
n_iter = n_iter ,
steps = ddim_steps ,
cfg_scale = cfg_scale ,
width = width ,
height = height ,
prompt_matrix = separate_prompts ,
use_GFPGAN = use_GFPGAN ,
GFPGAN_model = GFPGAN_model ,
use_RealESRGAN = use_RealESRGAN ,
realesrgan_model_name = RealESRGAN_model ,
use_LDSR = use_LDSR ,
LDSR_model_name = LDSR_model ,
ddim_eta = ddim_eta ,
normalize_prompt_weights = normalize_prompt_weights ,
save_individual_images = save_individual_images ,
sort_samples = group_by_prompt ,
write_info_files = write_info_files ,
jpg_sample = save_as_jpg ,
variant_amount = variant_amount ,
variant_seed = variant_seed ,
api_key = stable_horde_key
)
2022-09-15 03:17:07 +03:00
else :
2022-10-16 01:37:04 +03:00
#try:
output_images , seed , info , stats = process_images (
outpath = outpath ,
func_init = init ,
func_sample = sample ,
prompt = prompt ,
seed = seed ,
sampler_name = sampler_name ,
save_grid = save_grid ,
batch_size = batch_size ,
n_iter = n_iter ,
steps = ddim_steps ,
cfg_scale = cfg_scale ,
width = width ,
height = height ,
prompt_matrix = separate_prompts ,
use_GFPGAN = use_GFPGAN ,
GFPGAN_model = GFPGAN_model ,
use_RealESRGAN = use_RealESRGAN ,
realesrgan_model_name = RealESRGAN_model ,
use_LDSR = use_LDSR ,
LDSR_model_name = LDSR_model ,
ddim_eta = ddim_eta ,
normalize_prompt_weights = normalize_prompt_weights ,
save_individual_images = save_individual_images ,
sort_samples = group_by_prompt ,
write_info_files = write_info_files ,
jpg_sample = save_as_jpg ,
variant_amount = variant_amount ,
variant_seed = variant_seed ,
)
del sampler
2022-09-15 03:17:07 +03:00
return output_images , seed , info , stats
#except RuntimeError as e:
#err = e
#err_msg = f'CRASHED:<br><textarea rows="5" style="color:white;background: black;width: -webkit-fill-available;font-family: monospace;font-size: small;font-weight: bold;">{str(e)}</textarea><br><br>Please wait while the program restarts.'
#stats = err_msg
#return [], seed, 'err', stats
2022-10-06 11:45:47 +03:00
2022-10-02 06:18:09 +03:00
#
2022-10-16 01:37:04 +03:00
#@logger.catch
2022-09-14 00:08:40 +03:00
def layout ( ) :
2022-09-15 03:17:07 +03:00
with st . form ( " txt2img-inputs " ) :
st . session_state [ " generation_mode " ] = " txt2img "
input_col1 , generate_col1 = st . columns ( [ 10 , 1 ] )
2022-09-15 16:29:41 +03:00
2022-09-15 03:17:07 +03:00
with input_col1 :
#prompt = st.text_area("Input Text","")
2022-10-09 13:21:06 +03:00
prompt = st . text_area ( " Input Text " , " " , placeholder = " A corgi wearing a top hat as an oil painting. " )
2022-09-15 03:17:07 +03:00
# creating the page layout using columns
2022-10-01 21:14:32 +03:00
col1 , col2 , col3 = st . columns ( [ 1 , 2 , 1 ] , gap = " large " )
2022-09-15 03:17:07 +03:00
with col1 :
2022-09-18 21:11:23 +03:00
width = st . slider ( " Width: " , min_value = st . session_state [ ' defaults ' ] . txt2img . width . min_value , max_value = st . session_state [ ' defaults ' ] . txt2img . width . max_value ,
value = st . session_state [ ' defaults ' ] . txt2img . width . value , step = st . session_state [ ' defaults ' ] . txt2img . width . step )
height = st . slider ( " Height: " , min_value = st . session_state [ ' defaults ' ] . txt2img . height . min_value , max_value = st . session_state [ ' defaults ' ] . txt2img . height . max_value ,
value = st . session_state [ ' defaults ' ] . txt2img . height . value , step = st . session_state [ ' defaults ' ] . txt2img . height . step )
cfg_scale = st . slider ( " CFG (Classifier Free Guidance Scale): " , min_value = st . session_state [ ' defaults ' ] . txt2img . cfg_scale . min_value ,
max_value = st . session_state [ ' defaults ' ] . txt2img . cfg_scale . max_value ,
2022-10-01 21:14:32 +03:00
value = st . session_state [ ' defaults ' ] . txt2img . cfg_scale . value , step = st . session_state [ ' defaults ' ] . txt2img . cfg_scale . step ,
2022-09-18 21:11:23 +03:00
help = " How strongly the image should follow the prompt. " )
2022-09-15 03:17:07 +03:00
seed = st . text_input ( " Seed: " , value = st . session_state [ ' defaults ' ] . txt2img . seed , help = " The seed to use, if left blank a random seed will be generated. " )
2022-10-01 21:14:32 +03:00
2022-09-26 14:53:34 +03:00
with st . expander ( " Batch Options " ) :
2022-10-02 23:10:17 +03:00
#batch_count = st.slider("Batch count.", min_value=st.session_state['defaults'].txt2img.batch_count.min_value, max_value=st.session_state['defaults'].txt2img.batch_count.max_value,
#value=st.session_state['defaults'].txt2img.batch_count.value, step=st.session_state['defaults'].txt2img.batch_count.step,
#help="How many iterations or batches of images to generate in total.")
#batch_size = st.slider("Batch size", min_value=st.session_state['defaults'].txt2img.batch_size.min_value, max_value=st.session_state['defaults'].txt2img.batch_size.max_value,
#value=st.session_state.defaults.txt2img.batch_size.value, step=st.session_state.defaults.txt2img.batch_size.step,
#help="How many images are at once in a batch.\
#It increases the VRAM usage a lot but if you have enough VRAM it can reduce the time it takes to finish generation as more images are generated at once.\
#Default: 1")
2022-10-06 11:45:47 +03:00
2022-10-08 03:57:06 +03:00
st . session_state [ " batch_count " ] = st . number_input ( " Batch count. " , value = st . session_state [ ' defaults ' ] . txt2img . batch_count . value ,
help = " How many iterations or batches of images to generate in total. " )
2022-10-06 11:45:47 +03:00
2022-10-08 03:57:06 +03:00
st . session_state [ " batch_size " ] = st . number_input ( " Batch size " , value = st . session_state . defaults . txt2img . batch_size . value ,
2022-10-03 07:25:41 +03:00
help = " How many images are at once in a batch. \
It increases the VRAM usage a lot but if you have enough VRAM it can reduce the time it takes \
to finish generation as more images are generated at once . \
2022-10-08 03:57:06 +03:00
Default : 1 " )
2022-09-15 03:17:07 +03:00
with st . expander ( " Preview Settings " ) :
2022-10-06 11:45:47 +03:00
2022-10-02 23:10:17 +03:00
st . session_state [ " update_preview " ] = st . session_state [ " defaults " ] . general . update_preview
2022-10-08 02:59:29 +03:00
st . session_state [ " update_preview_frequency " ] = st . number_input ( " Update Image Preview Frequency " ,
min_value = 1 ,
value = st . session_state [ ' defaults ' ] . txt2img . update_preview_frequency ,
help = " Frequency in steps at which the the preview image is updated. By default the frequency \
is set to 10 step . " )
2022-10-01 21:14:32 +03:00
2022-09-15 03:17:07 +03:00
with col2 :
preview_tab , gallery_tab = st . tabs ( [ " Preview " , " Gallery " ] )
with preview_tab :
#st.write("Image")
#Image for testing
#image = Image.open(requests.get("https://icon-library.com/images/image-placeholder-icon/image-placeholder-icon-13.jpg", stream=True).raw).convert('RGB')
#new_image = image.resize((175, 240))
#preview_image = st.image(image)
# create an empty container for the image, progress bar, etc so we can update it later and use session_state to hold them globally.
st . session_state [ " preview_image " ] = st . empty ( )
2022-10-06 11:45:47 +03:00
2022-09-15 03:17:07 +03:00
st . session_state [ " progress_bar_text " ] = st . empty ( )
2022-10-02 01:40:50 +03:00
st . session_state [ " progress_bar_text " ] . info ( " Nothing but crickets here, try generating something first. " )
2022-10-06 11:45:47 +03:00
2022-09-15 03:17:07 +03:00
st . session_state [ " progress_bar " ] = st . empty ( )
message = st . empty ( )
2022-10-06 11:45:47 +03:00
2022-10-02 01:40:50 +03:00
with gallery_tab :
2022-10-06 11:45:47 +03:00
st . session_state [ " gallery " ] = st . empty ( )
2022-10-02 01:40:50 +03:00
st . session_state [ " gallery " ] . info ( " Nothing but crickets here, try generating something first. " )
2022-09-15 16:29:41 +03:00
2022-09-15 03:17:07 +03:00
with col3 :
2022-10-01 21:14:32 +03:00
# If we have custom models available on the "models/custom"
2022-09-15 03:17:07 +03:00
#folder then we show a menu to select which model we want to use, otherwise we use the main model for SD
2022-09-25 01:27:09 +03:00
custom_models_available ( )
2022-10-01 21:14:32 +03:00
2022-09-29 13:29:44 +03:00
if server_state [ " CustomModel_available " ] :
st . session_state [ " custom_model " ] = st . selectbox ( " Custom Model: " , server_state [ " custom_models " ] ,
2022-09-25 10:03:05 +03:00
index = server_state [ " custom_models " ] . index ( st . session_state [ ' defaults ' ] . general . default_model ) ,
2022-09-18 21:11:23 +03:00
help = " Select the model you want to use. This option is only available if you have custom models \
on your ' models/custom ' folder . The model name that will be shown here is the same as the name \
the file for the model has on said folder , it is recommended to give the . ckpt file a name that \
2022-10-01 21:14:32 +03:00
will make it easier for you to distinguish it from other models . Default : Stable Diffusion v1 .4 " )
2022-10-06 11:45:47 +03:00
st . session_state . sampling_steps = st . number_input ( " Sampling Steps " , value = st . session_state . defaults . txt2img . sampling_steps . value ,
min_value = st . session_state . defaults . txt2img . sampling_steps . min_value ,
step = st . session_state [ ' defaults ' ] . txt2img . sampling_steps . step ,
help = " Set the default number of sampling steps to use. Default is: 30 (with k_euler) " )
2022-09-15 16:29:41 +03:00
2022-09-15 03:17:07 +03:00
sampler_name_list = [ " k_lms " , " k_euler " , " k_euler_a " , " k_dpm_2 " , " k_dpm_2_a " , " k_heun " , " PLMS " , " DDIM " ]
sampler_name = st . selectbox ( " Sampling method " , sampler_name_list ,
2022-10-01 21:14:32 +03:00
index = sampler_name_list . index ( st . session_state [ ' defaults ' ] . txt2img . default_sampler ) , help = " Sampling method to use. Default: k_euler " )
2022-09-15 03:17:07 +03:00
with st . expander ( " Advanced " ) :
2022-10-15 15:34:07 +03:00
with st . expander ( " Stable Horde " ) :
2022-10-16 01:37:04 +03:00
use_stable_horde = st . checkbox ( " Use Stable Horde " , value = False , help = " Use the Stable Horde to generate images. More info can be found at https://stablehorde.net/ " )
stable_horde_key = st . text_input ( " Stable Horde Api Key " , value = ' ' , type = " password " ,
help = " Optional Api Key used for the Stable Horde Bridge, if no api key is added the horde will be used anonymously. " )
2022-10-14 22:09:47 +03:00
2022-10-02 23:10:17 +03:00
with st . expander ( " Output Settings " ) :
separate_prompts = st . checkbox ( " Create Prompt Matrix. " , value = st . session_state [ ' defaults ' ] . txt2img . separate_prompts ,
help = " Separate multiple prompts using the `|` character, and get all combinations of them. " )
2022-10-06 11:45:47 +03:00
2022-10-02 23:10:17 +03:00
normalize_prompt_weights = st . checkbox ( " Normalize Prompt Weights. " , value = st . session_state [ ' defaults ' ] . txt2img . normalize_prompt_weights ,
help = " Ensure the sum of all weights add up to 1.0 " )
2022-10-06 11:45:47 +03:00
2022-10-02 23:10:17 +03:00
save_individual_images = st . checkbox ( " Save individual images. " , value = st . session_state [ ' defaults ' ] . txt2img . save_individual_images ,
help = " Save each image generated before any filter or enhancement is applied. " )
2022-10-06 11:45:47 +03:00
2022-10-02 23:10:17 +03:00
save_grid = st . checkbox ( " Save grid " , value = st . session_state [ ' defaults ' ] . txt2img . save_grid , help = " Save a grid with all the images generated into a single image. " )
group_by_prompt = st . checkbox ( " Group results by prompt " , value = st . session_state [ ' defaults ' ] . txt2img . group_by_prompt ,
help = " Saves all the images with the same prompt into the same folder. When using a prompt matrix each prompt combination will have its own folder. " )
2022-10-06 11:45:47 +03:00
2022-10-02 23:10:17 +03:00
write_info_files = st . checkbox ( " Write Info file " , value = st . session_state [ ' defaults ' ] . txt2img . write_info_files ,
help = " Save a file next to the image with informartion about the generation. " )
2022-10-06 11:45:47 +03:00
2022-10-02 23:10:17 +03:00
save_as_jpg = st . checkbox ( " Save samples as jpg " , value = st . session_state [ ' defaults ' ] . txt2img . save_as_jpg , help = " Saves the images as jpg instead of png. " )
2022-10-06 11:45:47 +03:00
2022-10-01 21:52:31 +03:00
# check if GFPGAN, RealESRGAN and LDSR are available.
2022-10-06 09:47:05 +03:00
#if "GFPGAN_available" not in st.session_state:
GFPGAN_available ( )
2022-10-06 11:45:47 +03:00
2022-10-06 09:47:05 +03:00
#if "RealESRGAN_available" not in st.session_state:
RealESRGAN_available ( )
2022-10-06 11:45:47 +03:00
2022-10-06 09:47:05 +03:00
#if "LDSR_available" not in st.session_state:
LDSR_available ( )
2022-10-06 11:45:47 +03:00
2022-10-02 06:18:09 +03:00
if st . session_state [ " GFPGAN_available " ] or st . session_state [ " RealESRGAN_available " ] or st . session_state [ " LDSR_available " ] :
2022-10-01 21:52:31 +03:00
with st . expander ( " Post-Processing " ) :
2022-10-02 06:18:09 +03:00
face_restoration_tab , upscaling_tab = st . tabs ( [ " Face Restoration " , " Upscaling " ] )
with face_restoration_tab :
# GFPGAN used for face restoration
if st . session_state [ " GFPGAN_available " ] :
#with st.expander("Face Restoration"):
#if st.session_state["GFPGAN_available"]:
#with st.expander("GFPGAN"):
st . session_state [ " use_GFPGAN " ] = st . checkbox ( " Use GFPGAN " , value = st . session_state [ ' defaults ' ] . txt2img . use_GFPGAN ,
help = " Uses the GFPGAN model to improve faces after the generation. \
This greatly improve the quality and consistency of faces but uses \
extra VRAM . Disable if you need the extra VRAM . " )
2022-10-06 11:45:47 +03:00
2022-10-02 06:18:09 +03:00
st . session_state [ " GFPGAN_model " ] = st . selectbox ( " GFPGAN model " , st . session_state [ " GFPGAN_models " ] ,
2022-10-06 11:45:47 +03:00
index = st . session_state [ " GFPGAN_models " ] . index ( st . session_state [ ' defaults ' ] . general . GFPGAN_model ) )
2022-10-02 06:18:09 +03:00
#st.session_state["GFPGAN_strenght"] = st.slider("Effect Strenght", min_value=1, max_value=100, value=1, step=1, help='')
2022-10-06 11:45:47 +03:00
2022-10-01 21:52:31 +03:00
else :
2022-10-06 11:45:47 +03:00
st . session_state [ " use_GFPGAN " ] = False
2022-10-02 06:18:09 +03:00
with upscaling_tab :
2022-10-05 22:23:31 +03:00
st . session_state [ ' use_upscaling ' ] = st . checkbox ( " Use Upscaling " , value = st . session_state [ ' defaults ' ] . txt2img . use_upscaling )
2022-10-06 11:45:47 +03:00
# RealESRGAN and LDSR used for upscaling.
2022-10-02 06:18:09 +03:00
if st . session_state [ " RealESRGAN_available " ] or st . session_state [ " LDSR_available " ] :
2022-10-06 11:45:47 +03:00
2022-10-02 06:18:09 +03:00
upscaling_method_list = [ ]
if st . session_state [ " RealESRGAN_available " ] :
upscaling_method_list . append ( " RealESRGAN " )
if st . session_state [ " LDSR_available " ] :
upscaling_method_list . append ( " LDSR " )
2022-10-06 11:45:47 +03:00
2022-10-03 07:25:41 +03:00
#print (st.session_state["RealESRGAN_available"])
2022-10-02 06:18:09 +03:00
st . session_state [ " upscaling_method " ] = st . selectbox ( " Upscaling Method " , upscaling_method_list ,
2022-10-03 07:25:41 +03:00
index = upscaling_method_list . index ( str ( st . session_state [ ' defaults ' ] . general . upscaling_method ) ) )
2022-10-06 11:45:47 +03:00
2022-10-02 06:18:09 +03:00
if st . session_state [ " RealESRGAN_available " ] :
2022-10-03 06:26:01 +03:00
with st . expander ( " RealESRGAN " ) :
2022-10-05 22:23:31 +03:00
if st . session_state [ " upscaling_method " ] == " RealESRGAN " and st . session_state [ ' use_upscaling ' ] :
2022-10-03 06:26:01 +03:00
st . session_state [ " use_RealESRGAN " ] = True
else :
st . session_state [ " use_RealESRGAN " ] = False
2022-10-06 11:45:47 +03:00
2022-10-03 06:26:01 +03:00
st . session_state [ " RealESRGAN_model " ] = st . selectbox ( " RealESRGAN model " , st . session_state [ " RealESRGAN_models " ] ,
2022-10-06 11:45:47 +03:00
index = st . session_state [ " RealESRGAN_models " ] . index ( st . session_state [ ' defaults ' ] . general . RealESRGAN_model ) )
2022-10-02 06:18:09 +03:00
else :
st . session_state [ " use_RealESRGAN " ] = False
st . session_state [ " RealESRGAN_model " ] = " RealESRGAN_x4plus "
2022-10-06 11:45:47 +03:00
2022-10-02 06:18:09 +03:00
#
if st . session_state [ " LDSR_available " ] :
2022-10-03 06:26:01 +03:00
with st . expander ( " LDSR " ) :
2022-10-05 22:23:31 +03:00
if st . session_state [ " upscaling_method " ] == " LDSR " and st . session_state [ ' use_upscaling ' ] :
2022-10-03 06:26:01 +03:00
st . session_state [ " use_LDSR " ] = True
else :
st . session_state [ " use_LDSR " ] = False
2022-10-06 11:45:47 +03:00
2022-10-03 06:26:01 +03:00
st . session_state [ " LDSR_model " ] = st . selectbox ( " LDSR model " , st . session_state [ " LDSR_models " ] ,
2022-10-06 11:45:47 +03:00
index = st . session_state [ " LDSR_models " ] . index ( st . session_state [ ' defaults ' ] . general . LDSR_model ) )
2022-10-08 03:57:06 +03:00
st . session_state [ " ldsr_sampling_steps " ] = st . number_input ( " Sampling Steps " , value = st . session_state [ ' defaults ' ] . txt2img . LDSR_config . sampling_steps ,
help = " " )
2022-10-06 11:45:47 +03:00
2022-10-08 03:57:06 +03:00
st . session_state [ " preDownScale " ] = st . number_input ( " PreDownScale " , value = st . session_state [ ' defaults ' ] . txt2img . LDSR_config . preDownScale ,
help = " " )
2022-10-06 11:45:47 +03:00
2022-10-08 03:57:06 +03:00
st . session_state [ " postDownScale " ] = st . number_input ( " postDownScale " , value = st . session_state [ ' defaults ' ] . txt2img . LDSR_config . postDownScale ,
help = " " )
2022-10-06 11:45:47 +03:00
2022-10-03 06:26:01 +03:00
downsample_method_list = [ ' Nearest ' , ' Lanczos ' ]
st . session_state [ " downsample_method " ] = st . selectbox ( " Downsample Method " , downsample_method_list ,
index = downsample_method_list . index ( st . session_state [ ' defaults ' ] . txt2img . LDSR_config . downsample_method ) )
2022-10-06 11:45:47 +03:00
2022-10-02 06:18:09 +03:00
else :
st . session_state [ " use_LDSR " ] = False
2022-10-06 11:45:47 +03:00
st . session_state [ " LDSR_model " ] = " model "
2022-09-26 14:53:34 +03:00
with st . expander ( " Variant " ) :
variant_amount = st . slider ( " Variant Amount: " , value = st . session_state [ ' defaults ' ] . txt2img . variant_amount . value ,
min_value = st . session_state [ ' defaults ' ] . txt2img . variant_amount . min_value , max_value = st . session_state [ ' defaults ' ] . txt2img . variant_amount . max_value ,
step = st . session_state [ ' defaults ' ] . txt2img . variant_amount . step )
2022-10-02 01:40:50 +03:00
variant_seed = st . text_input ( " Variant Seed: " , value = st . session_state [ ' defaults ' ] . txt2img . seed ,
help = " The seed to use when generating a variant, if left blank a random seed will be generated. " )
2022-10-01 21:14:32 +03:00
2022-09-26 14:53:34 +03:00
#galleryCont = st.empty()
2022-09-15 03:17:07 +03:00
2022-09-29 13:29:44 +03:00
# Every form must have a submit button, the extra blank spaces is a temp way to align it with the input field. Needs to be done in CSS or some other way.
generate_col1 . write ( " " )
generate_col1 . write ( " " )
2022-10-01 21:14:32 +03:00
generate_button = generate_col1 . form_submit_button ( " Generate " )
2022-09-29 13:29:44 +03:00
2022-10-02 06:18:09 +03:00
#
2022-10-06 11:45:47 +03:00
if generate_button :
2022-09-28 19:33:54 +03:00
with col2 :
2022-10-16 01:37:04 +03:00
if not use_stable_horde :
with hc . HyLoader ( ' Loading Models... ' , hc . Loaders . standard_loaders , index = [ 0 ] ) :
load_models ( use_LDSR = st . session_state [ " use_LDSR " ] , LDSR_model = st . session_state [ " LDSR_model " ] ,
use_GFPGAN = st . session_state [ " use_GFPGAN " ] , GFPGAN_model = st . session_state [ " GFPGAN_model " ] ,
use_RealESRGAN = st . session_state [ " use_RealESRGAN " ] , RealESRGAN_model = st . session_state [ " RealESRGAN_model " ] ,
CustomModel_available = server_state [ " CustomModel_available " ] , custom_model = st . session_state [ " custom_model " ] )
2022-10-02 17:54:56 +03:00
2022-10-02 19:46:14 +03:00
#print(st.session_state['use_RealESRGAN'])
#print(st.session_state['use_LDSR'])
#try:
#
2022-10-06 11:45:47 +03:00
2022-10-02 23:10:17 +03:00
output_images , seeds , info , stats = txt2img ( prompt , st . session_state . sampling_steps , sampler_name , st . session_state [ " batch_count " ] , st . session_state [ " batch_size " ] ,
2022-10-02 19:46:14 +03:00
cfg_scale , seed , height , width , separate_prompts , normalize_prompt_weights , save_individual_images ,
2022-10-06 11:45:47 +03:00
save_grid , group_by_prompt , save_as_jpg , st . session_state [ " use_GFPGAN " ] , st . session_state [ ' GFPGAN_model ' ] ,
2022-10-02 19:46:14 +03:00
use_RealESRGAN = st . session_state [ " use_RealESRGAN " ] , RealESRGAN_model = st . session_state [ " RealESRGAN_model " ] ,
2022-10-06 11:45:47 +03:00
use_LDSR = st . session_state [ " use_LDSR " ] , LDSR_model = st . session_state [ " LDSR_model " ] ,
2022-10-16 01:37:04 +03:00
variant_amount = variant_amount , variant_seed = variant_seed , write_info_files = write_info_files ,
use_stable_horde = use_stable_horde , stable_horde_key = stable_horde_key )
2022-10-02 19:46:14 +03:00
message . success ( ' Render Complete: ' + info + ' ; Stats: ' + stats , icon = " ✅ " )
2022-10-02 06:18:09 +03:00
#history_tab,col1,col2,col3,PlaceHolder,col1_cont,col2_cont,col3_cont = st.session_state['historyTab']
#if 'latestImages' in st.session_state:
#for i in output_images:
##push the new image to the list of latest images and remove the oldest one
##remove the last index from the list\
#st.session_state['latestImages'].pop()
##add the new image to the start of the list
#st.session_state['latestImages'].insert(0, i)
#PlaceHolder.empty()
#with PlaceHolder.container():
#col1, col2, col3 = st.columns(3)
#col1_cont = st.container()
#col2_cont = st.container()
#col3_cont = st.container()
#images = st.session_state['latestImages']
#with col1_cont:
#with col1:
#[st.image(images[index]) for index in [0, 3, 6] if index < len(images)]
#with col2_cont:
#with col2:
#[st.image(images[index]) for index in [1, 4, 7] if index < len(images)]
#with col3_cont:
#with col3:
#[st.image(images[index]) for index in [2, 5, 8] if index < len(images)]
#historyGallery = st.empty()
## check if output_images length is the same as seeds length
#with gallery_tab:
#st.markdown(createHTMLGallery(output_images,seeds), unsafe_allow_html=True)
#st.session_state['historyTab'] = [history_tab,col1,col2,col3,PlaceHolder,col1_cont,col2_cont,col3_cont]
2022-10-06 11:45:47 +03:00
2022-10-02 06:18:09 +03:00
with gallery_tab :
2022-10-15 15:34:07 +03:00
logger . info ( seeds )
2022-10-02 06:18:09 +03:00
sdGallery ( output_images )
2022-10-06 11:45:47 +03:00
2022-10-01 21:14:32 +03:00
2022-10-02 06:18:09 +03:00
#except (StopException, KeyError):
#print(f"Received Streamlit StopException")
2022-10-01 21:14:32 +03:00
2022-09-15 16:29:41 +03:00
# this will render all the images at the end of the generation but its better if its moved to a second tab inside col2 and shown as a gallery.
# use the current col2 first tab to show the preview_img and update it as its generated.
#preview_image.image(output_images)
2022-09-14 00:08:40 +03:00
2022-10-01 21:14:32 +03:00