Skip to content

aevyraai/forge

Repository files navigation

aevyra-forge

CI Security License Docs Open In Colab

Forge tunes your vLLM deployment overnight. Give it a model, a GPU, and a workload trace. It runs an autonomous loop — propose a config, boot the server, benchmark against your real workload, keep or revert, repeat. By morning you have a deployment recipe that beats hand-tuned defaults, with a full audit trail of every experiment.

Witness  →  captures what happened           (aevyra-witness)
Verdict  →  judges it                        (aevyra-verdict)
Origin   →  finds where it went wrong        (aevyra-origin)
Reflex   →  fixes the prompts                (aevyra-reflex)
Forge    →  tunes the deployment             (you are here)
flowchart LR
    WL[Workload\nJSONL trace]:::data
    HW[Hardware\nauto-detected]:::data

    PB[Playbook\nheuristics]:::forge
    AG[Agent\n1 LLM call]:::forge
    VL[vLLM\nserver]:::bench
    BN[bench\nreplay workload]:::bench

    SC([Score\nthroughput × accuracy]):::score
    RY[best_recipe.yaml]:::output

    WL & HW --> AG
    PB --> AG
    AG -->|mutated recipe| VL
    VL --> BN
    BN -->|BenchResult| SC
    SC -->|keep / revert| AG
    SC --> RY

    classDef data    fill:#6E3FF3,color:#fff,stroke:none
    classDef forge   fill:#9B6BFF,color:#fff,stroke:none
    classDef bench   fill:#3FBFFF,color:#fff,stroke:none
    classDef score   fill:#FF6B35,color:#fff,stroke:none
    classDef output  fill:#2ECC71,color:#fff,stroke:none
Loading

Use cases

  • Maximising throughput overnight — run Forge against your production workload before a traffic spike. Wake up to a recipe that gets 30–50% more tokens per second without touching the model weights.
  • Reducing P99 latency — Forge searches chunked prefill, prefix caching, and batching knobs jointly. The playbook encodes which combinations help and which hurt on your GPU class.
  • Validating a new GPU — spin up a T4, A100, or MI300X and get a hardware-specific best config in one command. Forge auto-detects the GPU via nvidia-smi / rocm-smi — no lookup tables, no manual spec sheets.
  • Audit-ready deployment — every experiment is checkpointed to disk with its config, bench result, and agent rationale. The full search history is queryable and exportable as TSV or JSON.

Works with any LLM for the agent — Claude, OpenAI, OpenRouter, local Ollama or vLLM, or any OpenAI-compatible endpoint.

Install

pip install aevyra-forge               # Claude included by default
pip install aevyra-forge[openai]       # add OpenAI / OpenRouter / Together / Groq
pip install aevyra-forge[all]          # everything

Python 3.10+. vLLM must be installed separately on the GPU host:

pip install vllm                       # NVIDIA
pip install vllm --extra-index-url ... # AMD ROCm — follow vLLM's ROCm guide

Colab / pre-installed environments — uninstall torchvision before installing vLLM to avoid an MKL conflict that crashes the vLLM subprocess:

pip uninstall -y torchvision
pip install "vllm==0.19.0"   # last release with CUDA 12 support
Provider Extra Env var
Anthropic (included) ANTHROPIC_API_KEY
OpenAI [openai] OPENAI_API_KEY
OpenRouter [openai] OPENROUTER_API_KEY
Together AI [openai] TOGETHER_API_KEY
Groq [openai] GROQ_API_KEY
Ollama [openai]

Quick start

pip install aevyra-forge
export ANTHROPIC_API_KEY=sk-ant-...

aevyra-forge tune \
  --model meta-llama/Llama-3.2-1B-Instruct \
  --device cuda \
  --workload examples/sample_workload.jsonl \
  --max-experiments 10

Forge auto-detects your GPU, boots vLLM with the baseline config, then runs the loop. Each experiment takes 5–15 minutes. Results are saved to .forge/.

Resume an interrupted run — all config is read from disk, no args needed:

aevyra-forge tune resume

View results:

aevyra-forge report .forge/

Key CLI flags

