llama.cpp/examples/agent
2024-10-04 04:06:00 +01:00
..
tools agent: tool tweaks (remove ansi escapes from python output, update env keys + provider docs) 2024-10-03 22:20:34 +01:00
README.md agent: tool tweaks (remove ansi escapes from python output, update env keys + provider docs) 2024-10-03 22:20:34 +01:00
requirements.txt agent: ditch openai dependency, use cache_prompt and expose seed 2024-10-02 16:26:45 +01:00
run.py agent: handle function errors and dont' stringify str outputs 2024-10-04 04:06:00 +01:00
serve_tools_inside_docker.sh agent: handle function errors and dont' stringify str outputs 2024-10-04 04:06:00 +01:00
serve_tools.py agent: tool tweaks (remove ansi escapes from python output, update env keys + provider docs) 2024-10-03 22:20:34 +01:00

Agents / Tool Calling w/ llama.cpp

  • Install prerequisite: uv (used to simplify python deps)

  • Run llama-server w/ jinja templates. Note that most models need a template override (the HF to GGUF conversion only retains a single chat_template, but sometimes the models only support tool calls in an alternative chat template).

    make -j LLAMA_CURL=1 llama-server
    
    # Nous Hermes 2 Pro Llama 3 8B
    ./llama-server --jinja -fa --verbose \
      -hfr NousResearch/Hermes-2-Pro-Llama-3-8B-GGUF -hff Hermes-2-Pro-Llama-3-8B-Q8_0.gguf \
      --chat-template "$( python scripts/get_hf_chat_template.py NousResearch/Hermes-2-Pro-Llama-3-8B tool_use )"
    
    # Llama 3.1 8B
    ./llama-server --jinja -fa --verbose \
      -hfr lmstudio-community/Meta-Llama-3.1-8B-Instruct-GGUF -hff Meta-Llama-3.1-8B-Instruct-Q5_K_M.gguf
    
    # Llama 3.1 70B
    ./llama-server --jinja -fa --verbose \
      -hfr lmstudio-community/Meta-Llama-3.1-70B-Instruct-GGUF -hff Meta-Llama-3.1-70B-Instruct-Q4_K_M.gguf
    
    # functionary-small-v3
    ./llama-server --jinja -fa --verbose \
      -hfr meetkai/functionary-small-v3.2-GGUF -hff functionary-small-v3.2.Q4_0.gguf \
      --chat-template "$( python scripts/get_hf_chat_template.py meetkai/functionary-medium-v3.2 )"
    
    # Llama 3.2 3B (poor adherence)
    ./llama-server --jinja -fa --verbose \
      -hfr lmstudio-community/Llama-3.2-3B-Instruct-GGUF -hff Llama-3.2-3B-Instruct-Q6_K_L.gguf \
      --chat-template "$( python scripts/get_hf_chat_template.py meta-llama/Llama-3.2-3B-Instruct )"
    
    # Llama 3.2 1B (very poor adherence)
    ./llama-server --jinja -fa --verbose \
      -hfr lmstudio-community/Llama-3.2-1B-Instruct-GGUF -hff Llama-3.2-1B-Instruct-Q4_K_M.gguf \
      --chat-template "$( python scripts/get_hf_chat_template.py meta-llama/Llama-3.2-3B-Instruct )"
    
  • Run the tools in examples/agent/tools inside a docker container (check http://localhost:8088/docs once running):

    export BRAVE_SEARCH_API_KEY=... # https://api.search.brave.com/
    # Shorthand: ./examples/agent/serve_tools_inside_docker.sh
    docker run -p 8088:8088 -w /src -v $PWD/examples/agent:/src \
      --env BRAVE_SEARCH_API_KEY=$BRAVE_SEARCH_API_KEY \
      --rm -it ghcr.io/astral-sh/uv:python3.12-alpine \
      uv run serve_tools.py --port 8088
    

    Warning

    The command above gives tools (and your agent) access to the web (and read-only access to examples/agent/**. If you're concerned about unleashing a rogue agent on the web, please explore setting up proxies for your docker (and contribute back!)

  • Run the agent with some goal

    uv run examples/agent/run.py --tools http://localhost:8088 \
      "What is the sum of 2535 squared and 32222000403?"
    
    See output w/ Hermes-3-Llama-3.1-8B
    🛠️  Tools: python, fetch_page, brave_search
    ⚙️  python(code="print(2535**2 + 32222000403)")
    → 15 chars
    The sum of 2535 squared and 32222000403 is 32228426628.
    
    uv run examples/agent/run.py --tools http://localhost:8088 \
      "What is the best BBQ joint in Laguna Beach?"
    
    See output w/ Hermes-3-Llama-3.1-8B
    🛠️  Tools: python, fetch_page, brave_search
    ⚙️  brave_search(query="best bbq joint in laguna beach")
    → 4283 chars
    Based on the search results, Beach Pit BBQ seems to be a popular and highly-rated BBQ joint in Laguna Beach. They offer a variety of BBQ options, including ribs, pulled pork, brisket, salads, wings, and more. They have dine-in, take-out, and catering options available.
    
    uv run examples/agent/run.py --tools http://localhost:8088 \
      "Search for, fetch and summarize the homepage of llama.cpp"
    
    See output w/ Hermes-3-Llama-3.1-8B
    🛠️  Tools: python, fetch_page, brave_search
    ⚙️  brave_search(query="llama.cpp")
    → 3330 chars
    Llama.cpp is an open-source software library written in C++ that performs inference on various Large Language Models (LLMs). Alongside the library, it includes a CLI and web server. It is co-developed alongside the GGML project, a general-purpose tensor library. Llama.cpp is also available with Python bindings, known as llama.cpp-python. It has gained popularity for its ability to run LLMs on local machines, such as Macs with NVIDIA RTX systems. Users can leverage this library to accelerate LLMs and integrate them into various applications. There are numerous resources available, including tutorials and guides, for getting started with Llama.cpp and llama.cpp-python.
    
  • To compare the above results w/ a cloud provider's tool usage behaviour, just set the --provider flag (accepts openai, together, groq) and/or use --endpoint, --api-key, and --model

    export LLAMA_API_KEY=...      # for --provider=llama.cpp https://github.com/ggerganov/llama.cpp/blob/master/examples/server/README.md
    export OPENAI_API_KEY=...     # for --provider=openai    https://platform.openai.com/api-keys
    export TOGETHER_API_KEY=...   # for --provider=together  https://api.together.ai/settings/api-keys
    export GROQ_API_KEY=...       # for --provider=groq      https://console.groq.com/keys
    uv run examples/agent/run.py --tools http://localhost:8088 \
      "Search for, fetch and summarize the homepage of llama.cpp" \
      --provider=openai
    

TODO

  • Implement code_interpreter using whichever tools are builtin for a given model.