Enumerating Backgammon Positions: The Perfect Hash

Like many games, people place money wagers on backgammon games. These wagers can change during the game. In order to make intelligent bets, one needs to know the chances of winning at any point in the game. We were working on this for positions near the end of the game when we needed to explicitly label each of the positions so the computer could refer to them. The labeling developed here uses the least possible amount of computer memory, is reasonably fast, and works well with a technique known as dynamic programming. INTRODUCTION The Game of Backgammon Backgammon is played on a board with 15 checkers per player, and 24 points (organized into four tables of six points each) that checkers may rest on. Players take turns rolling the two dice to move checkers toward their respective "home boards," and ultimately off the board. T h e first player to move all of his checkers off the board wins. We were concerned with the very end of the game, when each of the 15 checkers is either on one of the six points in the home board, or off the board. This is known as the "bearoff," since checkers are borne off the board at each turn. Some sample bearoff positions are shown in Figure 1. We wanted to calculate the chances of winning for any arrangement of positions in the bearoff. To do this, we needed to have a computer play backgammon against itself, to keep track of which side won more often. As part of its strategy, the computer needed to know how many turns it would take to bear off completely from any bearoff position. Thus , we need to know how many bearoff positions there are, and we need a good way of referring to them (a "hash" function). Figure 1. Sample bearoff positions. Left: 3 checkers off the board. Right: 4 checkers off the board. INTERFACE Vol. XVI, Number 1, Summer 1996 The Problem At Hand We want a way to look at a backgammon position and give it a unique and easy-tocompute number that specifies the position. The most obvious way to refer to positions would have used impractical amounts of memory (almost five thousand times as much as necessary). It was like writing a dictionary with entries for "aaaaa" through "zzzzz", with most of the entries blank. Instead, we found a way to give each position a number, such that there are no gaps between positions (no blank entries in the dictionary). Computer scientists refer to this as a "hash" function. Moreover, the function is easy to compute in either direction. It is as if we can look at any word and know which page in the dictionary it appears on, and we can tell which word appears on a page without looking it up. This ability is due to the special structure of backgammon. SOME SIMPLE COMBINATORICS In order to develop our enumeration scheme, we need some simple formulas from combinatorics (the study of ways to combine things). The first is the factorial function, denoted with an exclamation mark (!). This denotes the number of ways of ordering some number of objects. The number of ways to put four books onto a bookshelf is denoted 4 ! . These numbers are easily calculated: n\ = n (n— I) (n — 2)---2 • 1 . So, l ! = 1 , 2! = 2 , 3! = 6 , 4! = 24 , 5! = 120, and so forth. We can use the factorial function to answer more complicated questions. How many ways are there of choosing 4 books out of 6, and putting them on a shelf? The answer is 6 ! / (6 — 4 ) ! , or 360. This is only the case if we must decide on the order of the 4 books, though. If the final order doesnt matter, our value of 360 is too large: the selection ABCD gets counted as different from DCBA, even though the same books were chosen. In fact, each selection is counted 4! times. So, to get the number of ways to chose 4 books from 6 (denoted , , pronounced "six choose four" or "choose four from six"), we take & = 1 5 ( 6 4 ) ! 4 ! And, in general, Kk) (n-k)lkl When we are using the "choose" function, we are not allowed to take more than one of each item. We can't take the same book twice, for example. If we relax this restriction, we end up with more possibilities. How many possible four-scoop ice cream cones are there when we have six flavors to choose from? Now we could get four of the same flavor, or two of two flavors, and so forth. This problem is denoted , , 4 Interface FALL 1996 and pronounced "six multichoose four". It is possible to show that ri\ (n + kk) { k This means that there are II , II = 1,1 = 126 ways to order a four-scooper when presented with six flavors. This is substantially more than the number of choices we had if we could not duplicate flavors. It is also possible to show that , has another interpretation: it is the number of ways to distribute k identical objects to n distinct recipients. One can think of this as distributing four votes to the six ice cream flavors. One could get all of the votes, or four of them could get one vote each, and so forth. It is this last interpretation that will be useful in enumerating backgammon positions. HOW MANY BEAROFF POSITIONS ARE THERE? There are at most 15 checkers to distribute among 6 points. We say "at most" because some of the checkers might have been borne off the board already. If Ki denotes the number of checkers on the z'-th point, then it must be the case that K1 + K2 + ... + K6 < 15 . If we add a "dummy" point, point 0, that counts the number of checkers off the board, we have K0 + Kx + ... + K6= 15 . The number of ways to do this, as discussed above, is , , with n — 1 points and £ = 1 5 identical checkers. So, there are 11= 54264 possible bearoff positions. STORING BEAROFF POSITIONS Each one of these 54264 positions may be represented as a length seven vector of integers, each one between zero and fifteen (inclusive). If we wanted to store some information for each position, and declared a 7-dimensional array on the computer, it would require at least 16 > 268 Megabytes of RAM, an impractical amount on almost any computer. A better method of storage is needed. One reason for the large amount of RAM is the sparseness of the array. The positions are constrained to have the sum of their elements equal 15; that is, if A" is a 6 bearoff position vector, ^T Ki = 15 . Thus, vectors such as (0, 0, 0, 0, 0, 0, 0) and i = 0 (15, 15, 15, 15, 15, 15, 15) are illegal. To guarantee 15 checkers, we can change the vector representation to a length 15 list representation of each checker's position. ROSS Backgammon Positions 5 Thus, the position "all checkers off the board" is expressible as (15, 0, 0, 0, 0, 0, 0) or 000000000000000, and "all checkers on the six-point" is (0, 0, 0, 0, 0, 0, 15) or 666666666666666. Since all checkers are identical, some positions have many representations in this form. To stop this duplication, we restrict the list to be nondecreasing from left to right. We then sort the lists lexicographically, as in Table 1.