Flag Default Description
--max-experiments N 50 Global experiment cap across all layers
--max-hours H 12.0 Wall-clock time limit
--max-config-experiments N Cap Layer 1 config tuning at N experiments, then escalate to quant regardless of convergence
--max-quant-experiments N Cap Layer 2 quant experiments
--skip-config false Skip Layer 1 entirely — go straight to Layer 2 quant
--skip-quant false Skip Layer 2 quantization
--skip-kernel false Skip Layer 3 kernel synthesis
--llm provider/model anthropic/claude-sonnet-4-6 LLM for the agent
--concurrency N 8 Concurrent requests during bench (T4/A10: 8–16, A100/H100: 32–64)
--run-dir PATH .forge Custom store directory

On constrained hardware (e.g. T4) where config search space is small, use --max-config-experiments 3 to avoid burning time on Layer 1 before moving to quant.

=== Forge Report: .forge/runs/001_2026-05-13T04-10-00 ===

Total experiments: 12
Best score:        1.2847
Best recipe ID:    e5f6a7b8
Best generation:   4
Throughput:        3421.0 tok/s
P99 latency:       187 ms

exp  id        gen  score   throughput  p99_ms  accuracy  kept  rationale
0    a1b2c3d4  0    1.0000  2718.3      241     0.991     ✓     baseline
1    e5f6a7b8  1    1.1204  3047.1      218     0.993     ✓     enable_prefix_caching: prefix_cache_hit...
2    f9a0b1c2  2    0.9831  2601.5      289     0.989     ✗     reduce max_num_seqs to 64 to lower p99...
...

How it works

flowchart TB
    subgraph loop["  Forge loop (one experiment per iteration)  "]
        direction LR
        AG[Agent\n1 LLM call\nreads playbook + history]:::forge
        MU[mutate\nrecipe.yaml]:::forge
        VL[boot\nvLLM]:::bench
        BN[bench\nreplay workload\nconcurrent requests]:::bench
        SC{score ≥ best\n+ accuracy floor?}:::score
        KP[keep\nupdate best]:::keep
        RV[revert\nto prior best]:::revert
    end

    WL[Workload\nJSONL trace]:::data
    HW[Hardware\nauto-detected via smi]:::data
    PB[Playbook\nheuristics + search space]:::data
    OUT[best_recipe.yaml\n+ experiments.tsv]:::output

    WL & HW & PB --> AG
    AG --> MU --> VL --> BN --> SC
    SC -->|yes| KP --> AG
    SC -->|no| RV --> AG
    KP & RV --> OUT

    classDef data    fill:#6E3FF3,color:#fff,stroke:none
    classDef forge   fill:#9B6BFF,color:#fff,stroke:none
    classDef bench   fill:#3FBFFF,color:#fff,stroke:none
    classDef score   fill:#FF6B35,color:#fff,stroke:none
    classDef keep    fill:#2ECC71,color:#fff,stroke:none
    classDef revert  fill:#444,color:#fff,stroke:none
    classDef output  fill:#2ECC71,color:#fff,stroke:none
Loading

One artifactrecipe.yaml — holds the complete vLLM config across three tuning layers: serving args (v0), quantization (v0.2), and kernel overrides (v0.3). Every mutation is one targeted change; the agent's rationale explains why.

One verifierbench.py — replays the workload against the running vLLM server at full concurrency, returning structured throughput, P50/P99 latency, TTFT, and accuracy.

One playbookplaybook.md — encodes serving expertise as heuristics the agent reads. It tells the agent what to try first, what ranges are safe, and which combinations to avoid. Custom playbooks can be passed with --playbook.

One tight loop — ~5–15 min per experiment. The agent picks one mutation per call, keeping the search space focused and the audit trail reviewable.

Workload format

A workload is a JSONL file, one request per line:

{"prompt": "Explain attention in transformers.", "expected_output_tokens": 256}
{"prompt": "Write a Python function to merge two sorted lists.", "expected_output_tokens": 128}
{"prompt": "What is the capital of France?", "expected_output_tokens": 32, "arrival_offset_s": 0.5}

arrival_offset_s is optional (defaults to 0). expected_output_tokens tells the bench verifier how long each response should be.

A 50-example starter is bundled:

aevyra-forge tune \
  --model meta-llama/Llama-3.2-1B-Instruct \
  --device cuda \
  --workload examples/sample_workload.jsonl

For production use, export a sample of your real traffic from Langfuse, your API gateway, or any JSONL source. Forge optimizes against your actual distribution, not a benchmark.

CLI reference

