ChatGLM3 / composite_demo /README_en.md
kakuguo's picture
Upload 52 files
afd4069

A newer version of the Gradio SDK is available: 5.5.0

Upgrade

ChatGLM3 Web Demo

Demo webpage

Installation

We recommend managing environments through Conda.

Execute the following commands to create a new conda environment and install the necessary dependencies:

conda create -n chatglm3-demo python=3.10
conda activate chatglm3-demo
pip install -r requirements.txt

Please note that this project requires Python 3.10 or higher.

Additionally, installing the Jupyter kernel is required for using the Code Interpreter:

ipython kernel install --name chatglm3-demo --user

Execution

Run the following command to load the model locally and start the demo:

streamlit run main.py

Afterward, the address of the demo can be seen from the command line; click to access. The first visit requires the download and loading of the model, which may take some time.

If the model has already been downloaded locally, you can specify to load the model locally through export MODEL_PATH=/path/to/model. If you need to customize the Jupyter kernel, you can specify it through export IPYKERNEL=<kernel_name>.

Usage

ChatGLM3 Demo has three modes:

  • Chat: Dialogue mode, where you can interact with the model.
  • Tool: Tool mode, where the model, in addition to dialogue, can perform other operations through tools.
  • Code Interpreter: Code interpreter mode, where the model can execute code in a Jupyter environment and obtain results to complete complex tasks.

Dialogue Mode

In dialogue mode, users can directly modify parameters such as top_p, temperature, System Prompt in the sidebar to adjust the behavior of the model. For example,

The model responses following system prompt

Tool Mode

You can enhance the model's capabilities by registering new tools in tool_registry.py. Just use the @register_tool decorator to complete the registration. For tool declarations, the function name is the name of the tool, and the function docstring is the description of the tool; for tool parameters, use Annotated[typ: type, description: str, required: bool] to annotate the type, description, and whether it is necessary of the parameters.

For example, the registration of the get_weather tool is as follows:

@register_tool
def get_weather(
    city_name: Annotated[str, 'The name of the city to be queried', True],
) -> str:
    """
    Get the weather for `city_name` in the following week
    """
    ...

The model uses tool to query the weather of pairs.

Additionally, you can enter the manual mode through Manual mode on the page. In this mode, you can directly specify the tool list through YAML, but you need to manually feed back the tool's output to the model.

Code Interpreter Mode

Due to having a code execution environment, the model in this mode can perform more complex tasks, such as drawing charts, performing symbolic operations, etc. The model will automatically execute multiple code blocks in succession based on its understanding of the task completion status until the task is completed. Therefore, in this mode, you only need to specify the task you want the model to perform.

For example, we can ask ChatGLM3 to draw a heart:

The code interpreter draws a heart according to the user's instructions.

Additional Tips

  • While the model is generating text, it can be interrupted by the Stop button at the top right corner of the page.
  • Refreshing the page will clear the dialogue history.

Enjoy!