Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/chain-ml/council
Council is an open-source platform for the rapid development and robust deployment of customized generative AI applications
https://github.com/chain-ml/council
agent ai artificial-intelligence chatgpt generative-ai gpt gpt3 gpt4 machine-learning python
Last synced: 2 months ago
JSON representation
Council is an open-source platform for the rapid development and robust deployment of customized generative AI applications
- Host: GitHub
- URL: https://github.com/chain-ml/council
- Owner: chain-ml
- License: apache-2.0
- Created: 2023-07-10T17:47:04.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-10-29T13:23:46.000Z (3 months ago)
- Last Synced: 2024-10-29T16:03:57.211Z (3 months ago)
- Topics: agent, ai, artificial-intelligence, chatgpt, generative-ai, gpt, gpt3, gpt4, machine-learning, python
- Language: Python
- Homepage: https://council.dev
- Size: 2.67 MB
- Stars: 820
- Watchers: 18
- Forks: 33
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ChatGPT-repositories - council - Council is an open-source platform for the rapid development and robust deployment of customized generative AI applications (Others)
- awesome_ai_agents - Council - Council is an open-source platform for the rapid development and robust deployment of customized generative AI applications (Building / Deployment)
- awesome_ai_agents - Council - Council is an open-source platform for the rapid development and robust deployment of customized generative AI applications (Building / Deployment)
README
![Council](council_banner.png "council")
Council: AI Agent Platform with Control Flow and Scalable Oversight
![Supported Python versions](https://raw.githubusercontent.com/chain-ml/council/main/docs/source/_static/python.svg)
[![License](https://img.shields.io/badge/license-Apache%202.0-green.svg)](https://opensource.org/licenses/Apache-2.0)
[![PyPI version](https://badge.fury.io/py/council-ai.svg)](https://badge.fury.io/py/council-ai)
[![](https://dcbadge.vercel.app/api/server/DWNCftGQZ3?compact=true&style=flat)](https://discord.gg/DWNCftGQZ3)
[![](https://readthedocs.org/projects/council/badge/?version=stable)](https://council.dev)# Welcome
**Council** is an open-source platform for the rapid development and robust deployment of customized generative AI applications using teams of `agents` - built in Python and (soon) Rust.
Council extends the LLM tool ecosystem by enabling advanced control and scalable oversight for AI agents. Users can create sophisticated agents with predictable behavior by leveraging Council's powerful approach to control flow using Controllers, Filters, Evaluators and Budgets for agents. This allows the automated routing between agents, comparing, evaluating and selecting the best results for a (sub-)task.
The framework provides connectivity to a wide variety of Large Language Models (LLMs) natively and by integrating with popular libraries such as LangChain.
**Council** aims to facilitate packaging and seamlessly deploying Agents at scale on multiple deployment platforms while enabling enterprise-grade monitoring and advanced quality control in a future release (contributions are welcome).
# Key Features
* 🧐 **Support for Sophisticated Agents**: Reliable agents that can iterate over tasks that require exploring alternatives, creating and completing subgoals, and evaluating quality under budget constraints.
* 🥰 **Built for Data Scientists**: Python library, local development environment, integrated with popular frameworks.
* 🚀 **Seamless Production Deployments**: Easy packaging, deployment and monitoring at scale on multiple deployment platforms via Kubernetes integration.
* 🤝 **Ecosystem Connectivity**: Connected with a growing AI Agent ecosystem, integrated with LangChain, LlamaIndex and leading AI models.
* 👮 **Scalable Oversight**: Built-in tooling to manage, version, monitor, evaluate and control deployed Agents.Note: Some of the features listed above are work-in-progress and due in a future release.
# Key Concepts
Key components of the framework are shown in below image and further introduced in this section.
![engine flow](docs/source/introduction/engine_flow.png "engine")
## Agent
Agents encapsulate the end-to-end application logic from prompt input to final response across Controller, Evaluation and registered Chains of Skills. Agents itself can be recursively nested within other Agents in the form of AgentChains.## Controller
Controllers determine user intent given a prompt and prompt history and route the prompt to one or multiple of registered Chains before leveraging one or multiple Evaluators to score returned results and determine further course of action (including the ability to determine whether a revision is needed in which case Chains might be prompted again). Controllers will control whether one or multiple Chains are called, whether calls happen in series or in parallel. They will also be responsible for the distribution of compute budget to Chains and handling Chains that are not able to return results within the allocated compute budget. A State Management component will allow Controllers to save and retrieve state across user sessions. Controllers can be implemented in Python or (soon) Rust (to meet the needs of performance-critical applications).## Skill
Skills are services that receive a prompt / input and will return an output. Skills can represent a broad range of different tasks relevant in a conversational context. They could wrap general purpose calls to publicly available language model APIs such as OpenAI’s GPT-4, Anthropic’s Claude, or Google’s Bison. They could also encapsulate locally available smaller language models such as Stable-LM and Cerebras-GPT, or serve more specific purposes such as providing interfaces to application-specific knowledge bases or generate application-aware code snippets.## Chain
Chains are directed graphs of Skills that are co-located and expose a single entry point for execution to Controllers. Users will be able to define their own Chains or reuse existing implementations. Chains themselves can be Agents that are recursively nested into the execution of another Agent as AgentChain.## Evaluator
Evaluators are responsible for assessing the quality of one or multiple Skills / Chains at runtime for example by ranking and selecting the best response or responses that meet a given quality threshold. This can happen in multiple ways and is dependent on the implementation chosen. Users can extend standard Evaluators to achieve custom behavior that best matches their requirements.## Filter
Filters are responsible for filtering responses given back to the controller.## State Management
Council provides native objects to facilitate management of Agent, Chain and Skill context. These objects make it easy to keep track of message history and intermediate results.# Quickstart
## Installation
Install Council in one of multiple ways:
1. (Recommended) Install with pip via Pypi: `pip install council-ai`
2. Install with pip from git ref: `pip install git+https://github.com/chain-ml/council.git@`
- More documentation here: https://pip.pypa.io/en/stable/topics/vcs-support/#git
3. Install with pip from local copy:
- Clone this repository
- Navigate to local project root and install via `pip install -e git+https://github.com/chain-ml/council.git@.`Uninstall with: `pip uninstall council-ai`
## Setup
Set up your required API keys in a `.env` (e.g. OpenAI). Refer to `.env.example` as an example.
## Usage
Import Council.
```python
from council.chains import Chain
from council.skills import LLMSkill
from council.llm import OpenAILLM
```Setup API keys in .env file (example in repository) and use it to set up the LLM here: OpenAILLM
```python
import dotenvdotenv.load_dotenv()
openai_llm = OpenAILLM.from_env()
```Create your first Hello World Skill and Wrap it in a Chain.
```python
prompt = "You are responding to every prompt with a short poem titled hello world"
hw_skill = LLMSkill(llm=openai_llm, system_prompt=prompt)
hw_chain = Chain(name="Hello World", description="Answers with a poem about titled Hello World", runners=[hw_skill])
```Create a second Skill (that responds only with Emojis).
```python
prompt = "You are responding to every prompt with an emoji that best addresses the question asked or statement made"
em_skill = LLMSkill(llm=openai_llm, system_prompt=prompt)
em_chain = Chain(name="Emoji Agent", description="Responds to every prompt with an emoji that best fits the prompt",
runners=[em_skill])
```Create a Controller to route prompts to chains. Here we use the straight-forward LLMController in which an LLM instance is tasked to make a routing decision.
```python
from council.controllers import LLMControllercontroller = LLMController(llm=openai_llm, chains=[hw_chain, em_chain], response_threshold=5)
```Create an Evaluator. Here, we use an LLMEvaluator in which an LLM is tasked to evaluate each response received.
```python
from council.evaluators import LLMEvaluatorevaluator = LLMEvaluator(llm=openai_llm)
```Finalize setup of the Hello World first Agent by combining all components created.
```python
from council.agents import Agent
from council.filters import BasicFilteragent = Agent(controller=controller, evaluator=evaluator, filter=BasicFilter())
```Now, we are ready to invoke the agent.
```python
result = agent.execute_from_user_message("hello world?!")
print(result.best_message.message)
```## Linter
Use `make lint` to verify your code.
## Black
Use `black .` to automatically reformat files.
# Documentation
A detailed documentation of Council can be found at council.dev.
# Support
Please submit a GitHub issue should you need any help or reach out to the team via Discord.
# Contributors
Council is a project under active development. We welcome all contributions, pull requests, feature requests or reported issues.
# Community
Join our Discord community to connect with the core development team and users here.