1. Field of the Invention
This invention pertains generally to games of chance using fixed pools from which winnings are drawn. More particularly, the invention is a method and apparatus for enabling bonus plays on gaming machines where winnings are drawn from fixed pools.
2. The Prior Art
Traditional fixed pool games are those where a set of draws, prizes, and prize amounts are predetermined. The entire set of draws (including draws having no winnings) is called a fixed or known pool. To play, players draw individual results from the pool. “Drawing” from the pool is traditionally achieved by printing a set of tickets such that one ticket represents one draw from the pool; these tickets are called pre-printed tickets, where the winnings/losings are printed inside each ticket (or under black ink which is scraped off, in which case they are called “scratchers”). A player participates in the draw by purchasing individual pre-printed tickets.
With the advent of Amerindian casinos being run under IGRA (25 U.S.C. §2701-2721), the interest in Class II games has risen dramatically. Class II games can be used in Amerindian casinos without entering into state compacts, a significant advantage over Class III (Nevada-style) games. Traditional fixed pool games such as scratch tickets are categorized as Class II games. As a result, games based on fixed pools that provide more player interest and excitement than traditional scratch tickets or lottery tickets are in demand.
There has been some success in the manufacture of games making use of fixed pools in Amerindian casinos. When a player plays a game in an Amerindian casino, the game makes a request for a game result from a central server. The central server holds the fixed pools, and when a request comes in from a gaming machine, the server randomly picks one result from the pool (the electronic equivalent of a player buying a ticket).
The draw results are sent to the game machine, which displays the pre-determined result to the player in an entertaining fashion. A typical display will in some fashion mimic a video slot reel machine, showing reels spinning and stopping in such a way that the “wins” on the reel symbols match the amount of the pre-determined win. However, the games are extremely limited in terms of play options because of the limitations of using fixed, pre-determined results. For example, there can be no traditional Nevada-style bonus games, because they ordinarily involve winnings based on randomized events beyond that of the initial winnings. Thus, traditional gaming solutions for added secondary games, bonus games, progressives, etc., cannot be used with fixed pool gaming machines. The result has been fixed pool games that provide no added play and very little entertainment beyond simply displaying a result from the fixed pool.
Because of the above-described limitations, there is a need to find a way to provide players of fixed pool gaming machines with features found in Nevada-style gaming, especially game bonus rounds or bonuses.
The present invention will be more fully understood by reference to the following drawings, which are for illustrative purposes.
Persons of ordinary skill in the art will realize that the following description of the present invention is illustrative, not limiting. Other embodiments and variations in the structure and method of the invention will suggest themselves to such skilled persons who have the benefit of the present disclosure, all within the inventive nature of the present disclosure.
Each player terminal must have an operable connection 110 to a central server 112. This will typically be a serial line or ethernet connection within a single site, but readily includes any type of LAN/WAN configuration required for each particular installation, including physically remote sites, using a common server. Further contemplated are evolving networked connections such as wireless networks.
Each player terminal will have internal portions (not illustrated) that are typical for this type of gaming or entertainment machine. That includes electronic interfaces to each video or mechanical human interface device, electronic interfaces to a printer (if a printer is used), a network interface, at least one programmable logic unit (or CPU) and associated support chips including but not limited to static and dynamic memory, software executable on the CPU or main processor board to carry out gaming functions, and one or more interface boards and associated logic operably connecting each externally visible function or port to a CPU.
Voucher 314 is one method a player may use to transfer game credits and/or game information (typically ticket purchase or winning ticket information) from one player terminal to another. This enables a player to stop playing at a terminal by requesting a voucher that has the player's current game play state thereon. This will typically be done using a unique ID (which may be comprised of the issuing machine ID coupled with date/time information to the granularity required for uniqueness, or other unique numerical ID) which will then be used to retrieve game information when the voucher is inserted into another player terminal. Alternatively, the voucher may have all outstanding ticket information on it, so that when a player inserts the voucher into another player terminal at a later time or date, the central server sends the results of the finished games corresponding to the tickets on the voucher to the player terminal now in use.
Also shown are network connections 312 which enable operable coupling of the player terminals to Central Determination Server 300. The present invention requires the use of at least one server 300, but is not limited to one. Each server will have at least one pool of predetermined results, from which a single result is randomly drawn and sent to a player terminal when game play is initiated (conceptually the electronic equivalent of purchasing a scratch-off ticket at a lottery counter; the results are predetermined, but are not known to the player until the results are displayed). Depending on the specifics of each implementation, there may be a plurality of servers on a site or distributed over several sites. As discussed above, a player may request a voucher which (to a player) stops game play on that terminal. Either the player terminal generates a unique transaction ID or the central server may generate it (of which device generates the unique transaction ID that will be implementation-dependent). In either case, the ticket data and unique transaction ID are stored in the database (Oracle or similar database package) on the server. The voucher may or may not have all outstanding ticket data printed thereon—this will depend on the specifics of each implementation. The voucher will always have the unique transaction ID on it, preferably in encryped form (this will require) an encryption/decryption program on either each player terminal or on the server—the machines that generate unique IDs will need to have the capability to encrypt/decrypt). When a player inserts the voucher on a different player terminal, the server will (i) verify the tickets to be displayed on the player terminal if the ticket info was on the voucher, or (ii) retrieve any ticket info associated with the unique transaction ID on the voucher from its database.
The database on server 300 is also usable with player IDs, both in traditional form (a player ID card) and with APIDs (anonymous player IDs). The data about tickets bought, when, and on what machine will be kept in a manner associated with the player ID. The player ID will then be used to retrieve the information. This allows a player to keep one voucher or one player's card, and go from player terminal to player terminal as he/she wishes, even with game in play.
Central determination or fixed pool games can be divided into games that use results from a single draw from a single pool, or use two (or more) draws from the same number of pools. These differences reflect the requirements of local jurisdictions. Some allow only single draws from a single pool per game play, while others allow single draws from more than one pool where the second or tertiary pools can then be used for certain additional play results. Different solutions to providing players with the appearance of bonus game play are found in different embodiments of the present invention, using single or multiple pool draws.
There is always a base game, which is the game shown to a player representing a predetermined win amount that is not a bonus, or secondary, game and which is always shown or played before a bonus or secondary game. The game terminal requests a game outcome (win amount or winnings, which include 0-value-win or losing game outcomes) from a server and receives a game outcome or game result. The game machine then has the job of creating a display that results in the paylines (or other winning indicia) which must show a total equal in value to the already determined win amount. This process is generally known as reverse mapping, which is taking a known result and creating the correct display of winning symbols. Reverse-mapping is the opposite of a normal Nevada-style gaming machine which takes the display of winning symbols and adds them up to determine a winning amount.
A first method of using a single draw to create a base game result and a bonus is for the gaming machine is shown in
Moving to box 406, the actions correspond to initiating a bonus or secondary game round. The second portion of the predetermined win amount will be used as the amount to be given to the player in the simulated bonus round game play. Different bonus game types require different ways of presenting the results to a player. If the bonus game type is a “pick” style bonus game, box 406 is left for box 410. If the bonus game play is not a “pick” style game, then circle 408 is entered for “Other” bonus game play types.
The actions corresponding to box 410 include initiating a pick style bonus round using the second portion of the predetermined results. A player picks (typically using a touchscreen) a-one or more symbols from a plurality of symbols on the player terminal's display. In an actual Nevada-style game the results picked are randomized and summed after game play; in a central determination system the bonus round amount must be reverse-mapped into a bonus game or bonus screen display on the player terminal that mimics the appearance of a Nevada-style pick bonus game.
Continuing to box 412, a randomized value sequence is generated using a random number generator. The randomized sequence is constructed to generate a sequence of numbers that when added together, yield the bonus prize amount. This may be a sequence of one or more numbers and may include 0 value entries that are not “game over” entries (the game developers will decided if they want to make use of 0-value picks depending on the pick game being mimicked). The number in the sequence is variable to keep repeat players from detecting a pattern to the bonus games. Some pick style bonus games limit players to a single touch; in those cases, the full amount of the bonus game portion of the predetermined win will be shown to the player as soon as they indicate any of the pick indicia. When player may make a plurality of choices, then as each choice is made the corresponding element in the randomized sequence is displayed to the player (i.e., the first game indicia picked by the player results in the first element from the randomized sequence being displayed to the player, although it is possible to randomly associate elements from the list with player choices as well). The way in which the value will be shown to the player will be consistent with the bonus game being mimicked (i.e., the game indicia appears to “dissolve” on the screen showing a value, there is an award counter that increments to the side of the screen or buttons, etc.).
Play continues until the cumulative amount shown as won during the bonus game play corresponds to the second portion of the predetermined winnings, with the final choice a player makes typically being a “loser” pick. The exact form of a “loser” pick will be determined by the game, but involves the player making a choice from the remaining indicia and then being shown either a no-win screen or a “game over” screen (or game-over symbol), ending the bonus game. The later allows for the use of O-values in the randomized sequence.
Pool Generation or Protocol Use for Fixed-Pool Games with Bonus
An example Nevada-style game having bonus rounds could look like the following. Assume the base game has the following 3 prizes:
10
100
1000
The game includes a bonus game, which may be entered or played after winning 1000 in the base game. The bonus game can have the following payouts:
10
20
30
If the above game is being mimicked in a jurisdiction allowing fixed-pool games to use multiple pools, the base game outcome is drawn from a base game pool and when triggered, the bonus game outcome would be drawn from a bonus pool. The player terminal would receive these prizes as two parts: a base prize of 1000 credits, and a bonus prize of between 10-30 credits.
If the above game is being mimicked in a jurisdiction that requires fixed-pool games to use a single pool, the mimicked game's base game outcome and bonus game outcome would be combined into elements from the single pool, as follows:
10
1000
1010//bonus
1020//bonus
1030//bonus
When the player terminal receives a bonus ticket, it allocates the combined amount (greater than 1000) into a base game win amount (1000) and a bonus game win amount (the amount left after subtracting 1000).
Another example of a pick style bonus game paytable is as follows.
The paytable is laid out as follows:
The player has a 1 in 10 chance of hitting the game ending indicia. There are, however, many ways of presenting each combination of awards to the player. In this example, there are 512 combinations in this screen. So for any given prize value, the RNG has to work through 512 combinations (worst case) to obtain a set of picks to match the bonus prize. Working through each combination to determining the outcome is called the brute force approach. Another method would be to store each possible bonus prize in the reverse map, along with some information on which series or sequence of picks will be used to generate that prize. The latter is a more desirable implementation method when the amount of this information is reasonable.
In another game with a pick bonus screen the player can select up to 24 boxes. This generates 16 million possible outcomes, which is difficult to deal with from a brute force or data lookup scenario. Another problem is that there are not enough bonus triggers in the finite pool to cover all these bonus outcomes. The solution involves reducing the bonus game outcomes to a reasonable level that can still represent the game.
In this example, the base game triggers the bonus 180,000 times. A template can be created with the same number of tickets as the original game cycle, resulting in 180,000 different bonus prizes to map. There are existing gaming protocols having lower limits than 180,000, however, and part of the usefulness and novelty of the present invention is that it is able to work within limits of older (existing) protocols, which were not designed for use with extra play or bonus game machines. One existing protocol limits the number of unique tickets in a pool to approximately 50,000, so 180,000 must be reduced still further in order to fit these restrictions.
In the case of free spin games, this limits the number of free game outcomes that can be represented in the template. Free spin games are also significantly more difficult to reverse map.
One solution is to use a portion of a field in an existing protocol to send an index that can be used to do a table lookup into a set of bonus outcomes stored in a reverse map. That same index could be used to differentiate between similar amounts with different outcomes. Further, seed data can be sent in an existing field that can be used to map to and represent a set of bonus outcomes
This is based on the idea that you use a RNG to generate the bonus prize originally. If the seed that was used to generate the bonus prize is saved and sent to the gaming machine, the same sequence can be regenerated using the saved seed. This requires some changes to the reverse mapping algorithm.
It is also possible to use the prize index and store all possible bonus prizes with seed value in a reverse map table
This applies to a system where the Lottery terminal receives the entire prize on one electronic ticket only. For display purposes, the Lottery terminal may display this ticket outcome as a single prize, or a series of prizes providing entertainment to the player.
Methods involving limited prize information (i.e., a single draw and limited information passing between the central server and the player terminal). Typical in lottery situations, where the lottery terminal typically receives the prize value with an index value relating to the location in the prize pool from where the ticket was drawn.
One example follows.
Using the above example, the Terminal could receive the following information when a prize of 10 was drawn:
Prize Index: 1
Prize Value: 10
The terminal could use the information in several ways, including:
Verification:
The index and amount could also be stored on the terminal, and comparing this information to the received values can be used as a means of verifying that the terminal has the ability to display this outcome in a suitable fashion.
Display:
The index and value may also be used as a basis for some form of lookup on a table containing display data that may be used to display the outcome.
Display:
The index may be used to differentiate between different ways of displaying the same amount. In the Example above, the prize of 1000 could be displayed in different ways depending on the prize index received by the terminal.
Displaying a Bonus Prize:
Following the example above, imagine a scenario where we wish to display the outcome in a series of stages to the player. We could make a determination that certain prizes can be broken up into two or more smaller prizes, which may then be displayed separately. As an example, assume the terminal received a prize of 1150, index 7 from the pool above. The terminal could make the determination that a suitable way to display this would be as follows:
Display a primary award of 1000 to the player
Display a secondary award of 150 to the player, involving some sort of bonus round.
Determining the Bonus Prize:
The bonus amount of any given prize may be calculated by first determining the primary award. This may be ascertained by using the prize index into a lookup table for display data. In the example above, assume that the prize of 1000 may be mapped to one or more primary outcomes by the terminal. Further, assume that the prize of 1150 is also mapped to a similar set of outcomes, which show a primary outcome of 1000 and also indicate a bonus round. The difference of 150 can then be applied to some form of algorithm or lookup table to determine a suitable outcome for the bonus round.
One such method would be to store possible bonus outcomes on the terminal, with display data.
A successful table lookup would verify that the bonus prize could be mapped. This method can be used for many different bonus outcomes.
More Complicated Bonus Prizes:
One problem with bonus displays is that they can differ depending on the theme represented on the lottery terminal. This requires that the bonus outcomes are stored in many different ways, depending on the complexity of the bonus theme.
A bonus display data can take some of the following forms:
In the example above, the prize information field is used to store the bonus display information previously stored on the lottery terminal. This has the advantage of requiring fewer storage resources on the terminal side, but requires more communications overhead. Because the bonus display information is receive at the same time as the prize, the terminal is not required to determine if the prize is a bonus or not: it already knows because of extra information. This information is not limited to bonus displays only. It can also be used for primary display outcome information.
In a manner similar to the methods described above, this extra set of information could be used for the following methods of enhancing the display:
Working now with multiple pools (multiple draws from different pools), if the jurisdiction allows it, there are further ways to generate bonus winnings. In this case, the wager amount is divided into two portions, with one portion being used with one pool (the main game winnings, if any) and a second portion used to get a result from a second pool (the bonus winning, if any). This further enables the capability of a multi-draw games.
In this example, the player would normally be awarded prizes from the first pool, but in special circumstances, the player would become eligible to draw prizes from the secondary pool, involving a bonus game.
Because the prize awarded from a lottery pool is picked randomly, the player can receive many more bonus outcomes than from the single draw method. For instance, if the prizes of 100 and 1000 in the primary pool allow the player to become eligible for a secondary prize, then the possible outcomes are as follows:
This method is advantageous because each possible prize combination is not required to be stored in the prize pool initially. Furthermore, it is easier to separate primary and bonus outcomes and display them because they are separate draws. Note that the secondary draw is not in any way visible obvious to the player, as they perceive the entire set of outcomes as a single event; it constitutes a single game play: some portion of the primary pool wager must be applied towards the secondary or bonus pool(s).
Methods for generating, storing and displaying outcomes on fixed pool or lottery terminals include storing reel stops for slot emulation. In a typical slot machine, the reel strips and paytable define how the game pays. A set of reel stops are indexes into the reel strips, and when the symbols at these stops are evaluated against the paytable, the appropriate win amount may be determined.
In order to represent such a game on a lottery or finite pool system, it is first necessary to generate all possible reel stop combinations and associated wins to create the finite pool. Furthermore, some method must be used to recreate these stops in order to display any given win amount in an appropriate fashion.
One such method is to store a set of valid reel stops for a given win as a series of bitmaps as follows:
Give a slot machine with 3 reels as follows:
Assuming 3 Aces pay a prize amount, we would need to store the following combinations
One such storage method is to store valid reel stops for any given reel as a bit mask, where an on bit represents a valid reel stop, and an off bit represents an invalid stop. In the example above, the table could be represented as 3 such bit masks for each reel as follows:
Reel 1: 00100001
Reel 2: 00000110
Reel 3: 00001100
This method can be extended to storing masks for multiple wins, further saving storage space.
The following algorithm may be used to regenerate the reel stops from such a bit mask. First, the number of valid stops (bit on) is counted. Then a random valid stop is chosen and the outcome is calculated and verified against the prize received from the lottery system.
General method for storing key data. This method is more general than the method described above, usable for many different types of outcomes. This method is based upon the idea of generating a number of outcomes to be stored in a lottery (fixed) pool, and regenerating those outcomes to provide a display on the terminal side.
Assuming a set of outcomes can be generated by some algorithm, and that algorithm is deterministic and can be driven by some small amount of key data, then it is possible to store the key and use it to regenerate any given set of outcomes on demand.
As an example, consider a bonus display where the player is given the choice of picking a number of boxes. There are a total of 30 boxes, arranged randomly on a 6×5 grid. 24 of the boxes contain prizes, while 6 of the boxes contain a ‘pooper’ prize. The game is such that the player picks until they hit a pooper prize, and are awarded the value of their accumulated picks.
For example:
The empty grids above contain prizes. This game has 2^24 possible outcome combinations, or 16 million. In theory, any attempt to determine the boxes picked for a given prize would involve testing all these combinations. If it is possible to generate the prizes using an algorithm, then it is possible to store a small amount of data for each outcome and use this to regenerate the picks, rather than attempting to brute force the solution. It has been found that one usable algorithm uses a RNG called the LCG (Linear Congruential Generator), with the following formula: Random=69069*Random+23606797
If the first instance of Random is stored, then repeated calls to this function will generate a sequence of random numbers that can be used to pick the prizes in the table above. This seed or key value is stored, along with the bonus prize on the lottery terminal. The bonus prize is also stored in the lottery pool as described above.
If the terminal receives such a bonus prize, the seed value is looked up and the same algorithm is used again to determine the appropriate outcome to be displayed to the player. This method avoids a brute force solution, which may be computationally expensive.
Although the description above contains many specificities, these should not be construed as limiting the scope of the invention but rather as providing an illustration of the presently preferred embodiment of the invention.
This application claims the benefit of provisional application 60/405,120 filed on 22 Aug. 2002. This application is also related to U.S. patent application Ser. No. 10/329,263 filed Dec. 23, 2002, U.S. patent application Ser. No. 10/766,443 filed Jan. 28, 2004, and U.S. patent application Ser. No. 10/772,543 filed Feb. 5, 2004. This application is also related to U.S. patent application Ser. No. 11/381,621, which is a continuation of U.S. patent application Ser. No. 10/891,312 filed Jul. 13, 2004, now U.S. Pat. No. 7,059,966, which is a divisional U.S. patent application Ser. No. 10/142,138 filed May 8, 2002, now U.S. Pat. No. 6,780,108, which claims the benefit of U.S. Provisional Application No. 60/289,845, filed May 8, 2001.
Number | Name | Date | Kind |
---|---|---|---|
4494197 | Troy et al. | Jan 1985 | A |
4817951 | Crouch et al. | Apr 1989 | A |
5324035 | Morris et al. | Jun 1994 | A |
5456465 | Durham | Oct 1995 | A |
5586937 | Menashe | Dec 1996 | A |
5655961 | Acres et al. | Aug 1997 | A |
5779545 | Berg et al. | Jul 1998 | A |
6012982 | Piechowiak et al. | Jan 2000 | A |
6089976 | Schneider et al. | Jul 2000 | A |
6183361 | Cummings et al. | Feb 2001 | B1 |
6315664 | Baerlocher et al. | Nov 2001 | B1 |
6375567 | Acres | Apr 2002 | B1 |
6419583 | Crumby et al. | Jul 2002 | B1 |
6537150 | Luciano et al. | Mar 2003 | B1 |
6609971 | Vancura | Aug 2003 | B2 |
6729961 | Millerschone | May 2004 | B1 |
6749500 | Nelson et al. | Jun 2004 | B1 |
6878061 | Baerlocher et al. | Apr 2005 | B2 |
6988948 | Perrie et al. | Jan 2006 | B2 |
7037195 | Schneider et al. | May 2006 | B2 |
7179168 | Tulley et al. | Feb 2007 | B1 |
20030027619 | Nicastro, Sr. | Feb 2003 | A1 |
Number | Date | Country |
---|---|---|
WO0067424 | Sep 2000 | WO |
Number | Date | Country | |
---|---|---|---|
60405120 | Aug 2002 | US |