2
from typing import Optional
3
from transformers.utils.versions import require_version
5
from llmtuner.webui.components import (
13
from llmtuner.webui.common import save_config
14
from llmtuner.webui.css import CSS
15
from llmtuner.webui.engine import Engine
18
require_version("gradio>=3.38.0,<4.0.0", "To fix: pip install \"gradio>=3.38.0,<4.0.0\"")
21
def create_ui(demo_mode: Optional[bool] = False) -> gr.Blocks:
22
engine = Engine(demo_mode=demo_mode, pure_chat=False)
24
with gr.Blocks(title="LLaMA Board", css=CSS) as demo:
27
"<h1><center>LLaMA Board: A One-stop Web UI for Getting Started with LLaMA Factory</center></h1>"
30
"<h3><center>Visit <a href=\"https://github.com/hiyouga/LLaMA-Factory\" target=\"_blank\">"
31
"LLaMA Factory</a> for details.</center></h3>"
33
gr.DuplicateButton(value="Duplicate Space for private use", elem_classes="duplicate-button")
35
engine.manager.all_elems["top"] = create_top()
36
lang: "gr.Dropdown" = engine.manager.get_elem_by_name("top.lang")
39
engine.manager.all_elems["train"] = create_train_tab(engine)
41
with gr.Tab("Evaluate & Predict"):
42
engine.manager.all_elems["eval"] = create_eval_tab(engine)
45
engine.manager.all_elems["infer"] = create_infer_tab(engine)
48
with gr.Tab("Export"):
49
engine.manager.all_elems["export"] = create_export_tab(engine)
51
demo.load(engine.resume, outputs=engine.manager.list_elems())
52
lang.change(engine.change_lang, [lang], engine.manager.list_elems(), queue=False)
53
lang.input(save_config, inputs=[lang], queue=False)
58
def create_web_demo() -> gr.Blocks:
59
engine = Engine(pure_chat=True)
61
with gr.Blocks(title="Web Demo", css=CSS) as demo:
62
lang = gr.Dropdown(choices=["en", "zh"])
63
engine.manager.all_elems["top"] = dict(lang=lang)
65
chat_box, _, _, chat_elems = create_chat_box(engine, visible=True)
66
engine.manager.all_elems["infer"] = dict(chat_box=chat_box, **chat_elems)
68
demo.load(engine.resume, outputs=engine.manager.list_elems())
69
lang.change(engine.change_lang, [lang], engine.manager.list_elems(), queue=False)
70
lang.input(save_config, inputs=[lang], queue=False)
75
if __name__ == "__main__":
78
demo.launch(server_name="0.0.0.0", server_port=7860, share=False, inbrowser=True)