Text Generation
GGUF
llama.cpp
agent
agentic
tool-use
function-calling
react
local-government
agenda-parser
conversational
Instructions to use build-small-hackathon/agenda-parser-medium with libraries, inference providers, notebooks, and local apps. Follow these links to get started.
- Libraries
- llama-cpp-python
How to use build-small-hackathon/agenda-parser-medium with llama-cpp-python:
# !pip install llama-cpp-python from llama_cpp import Llama llm = Llama.from_pretrained( repo_id="build-small-hackathon/agenda-parser-medium", filename="agenda-parser-medium-Q4_K_M.gguf", )
llm.create_chat_completion( messages = [ { "role": "user", "content": "What is the capital of France?" } ] ) - Notebooks
- Google Colab
- Kaggle
- Local Apps Settings
- llama.cpp
How to use build-small-hackathon/agenda-parser-medium with llama.cpp:
Install from brew
brew install llama.cpp # Start a local OpenAI-compatible server with a web UI: llama-server -hf build-small-hackathon/agenda-parser-medium:Q4_K_M # Run inference directly in the terminal: llama-cli -hf build-small-hackathon/agenda-parser-medium:Q4_K_M
Install from WinGet (Windows)
winget install llama.cpp # Start a local OpenAI-compatible server with a web UI: llama-server -hf build-small-hackathon/agenda-parser-medium:Q4_K_M # Run inference directly in the terminal: llama-cli -hf build-small-hackathon/agenda-parser-medium:Q4_K_M
Use pre-built binary
# Download pre-built binary from: # https://github.com/ggerganov/llama.cpp/releases # Start a local OpenAI-compatible server with a web UI: ./llama-server -hf build-small-hackathon/agenda-parser-medium:Q4_K_M # Run inference directly in the terminal: ./llama-cli -hf build-small-hackathon/agenda-parser-medium:Q4_K_M
Build from source code
git clone https://github.com/ggerganov/llama.cpp.git cd llama.cpp cmake -B build cmake --build build -j --target llama-server llama-cli # Start a local OpenAI-compatible server with a web UI: ./build/bin/llama-server -hf build-small-hackathon/agenda-parser-medium:Q4_K_M # Run inference directly in the terminal: ./build/bin/llama-cli -hf build-small-hackathon/agenda-parser-medium:Q4_K_M
Use Docker
docker model run hf.co/build-small-hackathon/agenda-parser-medium:Q4_K_M
- LM Studio
- Jan
- vLLM
How to use build-small-hackathon/agenda-parser-medium with vLLM:
Install from pip and serve model
# Install vLLM from pip: pip install vllm # Start the vLLM server: vllm serve "build-small-hackathon/agenda-parser-medium" # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:8000/v1/chat/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "build-small-hackathon/agenda-parser-medium", "messages": [ { "role": "user", "content": "What is the capital of France?" } ] }'Use Docker
docker model run hf.co/build-small-hackathon/agenda-parser-medium:Q4_K_M
- Ollama
How to use build-small-hackathon/agenda-parser-medium with Ollama:
ollama run hf.co/build-small-hackathon/agenda-parser-medium:Q4_K_M
- Unsloth Studio
How to use build-small-hackathon/agenda-parser-medium with Unsloth Studio:
Install Unsloth Studio (macOS, Linux, WSL)
curl -fsSL https://unsloth.ai/install.sh | sh # Run unsloth studio unsloth studio -H 0.0.0.0 -p 8888 # Then open http://localhost:8888 in your browser # Search for build-small-hackathon/agenda-parser-medium to start chatting
Install Unsloth Studio (Windows)
irm https://unsloth.ai/install.ps1 | iex # Run unsloth studio unsloth studio -H 0.0.0.0 -p 8888 # Then open http://localhost:8888 in your browser # Search for build-small-hackathon/agenda-parser-medium to start chatting
Using HuggingFace Spaces for Unsloth
# No setup required # Open https://huggingface.co/spaces/unsloth/studio in your browser # Search for build-small-hackathon/agenda-parser-medium to start chatting
- Pi
How to use build-small-hackathon/agenda-parser-medium with Pi:
Start the llama.cpp server
# Install llama.cpp: brew install llama.cpp # Start a local OpenAI-compatible server: llama-server -hf build-small-hackathon/agenda-parser-medium:Q4_K_M
Configure the model in Pi
# Install Pi: npm install -g @mariozechner/pi-coding-agent # Add to ~/.pi/agent/models.json: { "providers": { "llama-cpp": { "baseUrl": "http://localhost:8080/v1", "api": "openai-completions", "apiKey": "none", "models": [ { "id": "build-small-hackathon/agenda-parser-medium:Q4_K_M" } ] } } }Run Pi
# Start Pi in your project directory: pi
- Hermes Agent new
How to use build-small-hackathon/agenda-parser-medium with Hermes Agent:
Start the llama.cpp server
# Install llama.cpp: brew install llama.cpp # Start a local OpenAI-compatible server: llama-server -hf build-small-hackathon/agenda-parser-medium:Q4_K_M
Configure Hermes
# Install Hermes: curl -fsSL https://hermes-agent.nousresearch.com/install.sh | bash hermes setup # Point Hermes at the local server: hermes config set model.provider custom hermes config set model.base_url http://127.0.0.1:8080/v1 hermes config set model.default build-small-hackathon/agenda-parser-medium:Q4_K_M
Run Hermes
hermes
- Atomic Chat new
- Docker Model Runner
How to use build-small-hackathon/agenda-parser-medium with Docker Model Runner:
docker model run hf.co/build-small-hackathon/agenda-parser-medium:Q4_K_M
- Lemonade
How to use build-small-hackathon/agenda-parser-medium with Lemonade:
Pull the model
# Download Lemonade from https://lemonade-server.ai/ lemonade pull build-small-hackathon/agenda-parser-medium:Q4_K_M
Run and chat with the model
lemonade run user.agenda-parser-medium-Q4_K_M
List all available models
lemonade list
| license: gemma | |
| base_model: google/gemma-4-26B-A4B-it | |
| datasets: | |
| - build-small-hackathon/agenda-parser-tool-traces | |
| library_name: gguf | |
| pipeline_tag: text-generation | |
| tags: | |
| - gguf | |
| - llama.cpp | |
| - agent | |
| - agentic | |
| - tool-use | |
| - function-calling | |
| - react | |
| - local-government | |
| - agenda-parser | |
| # agenda-parser-medium | |
| **A Gemma 4 26B-A4B (MoE) fine-tune that drives the [Agenda Parser](https://huggingface.co/rdubwiley) agents' tool-calling loop** β quantized to **Q4_K_M** GGUF for [llama.cpp](https://github.com/ggml-org/llama.cpp). | |
| This is the **medium** member of a three-model family (26B total / ~4B active params) fine-tuned to follow a strict ReAct *single-JSON-action* protocol over public-meeting agenda packets and local-government legal questions. It is **not** a general chat assistant. | |
| | | | | |
| |---|---| | |
| | **Base model** | [`google/gemma-4-26B-A4B-it`](https://huggingface.co/google/gemma-4-26B-A4B-it) (26B total / ~4B active) | | |
| | **Method** | LoRA SFT β merged β Q4_K_M GGUF | | |
| | **Training data** | [`build-small-hackathon/agenda-parser-tool-traces`](https://huggingface.co/datasets/build-small-hackathon/agenda-parser-tool-traces) (`filtered` config) | | |
| | **LoRA adapter** | [`build-small-hackathon/agenda-parser-medium-lora`](https://huggingface.co/build-small-hackathon/agenda-parser-medium-lora) | | |
| | **License** | [Gemma Terms of Use](https://ai.google.dev/gemma/terms) | | |
| ## What it does β the agent protocol | |
| The model is trained to act as a ReAct agent that calls one tool at a time. Each step it must emit **a single JSON object and nothing else**: | |
| ```json | |
| {"thought": "<one short sentence>", "tool": "<tool name>", "args": { ... }} | |
| ``` | |
| It reads the tool's result, then emits the next action, until it calls `final_answer`. It is trained on **two toolkits**: | |
| - **Agenda packet research** β `list_agenda_items`, `get_item_text`, `search_packet` (semantic), `find_text` (exact), `summarize`, `report`, `final_answer`. Answers questions about an uploaded agenda packet (what an item approves, costs, dates, which items mention X, briefings). | |
| - **Cornell LII legal research** (scoped to **local-government** law) β `search_regulations`, `resolve_cfr`/`resolve_usc`, `mcl_find`/`mcl_search`/`mcl_text`/`mcl_outline`/`mcl_lookup`, etc. Answers questions on Open Meetings Act, FOIA, municipal budgeting/taxation, zoning, ethics, and the Michigan statutes governing local governments β citing CFR/USC and reading Michigan MCL text. | |
| ## How it was trained | |
| 1. **Teacher traces.** Two strong teacher models β **Kimi k2.6** and **DeepSeek 4 pro** (via [OpenCode Go](https://opencode.ai)) β drove the *real* agent loop over 11 public agenda packets and a set of local-government legal questions. Tools executed live, so every observation is grounded. | |
| 2. **Judge filtering.** Each completed trace's final answer was scored for **faithfulness** against the text the agent actually retrieved (fast OpenCode-Go judge); only high-faithfulness traces were kept. One accepted agent step = one training example. | |
| 3. **SFT.** LoRA on the base's attention projections (q/k/v/o), 4 epochs over **974 examples** (held-out packet excluded β see Evaluation), full-sequence loss (the Gemma chat template lacks `{% generation %}` markers for assistant-only loss), bf16 + gradient checkpointing, then **merged** and converted to GGUF. | |
| | hyperparameter | value | | |
| |---|---| | |
| | LoRA rank / Ξ± / dropout | 32 / 64 / 0.05 | | |
| | target modules | attention + MLP `q,k,v,o,gate,up,down_proj` (auto-detected real `nn.Linear`) | | |
| | epochs | 4 | | |
| | learning rate | 1e-4 (cosine, 3% warmup) | | |
| | batch Γ grad-accum | 1 Γ 16 | | |
| | max sequence length | 4096 | | |
| | precision / GPU | bf16 / H100 | | |
| | final in-training token accuracy | ~0.96 | | |
| The full training/generation pipeline (trace capture, judge, LoRA, merge, GGUF) is reproducible from the dataset card. | |
| ## Training data & provenance | |
| Built from [`build-small-hackathon/agenda-parser-tool-traces`](https://huggingface.co/datasets/build-small-hackathon/agenda-parser-tool-traces): per-step `{system, user, assistant}` chat examples whose `system` message is the deployed agent's exact tool catalog + protocol. The source agenda packets are published in that dataset's [`source_packets/`](https://huggingface.co/datasets/build-small-hackathon/agenda-parser-tool-traces/tree/main/source_packets) folder; each trace row links to its source by `meta.unit_id`. Distilled from third-party teacher models (their terms may apply to generated text); source PDFs are public meeting records. | |
| ## Sibling models | |
| | model | base | quant | this card | | |
| |---|---|---|:---:| | |
| | [`agenda-parser-lite`](https://huggingface.co/build-small-hackathon/agenda-parser-lite) | Gemma 4 E4B | Q8_0 | | | |
| | [`agenda-parser-medium`](https://huggingface.co/build-small-hackathon/agenda-parser-medium) | Gemma 4 26B-A4B (MoE) | Q4_K_M | β | | |
| | [`agenda-parser-high`](https://huggingface.co/build-small-hackathon/agenda-parser-high) | Gemma 4 26B-A4B (MoE) | Q8_0 | | | |
| (`lite` = fast/small; `medium` = balanced; `high` = best quality. `medium`/`high` share the 26B-A4B base, fine-tuned independently and shipped at different quants.) | |
| ## Evaluation | |
| One agenda packet (`oakland-1570`) and a held-out task seed are **excluded from training** and reserved for a base-vs-fine-tuned A/B benchmark (objective protocol metrics β valid-JSON-action rate, clean-`final_answer` rate, tool-error rate β plus an LLM-judge of answer faithfulness, absolute and pairwise). See the project repo's `sft/eval.py`. | |
| ## Run | |
| ```bash | |
| huggingface-cli download build-small-hackathon/agenda-parser-medium agenda-parser-medium-Q4_K_M.gguf | |
| # --jinja loads the embedded chat/tool template | |
| llama-server -m agenda-parser-medium-Q4_K_M.gguf --jinja | |
| ``` | |
| The model expects the agent's system prompt (tool catalog + protocol) and replies with one JSON action per turn. | |
| ## Intended use & limitations | |
| - **Intended:** the in-process llama.cpp backend for the Agenda Parser agents over uploaded agenda PDFs and local-government legal lookups. | |
| - **Out of scope:** general-purpose chat; non-tool-calling use; legal/financial advice. Always verify answers against the cited source packet / statute. | |
| - Inherits the [Gemma Terms of Use](https://ai.google.dev/gemma/terms) and use restrictions. | |