Game talk service bus

Information

  • Patent Grant
  • 8266212
  • Patent Number
    8,266,212
  • Date Filed
    Tuesday, August 21, 2007
    17 years ago
  • Date Issued
    Tuesday, September 11, 2012
    12 years ago
Abstract
A service-oriented bus for distributed gaming systems allowing gaming machines, servers, workstations, mobile PCs, handheld devices and automatic telling machines to talk together over a network. The game service bus provides a publish-and-subscribe message bus over a private network within a gaming property and/or over the public Internet across several properties. The service bus framework allows participating communicating end points to publish services or subscribe to services in a simple and standardized high level fashion, thereby enabling the devices to understand one-another, thus “talk” together. The “talking together” paradigm is rather appropriate, as it emphasizes the value that the service bus brings to a complex distributed casino gaming system that may include thousands of devices manufactured by dozens of vendors. Gaming machines may talk together in a peer-fashion over the service bus, which is well suited for multiplayer gaming. The service-oriented bus allows third party ultra-specialized vendors to offer dazzling plug-in services directly on the casino floor, such as automated geo-localized logistic support and other geo-localized services.
Description
BACKGROUND OF THE INVENTION

1. Field of the Invention


Embodiments of the present invention relate generally to the field of pay computer-controlled games and entertainment devices, including both games of skills and games of chance. More particularly, embodiments of the present invention relate the field of methods, systems and devices for the automated monitoring and control of a large number of clusters of such pay gaming and entertainment devices.


2. Description of the Related Art


Conventional pay entertainment and gaming systems, either of the cash or the cash-less type, are seriously limited due to the technical choices that are typically made to comply with regulatory requirements. Indeed, regulators are mainly concerned with fraud, cheating and stealing, as may occur when legitimate winners are deprived of their just winnings or when illegitimate users receive illegitimate winnings. Because of these security concerns, regulators are reluctant to approve licenses for state-of-the-art “open” multimedia and Internet technologies, opting instead for known but antiquated technology.


However, the security of such antiquated technology (i.e., technology developed prior to the present advanced multimedia and Internet age) is mostly illusory. Such conventional technologies are only perceived as being more stable and secure because their flaws are not widely publicized. Computer technology being extremely complex, there are always latent imperfections and flaws, which may be exploited by the ill intentioned. This is even truer with antiquated technology, as hacker-crackers have now access to considerable information on software weaknesses as well as sophisticated attack strategies and tools that they may apply to older software.


Legacy entertainment and gaming systems that are authorized for use in public places are usually aggregates of old technologies bundled together with some PC hardware featuring basic fault tolerance, basic data integrity and ad-hoc security means, together with some LAN networking functionality to enable some primitive centralized auditing. Although some advanced security means have been proposed (such as disclosed in, for example WO 01/41892) that promote off-line gaming security using smart cards, this approach in fact exposes the system to latent unidentified security threats that hacker-crackers or employees will likely eventually exploit. Off-line or semi-on-line systems are totally in the hands of very few people. In short, these systems operate essentially with little means for detecting under-the-radar fraud (to push the analogy farther, finer-grained and smarter radar means would be uneconomical for casino and gaming operators to implement).


In contrast, lottery and pari-mutual wager systems have evolved to modern fully on-line very-high-capacity mission-critical systems funneling billions of dollars annually while offering significantly greater security means than the security afforded by banks. Since these organizations have come on-line, lawsuits resulting from complaints, flaws and fraud, including internal fraud by employees, have virtually disappeared. However, although pay entertainment and gaming machines based on secure Internet web browser and cash-less payment technology are ideal centralized candidate solutions to equip casinos and like sites, these may rapidly kill the traditional gaming support industry.


The entertainment and gaming systems lag behind state-of-the-art multimedia PC, gaming console, wireless and interactive TV technologies; consequently these systems are ill prepared to attract the younger player generation accustomed to flashy and networked games.


SUMMARY OF THE INVENTION

It is therefore an object of this invention to provide an architecture that overcomes the technical lag, security limitations and lack of stability of the prior art. It is a further object of this invention to provide an architecture that overcomes rapid obsolescence of technology. It is yet another object of this invention to provide a flexible architecture that may more easily accommodate the variety of specific regulatory requirements encountered around the world. It is a still further object of this invention to provide specific function peripheral devices with means of secure identification and secure network communication.


An embodiment of the present invention is a distributed gaming system. The distributed gaming system may include a communication bus; at least one first node, each including a first computer coupled to the communication bus, and at least one second node, each including a second computer coupled to the communication bus. The at least one first node may further include at least one first service oriented software executing in the first computer of each first node, the first service oriented software including at least one high-level function and a first service oriented protocol, the first service oriented protocol being configured to negotiate service messages over the communication bus, the first service oriented software being configured to selectively:

    • publish the at least one high-level function;
    • provide the at least one high-level function upon receiving a request to consume the at least one high-level function;
    • enable execution of the at least one high-level function upon receiving a request for execution;
    • perform a call back upon receiving a request to consume or execute the at least one high-level function, and
    • return a reply subsequent to receiving a request for execution of the at least one high-level function.


The at least one second node may include a second computer coupled to the communication bus, and at least one second service oriented software executing in the second computer of each second node, the second service oriented software including at least one function call and a second service oriented protocol configured to negotiate service messages over the communication bus, the second service oriented software being configured, upon execution of the at least one function call, to selectively:

    • subscribe to or consume the published or provided at least one high-level function;
    • request that the at least one first node execute the at least one high-level function;
    • accept the reply subsequent to receiving a reply from the at least one first node, and
    • accept the call-back upon receiving a call-back from the at least one first node.


The first service oriented software may be configured to provide the at least one high-level function upon receiving a request to consume the at least one high-level function via a remote procedure call. The first service oriented software may be configured to provide the at least one high-level function upon receiving a request to consume the at least one high-level function via a HTTP request. The first service oriented software may be configured to enable execution of the at least one high-level function upon receiving a request for execution via a HTTP request. The first service oriented software may be configured to perform a call back upon receiving a request to consume or execute the at least one high-level function via a remote procedure call. The first service oriented software may be configured to return a HTTP reply subsequent to receiving a HTTP request for execution of the at least one high-level function.


The service oriented protocol is the Service Oriented Architecture Protocol (SOAP), for example. The communication bus may include loosely coupled and/or tightly coupled nodes. The loosely coupled nodes may include nodes coupled via Ethernet, Wi-Fi, Internet, radio-link, RS-422, micro-wave link and/or satellite link, for example. The tightly coupled nodes may include nodes coupled via inter-process communication, USB, Bluetooth, RS-232, RS-422 and/or IEEE1394 FIREWIRE connection protocols, for example. The at least one high-level function may include a business function, an audit function, an authentication function, a biometric identification function, a graphics rendering computation function and/or an outcome determination function, to name but a few of the possible high-level functions. The at least one first node may include a gaming machine, an entertainment machine, a payment verification unit, a specialized device, an IP enabled peripheral, a server, a server farm, a computer device, and/or an automatic teller machine, for example.


The at least one second node may include, for example, a gaming machine, an entertainment machine, a payment verification unit, a specialized device, an IP enabled device, a server, a server farm, a computer device, and/or an automatic teller machine. The first and/or second service oriented protocol may include asynchronous notification of events, COM+, DCOM, MICROSOFT REMOTING, MICROSOFT .NET, CORBA, SOAP, IBM SOA and/or UDDI protocols, for example. Security over the communication bus may be provided by implementing the IPSec protocol, the VPN tunneling protocol and/or the SSL protocol, for example.


The at least one second node may include a gaming machine. The at least one second node may be included inside a gaming machine. The at least one first node may include a gaming machine. The at least one first node may be included inside a gaming machine. The at least one second node may include a gaming machine played by a player and may be configured to execute at least one function call during a game session. The at least one second node may be included inside a gaming machine played by a player and may be configured to execute at least one function call during a game session. The at least one first node may be configured for load balancing with another one of the at least one first node. The negotiating of service messages on the communication bus may include at least one of, for example, naming, discovery, message routing, publishing eventing, subscribing eventing, message transformations, workflows, and communication recovery from nodes powering-off then on again.


According to another embodiment thereof, the present invention is a distributed gaming system that may include a communication bus; a first gaming machine coupled to the communication bus; the first gaming machine being configured to selectively publish, execute and provide at least one high-level function, and a second gaming machine coupled to the communication bus, the second gaming machine being configured to selectively subscribe to or consume the at least one high-level function published or provided by the first gaming machine, and selectively request that the first gaming machine execute the at least one high-level function.


The first gaming machine may be further configured to perform a call back upon receiving a request to consume or execute the at least one high-level function, and return a reply and wherein the second gaming machine is further configured to accept the reply subsequent to receiving the call-back from the first gaming machine. The distributed gaming system may further include a service-oriented device coupled to the communication bus, the service oriented device including at least one of a payment verification unit, a specialized device, an IP enabled peripheral, a server, a server farm, a computer device, and an automatic teller machine, for example. The service oriented device may be configured to selectively publish, subscribe, provide, execute and request that either the first or the second gaming machine execute the at least one high level function.


According to another embodiment thereof, the present invention is a method for distributed gaming over a communication bus. The method may include steps of, for example, providing a first gaming machine and coupling the first gaming machine to the communication bus; publishing, by the first gaming machine, a first high-level function over the communication bus; providing a node coupled to the communication bus; receiving, from the node, a request to subscribe to the published first high-level function; accepting the subscription request; initiating a gaming session on the first gaming machine, and responsive to updates occurring during the gaming session, providing call backs, by the first gaming machine, the call backs returning a result of the execution of the first high-level function to the node over the communication bus.


The receiving step may be carried out with the node including a second gaming machine. The receiving step may be carried out with the node including at least one of an entertainment machine, a payment verification unit, a specialized device, an IP enabled device, a server, a server farm, a computer device, and/or an automatic teller machine, for example. The high-level function may include at least one of a business function, an audit function, an authentication function, a biometric identification function, a graphics rendering computation function and/or an outcome determination function. The method may further include a step of receiving, from the node, a request that the first gaming machine executes the high-level function. A step may be carried out of the first gaming machine performing a call back upon receiving the request to consume or execute the high-level function. The second providing step may be further carried out with the node being configured to selectively publish, subscribe, provide, execute and request that the first gaming machine execute the high level function.


According to yet another embodiment thereof, the present invention is a method for distributed gaming over a communication bus. The method may include providing a first node and coupling the first node to the communication bus; publishing, by the first node, a high-level function over the communication bus; providing a first gaming machine coupled to the communication bus; receiving, from the first gaming machine, a request to subscribe to the published high-level function; accepting the subscription request; initiating a gaming session on the first gaming machine, and responsive to updates occurring during the gaming session, providing call backs, by the first node, the call backs returning a result of the execution of the high-level function to the first gaming machine over the communication bus.


