← 返回 Skills 市场
helloml0326

Auto Arena

作者 helloml0326 · GitHub ↗ · v1.0.0 · MIT-0
cross-platform ⚠ suspicious
252
总下载
0
收藏
0
当前安装
1
版本数
在 OpenClaw 中安装
/install auto-arena
功能描述
Automatically evaluate and compare multiple AI models or agents without pre-existing test data. Generates test queries from a task description, collects resp...
使用说明 (SKILL.md)

Auto Arena Skill

End-to-end automated model comparison using the OpenJudge AutoArenaPipeline:

  1. Generate queries — LLM creates diverse test queries from task description
  2. Collect responses — query all target endpoints concurrently
  3. Generate rubrics — LLM produces evaluation criteria from task + sample queries
  4. Pairwise evaluation — judge model compares every model pair (with position-bias swap)
  5. Analyze & rank — compute win rates, win matrix, and rankings
  6. Report & charts — Markdown report + win-rate bar chart + optional matrix heatmap

Prerequisites

# Install OpenJudge
pip install py-openjudge

# Extra dependency for auto_arena (chart generation)
pip install matplotlib

Gather from user before running

Info Required? Notes
Task description Yes What the models/agents should do (set in config YAML)
Target endpoints Yes At least 2 OpenAI-compatible endpoints to compare
Judge endpoint Yes Strong model for pairwise evaluation (e.g. gpt-4, qwen-max)
API keys Yes Env vars: OPENAI_API_KEY, DASHSCOPE_API_KEY, etc.
Number of queries No Default: 20
Seed queries No Example queries to guide generation style
System prompts No Per-endpoint system prompts
Output directory No Default: ./evaluation_results
Report language No "zh" (default) or "en"

Quick start

CLI

# Run evaluation
python -m cookbooks.auto_arena --config config.yaml --save

# Use pre-generated queries
python -m cookbooks.auto_arena --config config.yaml \
  --queries_file queries.json --save

# Start fresh, ignore checkpoint
python -m cookbooks.auto_arena --config config.yaml --fresh --save

# Re-run only pairwise evaluation with new judge model
# (keeps queries, responses, and rubrics)
python -m cookbooks.auto_arena --config config.yaml --rerun-judge --save

Python API

import asyncio
from cookbooks.auto_arena.auto_arena_pipeline import AutoArenaPipeline

async def main():
    pipeline = AutoArenaPipeline.from_config("config.yaml")
    result = await pipeline.evaluate()

    print(f"Best model: {result.best_pipeline}")
    for rank, (model, win_rate) in enumerate(result.rankings, 1):
        print(f"{rank}. {model}: {win_rate:.1%}")

asyncio.run(main())

Minimal Python API (no config file)

import asyncio
from cookbooks.auto_arena.auto_arena_pipeline import AutoArenaPipeline
from cookbooks.auto_arena.schema import OpenAIEndpoint

async def main():
    pipeline = AutoArenaPipeline(
        task_description="Customer service chatbot for e-commerce",
        target_endpoints={
            "gpt4": OpenAIEndpoint(
                base_url="https://api.openai.com/v1",
                api_key="sk-...",
                model="gpt-4",
            ),
            "qwen": OpenAIEndpoint(
                base_url="https://dashscope.aliyuncs.com/compatible-mode/v1",
                api_key="sk-...",
                model="qwen-max",
            ),
        },
        judge_endpoint=OpenAIEndpoint(
            base_url="https://api.openai.com/v1",
            api_key="sk-...",
            model="gpt-4",
        ),
        num_queries=20,
    )
    result = await pipeline.evaluate()
    print(f"Best: {result.best_pipeline}")

asyncio.run(main())

CLI options

Flag Default Description
--config Path to YAML configuration file (required)
--output_dir config value Override output directory
--queries_file Path to pre-generated queries JSON (skip generation)
--save False Save results to file
--fresh False Start fresh, ignore checkpoint
--rerun-judge False Re-run pairwise evaluation only (keep queries/responses/rubrics)

Minimal config file

task:
  description: "Academic GPT assistant for research and writing tasks"

target_endpoints:
  model_v1:
    base_url: "https://api.openai.com/v1"
    api_key: "${OPENAI_API_KEY}"
    model: "gpt-4"
  model_v2:
    base_url: "https://api.openai.com/v1"
    api_key: "${OPENAI_API_KEY}"
    model: "gpt-3.5-turbo"

