Skip to main content

Multi-LLM roundtable for diverse perspective gathering

Project description

taskforce

AI agent-oriented multi-LLM roundtable library.

Multiple top-tier LLMs (GPT, Grok, Claude, Gemini) are queried in parallel with the same agenda, and the collected opinions are classified into common / divergent / unique perspectives, returned as a structured IdeaPool.

This package is designed for AI agents, not for direct human use. The primary interface is the MCP wrapper (roundtable_discuss tool), which allows agents to invoke a roundtable discussion as a tool call. A Python API is also available for programmatic integration.

Quick Start

1. Install

pip install taskforce

For MCP server support:

pip install taskforce[mcp]

2. Set environment variables

At least two provider API keys are required (one will be excluded as the caller). XAI_API_KEY is always required (used by the summarizer).

OPENAI_API_KEY=sk-...
XAI_API_KEY=xai-...
ANTHROPIC_API_KEY=sk-ant-...
GEMINI_API_KEY=AI...

3. Use as MCP tool (recommended for agents)

Add to your MCP server config:

TASKFORCE_CALLER_PROVIDER is the provider of the agent that will call this tool. The matching provider's model is excluded from the panel -- querying the same model that is already reasoning adds no diversity. For example, if Claude Code is the caller, set it to "anthropic" so Claude is excluded from the panel.

{
  "mcpServers": {
    "taskforce": {
      "command": "python",
      "args": ["-m", "taskforce.mcp_wrapper"],
      "env": {
        "TASKFORCE_CALLER_PROVIDER": "anthropic"
      }
    }
  }
}

The agent can then call the roundtable_discuss tool with agenda and context parameters.

4. Use as Python library

from taskforce import Taskforce

tf = Taskforce(caller_provider="anthropic")
pool = tf.discuss(
    agenda="Evaluate the trade-offs of approach A vs B",
    context="<detailed context here>"
)

# pool.common    -- list[str]: points most models agree on
# pool.divergent -- list[DivergentPoint]: topics with differing positions
# pool.unique    -- list[UniquePoint]: points raised by only one model

Important Notes

  • Paid API calls. Every discuss() invocation calls multiple LLM APIs in parallel. Agents should confirm with the user before calling.
  • caller_provider exclusion. The model from the same provider as the calling agent is excluded from the panel to maximize perspective diversity.
  • XAI_API_KEY is mandatory. The summarizer (grok-4-1-fast-non-reasoning) always uses the XAI key.
  • Rich context matters. Input tokens are cheap. Provide as much context as possible -- specifications, constraints, background, decisions already made -- so the panel can give concrete, actionable opinions instead of generic advice.

API

Taskforce(caller_provider, dotenv_path=None)

  • caller_provider (str): The LLM provider of the calling agent (e.g. "anthropic", "openai"). That provider's model is excluded from the panel.
  • dotenv_path (str | None): Path to .env file. Defaults to auto-discovery.

Taskforce.discuss(agenda, context="") -> IdeaPool

Synchronous wrapper. Queries the panel, summarizes, and returns an IdeaPool.

Taskforce.discuss_async(agenda, context="") -> IdeaPool

Async version for use in async contexts.

IdeaPool

Field Type Description
agenda str The original agenda
common list[str] Points most models agree on
divergent list[DivergentPoint] Topics with differing positions (topic, positions: dict[model, position])
unique list[UniquePoint] Points from a single model (point, source_model)
total_cost float Total API cost (USD)
total_tokens int Total tokens consumed

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

ff_taskforce-0.1.0.tar.gz (17.9 kB view details)

Uploaded Source

Built Distribution

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

ff_taskforce-0.1.0-py3-none-any.whl (21.8 kB view details)

Uploaded Python 3

File details

Details for the file ff_taskforce-0.1.0.tar.gz.

File metadata

  • Download URL: ff_taskforce-0.1.0.tar.gz
  • Upload date:
  • Size: 17.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.19

File hashes

Hashes for ff_taskforce-0.1.0.tar.gz
Algorithm Hash digest
SHA256 7f64a320544f9417fbe4dd3074abf5d9280d1c532c925b35fc988404b9ccdf55
MD5 a0bd6c0dd8549d17bf6696a110aed16b
BLAKE2b-256 528fa60e6915402bd8da88d001ec5877e4e1495dca9142e47816f63f434beef0

See more details on using hashes here.

File details

Details for the file ff_taskforce-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: ff_taskforce-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 21.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.19

File hashes

Hashes for ff_taskforce-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 81714112b0a8603f968aa970036fff7d933c476d714f517e400d026952adb904
MD5 4efaec7d40377fa9335ea8c82a90845c
BLAKE2b-256 aebb98c038bdc26fb31395b8d288305045e17bd109fa71c6e5a762b3f75cbfa0

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