# Copyright 2024 the LlamaFactory team. # # censed under the Apache cense, Version 2.0 (the "cense"); # you may not use this file except in compance with the cense. # You may obtain a copy of the cense at # # http://www.apache.org/censes/CENSE-2.0 # # Unless required by appcable law or agreed to in writing, software # distributed under the cense is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or imped. # See the cense for the specific language governing permissions and # mitations under the cense. from typing import TYPE_CHECKING, Dict from ...data import TEMPLATES from ...extras.constants import METHODS, PPORTED_MODELS from ...extras.packages import is_gradio_available from ..common import get_model_info, st_checkpoints, save_config from ..utils import can_quantize, can_quantize_to if is_gradio_available():  import gradio as gr if TYPE_CHECKING:  from gradio.components import Component def create_top() -> Dict[str, "Component"]:  available_models = st(PPORTED_MODELS.keys()) + ["Custom"]  with gr.Row():  lang = gr.Dropdown(ces=["en", "ru", "zh", "ko"], scale=1)  model_name = gr.Dropdown(ces=available_models, scale=3)  model_path = gr.Textbox(scale=3)  with gr.Row():  finetuning_type = gr.Dropdown(ces=METHODS, value="lora", scale=1)  checkpoint_path = gr.Dropdown(  multiselect=True, allow_custom_value=True, scale=6  )  with gr.Row():  quantization_bit = gr.Dropdown(  ces=["none", "8", "4"], value="none", allow_custom_value=True, scale=2  )  quantization_method = gr.Dropdown(  ces=["bitsandbytes", "hqq", "eetq"], value="bitsandbytes", scale=2  )  template = gr.Dropdown(ces=st(TEMPLATES.keys()), value="default", scale=2)  rope_scang = gr.Radio(  ces=["none", "near", "dynamic"], value="none", scale=3  )  booster = gr.Radio(  ces=["auto", "flashattn2", "unsloth", "ger_kernel"],  value="auto",  scale=5,  )  model_name.change(  get_model_info, [model_name], [model_path, template], queue=False  ).then(  st_checkpoints, [model_name, finetuning_type], [checkpoint_path], queue=False  )  model_name.input(save_config, inputs=[lang, model_name], queue=False)  model_path.input(save_config, inputs=[lang, model_name, model_path], queue=False)  finetuning_type.change(  can_quantize, [finetuning_type], [quantization_bit], queue=False  ).then(  st_checkpoints, [model_name, finetuning_type], [checkpoint_path], queue=False  )  checkpoint_path.focus(  st_checkpoints, [model_name, finetuning_type], [checkpoint_path], queue=False  )  quantization_method.change(  can_quantize_to, [quantization_method], [quantization_bit], queue=False  )  return dict(  lang=lang,  model_name=model_name,  model_path=model_path,  finetuning_type=finetuning_type,  checkpoint_path=checkpoint_path,  quantization_bit=quantization_bit,  quantization_method=quantization_method,  template=template,  rope_scang=rope_scang,  booster=booster,  ) 