Skip to main content

Alita with Sandbox and Dynamic MCP Box

Project description

CAlita: Adaptive LLM-based Iterative Task Automation

Inspired by the paper "Alita: Generalist Agent Enabling Scalable Agentic Reasoning with Minimal Predefinition and Maximal Self-Evolution".

CAlita is an intelligent meta-agent system that automatically invents Python scripts as tools to solve complex tasks through an iterative CodeReAct (Code Reasoning and Acting) loop. The system can analyze natural language requirements, detect capability gaps, search for external resources, generate and register executable code, and manage isolated execution environments between tasks. CAlita refer to OpenAlita๏ผŒrebuild with E2B sandbox and dynamic McpBox.

๐Ÿš€ Key Features

  • Intelligent Task Analysis: Uses LLM-powered brainstorming to analyze tasks and detect capability gaps
  • Dynamic Code Generation: Automatically generates self-contained Python scripts based on task specifications
  • Sandbox Execution: Use E2B sandbox execute script and code
  • External Resource Integration: Searches and incorporates web resources when needed
  • Iterative Refinement: Learns from execution failures and refines solutions automatically
  • MCP Registry: Stores and reuses successful Model Context Protocols (MCPBox)
  • Comprehensive Benchmarking: Supports evaluation on GAIA, MathVista, and PathVQA datasets

๐Ÿ—๏ธ Architecture

CAlita consists of several core components:

Core Modules

  • MangerAgent: Central orchestrates WebAgent, McpToolAgent, McpCreationAgent
  • McpCreationAgentPro: More Simple and Efficient McpCreationAgent
  • McpCreationAgent: Central coordinator that orchestrates the entire pipeline
  • MCPBrainstorm: Analyzes tasks and generates tool specifications using LLM
  • ResearchAgent: Performs intelligent information retrieval using LangGraph and MCP tools
  • ScriptGenerator: Generates executable Python scripts from specifications
  • CodeRunner: Executes scripts in E2B Sandbox
  • MCPRegistry: Persistent storage for successful Model Context Protocols Tool to McpBox
  • Benchmark: Evaluation framework for multiple datasets

Detailed Process Flow:

  1. Task Analysis: Analyze input task and detect capability gaps
  2. Resource Gathering: Search external resources if gaps are detected
  3. Script Generation: Generate self-contained Python script
  4. Execution: Run script and capture output
  5. Registration: Store successful scripts as reusable MCPs
  6. Iteration: Refine based on feedback if execution fails

๐Ÿ“‹ Prerequisites

  • Python 3.13+
  • Required Python packages (see installation section)

๐Ÿ› ๏ธ Installation

  1. Clone the repository:

    git clone <repository-url>
    cd CAlita_repo
    
  2. Install dependencies:

    uv sync --python 3.13
    
  3. Set up configuration:

    • Copy config.yaml.example to config.yaml and update the API keys:
    api:
      litellm_api_key: "your-actual-litellm-api-key-here"
      openai_api_key: "your-actual-openai-api-key-here"
      anthropic_api_key: "your-actual-anthropic-api-key-here"  # If using Anthropic models
    
  4. Config OS ENV:

      export E2B_API_KEY=XX
      export E2B_ACCESS_TOKEN=XX
      export LITELLM_API_KEY=XX 
    
  5. Run Calita App:

      uv run calita
    
  6. Run McpBox Server:

      uv run calita-mcpbox
    

โš™๏ธ Configuration

The system is configured through config.yaml. Key configuration sections:

Agent Configuration

agent:
  primary_llm: "openai/qwen3-235b-a22b"                   # Primary LLM model
  coder_llm: "openai/qwen3-coder-480b-a35b-instruct"      # Coder model
  reason_llm: "openai/qwen3-235b-a22b-thinking-2507"      # Reason model
  script_gen_prompt_template: "templates/script_template.txt"

API Configuration

api:
  litellm_api_key: "<YOUR_LITELLM_API_KEY_HERE>"  # LITELLM OpenSource API key
  litellm_api_url: "https://dashscope.aliyuncs.com/compatible-mode/v1"   # OpenSource API endpoint
  openai_api_key: "<YOUR_OPENAI_API_KEY_HERE>"  # OpenAI API key
  openai_api_url: "https://api.openai.com/v1"   # OpenAI API endpoint
  anthropic_api_key: "<YOUR_ANTHROPIC_API_KEY_HERE>"  # Anthropic API key
  anthropic_base_url: "https://api.anthropic.com"  # Anthropic API endpoint (optional)

Benchmark Configuration

benchmark:
  gaia:
    dataset_path: "data/gaia.json"
  mathvista:
    sample_size: 100
    dataset_path: "data/mathvista.json"
  pathvqa:
    sample_size: 100
    dataset_path: "data/pathvqa.json"

๐Ÿš€ Usage

Single Task Mode

Run CAlita on a single natural language task:

uv run calita

Then enter your task when prompted:

Enter a natural language query/task: Calculate the fibonacci sequence up to 100

Benchmark Mode

Run evaluation on benchmark datasets:

uv run calita

