[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

US20080287181A1 - Universal gaming engine - Google Patents

Universal gaming engine Download PDF

Info

Publication number
US20080287181A1
US20080287181A1 US12/099,675 US9967508A US2008287181A1 US 20080287181 A1 US20080287181 A1 US 20080287181A1 US 9967508 A US9967508 A US 9967508A US 2008287181 A1 US2008287181 A1 US 2008287181A1
Authority
US
United States
Prior art keywords
game
player
network
rules
games
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US12/099,675
Inventor
Rolf E. Carlson
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Zynga Inc
Original Assignee
Legal iGaming Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from US08/358,242 external-priority patent/US5707286A/en
Application filed by Legal iGaming Inc filed Critical Legal iGaming Inc
Priority to US12/099,675 priority Critical patent/US20080287181A1/en
Publication of US20080287181A1 publication Critical patent/US20080287181A1/en
Assigned to Knobbe, Martens, Olson & Bear, LLP reassignment Knobbe, Martens, Olson & Bear, LLP SECURITY INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: LEGAL IGAMING, INC.
Assigned to Atwater Ventures Limited reassignment Atwater Ventures Limited ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: LEGAL IGAMING INC.
Assigned to ZYNGA INC. reassignment ZYNGA INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: ATWATER VENTURES LTD.
Assigned to LEGAL IGAMING, INC. reassignment LEGAL IGAMING, INC. RELEASE BY SECURED PARTY (SEE DOCUMENT FOR DETAILS). Assignors: Knobbe, Martens, Olson & Bear, LLP
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G07CHECKING-DEVICES
    • G07FCOIN-FREED OR LIKE APPARATUS
    • G07F17/00Coin-freed apparatus for hiring articles; Coin-freed facilities or services
    • G07F17/32Coin-freed apparatus for hiring articles; Coin-freed facilities or services for games, toys, sports, or amusements
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F7/00Methods or arrangements for processing data by operating upon the order or content of the data handled
    • G06F7/58Random or pseudo-random number generators
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F7/00Methods or arrangements for processing data by operating upon the order or content of the data handled
    • G06F7/58Random or pseudo-random number generators
    • G06F7/582Pseudo-random number generators

Definitions

  • the present invention relates, in general, to gaming machines, and, more particularly, to an electronic gaming engine supporting multiple games and multiple users.
  • Casino gaming has grown rapidly in the United States. Casino gaming is experiencing similar growth throughout the world. An important segment of this developing industry is electronic games. An electronic implementation of a game requires a method for interpreting human actions as they occur within the constraints of the rules as well as the ability to respond with chance events.
  • Microprocessors allow games that formerly relied on analog devices for generating chance events, such as dice, to be simulated digitally. Simulating a die roll with a computer would seem to be a contradiction because the microprocessor is the embodiment of logic and determinism. With care, however, it is possible to create deterministic algorithms that produce unpredictable, statistically random numbers.
  • Contemporary games consist of a framework of rules that define the options for how a user or random event generator may change the game state. Play begins with an initial state. Subsequent play consists of user initiated events that trigger the execution of one or more rules. A rule may proceed deterministically or non-deterministically.
  • Typical games consist of deterministic and non-deterministic rules. A game progresses by the interaction of these rules. There are two sources for non-determinism” player decisions and chance events. In the game of Poker, for example, deciding to replace three instead of two cards in a hand is a player decision that is limited, but not pre-determined, by rules. The rules limit the range of options the player has, but within that set of options the player is free to choose. An example of a chance event is the random set of cards received by the poker player. Shuffled cards do not produce a predictable hand.
  • the first Blackjack hand a player receives is two cards from a shuffled deck. The number of cards dealt is two, but the cards could be any from the deck, Keno is essentially a lottery. In Keno, a player attempts to guess twenty balls chosen from a basket of eighty balls. The rules dictate that to participate, a player must fill out a Keno ticket indicating the balls he believes will be chosen in the next round. the selection of balls, however, is a purely random event. Slot machines require the player to pull a handle for each round. Slot wheels stop at random positions.
  • a casino player must know the likelihood of winning a jackpot is commensurate with the stated theoretical probabilities of the game. Moreover, the casino would like to payout as little as possible while maximizing the number of their game participants. Because each game sponsored by a casino has a built-in theoretical edge for the house, over time and with repeated play, the house will make money. In other words, the casino does not need to cheat the customer because it has a built-in edge. The customer, who is at a disadvantage in the long run, will want to know the game is fair in order to manage risk. In is a theoretical fact that bold wagering in Roulette increases a players odds of winning. A player who cannot know the odds of winning cannot formulate a strategy.
  • an engineer creating an electronic game generates a flow chart representing the rules and uses a random number generator in conjunction with combinatorial algorithms for generating chance events. Representing rules is one problem. Generating chance events to support those rules is another. Creating pseudo-random numbers is a subtle problem that requires mathematical skills distinct from other problems of gaming. In other words, a skilled game programmer may be unable to solve the problems of developing a proper random number generator. Even if given a quality random number generator, problems can occur in hardware implementations that render the generator predictable. One example is using the same seed, or initial state, for the generator at regular intervals and repeatedly generating a limited batch of numbers. Without attending to the theoretical aspects of a uniform random number generator, it is not possible to implement the rules of a game perfectly. The result is a game unfair to the house, players, or both. Hence, there is a need for a gaming system, apparatus, and method that separate the problem of implementing game rules from that of random event generation.
  • Gaming is a heavily regulated industry. States, tribes, and the federal government have gaming regulatory agencies at various levels to ensure fairness of the games.
  • the gaming regulatory authority certifies that a particular implementations of a game reflects the underlying probabilities. Because electronic games are implemented in often difficult to understand software, the problem of verifying fairness of a game is challenging. Further, there is little uniformity in the implementation of fundamental components of various games. To determine fairness, the gaming authority subjects each game to a battery of tests. No set of statistical tests performed on a limited portion of the random number generator period can ensure that the generator will continue to perform fairly in the field. The process of testing is both expensive and of limited accuracy. Hence, a regulatory need exists for a uniform, standardized method of implementing games that reduce the need and extent of individual game testing while increasing he reliability of detecting and certifying game fairness.
  • the Universal Gaming Engine (UGE) in accordance with the present invention is a gaming apparatus providing a consistent game development platform satisfying the needs of the gaming authority, house, player, and game developer.
  • the UGE separates the problems of developing game rules from the difficulty, of producing chance events to support those rules. Functions that are common to a number of games are included in the gaming engine so that they need not be implemented separately for each game. By including basic functions shared by a number of games, hardware costs are greatly reduced as new games can be implemented merely by providing a new set of rules in the rules library and the basic hardware operating the game remains unchanged.
  • the present invention provides a system, apparatus, and method for implementing a game having a deterministic component and a non-deterministic component wherein a player uses the game through at least one player interface unit.
  • Each player interface unit generates a player record indicating player-initiated events.
  • a random number generator provides a series of pseudo-random numbers that are preferably statistically verified by integral verification algorithms and stored in a buffer.
  • the random number generator allows seed and key restoration automatically or manually upon power fault.
  • a rules library stores indexed rules for one or more games.
  • An interface registry stores mapping records where the mapping records are used to associate the player-initiated events to pre-selected rules in the rules library.
  • a control means is coupled to receive the output of the player interface unit, coupled to the interface registry, the rules library, and the random number generator. The control means processes the player record and returns an output record to the player interface unit where the output record is determined by executing the game's rules with reference to the pseudo-random numbers and predefined combinatorial algorithms for selecting sets of the pseudo-random numbers.
  • FIG. 1 illustrates a simplified block diagram of the gaming engine in accordance with the present invention
  • FIG. 2 illustrates a block diagram of the pseudo-random number subsystem in accordance with the present invention
  • FIG. 3 illustrates the non-uniform distribution generator and combinatorial algorithm subsystems in accordance with the present invention
  • FIG. 4 illustrates a main control circuit in accordance with the present invention
  • FIG. 5 illustrates in block diagram form implementation of the rules library in accordance with the present invention
  • FIG. 6 illustrates a flow chart of a game implementation using the apparatus shown in FIG. 1 ;
  • FIG. 7 illustrates a flow diagram for a second embodiment pseudo-random number distribution system
  • FIG. 8 illustrates a multiple player networked implementation in accordance with the present invention.
  • FIG. 9 illustrates in graphical form relationships between server speed, queue size, and customer wait times of an apparatus in accordance with the present invention.
  • FIG. 1 illustrates, in simplified schematic form, a gaming apparatus in accordance with the present invention.
  • the gaining apparatus in accordance with the present invention is also referred to as a “universal gaming engine” as it serves in some embodiments as a platform for implementing any number of games having deterministic and random components.
  • the universal gaming engine in accordance with the present invention provides a platform that supports multiple players across a network where each player preferably independently selects which game they play and independently controls progression of the game.
  • Gaming engine 100 is illustrated schematically in FIG. 1 , including major subsystems in the preferred embodiments. Each of the subsystems illustrated in FIG. 1 is described in greater detail below. FIG. 1 , however, is useful in understanding the overall interconnections and functioning of the gaming engine in accordance with the present invention.
  • Gaming engine 100 performs several basic functions common to many electronically implemented casino games. The most basic of these functions includes interacting with the player to detect player initiated events, and to communicate the state of a game to the player. Gaming engine 100 must process the player initiated event by determining the appropriate rules of the game that must be executed and then executing the appropriate rules. Execution of the rules may require only simple calculation or retrieving information from memory in the case of >deterministic rules, or may require access to pseudo-random values or subsets of pseudo-random values in the case of non-deterministic components.
  • Gaming engine 100 uses a main control circuit 101 to control and perform basic functions.
  • Main control circuit 101 is a hardware or software programmable microprocessor or microcontroller. Alternatively, main control circuit 101 can be implemented as an ASIC device with dedicated logic to perform the required control functions.
  • Main control circuit 101 communicates with player interface unit 102 via interface bus 103 .
  • Player interface unit 102 is a machine having at least some form of display for communicating information to the player and some form of switch (i.e., buttons, levers, keyboard, coin slot, or the like) for communicating information from the player.
  • Player interface unit 102 generates a player record of information and transmits the player record over bus 103 to main control circuit 101 .
  • the player record of information contains information about the player initiated event as well as any data that may be associated with the particular event. For example, a player initiated event may be drawing two cards from a deck of cards.
  • the player record will include information about the event (i.e., drawing cards), and data (i.e., two cards).
  • the player record may include other information such as the state of the game that is being played. By “state of the game” it is meant at which stage in the rule defined progression of the game the game currently exists. State information may be maintained by gaming engine 100 or player interface unit 102 , or both.
  • Main control circuit 101 responds to a player initiated event by referencing a public interface registry 107 .
  • Public interface registry 107 is essentially a lookup table implemented in volatile, semi-volatile, or non-volatile memory. Public interface registry 107 is desirably organized as an addressable memory where each address is associated with a mapping record. Main control circuit 101 uses the player event portion of the player record to address public interface registry 107 in a preferred embodiment. Public interface registry 107 then provide a selected mapping record to main control circuit 101 . Main control circuit 101 uses the selected mapping record to address rules library 108 .
  • Rules library 108 is essentially an addressable memory preferably allowing random access. Rules library 108 can be implemented in volatile, semi-volatile, or non-volatile memory of any convenient organizational structure. Rules library 108 responds to the address from main control circuit 101 . by supplying one or more rules, which correspond to game rules, to main control circuit 103 . The rules provided by rules library 101 are preferably executable instructions for main control circuit 101 .
  • Main control circuit 101 processes the selected rules by selectively accessing random number circuit 104 and transform function algorithms 106 . As set out herein before, completely deterministic rules may be executed entirely within main control circuit 101 by simple calculations or data transfer operations. Where the selected rule requires main control circuit 101 to access one or more pseudo-random numbers, random number circuit 104 is accessed. In the preferred embodiment random number circuit 104 provides a series of pseudo-random numbers of arbitrary length having uniform distribution as described in greater detail hereinafter.
  • main control circuit 101 implements the selected rule by accessing transform function algorithms from block 106 in FIG. 1 .
  • the transform function algorithms transform the series of uniformly distributed pseudo-random numbers from random number circuit 104 by 1) transforming them into a non-uniform distribution, 2) using a given set of the uniformly distributed pseudo-random numbers to performing set selection permutations or 3) both.
  • the basic functions of pseudo-random number generation, pseudo-random number transformation, and association of rules with player or player events are standardized and entirely contained in gaming engine 100 .
  • System operator interface 109 is used by the casino or game developer to communicate with uniform random number circuit 104 and main control circuit 101 . This communication is desirable to initialize, program, and maintain main control circuit 101 and public interface registry 107 , for example. System operator interface also enables an operator to initialize, monitor and change seed values and key values used by uniform random number circuit 104 . Any convenient hardware may be used to implement system operator interface 109 including DIP switches, a smart terminal, personal computer, or a dedicated interface circuit.
  • a game programmer develops a series of rules for the game.
  • the series of rules are stored as a volume in rules library 108 .
  • the game programmer will then register the new game in public interface registry 107 by storing the location of the volume of rules in an appropriate address in public interface registry 107 .
  • the game programmer does not need to program or develop the random number circuit or transform algorithms to implement a new game.
  • the player using player interface unit 102 can access any of the games stored in rules library 108 .
  • a game regulatory authority need only review the rules in the rules library 108 to verify that they follow the established rules for a particular game. This verification can be easily done by reviewing high-level language code such as FORTRAN, C, or Basic.
  • Player interface unit 102 may be entirely electronic or combine electronic and mechanical components. Player interface unit may supply any amount and kind of information in addition to the basic functions set forth above to main control circuit 101 . Player interface unit 102 may be located in the same physical machine as the remaining portions of gaming engine 100 or may be located at a great distance from gaming engine 100 . These and other alternatives will be discussed in greater detail hereinafter.
  • Random number circuit 104 preferably includes random number generator circuit 201 , verification algorithms 202 , and buffer 203 . Random number circuit 104 is controlled by random number control circuit 204 which is a microprocessor, microcontroller, or dedicated logic control circuit.
  • Random number generator circuit 201 provides a stream of uniformly distributed pseudo-random numbers on output 206 .
  • random number generator circuit 201 can provide parallel outputs on output 206 .
  • more than one random number generator circuit 201 may be employed depending on the quantity of pseudo-random numbers demanded by the system.
  • Random number generator circuit 201 preferably supplies uniformly distributed pseudo-random numbers because a set of uniformly distributed numbers can be transformed easily by transform algorithms 106 into non-uniform distributions and combinatorial subsets.
  • a preferred circuit for implementing random number generator circuit 201 is an ANSI X9.17 pseudo random number generator based upon a plurality of data encryption standard (DES) encryption circuits.
  • random number generator circuit 201 may be implemented using the international data encryption algorithm (IDEA) encryption.
  • Other random number generator circuits are known.
  • DES data encryption standard
  • Other random number generator circuits are known.
  • a major advantage of the present invention is that the random number circuit 104 need be implemented only once to serve a plurality of games making it cost efficient to use relatively expensive circuitry to provide a high quality random numbered circuit 104 .
  • Random number generator circuit 201 accepts as input one or more key values which are typically binary values having a fixed relatively large number of bits. For example, the ANSI X9.17 pseudo-random number generator uses 56-bit keys. Random generator circuit 201 also usually accepts a seed value, which is also another large bit binary value. Further, random number generator circuit 201 has a data input or clock input that accepts a continuously variable signal which is conveniently a clock representing date and time. In this manner, each time the signal on the clock or data input changes a new random number is output on line 206 . Random number control circuit stores and provides the key values, seed value, and clock values to random number generator circuit 201 .
  • a desirable feature in accordance with the present invention is that random number circuit 104 be able to boot up after a power fault (i.e., power is removed from the system) using the same seed values, key values, and clock value that existed before the power fault. This feature prevents a player or operator from continually resetting the system or gaining any advantage by removing power from gaming engine 100 .
  • One way of providing this functionality is to buffer the key values, seed values, and clock values in memory within random number control circuit 204 before they are provided to random number generator 201 . After a power on default, circuit 104 can reboot autonomously using the values stored in buffers. Alternatively, new values can be provided via system operator interface 109 to ensure that the output after a power fault is in no way predictable based upon knowledge of output after a prior power fault.
  • random number generator circuit operates continuously to provide the series of random numbers on line 206 at the highest speed possible.
  • random number generator circuit 201 operates at a rate that is not determined by the demand for random numbers by the rest of the system.
  • Random number control circuit 204 provides key values, seed values, and data values to random number generator circuit 201 independently of any processing demands on main control circuit 101 (shown in FIG. 1 ). This arrangement ensures that random number circuit 104 operates at a high degree of efficiency and is not slowed down by computational demands placed on main control circuit 101 .
  • the control circuit resources that implement random number control circuit 204 are independent of and usually implemented in a separate circuit from main control circuit 101 .
  • Random number control circuit 204 accesses one or more verification algorithms 202 via connection 207 .
  • Verification algorithms 202 serve to verify that the raw random numbers on line 206 are statistically random to a predetermined level of certainty.
  • verification algorithms 202 include algorithms for testing independence, one-dimensional uniformity, and multi-dimensional uniformity. Algorithms for accomplishing these tests are well known. For example, independence of the pseudo random numbers can be performed by a Runs test. Uniformity can be verified by the Kolmorgorov-Smirnov or K-S test. Alternatively, a Chi-square test verify uniformity. A serial test is an extension of the Chi-square test that can check multi-dimensional uniformity.
  • Random number control circuit 204 preferably receives and stores a set of raw random numbers from random number generator circuit 201 .
  • the set of raw random numbers can be of any size, for example 1000 numbers. Random number control circuit 204 then implements the verification algorithms either serially or in parallel to test independence and uniformity as described hereinbefore. It may be advantageous to use more than one physical circuit to implement random number control circuit 204 so that the verification algorithms may be executed in parallel on a given set of raw random numbers.
  • Buffer 203 is preferably implemented as a first-in, first-out (FIFO) shift register of arbitrary size. For example, buffer 203 may hold several thousand or several million random numbers.
  • gaming engine 100 in accordance with the present invention ensures that all of the pseudo-random numbers in buffer 203 are in fact statistically random. This overcomes a common problem in pseudo-random number circuits wherein the random numbers are long-term random, but experience short-term runs or trends. These short-term trends make prediction of both the player and casino odds difficult and may create an illusion of unfairness when none in fact exists.
  • the verification algorithms 202 in accordance with the present invention largely eliminate these short-term trending problems and create a pool of random numbers in buffer 203 that are both statistically random and will appear to be random in the short run time period in which both the casino and players operate.
  • Buffer 203 makes the random numbers available continuously to main control circuit 101 .
  • Main control circuit 101 may access any quantity of the numbers in buffer 203 at a time.
  • Buffer 203 also serves to provide a large quantity of random numbers at a rate higher than the peak generation rate of random number generator circuit 201 .
  • random number generator circuit 201 and verification algorithms 202 are processed so as to provide random numbers to buffer 203 at a higher rate than required by gaming engine 100 , short-term bursts of random numbers can be provided by buffer 203 at a higher rate.
  • Transform function algorithms 106 are accessed by main control circuit 101 as illustrated in FIG. 3 .
  • Examples of transform function algorithms 106 are a non-uniform distribution generator 301 and combinatorial algorithms 302 .
  • main control circuit 101 may be required to select one or more random values from a non-uniform distribution.
  • Examples of non-uniform distributions are normal distribution, exponential distribution, gamma distribution, as well as geometric and hypergeometric distributions. All of these non-uniform distributions can be generated from the uniform distribution provided by random number circuit 104 .
  • Rule implementations primarily require that main control circuit 101 access a series of pseudo-random numbers in the context of random set selection and permutations. This subset selection is performed by combinatorial algorithms 302 .
  • the combinatorial algorithms 302 operate on either the uniform number distribution provided directly by random number circuit 104 or the non-uniform distribution provided by non-uniform distribution generator 301 . In this manner, a game of keno can be implemented by selecting a random 20 from a group of 80.
  • transform algorithms 106 Another function of the transform algorithms 106 is to scale and center the series of random numbers. For example, a deck of cards includes 52 cards so that the set of random numbers must be scaled to range from 1 to 52. These and similar transform functions are well known.
  • An advantageous feature of the present invention is that these transform functions can be implemented a single time in a single piece of software or hardware and selectively accessed by any of the games in rules library 108 .
  • This allows a great variety of transform functions to be provided in a cost efficient and computationally efficient manner.
  • the game designer need only provide rules in rules library 108 that access appropriate transform function algorithms 106 and need not be concerned with the details of how the transform function algorithms 106 are implemented.
  • a gaming regulatory authority can verify the correctness and fairness of transform algorithms a single time by providing extensive testing. Once the transform functions are verified, they need not be verified again for each game that is implemented in rules library 108 . This independence between the rules programming and the non-deterministic programming result in highly standardized and reliable games while allowing the games designer greater flexibility to design a game in the rules library 108 .
  • main control circuit 101 A preferred embodiment of main control circuit 101 is shown in block diagram form in FIG. 4 .
  • a micro-controller microprocessor 401 is provided to perform calculations, memory transactions, and data processing.
  • Microprocessor 401 is coupled through bus 103 to player interface unit 102 .
  • Microprocessor 401 is also coupled to player number circuit 104 , transform function algorithms 106 , public interface registry 107 , and rules library 108 through bi-directional communication lines 402 .
  • main control circuit 101 will have a quantity of RAM/SRAM 403 , a quantity of non-volatile memory 404 , and ROM for storing an operating system and boot sequence.
  • ROM 406 operates in a conventional manner and will not be described in greater detail hereinafter.
  • Non-volatile memory 404 is an addressable, preferably random access memory used to store information that is desirably saved even if power is removed from main control circuit 101 .
  • microprocessor 401 may calculate statistics regarding the type of games played, the rate of game play, the rate of number request, or information about the player from player interface unit 102 . The statistics are preferably stored in a non-volatile memory 404 to maintain integrity of the information.
  • non-volatile memory 404 may be used to maintain the state of a game in progress on player interface unit 102 so that is power is removed, universal gaming engine 100 can restore player interface unit 102 to the state at which it existed prior to the power outage. This may be important in a casino operation where the casino could incur liability for stopping a game when the player believes a payoff is imminent.
  • RAM 403 serves as operating memory for temporary storage of rules access from rules library 108 or for storing the operating system for quick access.
  • RAM. 403 may also store groups of random numbers while they are being processed by the transform function algorithms as well as address data provided to and accepted from the public interface registry.
  • main control circuit 101 may be implemented in a variety of fashions using conventional circuitry. While some memory will almost surely be required, the memory may be implemented as RAM, SRAM, EPROM or EEPROM to meet the needs of a particular application. Similarly, the components of main control circuit 101 shown in FIG. 4 may be implemented as a single circuit or single integrated circuit or in multiple circuits or integrated circuits. Additional features may be added to implement additional functions in a conventional manner.
  • Rules library 108 is preferably implemented as a plurality of volumes of rules where each volume is fixed in a rule EPROM 502 - 506 . Any number of rule EPROM's can be supplied in rule library 108 . Also, rule EPROM's 502 can be of various sizes. Rule EPROM's 502 - 506 may be replaced with equivalent memory circuits such as RAM, S RAM, or ROM. It is desirable from a gaming regulatory authority standpoint that rule EPROM's 502 - 506 cannot be altered once programmed so that the rules cannot be changed from the designed rules. This allows the gaining regulatory authority to verify the EPROM rules.
  • Address logic 501 provides address signals to-select one of rule EPROM's 502 - 506 . Additionally, address logic 501 serves to position a pointer to a specific rule within each rule EPROM 502 - 506 . As set out herein before, which of rule EPROM's 502 - 506 is selected as determined by the current game being played as indicated by player interface unit 102 (shown in FIG. 1 ). The location of the pointer within a rule EPROM is addressed based upon the current state of the game and the particular user initiated event indicated by player interface unit 102 . The information is conveyed from the user interface unit 102 in a player record that is mapped to rule library 108 by the information in public interface registry 107 .
  • a game developer will program a series of rules that dictate the progression of a game in response to user or player initiated events.
  • the rules will also dictate when random numbers are accessed and the type of random numbers which should be accessed (i.e., uniform or non-uniform distributions). Rules will also control payoffs, and place boundaries on the types of player events which will be accepted.
  • the game developer will then burn these rules, once complete, into a rule EPROM, such as rule EPROM's 502 - 506 .
  • the rule EPROM can then be verified by a gaming regulatory authority, and once approved, be distributed to owners of gaming engines wishing to implement the newly developed game.
  • the rule EPROM is installed in rules library 108 and registered in public interface registry 107 .
  • the registration process described hereinbefore provides gaming engine 100 the address information necessary to enable address logic 501 to access a particular rule in rules library 108 and provide that rule on output line 507 to main control circuit 101 .
  • rules library 108 has been described in terms of a plurality of EPROM's 502 - 506 wherein each EPROM holds one volume of rules pertaining to a particular game, it should be apparent that many other configurations for rules library 108 are possible. Rules can be implemented in a single large memory or in a serial memory such as a tape or disk. Address logic 500 may be integrated in rules library 108 , or may be integrated with main control circuit 101 . Each game may be implemented in a single EPROM or may require several EPROM's depending on the particular needs of an application.
  • FIG. 6 and FIG. 7 together illustrate in flow chart form a preferred method of operation of gaming engine 100 in accordance with the present invention.
  • FIG. 6 details operation of a first embodiment single player gaming engine 100 .
  • main control circuit 101 is initialized and goes through a boot-up sequence to bring it to an initial state. In this initial state it waits for user input at step 604 .
  • the player input or player record preferably indicates the game that is being played, the state of that game, and user initiated events and data that must be processed.
  • the public registry is addressed in step 606 .
  • the public registry returns a mapping record that matches the user record with a particular rule in the rules library in step 608 .
  • One or more rules are accessed in step 608 .
  • Each of the one or more rules are processed in serial fashion in the embodiment illustrated in FIG. 6 .
  • One rule is processed in each pass through steps 610 - 622 .
  • a logical component of a first rule is processed in step 610 , where the logical component includes processes of memory manipulations, calculations, and the like.
  • step 612 it is determined if the particular rule that was executed in step 610 requires pseudo-random numbers to process. If pseudo-random numbers are required, they are retrieved in step 700 which is illustrated in greater detail in reference to FIG. 7 .
  • step 614 It is determined if the rule requires any transform algorithm in step 614 . If a transform algorithm is required it is obtained in step 616 . It should be understood that the transform algorithm may be permanently resident in the main control circuit 101 and so the step of obtaining 616 may be trivial. Once the necessary transfer algorithm is obtained, it is determined if the rule is completely processed in step 618 . If not, flow returns to step 610 and the rule logic is executed until the rule is completely processed and a final result of the rule is determined. Once the rule is finished, control moves from step 618 to result accumulation step 620 .
  • Each rule accessed in step 608 is processed in a similar manner by sequentially selecting each rule in step 626 until it is determined that all rules have been processed in step 622 . Once all the rules are processed, the accumulated results are returned to the player in step 624 .
  • the results are of the rule are determined in steps 610 , 612 , and 614 by performing any transforms required on the random numbers, executing any deterministic components using conventional calculations and memory transactions.
  • FIG. 7 illustrates a flow chart showing steps in filling random number request step 700 in FIG. 6 .
  • the process shown in FIG. 7 is initiated when request 614 is made. More accurately, many of the sub-processes shown in FIG. 7 are ongoing, but the processes for generating and supplying random numbers are also responsive to the request for random numbers 700 .
  • Continuously ongoing processes include clock generation step 706 , providing key value(s) step 710 , and providing seed value(s) step 712 .
  • the clock signal generated in step 706 need not be a real time clock, nor does it have to provide a linearly increasing or decreasing output. It is sufficient that clock 706 output a continuously variable signal at a regular interval. As set out herein before, clock generation is preferably performed by random number control circuit 204 shown in FIG. 2 .
  • a signal is generated by the occurrence of the player event.
  • the time of the player event is determined at step 704 and may be used as shown in FIG. 7 .
  • the clock signal and the player event signal are combined to provide a continuously variable non-random signal, Where both the player event signal and the clock are digital, the combination can be realized as logical function such as AND, OR, XOR, NAND or the like. Also, the combination may be a concatenation or subtraction function. This feature of the present invention is optional, but adds a new degree of randomness.
  • a series of raw random numbers is generated using the continuously provided key values, seed values, and variable signal.
  • the raw random numbers are stored at step 716 to build a group large enough to be verified during step 718 . Groups of raw random numbers that fail verification step 718 are discarded, while those that pass are stored at step 720 in buffer 203 shown in FIG. 2 .
  • the verified random numbers are delivered in step 722 , returning process flow to step 618 shown in FIG. 6 .
  • request 614 is queued at step 728 using RAM 403 shown in FIG. 4 .
  • Request queuing 728 is implemented as a first in first out or “push up” register having N queue capacity. In one embodiment, N is between 2 and 10. Queuing step 728 stores each request and processes each request in turn.
  • delivery step 722 serves whatever request is provided during step 728 . Once a request is delivered, the request queue is updated in step 724 .
  • FIG. 9 illustrates generally a relationship between server speed, queue size, and the average number of customers, or requests for pseudo-random numbers, are waiting in the system.
  • FIG. 9 is derive by modeling gaming engine 800 (shown in FIG. 8 ) as an M/M/1 queue to produce parameters for expected wait times in the system.
  • FIG. 9 assumes that requests for pseudo-random numbers are made according to a Poisson process. This means that the times between successive arrivals are independent exponential random variables.
  • request queue 728 can be viewed as an M/M/1 queue. The first two M's indicate that both the interarrival times as well as the service times for requests are exponential random variables. The “1” indicates there is just one server.
  • Server speed is largely determined by the hardware chosen to implement the present invention, and can be easily varied by those of skill in the art to meet the needs of a particular application. As is apparent in FIG. 9 , higher server speeds result in fewer waiting customers. From the lower portion of FIG. 9 , is apparent that if the queue size is reduced to zero (i.e., no request queue), the average wait time climbs even with very fast servers. Hence, to minimize wait time, a request queue is desirable.
  • process steps shown in FIG. 7 may be carried out in any convenient-order unless expressly specified above. Process steps may be carried out in serial or parallel depending on the particular capabilities of main control circuit 101 shown in FIG. 1 . For example, where control circuit 101 is multi-tasking or capable of parallel processing, several process steps may be executed at once. Also, process steps may be added to those shown in FIG. 7 to implement additional functions without departing from the inventive features of the present invention.
  • FIG. 8 illustrates in block diagram for network embodiment in accordance with the present invention.
  • Basic components of gaming engine 800 are similar to gaming engine 100 including random number circuit 804 , transform algorithms 806 , public interface registry 807 , and rules library 808 .
  • Main control circuit 801 includes all of the functions described herein before in reference to main control circuit 101 but also includes function for supporting network interface circuit 812 , Data bus 812 couples main control circuit 801 to network interface circuit 812 .
  • the network embodiment shown in FIG. 8 serves a plurality of player interface units 802 a - 801 e .
  • This additional functionality is provided in part by network interface circuit 812 and network I/O circuits 812 a - 812 e .
  • Network interface circuit 812 and network I/O circuits 812 a - 812 e can be conventional network circuits used for 10baseT, ethernet, Appletalk, or other known computer network systems. In selecting the network circuits, it is important that the data throughput is adequate to meet the needs of a particular system.
  • Network interface circuit 812 communicates a plurality of player records of information to main control circuit 801 .
  • Main control circuit may be a conventional processing circuit that serially processes each of the player records in a manner similar to main control circuit 101 .
  • main control circuit 801 includes multitasking or parallel processing capabilities allowing it to process the plurality of player records simultaneously.
  • Simultaneous processing requires that main control circuit 801 access a plurality of rules from rules library 808 , each of which may require main control unit 801 to request a set of pseudo-random numbers from random number circuit 804 .
  • the multiple requests for pseudo-random numbers are stored in a request queue implemented in memory of main control circuit 801 .
  • the request queue is preferably able to store more than one request.
  • a suitable request queue can store ten requests.
  • Random number circuit 804 treats each request from the request queue of main control circuit 801 in a manner similar to the requests from main control circuit 101 described herein before.
  • the combination of the request queue with the buffer of random number circuit 804 allows gaming engine 800 to service requests corresponding to player initiated events very efficiently.
  • a request queue holding even two or three requests can reduce the probability of any player waiting for delivery of a set of pseudo-random numbers significantly.
  • the request queue can be implemented by configuring a portion of the RAM available to main control circuit 801 as a first-in first-out register or push up stack. Each request for a set of random numbers is initially placed at the bottom of the request queue and sequentially raised in the request queue until the request is filled. This operation is described herein before with respect to FIG. 7 .
  • the universal gaming engine in accordance with the present invention is a gaming apparatus providing a consistent game development platform satisfying the needs of gaming authorities, house, player, and game developer.
  • the gaming engine in accordance with the present invention separates the problems of developing game rules from the difficulty of producing chance events to support those rules.
  • hardware costs are greatly reduced as new games can be implemented merely by providing a new set of rules in the rules library and the basic hardware operating the game remains unchanged.