The receiving step may be carried out with the first node including a second gaming machine. The receiving step may be carried out with the node including an entertainment machine, a payment verification unit, a specialized device, an IP enabled device, a server, a server farm, a computer device and/or an automatic teller machine, for example. The high-level function may include a business function, an audit function, an authentication function, a biometric identification function, a graphics rendering computation function and/or an outcome determination function, for example. The method may further include a step of receiving, from the first gaming machine, a request that the node execute the first high-level function. A step may be carried out of the node performing a call back upon receiving the request to consume or execute the high-level function. The second providing step may be further carried out with the first gaming machine being configured to selectively publish, subscribe, provide, execute and request that the node execute the high level function.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a diagram of a gaming system in accordance with an embodiment of the present invention.



FIG. 2 is a diagram of an exemplary cash gaming machine in accordance with an embodiment of the present invention.



FIG. 3 is a diagram of an exemplary cash-less gaming machine in accordance with an embodiment of the present invention.



FIG. 4 is a diagram of an exemplary entertainment machine in accordance with an embodiment of the present invention.



FIG. 5 is a diagram an exemplary PVU (Payment Verification Unit) in accordance with an embodiment of the present invention.



FIG. 6 is a diagram of an exemplary compact PVU in accordance with an embodiment of the present invention.



FIG. 7 is a diagram depicting an exemplary Automatic PVU (APVU) or “Smart Cashier” in accordance with an embodiment of the present invention.



FIG. 8 is a diagram depicting a tightly coupled configuration of a gaming machine in accordance with an embodiment of the present invention.



FIG. 9 is a diagram depicting a modular software architecture of a gaming machine in accordance with an embodiment of the present invention.



FIG. 10 is a diagram depicting a loosely coupled software configuration of a gaming machine in accordance with an embodiment of the present invention.



FIG. 11 is a diagram depicting a virtual configuration of the software architecture of a gaming machine in accordance with an embodiment of the present invention.



FIG. 12 is a diagram depicting an extended virtual configuration of the software architecture of a gaming machine in accordance with an embodiment of the present invention.



FIG. 13 is a diagram depicting a number of Internet-ready, specialized devices coupled to an APVU, according to an embodiment of the present invention.



FIG. 14 is a diagram depicting partial processing by central server(s) 112 in accordance with an embodiment of the present invention.



FIG. 15 is a diagram depicting a central server system, according to an embodiment of the present invention.



FIG. 16 is a diagram depicting processing of gaming machine functions by PCs within a central server system, in accordance with an embodiment of the present invention.



FIG. 17 is a diagram depicting each remote gaming machine connected to an individual PC or computer server located within a central server system 112, in accordance with an embodiment of the present invention.



FIG. 18 is a diagram depicting a central server system that includes a server farm for performing operating system and applications boot to the individual PCs of a central server from a central storage facility, in accordance with an embodiment of the present invention.



FIG. 19 is a diagram depicting a simplified Plug and Play protocol, in accordance with an embodiment of the present invention.



FIG. 20 is a diagram depicting asynchronous notification of events, in accordance with an embodiment of the present invention.



FIG. 21 illustrates a view of the service based gaming system according to an embodiment of the present invention, including a plurality of nodes arranged such as to offer one service publisher and multiple service subscribers.



FIG. 22 illustrates a view of the service based gaming system according to an embodiment of the present invention, including a plurality of nodes arranged such as to offer multiple service publishers and one service subscriber.



FIG. 23 illustrates a view of the service based gaming system according to an embodiment of the present invention, including a plurality of nodes arranged such as to offer multiple service publishers and multiple service subscribers.



FIG. 24 illustrates a view of the service based gaming system according to an embodiment of the present invention, including a plurality of nodes, wherein each node is arranged such as to offer a one service publisher, multiple service publishers, one service subscriber and/or multiple service subscribers.



FIG. 25 illustrates a view of the service based gaming system according to an embodiment of the present invention, including a plurality of nodes, wherein each node is arranged such as to offer one service publisher, multiple service publishers, one service subscriber and/or multiple service subscribers and wherein the communication network is pictured as a service bus that may include loosely coupled and/or tightly coupled nodes.





DETAILED DESCRIPTION OF THE INVENTION

Reference will now be made in detail to the construction and operation of preferred implementations of the present invention illustrated in the accompanying drawings. The following description of the preferred implementations of the present invention is only exemplary of the invention. Embodiments of the present invention are not limited to these implementations, but may be realized by other implementations.



FIG. 1 illustrates a gaming system 100 according to an embodiment of the present invention. The system 100 may include a plurality of gaming machines 200, 300; one or a plurality of gaming machines clusters 106 located in the same site or in geographically dispersed locations; a plurality of Payment Verification Units 500 (hereafter, “PVU”), at least one such PVU 500 being associated with each gaming machines cluster 106, and one or more central server(s) 112. Instead of or in addition to the PVU 500, a compact PVU 600 (FIG. 6) and/or an automated PVU or APVU 700 may be associated with individual gaming machines 200, 300 and/or cluster(s) 106. The clustering of gaming machines may be carried out according to geographical location, type of gaming machine, regulatory requirements, type of application and/or any criteria for grouping the gaming machines in a physical or logical cluster 106. The gaming machines 200, 300, PVUs 500, 600 or 700 and central server(s) 112 are networked together within a wide area network 102 (which may include, for example, the Internet).


The gaming system 100 may further include one or a plurality of entertainment machines. Alternatively, the entertainment machines 400 may be substituted for all or some of the gaming machines 200, 300. Within the context of the present inventions, gaming machines 200, 300 include machines that enable the player to plays games of chance while entertainment machines 400 include machines that enable the player to play games of skill, to watch entertainment materials or to even participate in interactive entertainment sessions with groups of players or other individual players. Monetary payouts from games of skills and entertainment machines 400 are usually illegal and prizes may commonly be awarded in the form of longer play sessions or ranking into a higher skill level.


Central server(s) 112 may be located on the same premises as the gaming machines 200, 300, entertainment machines 400 and PVUs 500, 600, 700 or elsewhere. A plurality of servers 112 may be used in various configurations. For example, the server(s) 112 may be located on same premises for fault tolerance backup, located on different premises for disaster tolerance backup, located on same or different premises for load balancing and/or configured in a hierarchical structure, whereby a hierarchically-higher server 112 provides consolidated services for one or a plurality of hierarchically-lower servers 112.



FIG. 2 illustrates a gaming and identification verification machine 200 that accepts and redeems cash. It is to be understood that the gaming machine 200 is but one possible implementation of such gaming machines and that embodiments of the present invention are not limited thereto. Indeed, the system 100 may include any mix of any gaming and/or entertainment machines of most any kind. The gaming and identification verification machine 200 may include a display 202, a coin acceptor 204, a banknote acceptor 206, a coin hopper 210, a gaming machine identification (hereafter, “ID”) device 212 and a plurality of user interaction means 208, which may include buttons, trackballs and/or joysticks, for example. The gaming machine ID device 212 is commonly used for identifying players that subscribe to a loyalty program to benefit from advantages and promotions offered by the gaming operator. FIG. 3 illustrates an exemplary cash-less gaming machine 300 that does not accept or redeem cash. It is to be understood that the gaming machine 300 is but one possible implementation of such a cashless gaming machine and embodiments of the present invention are not limited thereto. For cash-less operation, a gaming device ID device(s) 304, 306 is/are necessary. The gaming machine ID device 304, 306 may include a magnetic card reader, a SmartCard reader and writer, a barcode reader, a ticket printer, a biometric reader, a touch-screen, keyboard or keypad to enable players to enter a PIN (Personal Identification Number) and/or a “Pay” button. The gaming machine identification device 304, 306 may further include an ID token reader to read other forms of advanced ID devices such as ID buttons, ID key-chains (such as disclosed, for example in commonly assigned US design patent entitled “Personal Communicator and Secure ID Device” U.S. Pat. No. D441,765 issued on May 8, 2001) as well as secure communication means for securely communicating with, for example, personal wallets, hand held PCs or computer wrist-watch via infra red, magnetic field, capacitive charges or RF (BLUETOOTH, IEEE 802.11 communication protocols, etc.) for player identification purposes. According to one embodiment of the present invention, a player initially establishes a player account with the central server(s) 112 and receives a player ID card or ID token bearing the player's account number and other relevant information. Alternatively, gaming machine 200, 300, may include a printer 314 (FIG. 3) to provide the player with a printed ticket 312 including a human and/or a machine-readable ID code. Alternatively, the printed ticket 312 may be provided by the PVU 500, 600 or 700 and read by the gaming machine 200, 300 via a ticket reader 316. Alternatively still, the player may register a biometric feature such as fingerprint, voiceprint and/or face print, and a PIN to be entered whenever confirmation of identity is required. All of these ID devices may allow the player to remain anonymous; in that case, the player's personal information is not requested and the assigned or chosen ID is associated with a numbered account instead of a personal account. Wager debits and prize credits are controlled by the central server(s) 112. Players may redeem any account balance by pressing the “Pay Button” (which may halt the current gaming session) and by claiming the funds from a cashier that is connected with the central server(s) 112. A machine coded (e.g., bar coded) printed ticket 312 may be generated by the gaming machine 200, 300 as additional means for claiming the funds or to begin a new game session on another gaming machine 200, 300 by causing the ticket reader 316 of the other gaming machine 200, 300 to scan the machine code on the printed ticket 312.


Electronic purses such as those based on the SmartCard technologies may also be used, either in on-line or off-line modes, although off-line operation is to be avoided to preclude latent and under-the-radar fraud, especially from inside employees.



FIG. 4 illustrates a cash-less entertainment machine 400 including the following identification and payment means: a magnetic card reader or a SmartCard reader/writer 404, a ticket printer 412 for printing a ticket 410, a touch-screen 402 (and/or a keyboard or keypad) to enter a Personal Identification Number “PIN” and one or more buttons 406, 408, at least one of which may be a “Pay” button. It is to be understood that the gaming machine 400 shown in FIG. 4 is but one possible implementation of such an entertainment machine and that embodiments of the present invention are not limited thereto. The entertainment gaming machine 400 may further include a biometric reader such as voice recognition (for example), to enable media-less identification means. The entertainment machine 400 may be configured for cash-less and/or for cash payment. Such entertainment machines 400 may have more than one screen, may allow for 3D, 360-degree vision and/or immersive vision, may include advanced interactive controls, force feed-back, motion feed-back, motion control, immersive sound and/or any technology that enhances the player's entertainment sensory experiences.


Moreover, the entertainment machines 400 and/or gaming machines 200, 300 may further include a video camera to allow for face-to-face action, face ID recognition, creation of avatars (movable three-dimensional images that may be used to represent a person or part thereof—such as a head—in cyberspace) and the like. Incorporating functionality for identifying players based upon recognition of their facial features in the entertainment machines 400 and/or the gaming machines 200, 300 would allow any pre-registered person to be immediately greeted and his or her account retrieved as soon as he or she stands by the entertainment machine 400 and/or the gaming machine 200, 300. Alternatively still, entertainment machines 400 may enable the player to participate in a game of chance while offering the player a superb multimedia and sensorial experience.