This will evaluate the system on GAIA, MathVista, and PathVQA datasets and output metrics including pass@1 and pass@3 scores.

Programmatic Usage

from calita.manager_agent import ManagerAgent
from calita.utils.utils import get_global_config, setup_logging

# Load configuration
config = get_global_config("config.yaml")
setup_logging(config)
# Initialize the agent
manager = ManagerAgent(config)

# Process a task
result = manager.generate("Create a function to sort a list of numbers")
print(result)

๐Ÿ“ Project Structure

CAlita_repo/
โ”œโ”€โ”€ calita/            # src, all code 
โ”‚   โ”œโ”€โ”€ manager_sub_agents # manager coodinate sub agents code
โ”‚   โ””โ”€โ”€ mcp_creation # mcp tool create and run code 
โ”‚   โ””โ”€โ”€ tools # pypi eg.. tools code
โ”‚   โ””โ”€โ”€ utils # utility code
โ”œโ”€โ”€ examples/      # example code 
โ”œโ”€โ”€ mcp_config/      # MCP Server config 
โ”œโ”€โ”€ templates/            # Prompt templates 
โ”‚   โ”œโ”€โ”€ brain_storm_template.txt # analysis task
โ”‚   โ””โ”€โ”€ script_template.txt  # ScriptGenerator create mcp tool script
โ”‚   โ””โ”€โ”€ final_result_template.txt  # FinalResultAgent evaluate result and formate result
โ”‚   โ””โ”€โ”€ mcp_tool_fetch_template.txt   # McpToolAgent fetch mcp tools
โ”‚   โ””โ”€โ”€ task_plan_template.txt  # TaskPlanAgent plan task
โ”œโ”€โ”€ data/                 # Dataset files (create this directory)
โ”‚   โ”œโ”€โ”€ gaia.json
โ”‚   โ”œโ”€โ”€ mathvista.json
โ”‚   โ””โ”€โ”€ pathvqa.json
โ””โ”€โ”€ logs/                 # Log files (auto-created)
    โ””โ”€โ”€ CAlita.log

๐Ÿ“Š Evaluation Metrics

The system supports comprehensive evaluation with the following metrics:

  • Pass@1: Success rate on first attempt
  • Pass@3: Success rate within 3 attempts
  • Dataset-specific metrics:
    • GAIA: Breakdown by difficulty levels (Level 1, 2, 3)
    • MathVista: Mathematical reasoning accuracy
    • PathVQA: Medical image question answering accuracy

๐Ÿ” Logging

Logs are automatically generated in logs/CAlita.log. Configure logging level in config.yaml:

logging:
  level: "INFO"              # DEBUG, INFO, WARNING, ERROR
  log_file: "logs/CAlita.log"

Inspiration and Credits

This project is inspired by the CAlita project by CharlesQ9 and the concepts presented in the research paper "CAlita: Generalist Agent Enabling Scalable Agentic Reasoning with Minimal Predefinition and Maximal Self-Evolution".

Original CAlita Project: CharlesQ9/CAlita on GitHub Research Paper: CAlita: Generalist Agent Enabling Scalable Agentic Reasoning with Minimal Predefinition and Maximal Self-Evolution (arXiv:2505.20286) Full credits to the authors and contributors of these works for the foundational architecture and ideas.

๐Ÿค Contributing

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

๐Ÿ“„ License

This project is licensed under the MIT License - see the LICENSE file for details.

๐Ÿ™ Acknowledgments

  • OpenAI for providing the LLM API
  • The research community for benchmark datasets (GAIA, MathVista, PathVQA)
  • Contributors and maintainers of the open-source libraries used

๐Ÿ“ž Support

For questions, issues, or contributions, please:

  • Open an issue on GitHub
  • Check the logs in logs/CAlita.log for debugging
  • Ensure your OpenAI API key is properly configured

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

calita-0.4.2.tar.gz (873.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

calita-0.4.2-py3-none-any.whl (48.9 kB view details)

Uploaded Python 3

File details

Details for the file calita-0.4.2.tar.gz.

File metadata

  • Download URL: calita-0.4.2.tar.gz
  • Upload date:
  • Size: 873.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.19

File hashes

Hashes for calita-0.4.2.tar.gz
Algorithm Hash digest
SHA256 9745fd0b25daa98c8987c34744fb7dca9c559d4cde823baf04fd55638813ce81
MD5 7c03e49fc28fa82666edc25608a2b41d
BLAKE2b-256 b32d3925fa7cafa6f4922f3f99fce06fe783abf98bce019d1efd2a57463aa059

See more details on using hashes here.

File details

Details for the file calita-0.4.2-py3-none-any.whl.

File metadata

  • Download URL: calita-0.4.2-py3-none-any.whl
  • Upload date:
  • Size: 48.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.19

File hashes

Hashes for calita-0.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 96ed65d56bec3c6471d9de3369679a67f86389d5393ba73b9dc9e869cd829223
MD5 a5859b8bc6ac6f98f6da4b0a5c48cc8d
BLAKE2b-256 bf1170f81250ed25f26eb2c4d45a1b71ac825a4ef633728225e2e2ad427733f5

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page