Skip to main content

Personal Simple Generic Agents

Project description

FivcPlayground

An intelligent agent ecosystem built on Strands for autonomous tool generation, task assessment, and dynamic agent orchestration.

๐Ÿ”„ Dual Backend Support: FivcPlayground supports both Strands (default) and LangChain backends. See Backend Selection Guide for details on switching backends.

๐ŸŽฏ Overview

FivcPlayground provides a flexible multi-agent system that can:

  • Assess tasks intelligently to determine the best approach
  • Retrieve and use tools dynamically based on task requirements
  • Plan and execute complex workflows with specialized agents
  • Generate and optimize tools autonomously
  • Chat and assist users through an interactive web interface

๐Ÿš€ Quickstart

Prerequisites

  • Python 3.10 or higher
  • API keys for LLM providers (OpenAI, Ollama, etc.)

Installation

# Install with uv (recommended)
make install        # runtime + dev dependencies

# Or minimal installation
make install-min    # runtime only

# Or with pip
pip install -e .

Configuration

  1. Copy the example environment file:
cp .env.example .env
  1. Configure your LLM provider settings in .env:
# OpenAI
OPENAI_API_KEY=your_key_here
OPENAI_BASE_URL=https://api.openai.com/v1

# Or Ollama
OLLAMA_BASE_URL=http://localhost:11434

Quick Start

# Launch the web interface
make serve

# Or run an agent from CLI
uv run fivcplayground run Generic --query "What is machine learning?"

# Show available commands
uv run fivcplayground --help

๐Ÿ“ Project Structure

src/fivcplayground/
โ”œโ”€โ”€ agents/          # Agent creation and management
โ”‚   โ””โ”€โ”€ types/       # Agent retriever and creator types
โ”œโ”€โ”€ backends/        # Backend implementations (langchain, strands)
โ”‚   โ”œโ”€โ”€ langchain/   # LangChain backend
โ”‚   โ””โ”€โ”€ strands/     # Strands backend
โ”œโ”€โ”€ plays/           # Streamlit web interface
โ”œโ”€โ”€ embeddings/      # Vector database and embeddings
โ”‚   โ””โ”€โ”€ types/       # Embedding database types
โ”œโ”€โ”€ models/          # LLM model factories and providers
โ”‚   โ””โ”€โ”€ types/       # Model types and implementations
โ”‚       โ”œโ”€โ”€ repositories/  # Model configuration repositories
โ”‚       โ””โ”€โ”€ base.py        # ModelConfig data model
โ”œโ”€โ”€ schemas.py       # Pydantic data schemas
โ”œโ”€โ”€ settings/        # Configuration management
โ”œโ”€โ”€ tasks.py         # Task execution functions
โ”œโ”€โ”€ tools/           # Tool management and retrieval
โ”‚   โ””โ”€โ”€ types/       # Tool retriever and config types
โ””โ”€โ”€ utils/           # Utility functions

configs/             # Configuration examples
examples/            # Usage examples
โ”œโ”€โ”€ agents/          # Agent usage examples
โ””โ”€โ”€ tools/           # Tool usage examples
tests/               # Test suite
docs/                # Documentation

๐Ÿ’ป Usage

Command Line Interface

# Show all available commands
fivcplayground --help

# Run an agent interactively
fivcplayground run Generic

# Run an agent with a specific query
fivcplayground run Generic --query "What is machine learning?"

# Run different agent types
fivcplayground run Companion --query "Tell me a joke"
fivcplayground run Consultant --query "How should I approach this task?"

# Clean temporary files
fivcplayground clean

# Show system information
fivcplayground info

Available Agents

  • Generic - Standard agent for general task execution
  • Companion - Friendly chat agent for conversations
  • Consultant - Assesses tasks and recommends approaches
  • Planner - Creates execution plans and teams
  • Researcher - Analyzes patterns and workflows
  • Engineer - Develops and optimizes tools
  • Evaluator - Assesses performance and quality

Web Interface

FivcPlayground includes a modern web interface built with Streamlit:

# Launch web interface (default: localhost:8501)
fivcplayground web

# Or using Make
make serve

# Development mode with auto-reload
make serve-dev

# Custom port and host
fivcplayground web --port 8080 --host 0.0.0.0

Features:

  • ๐Ÿ’ฌ Interactive chat interface - Natural conversation with agents
  • ๐Ÿ”„ Async execution - Non-blocking, responsive interface
  • ๐Ÿ› ๏ธ Tool integration - Automatic tool selection and execution
  • ๐Ÿ“ Conversation history - Full session management
  • ๐ŸŽจ Modern UI - Clean, intuitive Streamlit interface

See Web Interface Documentation for detailed usage instructions.

๐Ÿงฐ Available Tools

FivcPlayground includes built-in tools and supports MCP (Model Context Protocol) tools:

Built-in Tools:

  • calculator - Mathematical calculations
  • current_time - Current date and time
  • python_repl - Python code execution

MCP Tools: Configure MCP servers in configs/mcp.yaml to add additional tools dynamically.

๐Ÿ“š Documentation

For comprehensive documentation, see the docs/ directory:

๐Ÿค Contributing

Contributions are welcome! Please feel free to submit issues and pull requests.

๐Ÿ“„ License

MIT

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

fivcplayground-0.1.20.tar.gz (124.2 kB view details)

Uploaded Source

Built Distribution

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

fivcplayground-0.1.20-py3-none-any.whl (94.8 kB view details)

Uploaded Python 3

File details

Details for the file fivcplayground-0.1.20.tar.gz.

File metadata

  • Download URL: fivcplayground-0.1.20.tar.gz
  • Upload date:
  • Size: 124.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.5.10

File hashes

Hashes for fivcplayground-0.1.20.tar.gz
Algorithm Hash digest
SHA256 a4bfa65cc7557063ccf4eb4b8c49091b9bf1f69e8e4fd61e446adce1334b9b5c
MD5 980c5221081e52ba62580f429d7a809d
BLAKE2b-256 ffd7cfb6fb104fa87d784bff99435fae89f0a19ceeb70ca0101d550942edd539

See more details on using hashes here.

File details

Details for the file fivcplayground-0.1.20-py3-none-any.whl.

File metadata

File hashes

Hashes for fivcplayground-0.1.20-py3-none-any.whl
Algorithm Hash digest
SHA256 fee8671dbfc116179fef14279d1638857a13d1aa2f40da8d1c07b8ad3b7be0aa
MD5 2a64163eed5b62f0d0eca842f9864976
BLAKE2b-256 36a11d51d15d55045c387dd722b479d661d40efe745c255ca7c4798544810ef3

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