Because of the technical similarities and potential functional overlap between gaming machines 200, 300 and entertainment machines 400, the term “gaming machine”, as used herein below will collectively refer to both gaming machines 200, 300 and entertainment machines 400 and/or any variant or combinations thereof.



FIG. 5 illustrates a payment verification unit or PVU 500, according to an embodiment of the present invention. The PVU may include a computer 502 connected to the network 102 with the gaming machines and/or the central server(s) 112 and a ticket printer 504. The ticket printer 504 may include an integrated printer for printing tickets or receipts 506 that include a human and/or machine readable code imprinted thereon and code reader 508 for reading the code(s) imprinted on the ticket 506. The PVU 500 may also include, for example, a magnetic card reader 510, a SmartCard reader 512, a biometric reader 514 (such as a fingerprint reader, for example), a display 520 and input devices such as a keyboard 518 and/or a mouse 516.


When a player wishes to redeem the credit available in his or her account, the player may consult a nearby cashier equipped with a PVU 500 who may identify the player's account using one of the ID media provided by the player, query the central server(s) 112 for payment authorization, and proceed with payment. When processing the payment authorization, smart pattern analysis software may be used to detect possible fraud resulting from counterfeiting whereby (for example) the player would deposit some cash funds for credit to his or her account, play very small wager amounts then claim the totality of the balance at another cashier. In that case, there is a high probability that the coins or notes remitted by the player may be counterfeits or originate from suspicious origin. The PVU 500 may also be used for crediting the player's account when the player remits cash to play on one of the cash-less gaming machines.



FIG. 6 illustrates a compact version of the PVU 500, according to another embodiment of the present invention. The PVU 600 may include an enclosure 602, a data display 616 (which may include a touch screen), a magnetic card 606, a smart card reader 608, a printed ticket exit 612 through which a printer (internally mounted, not shown) dispenses printed tickets or receipts, an optical reader 610 and/or a speaker 604, for example. The optical reader 610 may include a barcode reader or most any machine vision system. The printer and the optical reader 610 may draw, for example, from aspects of the printers and scanners disclosed in commonly assigned U.S. Pat. No. 6,710,895, issued Mar. 23, 2004, and/or U.S. Pat. No. 6,732,920, issued May 11, 2004, both patents of which are hereby incorporated herein by reference in their entireties.



FIG. 7 illustrates an embodiment of an automated PVU or APVU 700, which dispenses with the need for a human cashier. The APVU 700 may include an internal computer connected to the network 102 with the gaming machines and/or the central server(s) 112, a coin acceptor 722, a note acceptor 720, a coin dispenser/hopper 718, a SmartCard or magnetic card dispenser 704, a note dispenser 714, a ticket printer 710 for printing a ticket 712, a magnetic card reader 702, a SmartCard reader/writer 706, a barcode reader 708, display with touch-screen 726, a keypad 724, a video camera 728 and/or a UL 291 certified cash safe 716, for example. The UL 291 certified cash safe 716 prevents robbery of the cash stored inside the APVU 700. The APVU 700 may further include biometric ID readers, ID token readers to read other forms of advanced ID devices such as ID buttons, ID key-chains, etc. as well as secure communications means for communicating with personal wallets, hand held PCs or computer wrist-watch via infra red, magnetic field, capacitive charges or RF (Bluetooth, IEEE 802.11, etc.) for identification purposes.


When a player wishes to redeem the credit available in his or her account, the player may consult a nearby APVU 700 or “smart-cashier” who will identify the player's account using one of the ID media provided by the player, query the central server(s) 112 for payment authorization, then proceed with cash payment via the coin hopper 718 and note dispenser 714, for example. When processing the payment authorization, smart pattern analysis software may be used to detect possible fraud. The APVU 700 may also allow the player to credit directly his or her account by remitting cash via the note acceptor 720, the coin acceptor 722 or alternatively via Electronic Fund Transfer (“EFT”) with his or her bank account, to play one of the gaming machines. Any of the ID media may be used to allow the player to play on any of the gaming machines connected to the network 102.



FIG. 8 illustrates a typical tightly coupled configuration that may be used with the present gaming machines. The gaming machine main processing platform may be built on a PC or equivalent hardware platform 801 that communicates with the central server(s) 112 and the PVU 500, 600, 700 via a network link. In addition to the PC platform, operating system, low level software, power supply, the main enclosure and any physical intrusion security, a gaming machine according to an embodiment of the present invention may include payment and identification devices, high-level application software modules, network communication means for enabling the gaming machine to exchange data with external devices (such as the central server(s) 112 and the PVU 500, 600, 700). The present gaming machine may also include an internal true RNG 808 (Random Number Generator) or means for receiving random combinations via the network 102 from external devices.


A hardware RNG is extremely desirable in order to ensure maximum entropy of encryption of the secret keys such that the encrypted keys are formed of true random bits, thereby rendering a brute force attack thereon to its maximum theoretical level of difficulty. An embedded true RNG based on diode noise, for example, enables systematic use of the highest encryption strength for the encryption algorithms and key length allowed by government. Flaws in RNGs and badly chosen encryption keys are responsible for highly publicized cracked systems. Although 128-bit encryption such as RSA, 3DES, etc. requires a considerable theoretical computer power to crack, a badly chosen encryption key may result in the secret keys being cracked within hours. There is a need to provide the gaming machines and external sources of random numbers coupled to the present gaming machines with almost “Military Defense Class” security. Virtual private Networks (VPNs), Secure Socket layer (SSL) and other secure communication protocols that rely on locally generated encryption keys are solutions that are widely available today. The resilience of such encryption protocols to attack depend on the quality of the encryption keys or their maximum entropy, such as discussed in Schneider, Secrets and Lies: Digital Security in a Networked World, Wiley & Sons, Inc. ©2000, pages 102-106, which is incorporated herein by reference.


The present gaming machine may also include one or more player video displays 802 driven directly by a multimedia controller within the gaming machine or driven externally thereto, one or more non-video displays 804 such as status indicators, digital indicators, mechanical indicators, blinking lights illuminations and the like and one or more player interactive controls 806 such as a one-arm bandit handle, push-buttons, trackballs or a joystick. As shown, the payment and identification devices of the present gaming machines may include a coin acceptor 810, a coin dispenser or hopper 812, a bill or note acceptor 814, a bill dispenser 816, a smart card reader and writer 818, a smart card dispenser 820, a bar or other machine readable code reader 822, a ticket printer 824, a magnetic card reader 826, a biometric ID reader 828 and/or other devices, generically referenced at 830. The payment and identification devices may advantageously be coupled to the platform 801 via RS232/RS485 or similar connections.


The payment and identification devices listed above are collectively referenced herein as “specialized devices” herein below and may not all be present in a given gaming machine configuration. For example, a gaming machine may only be configured for cash-less payment using voice ID; in that case, only a microphone and touch-screen (and/or display and keypad) need be present. Moreover, the list of specialized devices above is not limitative, as new specialized devices may become available such as interfaces with personal wallets, contact-less smart cards or ID tokens, for example. Any such specialized devices may readily be incorporated within the present gaming machines. It is to be noted that the purpose for listing a significant number of specialized devices is not to recommend equipping gaming machine with each listed specialized device, but rather to teach the benefits of designed-in modularity, as is discussed in detail herein below. Furthermore, the same architecture may be advantageously applied to the APVU 700 (Automated Payment Verification Unit or Smart-Cashier).


In legacy gaming machines, the connection between specialized devices and the processing hardware is rather ad-hoc, as a wide variety of interfaces are encountered such as RS232, RS422, Parallel, via dedicated add-on board, etc. More recent specialized devices are now capable of providing a Universal Serial Bus (“USB”) interface. However, all of these devices require that special software (software device drivers) that understands the inner characteristics of the hardware be developed. Software device drivers are well known to be difficult to develop and to introduce computer instabilities and limitations, especially when there is a large number of devices that may give rise to resource sharing conflicts.


As shown in FIG. 8, the high-level software application modules for a gaming machine according to an embodiment of the present invention may include an audit engine 832, an authentication engine 834, a business engine 836 and/or a video entertainment/game engine 838. The audit engine 832, as a passive observation layer, transparently intercepts all the important events and all regulatory critical parameters associated with the operation of the specialized devices such as cash/cash-out or submitted identification information, the serial numbers of all connected devices and generates a non-modifiable reference audit log 840 that may consulted by the central server(s) 112 or the PVU 500, 600, 700. In addition, the audit engine 832 compares all devices connected to the gaming machine with a map of authorized regulatory configurations and may alert responsible personnel and/or regulators whenever non-valid device configurations are encountered, such as may occur after replacing devices or relocation of the gaming machine. The audit engine 832 may include instantly accessible non-volatile data storage, which data storage may be locally or remotely located (accessible via network 102). This would allow resolving data coherence and correctness in case of power failure, interruption, virus infection and/or software crash so as not jeopardize the accuracy of the game record keeping. For example, the audit engine 832 allows resolving conflicts wherein a record indicates a win and a payout amount although a power interruption has prevented the full payout from occurring. Moreover, the audit engine 832 may keep very specific accounting data as required by a given jurisdiction to meet locally applicable gambling regulations. For example, the audit engine 832 may keep a log of each drawn random number combination for audit purposes.


The audit engine 832 may keep audit trails separately for all of the different forms of monetary value that may be accepted by modern gaming machines such as, for example, audit trails of all wagers found in the coin and currency cash boxes. In gaming machines equipped with coupon readers, audit trail of the currency box may contain bar coded coupons of varying amounts in addition to cash. In the case of cashless wagers (e.g., those placed from player charge accounts or using some form of electronic money), as there is no currency in either of the coin or currency cash boxes, the audit trail may include relevant information exchanged during the player identification process, retrieval of the balance held in the central server(s) 112, the wager debits and the prize credits, for example.


The authentication engine 834 may include functionality to consult a Certificate Authority (which may be located on a server on the network 102 or on a computer network connected thereto), certify the authenticity of the identification presented, authorize a given operation, ensure data integrity of data exchanged, securely time-stamp the operation (to ensure non-repudiation of the operation) and/or revoke illegal identifications, for example.


The business engine 836 handles the games rules and the associated bookkeeping and may be subject to regulatory requirements. The business engine 836 handles the business aspects of the game and/or entertainment provided, controls wagers and maintains the prize matrix. This software application module customarily requires extensive testing by an independent laboratory to receive the certification mandated by local regulatory requirements. The regulatory requirements essentially insure that funds are reliably disbursed to legitimate players and insure that funds are not acquired by other individuals because of flaws, cheating and/or stealing.


The business engine 836 may include a transaction engine 842 for online operation with the central server(s) 112. In the case of game of chance, the video/entertainment/gaming engine 844 receives the current draw from one or more random number generators 808 located inside the gaming machine or outside the gaming machine (see reference numbers 902 and 904 in FIG. 8), in accordance with local regulatory requirements. In case of games of skills, the gaming engine 844 receives the bonus from the business engine 836 in accordance with a given skill strategy, which may also require certification by a regulatory body and compliance with local regulatory requirements. An example of skill strategy may be rapidity, precision, ability to reach a given score, intelligence, memory, ability to focus on critical events amongst less critical events, etc. The business engine 836 may have received the applicable regulatory certification as illustrated by the star-shaped stamp 846.


