Tutorials
Description
In this tutorial, you’ll explore Competitive Game AI—a unique area of competitive programming where the goal is to develop an agent for a game you haven’t seen before. We’ll focus on CodinGame contests, which are known for attracting thousands of participants (typically 4,000–7,000 competitors, held two to three times a year) and for being accessible to both beginners and seasoned competitive AI developers.
Here’s what you can expect:
- Contest Dynamics: Learn about the competition structure, including the usual 10-day timeframe that tests not only your coding skills but also your time and project management. You’ll also get insights on working within strict constraints like a 50–100 millisecond decision time per turn and a 100,000-character code limit.
- Game and Algorithm Matching: Discover a range of intriguing games used in recent competitions and understand how specific algorithms can be tailored to excel in each scenario.
- Winning Strategies: Dive into popular approaches like Monte Carlo Tree Search (MCTS), Beam Search, Minimax, and Rolling Horizon Evolutionary Algorithms (RHEA). While these will be discussed briefly, you’ll see how subtle tweaks and optimizations—often beyond what is covered in academic literature—make a difference.
- Optimization Techniques: Get to know the art of optimizing under limited computational budgets. This includes learning clever action pruning methods, low-level engine improvements, compile-time precomputations, and bit-level optimizations.
Prerequisites
No specialized background is required to attend this session. While some standard search algorithms will be mentioned, they will only be introduced briefly so you can quickly get to the heart of the strategies that drive competitive success in game AI.
Organizers
- Jakub Kowalski, University of Wrocław