Landscapes

  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Computational Mathematics (AREA)
  • Mathematical Analysis (AREA)
  • Mathematical Optimization (AREA)
  • Pure & Applied Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • Slot Machines And Peripheral Devices (AREA)
  • Pinball Game Machines (AREA)

Abstract

An apparatus for implementing a game having a deterministic component and a non-deterministic component wherein a player uses the game through at least one player interface unit. Each player interface unit generates a player record indicating player-initiated events. A random number generator provides a series of pseudo-random numbers and a rules library stores indexed rules for one or more games. An interface registry stores mapping records where the mapping records are used to associate the player-initiated events to pre-selected rules in the rules library. A control means is coupled to the player interface to receive the output of the player interface unit, coupled to the interface registry, the rules library, and the random number generator. The control means processes the player record and returns an output record to the player interface unit where the output record is determined by executing the game's rules with reference to the pseudo-random numbers and predefined combinatorial algorithms for selecting sets of the pseudo-random numbers.

Description

    CROSS-REFERENCE TO RELATED APPLICATIONS
  • This application is a continuation of U.S. patent application Ser. No. 11/302,564, filed on Dec. 13, 2005, which is a division of U.S. patent application Ser. No. 09/143,907, filed on Aug. 31, 1998, now U.S. Pat. No. 6,986,055, which is a division of U.S. patent application Ser. No. 08/959,575, filed on Oct. 28, 1997, now U.S. Pat. No. 6,272,223, which is a division of U.S. patent application Ser. No. 08/358,242, filed on Dec. 19, 1994, now U.S. Pat. No. 5,707,286, all of which are incorporated herein by reference.
  • BACKGROUND OF THE INVENTION
  • 1. Field of the Invention
  • The present invention relates, in general, to gaming machines, and, more particularly, to an electronic gaming engine supporting multiple games and multiple users.
  • 2. Description of the Related Art
  • Statement of the Problem
  • Casino gaming has grown rapidly in the United States. Casino gaming is experiencing similar growth throughout the world. An important segment of this developing industry is electronic games. An electronic implementation of a game requires a method for interpreting human actions as they occur within the constraints of the rules as well as the ability to respond with chance events.
  • Microprocessors allow games that formerly relied on analog devices for generating chance events, such as dice, to be simulated digitally. Simulating a die roll with a computer would seem to be a contradiction because the microprocessor is the embodiment of logic and determinism. With care, however, it is possible to create deterministic algorithms that produce unpredictable, statistically random numbers.
  • Contemporary games consist of a framework of rules that define the options for how a user or random event generator may change the game state. Play begins with an initial state. Subsequent play consists of user initiated events that trigger the execution of one or more rules. A rule may proceed deterministically or non-deterministically.
  • Typical games consist of deterministic and non-deterministic rules. A game progresses by the interaction of these rules. There are two sources for non-determinism” player decisions and chance events. In the game of Poker, for example, deciding to replace three instead of two cards in a hand is a player decision that is limited, but not pre-determined, by rules. The rules limit the range of options the player has, but within that set of options the player is free to choose. An example of a chance event is the random set of cards received by the poker player. Shuffled cards do not produce a predictable hand.
  • Other examples that illustrate determinism and non-determinism in gaming are popular casino pastimes such as Blackjack, Keno, and Slot machines. The first Blackjack hand a player receives is two cards from a shuffled deck. The number of cards dealt is two, but the cards could be any from the deck, Keno is essentially a lottery. In Keno, a player attempts to guess twenty balls chosen from a basket of eighty balls. The rules dictate that to participate, a player must fill out a Keno ticket indicating the balls he believes will be chosen in the next round. the selection of balls, however, is a purely random event. Slot machines require the player to pull a handle for each round. Slot wheels stop at random positions.
  • The non-deterministic problem in most parlor games is random sampling without replacement: given a set of n elements, randomly choose m of them without replacement where m is less than or equal to n. Although sampling without replacement covers most popular games, it would be easy to conceive of games that required replacement. For example, consider a variant of Keno that replaces each chosen ball before selecting the next ball. Until now, no device is available that services the needs of multiple games by providing algorithms for sampling with and without replacement as well as others such as random permutation generation, sorting, and searching.
  • A casino player must know the likelihood of winning a jackpot is commensurate with the stated theoretical probabilities of the game. Moreover, the casino would like to payout as little as possible while maximizing the number of their game participants. Because each game sponsored by a casino has a built-in theoretical edge for the house, over time and with repeated play, the house will make money. In other words, the casino does not need to cheat the customer because it has a built-in edge. The customer, who is at a disadvantage in the long run, will want to know the game is fair in order to manage risk. In is a theoretical fact that bold wagering in Roulette increases a players odds of winning. A player who cannot know the odds of winning cannot formulate a strategy.
  • Provided that the deterministic rules of a game are implemented correctly, it is essential that the chance events of a game are indeed random. an important subproblem for generating random events is uniform random number generation. If the underlying uniform random number generator does not generate statistically independent and uniform pseudo-random numbers, then either the house or customer will be at a disadvantage. A poorly designed system might favor the house initially and over time turn to favor the player. Certainly the house would not want this situation because it makes revenue projection impossible. Any regulatory body would like to ensure that neither the house nor customer have an advantage beyond the stated theoretical probabilities of the game. In the context of fairly implemented rules, the only way for the house to increase its revenue is to increase the number of players participating in their games.
  • Typically, an engineer creating an electronic game generates a flow chart representing the rules and uses a random number generator in conjunction with combinatorial algorithms for generating chance events. Representing rules is one problem. Generating chance events to support those rules is another. Creating pseudo-random numbers is a subtle problem that requires mathematical skills distinct from other problems of gaming. In other words, a skilled game programmer may be unable to solve the problems of developing a proper random number generator. Even if given a quality random number generator, problems can occur in hardware implementations that render the generator predictable. One example is using the same seed, or initial state, for the generator at regular intervals and repeatedly generating a limited batch of numbers. Without attending to the theoretical aspects of a uniform random number generator, it is not possible to implement the rules of a game perfectly. The result is a game unfair to the house, players, or both. Hence, there is a need for a gaming system, apparatus, and method that separate the problem of implementing game rules from that of random event generation.
  • The need for such a device is also evident at the regulatory level. Gaming is a heavily regulated industry. States, tribes, and the federal government have gaming regulatory agencies at various levels to ensure fairness of the games. The gaming regulatory authority certifies that a particular implementations of a game reflects the underlying probabilities. Because electronic games are implemented in often difficult to understand software, the problem of verifying fairness of a game is challenging. Further, there is little uniformity in the implementation of fundamental components of various games. To determine fairness, the gaming authority subjects each game to a battery of tests. No set of statistical tests performed on a limited portion of the random number generator period can ensure that the generator will continue to perform fairly in the field. The process of testing is both expensive and of limited accuracy. Hence, a regulatory need exists for a uniform, standardized method of implementing games that reduce the need and extent of individual game testing while increasing he reliability of detecting and certifying game fairness.
  • Solution to the Problem
  • The Universal Gaming Engine (UGE) in accordance with the present invention is a gaming apparatus providing a consistent game development platform satisfying the needs of the gaming authority, house, player, and game developer. The UGE separates the problems of developing game rules from the difficulty, of producing chance events to support those rules. Functions that are common to a number of games are included in the gaming engine so that they need not be implemented separately for each game. By including basic functions shared by a number of games, hardware costs are greatly reduced as new games can be implemented merely by providing a new set of rules in the rules library and the basic hardware operating the game remains unchanged.
  • SUMMARY OF THE INVENTION
  • Briefly stated, the present invention provides a system, apparatus, and method for implementing a game having a deterministic component and a non-deterministic component wherein a player uses the game through at least one player interface unit. Each player interface unit generates a player record indicating player-initiated events. A random number generator provides a series of pseudo-random numbers that are preferably statistically verified by integral verification algorithms and stored in a buffer. Preferably, the random number generator allows seed and key restoration automatically or manually upon power fault.
  • A rules library stores indexed rules for one or more games. An interface registry stores mapping records where the mapping records are used to associate the player-initiated events to pre-selected rules in the rules library. A control means is coupled to receive the output of the player interface unit, coupled to the interface registry, the rules library, and the random number generator. The control means processes the player record and returns an output record to the player interface unit where the output record is determined by executing the game's rules with reference to the pseudo-random numbers and predefined combinatorial algorithms for selecting sets of the pseudo-random numbers.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 illustrates a simplified block diagram of the gaming engine in accordance with the present invention;
  • FIG. 2 illustrates a block diagram of the pseudo-random number subsystem in accordance with the present invention;
  • FIG. 3 illustrates the non-uniform distribution generator and combinatorial algorithm subsystems in accordance with the present invention;
  • FIG. 4 illustrates a main control circuit in accordance with the present invention;
  • FIG. 5 illustrates in block diagram form implementation of the rules library in accordance with the present invention;
  • FIG. 6 illustrates a flow chart of a game implementation using the apparatus shown in FIG. 1;
  • FIG. 7 illustrates a flow diagram for a second embodiment pseudo-random number distribution system;
  • FIG. 8 illustrates a multiple player networked implementation in accordance with the present invention; and
  • FIG. 9 illustrates in graphical form relationships between server speed, queue size, and customer wait times of an apparatus in accordance with the present invention.
  • DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT
  • FIG. 1 illustrates, in simplified schematic form, a gaming apparatus in accordance with the present invention. The gaining apparatus in accordance with the present invention is also referred to as a “universal gaming engine” as it serves in some embodiments as a platform for implementing any number of games having deterministic and random components. In other embodiments, the universal gaming engine in accordance with the present invention provides a platform that supports multiple players across a network where each player preferably independently selects which game they play and independently controls progression of the game.
  • Although in the preferred embodiment all of the games discussed are implemented entirely electronically, it is a simple modification to alter the player interface to include mechanical switches, wheels, and the like. Even in mechanically implemented games electronic functions that are performed by the gaming engine in accordance with the present invention are required. Hence, these mechanical machines are greatly simplified using the gaming engine in accordance with the present invention.
  • Gaming engine 100 is illustrated schematically in FIG. 1, including major subsystems in the preferred embodiments. Each of the subsystems illustrated in FIG. 1 is described in greater detail below. FIG. 1, however, is useful in understanding the overall interconnections and functioning of the gaming engine in accordance with the present invention.
  • Gaming engine 100 performs several basic functions common to many electronically implemented casino games. The most basic of these functions includes interacting with the player to detect player initiated events, and to communicate the state of a game to the player. Gaming engine 100 must process the player initiated event by determining the appropriate rules of the game that must be executed and then executing the appropriate rules. Execution of the rules may require only simple calculation or retrieving information from memory in the case of >deterministic rules, or may require access to pseudo-random values or subsets of pseudo-random values in the case of non-deterministic components.
  • Gaming engine 100 in accordance with the present invention uses a main control circuit 101 to control and perform basic functions. Main control circuit 101 is a hardware or software programmable microprocessor or microcontroller. Alternatively, main control circuit 101 can be implemented as an ASIC device with dedicated logic to perform the required control functions. Main control circuit 101 communicates with player interface unit 102 via interface bus 103. Player interface unit 102 is a machine having at least some form of display for communicating information to the player and some form of switch (i.e., buttons, levers, keyboard, coin slot, or the like) for communicating information from the player.
  • Player interface unit 102 generates a player record of information and transmits the player record over bus 103 to main control circuit 101. The player record of information contains information about the player initiated event as well as any data that may be associated with the particular event. For example, a player initiated event may be drawing two cards from a deck of cards. The player record will include information about the event (i.e., drawing cards), and data (i.e., two cards). The player record may include other information such as the state of the game that is being played. By “state of the game” it is meant at which stage in the rule defined progression of the game the game currently exists. State information may be maintained by gaming engine 100 or player interface unit 102, or both.
  • Main control circuit 101 responds to a player initiated event by referencing a public interface registry 107. Public interface registry 107 is essentially a lookup table implemented in volatile, semi-volatile, or non-volatile memory. Public interface registry 107 is desirably organized as an addressable memory where each address is associated with a mapping record. Main control circuit 101 uses the player event portion of the player record to address public interface registry 107 in a preferred embodiment. Public interface registry 107 then provide a selected mapping record to main control circuit 101. Main control circuit 101 uses the selected mapping record to address rules library 108.
  • Rules library 108 is essentially an addressable memory preferably allowing random access. Rules library 108 can be implemented in volatile, semi-volatile, or non-volatile memory of any convenient organizational structure. Rules library 108 responds to the address from main control circuit 101. by supplying one or more rules, which correspond to game rules, to main control circuit 103. The rules provided by rules library 101 are preferably executable instructions for main control circuit 101.
  • Main control circuit 101 processes the selected rules by selectively accessing random number circuit 104 and transform function algorithms 106. As set out herein before, completely deterministic rules may be executed entirely within main control circuit 101 by simple calculations or data transfer operations. Where the selected rule requires main control circuit 101 to access one or more pseudo-random numbers, random number circuit 104 is accessed. In the preferred embodiment random number circuit 104 provides a series of pseudo-random numbers of arbitrary length having uniform distribution as described in greater detail hereinafter.
  • Often times, however, a rule will require a non-uniform distribution of pseudo-random numbers, or some subset of a series of pseudo-random numbers. In this case, main control circuit 101 implements the selected rule by accessing transform function algorithms from block 106 in FIG. 1. The transform function algorithms transform the series of uniformly distributed pseudo-random numbers from random number circuit 104 by 1) transforming them into a non-uniform distribution, 2) using a given set of the uniformly distributed pseudo-random numbers to performing set selection permutations or 3) both. In this manner, the basic functions of pseudo-random number generation, pseudo-random number transformation, and association of rules with player or player events are standardized and entirely contained in gaming engine 100. System operator interface 109 is used by the casino or game developer to communicate with uniform random number circuit 104 and main control circuit 101. This communication is desirable to initialize, program, and maintain main control circuit 101 and public interface registry 107, for example. System operator interface also enables an operator to initialize, monitor and change seed values and key values used by uniform random number circuit 104. Any convenient hardware may be used to implement system operator interface 109 including DIP switches, a smart terminal, personal computer, or a dedicated interface circuit.
  • To implement a game, a game programmer develops a series of rules for the game. The series of rules are stored as a volume in rules library 108. The game programmer will then register the new game in public interface registry 107 by storing the location of the volume of rules in an appropriate address in public interface registry 107. The game programmer does not need to program or develop the random number circuit or transform algorithms to implement a new game. Further, the player using player interface unit 102 can access any of the games stored in rules library 108. To certify a new game, a game regulatory authority need only review the rules in the rules library 108 to verify that they follow the established rules for a particular game. This verification can be easily done by reviewing high-level language code such as FORTRAN, C, or Basic.
  • While the present invention is described in terms of the preferred implementation of casino games it should be understood that any game which has a random component and progresses by following pre-defined rules can be implemented in gaming engine 100. Player interface unit 102 may be entirely electronic or combine electronic and mechanical components. Player interface unit may supply any amount and kind of information in addition to the basic functions set forth above to main control circuit 101. Player interface unit 102 may be located in the same physical machine as the remaining portions of gaming engine 100 or may be located at a great distance from gaming engine 100. These and other alternatives will be discussed in greater detail hereinafter.
  • Random Number Circuit.
  • A preferred random number circuit 104 is shown in FIG. 2. Random number circuit 104 preferably includes random number generator circuit 201, verification algorithms 202, and buffer 203. Random number circuit 104 is controlled by random number control circuit 204 which is a microprocessor, microcontroller, or dedicated logic control circuit.
  • Random number generator circuit 201 provides a stream of uniformly distributed pseudo-random numbers on output 206. Alternatively, random number generator circuit 201 can provide parallel outputs on output 206. Also, more than one random number generator circuit 201 may be employed depending on the quantity of pseudo-random numbers demanded by the system.
  • Random number generator circuit 201 preferably supplies uniformly distributed pseudo-random numbers because a set of uniformly distributed numbers can be transformed easily by transform algorithms 106 into non-uniform distributions and combinatorial subsets. A preferred circuit for implementing random number generator circuit 201 is an ANSI X9.17 pseudo random number generator based upon a plurality of data encryption standard (DES) encryption circuits. Alternatively, random number generator circuit 201 may be implemented using the international data encryption algorithm (IDEA) encryption. Other random number generator circuits are known. When implementing other random number generator circuits 201, however, it should be appreciated that a high quality, cryptographically strong pseudo-random number generator is preferable. A major advantage of the present invention is that the random number circuit 104 need be implemented only once to serve a plurality of games making it cost efficient to use relatively expensive circuitry to provide a high quality random numbered circuit 104.
  • Random number generator circuit 201 accepts as input one or more key values which are typically binary values having a fixed relatively large number of bits. For example, the ANSI X9.17 pseudo-random number generator uses 56-bit keys. Random generator circuit 201 also usually accepts a seed value, which is also another large bit binary value. Further, random number generator circuit 201 has a data input or clock input that accepts a continuously variable signal which is conveniently a clock representing date and time. In this manner, each time the signal on the clock or data input changes a new random number is output on line 206. Random number control circuit stores and provides the key values, seed value, and clock values to random number generator circuit 201.
  • A desirable feature in accordance with the present invention is that random number circuit 104 be able to boot up after a power fault (i.e., power is removed from the system) using the same seed values, key values, and clock value that existed before the power fault. This feature prevents a player or operator from continually resetting the system or gaining any advantage by removing power from gaming engine 100. One way of providing this functionality is to buffer the key values, seed values, and clock values in memory within random number control circuit 204 before they are provided to random number generator 201. After a power on default, circuit 104 can reboot autonomously using the values stored in buffers. Alternatively, new values can be provided via system operator interface 109 to ensure that the output after a power fault is in no way predictable based upon knowledge of output after a prior power fault.
  • In a preferred embodiment, random number generator circuit operates continuously to provide the series of random numbers on line 206 at the highest speed possible. By continuously, it is meant that random number generator circuit 201 operates at a rate that is not determined by the demand for random numbers by the rest of the system. Random number control circuit 204 provides key values, seed values, and data values to random number generator circuit 201 independently of any processing demands on main control circuit 101 (shown in FIG. 1). This arrangement ensures that random number circuit 104 operates at a high degree of efficiency and is not slowed down by computational demands placed on main control circuit 101. In other words, the control circuit resources that implement random number control circuit 204 are independent of and usually implemented in a separate circuit from main control circuit 101.
  • Random number control circuit 204 accesses one or more verification algorithms 202 via connection 207. Verification algorithms 202 serve to verify that the raw random numbers on line 206 are statistically random to a predetermined level of certainty. Preferably, verification algorithms 202 include algorithms for testing independence, one-dimensional uniformity, and multi-dimensional uniformity. Algorithms for accomplishing these tests are well known. For example, independence of the pseudo random numbers can be performed by a Runs test. Uniformity can be verified by the Kolmorgorov-Smirnov or K-S test. Alternatively, a Chi-square test verify uniformity. A serial test is an extension of the Chi-square test that can check multi-dimensional uniformity.
  • Random number control circuit 204 preferably receives and stores a set of raw random numbers from random number generator circuit 201. The set of raw random numbers can be of any size, for example 1000 numbers. Random number control circuit 204 then implements the verification algorithms either serially or in parallel to test independence and uniformity as described hereinbefore. It may be advantageous to use more than one physical circuit to implement random number control circuit 204 so that the verification algorithms may be executed in parallel on a given set of raw random numbers.
  • If a set of raw random numbers do not pass one of the verification tests the numbers are discarded or overwritten in memory so that they cannot be used by gaming engine 100. Only after a batch of numbers' passes the battery of verification tests, are they passes via line 208 to verify random number buffer 203. Buffer 203 is preferably implemented as a first-in, first-out (FIFO) shift register of arbitrary size. For example, buffer 203 may hold several thousand or several million random numbers.
  • By integrating verification algorithms 202 in a random number circuit 104, gaming engine 100 in accordance with the present invention ensures that all of the pseudo-random numbers in buffer 203 are in fact statistically random. This overcomes a common problem in pseudo-random number circuits wherein the random numbers are long-term random, but experience short-term runs or trends. These short-term trends make prediction of both the player and casino odds difficult and may create an illusion of unfairness when none in fact exists. The verification algorithms 202 in accordance with the present invention largely eliminate these short-term trending problems and create a pool of random numbers in buffer 203 that are both statistically random and will appear to be random in the short run time period in which both the casino and players operate.
  • Buffer 203 makes the random numbers available continuously to main control circuit 101. Main control circuit 101 may access any quantity of the numbers in buffer 203 at a time. Buffer 203 also serves to provide a large quantity of random numbers at a rate higher than the peak generation rate of random number generator circuit 201. Although it is preferable that random number generator circuit 201 and verification algorithms 202 are processed so as to provide random numbers to buffer 203 at a higher rate than required by gaming engine 100, short-term bursts of random numbers can be provided by buffer 203 at a higher rate.
  • Transform Function Algorithms.
  • Transform function algorithms 106 are accessed by main control circuit 101 as illustrated in FIG. 3. Examples of transform function algorithms 106 are a non-uniform distribution generator 301 and combinatorial algorithms 302. To execute some rules obtained from rules library 108, main control circuit 101 may be required to select one or more random values from a non-uniform distribution. Examples of non-uniform distributions are normal distribution, exponential distribution, gamma distribution, as well as geometric and hypergeometric distributions. All of these non-uniform distributions can be generated from the uniform distribution provided by random number circuit 104.
  • Rule implementations primarily require that main control circuit 101 access a series of pseudo-random numbers in the context of random set selection and permutations. This subset selection is performed by combinatorial algorithms 302. The combinatorial algorithms 302 operate on either the uniform number distribution provided directly by random number circuit 104 or the non-uniform distribution provided by non-uniform distribution generator 301. In this manner, a game of keno can be implemented by selecting a random 20 from a group of 80.
  • Another function of the transform algorithms 106 is to scale and center the series of random numbers. For example, a deck of cards includes 52 cards so that the set of random numbers must be scaled to range from 1 to 52. These and similar transform functions are well known.
  • An advantageous feature of the present invention is that these transform functions can be implemented a single time in a single piece of software or hardware and selectively accessed by any of the games in rules library 108. This allows a great variety of transform functions to be provided in a cost efficient and computationally efficient manner. The game designer need only provide rules in rules library 108 that access appropriate transform function algorithms 106 and need not be concerned with the details of how the transform function algorithms 106 are implemented. Similarly, a gaming regulatory authority can verify the correctness and fairness of transform algorithms a single time by providing extensive testing. Once the transform functions are verified, they need not be verified again for each game that is implemented in rules library 108. This independence between the rules programming and the non-deterministic programming result in highly standardized and reliable games while allowing the games designer greater flexibility to design a game in the rules library 108.
  • Main Control Circuit.
  • A preferred embodiment of main control circuit 101 is shown in block diagram form in FIG. 4. Preferably, a micro-controller microprocessor 401 is provided to perform calculations, memory transactions, and data processing. Microprocessor 401 is coupled through bus 103 to player interface unit 102. Microprocessor 401 is also coupled to player number circuit 104, transform function algorithms 106, public interface registry 107, and rules library 108 through bi-directional communication lines 402.
  • In a typical configuration, main control circuit 101 will have a quantity of RAM/SRAM 403, a quantity of non-volatile memory 404, and ROM for storing an operating system and boot sequence. ROM 406 operates in a conventional manner and will not be described in greater detail hereinafter. Non-volatile memory 404 is an addressable, preferably random access memory used to store information that is desirably saved even if power is removed from main control circuit 101. For example, microprocessor 401 may calculate statistics regarding the type of games played, the rate of game play, the rate of number request, or information about the player from player interface unit 102. The statistics are preferably stored in a non-volatile memory 404 to maintain integrity of the information. Similarly, non-volatile memory 404 may be used to maintain the state of a game in progress on player interface unit 102 so that is power is removed, universal gaming engine 100 can restore player interface unit 102 to the state at which it existed prior to the power outage. This may be important in a casino operation where the casino could incur liability for stopping a game when the player believes a payoff is imminent.
  • RAM 403 serves as operating memory for temporary storage of rules access from rules library 108 or for storing the operating system for quick access. RAM. 403 may also store groups of random numbers while they are being processed by the transform function algorithms as well as address data provided to and accepted from the public interface registry.
  • It should be understood that main control circuit 101 may be implemented in a variety of fashions using conventional circuitry. While some memory will almost surely be required, the memory may be implemented as RAM, SRAM, EPROM or EEPROM to meet the needs of a particular application. Similarly, the components of main control circuit 101 shown in FIG. 4 may be implemented as a single circuit or single integrated circuit or in multiple circuits or integrated circuits. Additional features may be added to implement additional functions in a conventional manner.
  • Rules Library.
  • An exemplary embodiment of rules library 108 is illustrated in block diagram form in FIG. 5. Rules library 108 is preferably implemented as a plurality of volumes of rules where each volume is fixed in a rule EPROM 502-506. Any number of rule EPROM's can be supplied in rule library 108. Also, rule EPROM's 502 can be of various sizes. Rule EPROM's 502-506 may be replaced with equivalent memory circuits such as RAM, S RAM, or ROM. It is desirable from a gaming regulatory authority standpoint that rule EPROM's 502-506 cannot be altered once programmed so that the rules cannot be changed from the designed rules. This allows the gaining regulatory authority to verify the EPROM rules.
  • Address logic 501 provides address signals to-select one of rule EPROM's 502-506. Additionally, address logic 501 serves to position a pointer to a specific rule within each rule EPROM 502-506. As set out herein before, which of rule EPROM's 502-506 is selected as determined by the current game being played as indicated by player interface unit 102 (shown in FIG. 1). The location of the pointer within a rule EPROM is addressed based upon the current state of the game and the particular user initiated event indicated by player interface unit 102. The information is conveyed from the user interface unit 102 in a player record that is mapped to rule library 108 by the information in public interface registry 107.
  • In practice, a game developer will program a series of rules that dictate the progression of a game in response to user or player initiated events. The rules will also dictate when random numbers are accessed and the type of random numbers which should be accessed (i.e., uniform or non-uniform distributions). Rules will also control payoffs, and place boundaries on the types of player events which will be accepted. The game developer will then burn these rules, once complete, into a rule EPROM, such as rule EPROM's 502-506. The rule EPROM can then be verified by a gaming regulatory authority, and once approved, be distributed to owners of gaming engines wishing to implement the newly developed game. In order to install the new game, the rule EPROM is installed in rules library 108 and registered in public interface registry 107. The registration process described hereinbefore provides gaming engine 100 the address information necessary to enable address logic 501 to access a particular rule in rules library 108 and provide that rule on output line 507 to main control circuit 101.
  • Although rules library 108 has been described in terms of a plurality of EPROM's 502-506 wherein each EPROM holds one volume of rules pertaining to a particular game, it should be apparent that many other configurations for rules library 108 are possible. Rules can be implemented in a single large memory or in a serial memory such as a tape or disk. Address logic 500 may be integrated in rules library 108, or may be integrated with main control circuit 101. Each game may be implemented in a single EPROM or may require several EPROM's depending on the particular needs of an application.
  • Method of Operation.
  • FIG. 6 and FIG. 7 together illustrate in flow chart form a preferred method of operation of gaming engine 100 in accordance with the present invention. FIG. 6 details operation of a first embodiment single player gaming engine 100. When gaming engine 100 is started as indicated at 601 in FIG. 6, main control circuit 101 is initialized and goes through a boot-up sequence to bring it to an initial state. In this initial state it waits for user input at step 604. The player input or player record preferably indicates the game that is being played, the state of that game, and user initiated events and data that must be processed. Upon receipt of the player record, the public registry is addressed in step 606. The public registry returns a mapping record that matches the user record with a particular rule in the rules library in step 608.
  • One or more rules are accessed in step 608. Each of the one or more rules are processed in serial fashion in the embodiment illustrated in FIG. 6. One rule is processed in each pass through steps 610-622. A logical component of a first rule is processed in step 610, where the logical component includes processes of memory manipulations, calculations, and the like. In step 612, it is determined if the particular rule that was executed in step 610 requires pseudo-random numbers to process. If pseudo-random numbers are required, they are retrieved in step 700 which is illustrated in greater detail in reference to FIG. 7.
  • It is determined if the rule requires any transform algorithm in step 614. If a transform algorithm is required it is obtained in step 616. It should be understood that the transform algorithm may be permanently resident in the main control circuit 101 and so the step of obtaining 616 may be trivial. Once the necessary transfer algorithm is obtained, it is determined if the rule is completely processed in step 618. If not, flow returns to step 610 and the rule logic is executed until the rule is completely processed and a final result of the rule is determined. Once the rule is finished, control moves from step 618 to result accumulation step 620.
  • Each rule accessed in step 608 is processed in a similar manner by sequentially selecting each rule in step 626 until it is determined that all rules have been processed in step 622. Once all the rules are processed, the accumulated results are returned to the player in step 624. The results are of the rule are determined in steps 610, 612, and 614 by performing any transforms required on the random numbers, executing any deterministic components using conventional calculations and memory transactions.
  • Method for Random Number Generation.
  • FIG. 7 illustrates a flow chart showing steps in filling random number request step 700 in FIG. 6. The process shown in FIG. 7 is initiated when request 614 is made. More accurately, many of the sub-processes shown in FIG. 7 are ongoing, but the processes for generating and supplying random numbers are also responsive to the request for random numbers 700.
  • Continuously ongoing processes include clock generation step 706, providing key value(s) step 710, and providing seed value(s) step 712. The clock signal generated in step 706 need not be a real time clock, nor does it have to provide a linearly increasing or decreasing output. It is sufficient that clock 706 output a continuously variable signal at a regular interval. As set out herein before, clock generation is preferably performed by random number control circuit 204 shown in FIG. 2.
  • In a preferred embodiment, a signal is generated by the occurrence of the player event. For example, the time of the player event is determined at step 704 and may be used as shown in FIG. 7. At step 708, the clock signal and the player event signal are combined to provide a continuously variable non-random signal, Where both the player event signal and the clock are digital, the combination can be realized as logical function such as AND, OR, XOR, NAND or the like. Also, the combination may be a concatenation or subtraction function. This feature of the present invention is optional, but adds a new degree of randomness.
  • At step 714, a series of raw random numbers is generated using the continuously provided key values, seed values, and variable signal. The raw random numbers are stored at step 716 to build a group large enough to be verified during step 718. Groups of raw random numbers that fail verification step 718 are discarded, while those that pass are stored at step 720 in buffer 203 shown in FIG. 2.
  • In accordance with a first embodiment, the verified random numbers are delivered in step 722, returning process flow to step 618 shown in FIG. 6. In an alternative embodiment shown in FIG. 7, request 614 is queued at step 728 using RAM 403 shown in FIG. 4. Request queuing 728 is implemented as a first in first out or “push up” register having N queue capacity. In one embodiment, N is between 2 and 10. Queuing step 728 stores each request and processes each request in turn. In this embodiment, delivery step 722 serves whatever request is provided during step 728. Once a request is delivered, the request queue is updated in step 724.
  • Although the request queue is optional, it increases efficiency of random number generation step 700. This is especially important in the networked multi-user embodiment shown in FIG. 8. FIG. 9 illustrates generally a relationship between server speed, queue size, and the average number of customers, or requests for pseudo-random numbers, are waiting in the system. FIG. 9 is derive by modeling gaming engine 800 (shown in FIG. 8) as an M/M/1 queue to produce parameters for expected wait times in the system. FIG. 9 assumes that requests for pseudo-random numbers are made according to a Poisson process. This means that the times between successive arrivals are independent exponential random variables.
  • Upon arrival, a customer either immediately goes into service if the server is free, or joins queue 728 if the server is busy. When step 722 finishes obtaining the requested subset, the request is returned to the game and leaves the system. The next request, if any, is serviced. The times required to form the requested random subsets are assumed to be independent exponential random variables also. With these assumptions, request queue 728 can be viewed as an M/M/1 queue. The first two M's indicate that both the interarrival times as well as the service times for requests are exponential random variables. The “1” indicates there is just one server.
  • Server speed is largely determined by the hardware chosen to implement the present invention, and can be easily varied by those of skill in the art to meet the needs of a particular application. As is apparent in FIG. 9, higher server speeds result in fewer waiting customers. From the lower portion of FIG. 9, is apparent that if the queue size is reduced to zero (i.e., no request queue), the average wait time climbs even with very fast servers. Hence, to minimize wait time, a request queue is desirable.
  • It should be understood that the process steps shown in FIG. 7 may be carried out in any convenient-order unless expressly specified above. Process steps may be carried out in serial or parallel depending on the particular capabilities of main control circuit 101 shown in FIG. 1. For example, where control circuit 101 is multi-tasking or capable of parallel processing, several process steps may be executed at once. Also, process steps may be added to those shown in FIG. 7 to implement additional functions without departing from the inventive features of the present invention.
  • Network Embodiment.
  • FIG. 8 illustrates in block diagram for network embodiment in accordance with the present invention. Basic components of gaming engine 800 are similar to gaming engine 100 including random number circuit 804, transform algorithms 806, public interface registry 807, and rules library 808. Main control circuit 801 includes all of the functions described herein before in reference to main control circuit 101 but also includes function for supporting network interface circuit 812, Data bus 812 couples main control circuit 801 to network interface circuit 812.
  • The network embodiment shown in FIG. 8 serves a plurality of player interface units 802 a-801 e. This additional functionality is provided in part by network interface circuit 812 and network I/O circuits 812 a-812 e. Network interface circuit 812 and network I/O circuits 812 a-812 e can be conventional network circuits used for 10baseT, ethernet, Appletalk, or other known computer network systems. In selecting the network circuits, it is important that the data throughput is adequate to meet the needs of a particular system.
  • Network interface circuit 812 communicates a plurality of player records of information to main control circuit 801. Main control circuit may be a conventional processing circuit that serially processes each of the player records in a manner similar to main control circuit 101. Preferably, main control circuit 801 includes multitasking or parallel processing capabilities allowing it to process the plurality of player records simultaneously.
  • Simultaneous processing requires that main control circuit 801 access a plurality of rules from rules library 808, each of which may require main control unit 801 to request a set of pseudo-random numbers from random number circuit 804. In a preferred embodiment, the multiple requests for pseudo-random numbers are stored in a request queue implemented in memory of main control circuit 801. The request queue is preferably able to store more than one request. A suitable request queue can store ten requests. Random number circuit 804 treats each request from the request queue of main control circuit 801 in a manner similar to the requests from main control circuit 101 described herein before. The combination of the request queue with the buffer of random number circuit 804 allows gaming engine 800 to service requests corresponding to player initiated events very efficiently. A request queue holding even two or three requests can reduce the probability of any player waiting for delivery of a set of pseudo-random numbers significantly.
  • The request queue can be implemented by configuring a portion of the RAM available to main control circuit 801 as a first-in first-out register or push up stack. Each request for a set of random numbers is initially placed at the bottom of the request queue and sequentially raised in the request queue until the request is filled. This operation is described herein before with respect to FIG. 7.
  • By now it should be appreciated that an apparatus, method, and system for gaming is provided with greatly improved efficiency and quality over existing gaming methods and systems. The universal gaming engine in accordance with the present invention is a gaming apparatus providing a consistent game development platform satisfying the needs of gaming authorities, house, player, and game developer. The gaming engine in accordance with the present invention separates the problems of developing game rules from the difficulty of producing chance events to support those rules. By including basic functions shared by a number of games, hardware costs are greatly reduced as new games can be implemented merely by providing a new set of rules in the rules library and the basic hardware operating the game remains unchanged. It is to be expressly understood that the claimed invention is not to be limited to the description of the preferred embodiments but encompasses other modifications and alterations within the scope and spirit of the inventive concept.

