A Patience game | |
A game of FreeCell on KDE |
|
Named Variants | Baker's Game |
---|---|
Deck | Single 52-card |
Family | Freecell |
See also Glossary of solitaire |
FreeCell is a solitaire-based card game played with a 52-card standard deck. It is fundamentally different from most solitaire games in that nearly all deals can be solved. Although software implementations vary, most versions label the hands with a number (derived from the random number seed used to generate the hand).
A version of FreeCell was created by Microsoft for release with the Windows operating system.
Contents |
Construction and layout:
Building during play:
Moves:
Victory:
For games with the standard layout (four open cells and eight cascades) most games are easily solved.
One of the oldest ancestors of FreeCell is Eight Off. In the June 1968 edition of Scientific American, Martin Gardner described in his "Mathematical Games" column a game by C. L. Baker that is similar to FreeCell, except that cards on the tableau are built by suit rather than by alternate colors. Gardner wrote "The game was taught to Baker by his father, who in turn learned it from an Englishman during the 1920's".[1] This variant is now called Baker's Game. FreeCell's origins may date back even further to 1945 and a Scandinavian game called Napoleon in St. Helena (not the game Napoleon at St. Helena, also known as Forty Thieves).[2]
Paul Alfille changed Baker's Game by making cards build according to alternate colors, thus creating FreeCell. He implemented the first computerised version of it in the TUTOR programming language for the PLATO educational computer system in 1978. Alfille was able to display easily recognizable graphical images of playing cards on the 512 × 512 monochrome display on the PLATO systems.[3]
This original FreeCell environment allowed games with 4–10 columns and 1–10 cells in addition to the standard 8 × 4 game. For each variant, the program stored a ranked list of the players with the longest winning streaks. There was also a tournament system that allowed people to compete to win difficult hand-picked deals. Paul Alfille describes this early FreeCell environment in more detail in an interview from 2000.[4]
The FreeCell game has a constant number of cards. This implies that in constant time, a person or computer could list all of the possible moves from a given start configuration and discover a winning set of moves or, assuming the game cannot be solved, the lack thereof. To perform an interesting complexity analysis one must construct a generalized version of the FreeCell game with 4 × n cards. This generalized version of the game is NP-complete;[5] it is unlikely that any algorithm more efficient than a brute-force search exists that can find solutions for arbitrary generalized FreeCell configurations.
There are 52! (i.e., 52 factorial), or approximately 8×1067, unique deals. However, some games are effectively identical to others because suits assigned to cards are arbitrary or columns can be swapped. After taking these factors into account, there are approximately 1.75×1064 unique games.[2]
One of the passions of several FreeCell enthusiasts was to construct computer programs that could automatically solve FreeCell. Don Woods wrote a solver for FreeCell and several similar games as early as 1997.[6]
Another known solver is Patsolve by Tom Holroyd. Patsolve uses atomic moves, and since version 3.0 has incorporated a weighting function based on the results of a genetic algorithm that make it much faster.[7]
Shlomi Fish started his own solver in 2000, written in C and distributed with source under the public domain (later relicensed under the MIT License).[8][9] This solver was simply dubbed Freecell Solver.
Gary Campbell wrote his FCELL solver for DOS in 8086 assembly language. This solver is 12 kilobytes, and is quite fast. FCELL was incorporated into the Faslo FreeCell AutoPlayer in 2007.[10]
Some of these solvers and others have been incorporated into larger FreeCell or Solitaire programs. FreeCell Pro, the enhanced Windows-based Solitaire implementation by Adrian Ettlinger and Wilson Callan (formerly freeware, later licensed under GPL), first integrated Don Woods' solver[2] and later on used Fish's Freecell Solver and Holroyd's Patsolve.[11] PySolFC has integrated Freecell Solver,[12] while KDE's KPatience solitaire suite had initially integrated Freecell Solver as well, but later switched to a heavily modified version of Patsolve.[13]
It is believed that game #11982 is the only unbeatable game out of the original 32,000 Windows FreeCell games. In the new one million deals in the Windows XP version of FreeCell, there are 8 deals that were shown to be unsolvable.[2] Currently, no computer simulation has been able to solve #11982 while using only four free spaces.[14]
When Microsoft FreeCell became very popular during the 1990s it was not clear which of the 32,000 deals in the program were solvable. To clarify the situation, Dave Ring started The Internet FreeCell Project and took on the challenge of trying to solve all the deals using human solvers. Ring assigned 100 consecutive games chunks across volunteering human solvers and collected the games that they reported to be unsolvable, and assigned them to other people. This project used the power of crowdsourcing to quickly converge on the answer. The project was finished in October 1995, and only one game defied every human player's attempt: #11,982. This deal has also defied every attempt to solve it by several exhaustive-search software solvers, and is therefore assumed to be impossible.[2]
11,982 is inherently difficult due to the large number of aces and other small cards high in the stack, as well as the high cards being relatively evenly distributed among the stacks, requiring one to use many of the cells to get to any useful cards.
Out of the current Microsoft Windows games, there are eight that are unsolvable: the games numbered 11,982; 146,692; 186,216; 455,889; 495,505; 512,118; 517,776 and 781,948. Exhaustive search has shown that 5 free cells (rather than the standard four) are required for these games. Adrian Ettlinger, using Don Woods' solver, has used the same random hand generator as Microsoft Windows FreeCell to explore a further 10 million games. Of the 130 unsolvable games in the first 10 million, all of them require 5 free cells. Ryan L. Miller, with the help of others explored 100 million games, with a total of 1282 being unsolvable. This gives FreeCell a win rate of about 99.998718%.[2]
In the earliest versions, games numbered -1 and -2 were included as a kind of easter egg to demonstrate that there were some possible card combinations that clearly could not be won. Following that, the cards are arranged in order of value, such as King, Queen, Jack, 10, 9 and 8 in the first four piles, and the remaining numbers in the other.
In versions before Windows Vista, if the user pushes the combination of Ctrl+Shift+F10 at any time during the game, the user will be presented with a tool used by the developers during testing.[15]
In the Windows Vista and Windows 7 versions, if the user hits 'Select Game' and types -3 or -4 in the dialog box, then, when the game loads, drags an ace to the suit home pile, the other cards will automatically follow onto the suit home pile, winning the game. Selecting -1 or -2 in the dialog box results in two highly ordered non-random but impossible hands.