The video/entertainment/game engine 844 communicates with the business engine 836 to translate the business rules into an attractive interactive experience for the player. Indeed, the video/entertainment/game engine 844 handles the player user interface, the multimedia interactive and entertainment and game graphics, sound, motion feedback and video streaming. The video/entertainment/game engine 844 may include a library 838 that offers a variety of entertainment multimedia, game multimedia and video streaming to suit the player's taste and expectations, as well as to accommodate a given strategy formulated by the game operator. For example, the engine 844 and library 838 may implement the methods and systems disclosed in commonly assigned U.S. Pat. No. 6,921,331, issued Jul. 26, 2005, which patent is hereby incorporated herein by reference in its entirety.


The central server(s) 112 provides on-line control of the gaming machines, the PVU 500, 600 and APVUs 700. An advantageous embodiment of the present invention is for the central server(s) 112 to instantly capture all the critical events occurring within the entire gaming system 100, including for example when each coin is inserted in the coin acceptor 810, noting its value as well as each coin rejection event. Further operation of the gaming machine may be prevented upon failure of the network 102. This principle is the basis of operation of large lottery systems, whereby thousands of terminals are deployed in remote areas. Such a model has proven to be extremely successful at avoiding fraud, including fraud committed by employees having access to sensitive data such as program source code. Performance is not an issue, as central server(s) 112s may use a farm of Intel Pentium® (for example)—based servers and a transactional protocol such as described in commonly assigned application Ser. No. 09/862,165, filed May 21, 2001, which application is hereby incorporated herein by reference in its entirety, may handle tens of thousands of transactions per second with a guaranteed latency for each individual transaction no greater than 200 milliseconds.



FIG. 9 illustrates a modular configuration that may be applied to a gaming machine according to an embodiment of the present invention, in which the gaming machine includes the same elements as described above but arranged in a modular fashion with their software Application Programming Interfaces or APIs clearly identified. Moreover, Secure APIs or S-APIs are also employed when data and programming security are essential. As represented in FIG. 9, the constituent elements of the present gaming machines communicate with one-another only via their associated APIs or S-APIs.


It is to be noted that APIs not only define the exchange of information between the adjacent modules but also define how one module may provide services that may be consumed by the other. In this manner, one module may be made to control another module.


The specialized devices may be configured to possess the necessary embedded processing resources to control the entire operation of the device and to communicate with high-level application software via a clearly defined API or S-API. In FIG. 9, the capability to control the hardware is represented by the elements named “Driver”; consequently, the low level details necessary to operate the specialized device are not made available to the high-level software module. According to embodiments of the present invention, the device drivers may form part of the embedded software of the specialized devices or may form part of the software of the platform 801 (such as a PC or other computing platform), so as to offer an API to the audit engine 832. Each specialized device may also be configured to supply its identity to the central server(s) 112; this is represented by the element named “ESN”, which is an acronym for Electronic Serial Number. It is advisable to rely on secure means of authentication that may cooperate with the authentication engine 834 to ensure that the ESN is not associated with an illegal specialized device. Embodiments of the specialized devices may include secure ESN (secure serial numbers) that may be seeded with, e.g., a X509 certificate or a secret private key via a configuration step such as embedded smart card modules and TPM (Trusted Platform Module of the Trusted Computing Group). The authentication engine 834 may advantageously maintain a registry of authorized devices and may dispatch alerts to prevent illegal devices from operating. The player video displays 802, other player displays 804 and player interactive controls 806 are preferably modular devices capable of communication via a clearly defined API. Moreover, the audit engine 832 may read and record the serial numbers of each device connected to or coupled with the gaming machine.


According to embodiments of the present invention, some or all of the specialized devices may have their hardware aggregated such as to present only one coupling interface. For example, video displays 802, non-video displays 804, interactive controls 806 and card reader 818 may be aggregated into a single specialized device mounted in, on or coupled to the gaming machine. For example a player tracking device running WINDOWS CE operating system may be loosely coupled via the communication network to a high-level software module running in the central server, the high-level software module implementing a player tracking management function.



FIG. 10 shows another configuration of a gaming machine according to another embodiment of the present invention, showing how components once having a clearly defined APIs may be controlled instead by components via a LAN (Local Area Network) and/or a WAN (Wide Area Network) 1002 via Remote Procedure Calls “RPCs.” A more modern control model is object-oriented, whereby a module may offer network services for consumption by other modules. Widely used standards for such object-oriented models include, for example, Distributed Common Object Module (“DCOM”, developed by Microsoft Corporation) and Simple Object Access Protocol “SOAP”, a vendor independent protocol based on eXtensible Markup Language (“XML”).


SOAP forms the foundation layer of the Web services stack for providing a service oriented messaging framework, featuring a basic messaging framework that more abstract layers can build on. SOAP is a protocol for exchanging XML-based messages over computer networks using the HTTP/HTTPS stack, notably the following two methods: HTTP-request (or GET) and HTTP-response (or POST). There are several different types of messaging patterns in SOAP, but by far the most common is the RPC pattern, in which one network node (the client) sends to another node (the server) a request message for a service to be provided (the request may contain input parameters), and the server subsequently sends to the client a response message containing the return (which may contain output parameters) in accordance with the provided service. A node is a device that is connected as part of a computer network. For example, a node may be or include a computer, a personal digital assistant, a cell phone, a router, a switch, a hub, a server, a workstation, a handheld PC, gaming machine, specialized device or ATM.


SOAP is the successor of XML-RPC. SOAP originally stood for Simple Object Access Protocol, and lately also Service Oriented Architecture Protocol, but is now simply SOAP. The SOAP specification is currently maintained by the XML Protocol Working Group of the World Wide Web Consortium. SOAP is encapsulated in the Microsoft WCF—Windows Communication Foundation available in “.NET Framework 3.0” and later versions.


In a preferred embodiment, abstract layers may be build on SOAP for providing a service oriented architecture (SOA) such as a game service bus, whereby the game service bus provides a publish-and-subscribe message bus. A bus, according to embodiments of the present invention, is a service messaging engine based on, for example, standards such as SOAP, RPC, Microsoft Remoting, CORBA, RSS and/or Microsoft WCF (Windows Communication Foundation of .NET Framework 3.0).


The game service bus according to embodiments of the present invention provides high level applications and specialized devices with a uniform set of mechanisms for negotiating service messages on the communication bus such as naming, discovery, message routing, publish and subscribe eventing, message transformations, workflows, communication recovery from nodes powering-off then on again, and so on. The game service bus may be deployed within a casino property via private Intranet or across casino properties via public Internet (using secure communication means such as VPN, SSL or IPSec, for example). MICROSOFT “Biztalk Services” (www.biztalk.net) may advantageously be used to quickly deploy a service bus across properties. Biztalk Services is an Internet Service Bus, i.e. a fabric that interconnects distributed applications.


The service bus framework (or fabric) allows participating communicating end points (or nodes) to publish services or subscribe to services in a simple high level fashion, enabling the devices to understand one-another, thus to “talk” to one another. The “talking together” paradigm is rather appropriate as it emphasizes the value that the service bus brings to a complex distributed casino gaming system that may include thousands of devices manufactured by dozens of vendors.


According to an embodiment of the invention, a casino progressive Jackpot server may advantageously be built on the game service bus framework, whereby the progressive Jackpot is a service provider to gaming machines that subscribe to the services offered by the Jackpot service provider. The jackpot grows progressively as each spin/hand played on a connected gaming machine adds a small credit to the running jackpot total. Several casinos may join together to form an inter-casino progressive jackpot that can generate very large sums. In this example, a progressive Jackpot high level application service may be hosted on a server and published across the network. Each participating gaming machine may subscribe to the published progressive Jackpot service, may contribute to the jackpot at every spin/hand played and may claim the jackpot if the winning jackpot combination is drawn.


According to embodiments of the present invention, each gaming machine may publish its accounting meters via the game talk service bus and then authorized management servers, workstations, mobile handhelds and peer gaming machines may register to receive all or a subset of the accounting meters each time they are updated, at a predetermined interval or upon the occurrence of a predefined event, for example.


The ticket printer in each gaming machine may, according to further embodiments of the present invention, publish its printing services via the game talk service bus. Authorized management servers, workstations, mobile handhelds and/or peer gaming machines, for example, may then register to print a ticket. For instance, a promotional central server may print a free meal ticket for the player currently playing on the gaming machine he or she is currently playing on, either as a random bonus, or because the play profile of the player meets predetermined criteria for the awarding of such a meal ticket. Likewise, a floor manager carrying a wireless mobile handheld and observing a player may print on the player's gaming machine printer a free trial coupon for a new game that has just been released and that may suit the player's playing style, style as observed by the floor manager.


According to further embodiments of the present invention, a central logistic support server may subscribe to the printers' services (a printer being installed in each gaming machine) for a paper low or paper jam alert, and the technician closest to the gaming machine having the necessary repair skill or paper supply may receive instantly an SMS message on his location-finder equipped mobile phone to attend to the problem. The central logistic support server and the location-finder equipped mobile phones may be supplied by a third-party vendor specialized in automated geo-localized logistic support or geo-localized services for large factories, such as car manufacturing plans, airplane manufacturing plans, airports, harbor facilities, for example. The central casino management system may also subscribe independently to the printers' alerts for general accounting purposes.


Each gaming machine, according to still further embodiments, may publish player tracking services that (a) reads the player tracking card inserted in a card reader specialized device, (b) displays player tracking information on at least one of the player display (e.g. via a dedicated video display, via pop-up overlapping windows over a player video display, via a sliding overlapping windows over a player video display, via alpha-blended outlined data, icons or sprites over a player video display, or any other mechanisms to overlay information over a player video display), and (c) interacts with the player (e.g. via a touch-screen, a keypad, a pointing device, a joystick, biometric input). A central player tracking management system (that may advantageously leverage on intelligence data retrieved from the casino property hospitality network and servers) may subscribe to the player tracking services (offered on each gaming machine) in order for the central player tracking high level applications to interact directly with a player at the gaming machine.


According to an embodiment of the invention, client-side player tracking services may be offered by a specialized device including, for example, (a) an embedded computer controller running Windows CE, (b) a touch-screen video display, (c) a card reader (or any other means of player identification such as smartcard reader, PIN entry, pseudo+password entry, biometric identification, etc.), (d) a network interface for communicating over the game talk service bus and (e) controlling software to provide the client-side player tracking software services.


In a service oriented architecture such as SOAP, IBM SOA and a game service bus, the term publishing a service (or services) encompasses within its scope the functionality of providing a service (or services), and the term subscribing to a service (or services) encompasses within its scope the functionality of consuming or invoking a service (or services). The binding term is associated with the capability for allowing the publisher/provider to perform an asynchronous callback to the subscriber/consumer when a subscribed service (or services) is/are available (data update for example). The term publishing a service (or services) includes within its scope the functionality of exposing a service (or services).