judge_endpoint:
  base_url: "https://api.openai.com/v1"
  api_key: "${OPENAI_API_KEY}"
  model: "gpt-4"

Full config reference

task

Field Required Description
description Yes Clear description of the task models will be tested on
scenario No Usage scenario for additional context

target_endpoints.\x3Cname>

Field Default Description
base_url API base URL (required)
api_key API key, supports ${ENV_VAR} (required)
model Model name (required)
system_prompt System prompt for this endpoint
extra_params Extra API params (e.g. temperature, max_tokens)

judge_endpoint

Same fields as target_endpoints.\x3Cname>. Use a strong model (e.g. gpt-4, qwen-max) with low temperature (~0.1) for consistent judgments.

query_generation

Field Default Description
num_queries 20 Total number of queries to generate
seed_queries Example queries to guide generation
categories Query categories with weights for stratified generation
endpoint judge endpoint Custom endpoint for query generation
queries_per_call 10 Queries generated per API call (1–50)
num_parallel_batches 3 Parallel generation batches
temperature 0.9 Sampling temperature (0.0–2.0)
top_p 0.95 Top-p sampling (0.0–1.0)
max_similarity 0.85 Dedup similarity threshold (0.0–1.0)
enable_evolution false Enable Evol-Instruct complexity evolution
evolution_rounds 1 Evolution rounds (0–3)
complexity_levels ["constraints", "reasoning", "edge_cases"] Evolution strategies

evaluation

Field Default Description
max_concurrency 10 Max concurrent API requests
timeout 60 Request timeout in seconds
retry_times 3 Retry attempts for failed requests

output

Field Default Description
output_dir ./evaluation_results Output directory
save_queries true Save generated queries
save_responses true Save model responses
save_details true Save detailed results

report

Field Default Description
enabled false Enable Markdown report generation
language "zh" Report language: "zh" or "en"
include_examples 3 Examples per section (1–10)
chart.enabled true Generate win-rate chart
chart.orientation "horizontal" "horizontal" or "vertical"
chart.show_values true Show values on bars
chart.highlight_best true Highlight best model
chart.matrix_enabled false Generate win-rate matrix heatmap
chart.format "png" Chart format: "png", "svg", or "pdf"

Interpreting results

Win rate: percentage of pairwise comparisons a model wins. Each pair is evaluated in both orders (original + swapped) to eliminate position bias.

