The present disclosure relates to gaming networks and, more particularly, to gaming networks for providing multi-player bingo games.
Gaming in the United States is divided into Class I, Class II and Class III games. Class I gaming includes social games played for minimal prizes, or traditional ceremonial games. Class II gaming includes bingo and bingo-like games. Bingo includes games played for prizes, including monetary prizes, with cards bearing numbers or other designations in which the holder of the cards covers such numbers or designations when objects, similarly numbered or designated, are drawn or electronically determined, and in which the game is won by the first person covering a previously designated arrangement of numbers or designations on such cards. Such an arrangement will sometimes be referred to herein as a “game-winning pattern” or a “game-ending pattern.” Class II gaming may also include pull tab games if played in the same location as bingo games, lotto, punch boards, tip jars, instant bingo, and other games similar to bingo. Class III gaming includes any game that is not a Class I or Class II game, such as a game of chance of the kind typically offered in non-Indian, state-regulated casinos.
Two basic forms of bingo exist. In traditional bingo, the players purchase cards after which a draw takes place. The first player to achieve a designated pattern wins. In one type of bingo game known as Bonanza Bingo, the draw for the game takes place before the players know the arrangements on their bingo cards. After the draw occurs, the players may purchase cards and compare the arrangements on the cards to the drawn numbers to determine whether predetermined patterns are matched. Play continues in Bonanza Bingo until at least one of the players matches a designated game-winning pattern. Bonanza Bingo may also encompass bingo variations wherein a partial draw is conducted for some numbers (generally fewer than the number of balls expected to be necessary to win the game) prior to selling the bingo cards. After the bingo cards are sold, additional numbers are drawn until there is a winner.
In a typical bingo game, a “ball drop” display indicates randomly-drawn numbers to be used in playing the bingo game. Accordingly, the term “ball drop” or the like will be used herein to signify the random selection of numbers used in a bingo game; accordingly, the numbers themselves will often be referred to as “balls.” Those of skill in the art will realize that the numbers used in an electronic bingo game may be displayed in any convenient fashion and that a simulated “ball drop” is merely one such example. The number of balls drawn and the timing of the ball drops may vary according to the type of bingo game.
As indicated above, a bingo game is played until at least one player covers a predetermined game-winning pattern on the player's bingo card. The game may also include interim winners of prizes based on matching predetermined interim patterns on the bingo card using the same ball draw. The interim pattern wins do not terminate the bingo game. For interim pattern awards, players covering certain interim patterns may receive an additional award as the game continues. Some exceptional bingo versions may allow bingo draws beyond those needed to achieve the bingo game win so as to pay out interim pattern wins at a desired rate. The game-winning awards are generally pari-mutuel in nature. That is, the bingo win award is based upon the total amount wagered on a given occurrence of the bingo game. However, interim pattern awards typically are not pari-mutuel.
Gaming machines such as slot machines and video poker machines have proven to be very popular. However, many games of chance that are played on gaming machines fall into the category of Class III games, which may be subject to stricter approval and regulation. Many gaming establishments have a limited number of gaming machines for playing Class III games and a greater number of gaming machines for playing Class II games, such as bingo.
As such, it would be desirable to provide a gaming system wherein a Class II game may be played on a gaming machine with at least some of the “look and feel” of a Class III game. For example, prior art systems have failed to provide a bingo game on a network of gaming machines that satisfies the regulatory requirements for a Class II game while simulating important aspects of a Class III game.
Novel methods, devices and systems are described for mapping pay amounts for a variety of Class III game themes to a common set of bingo pay amounts. Each Class III game theme may cause a different type of entertaining display on a gaming machine when bingo is played, based upon a corresponding Class III game. Preferably, each Class III game theme will offer game play and paytable percentages closely matching those of the original Class III game. Some implementations allow flexibility in matching the probabilities of bingo outcomes and Class III game outcomes by mapping ranges of Class III pay amounts to a single bingo pay amount or vice versa. Some implementations provide a system wherein electronic gaming machines presenting entertaining displays of various Class III game themes are linked to a single bingo server.
Some embodiments of the invention provide a gaming machine that includes the following elements: a network interface; a storage medium; a payout device; at least one display device; and at least one logic device. The logic device is configured to perform the following tasks: control a first display of a bingo game according to bingo game information received via the network interface; determine a bingo payout amount for a result of the bingo game; select a Class III payout amount from a global bingo paytable corresponding with a first Class III game and the bingo payout amount; control a second display of a simulated Class III game outcome corresponding with the Class III payout amount; and determine whether there is a difference between the Class III payout amount and the bingo payout amount.
The logic device may be further configured to control the payout device to award the Class III payout amount, plus a bonus equal to the difference between the Class III payout amount and the bingo payout amount, when the logic device determines that there is a difference between the Class III payout amount and the bingo payout amount. The logic device may be further configured to control the payout device to award the Class III payout amount when the logic device determines that there is no difference between the Class III payout amount and the bingo payout amount. In some instances, the bingo payout amount and the Class III payout amount are equal to zero.
The selecting step may involve selecting a Class III payout amount having a first probability that is approximately equal to a second probability of the bingo payout amount. The selecting step may involve searching a data structure stored in the storage medium, the data structure comprising M bingo payout amounts and N Class III payout amounts.
The selecting step may involve selecting one of a plurality of Class III payout amounts corresponding to the bingo payout amount. For example, the storage medium may contains numbers of Class III outcome representations corresponding to a plurality of Class III payout amounts, the numbers being in proportion to the relative probabilities of the Class III payout amounts, and the selecting step may involve randomly selecting one of the Class III outcome representations. The Class III outcome representations may comprise RNG seeds.
Alternatively (or additionally), a weighting function may be applied to select one of the plurality of Class III payout amounts. The weighting function may, for example, apply a weight in proportion to a probability of a Class III payout amount.
The gaming machine may comprise a first display device and a second display device. The bingo game may be displayed on the first display device and a simulated Class III game may be displayed on the second display device.
The logic device may also be configured for receiving an indication that a second Class III game has been selected and mapping payout amounts of the second Class III game to the global bingo paytable. The logic device may be configured for selecting a Class III payment amount from the global bingo paytable according to a bingo payout amount and the second Class III game.
Alternative implementations of the invention provide a method of forming a global bingo payout set. The method includes these steps: establishing B predetermined bingo payout amounts; assigning at least one bingo pattern to each of the B predetermined bingo payout amounts; and mapping each of the B predetermined bingo payout amounts to at least one Class III payout amount of a first Class III game.
The mapping step may involve mapping ranges of Class III payout amounts to corresponding individual bingo payout amounts. Each Class III payout amount in a range may be less than or equal to a corresponding bingo payout amount. A probability of a bingo payout amount is approximately equal to a sum of probabilities of the Class III payout amounts in the corresponding range. The mapping step may involve associating a plurality of Class III payout amounts in a range with the corresponding bingo payout amount such that when a bingo payout amount is awarded in a bingo game, an outcome corresponding to one of the Class III payout amounts in the range will be displayed on a gaming machine.
The mapping step can involve mapping a single Class III payout amount to more than one bingo payout amount. The method may further comprise assigning at least one Class III outcome to each Class III payout amount. The mapping step can include controlling a ratio of a Class III payout amount to a total payout amount. The mapping step may comprise scaling Class III probabilities according to a ratio between a total Class III probability and a total bingo probability. The mapping step may involve assigning a 100% probability that a predetermined bingo payout amount will result in a corresponding Class III payout amount. The mapping step may comprise mapping at least one individual Class III payout amount to an equal bingo payout amount.
The method can include the step of weighting the Class III payout amounts according to their probability in an underlying Class III game. The weighting step may comprise providing relatively more Class III outcomes for Class III payout amounts having relatively higher probabilities. The weighting step can involve applying a relatively higher weighting function to Class III payout amounts that have relatively higher probabilities. The weighting step may comprise approximating Class III win frequencies of the first Class III game, scaled to the a ratio of the total Class II probabilities and the total Class III probabilities. The weighting step can involve assigning a higher priority to matching probabilities of low payouts of the Class III game. The weighting step can involve assigning a higher priority to matching probabilities of high payouts of the Class III game.
The mapping step may involve mapping a plurality of bingo payouts to a Class III payout such that a sum of probabilities of the plurality of bingo payouts approximately equals a probability of the Class III payout. The mapping step may involve controlling D, a difference between a bingo payout amount and a Class III payout amount. For example, the mapping step may comprise minimizing D. The mapping step may involve controlling D to be no more than a predetermined fraction (e.g., ⅓, ½, ⅔ or ¾) of the bingo payout amount. The mapping step can involve controlling Class III payout probabilities to be inversely proportional to D.
The present invention provides hardware (such as gaming machines, network devices and components of such devices) that is configured to perform the methods of the invention, as well as software to control devices to perform these and other methods.
These and other features of the present invention will be presented in more detail in the following detailed description of the invention and the associated figures.
In this application, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be obvious, however, to one skilled in the art, that the present invention may be practiced without some or all of these specific details. In other instances, well known process steps have not been described in detail in order not to obscure the present invention.
Overview of Providing Class II Games That Simulate Class III Games
Various methods and devices will be described herein for presenting Class II games (primarily bingo games) with entertaining displays that simulate Class III games. According to some such implementations, bingo players may choose from a variety of Class III game themes, each theme having a different entertaining display adapted from a corresponding Class III game. Preferably, each Class III game theme will offer play and win dynamics and paytable percentages closely matching those of the original Class III game.
The following applications describe pertinent material and are hereby incorporated by reference: U.S. patent application Ser. No. 10/925,710, entitled “Draw Bingo” and filed on Aug. 24, 2004; U.S. patent application Ser. No. 10/937,227, entitled “Bingo Game Morphed to Display Non-Bingo Outcomes” and filed on Sep. 8, 2004; U.S. patent application Ser. No. 11/149,828, entitled “Perrius Poker and Other Bingo Game Variations” and filed on Jun. 10, 2005; This application is related to U.S. patent application Ser. No. 11/312,966, entitled “Bingo System with Downloadable Common Patterns” and filed on Dec. 19, 2005; and U.S. patent application Ser. No. 11/312,948, entitled “Bingo Gaming Machine Capable of Selecting Different Bingo Pools” and filed on Dec. 19, 2005 (the “Bingo Pools Application”), collectively, the “Class II/Class III Applications.”
As described in the foregoing applications, providing Class II games that simulate Class III games presents a number of challenges. One of these challenges is to implement such systems while complying with an evolving regulatory framework. It is expected, for example, that Class II regulations will soon require that all gaming machines participating in a single bingo game have the same bingo paytable (the same patterns with the same corresponding probabilities and payouts). This would mean, for example, that if an “X” bingo pattern that pays 10 credits and has a 5% probability of occurring in one game, the pattern must pay 10 credits and have a 5% probability of occurring for all games participating in the same bingo pool.
One approach is to take a Class III paytable, find bingo patterns and probabilities to match the values of the Class III paytable and turn the Class III game into a bingo game. If one were to do this with each Class III paytable individually, one would be turning each Class III game into a separate bingo game.
However, this is not an optimal solution. For example, if a player wants to play a bingo game that simulates Little Green Men®, it is not desirable for the player to play only against other people who are playing Little Green Men® for at least two reasons: (1) there could be a long delay before the game starts, because at least one other person must want to play Little Green Men® at the same time; and (2) the jackpots/bonus awards would tend to be much smaller. It would be preferable to have entertaining displays for many Class III game themes based on one underlying bingo game. This would make it more likely that as soon a player hits “PLAY,” the game can start right away because there is someone else out there playing some other game.
Accordingly, another approach (e.g., as described in the Class II/Class III Applications) is to take multiple Class III paytables and merge them into a single paytable. Some probabilities may be averaged in order to obtain the same payout level in each of the games. For example, the probability of hitting a 2-pay in all of the games can be averaged and the averaged probability value can be included in a global paytable for the bingo game. Bingo patterns that have approximately the averaged probability values may be used that for the global bingo paytable.
Although such methods have advantages, they also have various drawbacks. One drawback is that the global paytable may need to be recalculated and re-downloaded each time a new Class III game theme is added. There are other drawbacks, some of which involve the “hit frequency” issues discussed in the following paragraphs.
As described in the Bingo Pools Application, anticipated regulatory requirements introduce further challenges for Class II games that simulate Class III games having a number of player options that will sometimes be referred to herein as “Class III game options” or the like. Class III game options may be, e.g., the number of paylines in a simulated slot game, a number of hands in a simulated video poker game, a number of spots picked for a simulated keno game or a number of wagers placed on a simulated roulette game. However, in part because of the popularity of slot games, the most commonly referenced Class III game options herein are paylines for simulated slot games.
In a typical Class III slot game, the paytable changes based on the number of paylines played. A player playing one line expects all wins to be a multiple of his or her wager. Increasing the number of lines played increases the “hit frequency” but reduces the average payout size. Accordingly, players can play longer but are less likely to have substantial payouts when they do win. For example, a player playing 10 paylines expects some wins that are less than his or her wager (sometimes referred to as “dribble pays” or “cherry dribblers”), but that allow the player to continue playing longer than if only 1 payline were being played. Playing a large number of paylines appeals to players who desire a smooth, low-volatility game that they can play for a relatively long time. On the other hand, playing a small number of paylines appeals to players who prefer a higher-volatility game with less frequent but larger payouts.
In order to comply with the anticipated Class II regulations and more closely match Class III game play, some implementations described in the Bingo Pools Application provide a system wherein separate paytables and bingo pools are formed according to the number of Class III game options. For example, separate paytables and bingo pools may be formed according to the number of paylines played on slot-type game themes and/or the number of hands played on poker game themes. In some such implementations, players will be limited to predetermined numbers of lines (or hands) played, e.g., only 1, 3, 5 or 9 lines. In alternative implementations, a player's options regarding the number of lines played will depend, at least in part, on how many other players are playing any given number of lines on a slot game.
Some preferred implementations of the present invention develop a global bingo paytable and map multiple disparate paytables for Class III game themes (e.g., slot paytables, poker paytables, roulette paytables, etc.), without altering the global bingo paytable. Some such implementations of the invention provide a global bingo paytable with payouts only at predetermined pay levels. The pay levels may, for example, be selected after surveying popular Class III games and determining common pay levels in those games. Such methods do not need exactly to match the distribution of pays for the Class III games, but should provide a reasonable match with the relative probabilities of the Class III game outcomes.
For example, in one exemplary implementation the global bingo paytable may offer payouts of 1, 2, 3, 4, 5, 10, 15, 20, 25, 30, 40, 50, 100, 150, 200, 500 and 1000, even though the Class III game themes may have payouts at other pay levels. Each payout of the global bingo paytable is associated with at least one bingo pattern. Each pattern has a fixed probability. Preferably, each Class III game theme will offer play and win dynamics and paytable percentages closely matching those of the original Class III game.
Some implementations of the invention combine such methods with those described in the Bingo Pools Application. For example, a first global bingo paytable may be used to form a first bingo pool for a first number of Class III game options, a second global bingo paytable may be used to form a second bingo pool for a second number of Class III game options, etc.
Although slot games will be used as an example of mapping multiple disparate paytables of Class III game themes to a bingo paytable, the methods described herein are applicable to other Class III game themes. In this example, each slot paytable is then mapped so that all slot payouts are associated with a bingo payout paying at least as much as the slot payout. In general, the closer the Class II and Class III payouts are, the better.
In some cases, the slot payout will be the same as the bingo payout. For example, a slot payout of 1 may be associated with a bingo payout of 1. When the bingo game hits a payout of 1, the slot game is also assigned a payout of 1. However, in other cases, the slot payout will not necessarily be the same as the bingo payout.
Moreover, there may not always be a one-to-one relationship between bingo payouts and slot payouts. Instead, a single slot payout may correspond with multiple bingo payouts and vice versa. For example, slot payouts of 11, 12, 13 and 15 may be associated with a single bingo payout of, e.g., 15. In this example, when the bingo game hits a payout of 15, the slot game may be assigned a payout of 11, 12, 13 or 15. In other instances, a single slot payout may correspond with multiple bingo payouts. For example, a slot payout of 3 may correspond with bingo payouts of 3, 4 and 5. The difference between the bingo game payout and the slot game payout, if any, is paid as a “bingo bonus” or some other mystery bonus, so that the total amount awarded is equal to the bingo win.
When multiple slot payouts are associated with a single bingo payout (or vice versa), the payouts may (or may not) be weighted so that their frequency of occurrence corresponds to those of the original class III game within predetermined limits and/or criteria. For example, if a single slot payout is associated with more than one bingo payout, various types of weighting techniques may be employed to assign the proper hit frequency to the slot payouts. Various exemplary methods of this kind are discussed below. However, in alternative implementations, where there are N possible outcomes for the same payout, each outcome is simply assigned a probability of 1/N.
Some methods of the invention form a global bingo paytable having deliberate gaps between predetermined bingo pay levels in order to be able to match the distribution of Class III pays for a wide range of Class III games. For example, one exemplary global bingo paytable may have pays of 10 and 20, with no intermediate pays. Any Class III pay that is between 11 and 20 is in the 11-20 group. The bingo card pays 20 and that amount will be awarded for all Class III pays in the 11-20 group. If the Class III pay is less than 20, the difference between 20 and the Class III pay will be awarded as a “bingo win,” a “mystery bonus,” or the like.
As noted above, the pays in a range can be weighted in order to approximate expected pays and outcomes of the Class III game. Suppose, for example, that the Class III game has pays at 15, 18 and 20, and that the 15-pay is 3 times more likely than the 20-pay in the Class III game. Some implementations of the invention provide 3 times more outcomes that result in a 15-pay, as compared with outcomes that result in a 20-pay. For example, 3 times as many RNG seeds that result in 15-pay outcomes could be provided, as compared to the number of RNG seeds for 20-pay outcomes. Such methods provide the ability to match (or at least to approximate) the relative probabilities of different pays within that group.
Moreover, certain outcomes having the same payout level may be relatively more or less common than others. For example, there may be 4 or 5 different ways to get a 15-pay in the Class III game. Some of these Class III game outcomes may be more probable than others. Therefore, some implementations of the invention weight the more probable outcomes more heavily than the other outcomes of the same pay level. Such weighting could involve assigning more RNG seeds to more probable outcomes. Another method is to assign relative weights to each outcome, making each one more or less likely to be selected on account of the weighting function. The two methods can be combined. U.S. Provisional Patent Application No. 60/709,959, entitled “Multi-Play Poker Gaming System with Predetermined Game Outcomes” and filed Aug. 18, 2005 describes relevant methods, including methods for applying a weighting function to RNG seed selection. This application is hereby incorporated by reference.
Some examples of using a weighting function will now be discussed. In the first example, a player hits a bingo pattern that pays 20. In the list of results that can be sent down to the Class III portion of the game are a variety of RNG seeds. Those RNG seeds can either be weighted or not. If they are weighted, the weights for all of the seeds that are in that group are added. A random-number generator that is the size of the sum is used to pick one of the seeds. A seed that is more likely gets a higher weight than a seed that is less likely. Such methods provide more resolution than simply having relatively more RNG seeds for outcomes that are relatively more likely.
Referring now to
Referring now to
Table 200 illustrates several options that may be used in forming relationships between bingo payouts and Class III payouts. One such option is that of a one-to-one correspondence between some or all bingo payouts and Class III payouts. In this example, the bingo payouts of 3, 4 and 5 have a one-to-one correspondence with Class III payouts. Accordingly, each of these Class III payouts is assigned a weight of 1.00 and has the same probability as that of the bingo payout.
As will be discussed in more detail below, some implementations of the invention populate an entire table according to one-to-one correspondences between bingo payouts and Class III payouts. However, as table 200 illustrates, the same table that includes one-to-one correspondences may also include instances wherein one bingo payout corresponds with multiple Class III payouts and/or vice versa. Here, the Class III payouts of 6, 7, 8, 9 and 10 all correspond with a bingo payout of 10. Each Class III payout in this range, therefore, is assigned a weight of less than one. The sum of the weights is equal to one. The sum of the Class III probabilities in this range is equal to the corresponding bingo probability.
Similarly, the Class III payouts of 10, 12 and 14 all correspond with a bingo payout of 15. As before, the sum of the weights is equal to one and the sum of the Class III probabilities is equal to the corresponding bingo probability.
Table 200 also illustrates the option of overlapping ranges. In this example, there are 2 possible Class III 10-pays in table 200, one of which is assigned to the 6-10 pay range and another of which is assigned to an overlapping 10-15 pay range.
One issue that arises when mapping Class III payouts to a global bingo paytable is that some Class III games will not have low pays, such as 1-pays or 2-pays. If the Class III payouts from such a game are mapped to a global bingo paytable having lower bingo pays, a total “bingo win” or “mystery bonus” will be a common occurrence. For example, if a Class III game having no 1-pay is mapped to a global bingo paytable having a 1-pay, that 1-pay “bingo win” will not correspond with any win of the Class III game. Therefore, a 100% “bingo win” of 1 credit will be a relatively frequent result. For players focused mainly on the actual bingo game being played, this may not be a detriment. However, for players who are more focused on the entertaining displays of Class III game outcomes, this situation could detract from the illusion of playing a Class III game.
Accordingly, some implementations of the invention provide global bingo paytables wherein the smallest bingo payout is greater than 1. The lowest bingo payout may be set to 2, 3, 4, 5 or an even higher pay amount. For example, in some such global bingo paytables the smallest bingo payout is 5. This bingo payout corresponds to Class III payouts ranging from 1 to 5. When the player attains a bingo pattern corresponding with a payout of 5, the player will be awarded 5 credits. The “mystery bonus” will be the difference, if any, between 5 and the Class III payout. Unless the smallest payout in the Class III game is greater than 5, there will always be a corresponding Class III payout.
Some implementations of the invention provide multiple bingo pools that use different global bingo paytables. In some such implementations, the global bingo paytables may have different minimum pays and/or payout levels. For example, one global bingo paytable might have a minimum pay of 1, another might have a minimum pay of 2 and another might have a minimum pay of 5. In some implementations, Class III games can be sorted according to criteria that include their minimum payout amounts. For example, if it is determined that a slot game has no 1 pay, the slot game would use global bingo paytable having a higher minimum pay (e.g., of 2 or 5).
Examples of Adapting a Class III Paytable to a Global Class II Paytable
Following are several examples of forming relationships between payouts in a global Class II paytable (which will be a global bingo paytable in these examples) and a Class III paytable. These methods may be performed by any of various devices, either by acting alone or in combination with other devices. For example, the underlying computations may be performed by one or more logic devices in a host device, a server, etc. The starting Class II and Class III paytables may be received by such a device according to any method know in the art, e.g., by downloading, via data transfer from a memory device, via data entry, etc. Similarly, the resulting data structures, etc., may be provided to another device (e.g., a server, one or more gaming machines, etc.).
These examples will all refer to Class II paytable 300 illustrated in
Moreover, one or more such methods may be used in combination. In some such implementations, several methods are applied to map the same Class III paytable to a Class II paytable and the best outcome is selected according to a predetermined metric. The metric may be, for example, the lowest average (or lowest maximum) “mystery bonus,” the lowest frequency of a “mystery bonus,” the best fit to the original Class III paytable, or some combination of one or more of these. In other implementations, a “hybrid” of 2 or more methods may be used. A hybrid method can be formed, for example, by averaging the results from two or more methods, to produce a distinctly new result.
A comparison of Class II paytable 300 and Class III paytable 350 reveals many differences. These differences indicate some of the previously-referenced challenges in providing simulated Class III games based on a global bingo paytable. For example, many of the payouts do not match. There is no 8-pay, 25-pay, 80-pay or 800-pay in Class II payouts 305 corresponding with those of Class III payouts 355. Similarly, there is no 10-pay, 15-pay, 20-pay, 100-pay or 1000-pay in Class III payouts 355 corresponding with those of Class II payouts 305. Moreover, the overall number of payouts in Class II paytable 300 is larger than the number of payouts in Class III paytable 350.
Even for payouts that are common to both paytables, the probabilities do not match. For example, both paytables include a 1-pay, but column 310 indicates that the probability of obtaining a 1-pay in the Class II game is 0.0900000, whereas column 360 indicates that the probability of obtaining a 1-pay in the Class III game is 0.2152592. Moreover, row 320 indicates that the sum of the probabilities for the Class II payouts is 0.2717200, corresponding to a payback percentage 315 of 91%. Row 370 indicates that the sum of the probabilities for the Class III payouts is 0.4551456, corresponding to a payback percentage 365 of 99.169%.
As this example shows, there are sure to be differences between a given Class III paytable and a global Class II paytable. These differences may include differing pay amounts, different probabilities for the same pay amount, a different overall hit frequency and a different overall paytable percentage. The following discussion presents a series of methods for reconciling such differences.
A first such method 400 is outlined in the flow chart
According to method 400, Class III payouts are matched to Class II probabilities from lowest to highest. In alternative implementations, Class III payouts are matched to Class II probabilities from highest to lowest. As described below, these “bottom up” and “top down” approaches may or may not yield very similar results, depending on certain details that will be described below.
In step 405, a table is defined that associates the payouts and probabilities of the Class II paytable and the Class III paytable. One such table is table 500 of
Class II paytable 530 includes payouts 525 and probability row 515 and total probability 535. The probabilities in probability row 515 are simply the values from column 310 of the Class II paytable illustrated in
White cells 542 indicate where it is possible to associate a Class III win with a Class II win. Grey cells 544 show where it is not possible to associate a Class III win with a Class II win in accordance with the anticipated regulatory scheme. This is so because grey cells 544 indicate situations wherein the Class III win is greater than the Class II win: if we assume that the same bingo pattern must produce the same payout on all participating gaming machines and all Class III game themes, then it would not be permissible for some Class III payouts to be greater than the corresponding Class II payout. However, as discussed in more detail below, some preferred implementations of method 400 involve making interim calculations regarding these grey cells that yield beneficial results.
In step 410, all of the values in the cells 542 and 544 are set to zero. Although different end products are within the scope of the invention, the goal of method 400 is to define a table that determines the Class III payouts associated with each Class II payout and the probability of selecting a corresponding Class III payout, given a specific Class II payout. When a specific Class II win occurs, a Class III win is chosen according to the probabilities defined by the final values in some of cells 542. If the Class III win is less than the corresponding Class II win, the difference between the two is given as a “bingo win,” a “mystery bonus” or the like, so that the sum of the Class III win and the bingo win is always equal to the Class II win.
In step 415, the Class III probabilities are scaled so that the total of Class III probabilities 520 equals the total of Class II probabilities 535. This step is illustrated in
In method 400, each Class III payout is processed in order from lowest to highest. Broadly speaking, the probability of each Class III payout is assigned to as many of the Class II payouts as necessary, so that the total of all probabilities in the same row as the Class III payout is as close as possible to the Class III probability. In alternative methods, this process is performed from the highest Class III payout to the lowest Class III payout.
Accordingly, in step 420, the lowest Class III payout of one is selected. In step 425, the lowest Class II payout with some probability remaining to be assigned is selected. Here, this is the Class II payout of one.
In step 430, the probability associating the Class II payout of 1 with the Class III payout of 1 is set equal to the minimum of the remaining probability of the Class III payout of 1 and the remaining probability of the Class II payout of 1. The probability 546 for the Class II payout of 1 is 0.09, which is less than that for the Class III payout of 1 (0.1285088). Therefore, the entire probability for the Class II payout of 1 is assigned to area 546.
In step 435, it is determined whether the entire Class III probability has been assigned. Here, there is still some (0.1285088−0.09=0.0385088) of the Class III probability left to be assigned, so the process reverts to step 425. Accordingly, the lowest Class II payout with some probability left to be assigned is determined and selected. (Step 425.) That Class II payout is 2, having a probability of 0.07 (cell 550). The probability associating the Class II payout of 2 with the Class III payout of 1 is then set equal to the minimum of the remaining probability of the Class III payout (0.0385088) and the remaining probability of the Class II payout (0.07). (Step 430). Therefore, the remaining probability of the Class III payout (0.0385088) is inserted in cell 552.
In step 435, it is determined that the Class III probability for the payout of 1 has now been fully assigned. The process continues to step 440, wherein it is determined that all Class III payouts have not yet been processed. Therefore, the lowest Class III payout that has not yet been processed (payout=2) is selected. (Step 445.)
The lowest Class II payout with some probability left to be assigned is then determined and selected. (Step 425.) There is some remaining probability left to be assigned (0.07−0.0385088=0.0314912) for a Class II payout of 2. The probability associating the Class II payout of 2 with the Class III payout of 2 is then set equal to the minimum of the remaining probability of the Class III payout (0.0771962) and the remaining probability of the Class II payout (0.0314912). (Step 430). Therefore, the remaining probability of the Class II payout (0.0314912) is inserted in cell 554.
In step 435, it is again determined that the entire probability for the Class III payout of 2 has not yet been assigned, so the process reverts to step 425. The lowest Class II payout with some probability left to be assigned is then determined to be the payout of 3, which is selected. The probability associating the Class II payout of 3 with the Class III payout of 2 is then set equal to the minimum of the remaining probability of the Class III payout (0.0771962−0.0314912=0.045705) and the remaining probability of the Class II payout (0.03). (Step 430). Therefore, the remaining probability of the Class II payout (0.03) is inserted in cell 556.
It is once again determined that the entire probability for the Class III payout of 2 has not yet been assigned (step 435), so the process reverts to step 425. The lowest Class II payout with some probability left to be assigned is then determined to be the payout of 4, which is selected. The probability associating the Class II payout of 4 with the Class III payout of 2 is then set equal to the minimum of the remaining probability of the Class III payout (0.0771962−(0.0314912+0.03)=0.015705) and the remaining probability of the Class II payout (0.05). (Step 430). Therefore, the remaining probability of the Class III payout (0.015705) is inserted in cell 558.
Method 400 continues until it is determined in step 440 that all Class III payouts have been processed. For “bottom up” implementations of method 400, this determination means that the highest Class III payout (here, 800) has been processed. For “top down” implementations of method 400, this determination means that the lowest Class III payout (here, 1) has been processed. Note that when complete, the total of all probabilities in a single column should add up to the Class II probability and the total of all probabilities in a single row should add up to the Class III probability. The “final” Class III probabilities indicated in area 540 indicate, for example, the sum of all probabilities for the Class III payout of 1 (cell 553) and the sum of all probabilities for the Class III payout of 2 (cell 560).
The process then continues to optional step 450, which involves further processing of values, if any, in area 544. This implementation of method 400 temporarily allocates some probabilities in area 544, where the Class III payout exceeds the Class II payout. For example, cell 545 corresponds to a Class III payout of 25 and a Class II payout of 20. Similarly, cell 555 corresponds to a Class III payout of 80 and a Class II payout of 50. As previously noted, having a Class III payout exceed the payout of the Class II outcome is not a result in compliance with anticipated gaming regulations. Therefore, the final result of any method described herein will not provide a value to be used in area 544.
Accordingly, there are at least 2 general categories of implementations for method 400. In one type of implementation, some probabilities are temporarily allocated for cells in area 544. These probabilities may be dealt with in various ways within the scope of method 400. For example, the value in a cell of area 544 could simply be deleted in step 450. The results of such a method will be described below with reference to
Alternatively, in step 450 the value in a cell of area 544 can be added to one or more other probabilities in area 542, e.g., to another cell in the same column that is within area 542. In one such example, the value in cell 545 could be added to the value in cell 561. In another such example, the value in cell 555 could be added to cells 563 and 565 in equal portions, distributed according to the relative probability of each cell, or in another manner. For example, the value in a cell of area 544 could be added to other cells so as to minimize a maximum deviation from the total Class III probability for rows to which the value is added, to minimize an average deviation from such total Class III probabilities, etc. In this example, the value in cell 555 could be added to cells 563 and 565 so as to approximate the desired probabilities for the Class III payouts of 40 and 50 according to some predetermined metric(s).
In implementations of method 400 for which some probabilities are temporarily allocated for cells in area 544, it makes less difference whether a “top down” or a “bottom up” method is used. In other words, whether the method begins with the lowest Class III payout or the highest Class III payout, the resulting probabilities for the cells in area 542 (and the corresponding final Class III probabilities) are similar. Therefore, such implementations are preferred. Still, probabilities corresponding to lower payouts may, at least in some cases, be more similar to those of the underlying Class III game when a “bottom up” technique is used. Probabilities corresponding to higher payouts may be more similar to those of the underlying Class III game when a “top down” technique is used.
However, in other implementations of method 400, interim probabilities are not calculated for cells in area 544. In such implementations, step 450 can be omitted, because no such values will exist. One such implementation will be described below with reference to
Referring now to
Moreover, the sum of probabilities in the columns for Class II payouts of 20 and 50 no longer match the corresponding Class II probabilities. For example, the value in cell 561 does not equal that in cell 567. Similarly, the sum of values in cells 563 and 565 does not equal the value in cell 569.
In order to address this issue, in step 455 all probabilities are normalized so that the sum of probabilities in each column equals 1. This result is shown in
Referring now to
Turning now to
Worse yet, the available Class II probabilities are not sufficient for the method to proceed to any values corresponding to a Class III payout greater than 25 in this example. Cells 615, 620, 625 and 630 receive the corresponding probabilities of Class II payouts 40, 50, 100 and 1000. However, the sum of these probabilities (see cell 635) is still less than the probability of the Class III payout of 25 (see cell 640). Therefore, the method cannot continue beyond cell 630, even though all of the Class III payout levels have not been processed. As a result, in this example there are no Class II payouts that correspond with Class III payouts of 40 or higher.
A simpler method 700 for mapping Class II outcomes to Class III outcomes will now be described with reference to the flow chart of
In step 715, the lowest Class II payout is selected. This is a payout of 1 in the instant case. Accordingly, this implementation of method 700 is a “bottom up” implementation. In alternative implementations, the highest Class II payout is selected and the process operates from the top down. Alternative implementations start with still another payout.
In step 720, the highest Class III payout that is less than or equal to the selected Class II payout is selected. In this example, the only qualifying Class III payout is also a payout of 1. The probability for the Class III payout is then set to 1 and cell 805 is populated accordingly. (Step 725.) This means that when a Class II outcome occurs having a payout of 1, there is a 100% chance that a simulated Class III outcome having a payout of 1 will be presented when the resulting data structure is used during game play. No “mystery bonus” will be required, because the Class II and Class III payout amounts are the same. In the “pure” versions of this method, no effort is made to simulate more closely the hit frequency of the underlying Class III game.
In step 730, it is determined that all Class II payouts have not been processed, so the next-lowest Class II payout is selected. (Step 735.) In successive iterations, cells 810, 815, 820 and 825 are populated with values of 1, indicating that the Class II payouts of 2, 3, 4 and 5 will have a 100% correspondence with the Class III payouts of 2, 3, 4 and 5. Again, because the Class II and Class III payout amounts are the same, no “mystery bonus” will be required.
Cells 830, 835 and 840 are populated in the same way. However, in this instance, a 100% correspondence is made between 3 different Class II payouts (10, 15 and 20) and a single Class III payout (8). “Mystery bonuses” of 2, 7 and 12, respectively, are required to make the total win amount equal the Class II payout amount.
When the Class II payout of 40 is processed, another type of mismatch occurs. In this case, the Class III payout of 40 will be selected in step 720, because it is the highest Class III payout not yet processed that is less than or equal to the Class II payout. Therefore, a 100% correspondence is formed between the Class II payout of 40 and the Class III payout of 40 and cell 850 is populated with a 1. However, cell 845 is skipped. This means that there is no Class II payout that corresponds with a Class III payout of 25.
The remaining Class II payouts of 50, 100 and 1000 are processed in the same fashion in successive iterations of this implementation of method 700. Cells 855, 860 and 865 are populated with ones, as before. After it is determined in step 730 that the highest Class II payout has been processed, the method ends. (Step 740.)
As previously mentioned, “hybrids” of the foregoing methods and their equivalents are within the scope of the present invention. For example, one such hybrid implementation involves a determination as to whether there are Class III payouts that have no corresponding Class II payouts after one of the foregoing methods is completed.
For example, suppose a result such as that indicated by
Alternative method 900 of the invention will now be described. According to preferred implementations of this method, the probability for each Class III payout is distributed among all available Class II payouts in inverse proportion to the difference between the Class III and Class II payouts, which will again be referred to as a “mystery bonus” or the like. Some implementations of the method involve controlling the mystery bonus to be less than or equal to a predetermined amount.
Referring now to
In step 920, the lowest Class II payout greater than or equal to the current Class II payout is selected, which is payout of 1 in this instance. In step 925, one or more criteria are applied to control the maximum possible size of the mystery bonus. Various metrics may be used for this purpose, such as controlling the mystery bonus to be less than or equal to a predetermined fraction of the total win. For example, some implementations of this method ensure that the mystery bonus will be no more than ⅓, ½, ⅔ or ¾ of the total Class II payout. Similarly, such implementations of the method may ensure that the Class III is at least a predetermined fraction (e.g., ⅓, ½, ⅔ or ¾) of the total Class II payout, or conversely whether the Class II payout is no more than a predetermined multiple of the Class III payout.
Accordingly, in this example, step 925 involves a determination of whether the Class II payout is 3 times the Class III payout or more. In this example, the answer is “no,” so the method proceeds to step 930. At this stage, it is determined whether the Class III and Class II payouts are equal. They are equal, so the method proceeds to step 935.
In step 935, the probability is set to an arbitrarily high value (2 in this example). This places a higher weight on payouts involving no mystery bonus. Cell 1005 of
The next Class II payout is then selected (step 940) and the metric(s) of step 925 are applied once again. The next Class II payout is 2, which is less than 3 times the Class III payout of 1. It is determined in step 930 that the Class II and Class III payouts are not equal, so the probability of the Class II payout is scaled to be lower than the probability corresponding to a situation wherein the payouts are equal. (Step 945.) In this example, the probability is set to be inversely proportional to the difference between the Class II payout and the Class III payout (the inverse of the mystery bonus), which is 1/1=1. Cell 1010 of
The next Class II payout is then selected, which is 3 in this example (step 940). In step 925, it is determined that the Class II payout is 3 times the Class III payout, so no probability is calculated for cell 1015 of
In step 950, it is determined that all Class III payouts have not yet been processed, so the next lowest Class III payout is selected (step 955). The process continues until it is determined in step 950 that all Class III payouts have been processed. The result in this example is indicated in
Subsequent steps also involve scaling the probabilities, which may be done in various ways and in various sequences. In this example, the probabilities are first scaled so that all probabilities associated with a single Class III payout add up to that payout's probability. (Step 955.) This interim result is shown in
In optional step 960, any Class II payouts that have no associated probability are associated with a lower or equal Class III payout. Here, the Class II payout of 20 is associated with a Class III payout of 8. (See cell 1020 of
Next, the probabilities in each column are scaled such that their sum is equal to that of the Class II payout. (Step 965.) The result of this step is indicated in
The probabilities are then normalized, so that the sum of all probabilities associated with a single Class II payout is 1. (Step 970.) The result is shown in
Another example of a “hybrid” method will now be described with reference to
Some implementations of the polishing method evaluate such results to determine instances wherein two Class III payouts have probabilities in the same Class II column. If two Class III payouts have probabilities in the same Class II column, it is determined a) whether the lower Class III payout probability is higher than desired and b) whether the higher Class III payout is lower than desired. The “desired” probability is generally the Class III probability associated with a particular Class III payout before the foregoing methods are applied (e.g., as depicted in
Referring now to table 1100 of
According to the polishing method, both probabilities can be moved closer to the desired probabilities. Various mathematical operations may be used for the fine-tuning process. In the example shown in
The polishing method can improve the table in several ways. First of all, the polishing method reduces the discrepancy in the desired probabilities. Secondly, the polishing method reduces the average “mystery bonus.”
There are additional criteria that can trigger the polishing method. For example, it could be invoked when two Class III payouts both have probabilities in the same Class II column, both probabilities are too high and the lower Class III payout probability discrepancy is more than the higher Class III payout probability discrepancy. The polishing method could also be invoked when two Class III payouts both have probabilities in the same Class II column, both probabilities are too low and the lower Class III payout probability discrepancy is less than the higher Class III payout probability discrepancy.
It is desirable to have as many gaming machines as possible participating in the same bingo game. Having a large number of participating gaming machines allows larger jackpots to accumulate and reduces the time that players spend waiting for additional players. Therefore, some implementations provide a system wherein a plurality of electronic gaming machines, each of which is configured for presenting entertaining displays of various Class III game themes, is linked to a single bingo server. By linking many participating electronic gaming machines to a single server, some implementations of the invention allow progressive contributions from all of the participating electronic gaming machines to be pooled into a single progressive jackpot.
Some embodiments of the invention involve gaming machines that are configured with a graphical user interface (“GUI”) or the like that allows a player to select a Class III game theme from a plurality of Class III game themes. In some such embodiments, the gaming machine is configured to present any of the proffered Class III game themes.
Alternatively, or additionally, the game theme of a particular networked gaming machine (or a group of networked gaming machines) may be changed according to instructions received from a central system: some gaming networks described herein include a central system that is configured to download game software and data, including but not limited to the underlying bingo patterns, pays and game outcomes, to networked gaming machines. Such gaming networks allow for the convenient provisioning of networked gaming machines.
Moreover, such gaming networks allow additional game themes to be easily and conveniently added, if desired. Related software, including but not limited to game software, may be downloaded to networked gaming machines. Relevant information is set forth in U.S. patent application Ser. No. 11/225,407, by Wolf et al., entitled “METHODS AND DEVICES FOR MANAGING GAMING NETWORKS” and filed Sep. 12, 2005, in U.S. patent application Ser. No. 10/757,609 by Nelson et al., entitled “METHODS AND APPARATUS FOR GAMING DATA DOWNLOADING” and filed on Jan. 14, 2004, in U.S. patent application Ser. No. 10/938,293 by Benbrahim et al., entitled “METHODS AND APPARATUS FOR DATA COMMUNICATION IN A GAMING SYSTEM” and filed on Sep. 10, 2004, in U.S. patent application Ser. No. 11/225,337 by Nguyen et al., filed Sep. 12, 2005 and entitled “DISTRIBUTED GAME SERVICES” and in U.S. patent application Ser. No. 11/173,442 by Kinsley et al., filed Jul. 1, 2005 and entitled “METHODS AND DEVICES FOR DOWNLOADING GAMES OF CHANCE,” all of which are hereby incorporated by reference in their entirety and for all purposes. Some exemplary gaming networks and devices are below.
Exemplary System Architecture
One example of a network topology for implementing some aspects of the present invention is shown in
Gaming establishment 1205 includes 16 gaming machines 2, each of which is part of a bank 1210 of gaming machines 2. It will be appreciated that many gaming establishments include hundreds or even thousands of gaming machines 2, not all of which are included in a bank 1210. However, the present invention may be implemented in gaming establishments having any number of gaming machines.
Various alternative network topologies can be used to implement different aspects of the invention and/or to accommodate varying numbers of networked devices. For example, gaming establishments with very large numbers of gaming machines 2 may require multiple instances of some network devices (e.g., of main network device 1225, which combines switching and routing functionality in this example) and/or the inclusion of other network devices not shown in
Each bank 1210 has a corresponding bank switch 1215, which may be a conventional bank switch. Each bank switch is connected to server-based gaming (“SBG”) server 1230 via main network device 1225, which combines switching and routing functionality in this example. Although various floor communication protocols may be used, some preferred implementations use IGT's open, Ethernet-based SuperSAS® protocol, which IGT makes available for downloading without charge. However, other protocols such as Best of Breed (“BOB”) may be used to implement various aspects of SBG. IGT has also developed a gaming-industry-specific transport layer called CASH that rides on top of TCP/IP and offers additional functionality and security.
SBG server 1230, License Manager 1231, Arbiter 133 and main network device 1225 are disposed within computer room 1220 of gaming establishment 1205. License Manager 1231 may be implemented, at least in part, via a server or a similar device. Some exemplary operations of License Manager 1231 are described in detail in U.S. patent application Ser. No. 11/225,408, entitled “METHODS AND DEVICES FOR AUTHENTICATION AND LICENSING IN A GAMING NETWORK” by Kinsley et al., which is hereby incorporated by reference.
SBG server 1230 can be configured to implement, at least in part, various aspects of the present invention. Some preferred embodiments of SBG server 1230 include (or are at least in communication with) clustered CPUs, redundant storage devices, including backup storage devices, switches, etc. Such storage devices may include a redundant array of inexpensive disks (“RAID”), back-up hard drives and/or tape drives, etc. Preferably, a Radius and a DHCP server are also configured for communication with the gaming network. Some implementations of the invention provide one or more of these servers in the form of blade servers.
In some implementations of the invention, many of these devices (including but not limited to License Manager 1231 and main network device 1225) are mounted in a single rack with SBG server 1230. Accordingly, many or all such devices will sometimes be referenced in the aggregate as an “SBG server.” However, in alternative implementations, one or more of these devices is in communication with SBG server 1230 but located elsewhere. For example, some of the devices could be mounted in separate racks within computer room 1220 or located elsewhere on the network. For example, it can be advantageous to store large volumes of data elsewhere via a storage area network (“SAN”).
In some embodiments, these components are SBG server 1230 preferably has an uninterruptible power supply (“UPS”). The UPS may be, for example, a rack-mounted UPS module.
Computer room 1220 may include one or more operator consoles or other host devices that are configured for communication with SBG server 1230. Such host devices may be provided with software, hardware and/or firmware for implementing various aspects of the invention; many of these aspects involve controlling SBG server 1230. However, such host devices need not be located within computer room 1220. Wired host device 1260 (which is a laptop computer in this example) and wireless host device (which is a PDA in this example) may be located elsewhere in gaming establishment 1205 or at a remote location.
Arbiter 133 may be implemented, for example, via software that is running on a server or another networked device. Arbiter 133 serves as an intermediary between different devices on the network. Some implementations of Arbiter 133 are described in U.S. patent application Ser. No. 10/948,387, entitled “METHODS AND APPARATUS FOR NEGOTIATING COMMUNICATIONS WITHIN A GAMING NETWORK” and filed Sep. 23, 2004 (the “Arbiter Application”), which is incorporated herein by reference and for all purposes. In some preferred implementations, Arbiter 133 is a repository for the configuration information required for communication between devices on the gaming network (and, in some implementations, devices outside the gaming network). Although Arbiter 133 can be implemented in various ways, one exemplary implementation is discussed in the following paragraphs.
Referring to
Although the program memories 122, 132 are shown in
As shown in
As disclosed in further detail in the Arbiter Application, the Arbiter 133 may verify the authenticity of each network gaming device. The Arbiter 133 may receive a request for a communication session from a network device. For ease of explanation, the requesting network device may be referred to as the client, and the requested network device may be referred to as the host. The client may be any device on the network 12 and the request may be for a communication session with any other network device. The client may specify the host, or the gaming security arbiter may select the host based on the request and based on information about the client and potential hosts. The Arbiter 133 may provide encryption keys (session keys) for the communication session to the client via the secure communication channel. Either the host and/or the session key may be provided in response to the request, or may have been previously provided. The client may contact the host to initiate the communication session. The host may then contact the Arbiter 133 to determine the authenticity of the client. The Arbiter 133 may provide affirmation (or lack thereof) of the authenticity of the client to the host and provide a corresponding session key, in response to which the network devices may initiate the communication session directly with each other using the session keys to encrypt and decrypt messages.
Alternatively, upon receiving a request for a communication session, the Arbiter 133 may contact the host regarding the request and provide corresponding session keys to both the client and the host. The Arbiter 133 may then initiate either the client or the host to begin their communication session. In turn, the client and host may begin the communication session directly with each other using the session keys to encrypt and decrypt messages. An additional explanation of the communication request, communication response and key distribution is provided in the Arbiter Application.
Wireless devices are particularly useful for managing a gaming network. Such wireless devices could include, but are not limited to, laptops, PDAs or even cellular telephones. Referring once again to
If a host device is located in a remote location, security methods and devices (such as firewalls, authentication and/or encryption) should be deployed in order to prevent the unauthorized access of the gaming network. Similarly, any other connection between gaming network 1205 and the outside world should only be made with trusted devices via a secure link, e.g., via a virtual private network (“VPN”) tunnel. For example, the illustrated connection between SBG 1230, gateway 1250 and central system 1263 (here, IGT.com) that may be used for game downloads, etc., is advantageously made via a VPN tunnel.
An Internet-based VPN uses the open, distributed infrastructure of the Internet to transmit data between sites. A VPN may emulate a private IP network over public or shared infrastructures. A VPN that supports only IP traffic is called an IP-VPN. VPNs provide advantages to both the service provider and its customers. For its customers, a VPN can extend the IP capabilities of a corporate site to remote offices and/or users with intranet, extranet, and dial-up services. This connectivity may be achieved at a lower cost to the gaming entity with savings in capital equipment, operations, and services. Details of VPN methods that may be used with the present invention are described in the reference, “Virtual Private Networks-Technologies and Solutions,” by R. Yueh and T. Strayer, Addison-Wesley, 2001, ISBN#0-201-70209-6, which is incorporated herein by reference and for all purposes.
There are many ways in which IP VPN services may be implemented, such as, for example, Virtual Leased Lines, Virtual Private Routed Networks, Virtual Private Dial Networks, Virtual Private LAN Segments, etc. Additionally VPNs may be implemented using a variety of protocols, such as, for example, IP Security (IPSec) Protocol, Layer 2 Tunneling Protocol, Multiprotocol Label Switching (MPLS) Protocol, etc. Details of these protocols, including RFC reports, may be obtained from the VPN Consortium, an industry trade group (http://www.vpnc.com, VPNC, Santa Cruz, Calif.).
For security purposes, any information transmitted to or from a gaming establishment over a public network may be encrypted. In one implementation, the information may be symmetrically encrypted using a symmetric encryption key, where the symmetric encryption key is asymmetrically encrypted using a private key. The public key may be obtained from a remote public key server. The encryption algorithm may reside in processor logic stored on the gaming machine. When a remote server receives a message containing the encrypted data, the symmetric encryption key is decrypted with a private key residing on the remote server and the symmetrically encrypted information sent from the gaming machine is decrypted using the symmetric encryption key. A different symmetric encryption key is used for each transaction where the key is randomly generated. Symmetric encryption and decryption is preferably applied to most information because symmetric encryption algorithms tend to be 100-10,000 faster than asymmetric encryption algorithms.
As mentioned elsewhere herein, U.S. patent application Ser. No. 11/225,408, entitled “METHODS AND DEVICES FOR AUTHENTICATION AND LICENSING IN A GAMING NETWORK” by Kinsley et al., describes novel methods and devices for authentication, game downloading and game license management. This application has been incorporated herein by reference.
Providing a secure connection between the local devices of the SBG system and IGT's central system allows for the deployment of many advantageous features. For example, a customer (e.g., an employee of a gaming establishment) can log onto an account of central system 1263 (in this example, IGT.com) to obtain the account information such as the customer's current and prior account status.
Moreover, such a secure connection may be used by the central system 1263 to collect information regarding a customer's system. Such information includes, but is not limited to, error logs for use in diagnostics and troubleshooting. Some implementations of the invention allow a central system to collect other types of information, e.g., information about the usage of certain types of gaming software, revenue information regarding certain types of games and/or gaming machines, etc. Such information includes, but is not limited to, information regarding the revenue attributable to particular games at specific times of day, days of the week, etc. Such information may be obtained, at least in part, by reference to an accounting system of the gaming network(s), as described in U.S. patent application Ser. No. 11/225,407, by Wolf et al., entitled “METHODS AND DEVICES FOR MANAGING GAMING NETWORKS,” which has been incorporated herein by reference.
Automatic updates of a customer's SBG server may also be enabled. For example, central system 1263 may notify a local SBG server regarding new products and/or product updates. For example, central system 1263 may notify a local SBG server regarding updates of new gaming software, gaming software updates, peripheral updates, the status of current gaming software licenses, etc. In some implementations of the invention, central system 1263 may notify a local SBG server (or another device associated with a gaming establishment) that an additional theme-specific data set and/or updates for a previously-downloaded global payout set are available. Alternatively, such updates could be automatically provided to the local SBG server and downloaded to networked gaming machines.
After the local SBG server receives this information, it can identify relevant products of interest. For example, the local SBG server may identify gaming software that is currently in use (or at least licensed) by the relevant gaming entity and send a notification to one or more host devices, e.g., via email. If an update or a new software product is desired, it can be downloaded from the central system. Some relevant downloading methods are described elsewhere herein and in applications that have been incorporated herein by reference, e.g., in U.S. patent application Ser. No. 11/078,966. Similarly, a customer may choose to renew a gaming software license via a secure connection with central system 1263 in response to such a notification.
Secure communication links allow notifications to be sent securely from a local SBG server to host devices outside of a gaming establishment. For example, a local SBG server can be configured to transmit automatically generated email reports, text messages, etc., based on predetermined events that will sometimes be referred to herein as “triggers.” Such triggers can include, but are not limited to, the condition of a gaming machine door being open, cash box full, machine not responding, verification failure, etc.
In addition, providing secure connections between different gaming establishments can enable alternative implementations of the invention. For example, a number of gaming establishments, each with a relatively small number of gaming machines, may be owned and/or controlled by the same entity. In such situations, having secure communications between gaming establishments makes it possible for a gaming entity to use a single SBG server as an interface between central system 1263 and the gaming establishments.
Turning next to
Many different types of games, including mechanical slot games, video slot games, video poker, video black jack, video pachinko and lottery, may be provided with gaming machines of this invention. In particular, the gaming machine 2 may be operable to provide a play of many different instances of games of chance. The instances may be differentiated according to themes, sounds, graphics, type of game (e.g., slot game vs. card game), denomination, number of paylines, maximum jackpot, progressive or non-progressive, bonus games, etc. The gaming machine 2 may be operable to allow a player to select a game of chance to play from a plurality of instances available on the gaming machine. For example, the gaming machine may provide a menu with a list of the instances of games that are available for play on the gaming machine and a player may be able to select from the list a first instance of a game of chance that they wish to play.
The various instances of games available for play on the gaming machine 2 may be stored as game software on a mass storage device in the gaming machine or may be generated on a remote gaming device but then displayed on the gaming machine. The gaming machine 2 may executed game software, such as but not limited to video streaming software that allows the game to be displayed on the gaming machine. When an instance is stored on the gaming machine 2, it may be loaded from the mass storage device into a RAM for execution. In some cases, after a selection of an instance, the game software that allows the selected instance to be generated may be downloaded from a remote gaming device, such as another gaming machine.
The gaming machine 2 includes a top box 6, which sits on top of the main cabinet 4. The top box 6 houses a number of devices, which may be used to add features to a game being played on the gaming machine 2, including speakers 10, 12, 14, a ticket printer 18 which prints bar-coded tickets 20, a key pad 22 for entering player tracking information, a florescent display 16 for displaying player tracking information, a card reader 24 for entering a magnetic striped card containing player tracking information, and a video display screen 42. The ticket printer 18 may be used to print tickets for a cashless ticketing system. Further, the top box 6 may house different or additional devices than shown in
Understand that gaming machine 2 is but one example from a wide range of gaming machine designs on which the present invention may be implemented. For example, not all suitable gaming machines have top boxes or player tracking features. Further, some gaming machines have only a single game display—mechanical or video, while others are designed for bar tables and have displays that face upwards. As another example, a game may be generated in on a host computer and may be displayed on a remote terminal or a remote gaming device. The remote gaming device may be connected to the host computer via a network of some type such as a local area network, a wide area network, an intranet or the Internet. The remote gaming device may be a portable gaming device such as but not limited to a cell phone, a personal digital assistant, and a wireless game player. Images rendered from 3-D gaming environments may be displayed on portable gaming devices that are used to play a game of chance. Further a gaming machine or server may include gaming logic for commanding a remote gaming device to render an image from a virtual camera in a 3-D gaming environments stored on the remote gaming device and to display the rendered image on a display located on the remote gaming device. Thus, those of skill in the art will understand that the present invention, as described below, can be deployed on most any gaming machine now available or hereafter developed.
Some preferred gaming machines of the present assignee are implemented with special features and/or additional circuitry that differentiates them from general-purpose computers (e.g., desktop PC's and laptops). Gaming machines are highly regulated to ensure fairness and, in many cases, gaming machines are operable to dispense monetary awards of multiple millions of dollars. Therefore, to satisfy security and regulatory requirements in a gaming environment, hardware and software architectures may be implemented in gaming machines that differ significantly from those of general-purpose computers. A description of gaming machines relative to general-purpose computing machines and some examples of the additional (or different) components and features found in gaming machines are described below.
At first glance, one might think that adapting PC technologies to the gaming industry would be a simple proposition because both PCs and gaming machines employ microprocessors that control a variety of devices. However, because of such reasons as 1) the regulatory requirements that are placed upon gaming machines, 2) the harsh environment in which gaming machines operate, 3) security requirements and 4) fault tolerance requirements, adapting PC technologies to a gaming machine can be quite difficult. Further, techniques and methods for solving a problem in the PC industry, such as device compatibility and connectivity issues, might not be adequate in the gaming environment. For instance, a fault or a weakness tolerated in a PC, such as security holes in software or frequent crashes, may not be tolerated in a gaming machine because in a gaming machine these faults can lead to a direct loss of funds from the gaming machine, such as stolen cash or loss of revenue when the gaming machine is not operating properly.
For the purposes of illustration, a few differences between PC systems and gaming systems will be described. A first difference between gaming machines and common PC based computers systems is that gaming machines are designed to be state-based systems. In a state-based system, the system stores and maintains its current state in a non-volatile memory, such that, in the event of a power failure or other malfunction the gaming machine will return to its current state when the power is restored. For instance, if a player was shown an award for a game of chance and, before the award could be provided to the player the power failed, the gaming machine, upon the restoration of power, would return to the state where the award is indicated. As anyone who has used a PC, knows, PCs are not state machines and a majority of data is usually lost when a malfunction occurs. This requirement affects the software and hardware design on a gaming machine.
A second important difference between gaming machines and common PC based computer systems is that for regulation purposes, the software on the gaming machine used to generate the game of chance and operate the gaming machine has been designed to be static and monolithic to prevent cheating by the operator of gaming machine. For instance, one solution that has been employed in the gaming industry to prevent cheating and satisfy regulatory requirements has been to manufacture a gaming machine that can use a proprietary processor running instructions to generate the game of chance from an EPROM or other form of non-volatile memory. The coding instructions on the EPROM are static (non-changeable) and must be approved by a gaming regulators in a particular jurisdiction and installed in the presence of a person representing the gaming jurisdiction. Any changes to any part of the software required to generate the game of chance, such as adding a new device driver used by the master gaming controller to operate a device during generation of the game of chance can require a new EPROM to be burnt, approved by the gaming jurisdiction and reinstalled on the gaming machine in the presence of a gaming regulator. Regardless of whether the EPROM solution is used, to gain approval in most gaming jurisdictions, a gaming machine must demonstrate sufficient safeguards that prevent an operator or player of a gaming machine from manipulating hardware and software in a manner that gives them an unfair and some cases an illegal advantage. The gaming machine should have a means to determine if the code it will execute is valid. If the code is not valid, the gaming machine must have a means to prevent the code from being executed. The code validation requirements in the gaming industry affect both hardware and software designs on gaming machines.
A third important difference between gaming machines and common PC based computer systems is the number and kinds of peripheral devices used on a gaming machine are not as great as on PC based computer systems. Traditionally, in the gaming industry, gaming machines have been relatively simple in the sense that the number of peripheral devices and the number of functions the gaming machine has been limited. Further, in operation, the functionality of gaming machines were relatively constant once the gaming machine was deployed, i.e., new peripherals devices and new gaming software were infrequently added to the gaming machine. This differs from a PC where users will go out and buy different combinations of devices and software from different manufacturers and connect them to a PC to suit their needs depending on a desired application. Therefore, the types of devices connected to a PC may vary greatly from user to user depending in their individual requirements and may vary significantly over time.
Although the variety of devices available for a PC may be greater than on a gaming machine, gaming machines still have unique device requirements that differ from a PC, such as device security requirements not usually addressed by PCs. For instance, monetary devices, such as coin dispensers, bill validators and ticket printers and computing devices that are used to govern the input and output of cash to a gaming machine have security requirements that are not typically addressed in PCs. Therefore, many PC techniques and methods developed to facilitate device connectivity and device compatibility do not address the emphasis placed on security in the gaming industry.
To address some of the issues described above, a number of hardware/software components and architectures are utilized in gaming machines that are not typically found in general purpose computing devices, such as PCs. These hardware/software components and architectures, as described below in more detail, include but are not limited to watchdog timers, voltage monitoring systems, state-based software architecture and supporting hardware, specialized communication interfaces, security monitoring and trusted memory.
A watchdog timer is normally used in IGT gaming machines to provide a software failure detection mechanism. In a normally operating system, the operating software periodically accesses control registers in the watchdog timer subsystem to “re-trigger” the watchdog. Should the operating software fail to access the control registers within a preset timeframe, the watchdog timer will timeout and generate a system reset. Typical watchdog timer circuits contain a loadable timeout counter register to allow the operating software to set the timeout interval within a certain range of time. A differentiating feature of the some preferred circuits is that the operating software cannot completely disable the function of the watchdog timer. In other words, the watchdog timer always functions from the time power is applied to the board.
IGT gaming computer platforms preferably use several power supply voltages to operate portions of the computer circuitry. These can be generated in a central power supply or locally on the computer board. If any of these voltages falls out of the tolerance limits of the circuitry they power, unpredictable operation of the computer may result. Though most modern general-purpose computers include voltage monitoring circuitry, these types of circuits only report voltage status to the operating software. Out of tolerance voltages can cause software malfunction, creating a potential uncontrolled condition in the gaming computer. Gaming machines of the present assignee typically have power supplies with tighter voltage margins than that required by the operating circuitry. In addition, the voltage monitoring circuitry implemented in IGT gaming computers typically has two thresholds of control. The first threshold generates a software event that can be detected by the operating software and an error condition generated. This threshold is triggered when a power supply voltage falls out of the tolerance range of the power supply, but is still within the operating range of the circuitry. The second threshold is set when a power supply voltage falls out of the operating tolerance of the circuitry. In this case, the circuitry generates a reset, halting operation of the computer.
The standard method of operation for IGT slot machine game software is to use a state machine. Different functions of the game (bet, play, result, points in the graphical presentation, etc.) may be defined as a state. When a game moves from one state to another, critical data regarding the game software is stored in a custom non-volatile memory subsystem. This is critical to ensure the player's wager and credits are preserved and to minimize potential disputes in the event of a malfunction on the gaming machine.
In general, the gaming machine does not advance from a first state to a second state until critical information that allows the first state to be reconstructed is stored. This feature allows the game to recover operation to the current state of play in the event of a malfunction, loss of power, etc that occurred just prior to the malfunction. After the state of the gaming machine is restored during the play of a game of chance, game play may resume and the game may be completed in a manner that is no different than if the malfunction had not occurred. Typically, battery backed RAM devices are used to preserve this critical data although other types of non-volatile memory devices may be employed. These memory devices are not used in typical general-purpose computers.
As described in the preceding paragraph, when a malfunction occurs during a game of chance, the gaming machine may be restored to a state in the game of chance just prior to when the malfunction occurred. The restored state may include metering information and graphical information that was displayed on the gaming machine in the state prior to the malfunction. For example, when the malfunction occurs during the play of a card game after the cards have been dealt, the gaming machine may be restored with the cards that were previously displayed as part of the card game. As another example, a bonus game may be triggered during the play of a game of chance where a player is required to make a number of selections on a video display screen. When a malfunction has occurred after the player has made one or more selections, the gaming machine may be restored to a state that shows the graphical presentation at the just prior to the malfunction including an indication of selections that have already been made by the player. In general, the gaming machine may be restored to any state in a plurality of states that occur in the game of chance that occurs while the game of chance is played or to states that occur between the play of a game of chance.
Game history information regarding previous games played such as an amount wagered, the outcome of the game and so forth may also be stored in a non-volatile memory device. The information stored in the non-volatile memory may be detailed enough to reconstruct a portion of the graphical presentation that was previously presented on the gaming machine and the state of the gaming machine (e.g., credits) at the time the game of chance was played. The game history information may be utilized in the event of a dispute. For example, a player may decide that in a previous game of chance that they did not receive credit for an award that they believed they won. The game history information may be used to reconstruct the state of the gaming machine prior, during and/or after the disputed game to demonstrate whether the player was correct or not in their assertion.
Another feature of gaming machines, such as IGT gaming computers, is that they often contain unique interfaces, including serial interfaces, to connect to specific subsystems internal and external to the slot machine. The serial devices may have electrical interface requirements that differ from the “standard” EIA 232 serial interfaces provided by general-purpose computers. These interfaces may include EIA 485, EIA 422, Fiber Optic Serial, optically coupled serial interfaces, current loop style serial interfaces, etc. In addition, to conserve serial interfaces internally in the slot machine, serial devices may be connected in a shared, daisy-chain fashion where multiple peripheral devices are connected to a single serial channel.
The serial interfaces may be used to transmit information using communication protocols that are unique to the gaming industry. For example, IGT's Netplex is a proprietary communication protocol used for serial communication between gaming devices. As another example, SAS is a communication protocol used to transmit information, such as metering information, from a gaming machine to a remote device. Often SAS is used in conjunction with a player tracking system.
IGT gaming machines may alternatively be treated as peripheral devices to a casino communication controller and connected in a shared daisy chain fashion to a single serial interface. In both cases, the peripheral devices are preferably assigned device addresses. If so, the serial controller circuitry must implement a method to generate or detect unique device addresses. General-purpose computer serial ports are not able to do this.
Security monitoring circuits detect intrusion into an IGT gaming machine by monitoring security switches attached to access doors in the slot machine cabinet. Preferably, access violations result in suspension of game play and can trigger additional security operations to preserve the current state of game play. These circuits also function when power is off by use of a battery backup. In power-off operation, these circuits continue to monitor the access doors of the slot machine. When power is restored, the gaming machine can determine whether any security violations occurred while power was off, e.g., via software for reading status registers. This can trigger event log entries and further data authentication operations by the slot machine software.
Trusted memory devices are preferably included in an IGT gaming machine computer to ensure the authenticity of the software that may be stored on less secure memory subsystems, such as mass storage devices. Trusted memory devices and controlling circuitry are typically designed to not allow modification of the code and data stored in the memory device while the memory device is installed in the slot machine. The code and data stored in these devices may include authentication algorithms, random number generators, authentication keys, operating system kernels, etc. The purpose of these trusted memory devices is to provide gaming regulatory authorities a root trusted authority within the computing environment of the slot machine that can be tracked and verified as original. This may be accomplished via removal of the trusted memory device from the slot machine computer and verification of the secure memory device contents is a separate third party verification device. Once the trusted memory device is verified as authentic, and based on the approval of the verification algorithms contained in the trusted device, the gaming machine is allowed to verify the authenticity of additional code and data that may be located in the gaming computer assembly, such as code and data stored on hard disk drives. A few details related to trusted memory devices that may be used in the present invention are described in U.S. Pat. No. 6,685,567 from U.S. patent application Ser. No. 09/925,098, filed Aug. 8, 2001 and titled “Process Verification,” which is incorporated herein in its entirety and for all purposes.
Mass storage devices used in a general purpose computer typically allow code and data to be read from and written to the mass storage device. In a gaming machine environment, modification of the gaming code stored on a mass storage device is strictly controlled and would only be allowed under specific maintenance type events with electronic and physical enablers required. Though this level of security could be provided by software, IGT gaming computers that include mass storage devices preferably include hardware level mass storage data protection circuitry that operates at the circuit level to monitor attempts to modify data on the mass storage device and will generate both software and hardware error triggers should a data modification be attempted without the proper electronic and physical enablers being present.
Returning to the example of
During the course of a game, a player may be required to make a number of decisions, which affect the outcome of the game. For example, a player may vary his or her wager on a particular game, select a prize for a particular game selected from a prize server, or make game decisions that affect the outcome of a particular game. The player may make these choices using the player-input switches 32, the video display screen 34 or using some other device which enables a player to input information into the gaming machine. In some embodiments, the player may be able to access various game services such as concierge services and entertainment content services using the video display screen 34 and one more input devices.
During certain game events, the gaming machine 2 may display visual and auditory effects that can be perceived by the player. These effects add to the excitement of a game, which makes a player more likely to continue playing. Auditory effects include various sounds that are projected by the speakers 10, 12, 14. Visual effects include flashing lights, strobing lights or other patterns displayed from lights on the gaming machine 2 or from lights behind the belly glass 40. After the player has completed a game, the player may receive game tokens from the coin tray 38 or the ticket 20 from the printer 18, which may be used for further games or to redeem a prize. Further, the player may receive a ticket 20 for food, merchandise, or games from the printer 18.
A gaming network that may be used to implement additional methods performed in accordance with embodiments of the invention is depicted in
Here, gaming machine 1402, and the other gaming machines 1430, 1432, 1434, and 1436, include a main cabinet 1406 and a top box 1404. The main cabinet 1406 houses the main gaming elements and can also house peripheral systems, such as those that utilize dedicated gaming networks. The top box 1404 may also be used to house these peripheral systems.
The master gaming controller 1408 controls the game play on the gaming machine 1402 according to instructions and/or game data from game server 1422 or stored within gaming machine 1402 and receives or sends data to various input/output devices 1411 on the gaming machine 1402. In one embodiment, master gaming controller 1408 includes processor(s) and other apparatus of the gaming machines described above in
A particular gaming entity may desire to provide network gaming services that provide some operational advantage. Thus, dedicated networks may connect gaming machines to host servers that track the performance of gaming machines under the control of the entity, such as for accounting management, electronic fund transfers (EFTs), cashless ticketing, such as EZPay™, marketing management, and data tracking, such as player tracking. Therefore, master gaming controller 1408 may also communicate with EFT system 1412, EZPAy™ system 1416 (a proprietary cashless ticketing system of the present assignee), and player tracking system 1420. The systems of the gaming machine 1402 communicate the data onto the network 1422 via a communication board 1418.
It will be appreciated by those of skill in the art that embodiments of the present invention could be implemented on a network with more or fewer elements than are depicted in
Moreover, DCU 1424 and translator 1425 are not required for all gaming establishments 1401. However, due to the sensitive nature of much of the information on a gaming network (e.g., electronic fund transfers and player tracking data) the manufacturer of a host system usually employs a particular networking language having proprietary protocols. For instance, 10-20 different companies produce player tracking host systems where each host system may use different protocols. These proprietary protocols are usually considered highly confidential and not released publicly.
Further, in the gaming industry, gaming machines are made by many different manufacturers. The communication protocols on the gaming machine are typically hard-wired into the gaming machine and each gaming machine manufacturer may utilize a different proprietary communication protocol. A gaming machine manufacturer may also produce host systems, in which case their gaming machines are compatible with their own host systems. However, in a heterogeneous gaming environment, gaming machines from different manufacturers, each with its own communication protocol, may be connected to host systems from other manufacturers, each with another communication protocol. Therefore, communication compatibility issues regarding the protocols used by the gaming machines in the system and protocols used by the host systems must be considered.
A network device that links a gaming establishment with another gaming establishment and/or a central system will sometimes be referred to herein as a “site controller.” Here, site controller 1442 provides this function for gaming establishment 1401. Site controller 1442 is connected to a central system and/or other gaming establishments via one or more networks, which may be public or private networks. Among other things, site controller 1442 communicates with game server 1422 to obtain game data, such as ball drop data, bingo card data, etc.
In the present illustration, gaming machines 1402, 1430, 1432, 1434 and 1436 are connected to a dedicated gaming network 1422. In general, the DCU 1424 functions as an intermediary between the different gaming machines on the network 1422 and the site controller 1442. In general, the DCU 1424 receives data transmitted from the gaming machines and sends the data to the site controller 1442 over a transmission path 1426. In some instances, when the hardware interface used by the gaming machine is not compatible with site controller 1442, a translator 1425 may be used to convert serial data from the DCU 1424 to a format accepted by site controller 1442. The translator may provide this conversion service to a plurality of DCUs.
Further, in some dedicated gaming networks, the DCU 1424 can receive data transmitted from site controller 1442 for communication to the gaming machines on the gaming network. The received data may be, for example, communicated synchronously to the gaming machines on the gaming network.
Here, CVT 1452 provides cashless and cashout gaming services to the gaming machines in gaming establishment 1401. Broadly speaking, CVT 1452 authorizes and validates cashless gaming machine instruments (also referred to herein as “tickets” or “vouchers”), including but not limited to tickets for causing a gaming machine to display a game result and cash-out tickets. Moreover, CVT 1452 authorizes the exchange of a cashout ticket for cash. These processes will be described in detail below. In one example, when a player attempts to redeem a cash-out ticket for cash at cashout kiosk 1444, cash out kiosk 1444 reads validation data from the cashout ticket and transmits the validation data to CVT 1452 for validation. The tickets may be printed by gaming machines, by cashout kiosk 1444, by a stand-alone printer, by CVT 1452, etc. Some gaming establishments will not have a cashout kiosk 1444. Instead, a cashout ticket could be redeemed for cash by a cashier (e.g. of a convenience store), by a gaming machine or by a specially configured CVT.
The interfaces 1568 are typically provided as interface cards (sometimes referred to as “linecards”). Generally, interfaces 1568 control the sending and receiving of data packets over the network and sometimes support other peripherals used with the network device 1560. Among the interfaces that may be provided are FC interfaces, Ethernet interfaces, frame relay interfaces, cable interfaces, DSL interfaces, token ring interfaces, and the like. In addition, various very high-speed interfaces may be provided, such as fast Ethernet interfaces, Gigabit Ethernet interfaces, ATM interfaces, HSSI interfaces, POS interfaces, FDDI interfaces, ASI interfaces, DHEI interfaces and the like.
When acting under the control of appropriate software or firmware, in some implementations of the invention CPU 1562 may be responsible for implementing specific functions associated with the functions of a desired network device. According to some embodiments, CPU 1562 accomplishes all these functions under the control of software including an operating system and any appropriate applications software.
CPU 1562 may include one or more processors 1563 such as a processor from the Motorola family of microprocessors or the MIPS family of microprocessors. In an alternative embodiment, processor 1563 is specially designed hardware for controlling the operations of network device 1560. In a specific embodiment, a memory 1561 (such as non-volatile RAM and/or ROM) also forms part of CPU 1562. However, there are many different ways in which memory could be coupled to the system. Memory block 1561 may be used for a variety of purposes such as, for example, caching and/or storing data, programming instructions, etc.
Regardless of the network device's configuration, it may employ one or more memories or memory modules (such as, for example, memory block 1565) configured to store data, program instructions for the general-purpose network operations and/or other information relating to the functionality of the techniques described herein. The program instructions may control the operation of an operating system and/or one or more applications, for example.
Because such information and program instructions may be employed to implement the systems/methods described herein, the present invention relates to machine-readable media that include program instructions, state information, etc. for performing various operations described herein. Examples of machine-readable media include, but are not limited to, magnetic media such as hard disks, floppy disks, and magnetic tape; optical media such as CD-ROM disks; magneto-optical media; and hardware devices that are specially configured to store and perform program instructions, such as read-only memory devices (ROM) and random access memory (RAM). The invention may also be embodied in a carrier wave traveling over an appropriate medium such as airwaves, optical lines, electric lines, etc. Examples of program instructions include both machine code, such as produced by a compiler, and files containing higher-level code that may be executed by the computer using an interpreter.
Although the system shown in
The above-described devices and materials will be familiar to those of skill in the computer hardware and software arts. Although many of the components and processes are described above in the singular for convenience, it will be appreciated by one of skill in the art that multiple components and repeated processes can also be used to practice the techniques of the present invention.
Although illustrative embodiments and applications of this invention are shown and described herein, many variations and modifications are possible which remain within the concept, scope, and spirit of the invention, and these variations would become clear to those of ordinary skill in the art after perusal of this application. Accordingly, the present embodiments are to be considered as illustrative and not restrictive, and the invention is not to be limited to the details given herein, but may be modified within the scope and equivalents of the appended claims.
This application claims priority to U.S. Provisional Patent Application No. 60/752,014, entitled “BINGO GAMES THAT PROVIDE SIMULATED CLASS III GAME OUTCOMES” and filed on Dec. 19, 2005, which is hereby incorporated by reference. This application is related to U.S. patent application Ser. No. 11/312,966, entitled “Bingo System with Downloadable Common Patterns” and filed on Dec. 19, 2005, to U.S. patent application Ser. No. 11/402,726, entitled “Using Multiple Bingo Cards to Represent Multiple Slot Paylines and Other Class III Game Options” and filed on Apr. 11, 2006, and to U.S. patent application Ser. No. 11/312,948, entitled “Bingo Gaming Machine Capable of Selecting Different Bingo Pools” and filed on Dec. 19, 2005, which are hereby incorporated by reference.
Number | Name | Date | Kind |
---|---|---|---|
3671041 | Taylor et al. | Jun 1972 | A |
4332389 | Loyd, Jr. et al. | Jun 1982 | A |
4365810 | Richardson | Dec 1982 | A |
4373726 | Churchill et al. | Feb 1983 | A |
4455025 | Itkis | Jun 1984 | A |
4624462 | Itkis | Nov 1986 | A |
4798387 | Richardson | Jan 1989 | A |
4848771 | Richardson | Jul 1989 | A |
4856787 | Itkis | Aug 1989 | A |
5007649 | Richardson | Apr 1991 | A |
5092598 | Kamille | Mar 1992 | A |
5192076 | Komori | Mar 1993 | A |
5242163 | Fulton | Sep 1993 | A |
5297802 | Pocock et al. | Mar 1994 | A |
5351970 | Fioretti | Oct 1994 | A |
5393057 | Marnell, II | Feb 1995 | A |
5407199 | Gumina | Apr 1995 | A |
5611729 | Schumacher et al. | Mar 1997 | A |
5639088 | Schneider et al. | Jun 1997 | A |
5833540 | Miodunski et al. | Nov 1998 | A |
5967895 | Kellen | Oct 1999 | A |
6012984 | Roseman | Jan 2000 | A |
6089978 | Adams | Jul 2000 | A |
6093100 | Singer et al. | Jul 2000 | A |
6149156 | Feola | Nov 2000 | A |
6159095 | Frohm et al. | Dec 2000 | A |
6168521 | Luciano et al. | Jan 2001 | B1 |
6183361 | Cummings et al. | Feb 2001 | B1 |
6280325 | Fisk | Aug 2001 | B1 |
6524185 | Lind | Feb 2003 | B2 |
6537150 | Luciano | Mar 2003 | B1 |
6569017 | Enzminger et al. | May 2003 | B2 |
6656040 | Brosnan et al. | Dec 2003 | B1 |
6656044 | Lewis | Dec 2003 | B1 |
6802776 | Lind et al. | Oct 2004 | B2 |
6840858 | Adams | Jan 2005 | B2 |
7241221 | Luciano et al. | Jul 2007 | B1 |
7614948 | Saffari et al. | Nov 2009 | B2 |
7708633 | Lind et al. | May 2010 | B2 |
7753774 | Gail et al. | Jul 2010 | B2 |
7798898 | Luciano et al. | Sep 2010 | B2 |
8070579 | Bienvenue et al. | Dec 2011 | B2 |
20020013170 | Miller et al. | Jan 2002 | A1 |
20020113369 | Weingardt | Aug 2002 | A1 |
20020132661 | Lind et al. | Sep 2002 | A1 |
20030125101 | Campo | Jul 2003 | A1 |
20030130029 | Crumby | Jul 2003 | A1 |
20040072619 | Brosnan et al. | Apr 2004 | A1 |
20040077402 | Schlottmann | Apr 2004 | A1 |
20040152508 | Lind et al. | Aug 2004 | A1 |
20050014553 | Byrne | Jan 2005 | A1 |
20050096120 | Lind et al. | May 2005 | A1 |
20050130730 | Lind et al. | Jun 2005 | A1 |
20050233798 | Van Asdale | Oct 2005 | A1 |
20050233799 | LeMay | Oct 2005 | A1 |
20060025197 | Kane et al. | Feb 2006 | A1 |
20060025199 | Harkins et al. | Feb 2006 | A1 |
20060082056 | Kane et al. | Apr 2006 | A1 |
20060287058 | Resnick et al. | Dec 2006 | A1 |
20070155471 | Powell et al. | Jul 2007 | A1 |
20070155472 | Gail et al. | Jul 2007 | A1 |
20070161423 | Bienvenue et al. | Jul 2007 | A1 |
20070173313 | Bienvenue et al. | Jul 2007 | A1 |
20120040733 | Bienvenue et al. | Feb 2012 | A1 |
Number | Date | Country |
---|---|---|
0199067 | Dec 2001 | WO |
WO 0199067 | Dec 2001 | WO |
WO 03085613 | Oct 2003 | WO |
2004095383 | Apr 2004 | WO |
WO 2006039324 | Apr 2006 | WO |
WO 2007075401 | Jul 2007 | WO |
WO 2007075486 | Jul 2007 | WO |
WO 2007075582 | Jul 2007 | WO |
WO 2007078828 | Jul 2007 | WO |
WO 2008005278 | Jan 2008 | WO |
Number | Date | Country | |
---|---|---|---|
20070155473 A1 | Jul 2007 | US |
Number | Date | Country | |
---|---|---|---|
60752014 | Dec 2005 | US |