Claims (52)

1. A method of playing a game of chance on a gaming device, the method comprising:
selecting one of a plurality of games;
generating a player record responsive to input on a player interface;
communicating, via a network, the player record to a gaming engine;
receiving, via the network, a game play result from the gaming engine, wherein the game play result is based upon the player record, a verified random number generated by the gaming engine, and game rules for the selected game; and
displaying the game play results on the player interface.
2. The method of claim 1, wherein the plurality of games from which one is selected is configured via an operator interface of the gaming engine.
3. The method of claim 1, wherein the plurality of games is all games for which game rules are stored in the gaming engine.
4. The method of claim 1, wherein the step of selecting a game is performed responsive to input on the player interface.
5. The method of claim 1, wherein the game rules are implemented as computer code that is executed by the gaming engine.
6. The method of claim 1, wherein the network comprises the Internet.
7. A method of playing a game of chance, the method comprising:
receiving, via a network, one or more player records from one or more gaming devices responsive to player action initiated game events;
storing game rules for a plurality of games;
generating verified random numbers;
generating a game result for each of the one or more player records, wherein the game results are based upon the player records, the verified random numbers, and the game rules for a game being played; and
communicating the game results, via the network to the one or more gaming devices.
8. The method of claim 7, further comprising communicating a message, via the network, to the one or more gaming devices indicating games which may be played.
9. The method of claim 8, further comprising receiving a message, via the network, from the one or more gaming devices indicating which of the games which may be played is to be played at a particular gaming device.
10. The method of claim 8, wherein the games which may be played are the plurality of games for which game rules are stored.
11. The method of claim 7, wherein the game rules are stored as executable computer instructions.
12. The method of claim 11, wherein the game results are generated by the execution of the game rule computer instructions.
13. The method of claim 7, wherein the network comprises the Internet.
14. A method of playing a game, the method comprising:
receiving a plurality of game rules, wherein the game rules comprise computer executable instructions that have been certified by a gaming authority;
storing the game rules in a computer readable memory;
generating one or more verified random numbers;
receiving a player record responsive to player input on a player interface;
selecting one or more game rules for execution;
executing the one or more selected game rules on a processor to generate a game result based upon the player record, one or more verified random numbers, and the one or more selected game rules; and
outputting the game result;
15. The method of claim 14, wherein the game result is output via a network.
16. The method of claim 15, wherein the network comprises the Internet.
17. The method of claim 14, wherein the player record is received over a network.
18. The method of claim 17, wherein the network comprises the Internet.
19. An electronic device for playing a game of chance, the device comprising:
means for receiving input from a user, wherein the means for receiving input further comprises means for selecting one of a plurality of games;
means for generating a player record responsive to input received from a user;
means for communicating, via a network, the player record to a gaming engine;
means for receiving from the gaming engine, via the network, a game play result based upon the player record, a verified random number generated by the gaming engine, and game rules for the game being played; and
means for displaying the game result to a user.
20. The device of claim 19, wherein the plurality of games from which one is selected is configured via an operator interface of the gaming engine.
21. The device of claim 19, wherein the plurality of games is all games for which game rules are stored in the gaming engine.
22. The device of claim 19, wherein the game rules are implemented as computer code that is executed by the gaming engine.
23. The device of claim 19, wherein the network comprises the Internet.
24. A device for playing a game of chance, the device comprising:
means for receiving, via a network, one or more player records from one or more gaming devices responsive to player action initiated game events;
means for storing game rules for a plurality of games;
means for generating verified random numbers;
means for generating a game result for each of the one or more player records, wherein the game results are based upon the player records, the verified random numbers, and the game rules for a game being played; and
means for communicating the game results, via the network to the one or more gaming devices.
25. The device of claim 24, further comprising means for communicating a message, via the network, to the one or more gaming devices indicating games which may be played.
26. The device of claim 25, further comprising means receiving a message, via the network, from the one or more gaming devices indicating which of the games which may be played is to be played at a particular gaming device.
27. The device of claim 25, wherein the games which may be played are the plurality of games for which game rules are stored.
28. The device of claim 24, wherein the game rules are stored as executable computer instructions.
29. The device of claim 28, wherein the game results are generated by the execution of the game rule computer instructions.
30. The device of claim 24, wherein the network comprises the Internet.
31. A device for playing a game, the device comprising:
means for receiving a plurality of game rules, wherein the game rules comprise computer executable instructions that have been certified by a gaming authority;
means for storing the game rules to a computer readable memory;
means for generating one or more verified random numbers;
means for receiving a player record responsive to player input on a player interface;
means for selecting one or more game rules for execution;
means for executing the one or more selected game rules to generate a game result based upon the player record, one or more verified random numbers, and the one or more selected game rules; and
means for outputting the game result;
32. The device of claim 31, wherein the game result is output via a network.
33. The device of claim 32, wherein the network comprises the Internet.
34. The device of claim 31, wherein the player record is received over a network.
35. The device of claim 34, wherein the network comprises the Internet.
36. An electronic device for playing a game of chance, the device comprising:
a user interface further comprising a display and at least one input mechanism, wherein the input mechanism is configured to allow a user to select one of a plurality of games;
a processor, communicatively connected to the user interface, configured to generate a player record responsive to input from the user interface;
a network interface, communicatively connected to the processor, configured to transmit, via a network, the player record to a gaming engine;
wherein the network interface is also configured to receive from the gaming engine, via the network, a game play result based upon the player record, a verified random number generated by the gaming engine, and game rules for the game being played; and
wherein the user interface is configured to display the game result to a user on the display.
37. The device of claim 36, wherein the plurality of games from which one is selected is configured via an operator interface of the gaming engine.
38. The device of claim 36, wherein the plurality of games is all games for which game rules are stored in the gaming engine.
39. The device of claim 36, wherein the game rules are implemented as computer code that is executed by the gaming engine.
40. The device of claim 36, wherein the network comprises the Internet.
41. A device for playing a game of chance, the device comprising:
a network interface configured to receive, via a network, one or more player records from one or more gaming devices responsive to player action initiated game events;
a memory configured to store game rules for a plurality of games;
a verified random number generator;
a processor, communicatively connected to the network interface, the memory, and the number generator, configured to generate a game result for each of the one or more player records, wherein the game results are based upon the player records, the verified random numbers, and the game rules for a game being played; and
wherein the network interface is further configure to communicate the game results, via the network, to the one or more gaming devices.
42. The device of claim 41, wherein the network interface is further configured to communicate a message, via the network, to the one or more gaming devices indicating games which may be played.
43. The device of claim 42, wherein the network interface is further configured to receive a message, via the network, from the one or more gaming devices indicating which of the games which may be played is to be played at a particular gaming device.
44. The device of claim 42, wherein the games which may be played are the plurality of games for which game rules are stored.
45. The device of claim 41, wherein the game rules are stored as executable computer instructions.
46. The device of claim 45, wherein the game results are generated by the execution of the game rule computer instructions.
47. The device of claim 41, wherein the network comprises the Internet.
48. A device for playing a game, the device comprising:
a first interface configured to receive a plurality of game rules, wherein the game rules comprise computer executable instructions that have been certified by a gaming authority;
a computer readable memory, communicatively connected to the first interface, configured to store the game rules;
a verified random number generator;
a second interface configured to receive a player record responsive to player input on a player interface;
a processor, communicatively connected with the first and second interfaces, the memory, and the random number generator, wherein the processor is configured to select one or more game rules for execution; and
wherein the processor is configured generate a game result based upon the player record, one or more verified random numbers, and the one or more selected game rules; and
wherein the processor is configured to output the game result;
49. The device of claim 48, wherein the game result is output via a network.
50. The device of claim 49, wherein the network comprises the Internet.
51. The device of claim 48, wherein the player record is received over a network.
52. The device of claim 51, wherein the network comprises the Internet.
US12/099,675 1994-12-19 2008-04-08 Universal gaming engine Abandoned US20080287181A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US12/099,675 US20080287181A1 (en) 1994-12-19 2008-04-08 Universal gaming engine

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US08/358,242 US5707286A (en) 1994-12-19 1994-12-19 Universal gaming engine
US08/959,575 US6272223B1 (en) 1997-10-28 1997-10-28 System for supplying screened random numbers for use in recreational gaming in a casino or over the internet
US09/143,907 US6986055B2 (en) 1994-12-19 1998-08-31 Method for generating random numbers
US11/302,564 US7895640B2 (en) 1994-12-19 2005-12-13 Method for control of gaming systems and for generating random numbers
US12/099,675 US20080287181A1 (en) 1994-12-19 2008-04-08 Universal gaming engine

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US11/302,564 Continuation US7895640B2 (en) 1994-12-19 2005-12-13 Method for control of gaming systems and for generating random numbers

