A portion of the disclosure of this patent document contains material that is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the Patent and Trademark Office patent files or records, but otherwise reserves all copyright rights whatsoever.
The description relates generally to wide-area, distributed gaming systems.
The rapid advances in computer and software technologies has allowed the gaming industry to offer a large variety of highly sophisticated and entertaining gaming options to casino patrons. For example, a typical casino offers a variety of electronic wagering games, such as video and mechanical slots, video poker, blackjack video keno, video bingo, video pachinko, craps, roulette, and the like. These games are typically implemented as software applications that run on special-purpose computerized gaming machines. The gaming machines are, in turn, connected into gaming networks, such as an Internet Protocol (IP) based local or wide area networks. The size of such gaming networks frequently reaches several thousand gaming machines.
Typically, gaming networks use a hub-and-spoke topology, in which gaming machines are connected to one or more centralized gaming servers. The gaming server(s) manage and control operation of the gaming applications, as well as provide various services to the gaming machines, such as billing and user authentication services. The size of these gaming network and a large amount of network traffic generated by the gaming machines and servers in a gaming network having hub-and-spoke architecture can sometimes result in difficulties related to configuration, management, and resource allocation. Moreover, there can be inherent limitations that exist in this type of network architecture that sometimes impede the development of gaming applications that run across multiple gaming machines, particularly when attempting to provide highly dynamic and interactive gaming environment to casino patrons.
Briefly, and in general terms, various embodiments disclosed herein are directed to systems and methods for coordinating a distributed game in a gaming environment. According to one embodiment, the gaming system includes a polymorphous network of game managers. In the polymorphous network, each game manager is dynamically interconnected with one or more of the other game managers, and the dynamic interconnections are based on a game manager criteria or gaming data. The gaming system also includes a plurality of groups of gaming machines where a first group of gaming machines are only in communication with a first game manager. The first game manager receives game requests from the first group of gaming machines to initiate a game. The first game manager initiates the game if a sufficient number of game requests are received by the first game manager. Alternatively, the first game manager forwards the game requests to an appropriate game manager if the first gaming machine manager receives an insufficient number of game requests.
In another embodiment, the gaming system includes a plurality of groups of gaming machines in which each group of gaming machines is in communication with a dedicated game manager. The gaming system also includes a polymorphous network of dedicated game managers in which each dedicated game manager is dynamically interconnected with one or more of the dedicated game managers in the gaming system. The dedicated game managers operate in a cooperative manner to gather a sufficient number game requests from the plurality of groups of gaming machines in order to initiate a gaming session.
In yet another embodiment, the gaming system includes a plurality of groups of gaming machines. The gaming system also includes a plurality of game controller devices in which each game controller is in communication with a group of gaming machines. The gaming system further includes a plurality of game managers in communication with the plurality of game controller devices. Each game manager is dynamically interconnected with one or more of the game managers in the gaming system. The game managers operate in a cooperative manner to gather a sufficient number game requests from the plurality of groups of gaming machines in order to initiate a gaming session.
In addition to gaming systems, various methods for coordinating a distributed game in a gaming system having a polymorphous network of game managers and one or more gaming terminals are disclosed herein. According to one method, a player request is received at a dedicated game manager to participate in a distributed game where the dedicated game manager is in communication with other game managers in the polymorphous network. The dedicated game manager then determines whether it is an appropriate session host to satisfy the player request. If the dedicated manager is deemed the appropriate session host for the distributed game, play of the distributed game is managed at the dedicated game manager. Otherwise, the player request is forwarded to the appropriate session host.
In another method, a game manager is designated as a default session host for a first gaming session within a polymorphous network. The polymorphous network includes a plurality of game managers that are dynamically interconnected with one or more of the other game managers. A player request to participate in a distributed game is received at a first game manager. If the first game manager is the default session host for the first gaming session, the first game manager manages play of the distributed game. If the first game manager is not the default session host, the first game manager is associated with the default session host for the first gaming session, and the player request is forwarded to the default session host for processing. Alternatively, if the first game manager cannot be associated with the default session host for the first gaming session, a second gaming session, which is separate and distinct from the first gaming session, is created with the first game manager designated as a second session host.
In yet another method, a player request to participate in a distributed game is received at a dedicated game manager that is in communication with other game managers in a polymorphous network. If the dedicated manager is deemed the appropriate session host for the distributed game, play of the distributed game is managed by the dedicated game manager. If the dedicated game manager is not the appropriate session host, the player request is forwarded to the appropriate session host. Alternatively, if the player request can not be forwarded to the appropriate session host, a second gaming session is created with the dedicated game manager being designated as the default session host.
In addition to methods for coordinating a distributed game in a gaming system having a polymorphous network of game managers, various methods of reducing cheating in a distributed game presented on a plurality of gaming machines in a gaming system are disclosed herein. According to one method, at least two player requests are received at a dedicated game manager to participate in a distributed game. The game manager determines whether a low bettor is a sleeper and whether a high bettor is a beneficiary in the distributed game. The sleeper is a player that refuses to accept a prize to the benefit of another player (i.e., the beneficiary). The game manager then flags the gaming machines designated as the sleeper and the beneficiary in future gaming sessions. Once designated, the sleeper and the beneficiary are prevented from both joining a same game in future gaming sessions.
In another method, a determination is made to whether a first gaming machine receiving a low bet is a sleeper in a distributed game and whether a second gaming machine receiving a high bet is a beneficiary in the distributed game. The sleeper is defined as a gaming machine (or player) refuses to accept a prize to the benefit of the beneficiary. The gaming machines determined to be sleeper and the beneficiary are flagged, and the game manager prevents the sleeper and the beneficiary from both joining a same game in a future gaming session.
In yet another method, game play is monitored for suspicious gaming activity that includes a gaming machine receiving a low bet and refusing a prize for a winning outcome. The gaming machine receiving the low bet and refusing the prize is flagged as a sleeper. The gaming machine receiving the high bet and accepting the prize is flagged as a beneficiary. Once designated, the gaming system prevents the sleeper and the beneficiary gaming machines from both joining a same game in a future gaming session. The sleeper and beneficiary flags are removed from the gaming machines in response to a cash out event or a predetermined number of games without any suspicious gaming activity.
Other features and advantages will become apparent from the following detailed description, taken in conjunction with the accompanying drawings, which illustrate by way of example, the features of the various embodiments.
Various embodiments disclosed herein are directed to systems and methods for coordinating a distributed game in a gaming environment. Generally, the gaming system presents a distributed game to one or more gaming terminals, in which the distributed game may be a Class 2 bingo, lotto, or lottery game. The gaming system also includes a plurality of game managers, which are responsible for coordinating and managing play of the distributed game. Each of the game managers is fully accessible to other game managers in the gaming system. This accessibility allows a game manager to dynamically form interconnections with other game managers in the system. Given this dynamic structure, game requests (received at a game manager) may be satisfied or quickly routed to an appropriate game manager within the gaming system. As a result, the gaming system maximizes game play by reducing the time needed to obtain a sufficient number of game requests since the gaming requests received at a local game manager may be forwarded onto a busier game manager that can satisfy the request. Additionally, game play is maximized as game denials due to time outs or other time delays are minimized because game managers having low request rates can forward receive game requests to busier gaming managers within the gaming system.
In one embodiment, the gaming system is configured as a polymorphous network of game managers. A polymorphous network, as defined and described herein, relates to a network of game managers having varying network interconnections between the game managers. For example, a gaming network having four game managers (e.g., A, B, C, and D) may be initially interconnected as A to B, B to C, and C to D. From gaming session to gaming session (i.e., from game to game), the interconnections between the game managers may change in response to gaming data (e.g., local rate of play at game manager), thereby creating new interconnections between the game managers.
Additionally, the polymorphous network may also be a cooperative network. In a cooperative network, the game managers work or act together for a common purpose. In one embodiment, the common purpose is allowing players at any gaming site (e.g., gaming establishment) to play against other players at another gaming site, same gaming site, or shared central site provided that cooperation has been arranged (or designated) and a link is available. In another embodiment, the common purpose is minimizing game delays (i.e., reducing the time between the game request and game play). In yet another embodiment, the common purpose is minimizing or eliminating game denials (i.e., game request is not satisfied).
Referring now to the drawings, wherein like reference numerals denote like or corresponding parts throughout the drawings and, more particularly to
As shown in
In some embodiments, the game controller has additional functions depending on the type of bingo game. Some bingo games are “score-based” in which the game decides an award amount based on the balls drawn, and other bingo games are “template-based” in which the bingo system provides a lottery-style prize to the game. If the bingo game is “template-based,” the game controller 18 creates and manages the lottery pools and subsets of the lottery pool. Additionally, the game controller 18 also distributes prizes drawn from the subsets of pools in response to a game play request from a player at the gaming terminal.
In
Additionally, each of the game managers 12 is an “equal” to the other gaming managers. Unlike traditional hub and spoke networks, none of the game managers 12 is a hierarchical master (i.e., a game manager that only communicates with a few, specific game managers). Accordingly, in the gaming system 10 shown in
According to one embodiment, the game manager devices 12 include a processor for executing one or more algorithms for coordinating game request amongst a plurality of game managers. Additionally, the game managers 12 include one or more game applications that control game play and communications between the game manager and the player terminals 14. In one embodiment, the game application can also select the best host (local or remote) to satisfy a request for gaming participation. Alternatively, the software and/or hardware for coordinating game requests and establishing gaming sessions is independent of the game application. For example, in one embodiment, the software is an independent subsystem that routes game play messages to a host that can best satisfy the gaming request. The software is used in conjunction with the game application to implement a virtual network and routing for game play messages.
In another embodiment, the game manager 12 includes a coupler. The coupler establishes a communication link between two game managers 12. The coupler establishes the communication link between the game managers by either listening for requests (e.g., similar to a server) or establishing connections (e.g., similar to a client). The coupler implements a gaming session network using the proper program based upon the target game manager 12. For example, the coupler would implement a gaming session network (form interconnections between two game managers) using DirectX's DirectPlay peer interface if the target game manager is Windows-based applications. Alternatively, the coupler would implement a gaming session network (form interconnections between two game managers) using TCP sockets. It is also contemplated that other forms of IP transport such as, but not limited to, HTTP or HTTPS may be used to implement a gaming session network.
Unlike traditional peer-to-peer networks, the gaming session network formed by the network coupler does not require a session host, (i.e., one game manager designated as the hierarchical “master” of all the other game managers). In contrast, when a connection is made between two game managers and a socket is opened, each game manager is treated the same (i.e., there is no hierarchy between the two game managers). Additionally, the gaming session formed by the coupler does not require closure (i.e., a network session is established only when all the game managers are in communication with all the other game managers within the network). Rather, the gaming session may be formed by any number of game managers so long as there are a sufficient number of game requests.
The game managers 12 also include one or more ports for receiving and sending current status information that can be used to properly coordinate and route game requests. The game managers 12 further include a game engine, which entails the actual grouping of player requests and the execution of the central determination game. Additionally, each game manager is “provisioned” (i.e., given the addresses of the other members of the cooperative) in order to properly coordinate the central determination game. According to one embodiment, the game managers 12 are in communication with one another via an Ethernet network, a wireless network, wireless local area network, or an optical fiber network.
Additionally, each game manager is assigned a 64-bit identifier. The first portion of the 64-bit identifier is dedicated to the IP address of the game manager of the requesting game. The second portion of the 64-bit address is dedicated to the IP address of the requesting gaming machine. The different portions of the 64-bit address allows game play messages to be routed from the game manager executing the distributed game through the game manager to which the game is connected to the appropriate game terminal. In some instances, the game manager executing the distributed game and the game manager connected to the game terminal are the same game managers. In other instances, these game managers are different game managers.
When the game request is received at the local game manager 12, a selection algorithm allows the local game manager 12 to determine whether the game request should or should not be satisfied. In order for the selection algorithm to make a proper determination of routing the game request, each of the game managers 12 need to be appraised of the current status information of all the other game managers in the session. The selection algorithm compares the local request rate of the game manager device 12 to the request rates of other game managers in the session. If the local request rate is low (as compared to other request rates), the local game manager 12 forwards the game request directly to the game manager 12 most likely to satisfy the request. Otherwise, the local game manager will satisfy the game request if the local request rate is sufficient to support and satisfy the game request.
In another embodiment, the host chosen upon receiving a game request may also be selected based upon gaming data. Gaming data may be a “local game request rate,” which is defined as the number of game requests over a given time period received by the game manager from player terminals connected to the game manager. Alternatively, gaming data may be a “local game session rate,” which is defined as the number of gaming sessions occurring at a game manager over a given period of time. In another embodiment, the gaming data is a “local forward rate,” which is defined as the number of game requests (from gaming terminals connected to the game manager) forwarded over a defined period of time to another game manager within the network. In yet another embodiment, the gaming data is a “local provide rate,” which is defined as the number of forwarded game requests the game manager is executing.
In one embodiment, these various rates may be smoothed out using a moving average. Additionally, the rates may be calibrated to other settings such as, but not limited to, timeouts. In one embodiment, determinants of these rates include second-order derivatives of the rates so that shifts in the rates can be quickly detected. The rate data is used to maximize the session rate (number of games presented over a period of time).
Referring back to
Another aspect of the polymorphous cooperative includes defensive measures to prevent a player or players from taking advantage of the cooperative system presenting a Class 2 bingo game. Class 2 bingo games require multiple players to be grouped together for play of the bingo to proceed, and for each play of the bingo game there is typically a winner and a loser. In order to maximize game play (i.e., the number of games offered over time), the game manager may group players together having disparate bet amounts. In a “sleeper-beneficiary” scenario, a wily player can cheat the system. In this scenario, the player occupies two player terminals and places a minimum bet on one player terminal while placing a maximum bet on the other player terminal. The player can tell if the two gaming machines are in the same game session if the game start message, initial ball draw, sounds or graphics for the games are initiated at the same time. If the player determines that the two gaming machines are playing games in separate gaming sessions, the player will play the games normally. If the player determines that the two gaming machines are playing games in the same gaming session, the player does not daub if the low-bet terminal wins a prize. The session will time out waiting for the low-bet daub, and the game will continue (i.e., draws more balls) until the high-bet terminal gets a prize. The player will then accept the prize for the high-bet terminal as opposed to the low-bet terminal. Otherwise stated, the small bet is the “sleeper” and does not accept prizes, and the high bettor is a “beneficiary” because the high better always wins (as compared to the sleeper).
In order to detect a “beneficiary” and the “sleeper” in the “sleeper-beneficiary” scenario, a game manager looks for a high bettor is playing against a low better in a gaming session. The game manager also looks for a situation in which the low bettor has won a prize(s) yet refuses to collect the prize(s). This player is flagged as a “sleeper.” The high bettor is the player in this scenario that accepts the prize(s). The high bettor is flagged as the “beneficiary.” Messages identifying the “sleeper” and the “beneficiary” are sent along with the award message to the player terminals. When subsequent games are played on the “sleeper” or “beneficiary” player terminals, a “sleeper” or “beneficiary” flag is sent along with a game request.
Once a player is identified as a “sleeper” or a “beneficiary,” certain rules are implemented for subsequent game requests until the flags are reset. According to one embodiment, the “sleeper” can only join bingo games with other players making the same or lower wager. Additionally, the bingo games that the “beneficiary” may also be restricted so that the “beneficiary” is only allowed to play games other players who have the same wager, higher wagers, or lower bettors that do not include the “sleeper.” Lastly, a “beneficiary” who places a low bet cannot be placed in a game where the “sleeper” is a high bettor. This rule guards against the scenario in which the player reverses roles between the “sleeper” and the “beneficiary.” These rules apply regardless of the order of the request arrivals and have no influence on ranking and routing of game requests.
While the “sleeper” and “beneficiary” flags may reduce participation because it disallows suspicious play, the flags should be reset as soon as possible. Accordingly, there are basic rules for resetting the “sleeper” and “beneficiary” flags. According to one embodiment, a cash out event by the “sleeper” and/or the “beneficiary” clears the flags. In another embodiment, the flags are reset after a predetermined number of normal game plays (i.e., game play on a game terminal that is not involved in sessions with suspicious refusals). In yet another embodiment, the flags are reset after a predetermined number of voided game plays (i.e., player may be an innocent novice). The predetermined number of games required to reset the flags may be initially set at seven games (or any other number of games). Alternatively, the number of games required to reset the flags may be increased if the game terminal and/or game manager detects a pattern of sleeping at a particular player terminal. For example, ten consecutive games of non-suspicious game play may be required to reset a flag.
Optionally, in the event a sleeper is detected, a message may be sent to casino floor manager or other individuals at the gaming establishment to monitor one or more player terminals. In yet another embodiment, the gaming machine(s) suspected of suspicious play presents may be a message to the player. The message may be a basic message such as, but not limited to, presenting the player with the option to review the rules of the game or presenting flashing lights or sounds with a message to accept an award. In another embodiment, a warning message that the player is suspected of suspicious play is presented on the gaming machine.
Although the invention has been described in language specific to computer structural features, methodological acts, and by computer readable media, it is to be understood that the invention defined in the appended claims is not necessarily limited to the specific structures, acts, or media described. Therefore, the specific structural features, acts and mediums are disclosed as exemplary embodiments implementing the claimed invention.
Furthermore, the various embodiments described above are provided by way of illustration only and should not be construed to limit the invention. Those skilled in the art will readily recognize various modifications and changes that may be made to the claimed invention without following the example embodiments and applications illustrated and described herein, and without departing from the true spirit and scope of the claimed invention, which is set forth in the following claims.
This application is related to co-pending U.S. patent application Ser. No. 12/264,852 concurrently filed on Nov. 4, 2008, entitled SYSTEMS FOR COORDINATING A DISTRIBUTED GAME IN A GAMING ENVIRONMENT, which is hereby incorporated by reference.