ConnectFour
ConnectFour
Description
ConnectFour is an environment for evaluating agents on playing the classic Connect Four game against an LLM opponent. This environment wraps the ConnectFour implementation from TextArena, a framework for text-based game environments.
Capabilities
- Pattern recognition for horizontal, vertical, and diagonal sequences
- Strategic blocking and threat creation
- Multi-step planning to create winning opportunities
- Competitive two-player gameplay against an LLM opponent
Compute Requirements
ConnectFour does not require a sandbox. It has minimal compute requirements.
License
MIT.
Tasks
There are two splits: train (450 tasks) and test (450 tasks). Each split contains 50 tasks across each of 9 variants:
- ConnectFour-v0
- ConnectFour-v0-blind
- ConnectFour-v0-blind-raw
- ConnectFour-v0-blind-train
- ConnectFour-v0-large
- ConnectFour-v0-large-raw
- ConnectFour-v0-large-train
- ConnectFour-v0-raw
- ConnectFour-v0-train
Each task is seeded for reproducibility.
Reward Structure
This is a sparse reward environment. Rewards are mapped from TextArena's native range of {-1, 0, 1} to {0.0, 0.5, 1.0} via (raw + 1) / 2.
We do not use LLM graders for this environment; reward is determined programmatically.
Data
Game state is generated procedurally by the TextArena engine using seeded randomness. No external data files are required.
Tools
Agents are given a single tool:
drop_disc(column): Drop a disc into the specified column (0-6). The disc will fall to the lowest available position.
Time Horizon
ConnectFour is a multi-turn environment.
Environment Difficulty
Easy
Other Environment Requirements
This environment requires an OpenAI API key (passed via secrets) to power the LLM opponent.
Safety
Agents in ConnectFour interact only with a board game and have no access to external systems, the internet, or sensitive data. The environment does not present safety risks.
Citations
@software{textarena2024,
author = {Guertler, Leon and Banting, Wilfried and Pignatelli, Eduardo},
title = {TextArena},
year = {2024},
publisher = {GitHub},
url = {https://github.com/LeonGuertler/TextArena}
}