Publications (1)

Publication Number Publication Date
US20080287181A1 true US20080287181A1 (en) 2008-11-20

Family

ID=25502164

Family Applications (7)

Application Number Title Priority Date Filing Date
US08/959,575 Expired - Lifetime US6272223B1 (en) 1994-12-19 1997-10-28 System for supplying screened random numbers for use in recreational gaming in a casino or over the internet
US09/144,119 Expired - Lifetime US6210274B1 (en) 1994-12-19 1998-08-31 Universal gaming engine
US09/143,907 Expired - Lifetime US6986055B2 (en) 1994-12-19 1998-08-31 Method for generating random numbers
US09/143,908 Expired - Lifetime US6428413B1 (en) 1994-12-19 1998-08-31 Universal game engine for a game network and method therefor
US11/302,564 Expired - Fee Related US7895640B2 (en) 1994-12-19 2005-12-13 Method for control of gaming systems and for generating random numbers
US12/099,704 Abandoned US20080261679A1 (en) 1994-12-19 2008-04-08 Universal gaming engine
US12/099,675 Abandoned US20080287181A1 (en) 1994-12-19 2008-04-08 Universal gaming engine

Family Applications Before (6)

Application Number Title Priority Date Filing Date
US08/959,575 Expired - Lifetime US6272223B1 (en) 1994-12-19 1997-10-28 System for supplying screened random numbers for use in recreational gaming in a casino or over the internet
US09/144,119 Expired - Lifetime US6210274B1 (en) 1994-12-19 1998-08-31 Universal gaming engine
US09/143,907 Expired - Lifetime US6986055B2 (en) 1994-12-19 1998-08-31 Method for generating random numbers
US09/143,908 Expired - Lifetime US6428413B1 (en) 1994-12-19 1998-08-31 Universal game engine for a game network and method therefor
US11/302,564 Expired - Fee Related US7895640B2 (en) 1994-12-19 2005-12-13 Method for control of gaming systems and for generating random numbers
US12/099,704 Abandoned US20080261679A1 (en) 1994-12-19 2008-04-08 Universal gaming engine

