Branching factor

From HandWiki
A red–black tree with branching factor 2

In computing, tree data structures, and game theory, the branching factor is the number of children at each node, the outdegree. If this value is not uniform, an average branching factor can be calculated.

For example, in chess, if a "node" is considered to be a legal position, the average branching factor has been said to be about 35,[1][2] and a statistical analysis of over 2.5 million games revealed an average of 31.[3] This means that, on average, a player has about 31 to 35 legal moves at their disposal at each turn. By comparison, the average branching factor for the game Go is 250.[1]

Higher branching factors make algorithms that follow every branch at every node, such as exhaustive brute force searches, computationally more expensive due to the exponentially increasing number of nodes, leading to combinatorial explosion.

For example, if the branching factor is 10, then there will be 10 nodes one level down from the current position, 102 (or 100) nodes two levels down, 103 (or 1,000) nodes three levels down, and so on. The higher the branching factor, the faster this "explosion" occurs. The branching factor can be cut down by a pruning algorithm.

The average branching factor can be quickly calculated as the number of non-root nodes (the size of the tree, minus one; or the number of edges) divided by the number of non-leaf nodes (the number of nodes with children).

See also

References

  1. 1.0 1.1 Levinovitz, Alan (12 May 2014). "The Mystery of Go, the Ancient Game That Computers Still Can’t Win". Wired. https://www.wired.com/2014/05/the-world-of-computer-go/. Retrieved 2014-06-02. "The rate at which possible positions increase is directly related to a game’s “branching factor,” or the average number of moves available on any given turn. Chess’s branching factor is 35. Go’s is 250. Games with high branching factors make classic search algorithms like minimax extremely costly." 
  2. Laramée, François Dominic (6 August 2000). "Chess Programming Part IV: Basic Search". GameDev.net. http://www.gamedev.net/page/resources/_/technical/artificial-intelligence/chess-programming-part-iv-basic-search-r1171. Retrieved 2007-05-01. 
  3. Barnes, David. "What is the average number of legal moves per turn?". https://chess.stackexchange.com/a/24325. Retrieved 2019-06-01.