In a service oriented architecture (based on SOAP, CORBA, IBM SOA and Web-services, for example), services may be discovered using service discovery protocols. Service discovery protocols are network protocols which allow automatic detection of devices and services offered by these devices on a computer network. There are many service discovery protocols including, for example, DNS Service Discovery (DNS-SD), Service Location Protocol (SLP), Simple Service Discovery Protocol (SSDP) as used in Universal Plug and Play (UPnP), Universal Description, Discovery and Integration (UDDI) for Webservices, JINI for JAVA objects, BLUETOOTH Service Discovery Protocol (SDP), WS-Discovery (Web Services Dynamic Discovery), Internet Storage Name Service (iSNS), Web Proxy Autodiscovery Protocol and Dynamic Host Configuration Protocol, to name but a representative few.


At least the high-level engines 832, 834, 836, and 844 may communicate with the central server(s) 112 and/or the PVU 500, 600, 700.


The RNG (random number generator) located within the gaming machine 808 preferably behaves in the same manner as a specialized device and, therefore, has the same networking, API and secure communication characteristics, requirements and behaviors. The gaming machines may selectively receive random numbers for the game draw from different sources 902904 to accommodate the various regulatory requirements mandated by given states or given countries. As represented in FIGS. 8 and 9, the sources for such random numbers may be internal to the gaming machine as shown at 808 (wherein the RNG is configured as a specialized device), may originate from a RNG generator 902 internal or coupled to the PVU 500, 600 or APVU 700 and/or from a RNG generator or generators 904 internal or coupled to the central server(s) 112. According to one embodiment of the present invention, a RNG generator may be provided for each gaming machine 200, 300, 400, each PVU 500, 600, 700 and for each central server 112. For example, a single or a plurality of RNG generators 904 coupled to the central server(s) 112 may provide random number combinations to a large number of geographically distributed gaming machines. Also, a single or multiple RNG generators 902 coupled to the PVU 500, 600 or APVU 700 may provide random number configurations for selected gaming machines at a single location, within a cluster 106 and/or to several clusters 106, as shown in FIG. 1. This configuration offers a great degree of flexibility and allows the present gaming system to meet most any applicable regulatory requirement relating to the RNG generators.


It is to be noted that all the modern technologies for offering network services and consuming network services via wired or wireless networks have very high security protection using advanced security techniques such as authentication, encryption, Secure Sockets Layer (“SSL”), Public Key Infrastructure (“PKI”), Kerberos, True Random Number Generators (for generating secret keys with maximum entropy), hopping keys (constantly changing keys), 128-bit Wired Equivalent Privacy (“WEP”) algorithm, etc. In addition, a Virtual Private Network (“VPN”) tunnel may be used for secure inter-module communication. For example, a VPN tunnel may be established between the bill dispenser 816 specialized device and the central server(s) 112, or one or more software modules located on the central server(s) 112. A preferred embodiment of the present invention is to use the IPSec communication encryption standard that can be conveniently applied as a system wide policy.


Moreover, a “Network Access Point” component 1004 may be introduced that simply allows the APIs of the specialized devices to be directly supported and controlled over the network 102, 1002. These Network Access Points 1004 are sometimes called “IP Converters”. Examples of such network access points or IP converters include the USB to Ethernet converter from Inside Out Networks (www.IONetworks.com) and the RS232 to Ethernet from Moxa Technologies (www.moxa.com). Ideally, an Ethernet interface would be directly embedded on processing hardware that controls the specialized device.


An embodiment of the present invention includes the use of the IP protocol for intercommunication between each of the modules shown in FIG. 9. Other existing or future protocols may also be used such as, for example, IPX from NOVEL; however, the IP protocol is universally used for the Internet and many communicating products and components support it. The payment and identification devices may be coupled to the Network Access Point or IP Converter 1004 by an RS232, RS485, USB, I2C, 802.11, BLUETOOTH, Ethernet, FIREWIRE or most any standardized interface.


An embodiment of the present invention includes automatic binding of specialized devices with the central server(s) 112 following their activation for example after power-on or reset. FIG. 19 shows a simplified diagram wherein a specialized device coupled to the central server(s) 112 by network 102 sends, following its activation, broadcast packets over the network 102 indicating its availability. The broadcast packet may contain data identifying the specialized device and describing its location and capabilities. The server 112 that needs to communicate with this specialized device then enters into a binding protocol in order to establish bi-directional communication. A preferred embodiment for the automatic binding is the Universal Plug and Play standard proposal led by Microsoft, although other binding protocols may be used.


According to another embodiment of the present invention, the specialized devices may be configured to offer asynchronous notification of events directly to the central server(s) 112 over a communication network, such as shown at 102, for example. FIG. 20 shows a simplified diagram wherein a specialized device, coupled to the central server(s) 112 by a network, sends asynchronous notifications packets to the central server(s) 112 following an event being received by the specialized device or an event generated by the specialized device. For asynchronous notification of events, the server(s) 112 may register (subscribe) with the specialized devices for the list of events that are of interest. Then, the event notification process running in the specialized device may produce a call back to the server(s) 112 (thus the name callback) in order to pass details on the event information when it occurs. A mechanism to un-register (unsubscribe) may be provided wherein the server(s) may inform the specialized device to stop sending asynchronous notification of events. A preferred embodiment of the asynchronous notification of events is the callback feature of COM+, DCOM, REMOTING technologies from MICROSOFT and the callback capability of SOAP, although other technologies may be implement within the context of embodiments of the present invention.



FIG. 11 shows another embodiment of the present invention, in which the present gaming system is network-centric. In FIG. 11, the network 1102 is the centerpiece thus allowing all the elements internal to as well as external to the gaming machine to interact with one another over the network 102. This wheel and spoke network topology brings great flexibility benefits, as detailed herein under, as it allows virtually any configuration to be chosen for assembling the present gaming machines. For example, the business engine 836 may be located within the gaming machine, within the PVU 500, 600, 700 or within the central server(s) 112. Likewise, the video/entertainment/games engine 844 may also be located within the gaming machine, within the PVU 500, 600, 700 or within the central server(s) 112. The same holds true for the audit engine 832. The video/entertainment/games engine 844 may support real time MPEG compression. For example, the broadband channel between the LAN/Wan 1102 and the video/entertainment/games engine 844 may accommodate video streams encoded using the MPEG4 compression standard (for example) at 100/1000 Mbits/sec, enabling high quality graphics and video to be rendered on the player video displays 802 of the gaming machine(s).


Moreover, the technologies for offering and consuming services over a network such as network 1102 work equally well without any network; consequently the high-level software modules may remain unchanged whether or not a network exists inside the gaming machine for inter-module communication. Thus, the same high-level software modules may be used whether the gaming machine relies on a tightly coupled configuration as shown in FIG. 8 or on a loosely coupled configuration as shown in FIGS. 10 and 11.


The flexibility to configure a gaming machine in a variety of ways and avoid modifying high-level software modules (especially certified modules) is immensely valuable for a company that produces gaming machines to the global market, as regulatory requirements vary significantly from country to country and from state to state. Moreover, a manufacturer may more readily leverage on advanced integrated software development platforms such as Microsoft .NET to promote significant re-use of code across the product line, accelerate development time, improve code quality, facilitate code maintenance and upgrade and reduce development cost.



FIG. 12 represents an extension of FIG. 11, in which the specialized devices are directly capable of network communication using, for example, technology developed for smart IP peripherals, according to a still further embodiment of the present invention. Smart IP peripherals are commonly called Internet Appliances. According to an embodiment of the invention, the specialized devices may each be controlled by a processor capable of supporting an operating system such as MICROSOFT WINDOWS CE, MICROSOFT Embedded XP or Embedded Linux; IP networking may be carried out via a wired or wireless link. With such advanced operating system, applications may be loaded from the network. Therefore, applications need not be stored locally within the specialized device, thereby avoiding software upgrade issues. Indeed, application software may be loaded into the gaming machines 200, 300, 400, any specialized device thereof from a remote server 112 and/or from a PVU 500, 600, 700. Similarly, application software may be loaded into the PVUs 500, 600, 700 and/or into any specialized devices therein from a remote server 112. Moreover, the entire operating system of the present gaming machine may be replaced over the network 1202. The operating system may be booted from the network 1202 using PXE (Preboot Execution Environment), for example.



FIG. 13 represents the APVU 700 equipped with IP-Ready specialized devices. These specialized devices are preferably interchangeable with the IP-Ready specialized devices that equip the present gaming machine. Therefore, the APVU's specialized devices may interact directly with the central server(s) 112 via network services, thus benefiting of the same advantages as the gaming machine. As shown, the APVU 700 may incorporate hardware and corresponding software modules for a microphone 1302, a sound system 1304, a video camera 728, a display 1308, a keypad 1310, an alarm system 1312, a active security system 1314 for the internal safe, a power supply 1316 and an Uninterruptible Power Supply (“UPS”). Network Services, as referred to herein, relate to service-oriented architectures such as MICROSOFT Microsoft DCOM, Common Object Request Broker Architecture (CORBA), MICROSOFT.NET and Sun JAVA 2 Platform, Enterprise Edition (J2EE), for example. MICROSOFT.NET and Sun J2EE are also commonly referred as “Web Services” and offer a universal solution over the Internet using XML, SOAP, Web Services Description Language (WSDL) and Universal Description, Discovery and Integration (UDDI) standardized technologies. UDDI nodes enables developers to publish web services and enables their software to search for and bind to services offered by others.


Network Services deliver loose coupling services between service requestors and service providers. Service requestors “consume” services provided by services providers. Publication of service descriptions play a central role to enable service requestors to discover available services and hind to them. The service descriptions allow service requestors to bind to the service provider. The service requestor obtains service descriptions through a variety of techniques, from the simple “e-mail me the service description” approach to techniques such as MICROSOFT DISCO and sophisticated service registries like UDDI.


Network services offer a network distributed objects/services infrastructure for transparent activations and accessing of remote objects/services. Objects are typically the EGD's peripherals such as a note acceptor, and the services are the functions performed by the peripheral that are accessible externally via the IP network such as the value of the banknote entered. The central server is typically a service requester. Peripherals are commonly service providers as well as service requestors (consuming services provided by the central server). In the same way, the central server is a services requestor and a services provider.


For embodiments of the present invention, MICROSOFT DCOM is a currently preferred technology, as DCOM support is already integrated into MICROSOFT WINDOWS CE and EMBEDDED XP, although embodiments of the present invention may be readily configured using other technologies, as those of skill in this art may appreciate. In the long term, MICROSOFT.NET web services over a private IP network (or VPN over Internet) may become the preferred technology, as it offers flexible and dynamic discovery of Net/Web services. The notion of a private or non-operator UDDI node is critical to the emergence of a dynamic style of a service-oriented architecture. As of this writing, Microsoft MICROSOFT has announced support of .NET web services in WINDOWS CE.NET.