Country Status (1)

Country Link
US (7) US6272223B1 (en)

Cited By (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080032788A1 (en) * 1999-10-26 2008-02-07 Legal Igmaing, Inc. Cryptography and certificate authorities in gaming machines
US20100121896A1 (en) * 2008-11-12 2010-05-13 Gtech Corporation Secure random number generation
US20100167820A1 (en) * 2008-12-29 2010-07-01 Houssam Barakat Human interface device
US7877798B2 (en) 1994-12-19 2011-01-25 Legal Igaming, Inc. System and method for connecting gaming devices to a network for remote play
US7895640B2 (en) 1994-12-19 2011-02-22 Knobbe, Martens, Olson & Bear Llp Method for control of gaming systems and for generating random numbers
US8147339B1 (en) 2007-12-15 2012-04-03 Gaikai Inc. Systems and methods of serving game video
US8506402B2 (en) 2009-06-01 2013-08-13 Sony Computer Entertainment America Llc Game execution environments
US8560331B1 (en) 2010-08-02 2013-10-15 Sony Computer Entertainment America Llc Audio acceleration
US8613673B2 (en) 2008-12-15 2013-12-24 Sony Computer Entertainment America Llc Intelligent game loading
US8840476B2 (en) 2008-12-15 2014-09-23 Sony Computer Entertainment America Llc Dual-mode program execution
US8888592B1 (en) 2009-06-01 2014-11-18 Sony Computer Entertainment America Llc Voice overlay
US8926435B2 (en) 2008-12-15 2015-01-06 Sony Computer Entertainment America Llc Dual-mode program execution
US8968087B1 (en) 2009-06-01 2015-03-03 Sony Computer Entertainment America Llc Video game overlay
US9251649B2 (en) 2002-10-09 2016-02-02 Zynga Inc. System and method for connecting gaming devices to a network for remote play
CN107451061A (en) * 2017-08-03 2017-12-08 网易(杭州)网络有限公司 Game method of testing, device, storage medium, processor and service end
US9878240B2 (en) 2010-09-13 2018-01-30 Sony Interactive Entertainment America Llc Add-on management methods

Families Citing this family (195)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20030054879A1 (en) 1996-12-31 2003-03-20 Bruce Schneier System and method for securing electronic games
US20040166942A1 (en) * 1997-02-10 2004-08-26 Muir Robert Linley Distributed game accelerator
US6676127B2 (en) 1997-03-13 2004-01-13 Shuffle Master, Inc. Collating and sorting apparatus
US6655684B2 (en) 1998-04-15 2003-12-02 Shuffle Master, Inc. Device and method for forming and delivering hands from randomly arranged decks of playing cards
US6254096B1 (en) 1998-04-15 2001-07-03 Shuffle Master, Inc. Device and method for continuously shuffling cards
NZ509018A (en) * 1998-06-17 2002-06-28 Aristocrat Technologies Au Software verification and authentication
US6463078B1 (en) * 1998-07-22 2002-10-08 Microsoft Corporation Method for switching protocols transparently in multi-user applications
AR029163A1 (en) * 1999-06-11 2003-06-18 Ods Properties Inc SYSTEM FOR PERFORMING BETS INTERACTIVELY
US6735487B1 (en) 1999-07-01 2004-05-11 Ods Properties, Inc. Interactive wagering system with promotions
AU1942201A (en) 1999-12-06 2001-06-12 Ods Properties, Inc. Systems and methods for interactive wagering
US6712701B1 (en) * 2000-03-01 2004-03-30 Ods Technologies, L.P. Electronic book interactive wagering system
US7043641B1 (en) * 2000-03-08 2006-05-09 Igt Encryption in a secure computerized gaming system
CA2402389A1 (en) * 2000-03-08 2002-09-19 Shuffle Master, Inc. Computerized gaming system, method and apparatus
US7988559B2 (en) * 2001-03-08 2011-08-02 Igt Computerized gaming system, method and apparatus
US6773347B1 (en) 2000-03-31 2004-08-10 Ods Properties, Inc. Interactive wagering system
NZ521820A (en) * 2000-04-05 2004-05-28 Ods Properties Inc Interactive wagering systems and methods with multiple television feeds
EP1269674A2 (en) * 2000-04-05 2003-01-02 ODS Properties, Inc. Interactive wagering systems for providing wagering information and methods of use
US6674448B1 (en) 2000-04-05 2004-01-06 Ods Properties, Inc. Interactive wagering system with controllable graphic displays
MXPA02009907A (en) * 2000-04-05 2004-10-14 Ods Properties Inc Systems and methods for placing parimutuel wagers on future events.
US20010051540A1 (en) * 2000-04-05 2001-12-13 John Hindman Interactive wagering systems and methods with parimutuel pool features
CA2404251A1 (en) * 2000-04-05 2001-10-18 Ods Properties, Inc. Systems and methods for recognizing preferred wagerers
US8590896B2 (en) 2000-04-12 2013-11-26 Shuffle Master Gmbh & Co Kg Card-handling devices and systems
US7136889B1 (en) 2000-08-29 2006-11-14 Maxtor Corporation Method and apparatus for generating high quality real random numbers using a disk drive
EP1197909B1 (en) * 2000-10-13 2004-09-08 Matsushita Electric Industrial Co., Ltd. Contactless ic card, responding method, and program therefor
US7470196B1 (en) 2000-10-16 2008-12-30 Wms Gaming, Inc. Method of transferring gaming data on a global computer network
EP1351748A4 (en) 2000-11-28 2007-04-04 Ods Properties Inc Systems and methods for providing fixed-odds and pari-mutuel wagering
US20020065120A1 (en) * 2000-11-29 2002-05-30 Ods Properties, Inc. Interactive wagering system with automatic runner selection
US20080214300A1 (en) * 2000-12-07 2008-09-04 Igt Methods for electronic data security and program authentication
US7515718B2 (en) * 2000-12-07 2009-04-07 Igt Secured virtual network in a gaming environment
US20070136817A1 (en) * 2000-12-07 2007-06-14 Igt Wager game license management in a peer gaming network
US6802776B2 (en) * 2001-01-30 2004-10-12 Multimedia Games, Inc. Method and program product for producing and using game play records in a bingo-type game
US6749510B2 (en) * 2001-02-07 2004-06-15 Wms Gaming Inc. Centralized gaming system with modifiable remote display terminals
US7203841B2 (en) * 2001-03-08 2007-04-10 Igt Encryption in a secure computerized gaming system
US6993542B1 (en) * 2001-03-12 2006-01-31 Cisco Technology, Inc. Efficient random number generation for communication systems
US8480466B2 (en) 2001-03-27 2013-07-09 Igt Method and apparatus for previewing a game
US7918738B2 (en) 2001-03-27 2011-04-05 Igt Interactive game playing preferences
WO2003009130A1 (en) * 2001-07-18 2003-01-30 Fdk Corporation Probability generator
US7618317B2 (en) * 2001-09-10 2009-11-17 Jackson Mark D Method for developing gaming programs compatible with a computerized gaming operating system and apparatus
US8616552B2 (en) 2001-09-28 2013-12-31 Shfl Entertainment, Inc. Methods and apparatuses for an automatic card handling device and communication networks including same
US8708828B2 (en) 2001-09-28 2014-04-29 Igt Pluggable modular gaming modifiers and configuration templates for gaming environments
US7931533B2 (en) 2001-09-28 2011-04-26 Igt Game development architecture that decouples the game logic from the graphics logics
US8011661B2 (en) 2001-09-28 2011-09-06 Shuffle Master, Inc. Shuffler with shuffling completion indicator
US20030063742A1 (en) * 2001-09-28 2003-04-03 Neufeld E. David Method and apparatus for generating a strong random number for use in a security subsystem for a processor-based device
US7677565B2 (en) 2001-09-28 2010-03-16 Shuffle Master, Inc Card shuffler with card rank and value reading capability
US7753373B2 (en) 2001-09-28 2010-07-13 Shuffle Master, Inc. Multiple mode card shuffler and card reading device
US6902481B2 (en) 2001-09-28 2005-06-07 Igt Decoupling of the graphical presentation of a game from the presentation logic
US8337296B2 (en) 2001-09-28 2012-12-25 SHFL entertaiment, Inc. Method and apparatus for using upstream communication in a card shuffler
US8147334B2 (en) * 2003-09-04 2012-04-03 Jean-Marie Gatto Universal game server
US7297062B2 (en) * 2001-11-23 2007-11-20 Cyberview Technology, Inc. Modular entertainment and gaming systems configured to consume and provide network services
US8266212B2 (en) * 2001-11-23 2012-09-11 Igt Game talk service bus
US6945870B2 (en) * 2001-11-23 2005-09-20 Cyberscan Technology, Inc. Modular entertainment and gaming system configured for processing raw biometric data and multimedia response by a remote server
CA2469839A1 (en) * 2001-11-26 2003-06-05 Igt Pass-through live validation device and method
US20030128843A1 (en) * 2002-01-04 2003-07-10 Andrew Brown Method and apparatus for preserving a strong random number across battery replacement in a security subsystem
US6886829B2 (en) 2002-02-08 2005-05-03 Vendingdata Corporation Image capturing card shuffler
GB0203519D0 (en) * 2002-02-14 2002-04-03 Waterleaf Ltd Control system
US7722466B2 (en) * 2002-03-06 2010-05-25 Wms Gaming Inc. Integration of casino gaming and non-casino interactive gaming
US20030203755A1 (en) * 2002-04-25 2003-10-30 Shuffle Master, Inc. Encryption in a secure computerized gaming system
US9126102B2 (en) 2002-05-20 2015-09-08 Bally Gaming, Inc. Four-card poker game with variable wager
US20160136511A9 (en) 2002-05-20 2016-05-19 Bally Gaming, Inc. Four Card Poker Game with Variable Wager
GB0212012D0 (en) * 2002-05-24 2002-07-03 Waterleaf Ltd Purchase of services by prepayment
US20040162864A1 (en) * 2002-07-08 2004-08-19 Globespan Virata Inc. System and method for generating pseudo-random numbers
US20040023713A1 (en) * 2002-07-31 2004-02-05 Wolf Bryan D. Gaming device having a paytable with direct control over distribution of outcomes
US8083585B2 (en) * 2002-09-10 2011-12-27 Igt Apparatus and method for copying gaming machine configuration settings
US7104889B2 (en) * 2002-09-13 2006-09-12 Igt Method of using a rule based script to describe gaming machine payout
WO2004029757A2 (en) * 2002-09-26 2004-04-08 Realtime Gaming, Inc. Game payout value modification system and methods
US20040102242A1 (en) * 2002-11-21 2004-05-27 Poelmann Boudewijn Johannes Maria Systems and methods for establishing a verifiable random number
US20040152508A1 (en) * 2003-02-03 2004-08-05 Clifton Lind Method, system, and program product for conducting bingo games
US7708633B2 (en) * 2003-02-03 2010-05-04 Multimedia Games, Inc. Apparatus and method for mapping multiple bingo game results to a common display
US20040152499A1 (en) 2003-02-03 2004-08-05 Clifton Lind Method, system, and program product for conducting multiple concurrent bingo-type games
US6866584B2 (en) * 2003-02-21 2005-03-15 Igt Apparatus and method for generating a pool of seeds for a central determination gaming system
US8491391B2 (en) * 2003-03-10 2013-07-23 Igt Regulated gaming—agile media player for controlling games
US7600251B2 (en) * 2003-03-10 2009-10-06 Igt Universal peer-to-peer game download
US7921302B2 (en) 2003-03-10 2011-04-05 Igt Universal game download methods and system for legacy gaming machines
EP1611708A4 (en) * 2003-03-10 2009-12-30 Cyberview Technology Inc Dynamic configuration of a gaming system
US7802087B2 (en) * 2003-03-10 2010-09-21 Igt Universal method for submitting gaming machine source code software to a game certification laboratory
US20060063575A1 (en) * 2003-03-10 2006-03-23 Cyberscan Technology, Inc. Dynamic theming of a gaming system
US7337330B2 (en) * 2003-03-10 2008-02-26 Cyberview Technology, Inc. Universal game download system for legacy gaming machines
US20050059493A1 (en) * 2003-08-29 2005-03-17 Onesource Power Corporation Remote gaming system
US7328228B2 (en) * 2003-09-02 2008-02-05 Sap Aktiengesellschaft Mapping pseudo-random numbers to predefined number ranges
US20050050122A1 (en) * 2003-09-02 2005-03-03 Andreas Blumenthal Object-oriented pseudo-random number generator interface
US7688854B2 (en) * 2003-10-03 2010-03-30 Nokia Corporation Generalized spare extension field usage in frame protocol data frame
US20050164766A1 (en) * 2004-01-27 2005-07-28 Bettingcorp Uk Ltd. Pre-generated game creation methods and apparatus
US7637810B2 (en) 2005-08-09 2009-12-29 Cfph, Llc System and method for wireless gaming system with alerts
US8616967B2 (en) 2004-02-25 2013-12-31 Cfph, Llc System and method for convenience gaming
US7534169B2 (en) 2005-07-08 2009-05-19 Cfph, Llc System and method for wireless gaming system with user profiles
US20070060358A1 (en) 2005-08-10 2007-03-15 Amaitis Lee M System and method for wireless gaming with location determination
US7811172B2 (en) 2005-10-21 2010-10-12 Cfph, Llc System and method for wireless lottery
US8092303B2 (en) 2004-02-25 2012-01-10 Cfph, Llc System and method for convenience gaming
WO2006007481A2 (en) * 2004-07-01 2006-01-19 Progressive Gaming International Corporation Method for secure generation of a random number in a gaming system
US20060284376A1 (en) 2005-06-17 2006-12-21 Shuffle Master, Inc. Casino table variant of Texas hold'em poker
US9183705B2 (en) 2004-09-10 2015-11-10 Bally Gaming, Inc. Methods of playing wagering games
US20060066048A1 (en) 2004-09-14 2006-03-30 Shuffle Master, Inc. Magnetic jam detection in a card shuffler
US8015595B2 (en) * 2004-09-23 2011-09-06 Igt Methods and apparatus for negotiating communications within a gaming network
US8602882B2 (en) * 2004-10-04 2013-12-10 Igt Jackpot interfaces and services on a gaming machine
US7862427B2 (en) * 2004-10-04 2011-01-04 Igt Wide area progressive jackpot system and methods
US20060094497A1 (en) * 2004-11-03 2006-05-04 Ilya Presman Online gaming interaction protocol ensuring random events
AU2005305408A1 (en) * 2004-11-12 2006-05-18 Acei Ab Gaming system
US20060142079A1 (en) * 2004-12-29 2006-06-29 Igt Universal progressive game pool
US8388428B1 (en) 2005-01-10 2013-03-05 Pen-One, Inc. Community poker card game online playing system
US7736221B2 (en) * 2005-01-10 2010-06-15 Pen-One, Inc. Poker online playing system
US20060178186A1 (en) * 2005-02-04 2006-08-10 Multimedia Games, Inc. Configurable gaming machine and method for configuring games in a gaming machine
US7425002B2 (en) * 2005-02-22 2008-09-16 Randomaker Ltd. Apparatus and method for generating a graphical transformation of a lottery input number
US8128475B2 (en) * 2005-02-22 2012-03-06 Ionoco Limited Apparatus and method for generating a graphical transformation of an input number for use in a gaming application
US8663010B2 (en) * 2005-02-28 2014-03-04 Wms Gaming Inc. Remote game processing
US7722468B2 (en) * 2005-03-09 2010-05-25 Igt Magnetoresistive memory units as read only memory devices in gaming machines
US20060205513A1 (en) * 2005-03-09 2006-09-14 Igt MRAM as nonvolatile safe storage for power hit and ESD tolerance in gaming machines
US7736234B2 (en) * 2005-03-09 2010-06-15 Igt MRAM as critical event storage for powered down gaming machines
US8619981B2 (en) * 2005-05-12 2013-12-31 Jds Uniphase Corporation Systems and methods for producing pseudo-random number distributions in devices having limited processing and storage capabilities
US7764836B2 (en) 2005-06-13 2010-07-27 Shuffle Master, Inc. Card shuffler with card rank and value reading capability using CMOS sensor
US10510214B2 (en) 2005-07-08 2019-12-17 Cfph, Llc System and method for peer-to-peer wireless gaming
US8070604B2 (en) 2005-08-09 2011-12-06 Cfph, Llc System and method for providing wireless gaming as a service application
US7589742B2 (en) * 2006-03-06 2009-09-15 Microsoft Corporation Random map generation in a strategy video game
US7728837B2 (en) * 2006-03-06 2010-06-01 Microsoft Corporation Angular animation of a physical model
US7556266B2 (en) 2006-03-24 2009-07-07 Shuffle Master Gmbh & Co Kg Card shuffler with gravity feed system for playing cards
US8578116B2 (en) * 2006-03-28 2013-11-05 Broadcom Corporation System and method for memory data protection with secure pad memory
US7644861B2 (en) 2006-04-18 2010-01-12 Bgc Partners, Inc. Systems and methods for providing access to wireless gaming devices
US7549576B2 (en) 2006-05-05 2009-06-23 Cfph, L.L.C. Systems and methods for providing access to wireless gaming devices
US8939359B2 (en) 2006-05-05 2015-01-27 Cfph, Llc Game access device with time varying signal
US8579289B2 (en) 2006-05-31 2013-11-12 Shfl Entertainment, Inc. Automatic system and methods for accurate card handling
US8342525B2 (en) 2006-07-05 2013-01-01 Shfl Entertainment, Inc. Card shuffler with adjacent card infeed and card output compartments
US8353513B2 (en) 2006-05-31 2013-01-15 Shfl Entertainment, Inc. Card weight for gravity feed input for playing card shuffler
US8070574B2 (en) 2007-06-06 2011-12-06 Shuffle Master, Inc. Apparatus, system, method, and computer-readable medium for casino card handling with multiple hand recall feature
US9514596B2 (en) * 2006-07-12 2016-12-06 Igt Method and system for time gaming with skill wagering opportunities
US7722461B2 (en) * 2006-07-12 2010-05-25 Igt Method and system for time gaming with skill wagering opportunities
US20080214271A1 (en) * 2006-09-20 2008-09-04 Mattias Rydberg Electronic game card
US20080096624A1 (en) * 2006-09-20 2008-04-24 Matthias Rydberg Electronic game card
US8292741B2 (en) 2006-10-26 2012-10-23 Cfph, Llc Apparatus, processes and articles for facilitating mobile gaming
US9306952B2 (en) 2006-10-26 2016-04-05 Cfph, Llc System and method for wireless gaming with location determination
US8919775B2 (en) 2006-11-10 2014-12-30 Bally Gaming, Inc. System for billing usage of an automatic card handling device
US8510567B2 (en) 2006-11-14 2013-08-13 Cfph, Llc Conditional biometric access in a gaming environment
US9411944B2 (en) 2006-11-15 2016-08-09 Cfph, Llc Biometric access sensitivity
US8645709B2 (en) 2006-11-14 2014-02-04 Cfph, Llc Biometric access data encryption
US20080132222A1 (en) * 2006-11-30 2008-06-05 Brady Colin P Wireless communication using a picocell station having its own phone number
US8319601B2 (en) 2007-03-14 2012-11-27 Cfph, Llc Game account access device
US8581721B2 (en) 2007-03-08 2013-11-12 Cfph, Llc Game access device with privileges
US9183693B2 (en) 2007-03-08 2015-11-10 Cfph, Llc Game access device
US20090005138A1 (en) * 2007-06-28 2009-01-01 Microsoft Corporation User Creatable Machines
US8632407B2 (en) 2007-08-01 2014-01-21 Cfph, Llc General gaming engine
US8360871B2 (en) * 2007-09-26 2013-01-29 Wms Gaming Inc. Wagering game machines with non-volatile memory
WO2009052164A1 (en) 2007-10-18 2009-04-23 Wms Gaming Inc. Wagering game with dual-play feature
US8113936B2 (en) 2007-11-01 2012-02-14 Igt Time-based casino gaming using cumulative paytables
US8574051B2 (en) * 2008-01-18 2013-11-05 Igt Time based casino wagering with optional reinvestment
CA2716317A1 (en) * 2008-02-27 2009-09-03 Elektroncek D.D. Gaming system and game controller
US8246446B2 (en) * 2008-07-22 2012-08-21 Martin Wollner Method for mapping possible outcomes of a random event to concurrent dissimilar wagering games of chance
US20100058424A1 (en) * 2008-08-26 2010-03-04 Comcast Cable Holdings, Llc System and method for controlling signal traffic peaks on a video interactive network
US8795058B2 (en) * 2008-10-01 2014-08-05 Igt Gaming system and method having player accumulated points and determining each player's chances of winning an award based on the accumulated points
US8926434B2 (en) * 2008-11-07 2015-01-06 Next Gaming, LLC. Server-based gaming system and method utilizing unique memory environments
US8226467B2 (en) 2008-11-12 2012-07-24 Igt Gaming system and method enabling player participation in selection of seed for random number generator
WO2010107902A2 (en) * 2009-03-18 2010-09-23 Szrek2Solutions, Llc Secure provisioning of random numbers to remote clients
US8967621B2 (en) 2009-04-07 2015-03-03 Bally Gaming, Inc. Card shuffling apparatuses and related methods
US7988152B2 (en) 2009-04-07 2011-08-02 Shuffle Master, Inc. Playing card shuffler
KR101048439B1 (en) * 2009-04-24 2011-07-11 (주)엠더블유스토리 The server that stores the game execution authority authentication method, the recording medium on which the game execution authority authentication program is recorded, and the game execution authority authentication program.
US8231453B2 (en) 2009-08-25 2012-07-31 Igt Gaming system, gaming device and method for providing a player an opportunity to win a designated award based on one or more aspects of the player's skill
US8092299B2 (en) 2009-11-05 2012-01-10 Igt Gaming system and method for normalizing average expected payouts to players
WO2011077464A1 (en) * 2009-12-21 2011-06-30 Betware A Islandi Hf Generic auditable random generator
US8974302B2 (en) 2010-08-13 2015-03-10 Cfph, Llc Multi-process communication regarding gaming information
US8956231B2 (en) 2010-08-13 2015-02-17 Cfph, Llc Multi-process communication regarding gaming information
US8800993B2 (en) 2010-10-14 2014-08-12 Shuffle Master Gmbh & Co Kg Card handling systems, devices for use in card handling systems and related methods
US20130296021A1 (en) * 2010-12-06 2013-11-07 Mercury And Associates Structure Ii, Llc Enhanced slot-machine for casino applications
US8485527B2 (en) 2011-07-29 2013-07-16 Savant Shuffler LLC Card shuffler
US9731190B2 (en) 2011-07-29 2017-08-15 Bally Gaming, Inc. Method and apparatus for shuffling and handling cards
US8979634B2 (en) 2011-12-15 2015-03-17 Wms Gaming Inc. Wagering games with reel array interacting with simulated objects moving relative to the reel array
US9120007B2 (en) 2012-01-18 2015-09-01 Bally Gaming, Inc. Network gaming architecture, gaming systems, and related methods
US8974305B2 (en) 2012-01-18 2015-03-10 Bally Gaming, Inc. Network gaming architecture, gaming systems, and related methods
GB201202419D0 (en) * 2012-02-13 2012-03-28 Cammegh Ltd Roulette wheel system
US8740703B2 (en) 2012-03-16 2014-06-03 Empire Technology Development Llc Random data generation
US8979635B2 (en) 2012-04-02 2015-03-17 Wms Gaming Inc. Systems, methods and devices for playing wagering games with distributed and shared partial outcome features
WO2013158466A1 (en) 2012-04-15 2013-10-24 Shfl Entertainment, Inc. Interactive financial transactions
US9564007B2 (en) 2012-06-04 2017-02-07 Bally Gaming, Inc. Wagering game content based on locations of player check-in
US9305433B2 (en) 2012-07-20 2016-04-05 Bally Gaming, Inc. Systems, methods and devices for playing wagering games with distributed competition features
US8960674B2 (en) 2012-07-27 2015-02-24 Bally Gaming, Inc. Batch card shuffling apparatuses including multi-card storage compartments, and related methods
US9311777B2 (en) 2012-08-17 2016-04-12 Bally Gaming, Inc. Systems, methods and devices for configuring wagering game systems and devices
US8616981B1 (en) 2012-09-12 2013-12-31 Wms Gaming Inc. Systems, methods, and devices for playing wagering games with location-triggered game features
US9378766B2 (en) 2012-09-28 2016-06-28 Bally Gaming, Inc. Card recognition system, card handling device, and method for tuning a card handling device
US9511274B2 (en) 2012-09-28 2016-12-06 Bally Gaming Inc. Methods for automatically generating a card deck library and master images for a deck of cards, and a related card processing apparatus
US9552690B2 (en) 2013-03-06 2017-01-24 Igt System and method for determining the volatility of a game based on one or more external data feeds
KR20160144440A (en) 2014-04-11 2016-12-16 발리 게이밍, 인코포레이티드 Method and apparatus for shuffling and handling cards
US9474957B2 (en) 2014-05-15 2016-10-25 Bally Gaming, Inc. Playing card handling devices, systems, and methods for verifying sets of cards
US9875618B2 (en) 2014-07-24 2018-01-23 Igt Gaming system and method employing multi-directional interaction between multiple concurrently played games
US9566501B2 (en) 2014-08-01 2017-02-14 Bally Gaming, Inc. Hand-forming card shuffling apparatuses including multi-card storage compartments, and related methods
USD764599S1 (en) 2014-08-01 2016-08-23 Bally Gaming, Inc. Card shuffler device
US9504905B2 (en) 2014-09-19 2016-11-29 Bally Gaming, Inc. Card shuffling device and calibration method
JP6321723B2 (en) * 2015-06-04 2018-05-09 株式会社クァンタリオン A device that realizes uniqueness using the natural decay of radioisotopes
US9993719B2 (en) 2015-12-04 2018-06-12 Shuffle Master Gmbh & Co Kg Card handling devices and related assemblies and components
US10339765B2 (en) 2016-09-26 2019-07-02 Shuffle Master Gmbh & Co Kg Devices, systems, and related methods for real-time monitoring and display of related data for casino gaming devices
US10933300B2 (en) 2016-09-26 2021-03-02 Shuffle Master Gmbh & Co Kg Card handling devices and related assemblies and components
WO2019113326A1 (en) * 2017-12-07 2019-06-13 Ridgeback Network Defense, Inc. Tagging network data
US20190188955A1 (en) 2017-12-18 2019-06-20 Igt System and method for utilizing location-based analytics to provide gaming awards
US10713888B2 (en) * 2018-03-01 2020-07-14 Ags Llc Gaming system having boot locked validation of program installs, data installs and program launches
US11896891B2 (en) 2018-09-14 2024-02-13 Sg Gaming, Inc. Card-handling devices and related methods, assemblies, and components
US11376489B2 (en) 2018-09-14 2022-07-05 Sg Gaming, Inc. Card-handling devices and related methods, assemblies, and components
US11338194B2 (en) 2018-09-28 2022-05-24 Sg Gaming, Inc. Automatic card shufflers and related methods of automatic jam recovery
CN110532269B (en) * 2019-08-30 2023-06-09 深圳市原点参数信息技术有限公司 Cross-country accounting criterion conversion method based on machine learning financial statement
CN118593979A (en) 2019-09-10 2024-09-06 夏佛马士特公司 Card processing apparatus and method of assembling and using the same
US11173383B2 (en) 2019-10-07 2021-11-16 Sg Gaming, Inc. Card-handling devices and related methods, assemblies, and components

Citations (88)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3309509A (en) * 1962-05-10 1967-03-14 Csf System for checking the random character of sequences of n symbols
US4093223A (en) * 1976-01-23 1978-06-06 Wilke William F Electronic game apparatus and method
US4339798A (en) * 1979-12-17 1982-07-13 Remote Dynamics Remote gaming system
US4405829A (en) * 1977-12-14 1983-09-20 Massachusetts Institute Of Technology Cryptographic communications system and method
US4441714A (en) * 1979-05-30 1984-04-10 Tropic Industries, Inc. Poker-type table game
US4467424A (en) * 1979-12-17 1984-08-21 Hedges Richard A Remote gaming system
US4510495A (en) * 1982-08-09 1985-04-09 Cornell Research Foundation, Inc. Remote passive identification system
US4527798A (en) * 1981-02-23 1985-07-09 Video Turf Incorporated Random number generating techniques and gaming equipment employing such techniques
US4582324A (en) * 1984-01-04 1986-04-15 Bally Manufacturing Corporation Illusion of skill game machine for a gaming system
US4636951A (en) * 1983-05-02 1987-01-13 Ainsworth Nominees Pty. Ltd. Poker machine communication system
US4652998A (en) * 1984-01-04 1987-03-24 Bally Manufacturing Corporation Video gaming system with pool prize structures
US4819818A (en) * 1987-05-08 1989-04-11 John J. Simkus Random number generator
US4856787A (en) * 1986-02-05 1989-08-15 Yuri Itkis Concurrent game network
US4920432A (en) * 1988-01-12 1990-04-24 Eggers Derek C System for random access to an audio video data library with independent selection and display at each of a plurality of remote locations
US4926256A (en) * 1988-08-08 1990-05-15 Pioneer Electronic Corporation Billing data display system for a closed circuit television system
US4943062A (en) * 1988-11-23 1990-07-24 Gillette Richard A Random indicia selector
US4998199A (en) * 1987-10-02 1991-03-05 Namco Ltd. Game machine system with machine grouping feature
US5013038A (en) * 1989-12-08 1991-05-07 Interactive Network, Inc. method of evaluating data relating to a common subject
US5083272A (en) * 1988-11-02 1992-01-21 Britcanus Corporation Interactive telephone lottery system with a verification code
US5112050A (en) * 1990-01-05 1992-05-12 John R. Koza Broadcast lottery
US5128752A (en) * 1986-03-10 1992-07-07 Kohorn H Von System and method for generating and redeeming tokens
US5228077A (en) * 1987-12-02 1993-07-13 Universal Electronics Inc. Remotely upgradable universal remote control
US5309509A (en) * 1992-07-27 1994-05-03 At&T Bell Laboratories Graphical user interface workstation
US5326104A (en) * 1992-02-07 1994-07-05 Igt Secure automated electronic casino gaming system
US5330185A (en) * 1993-03-30 1994-07-19 Interlott, Inc. Method and apparatus for random play of lottery games
US5396440A (en) * 1993-01-12 1995-03-07 The Dow Chemical Company Optimum calibration frequency determination
US5398932A (en) * 1993-12-21 1995-03-21 Video Lottery Technologies, Inc. Video lottery system with improved site controller and validation unit
US5417424A (en) * 1993-09-28 1995-05-23 Gtech Corporation Player operated win checker appended to lottery agent terminal
US5420928A (en) * 1994-01-25 1995-05-30 Bell Communications Research, Inc. Pseudo-random generator
US5429361A (en) * 1991-09-23 1995-07-04 Bally Gaming International, Inc. Gaming machine information, communication and display system
US5434560A (en) * 1993-05-11 1995-07-18 Detector Electronics Corporation System for detecting random events
US5481542A (en) * 1993-11-10 1996-01-02 Scientific-Atlanta, Inc. Interactive information services control system
US5488411A (en) * 1994-03-14 1996-01-30 Multimedia Systems Corporation Interactive system for a closed cable network
US5511784A (en) * 1994-05-09 1996-04-30 Video Lottery Technologies, Inc. Method and apparatus for directly generating a random final outcome of a game
US5515307A (en) * 1994-08-04 1996-05-07 Bell Communications Research, Inc. Pseudo-random generator
US5526035A (en) * 1991-11-20 1996-06-11 Zing Systems, L.P. Transaction based interactive television system
US5528526A (en) * 1993-02-02 1996-06-18 Motorola, Inc. Arbitrary repeating pattern detector
US5634849A (en) * 1993-01-11 1997-06-03 Abecassis; Max Content-on-demand interactive video method and apparatus
US5643086A (en) * 1995-06-29 1997-07-01 Silicon Gaming, Inc. Electronic casino gaming apparatus with improved play capacity, authentication and security
US5659569A (en) * 1990-06-25 1997-08-19 Qualcomm Incorporated Data burst randomizer
US5668950A (en) * 1994-04-01 1997-09-16 Fujitsu Limited Network service system and communication unit for game machine and game machine capable of using said network service system
US5668945A (en) * 1994-02-28 1997-09-16 Sega Enterprises, Ltd. Data security apparatus and method
US5707286A (en) * 1994-12-19 1998-01-13 Mikohn Gaming Corporation Universal gaming engine
US5762552A (en) * 1995-12-05 1998-06-09 Vt Tech Corp. Interactive real-time network gaming system
US5770533A (en) * 1994-05-02 1998-06-23 Franchi; John Franco Open architecture casino operating system
US5790677A (en) * 1995-06-29 1998-08-04 Microsoft Corporation System and method for secure electronic commerce transactions
US5857025A (en) * 1996-09-09 1999-01-05 Intelligent Security Systems, Inc. Electronic encryption device and method
US5860862A (en) * 1996-01-05 1999-01-19 William W. Junkin Trust Interactive system allowing real time participation
US5867577A (en) * 1994-03-09 1999-02-02 Bull Cp8 Method and apparatus for authenticating a data carrier intended to enable a transaction or access to a service or a location, and corresponding carrier
US5954582A (en) * 1997-12-12 1999-09-21 Zach; Robert W. Wagering system with improved communication between host computers and remote terminals
US6012983A (en) * 1996-12-30 2000-01-11 Walker Asset Management Limited Partnership Automated play gaming device
US6071190A (en) * 1997-05-21 2000-06-06 Casino Data Systems Gaming device security system: apparatus and method
US6099408A (en) * 1996-12-31 2000-08-08 Walker Digital, Llc Method and apparatus for securing electronic games
US6117010A (en) * 1999-08-05 2000-09-12 Wms Gaming, Inc. Gaming device with a serial connection
US6183362B1 (en) * 1996-05-24 2001-02-06 Harrah's Operating Co. National customer recognition system and method
US6210274B1 (en) * 1994-12-19 2001-04-03 Rolf E. Carlson Universal gaming engine
US6233577B1 (en) * 1998-02-17 2001-05-15 Phone.Com, Inc. Centralized certificate management system for two-way interactive communication devices in data networks
US6234898B1 (en) * 1995-11-21 2001-05-22 Serge Christian Pierre Belamant Method and apparatus for controlling a gaming operation
US6264898B1 (en) * 1997-11-19 2001-07-24 The Titan Corporation Pulsed corona discharge apparatus
US6264560B1 (en) * 1996-01-19 2001-07-24 Sheldon F. Goldberg Method and system for playing games on a network
US20020032049A1 (en) * 1996-12-31 2002-03-14 Walker Jay S. Remote gaming device
US6370249B1 (en) * 1997-07-25 2002-04-09 Entrust Technologies, Ltd. Method and apparatus for public key management
US20020071557A1 (en) * 2000-12-07 2002-06-13 Nguyen Binh T. Secured virtual network in a gaming environment
US20020094858A1 (en) * 1999-12-10 2002-07-18 Yacenda Michael W. System and a method for operating on-line state lottery games
US20020094871A1 (en) * 2000-12-20 2002-07-18 Luciano Robert Anthony Method and apparatus for maintaining game state
US20020098888A1 (en) * 2000-04-07 2002-07-25 International Game Technology Wireless gaming environment
US20020103027A1 (en) * 2000-04-07 2002-08-01 Rick Rowe Gaming environment including portable transaction devices
US20020103028A1 (en) * 2001-01-29 2002-08-01 Carter Andrew W. Networked casino gaming system and method of participation
US6431983B2 (en) * 1996-06-25 2002-08-13 Acres Gaming, Inc. Method for providing incentive to play gaming devices connected by a network to a host computer
US20020115487A1 (en) * 2001-02-16 2002-08-22 Wells William R. Gaming device network
US20020116615A1 (en) * 2000-12-07 2002-08-22 Igt Secured virtual network in a gaming environment
US20020123966A1 (en) * 2000-06-23 2002-09-05 Luke Chu System and method for administration of network financial transaction terminals
US6508709B1 (en) * 1999-06-18 2003-01-21 Jayant S. Karmarkar Virtual distributed multimedia gaming method and system based on actual regulated casino games
US6527638B1 (en) * 1994-03-11 2003-03-04 Walker Digital, Llc Secure improved remote gaming system
US20030054880A1 (en) * 1999-10-06 2003-03-20 Igt USB device protocol for a gaming machine
US20030078103A1 (en) * 2001-09-28 2003-04-24 Igt Game development architecture that decouples the game logic from the graphics logic
US20030100372A1 (en) * 2001-11-23 2003-05-29 Cyberscan Technology, Inc. Modular entertainment and gaming systems
US6607439B2 (en) * 1995-06-30 2003-08-19 Walker Digital, Llc Off-line remote system for lotteries and games of skill
US20040002386A1 (en) * 2002-06-27 2004-01-01 Horseshoe Gaming Holding Corp. Wireless casino information management system and method
US20040002385A1 (en) * 2002-06-28 2004-01-01 Igt Redundant gaming network mediation
US6676522B2 (en) * 2000-04-07 2004-01-13 Igt Gaming system including portable game devices
US6711264B1 (en) * 1998-10-29 2004-03-23 Fujitsu Limited Security improvement method and security system
US20040111369A1 (en) * 2002-11-20 2004-06-10 Lane Kathleen Heila Method to associate the geographic location of a participant with the content of a communications session
US6757825B1 (en) * 1999-07-13 2004-06-29 Lucent Technologies Inc. Secure mutual network authentication protocol
US20040151366A1 (en) * 2003-02-04 2004-08-05 Nefian Ara V. Gesture detection from digital video images
US6846238B2 (en) * 2001-09-28 2005-01-25 Igt Wireless game player
US7260834B1 (en) * 1999-10-26 2007-08-21 Legal Igaming, Inc. Cryptography and certificate authorities in gaming machines
US20090088258A1 (en) * 1994-12-19 2009-04-02 Legal Igaming, Inc. System and method for connecting gaming devices to a network for remote play

Family Cites Families (46)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
FR1580212A (en) * 1968-04-10 1969-09-05
US4093509A (en) * 1977-06-27 1978-06-06 The Sherwin-Williams Company Production of pulp slurries employing isatoic anhydride
US4240635A (en) * 1979-03-09 1980-12-23 Harry Brown Slot machine device
JPS60250955A (en) * 1984-05-26 1985-12-11 Hamada Insatsuki Seizosho:Kk Printer slotter
US4786056A (en) * 1987-10-30 1988-11-22 Dunnigan Richard P Random number generator
US4977596A (en) * 1989-03-15 1990-12-11 The United States Of America As Represented By The United States Department Of Energy Cryptographic synchronization recovery by measuring randomness of decrypted data
DE3941268A1 (en) * 1989-09-30 1991-04-11 Stewing Kunststoff CABLE SLEEVE FOR CONNECTING AND BRANCHING CABLES, IN PARTICULAR. TELECOMMUNICATION CABLES
US5457306A (en) 1989-12-19 1995-10-10 Scotch Twist, Inc. Gaming machine system operable with general purpose charge cards
JP3077943B2 (en) * 1990-11-29 2000-08-21 シャープ株式会社 Signal encoding device
US5165091A (en) 1991-03-20 1992-11-17 Nec America Inc. Firmware download from a remote terminal to an optical network terminal in a digital loop carrier system
US5251165A (en) * 1992-04-09 1993-10-05 James Iii J Colin Two phase random number generator
US5356144A (en) 1992-07-21 1994-10-18 Fitzpatrick James R Hand-held lottery number generating device
US5515784A (en) * 1994-08-09 1996-05-14 The Ensign-Bickford Company Signal transmission devices and detonation systems using the same
US6002772A (en) 1995-09-29 1999-12-14 Mitsubishi Corporation Data management system
US5629980A (en) 1994-11-23 1997-05-13 Xerox Corporation System for controlling the distribution and use of digital works
US20040209660A1 (en) 1994-12-19 2004-10-21 Carlson Rolf E. Universal gaming engine
EP0882339B1 (en) * 1995-06-29 2011-01-19 Igt Electronic casino gaming system with improved play capacity, authentication and security
US5575717A (en) 1995-08-18 1996-11-19 Merit Industries, Inc. System for creating menu choices of video games on a display
US5689561A (en) 1995-10-06 1997-11-18 Pace; Michael Computer-based trading card system and method
US5695400A (en) 1996-01-30 1997-12-09 Boxer Jam Productions Method of managing multi-player game playing over a network
US5830069A (en) 1996-09-13 1998-11-03 Wango World Inc. Wide area networking gaming
US6142872A (en) * 1998-03-31 2000-11-07 Walker Digital, Llc Method and apparatus for team play of slot machines
DK0968607T3 (en) 1997-03-21 2003-06-10 Canal Plus Technologies Chip card for use with a receiver of encrypted transmitted signals and receiver
US5971849A (en) * 1997-04-28 1999-10-26 Falciglia; Sal Computer-based system and method for playing a poker-like game
US5964660A (en) 1997-06-18 1999-10-12 Vr-1, Inc. Network multiplayer game
US6816966B1 (en) 1997-06-30 2004-11-09 Sun Microsystems, Inc. Techniques for securing data flow in internet multicasting
US6783459B2 (en) 1997-08-22 2004-08-31 Blake Cumbers Passive biometric customer identification and tracking system
US6386974B1 (en) 1998-10-09 2002-05-14 Anchor Gaming Method of playing game and gaming device with interactive driving game display
US6805634B1 (en) 1998-10-14 2004-10-19 Igt Method for downloading data to gaming devices
US6460023B1 (en) 1999-06-16 2002-10-01 Pulse Entertainment, Inc. Software authorization system and method
GB9918427D0 (en) 1999-08-04 1999-10-06 Maygay Machines Data transfer devices and methods
US6645077B2 (en) 2000-10-19 2003-11-11 Igt Gaming terminal data repository and information distribution system
US20020151363A1 (en) 2001-04-12 2002-10-17 Howard Letovsky Method and system for broadcast and control of a remotely located wagering device
AU2002243209A1 (en) 2000-11-01 2002-07-24 Station Casinos, Inc. Method and system for remote gaming
US6969320B2 (en) 2001-01-10 2005-11-29 Multimedia Games, Inc. Distributed account based gaming system
US7186181B2 (en) 2001-02-02 2007-03-06 Igt Wide area program distribution and game information communication system
US20020142844A1 (en) 2001-02-06 2002-10-03 Kerr Michael A. Biometric broadband gaming system and method
US20020138600A1 (en) 2001-03-26 2002-09-26 International Business Machines Corporation Method, apparatus and program for multi-machine network install using writeable media
US20020142842A1 (en) 2001-03-29 2002-10-03 Easley Gregory W. Console-based system and method for providing multi-player interactive game functionality for use with interactive games
US6682423B2 (en) 2001-04-19 2004-01-27 Igt Open architecture communications in a gaming network
US6722985B2 (en) 2001-04-19 2004-04-20 Igt Universal player tracking system
JP2003257955A (en) * 2002-03-01 2003-09-12 Fujitsu Ltd Method of obtaining critical state of oxidation and reduction, method of evaluating the critical state, and method and apparatus of forming ferroelectric film
US20030233542A1 (en) 2002-06-18 2003-12-18 Benaloh Josh D. Selectively disclosable digital certificates
CA2501725A1 (en) 2002-10-09 2004-04-22 Legal Igaming, Inc. System and method for connecting gaming devices to a network for remote play
US7798900B2 (en) 2003-04-03 2010-09-21 Igt Secure gaming system
TWI239641B (en) 2004-04-02 2005-09-11 Powerchip Semiconductor Corp Non-volatile memory structure and manufacturing method thereof

Patent Citations (100)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3309509A (en) * 1962-05-10 1967-03-14 Csf System for checking the random character of sequences of n symbols
US4093223A (en) * 1976-01-23 1978-06-06 Wilke William F Electronic game apparatus and method
US4405829A (en) * 1977-12-14 1983-09-20 Massachusetts Institute Of Technology Cryptographic communications system and method
US4441714A (en) * 1979-05-30 1984-04-10 Tropic Industries, Inc. Poker-type table game
US4339798A (en) * 1979-12-17 1982-07-13 Remote Dynamics Remote gaming system
US4467424A (en) * 1979-12-17 1984-08-21 Hedges Richard A Remote gaming system
US4527798A (en) * 1981-02-23 1985-07-09 Video Turf Incorporated Random number generating techniques and gaming equipment employing such techniques
US4510495A (en) * 1982-08-09 1985-04-09 Cornell Research Foundation, Inc. Remote passive identification system
US4636951A (en) * 1983-05-02 1987-01-13 Ainsworth Nominees Pty. Ltd. Poker machine communication system
US4582324A (en) * 1984-01-04 1986-04-15 Bally Manufacturing Corporation Illusion of skill game machine for a gaming system
US4652998A (en) * 1984-01-04 1987-03-24 Bally Manufacturing Corporation Video gaming system with pool prize structures
US4856787B1 (en) * 1986-02-05 1997-09-23 Fortunet Inc Concurrent game network
US4856787A (en) * 1986-02-05 1989-08-15 Yuri Itkis Concurrent game network
US5128752A (en) * 1986-03-10 1992-07-07 Kohorn H Von System and method for generating and redeeming tokens
US4819818A (en) * 1987-05-08 1989-04-11 John J. Simkus Random number generator
US4998199A (en) * 1987-10-02 1991-03-05 Namco Ltd. Game machine system with machine grouping feature
US5228077A (en) * 1987-12-02 1993-07-13 Universal Electronics Inc. Remotely upgradable universal remote control
US4920432A (en) * 1988-01-12 1990-04-24 Eggers Derek C System for random access to an audio video data library with independent selection and display at each of a plurality of remote locations
US4926256A (en) * 1988-08-08 1990-05-15 Pioneer Electronic Corporation Billing data display system for a closed circuit television system
US5083272A (en) * 1988-11-02 1992-01-21 Britcanus Corporation Interactive telephone lottery system with a verification code
US4943062A (en) * 1988-11-23 1990-07-24 Gillette Richard A Random indicia selector
US5013038A (en) * 1989-12-08 1991-05-07 Interactive Network, Inc. method of evaluating data relating to a common subject
US5112050A (en) * 1990-01-05 1992-05-12 John R. Koza Broadcast lottery
US5659569A (en) * 1990-06-25 1997-08-19 Qualcomm Incorporated Data burst randomizer
US5429361A (en) * 1991-09-23 1995-07-04 Bally Gaming International, Inc. Gaming machine information, communication and display system
US5526035A (en) * 1991-11-20 1996-06-11 Zing Systems, L.P. Transaction based interactive television system
US5326104A (en) * 1992-02-07 1994-07-05 Igt Secure automated electronic casino gaming system
US5309509A (en) * 1992-07-27 1994-05-03 At&T Bell Laboratories Graphical user interface workstation
US5634849A (en) * 1993-01-11 1997-06-03 Abecassis; Max Content-on-demand interactive video method and apparatus
US5396440A (en) * 1993-01-12 1995-03-07 The Dow Chemical Company Optimum calibration frequency determination
US5528526A (en) * 1993-02-02 1996-06-18 Motorola, Inc. Arbitrary repeating pattern detector
US5330185A (en) * 1993-03-30 1994-07-19 Interlott, Inc. Method and apparatus for random play of lottery games
US5434560A (en) * 1993-05-11 1995-07-18 Detector Electronics Corporation System for detecting random events
US5417424A (en) * 1993-09-28 1995-05-23 Gtech Corporation Player operated win checker appended to lottery agent terminal
US5481542A (en) * 1993-11-10 1996-01-02 Scientific-Atlanta, Inc. Interactive information services control system
US5398932A (en) * 1993-12-21 1995-03-21 Video Lottery Technologies, Inc. Video lottery system with improved site controller and validation unit
US5420928A (en) * 1994-01-25 1995-05-30 Bell Communications Research, Inc. Pseudo-random generator
US5668945A (en) * 1994-02-28 1997-09-16 Sega Enterprises, Ltd. Data security apparatus and method
US5867577A (en) * 1994-03-09 1999-02-02 Bull Cp8 Method and apparatus for authenticating a data carrier intended to enable a transaction or access to a service or a location, and corresponding carrier
US6527638B1 (en) * 1994-03-11 2003-03-04 Walker Digital, Llc Secure improved remote gaming system
US5488411A (en) * 1994-03-14 1996-01-30 Multimedia Systems Corporation Interactive system for a closed cable network
US5668950A (en) * 1994-04-01 1997-09-16 Fujitsu Limited Network service system and communication unit for game machine and game machine capable of using said network service system
US5770533A (en) * 1994-05-02 1998-06-23 Franchi; John Franco Open architecture casino operating system
US5511784A (en) * 1994-05-09 1996-04-30 Video Lottery Technologies, Inc. Method and apparatus for directly generating a random final outcome of a game
US5515307A (en) * 1994-08-04 1996-05-07 Bell Communications Research, Inc. Pseudo-random generator
US20060165235A1 (en) * 1994-12-19 2006-07-27 Carlson Rolf E Method for control of gaming systems and for generating random numbers
US20090088240A1 (en) * 1994-12-19 2009-04-02 Legal Igaming, Inc. System and method for connecting gaming devices to a network for remote play
US6428413B1 (en) * 1994-12-19 2002-08-06 Rolf Carlson Universal game engine for a game network and method therefor
US6986055B2 (en) * 1994-12-19 2006-01-10 Legal Igaming, Inc. Method for generating random numbers
US20090088258A1 (en) * 1994-12-19 2009-04-02 Legal Igaming, Inc. System and method for connecting gaming devices to a network for remote play
US20090093312A1 (en) * 1994-12-19 2009-04-09 Legal Igaming, Inc. System and method for connecting gaming devices to a network for remote play
US5707286A (en) * 1994-12-19 1998-01-13 Mikohn Gaming Corporation Universal gaming engine
US20090093311A1 (en) * 1994-12-19 2009-04-09 Legal Igaming, Inc. System and method for connecting gaming devices to a network for remote play
US20090088257A1 (en) * 1994-12-19 2009-04-02 Legal Igaming, Inc. System and method for connecting gaming devices to a network for remote play
US6210274B1 (en) * 1994-12-19 2001-04-03 Rolf E. Carlson Universal gaming engine
US5790677A (en) * 1995-06-29 1998-08-04 Microsoft Corporation System and method for secure electronic commerce transactions
US5643086A (en) * 1995-06-29 1997-07-01 Silicon Gaming, Inc. Electronic casino gaming apparatus with improved play capacity, authentication and security
US6607439B2 (en) * 1995-06-30 2003-08-19 Walker Digital, Llc Off-line remote system for lotteries and games of skill
US6234898B1 (en) * 1995-11-21 2001-05-22 Serge Christian Pierre Belamant Method and apparatus for controlling a gaming operation
US5762552A (en) * 1995-12-05 1998-06-09 Vt Tech Corp. Interactive real-time network gaming system
US5860862A (en) * 1996-01-05 1999-01-19 William W. Junkin Trust Interactive system allowing real time participation
US6264560B1 (en) * 1996-01-19 2001-07-24 Sheldon F. Goldberg Method and system for playing games on a network
US6183362B1 (en) * 1996-05-24 2001-02-06 Harrah's Operating Co. National customer recognition system and method
US6431983B2 (en) * 1996-06-25 2002-08-13 Acres Gaming, Inc. Method for providing incentive to play gaming devices connected by a network to a host computer
US5857025A (en) * 1996-09-09 1999-01-05 Intelligent Security Systems, Inc. Electronic encryption device and method
US6012983A (en) * 1996-12-30 2000-01-11 Walker Asset Management Limited Partnership Automated play gaming device
US20020032049A1 (en) * 1996-12-31 2002-03-14 Walker Jay S. Remote gaming device
US6099408A (en) * 1996-12-31 2000-08-08 Walker Digital, Llc Method and apparatus for securing electronic games
US6071190A (en) * 1997-05-21 2000-06-06 Casino Data Systems Gaming device security system: apparatus and method
US6370249B1 (en) * 1997-07-25 2002-04-09 Entrust Technologies, Ltd. Method and apparatus for public key management
US6272223B1 (en) * 1997-10-28 2001-08-07 Rolf Carlson System for supplying screened random numbers for use in recreational gaming in a casino or over the internet
US6264898B1 (en) * 1997-11-19 2001-07-24 The Titan Corporation Pulsed corona discharge apparatus
US5954582A (en) * 1997-12-12 1999-09-21 Zach; Robert W. Wagering system with improved communication between host computers and remote terminals
US6233577B1 (en) * 1998-02-17 2001-05-15 Phone.Com, Inc. Centralized certificate management system for two-way interactive communication devices in data networks
US6711264B1 (en) * 1998-10-29 2004-03-23 Fujitsu Limited Security improvement method and security system
US6508709B1 (en) * 1999-06-18 2003-01-21 Jayant S. Karmarkar Virtual distributed multimedia gaming method and system based on actual regulated casino games
US6757825B1 (en) * 1999-07-13 2004-06-29 Lucent Technologies Inc. Secure mutual network authentication protocol
US6117010A (en) * 1999-08-05 2000-09-12 Wms Gaming, Inc. Gaming device with a serial connection
US20030054880A1 (en) * 1999-10-06 2003-03-20 Igt USB device protocol for a gaming machine
US20080032788A1 (en) * 1999-10-26 2008-02-07 Legal Igmaing, Inc. Cryptography and certificate authorities in gaming machines
US7260834B1 (en) * 1999-10-26 2007-08-21 Legal Igaming, Inc. Cryptography and certificate authorities in gaming machines
US20020094858A1 (en) * 1999-12-10 2002-07-18 Yacenda Michael W. System and a method for operating on-line state lottery games
US20020098888A1 (en) * 2000-04-07 2002-07-25 International Game Technology Wireless gaming environment
US20020103027A1 (en) * 2000-04-07 2002-08-01 Rick Rowe Gaming environment including portable transaction devices
US6676522B2 (en) * 2000-04-07 2004-01-13 Igt Gaming system including portable game devices
US6682421B1 (en) * 2000-04-07 2004-01-27 Igt Wireless gaming environment
US20020123966A1 (en) * 2000-06-23 2002-09-05 Luke Chu System and method for administration of network financial transaction terminals
US20020071557A1 (en) * 2000-12-07 2002-06-13 Nguyen Binh T. Secured virtual network in a gaming environment
US7168089B2 (en) * 2000-12-07 2007-01-23 Igt Secured virtual network in a gaming environment
US20020116615A1 (en) * 2000-12-07 2002-08-22 Igt Secured virtual network in a gaming environment
US20020094871A1 (en) * 2000-12-20 2002-07-18 Luciano Robert Anthony Method and apparatus for maintaining game state
US20020103028A1 (en) * 2001-01-29 2002-08-01 Carter Andrew W. Networked casino gaming system and method of participation
US20020115487A1 (en) * 2001-02-16 2002-08-22 Wells William R. Gaming device network
US6846238B2 (en) * 2001-09-28 2005-01-25 Igt Wireless game player
US20030078103A1 (en) * 2001-09-28 2003-04-24 Igt Game development architecture that decouples the game logic from the graphics logic
US20030100372A1 (en) * 2001-11-23 2003-05-29 Cyberscan Technology, Inc. Modular entertainment and gaming systems
US20040002386A1 (en) * 2002-06-27 2004-01-01 Horseshoe Gaming Holding Corp. Wireless casino information management system and method
US20040002385A1 (en) * 2002-06-28 2004-01-01 Igt Redundant gaming network mediation
US20040111369A1 (en) * 2002-11-20 2004-06-10 Lane Kathleen Heila Method to associate the geographic location of a participant with the content of a communications session
US20040151366A1 (en) * 2003-02-04 2004-08-05 Nefian Ara V. Gesture detection from digital video images

Cited By (27)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8571991B2 (en) 1994-12-19 2013-10-29 Zynga Inc. System and method for connecting gaming devices to a network for remote play
US9092932B2 (en) 1994-12-19 2015-07-28 Zynga Inc. System and method for connecting gaming devices to a network for remote play
US7877798B2 (en) 1994-12-19 2011-01-25 Legal Igaming, Inc. System and method for connecting gaming devices to a network for remote play
US7895640B2 (en) 1994-12-19 2011-02-22 Knobbe, Martens, Olson & Bear Llp Method for control of gaming systems and for generating random numbers
US8397305B2 (en) 1994-12-19 2013-03-12 Atwater Ventures Limited System and method for connecting gaming devices to a network for remote play
US8959154B2 (en) 1994-12-19 2015-02-17 Zynga Inc. System and method for connecting gaming devices to a network for remote play
US8023657B2 (en) 1999-10-26 2011-09-20 Atwater Ventures Limited Cryptography and certificate authorities in gaming machines
US20080032788A1 (en) * 1999-10-26 2008-02-07 Legal Igmaing, Inc. Cryptography and certificate authorities in gaming machines
US9251649B2 (en) 2002-10-09 2016-02-02 Zynga Inc. System and method for connecting gaming devices to a network for remote play
US8147339B1 (en) 2007-12-15 2012-04-03 Gaikai Inc. Systems and methods of serving game video
US9552191B2 (en) 2008-11-12 2017-01-24 Igt Canada Solutions Ulc Secure random number generation
US20100121896A1 (en) * 2008-11-12 2010-05-13 Gtech Corporation Secure random number generation
US8613673B2 (en) 2008-12-15 2013-12-24 Sony Computer Entertainment America Llc Intelligent game loading
US8840476B2 (en) 2008-12-15 2014-09-23 Sony Computer Entertainment America Llc Dual-mode program execution
US8926435B2 (en) 2008-12-15 2015-01-06 Sony Computer Entertainment America Llc Dual-mode program execution
US20100167820A1 (en) * 2008-12-29 2010-07-01 Houssam Barakat Human interface device
US8888592B1 (en) 2009-06-01 2014-11-18 Sony Computer Entertainment America Llc Voice overlay
US8968087B1 (en) 2009-06-01 2015-03-03 Sony Computer Entertainment America Llc Video game overlay
US8506402B2 (en) 2009-06-01 2013-08-13 Sony Computer Entertainment America Llc Game execution environments
US9203685B1 (en) 2009-06-01 2015-12-01 Sony Computer Entertainment America Llc Qualified video delivery methods
US9584575B2 (en) 2009-06-01 2017-02-28 Sony Interactive Entertainment America Llc Qualified video delivery
US9723319B1 (en) 2009-06-01 2017-08-01 Sony Interactive Entertainment America Llc Differentiation for achieving buffered decoding and bufferless decoding
US8560331B1 (en) 2010-08-02 2013-10-15 Sony Computer Entertainment America Llc Audio acceleration
US8676591B1 (en) 2010-08-02 2014-03-18 Sony Computer Entertainment America Llc Audio deceleration
US9878240B2 (en) 2010-09-13 2018-01-30 Sony Interactive Entertainment America Llc Add-on management methods
US10039978B2 (en) 2010-09-13 2018-08-07 Sony Interactive Entertainment America Llc Add-on management systems
CN107451061A (en) * 2017-08-03 2017-12-08 网易(杭州)网络有限公司 Game method of testing, device, storage medium, processor and service end

Also Published As

Publication number Publication date
US20060165235A1 (en) 2006-07-27
US20030028567A1 (en) 2003-02-06
US20080261679A1 (en) 2008-10-23
US6428413B1 (en) 2002-08-06
US7895640B2 (en) 2011-02-22
US6210274B1 (en) 2001-04-03
US6272223B1 (en) 2001-08-07
US6986055B2 (en) 2006-01-10

Similar Documents

Publication Publication Date Title
US6272223B1 (en) System for supplying screened random numbers for use in recreational gaming in a casino or over the internet
US5707286A (en) Universal gaming engine
US20040209660A1 (en) Universal gaming engine
US11657678B2 (en) General gaming engine
US7877798B2 (en) System and method for connecting gaming devices to a network for remote play
US7479062B2 (en) Apparatus and method for generating a pool of seeds for a central determination gaming system
US6663487B1 (en) Gaming machine with randomly variable pay table
JPH0134069B2 (en)
US20210390822A1 (en) Systems and methods providing a spinning reel indicator symbol trigger mechanism associated with a display position
AU2008203460B2 (en) Gaming system and a method of gaming
US20070072671A1 (en) Betting terminal with logging facility
US8708815B2 (en) Game method and gaming system
US20070270209A1 (en) Player Identification
AU2018202587A1 (en) Gaming system and a method of gaming

Legal Events

Date Code Title Description
AS Assignment

Owner name: KNOBBE, MARTENS, OLSON & BEAR, LLP, CALIFORNIA

Free format text: SECURITY INTEREST;ASSIGNOR:LEGAL IGAMING, INC.;REEL/FRAME:025309/0136

Effective date: 20101105

AS Assignment

Owner name: ATWATER VENTURES LIMITED, BAHAMAS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:LEGAL IGAMING INC.;REEL/FRAME:026740/0642

Effective date: 20110811

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION

AS Assignment

Owner name: ZYNGA INC., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:ATWATER VENTURES LTD.;REEL/FRAME:029924/0538

Effective date: 20130227

AS Assignment

Owner name: LEGAL IGAMING, INC., NEVADA

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:KNOBBE, MARTENS, OLSON & BEAR, LLP;REEL/FRAME:052818/0800

Effective date: 20151105