Spaces:
Running
on
Zero
Running
on
Zero
import spaces | |
import gradio as gr | |
from tagger.utils import gradio_copy_text, COPY_ACTION_JS | |
from tagger.tagger import convert_danbooru_to_e621_prompt, insert_recom_prompt | |
from genimage import generate_image | |
from llmdolphin import (get_llm_formats, get_dolphin_model_format, | |
get_dolphin_models, get_dolphin_model_info, select_dolphin_model, | |
select_dolphin_format, add_dolphin_models, get_dolphin_sysprompt, | |
get_dolphin_sysprompt_mode, select_dolphin_sysprompt, get_dolphin_languages, | |
select_dolphin_language, dolphin_respond, dolphin_parse, respond_playground) | |
css = """ | |
.title { text-align: center; } | |
""" | |
with gr.Blocks(theme='NoCrypt/miku@>=1.2.2', fill_width=True, css=css, delete_cache=(60, 3600)) as app: | |
with gr.Tab("Prompt Translator"): | |
with gr.Column(): | |
gr.Markdown("""# Natural Text to SD Prompt Translator With LLM alpha | |
Text in natural language (English, Japanese, ...) => Prompt | |
""", elem_classes="title") | |
state = gr.State(value={}) | |
with gr.Group(): | |
chatbot = gr.Chatbot(show_copy_button=True, show_share_button=False, layout="bubble", container=True) | |
with gr.Row(): | |
chat_msg = gr.Textbox(show_label=False, placeholder="Input text in English, Japanese, or any other languages and press Enter or click Send.", scale=4) | |
chat_submit = gr.Button("Send", scale=1, variant="primary") | |
chat_clear = gr.Button("Clear", scale=1, variant="secondary") | |
with gr.Accordion("Additional inputs", open=False): | |
chat_format = gr.Dropdown(choices=get_llm_formats(), value=get_dolphin_model_format(get_dolphin_models()[0][1]), label="Message format") | |
chat_sysmsg = gr.Textbox(value=get_dolphin_sysprompt(), label="System message") | |
with gr.Row(): | |
chat_tokens = gr.Slider(minimum=1, maximum=4096, value=512, step=1, label="Max tokens") | |
chat_temperature = gr.Slider(minimum=0.1, maximum=4.0, value=0.7, step=0.1, label="Temperature") | |
chat_topp = gr.Slider(minimum=0.1, maximum=1.0, value=0.95, step=0.05, label="Top-p") | |
chat_topk = gr.Slider(minimum=0, maximum=100, value=40, step=1, label="Top-k") | |
chat_rp = gr.Slider(minimum=0.0, maximum=2.0, value=1.1, step=0.1, label="Repetition penalty") | |
with gr.Accordion("Add models", open=False): | |
chat_add_text = gr.Textbox(label="URL or Repo ID", placeholder="https://huggingface.co/mradermacher/MagnumChronos-i1-GGUF/blob/main/MagnumChronos.i1-Q4_K_M.gguf", lines=1) | |
chat_add_format = gr.Dropdown(choices=get_llm_formats(), value=get_llm_formats()[0], label="Message format") | |
chat_add_submit = gr.Button("Update lists of models") | |
with gr.Accordion("Modes", open=True): | |
chat_model = gr.Dropdown(choices=get_dolphin_models(), value=get_dolphin_models()[0][1], allow_custom_value=True, label="Model") | |
chat_model_info = gr.Markdown(value=get_dolphin_model_info(get_dolphin_models()[0][1]), label="Model info") | |
with gr.Row(): | |
chat_mode = gr.Dropdown(choices=get_dolphin_sysprompt_mode(), value=get_dolphin_sysprompt_mode()[0], allow_custom_value=False, label="Mode") | |
chat_lang = gr.Dropdown(choices=get_dolphin_languages(), value="English", allow_custom_value=True, label="Output language") | |
with gr.Row(): | |
with gr.Group(): | |
output_text = gr.TextArea(label="Output tags", interactive=False, show_copy_button=True) | |
copy_btn = gr.Button(value="Copy to clipboard", size="sm", interactive=False) | |
with gr.Group(): | |
output_text_pony = gr.TextArea(label="Output tags (Pony e621 style)", interactive=False, show_copy_button=True) | |
copy_btn_pony = gr.Button(value="Copy to clipboard", size="sm", interactive=False) | |
with gr.Accordion(label="Advanced options", open=False, visible=False): | |
tag_type = gr.Radio(label="Output tag conversion", info="danbooru for Animagine, e621 for Pony.", choices=["danbooru", "e621"], value="e621", visible=False) | |
dummy_np = gr.Textbox(label="Negative prompt", value="", visible=False) | |
dummy_np_pony = gr.Textbox(label="Negative prompt", value="", visible=False) | |
recom_animagine = gr.Textbox(label="Animagine reccomended prompt", value="Animagine", visible=False) | |
recom_pony = gr.Textbox(label="Pony reccomended prompt", value="Pony", visible=False) | |
generate_image_btn = gr.Button(value="GENERATE IMAGE", size="lg", variant="primary") | |
with gr.Row(): | |
result_image = gr.Gallery(label="Generated images", columns=1, object_fit="contain", container=True, preview=True, height=512, | |
show_label=False, show_share_button=False, show_download_button=True, interactive=False, visible=True, format="png") | |
with gr.Tab("GGUF-Playground"): | |
gr.Markdown("""# Chat with lots of Models and LLMs using llama.cpp | |
This tab is copy of [CaioXapelaum/GGUF-Playground](https://huggingface.co/spaces/CaioXapelaum/GGUF-Playground).<br> | |
Don't worry about the strange appearance, **it's just a bug of Gradio!**""", elem_classes="title") | |
pg_chatbot = gr.Chatbot(scale=1, likeable=False, show_copy_button=True, show_share_button=False) | |
with gr.Accordion("Additional inputs", open=False): | |
pg_chat_model = gr.Dropdown(choices=get_dolphin_models(), value=get_dolphin_models()[0][1], allow_custom_value=True, label="Model") | |
pg_chat_model_info = gr.Markdown(value=get_dolphin_model_info(get_dolphin_models()[0][1]), label="Model info") | |
pg_chat_format = gr.Dropdown(choices=get_llm_formats(), value=get_dolphin_model_format(get_dolphin_models()[0][1]), label="Message format") | |
pg_chat_sysmsg = gr.Textbox(value="You are a helpful assistant.", label="System message") | |
with gr.Row(): | |
pg_chat_tokens = gr.Slider(minimum=1, maximum=4096, value=2048, step=1, label="Max tokens") | |
pg_chat_temperature = gr.Slider(minimum=0.1, maximum=4.0, value=0.7, step=0.1, label="Temperature") | |
pg_chat_topp = gr.Slider(minimum=0.1, maximum=1.0, value=0.95, step=0.05, label="Top-p") | |
pg_chat_topk = gr.Slider(minimum=0, maximum=100, value=40, step=1, label="Top-k") | |
pg_chat_rp = gr.Slider(minimum=0.0, maximum=2.0, value=1.1, step=0.1, label="Repetition penalty") | |
with gr.Accordion("Add models", open=True): | |
pg_chat_add_text = gr.Textbox(label="URL or Repo ID", placeholder="https://huggingface.co/mradermacher/MagnumChronos-i1-GGUF/blob/main/MagnumChronos.i1-Q4_K_M.gguf", lines=1) | |
pg_chat_add_format = gr.Dropdown(choices=get_llm_formats(), value=get_llm_formats()[0], label="Message format") | |
pg_chat_add_submit = gr.Button("Update lists of models") | |
gr.ChatInterface( | |
fn=respond_playground, | |
#title="Chat with lots of Models and LLMs using llama.cpp", | |
retry_btn="Retry", | |
undo_btn="Undo", | |
clear_btn="Clear", | |
submit_btn="Send", | |
#additional_inputs_accordion='gr.Accordion(label="Additional Inputs", open=False)', | |
additional_inputs=[pg_chat_model, pg_chat_sysmsg, pg_chat_tokens, pg_chat_temperature, pg_chat_topp, pg_chat_topk, pg_chat_rp, state], | |
chatbot=pg_chatbot | |
) | |
gr.LoginButton() | |
gr.DuplicateButton(value="Duplicate Space for private use (This demo does not work on CPU. Requires GPU Space)") | |
gr.on( | |
triggers=[chat_msg.submit, chat_submit.click], | |
fn=dolphin_respond, | |
inputs=[chat_msg, chatbot, chat_model, chat_sysmsg, chat_tokens, chat_temperature, chat_topp, chat_topk, chat_rp, state], | |
outputs=[chatbot], | |
queue=True, | |
show_progress="full", | |
trigger_mode="once", | |
).success(dolphin_parse, [chatbot, state], [output_text, copy_btn, copy_btn_pony]).success( | |
convert_danbooru_to_e621_prompt, [output_text, tag_type], [output_text_pony], queue=False, | |
).success(insert_recom_prompt, [output_text, dummy_np, recom_animagine], [output_text, dummy_np], queue=False, | |
).success(insert_recom_prompt, [output_text_pony, dummy_np_pony, recom_pony], [output_text_pony, dummy_np_pony], queue=False) | |
chat_clear.click(lambda: None, None, chatbot, queue=False) | |
chat_model.change(select_dolphin_model, [chat_model, state], [chat_model, chat_format, chat_model_info, state], queue=True, show_progress="full")\ | |
.success(lambda: None, None, chatbot, queue=False) | |
chat_format.change(select_dolphin_format, [chat_format, state], [chat_format, state], queue=False)\ | |
.success(lambda: None, None, chatbot, queue=False) | |
chat_mode.change(select_dolphin_sysprompt, [chat_mode, state], [chat_sysmsg, state], queue=False) | |
chat_lang.change(select_dolphin_language, [chat_lang, state], [chat_sysmsg, state], queue=False) | |
gr.on( | |
triggers=[chat_add_text.submit, chat_add_submit.click], | |
fn=add_dolphin_models, | |
inputs=[chat_add_text, chat_add_format], | |
outputs=[chat_model], | |
queue=True, | |
trigger_mode="once", | |
) | |
copy_btn.click(gradio_copy_text, [output_text], js=COPY_ACTION_JS) | |
copy_btn_pony.click(gradio_copy_text, [output_text_pony], js=COPY_ACTION_JS) | |
generate_image_btn.click(generate_image, [output_text, dummy_np], [result_image], show_progress="full") | |
pg_chat_model.change(select_dolphin_model, [pg_chat_model, state], [pg_chat_model, pg_chat_format, pg_chat_model_info, state], queue=True, show_progress="full") | |
pg_chat_format.change(select_dolphin_format, [pg_chat_format, state], [pg_chat_format, state], queue=False) | |
gr.on( | |
triggers=[pg_chat_add_text.submit, pg_chat_add_submit.click], | |
fn=add_dolphin_models, | |
inputs=[pg_chat_add_text, pg_chat_add_format], | |
outputs=[pg_chat_model], | |
queue=True, | |
trigger_mode="once", | |
) | |
if __name__ == "__main__": | |
app.queue() | |
app.launch() | |