[TOC]
The Brood War Application Programming Interface (BWAPI) is a free and open source C++ framework that is used to interact with the popular Real Time Strategy (RTS) game Starcraft: Broodwar. Using BWAPI, students, researchers, and hobbyists can create Artificial Intelligence (AI) agents that play the game.
BWAPI only reveals the visible parts of the game state to AI modules by default. Information on units that have gone back into the fog of war is denied to the AI. This enables programmers to write competitive non-cheating AIs that must plan and operate under partial information conditions. BWAPI also denies user input by default, ensuring the user cannot take control of game units while the AI is playing. These defaults can be changed for flexibility, unless enforced by a Tournament Module (game referee for AI tournaments). Changed defaults will be advertised when the match begins.
- Write competitive AIs for Starcraft: Broodwar by controlling individual units.
- Read all relevant aspects of the game state.
- Analyze replays frame-by-frame, and extract trends, build orders, and common strategies.
- Get comprehensive information on the unit types, upgrades, technologies, weapons, and more.
- Study and research real-time AI algorithms in a robust commercial RTS environment.
- Developing a bot in C++? Then download the latest release.
- If you would like to develop a bot in Java, please follow this tutorial.
- Want to help improve BWAPI? Fork the
develop
branch.
- Installation
- Install Visual Studio 2017
- Install StarCraft: Brood War
- Update StarCraft: Brood War to
1.16.1
- Install BWAPI
- Compile
- Open
ExampleProjects.sln
in the BWAPI install directory - Build the ExampleAIModule project in RELEASE mode
- Copy
ExampleAIModule.dll
tobwapi-data/AI
inside the StarCraft install folder
- Open
- Run StarCraft through Chaoslauncher
- Run
Chaoslauncher.exe
as administrator- Chaoslauncher is found in Chaoslauncher directory of BWAPI install directory
- Check the BWAPI Injector x.x.x [RELEASE]
- Click Start
- Make sure the version is set to Starcraft 1.16.1, not ICCup 1.16.1
- Run
- Run a game against Blizzard's AI
- Go to Single Player -> Expansion
- Select any user and click OK
- Click Play Custom, select a map, and start a game
- Run a game against yourself
- Run
Chaoslauncher - MultiInstance.exe
as administrator - Start
- Go to Multiplayer -> Expansion -> Local PC
- Select any user and click OK
- Click Create Game, select a map, and click OK
- Start -- Uncheck BWAPI Injector x.x.x [RELEASE] to let a human play, leave alone to make AI play itself
- Go to Multiplayer -> Expansion -> Local PC
- Select any user and click OK
- Join the existing game created by the other client
- Run
- Documentation: http://bwapi.github.io/
- Repository: https://github.com/bwapi/bwapi
- Issue Tracker: https://github.com/bwapi/bwapi/issues
- Releases: https://github.com/bwapi/bwapi/releases
- SSCAIT Discord: https://discord.gg/DqvHsq9
- IRC Channel: http://webchat.freenode.net/?channels=BWAPI
- Facebook: https://www.facebook.com/groups/bwapi/
- Links to competitions, bots, etc. : https://github.com/bwapi/bwapi/wiki/Useful-Links
Various venues host remote competitive AI competitions that allow developers from around the world to participate. These venues are often held annually and will sometimes offer prizes to the winners. It is also a great way to test your bot's capabilities.
- AAAI Conference on Artificial Intelligence and Interactive Digital Entertainment (AIIDE)
- IEEE Conference on Games (CoG)
- Student StarCraft AI (SSCAI) Tournament
- BWAPI Bots Ladder
You may experience issues when working with BWAPI. Here are some steps you may want to follow in order to resolve them.
- Check the log files found in
Starcraft/Errors/
. - Ask in the IRC channel if anyone has experienced your issue before.
- Check the Issue Tracker to see if your issue has already been reported.
- Submit an issue to the Issue Tracker. Some pieces of information to consider submitting are
- Log files
- Screenshots
- Version or revision number
- Operating System
- Steps to reproduce the problem
Starcraft and Starcraft: Broodwar are trademarks of Blizzard Entertainment. BWAPI is a third party "hack" that violates the End User License Agreement (EULA). It is strongly recommended to purchase a legitimate copy of Starcraft: Broodwar from Blizzard Entertainment before using BWAPI.