FIG. 14 illustrates a possible configuration that leverages on a virtual configuration architecture in which partial processing may be carried out at the central server(s) 112 (i.e., the gaming machines 200, 300, 400, the PVUs 500, 600, 700 may offload all or a part of their processing to the central servers 112. In this case, the audit engine, the authentication engine and the business engine software modules 832, 834, 836 may be located externally to the gaming machines, such as in the central server(s) 112, noting that the modules securely interact with one another precisely via their APIs, as defined in FIG. 9. That is to say, the specialized devices located in the present gaming machine interact directly with the audit engine 832 located in the central server(s) 112 via network services. In the same manner, the video/entertainment/games engine 844 located in the gaming machine interacts directly with the business engine 836 located in the central server(s) 112. The specialized devices and the video entertainment/games engine 844 located inside the gaming machine do not communicate or interact with one another.


The advantages of the configuration described above include significantly increased data integrity (fully on-line system, fault/disaster tolerant central server(s) 112), significantly strengthened fraud control (fully on-line system, centralized audit log, centralized code execution, quality code, centralized authentication), significantly increased stability (server class operating system, quality code, fault tolerant central server(s) 112), immediate code upgrade capability, accurate and instantly available audit (all the gaming machine critical events are instantly logged in the centralized audit log 840). Moreover, the hardware necessary to support the execution the video entertainment/games engine software module may be a very economical yet extremely multimedia capable game console such as MICROSOFT XBOX® or SONY PLAYSTATION®, for example.



FIG. 15 illustrates the trend in server hardware to increase the processing power per square foot of floor space. As shown, computer cabinets are available in multiples of the standardized “U” size and 42U high cabinets are commonly used for computer servers. 1U-size “pizza box like” servers are very popular with Internet service providers, which form factor allows 42 computer servers to be stacked on top of one another in a 42U size cabinet, as shown at 1502. Already, computer suppliers are packing twice and even 4-times this density, whereby 2 and 4 computer servers are integrated in a 1U rack, thus offering 84 and 168 computer servers 112 per 42U cabinet, as shown at reference numerals 1504 and 1506, respectively.


An alternative to the 1U pizza size form factor servers is the “blade” size factor whereby a complete server 112 may be integrated on a narrow board or blade. One presently proposed configuration allows 9 (reference numeral 1508) or 10 blade servers to be logged into a 3U size rack as shown on the right side of FIG. 15. These racks may then be stacked, as shown at 1510. The complete server fits on a small board that may be very easily accessed for replacement or upgrade. Higher density dense servers are being developed that make use of very low power processing components such as fitted in laptops and hand held PCs, to help resolve the heat dissipation problem. It is to be noted that each of the servers discussed above may include a complete computer with CPU, memory, disk, network interface, and optionally full graphics. Large server farms that have on the order of 10,000 servers employ this type of dense server technology.


According to one embodiment of the present invention, each server shown in FIG. 15 corresponds to a central server 112 and may be associated with and connected to a remotely located gaming machine. Preferably, each server 112 shown in FIG. 15 is configured for multimedia graphics, generating 3D video and data streams encoded according to an MPEG standard, for example. In this manner, the central servers 112 may be constructed of an array of inexpensive servers, such as off the shelf PCs. Indeed, according to another embodiment of the present invention, the video stream shown to the player is generated (in MPEG4 format, for example) and streamed to the gaming machine over a broadband connection.



FIG. 16 illustrates another embodiment of the present invention in which the execution of all the high-level software modules may be carried out at the central server(s) 112, including the video entertainment/game engine module 844. For this, a high-speed network 1602 is required to bring the video signal to the gaming machine, which may then be fitted with a simple video receiver. Each remote gaming machine may be connected to and associated with an individual server 112 within the central server system or farm of server 112. Other player displays and interactive control may also be controlled directly by the central server(s) 112 via network services.


Suitable means of transmitting such a video signal to the present gaming machine may include, for example, cable or wireless TV, HDTV or digital TV broadcast whereby each gaming machine is tuned to receive a separate predetermined frequency corresponding to the image to be displayed to the player, high quality video streaming such as MPEG2, MPEG4, or other emerging digital video standards via Fast Ethernet such as 100 Mbps, 1000 Mbps and upcoming higher bandwidth protocols, a fiber optic network, a wireless network such as IEEE 802.11b (11 Mbps), 802.11a (54 & 72 Mbps @ 5 GHz), 802.11g (54 Mbps @ 2.4 GHz) and upcoming higher bandwidth protocols. It is to be noted that the means of video transmission and reception listed above, whether based on TV technology or media streaming technology, are already fairly economical and it is believed that the associated costs will continue to decrease rapidly.



FIG. 17 illustrates another embodiment of the present invention, in which a server (an individual PC, for example) located in a 42U Bay (for example) is associated with each gaming machine at the central server(s) 112. The server 112 associated with each gaming machine would then execute all or part of the software modules (audit engine 832, the authentication engine 834, the business engine 836 and the video entertainment/game engine 844) of the gaming machine. Interaction between the gaming machines and the central server(s) 112 is via network appropriate services as detailed above.


In particular, intensive video rendering to the player may be best if generated by an individual server at the central site and then the generated video signal may then be transmitted to the gaming machine. In this manner, there is considerable power to generate very advanced and attractive graphics for the player. Real-time translation to video streaming such as MPEG2 or MPEG4 may require hardware acceleration that may be carried out by a separate dedicated integrated circuit or alternatively may be directly integrated within the graphic processing unit of the server associated with the gaming machine.


Devices to receive high quality video information from the central server(s) 112, decode it and display it on a TV screen or a video display monitor are readily available. These devices use advanced electronic components developed for the latest generation Internet ready set top boxes and interactive TV systems. For example, such devices may be drawn from the devices and systems disclosed in commonly assigned application Ser. No. 09/932,282, filed Aug. 17, 2001, which application is hereby incorporated herein by reference in its entirety.


According to further embodiments of the present invention, each of the gaming machines may be configured to selectively offload computations to the farm of computer servers over the communication network. This may be done in a one-to-one manner whereby a computer server is entirely allocated to a given gaming machine, in a one-to-many manner whereby several computer servers are allocated to one gaming machine, or in a many-to-one manner whereby one computer server is allocated to several gaming machines.



FIG. 18 shows another embodiment of the present invention in which the operating system and/or applications of each server 112 (collectively referenced by numeral 1806) may be booted from a central data storage such as a Storage Area Network (SAN) device 1804 coupled to the network 1802. This approach is commonly used for large server farms, as it enables each server 112 to obtain the same software image from a central repository (SAN 1804). Consequently, software upgrades are immediate. The PXE (Preboot Execution Environment) standard may be advantageously adopted to enable booting of the operating system within each of the server computers 112 via the network 1802. In this manner, each server 112 boots and loads the same software image from a centralized network accessible storage 1804.


The video rendering and distribution approach described above whereby the intensive graphics operations are performed at the central server(s) 112 has considerable benefits for the gaming machines, notably:

    • a. Low cost computer hardware (no CPU intensive graphics operation, no expensive graphics accelerator);
    • b. Stability and reliability as the gaming machine computer platform (hardware and software) are simple and do not need to be upgraded;
    • c. Future proofing (prevents obsolescence), as no software or hardware upgrades are required to accommodate extremely resource intensive multimedia advances such as future generations of advanced graphics animation, voice recognition, face recognition, avatar creation, etc. Moreover, selection of a given microprocessor architecture, operating system platform and supplier do not impact the future capabilities of the gaming machine, and
    • d. the video encoding, transmission, reception and decoding means may use low cost and mass-produced economical TV and streaming media components.


Moreover, this approach is ideally suited for offering wireless mobile gaming machines that players may take to the bar, the restaurant, the swimming pool, their hotel room, etc.


According to one embodiment of the present invention, MICROSOFT DCOM may be advantageously used; DCOM support is already integrated into MICROSOFT WINDOWS CE and EMBEDDED XP. In the long term, MICROSOFT.NET web services over a private IP network (or VPN over Internet) may become the preferred technology, as it offers flexible and dynamic discovery of Net/Web services. The notion of a private or non-operator UDDI node is critical to the emergence of a dynamic style of a service-oriented architecture. As of this writing, MICROSOFT has announced support of .NET web services in WINDOWS CE.NET. These network technologies are encapsulated in the MICOROSOFT WCF—Windows Communication Foundation available in “.NET Framework 3.0” and later versions.



FIGS. 21, 22, 23, 24 and 25 illustrate views of a service based gaming system in which SOAP is used, according to embodiments of the present invention. In the figures, a node may be or include a computer, personal digital assistant, cell phone, router, switch, hub, server, workstation, handheld PC, gaming machine, specialized device, an ATM or other device or process having the requisite processing functionality.



FIG. 21 illustrates a view of the service based gaming system according to an embodiment of the present invention including a plurality of nodes 2104, 2106, 2108, 2110, 2112 and 2114 arranged such as to offer one service publisher 2128 and multiple service subscribers 2130, 2132, 2134, 2136 and 2138. The network 2102 is representative of a physical communication medium that may be loosely coupled (e.g. LAN, WAN, Ethernet, Internet, Wi-Fi, BLUETOOTH communication protocol, USB-to-LAN adapters or a combination of them), tightly coupled (i.e. interprocess communication within a device or via USB) or a combination of loosely coupled and tightly coupled communication mediums. A SOAP communication stack 2116, 2118, 2120, 2122, 2124 and 2126 may be included in each node to allow the communication of services. The publisher 2128 may publish (or provide) services that one or a plurality of subscribers (or consumers) may consume, over the network 2102. The services provided by the publishing node 2104/2128 may be (a) high level functions such as from a business application server, a bonusing server, a customer loyalty server, a progressive jackpot server and a player tracking server, or (b) services from a specialized device, e.g. a network connected printer, a network connected bill acceptor, a player tracking combo (video display+touch-screen+card reader) and devices connected to a network bridge USB to Ethernet or RS232 to Ethernet. The services provided by the publishing node 2104/2128 may be consumed independently by multiple subscribing nodes 2106/2130, 2108/2132, 2110/2134, 2112/2136 and/or 2114/2138.



FIG. 22 illustrates a view of a service based gaming system, according to an embodiment of the present invention. As shown, the service based gaming system may include a plurality of nodes 2204, 2206, 2208, 2210, 2212 and 2214 arranged such as to offer multiple service publishers 2228, 2230, 2232, 2234 and 2236 and one service subscriber 2238. The network 2202 is representative of a physical communication medium that may be a loosely coupled (e.g. LAN, WAN, Ethernet, Internet, Wi-Fi, BLUETOOTH communication protocol, USB-to-LAN adapters or a combination of them), tightly coupled (i.e. interprocess communication within a device or via USB) or a combination of loosely coupled and tightly coupled communication mediums. A SOAP communication stack 2216, 2218, 2220, 2222, 2224 and 2226 may be included in each node to allow the communication of services. The services provided by the publishing node 2204/2228, 2206/2230, 2208/2232, 2210/2234 and/or 2212/2236 may be (a) high level functions such as from a business application server, a bonusing server, a customer loyalty server, a progressive jackpot server and a player tracking server, or (b) services from a specialized device, e.g. a network connected printer, a network connected bill acceptor, a player tracking combo (video display+touch-screen+card reader) and devices connected to a network bridge USB to Ethernet or RS232 to Ethernet. The services provided by the publishing nodes 2204/2228, 2206/2230, 2208/2232, 2210/2234 and 2212/2236 may be consumed independently by one subscribing node 2214/2238; for example, network connected printers installed in gaming machines may publish a range of services and a maintenance server may subscribe to, e.g., a paper jam alert and the paper low alert services such that the maintenance server may forward a job order to a technician on his or her mobile device.



FIG. 23 illustrates a view of a service based gaming system according to another embodiment of the present invention that may include a plurality of nodes 2302, 2304, 2306, 2308, 2310, 2312, 2314, 2316 and 2318 arranged such as to offer multiple service publishers 2336, 2340, 2346 and 2350 and multiple service subscribers 2338, 2342, 2344 and 2348. As described relative to FIGS. 21 and 22, the network 2302 may be representative of a physical communication medium that may be a loosely coupled (e.g. LAN, WAN, Ethernet, Internet, Wi-Fi, BLUETOOTH communication protocol, USB-to-LAN adapters or a combination of them), tightly coupled (i.e. interprocess communication within a device or via USB) or a combination of loosely coupled and tightly coupled communication mediums. A SOAP communication stack 2320, 2322, 2324, 2326, 2328, 2330, 2332 and 2334 may be included in each node to allow the communication of services.



FIG. 24 illustrates a view of a service based gaming system according to an embodiment of the present invention. As shown, the service based gaming system of FIG. 24 may include a plurality of nodes 2404, 2406 and 2408, wherein each node is arranged such as to offer one or more of: one service publisher, multiple service publishers, one service subscriber and multiple service subscribers. The network 2402 is representative of a physical communication medium that may be a loosely coupled (e.g. LAN, WAN, Ethernet, Internet, Wi-Fi, BLUETOOTH communication protocol, USB-to-LAN adapters or a combination of them), tightly coupled (i.e. interprocess communication within a device or via USB) or a combination of loosely coupled and tightly coupled communication mediums. A SOAP communication stack 2410, 2412 and 2414 may be included in each node to allow the communication of services. For example, node 2404 may include a central media server that may be configured to publish, for example, music content 2416, advertising video content 2418, promotional video content 2420 and a live TV feed 2422 to authorized participating nodes in the distributed gaming system. Node 2406 may include, for example, a billboard in a bar section wherein one network connected streaming plasma display 2424 may subscribe to the live video TV feed 2422 and the network connected ambience audio system may subscribe to the music content 2416. Node 2408 may include, for example, a gaming machine wherein an instance of a media player process 2430 may subscribe to the live video TV feed 2422 and another instance of a media player process 2432 may subscribe to the advertising video content 2418, and the video contents may be displayed simultaneously on the video gaming display or displays through a separate video window or 3D viewport. The gaming machine 2408 may publish 2428 its gaming meters using the GSA G2S protocol (Game Standard Association Game-to-System protocol), and any authorized node may subscribe to receive the gaming meters such as a casino management system (whose primary function is to satisfy regulatory accounting), a game download server, a security server, a marketing server, a player tracking server and/or a maintenance server, for example.



FIG. 25 illustrates a view of the service based gaming system according to an embodiment of the present invention. As shown, the present service based gaming system may include a plurality of nodes, and each node may be arranged such as to offer one or more of the following: (a) one service publisher, (b) multiple service publishers, (c) one service subscriber and (d) multiple service subscribers. The communication network labeled “network bus” 2502 may include loosely coupled and tightly coupled nodes carrying network services via the SOAP stack. Node 2504 may include, for example, a USB printer specialized device located within an ATM for publishing printing services in the ATM. Node 2508 may include, for example, a technician Wi-Fi handheld mobile device subscribing to alerts to repair jammed printers or bill acceptors. Node 2510 may include, for example, a billboard subscribing to a Keno server (not shown) that displays the published results of that Keno server.


In the illustrations of FIGS. 21, 22, 2324 and 25, the service discovery is not shown but may include any service discovery protocol as discussed previously, such as UDDI and SSDP. UDDI (Universal Description, Discovery and Integration) is a platform-independent, XML-based registry for businesses worldwide to list themselves on the Internet. UDDI is an open industry initiative, enabling businesses to publish service listings and discover each other and define how the services or software applications interact over the Internet. UDDI may also be applied in an Intranet network. SSDP (Simple Service Discovery Protocol) is the basis of the discovery protocol of Universal plug-and-play. SSDP provides a mechanism through which network clients can use to discover network services. Clients can use SSDP with little or no static configuration. SSDP provides multicast discovery support, server-based notification, and discovery routing. SSDP uses XML UDP unicast and multicast packets to advertise their services.


Nodes may be added and removed to the network; new services will be discovered and bound automatically, and services that are no longer available will be detected and their associated binding will be terminated. Nodes may be provided by any supplier complying with the service bus protocol. In the figures, the SOAP stack is the network service, but as may be readily inferred by persons of skill in the distributed network architecture arts, any other network service stack offering similar capability may be used, including the associated service discovery scheme.


Embodiments of the present invention offer a modular architecture for an on-line gaming system that may readily accommodate the wide variety of regulatory requirements encountered around the world. The strongest open security standards may be used. The very complex software code is located in the high-level software modules that may advantageously be developed using an advanced unified integrated development environment (such as, for example, MICROSOFT.NET). The various elements may be arranged in a tightly coupled configuration, loosely coupled configuration or in a mixture of tightly and loosely coupled configuration without requiring the high-level software modules to be entirely redesigned, retested and re-certified. In most cases, the high-level software modules may be re-used without modification thus saving enormous cost and development, validation and testing time. A gaming system may be constructed using a wide variety of computer hardware and software platforms, and make use of the latest multimedia technologies to attract the younger generation of players used to flashy and networked games. IP-Ready specialized devices using Internet appliance technologies offer tremendous benefit as the gaming machines, entertainment machines and payment verification units become a simple shell; the devices may be fully managed by the central server(s) 112. An advantageous embodiment of the invention is one in which the processing of all the high-level software modules, including graphics rendering, is carried out by the central server(s) 112, which relies on a server-class operating system and fault tolerant computing platform. Consequently, embodiments of the present invention provide an architecture that overcomes the technical lag, security limitations and lack of stability of the prior art.


Rapidity changing technologies, such as advanced multimedia graphics and biometric recognition that require continual increase in processing power are, according embodiments of the present invention, processed at the central server(s) 112. The present gaming machine, according to one embodiment thereof, only requires means of receiving and displaying high quality video images and means for sending locally captured biometric data (such as voice or video image of player) to the central server(s) 12. Wireless mobile gaming machine may be readily constructed. The central server(s) 112 (constructed with advanced server blades in one embodiment of the present invention) may be readily upgraded at any time by plugging in new replacement blades. Moreover, it is likely that entire server blades will soon fit on a single integrated circuit. One or more servers 112, therefore, may fit on a single integrated circuit. The present gaming machines do not require costly upgrades to take advantage of such multimedia advances. Consequently, embodiments of the present invention provide an architecture that overcomes rapid obsolescence of technology. The devices, methods and systems disclosed herein provide a flexible architecture that enables international suppliers to readily accommodate the variety of specific regulatory requirements encountered around the world.


Embodiments of the present invention also offer a modular architecture for an on-line gaming system that may readily accommodate the wide variety of regulatory requirements encountered around the world. The strongest open security standards may be used. The very complex software code is located in the high-level software modules that may advantageously be developed using an advanced unified integrated development environment (such as, for example, Microsoft .NET). The various elements may be arranged in a tightly coupled configuration, loosely coupled configuration or in a mixture of tightly and loosely coupled configuration without requiring the high-level software modules to be entirely redesigned, retested and re-certified. Similarly, a subset of the specialized devices may have its hardware aggregated such as to present only one coupling interface. Embodiments of video displays 802, non-video displays 804, interactive controls 806 and card reader 818 may be aggregated into a single specialized device mounted in the gaming machine, for example a player tracking device running WINDOWS CE operating system that is loosely coupled via the communication network to a high-level software module running in the central server, the high-level software module implementing a central player tracking management function. In most cases, the high-level software modules may be re-used without modification, thereby affording significant saving in costs and development, validation and testing time. A gaming system may be constructed using a wide variety of computer hardware and software platforms, and make use of the latest multimedia technologies to attract the younger generation of players used to flashy and networked games. IP-Ready specialized devices using Internet appliance technologies offer tremendous benefit as the gaming machines, entertainment machines and payment verification units become a simple shell; as the devices may be fully managed by the central server(s) 112. An advantageous embodiment of the invention is one in which the processing of all the high-level software modules, including graphics rendering, is carried out by the central server(s) 112, which relies on a server-class operating system and fault tolerant computing platform. Consequently, embodiments of the present invention provide an architecture that overcomes the technical lag, security limitations and lack of stability of the conventional gaming systems.

Claims
  • 1. A distributed gaining system, comprising: a communication bus;at least one first node, each including a first computer coupled to the communication bus;at least one first service oriented software executing in the first computer of each first node, the first service oriented software including at least one high-level function and a first service oriented protocol, the first service oriented protocol being configured to negotiate service messages over the communication bus, the first service oriented software being configured to selectively:publish the at least one high-level function;provide the at least one high-level function upon receiving a request to consume the at least one high-level function;enable execution of the at least one high-level function upon receiving a request for execution;perform a call back upon receiving a request to consume or execute the at least one high-level function, andreturn a reply subsequent to receiving a request for execution of the at least one high-level function;at least one second node, each including a second computer coupled to the communication bus, andat least one second service oriented software executing in the second computer of each second node, the second service oriented software including at least one function call and a second service oriented protocol configured to negotiate service messages over the communication bus, the second service oriented software being configured, upon execution of the at least one function call, to selectively:subscribe, to or consume the published or provided at least one high-level function;request that the at least one first node execute the at least one high-level function;accept the reply subsequent to receiving a reply from the at least one first node, and accept the call-back upon receiving a call-back from the at least one first node.
  • 2. The distributed gaining system of claim 1, wherein the first service oriented software is configured to provide the at least one high-level function upon receiving a request to consume the at least one high-level function via a remote procedure call.
  • 3. The distributed gaming system of claim 1, wherein the first service oriented software is configured to provide the at least one high-level function upon receiving a request to consume the at least one high-level function via a HTTP request.
  • 4. The distributed gaming system of claim 1, wherein the first service oriented software is configured to enable execution of the at least one high-level function upon receiving a request for execution via a HTTP request.
  • 5. The distributed gaming system of claim 1, wherein the first service oriented software is configured to perform a call back upon receiving a request to consume or execute the at least one high-level function via a remote procedure call.
  • 6. The distributed gaming system of claim 1, wherein the first service oriented software is configured to return a HTTP reply subsequent to receiving a HTTP request for execution of the at least one high-level function.
  • 7. The distributed gaming system of claim 1, wherein the service oriented protocol is the Service Oriented Architecture Protocol (SOAP).
  • 8. The distributed gaining system of claim 1, wherein the communication bus includes loosely coupled and/or tightly coupled nodes.
  • 9. The distributed gaming system of claim 8, wherein the loosely coupled nodes include nodes coupled via at least one of Ethernet, Wi-Fi, Internet, radio-link, RS-422, micro-wave link and satellite link.
  • 10. The distributed gaining system of claim 1, wherein the at least one high-level function includes one of a business function, an audit function, an authentication function, a biometric identification function, a graphics rendering computation function and an outcome determination function.
  • 11. The distributed gaming system of claim 1, wherein the at least one first node includes one of a gaming machine, an entertainment machine, a payment verification unit, a specialized device, an IP enabled peripheral, a server, a server farm, a computer device, and an automatic teller machine.
  • 12. The distributed gaming system of claim 1, wherein the at least one second node includes at least one of a gaining machine, an entertainment machine, a payment verification unit, a specialized device, an IP enabled device, a server, a server farm, a computer device, and an automatic teller machine.
  • 13. The distributed gaming system of claim wherein security over the communication bus is provided by implementation of at least one of the IPSec protocol, the VPN tunneling protocol and the SSL protocol.
  • 14. The distributed gaming system of claim 1, wherein the at least one second node includes a gaming machine.
  • 15. The distributed gaming system of claim 1, wherein the at least one second node is included inside a gaming machine.
  • 16. The distributed gaming system of claim 1, wherein the at least one first node includes a gaming machine.
  • 17. The distributed gaming system of claim 1, wherein the at least one first node is included inside a gaming machine.
  • 18. The distributed gaming system of claim 1, wherein the at least one second node is a gaming machine played by a player and is configured to execute at least one function all during a game session.
  • 19. The distributed gaming system of claim 1, wherein the at least one second node is included inside a gaming machine played by a player and is configured to execute at least one function call during a game session.
  • 20. The distributed gaming system of claim 1, wherein the at least one first node is configured for load balancing with another one of the at least one first node.
  • 21. The distributed gaming system of claim 1, wherein the negotiating of service messages on the communication bus include at least one of naming, discovery, message routing, publishing eventing, subscribing eventing, message transformations, workflows, and communication recovery from nodes powering-off then on again.
  • 22. A distributed gaming system, comprising: a communication bus;a first gaming machine coupled to the communication bus the first gaming machine being configured to selectively publish, execute and provide at least one high-level function, anda second gaming machine coupled to the communication bus, the second gamin machine being configured to selectively subscribe to or consume the at least one high-level function published or provided by the first gaming machine, and selectively request that the first gaming machine execute the at least one high-level function, wherein the first gaming machine further configured to perform a call back upon receiving a request to consume or execute the at least one high-level function, and return a reply and wherein the second gaming machine is further configured to accept the reply subsequent to receiving the call-back from the first gaming machine.
  • 23. The distributed gaming system of claim 22, further including a service-oriented device coupled to the communication bus, the service oriented device including at least one of a payment verification unit, a specialized device, an IP enabled peripheral, a server, a server farm, a computer device, and an automatic teller machine, the service oriented device being configured to selectively publish, subscribe, provide, execute and request that either the first or the second gaming machine execute the at least one high level function.
  • 24. A method for distributed gaming over a communication bus, comprising: providing a first gaming machine and coupling the first gaming machine to the communication bus;publishing, by the first gaming machine, a first high-level function over the communication bus;providing a node coupled to the communication bus;receiving, from the node, a request to subscribe to the published first high-level function;accepting the subscription request;initiating a gaming session on the first gaming machine, andresponsive to updates occurring during the gaming session, providing call backs, by the first gaming machine, the call backs returning a result of the execution of the first high-level function to the node over the communication bus.
  • 25. The method of claim 24, wherein the receiving step is carried out with the node including a second gaming machine.
  • 26. The method of claim 24, wherein the receiving step is carried out with the node including at least one of an entertainment machine, a payment verification unit, a specialized device, an IP enabled device, a server, a server farm, a computer device, and an automatic teller machine.
  • 27. The method of claim 24, wherein the high-level function includes at least one of a business function, an audit function, an authentication function, a biometric identification function, a graphics rendering computation function, and an outcome determination function.
  • 28. The method of claim 24, further comprising a step of receiving, from the node, a request that the first gaming machine executes the high-level function.
  • 29. The method of claim 24, further comprising a step of the first gaming machine performing a call back upon receiving the request to consume or execute the high-level function.
  • 30. The method of claim 24, wherein the second providing step is further carried out with the node being configured to selectively publish, subscribe, provide, execute and request that the first gaming machine execute the high level function.
  • 31. A method for distributed gaming over a communication bus, comprising: providing a first node and coupling the first node to the communication bus;publishing, by the first node, a high-level function over the communication bus;providing a first gaming machine coupled to the communication bus;receiving, from the first gaming machine, a request to subscribe to the published high-level function;accepting the subscription request;initiating a gaming session on the first gaining machine, and responsive to updates occurring during the gaming session, providing call backs, by the first node, the call backs returning a result of the execution of the high-level function to the first gaming machine over the communication bus.
  • 32. The method of claim 31, wherein the receiving step is carried out with the first node including a second gaming machine.
  • 33. The method of claim 31, wherein the receiving step is carried out with the node including at least one of an entertainment machine, a payment verification unit, a specialized device, an IP enabled device, a server, a server farm, a computer device, and an automatic teller machine.
  • 34. The method of claim 31, wherein the high-level function includes one of a business function, an audit function, an authentication function, a biometric identification function, a graphics rendering computation function, and an outcome determination function.
  • 35. The method of claim 31, further comprising a step of receiving, from the first gaining machine, a request that the node execute the first high-level function.
  • 36. The method of claim 31, further comprising a step of the node performing a call hack upon receiving the request to consume or execute the high-level function.
  • 37. The method of claim 31, wherein the second providing step is further carried out with the first gaining machine being configured to selectively publish, subscribe, provide, execute and request that the node execute the high level function.
CROSS-REFERENCE TO RELATED APPLICATIONS

This is a continuation-in part of application Ser. No. 10/120,635, filed Apr. 10, 2002 now U.S. Pat. No. 7,297,062, which claims the benefit under 35 U.S.C. §119(e) of provisional application Ser. No. 60/332,593, filed Nov. 23, 2001, both applications of which are hereby incorporated herein by reference in their entireties. This application is also related in subject matter to commonly assigned U.S. Pat. Nos. 6,916,247, 6,945,870 and 7,297,062 and to commonly assigned U.S. pending application Ser. No. 11/844,201 filed Aug. 23, 2007.

US Referenced Citations (73)
Number Name Date Kind
4335809 Wain Jun 1982 A
5179517 Sarbin et al. Jan 1993 A
5573248 Parra et al. Nov 1996 A
5667440 Sasaki et al. Sep 1997 A
5674128 Holch et al. Oct 1997 A
5759102 Pease et al. Jun 1998 A
5762552 Vuong et al. Jun 1998 A
5800269 Holch et al. Sep 1998 A
5970143 Schneier et al. Oct 1999 A
6048269 Burns et al. Apr 2000 A
6077163 Walker et al. Jun 2000 A
6089982 Holch et al. Jul 2000 A
6135887 Pease Oct 2000 A
6142876 Cumbers Nov 2000 A
6210274 Carlson Apr 2001 B1
6219836 Wells et al. Apr 2001 B1
6251014 Stockdale et al. Jun 2001 B1
6273821 Moriguchi Aug 2001 B1
6280328 Holch et al. Aug 2001 B1
6334614 Breeding Jan 2002 B1
6383078 Yacenda May 2002 B1
6409602 Wiltshire et al. Jun 2002 B1
6428413 Carlson Aug 2002 B1
RE37885 Acres et al. Oct 2002 E
6463530 Sposato Oct 2002 B1
6567854 Olshansky et al. May 2003 B1
6595859 Lynn Jul 2003 B2
6710895 Gatto et al. Mar 2004 B1
6732920 Gatto et al. May 2004 B2
6749510 Giobbi Jun 2004 B2
6908391 Gatto et al. Jun 2005 B2
6916247 Gatto et al. Jul 2005 B2
6921331 Gatto et al. Jul 2005 B2
6945870 Gatto et al. Sep 2005 B2
7297062 Gatto et al. Nov 2007 B2
7374486 Baerlocher May 2008 B2
7546602 Hejlsberg et al. Jun 2009 B2
7802276 Swix et al. Sep 2010 B2
20010014881 Drummond et al. Aug 2001 A1
20020090934 Mitchelmore Jul 2002 A1
20020137217 Rowe Sep 2002 A1
20020147040 Walker et al. Oct 2002 A1
20020174444 Gatto et al. Nov 2002 A1
20030037335 Gatto et al. Feb 2003 A1
20030087683 Gatto et al. May 2003 A1
20030100369 Gatto et al. May 2003 A1
20030100370 Gatto et al. May 2003 A1
20030100371 Gatto et al. May 2003 A1
20030100372 Gatto et al. May 2003 A1
20030103644 Klayh Jun 2003 A1
20030171140 Gatto et al. Sep 2003 A1
20030177187 Levine et al. Sep 2003 A1
20040185936 Block et al. Sep 2004 A1
20050027382 Kirmse et al. Feb 2005 A1
20050032577 Blackburn et al. Feb 2005 A1
20050054448 Frerking et al. Mar 2005 A1
20050059494 Kammler Mar 2005 A1
20050113172 Gong May 2005 A1
20050233811 Gatto et al. Oct 2005 A1
20050282637 Gatto et al. Dec 2005 A1
20060003835 Olive Jan 2006 A1
20060030383 Rosenberg et al. Feb 2006 A1
20060030399 Baerlocher Feb 2006 A1
20060183537 Dickerson Aug 2006 A1
20060270478 Barhydt et al. Nov 2006 A1
20070180371 Kammler Aug 2007 A1
20070184896 Dickerson Aug 2007 A1
20070191102 Coliz et al. Aug 2007 A1
20080171601 Kirmse et al. Jul 2008 A1
20080194317 Baerlocher Aug 2008 A1
20080214280 Baerlocher Sep 2008 A1
20090143133 Baerlocher Jun 2009 A1
20100203959 Olive Aug 2010 A1
Foreign Referenced Citations (15)
Number Date Country
19941504 Mar 2001 DE
1004970 May 2000 EP
1004970 May 2000 EP
1074955 Feb 2001 EP
1074955 Feb 2001 EP
1087323 Mar 2001 EP
1120757 Aug 2001 EP
1120757 Aug 2001 EP
1231577 Nov 2001 EP
1231577 Nov 2001 EP
9808581 Mar 1998 WO
0054214 Sep 2000 WO
0141892 Jun 2001 WO
0141892 Jun 2001 WO
0182176 Nov 2001 WO
Related Publications (1)
Number Date Country
20080032801 A1 Feb 2008 US
Provisional Applications (1)
Number Date Country
60332593 Nov 2001 US
Continuation in Parts (1)
Number Date Country
Parent 10120635 Apr 2002 US
Child 11842147 US