import os import gradio as gr from random import randint from all_models import models from datetime import datetime from threading import RLock lock = RLock() now2 = 0 nb_models=24 def split_models(models,nb_models): models_temp=[] models_lis_temp=[] i=0 for m in models: models_temp.append(m) i=i+1 if i%nb_models==0: models_lis_temp.append(models_temp) models_temp=[] if len(models_temp)>1: models_lis_temp.append(models_temp) return models_lis_temp def split_models_axb(models,a,b): models_temp=[] models_lis_temp=[] i=0 nb_models=b for m in models: for j in range(a): models_temp.append(m) i=i+1 if i%nb_models==0: models_lis_temp.append(models_temp) models_temp=[] if len(models_temp)>1: models_lis_temp.append(models_temp) return models_lis_temp , a*b def split_models_8x3(models,nb_models): models_temp=[] models_lis_temp=[] i=0 nb_models_x3=8 for m in models: models_temp.append(m) i=i+1 if i%nb_models_x3==0: models_lis_temp.append(models_temp+models_temp+models_temp) models_temp=[] if len(models_temp)>1: models_lis_temp.append(models_temp+models_temp+models_temp) return models_lis_temp """models_test=split_models_x3(models,nb_models)""" """models_test=split_models(models,nb_models)""" models_test , nb_models =split_models_axb(models,2,20) def get_current_time(): now = datetime.now() now2 = now current_time = now2.strftime("%Y-%m-%d %H:%M:%S") ki = f'{kii} {current_time}' return ki def load_fn(models): global models_load global num_models global default_models models_load = {} num_models = len(models) if num_models!=0: default_models = models[:num_models] else: default_models = {} for model in models: if model not in models_load.keys(): try: m = gr.load(f'models/{model}') except Exception as error: m = gr.Interface(lambda txt: None, ['text'], ['image']) models_load.update({model: m}) """models = models_test[1]""" load_fn(models) """models = {} load_fn(models)""" def extend_choices(choices): return choices + (nb_models - len(choices)) * ['NA'] """return choices + (num_models - len(choices)) * ['NA']""" def extend_choices_b(choices): choices_plus = extend_choices(choices) return [gr.Textbox(m, visible=False) for m in choices_plus] def update_imgbox(choices): choices_plus = extend_choices(choices) return [gr.Image(None, label=m, visible=(m != 'NA')) for m in choices_plus] def choice_group_a(group_model_choice): for m in models_test: if group_model_choice==m[1]: choice=m print(choice) return choice def choice_group_b(group_model_choice): choice=choice_group_a(group_model_choice) choice = extend_choices(choice) """return [gr.Image(label=m, min_width=170, height=170) for m in choice]""" return [gr.Image(None, label=m, visible=(m != 'NA')) for m in choice] def choice_group_c(group_model_choice): choice=choice_group_a(group_model_choice) choice = extend_choices(choice) return [gr.Textbox(m, visible=False) for m in choice] def choice_group_d(var_Test): (gen_button,stop_button,output,current_models)=var_Test for m, o in zip(current_models, output): gen_event = gen_button.click(gen_fn, [m, txt_input], o) stop_button.click(lambda s: gr.update(interactive=False), None, stop_button, cancels=[gen_event]) return gen_event def test_pass(test): if test==os.getenv('p'): print("ok") return gr.Dropdown(label="test Model", show_label=False, choices=list(models_test) , allow_custom_value=True) else: print("nop") return gr.Dropdown(label="test Model", show_label=False, choices=list([]) , allow_custom_value=True) def gen_fn(model_str, prompt): if model_str == 'NA': return None noise = str(randint(0, 9999)) try : m=models_load[model_str](f'{prompt} {noise}') except Exception as error : print("error : " + model_str) m=False return m def add_gallery(image, model_str, gallery): if gallery is None: gallery = [] with lock: if image is not None: gallery.insert(0, (image, model_str)) return gallery def make_me(): # with gr.Tab('The Dream'): with gr.Row(): #txt_input = gr.Textbox(lines=3, width=300, max_height=100) txt_input = gr.Textbox(label='Your prompt:', lines=3, width=300, max_height=100) gen_button = gr.Button('Generate images', width=150, height=30) stop_button = gr.Button('Stop', variant='secondary', interactive=False, width=150, height=30) gen_button.click(lambda s: gr.update(interactive=True), None, stop_button) gr.HTML("""
""") with gr.Row(): """output = [gr.Image(label=m, min_width=170, height=170) for m in default_models] current_models = [gr.Textbox(m, visible=False) for m in default_models]""" """choices=[models_test[0][0]]""" choices=models_test[0] """output = [gr.Image(label=m, min_width=170, height=170) for m in choices] current_models = [gr.Textbox(m, visible=False) for m in choices]""" output = update_imgbox([choices[0]]) current_models = extend_choices_b([choices[0]]) #with gr.Row(): # gallery = gr.Gallery(label="Output", show_download_button=True, elem_classes="gallery", # interactive=False, show_share_button=True, container=True, format="png", # preview=True, object_fit="cover", columns=2, rows=2) for m, o in zip(current_models, output): gen_event = gen_button.click(gen_fn, [m, txt_input], o) stop_button.click(lambda s: gr.update(interactive=False), None, stop_button, cancels=[gen_event]) #o.change(add_gallery, [o, m, gallery], [gallery]) """with gr.Accordion('Model selection'): model_choice = gr.CheckboxGroup(models, label=f' {num_models} different models selected', value=default_models, multiselect=True, max_choices=num_models, interactive=True, filterable=False) model_choice.change(update_imgbox, (gen_button,stop_button,group_model_choice), output) model_choice.change(extend_choices, model_choice, current_models) """ with gr.Accordion("test", open=True): """group_model_choice = gr.Dropdown(label="test Model", show_label=False, choices=list(models_test) , allow_custom_value=True)""" group_model_choice = gr.Dropdown(label="test Model", show_label=False, choices=list([]) , allow_custom_value=True) group_model_choice.change(choice_group_b,group_model_choice,output) group_model_choice.change(choice_group_c,group_model_choice,current_models) """group_model_choice.change(choice_group_d,(gen_button,stop_button,output,current_models),gen_event)""" with gr.Row(): txt_input_p = gr.Textbox(label='test', lines=1, width=300, max_height=100) test_button = gr.Button('test', width=30, height=10) test_button.click(test_pass,txt_input_p,group_model_choice) with gr.Row(): gr.HTML("""