Self-play

Self-play is a technique for improving the performance of reinforcement learning agents. Intuitively, agents learn to improve their performance by playing "against themselves".

Definition and motivation
In multi-agent reinforcement learning experiments, researchers try to optimize the performance of a learning agent on a given task, in cooperation or competition with one or more agents. These agents learn by trial-and-error, and researchers may choose to have the learning algorithm play the role of two or more of the different agents. When successfully executed, this technique has a double advantage:

Czarnecki et al argue that most of the games that people play for fun are "Games of Skill", meaning games whose space of all possible strategies looks like a spinning top. In more detail, we can partition the space of strategies into sets $$L_1, L_2, ..., L_n$$, such that any $$i < j, \pi_i\in L_i, \pi_j \in L_j$$, the strategy $$\pi_j$$ beats the strategy $$\pi_i$$. Then, in population-based self-play, if the population is larger than $$\max_i |L_i|$$, then the algorithm would converge to the best possible strategy.
 * 1) It provides a straightforward way to determine the actions of the other agents, resulting in a meaningful challenge.
 * 2) It increases the amount of experience that can be used to improve the policy, by a factor of two or more, since the viewpoints of each of the different agents can be used for learning.

Usage
Self-play is used by the AlphaZero program to improve its performance in the games of chess, shogi and go.

Self-play is also used to train the Cicero AI system to outperform humans at the game of Diplomacy. The technique is also used in training the DeepNash system to play the game Stratego.

Connections to other disciplines
Self-play has been compared to the epistemological concept of tabula rasa that describes the way that humans acquire knowledge from a "blank slate".