Rankings example:

  1. gpt4_baseline       [################----] 80.0%
  2. qwen_candidate      [############--------] 60.0%
  3. llama_finetuned      [##########----------] 50.0%

Win matrix: win_matrix[A][B] = how often model A beats model B across all queries.

Checkpoint & resume

The pipeline saves progress after each step. Interrupted runs resume automatically:

  • --fresh — ignore checkpoint, start from scratch
  • --rerun-judge — re-run only the pairwise evaluation step (useful when switching judge models); keeps queries, responses, and rubrics intact
  • Adding new endpoints to config triggers incremental response collection; existing responses are preserved

Output files

evaluation_results/
├── evaluation_results.json     # Rankings, win rates, win matrix
├── evaluation_report.md        # Detailed Markdown report (if enabled)
├── win_rate_chart.png          # Win-rate bar chart (if enabled)
├── win_rate_matrix.png         # Matrix heatmap (if matrix_enabled)
├── queries.json                # Generated test queries
├── responses.json              # All model responses
├── rubrics.json                # Generated evaluation rubrics
├── comparison_details.json     # Pairwise comparison details
└── checkpoint.json             # Pipeline checkpoint

API key by model

Model prefix Environment variable
gpt-*, o1-*, o3-* OPENAI_API_KEY
claude-* ANTHROPIC_API_KEY
qwen-*, dashscope/* DASHSCOPE_API_KEY
deepseek-* DEEPSEEK_API_KEY
Custom endpoint set api_key + base_url in config

Additional resources

安全使用建议
This skill's instructions will install and run a third‑party Python package (py-openjudge) and will send generated queries, model prompts, and model outputs to external APIs (judge + target endpoints). Before installing or running it: (1) verify the py-openjudge package source and reputation (prefer a GitHub repo or official release page); (2) confirm the registry metadata is updated to declare required env vars and any install steps; (3) avoid using high‑privilege or long‑lived secrets — create scoped API keys if possible; (4) do not feed sensitive or private data into the task because it will be transmitted to external providers; (5) consider running evaluations in an isolated environment or sandbox until you trust the package. If you need higher assurance, ask the author for the package source code (or an install spec pointing to a known release) and a corrected manifest that lists required env vars and explains checkpoint/storage behavior.
功能分析
Type: OpenClaw Skill Name: auto-arena Version: 1.0.0 The 'auto-arena' skill is a legitimate tool designed for benchmarking and comparing AI models using the OpenJudge framework. The SKILL.md file provides clear instructions for query generation, model evaluation, and report generation, aligning perfectly with its stated purpose. There are no signs of data exfiltration, malicious code execution, or prompt injection; the use of API keys and environment variables is standard for interacting with LLM providers like OpenAI and DashScope.
能力评估
Purpose & Capability
The described purpose (automated pairwise model evaluation) reasonably requires calling multiple model endpoints and a judge model and therefore needs API keys and a runtime library. However, the registry metadata lists no required environment variables or install spec while SKILL.md clearly expects API keys (OPENAI_API_KEY, DASHSCOPE_API_KEY, etc.) and the py-openjudge package. The metadata ↔ instructions mismatch is unexpected.
Instruction Scope
Runtime instructions direct generating queries, sending them to multiple external endpoints, collecting model outputs, calling a judge endpoint, and saving results. That behavior is consistent with the skill's purpose, but it means user prompts and model outputs will be transmitted to third‑party APIs (potentially leaking sensitive data). The SKILL.md also instructs the agent/user to run pip installs to obtain the implementation (no code is bundled).
Install Mechanism
There is no install spec in the registry, yet SKILL.md instructs pip installing 'py-openjudge' and 'matplotlib'. Relying on the agent/user to pip-install an external package is normal for instruction-only skills, but it increases risk: the package's provenance and trustworthiness are unknown and could execute arbitrary code when installed/used.
Credentials
The skill legitimately needs API keys for each target/judge endpoint, which explains asking for OPENAI_API_KEY, DASHSCOPE_API_KEY, etc. But the registry metadata lists no required env vars (a clear inconsistency). Also, the more providers/endpoints the user compares, the more credentials will be needed — ensure keys provided are scoped/minimal and not broader than necessary.
Persistence & Privilege
The skill does not request forced inclusion (always: false) or unusual privileges. It writes outputs/checkpoints to a local output directory (normal for an evaluation tool). Autonomous invocation is allowed by default; combine that with credential access only if you trust the package and configuration.
如何使用
  1. 确保已安装 OpenClaw(本地或 Docker 部署)
  2. 在对话框中输入安装命令:/install auto-arena
  3. 安装完成后,直接呼叫该 Skill 的名称或使用 /auto-arena 触发
  4. 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
版本历史
v1.0.0
Initial release of Auto Arena: end-to-end automated arena evaluation and ranking for AI models or agents. - Automatically generates test queries and evaluation rubrics from your task description. - Concurrently collects responses from multiple model endpoints; supports at least 2 models or agents. - Uses a strong judge model to run pairwise, position-bias-mitigated comparisons across all models. - Produces win-rate rankings, bar charts, optional heatmaps, and full Markdown reports. - Resumable, supports incremental endpoint addition, checkpointing, and judge model hot-swap. - Provides both CLI and Python API usage with extensive configuration and customization options.
元数据
Slug auto-arena
版本 1.0.0
许可证 MIT-0
累计安装 0
当前安装数 0
历史版本数 1
常见问题

Auto Arena 是什么?

Automatically evaluate and compare multiple AI models or agents without pre-existing test data. Generates test queries from a task description, collects resp... 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 252 次。

如何安装 Auto Arena?

在 OpenClaw 或 Claude Code 对话框中运行命令「/install auto-arena」即可一键安装,无需额外配置。

Auto Arena 是免费的吗?

是的,Auto Arena 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。

Auto Arena 支持哪些平台?

Auto Arena 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。

谁开发了 Auto Arena?

由 helloml0326(@helloml0326)开发并维护,当前版本 v1.0.0。

💬 留言讨论