Skip to content

nrlewis/autodebater

Repository files navigation

AutoDebater

Coverage Status GitHub Release GitHub Actions Workflow Status GitHub License

AutoDebater is a Python library and CLI for engaging Large Language Models (LLMs) in structured debates. It allows for the creation and management of debates between LLMs, including the ability to judge and score the arguments presented.

Note: This project is a work in progress. Contributions and feedback are welcome!

Features

  • Library and CLI: Engage with LLMs in debates programmatically or via the command line.
  • Multiple Roles: Support for debaters and judges, with configurable prompts and behaviors.
  • Extensible: Designed to be extended with different LLM backends.

Installation

Pip

You can install AutoDebater using pip:

pip install autodebater

Poetry for Development

AutoDebater uses Poetry for dependency management. You can install it with the following steps:

  1. Install Poetry if you haven't already:

    curl -sSL https://install.python-poetry.org | python3 -
  2. Add to your project

    git clone https://github.com/nrlewis/autodebater.git
    cd autodebater
  3. Install dependencies:

    poetry install

Setup

Before using AutoDebater, you need to set your keys:

OpenAI

If using OpenAI:

export OPENAI_API_KEY="your_openai_api_key"

Azure OpenAI

If using Azure, you must set several environment variables:

export AZURE_OPENAI_API_KEY="your_azure_api_key"
export AZURE_OPENAI_ENDPOINT="your_azure_api_endpoint"
export AZURE_OPENAI_API_VERSION="you_azure_api_version"
export AZURE_OPENAI_CHAT_DEPLOYMENT_NAME="your_azure_model_deployment_name"

Usage

CLI

You can use the CLI to start a debate. For example:

 Usage: autodebater [OPTIONS] COMMAND [ARGS]...

Options:
 --install-completion          Install completion for the current shell.                                                                                                                                            │
 --show-completion             Show completion for the current shell, to copy it or customize the installation.                                                                                                     │
 --help                        Show this message and exit.                                                                                                                                                          │

Commands:
 judged-debate   Start a new debate with the given motion and epochs.                                                                                                                                               │
 simple-debate   Start a new debate with the given motion and epochs.                                                                                                                                               │

Example Usage

Full CLI

autodebater judged-debate "AI will surpass human intelligence" --epochs 2

With Poetry

poetry run autodebater judged-debate "AI will surpass human intelligence" --epochs 2

Debates

There are two types of debates, Simple and Judged.

Simple Debate

A simple debate is just two debaters debating each other. One debater is FOR the motion passed, and the other is AGAINST the motion.

The debate will run as many epochs as passed in the CLI (default 2).

Judged Debate

A simple debate with judges listening. One judge is prompted to be an expert on the topic, and the other is a Bullshit Detector, prompted to sniff out logical fallacies.

The debate will run for the number of epochs passed in the CLI (default 2). While the debate goes on, the judges will keep an internal score and their interpretation of the debate as a whole. After the epochs are completed, the judges will summarize their interpretations of the entire debate.

Scoring

The score is set such that a score closer to zero means the judges are AGAINST the motion, and a score closer to 100 means they are FOR the motion. There is a running score showing the geometric mean of the score.

Conceptual Description of the OOP Model

The AutoDebater library follows an Object-Oriented Programming (OOP) model that structures the code into classes representing different entities and roles in a debate. Here is a conceptual overview of the key components:

Core Classes

  • Participant: An abstract base class representing a participant in the debate. It initializes the model to be used, sets the system prompt, and handles the message passing to and from the LLM.
    • Debater: A subclass of Participant. Represents a debater in the debate. Debaters take a stance (for or against the motion) and respond based on the chat history.
    • Judge: A subclass of Participant. Represents a judge in the debate. Judges listen to the debate, score the arguments, and provide a summary at the end.
      • BullshitDetector: A specific type of judge focused on identifying logical fallacies and inconsistencies.

Debate Management

  • Debate: An abstract base class managing the core logic of a debate, including registering participants and handling the message flow.
    • SimpleDebate: A subclass of Debate for simple debates between two debaters.
    • JudgedDebate: A subclass of Debate for debates with judges. Manages the scoring and summarizing of the debate.

Utility Classes

  • DialogueMessage: Represents a message in the debate, including the sender, role, stance, and the message content.
  • DialogueHistory: Manages the history of dialogue messages exchanged during the debate.
  • DialogueConverter: Converts dialogue messages into the format required by the LLM.
  • LLMWrapper: An abstract base class for wrapping LLM function calls. Subclasses handle specific LLM implementations like OpenAI.
    • OpenAILLMWrapper: A subclass of LLMWrapper for interacting with OpenAI's LLMs.

Library

You can also use AutoDebater as a library:

from autodebater.debate import JudgedDebate
from autodebater.participants import Debater, Judge

debate = JudgedDebate(motion="AI will surpass human intelligence", epochs=2)
debate.add_debaters(Debater(name="Debater1", motion="AI will surpass human intelligence", stance="for"))
debate.add_debaters(Debater(name="Debater2", motion="AI will surpass human intelligence", stance="against"))
debate.add_judge(Judge(name="Judge1", motion="AI will surpass human intelligence"))

for message in debate.debate():
    print(message)

Configuration

Modifying Prompts

The prompts used by AutoDebater can be modified by editing the src/autodebater/defaults.yaml file. This allows you to customize the behavior and responses of the debaters and judges to better fit your specific use case.

pyproject.toml

This file contains the configuration for Poetry, including dependencies and build settings.

Adding Participants

You can increase or decrease the number of participants: debaters and judges.

TODOs

  1. Extend LLMWrapper for Azure OpenAI and Claude
  2. AutoGenerate Names
  3. Insert Moderator for a moderated debate
  4. Allow prompt configuration from CLI
  5. Dynamically set judge expertise based on topic of motion rather than "you are an expert on this motion"
  6. Prompt judegs to consider their expertise more than debate structure
  7. Review scoring mechanism and alignment with prompt strategy
  8. Configure with backend for saving debates
  9. Configure with Langchain actions, allowing debaters to pull information from external sources

Contributing

Contributions are welcome! Please follow these steps:

  1. Fork the repository.
  2. Create a new branch for your feature or bugfix.
  3. Write tests for your changes.
  4. Ensure all tests pass.
  5. Submit a pull request.

License

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

Changelog

See the CHANGELOG file for a detailed list of changes and updates.

Contact

For any questions or issues, please open an issue on GitHub.