aevyra-forge tune [OPTIONS]          # start a new tuning run
aevyra-forge tune resume             # resume the latest interrupted run
aevyra-forge report <run-dir>        # print a summary table
aevyra-forge playbook show           # print the active playbook
aevyra-forge playbook validate       # validate playbook structure

Key options for tune:

Option Default Description
--model required HuggingFace model ID or local path
--device cuda GPU backend: cuda, rocm, or cpu
--workload required Path to workload JSONL
--concurrency 8 Max concurrent requests during benchmarking
--llm anthropic/claude-sonnet-4-6 Agent LLM (provider/model)
--max-experiments 50 Experiment budget
--max-hours 12.0 Wall-clock budget
--max-dollars LLM spend cap in USD
--accuracy-floor 0.99 Minimum acceptable accuracy
--playbook (bundled) Path to custom playbook
--dry-run False Skip vLLM; use synthetic bench results
--verbose False Debug logging

The --llm flag follows the same provider/model convention as aevyra-reflex: openrouter/meta-llama/llama-3.1-70b, openai/gpt-4o, ollama/qwen3:8b.

Run persistence and resume

Every run is checkpointed under .forge/runs/<id>_<timestamp>/:

.forge/
  runs/
    001_2026-05-13T04-10-00/
      config.json          ← model, hardware, workload, all CLI flags
      experiments.jsonl    ← append-only log (one line per experiment)
      experiments.tsv      ← human-readable table
      experiments.json     ← structured table for tooling
      best_recipe.yaml     ← best config so far (updated each experiment)
      completed.json       ← written on clean finish; absent = interrupted

A run with experiments.jsonl but no completed.json was interrupted and can be resumed. aevyra-forge tune resume finds the latest such run and continues from where it stopped — no args needed because everything is in config.json.

aevyra-forge tune resume             # resume latest interrupted run

Tuning layers

Layer What it tunes Status
1. Config vLLM serving args: batching, caching, parallelism ✅ Functional
2. Quantization INT4 AWQ / INT8 / FP8 E4M3, KV cache precision ✅ Functional
3. Kernel synthesis Custom kernels via AutoKernel hook Scaffolded (v0.3)

Layer 1 has the highest leverage per experiment because it requires no recompilation. Forge automatically escalates to Layer 2 when the Layer 1 search converges (no experiment improves score by more than --min-improvement-pct).

Layer 2 — workload-aware quantization

When Layer 1 converges, Forge checks HF Hub for a pre-quantized checkpoint. If one exists (e.g. Qwen/Qwen3-8B-AWQ), it loads it directly at zero calibration cost. If not, it runs INT4 AWQ calibration using prompts sampled from your workload JSONL — not a generic corpus.

# Full L1 + L2 run — Forge escalates automatically
aevyra-forge tune \
  --model Qwen/Qwen2.5-3B \
  --device cuda \
  --workload my_traffic.jsonl \
  --max-hours 4

# Skip straight to Layer 2 (quantize only, no config search)
aevyra-forge tune \
  --model Qwen/Qwen2.5-3B \
  --device cuda \
  --workload my_traffic.jsonl \
  --start-layer 2

Hardware gates — Forge enforces quantization method availability at the hardware level:

GPU INT4 AWQ INT8 FP8 E4M3
T4 (SM 7.5)
A100 (SM 8.0)
H100 / H200 (SM 9.0)
AMD MI300X (CDNA3)

Expected gains on T4 + Qwen2.5-3B:

  • Layer 1 (config tuned, BF16): baseline
  • Layer 2 (INT4 AWQ, workload-calibrated): +40–60% throughput

To explore Layer 2 interactively, see the Colab notebook.

Development

git clone https://github.com/aevyraai/forge
cd forge
pip install -e ".[dev]"

pytest tests/ -v         # 79 unit tests, no GPU needed
ruff check .
ruff format --check .

Tests cover workload, recipe, result, playbook, and cli helpers (including mocked nvidia-smi / rocm-smi paths). GPU-dependent paths — bench, orchestrator, runner — are tested in Colab.

Contributing

Read AGENT.md before opening a PR. Check CONTRIBUTING.md for ground rules.

License

Apache 2.0.

About

No description, website, or topics provided.

Resources

License

Contributing

Stars

Watchers

Forks

Packages

 
 
 

Contributors