This invention relates generally to gaming devices, and more particularly to a method and apparatus for controlling gaming devices interconnected by a computer network.
Networked gaming devices are known in the art. Interconnecting a plurality of gaming devices such as slot machines via a computer network to a central computer provides many advantages. The primary advantage of networked gaming devices is the ability to extract accounting data from the individual gaming devices as well as providing player tracking. An example of a data collection system is described in U.S. Pat. No. 4,283,709 issued to Lucero et al. Network systems such as described in Lucero et al. allow the central host computer to monitor the usage and payout, collectively known as audit data, of the individual gaming devices. This audit data includes data related to the number of coins or tokens inserted into the device, the number of times the device has been played, the amount paid in raises, the number and the type of jackpots paid by the machine, the number of door openings, etc. The host computer can then compile an accounting report based on the audit data from each of the individual gaming devices. This report can then be used by management, for example, to assess the profitability of the individual gaming devices.
Player tracking, as the name indicates, involves tracking individual player usage of gaming devices. In prior art player tracking systems, the player is issued a player identification card which has encoded thereon a player identification number that uniquely identifies the player. The individual gaming devices are fitted with a card reader, into which the player inserts a player tracking card prior to playing the associated gaming device. The card reader reads the player identification number off the card and informs a central computer connected thereto of the player's subsequent gaming activity. By tracking the individual players, individual player usage can be monitored by associating certain of the audit data with the player identification numbers. This allows gaming establishments to target individual players with direct marketing techniques according to the individual's usage.
One problem that can occur with current player tracking systems is that the player can insert a player identification card incorrectly unbeknownst to the player. Currently, if a player inserts a player identification card improperly into the card reader, a message appears on a display located away from the card reader. Unfortunately, the player may not be looking at the display while inserting the card. As a result, the player may not see the message on the display. Another prior art approach has been to provide a light emitting diode on the gaming device to indicate to the player the status of the card insertion. This too has been ineffective because the player may not know the purpose of the LED or the LED may be drowned out by all the other lights of the casino. The player may therefore commence playing with the card improperly inserted. In this case, both the player and the casino lose valuable player tracking information. This is frustrating for the player because his activity will not be credited to his account and frustrating for the casino because the casino's records will be incomplete. Accordingly, a need remains for an improved method and apparatus for informing the player when a player tracking card has been improperly inserted.
The full power of networked gaming devices has not been completely realized. Although the audit data indicates which devices are being under utilized and when, there is currently no automated method for altering under utilized gaming devices' configurations to make them more attractive to play. For example, during certain hours of the day, e.g. four to six a.m., the audit data may indicate that the machines are being under utilized. Thus, it would be desirable to reconfigure the under utilized gaming devices to provide an additional incentive to players to use these devices. In the past casinos have run “bonuses” during these times. An example of such bonuses include a “double jackpot” wherein a player hitting a jackpot is paid double the jackpot amount. Currently this is implemented by having an attendant manually payout the additional payout amount. This manual technique, however, is cumbersome and inefficient to administer because an attendant must be constantly supervising the bonusing gaming devices. Accordingly, a need remains for an automated method and apparatus to provide bonusing for gaming devices.
Another limitation of the current bonusing systems is that only predetermined machines are eligible for the bonusing. For example, in a progressive bonusing machine a plurality of machines are connected together to form a bank. Only the machines in the bank are then eligible to win the progressive jackpot. Thus, a casino must dedicate a certain number of its machines to these banks. This limits the casino's flexibility in tailoring its bonusing to the number and make-up of its customers. Accordingly, a need remains for a more flexible bonusing system whereby any of the casino's machines can participate in the bonusing.
It is, therefore, an object of the invention to reconfigure gaming devices remotely over a network to provide bonusing.
Another object of the invention is to provide an integrated system usable with a variety of gaming devices made by different manufacturers.
Another object of the invention is to integrate player tracking, data collection, and bonusing over the same network.
A further object of the invention is to provide visual feedback to the user when a player tracking card has been improperly inserted.
A system for operating networked gaming devices is described. The system according to the invention allows a casino in which the system is installed to run promotions or bonuses on any properly equipped gaming machines while simultaneously gathering player tracking and accounting data from all machines. The system provides the capability for the casino to select which of the plurality of machines are used in any given promotion. The system further allows any number of different promotions to operate simultaneously.
The system includes a plurality of gaming devices or machines connected to an associated floor controller over a network. The system includes one or more of said floor controllers. The floor controllers are interconnected by a high-speed network, such as an Ethernet network, to a database where accounting and player tracking data is stored. The system can also include pit terminals and/or fill and jackpot processing terminals. Each promotion involves sending a reconfiguration command from the floor controller to a gaming device that has been selected to be part of a given promotion over the associated network. Upon receipt of the reconfiguration command, the gaming device reconfigures its payout schedule in accordance with the received reconfiguration command. In the preferred embodiment, this reconfiguration includes activating a bonus payout schedule. A partial list of the promotions according to the invention include, but are not limited to: a multiple jackpot wherein the gaming device reconfigures its payout to be a multiple of its default payout schedule; a bonus jackpot wherein the gaming device reconfigures its payout schedule to payout an additional bonus amount when certain conditions are met; and a progressive jackpot wherein two or more gaming devices are combined in a progressive jackpot having a progressive jackpot payout schedule. In addition to these, many other promotions are possible by the above-described system for controlling and monitoring a plurality of gaming devices.
The system also allows for improved player tracking by recording each and every machine transaction including time of play, machine number, duration of play, coins in, coins out, hand paid jackpots and games played. The player tracking is conducted over the same network as the accounting data is extracted. This allows the invention to provide bonusing to certain individual players as well as during certain times. As with standard player tracking, the above-described system monitors and reports how many coins are played by each player. The system according to the invention, however, also includes the ability to record how long each player spends at each machine and the number of coins won, games played, and hand jackpots won by each player. The invention is able to record all this information because the system operates on a transaction by transaction basis. Each transaction, whether it be a coin in, a handle pull, etc., is recorded by the system. Other systems simply compile the player tracking information at the completion of play. All this information is stored on the database, which can be later analyzed for future targeted direct mailing campaigns. The player tracking according to the invention also allows the casino to schedule buses and other groups and measure their profitability. The system also allows for cashless play as well as advanced accounting and security features.
An advantage of the invention is that any of the casino's machines can be incorporated into a bonus promotion.
Another advantage of the invention is that several bonus promotions can operate simultaneously.
A further advantage of the invention is the ability to record each and every machine transaction including time of play, machine number, duration of play, coins in, coins out, hand paid jackpots and games played.
A further advantage of the invention is the ability to associate a player with a certain machine.
A further advantage of the invention is the ability to perform more targeted direct mailing based on individual play.
A further advantage of the invention is the ability to calculate a theoretical win exactly.
A further advantage of the invention is the ability to generate jackpot announcements, which provides for, among other things, better slot tournaments.
A yet further advantage of the invention is the ability to quickly and easily add new machines to the network.
The foregoing and other objects, features and advantages of the invention will become more readily apparent from the following detailed description of a preferred embodiment of the invention which proceeds with reference to the accompanying drawings.
A system for operating a plurality of gaming devices is shown generally at 10 in
This reconfiguration, in the preferred embodiment, comprises activating a bonus payout schedule. This bonus payout schedule is in addition to the normal pay table of the gaming device. The bonus payout schedule provides for additional bonus payouts in addition to the payouts specified by the device's normal pay table. The difference between the two is important for regulatory reasons. The composition of the pay table is subject to regulation by the various state gaming commissions while the bonus payout schedule is not. The preferred embodiment currently activates only the bonus payout schedule responsive to the reconfiguration command, while not altering the payout table. The invention, however, is not limited to activating only the bonus payout schedule. Other embodiments, which would be subject to regulatory approval, could modify the device's payout table. The preferred embodiment, however, does not.
The system, according to the invention, implements a variety of bonusing events through this reconfiguration process. These bonusing events include: a multiple jackpot wherein the gaming device reconfigures its payout to be a multiple of its default payout schedule; a bonus jackpot wherein the gaming device reconfigures its payout schedule to payout an additional bonus amount when certain conditions are met; and a progressive jackpot wherein two or more gaming devices are combined in a progressive jackpot having a progressive jackpot payout schedule.
The system, according to the invention, also provides for integrated player tracking and accounting data extraction. Unlike prior art systems that use disparate systems for player tracking and accounting data extraction, the system 10 provides for player tracking and accounting data extraction over the same network. The player tracking, according to the invention, allows the casino to run certain promotional events. The integrated player tracking and accounting data extraction also allows the system to support cashless play wherein a credit is given to a player over the network.
The system 10 includes one or more floor controllers 18 and 28. Each floor controller supports up to a predetermined maximum number of gaming devices. In the preferred embodiment, each floor controller can support up to 1024 gaming devices. The preferred embodiment also supports up to eight floor controllers. Thus, the system 10 can support up to 8192 separate gaming devices.
The system supports a multiplicity of various gaming devices. The gaming devices 12-16 and 22-26 shown in
The floor controllers 18 and 28 are, in the preferred embodiment, IBM-compatible personal computers. Each floor controller is responsible for monitoring the activity level of the corresponding gaming devices connected thereto and issuing commands to the associated gaming devices to reconfigure their payout schedules during certain bonusing events. The floor controllers issue status requests to each of the individual gaming devices to determine the activity level of each. In the event the floor controller detects any activity, the floor controller communicates that activity to a file server 32, which is connected to the floor controllers via a high speed network 38 connected therebetween.
In the preferred embodiment, the file server 32 includes a high performance personal computer or work station having a large hard disk capacity in order to store the gaming device activity therein. In the preferred embodiment, the high speed network 38 is a ten megabyte ethernet network. The system 10 also includes commercially available network software to support the industry-standard ethernet network 38. An example of such network software is Novell network software sold by Novell of Provo, Utah. The file server 32 also includes a database program by which reports can be generated using the data stored on the file server. Such reports include, e.g. area, model, denomination and summary reports. The database software also allows a user to generate custom reports. The database software is based on the industry-standard Paradox database language.
The system 10 also includes a pit terminal 34 which is also connected to the ethernet network 38. The pit terminal 34 is also a standard personal computer, in the preferred embodiment, and can be used to monitor the gaming device activity in the pit. This terminal 34 can also be used as a security monitoring device to detect any unanticipated events like fills or payouts.
The system 10 further includes any number of fill and jackpot processing terminals 36. These terminals 36 are placed in the cage and/or the change booth areas of the casino for fill and hand-paid jackpot processing. When a fill is required, a floor person goes to the nearest cashier's booth and states the gaming device number requiring a fill. The booth attendant enters the number into the fill and jackpot processing terminal 36 located in the cashier's booth. The terminal 36 then looks up the record associated with the particular gaming device in the file server 32 to determine the correct fill amount. The terminal 36 also calculates a theoretical hopper balance for the particular device based on the latest meter information, as described further below. If the calculation shows a significant hopper balance, a warning is given on the computer screen from which security can then be alerted.
A fill and jackpot processing terminal 36 prints a fill ticket upon demand. If the calculated hopper balance was nearly zero, the terminal 36 cause the words “computer verified” to be printed on the ticket in place of a supervisor's signature. In the event that the calculated hopper balance was not near zero, an extra signature is required to complete the fill transaction. The system follows a similar procedure for processing hand-paid jackpots.
A dispatch station (not shown) can also be included in the system. The dispatch station allows the casino to monitor activity on the gaming devices and “run the casino” from one location. The dispatch station allows the dispatcher to monitor customer service, maintenance, and security events and direct other casino personnel to handle these situations appropriately. For example, during hopper empties (fills) and jackpot events, as indicated by the dispatcher station, the dispatcher could radio down to the floor to have someone verify the event. The dispatcher station can also indicate when a machine door is opened without a technician card inserted, for example, in which case the dispatcher could take the appropriate course of action.
The above-described system 10 is but one embodiment of the system according to the invention. The system tasks can be allocated in a variety of ways amongst the system computers including floor controllers 18 and 28, file server 32, pit terminal 34 and fill and jackpot terminals 36. In some cases, the pit terminal 34 and fill and jackpot terminals 36 can even be eliminated and their tasks allocated to the floor controller or file server. In fact, because the file server 32 is essentially a virtual hard disk for the floor controllers 18 and 32, the floor controllers and the file server can be considered a single host computer for the system 10.
1. Overview
In order to communicate with the floor controller, each gaming device includes therein an electronic module 40, as shown in
2. Controller and Memory
The data communication node (DCN) 42 includes a data communication node controller 46, which in the preferred embodiment is an HD6473258P10 controller manufactured by Hitachi of Tokyo, Japan. The DCN 42 is coupled to the player tracking controller 44 through bus interface logic 45. The bus interface logic 45 is conventional interface logic including, for example, transceivers, as is known in the art of digital design.
A memory 48 is connected to the DCN controller 46. The memory includes program memory for storing program instructions for the DCN controller 46. In the preferred embodiment, this program memory includes a nonvolatile read-only memory (ROM). However, this program memory could also be flash or “battery” backed RAM in order for the program memory to be updated by the floor controller. In the event flash or “battery” back RAM is used the floor controller would download the updated program to the DCN controller and the DCN controller would overwrite the program memory with the downloaded program.
The memory 48 also includes system memory, e.g., static random-access memory (SRAM) for storing the gaming device information. This gaming device information includes at least the following meters: coins-in, coins-out, coins to drop, games played, jackpot occurrences. A separate meter counter is kept in memory 48 for each of these values. To increase reliability of the data, in the preferred embodiment, a redundant set of these counters is kept in a physically separate memory device within memory 48. Moreover, the memory devices storing these counters are nonvolatile so that in the event of a power failure the counts will be retained. The nonvolatile memories can either be battery-backed SRAM or electrically erasable programmable read-only memory (EEPROM). Although memory 48 is shown external to DCN controller 46, much if not all of the memory 48 can be included in the DCN controller 46.
3. Network Interface
The data communication node 42 also includes a network interface 49 for connecting the data communication node 42 to the associated floor controller. The network interface is coupled to the floor controller through a personality board 202, described below.
A more detailed drawing of network interface 49 is shown in
4. Serial Machine Interface
Referring to
Referring to
5. Serial Display Interface
The data communication node 42 further includes a serial display interface 70 illustrated in more detail in
6. Discrete Machine Interface
The data communication node 42 also includes a discrete machine interface 72, which is shown in detail in
All of the signal lines 76A-76J include a pullup resistor and a pulldown capacitor, which combined form an RC network on the associated line. The resistors are, in the preferred embodiment, in the form of a resistor pack 80 and the capacitors are individual discrete capacitors 82. Alternatively, the capacitors can be removed for high-speed signals.
7. Machine Configuration Circuit
The data communication node 42, as shown in
The machine configuration number presented on the parallel inputs of the parallel to serial converter 86 is latched therein responsive to a strobe signal received at the strobe STB input. A strobe input is generated by the DCN controller 46 on conductor 90 which is coupled to the strobe STB input. The parallel data is clocked out of the converter 86 to the DCN controller 46 on conductor 88 and connected between the serial output SOUT of the converter 86 and an input of the DCN controller 46 responsive to a clock signal received on the clock input CLK of the converter 86. The clock signal is generated by the DCN controller 46 and is transmitted to the converter 86 via conductor 92 which is coupled between an output of the DCN controller 46 and the clock input CLK of the converter 86.
The converter 86 also includes a serial input SIN for receiving serial input data. The serial input SIN is coupled to an expansion terminal 94C of expansion connector 94. Conductors 90 and 92 are also coupled to the expansion terminal 94 to provide the clock and strobe signals thereto. The expansion terminal 94 therefore provides the means for the DCN controller 46 to access additional serial information through the parallel to serial converter 86. In the preferred embodiment, the parallel to serial converter 86 is part number 4021 manufactured by Toshiba Corporation of Tokyo, Japan.
1. Overview
Referring again to
In the preferred embodiment, the player tracking module 44, with the exception of the card reader 100 and the display 102, resides on a single printed circuit board, while the data communication node 42 resides on a separate printed circuit board. The player tracking module 44 and the data communication node 42 are then connected by a cable 111 such as a ribbon cable.
2. Serial Display Circuit
A more detailed drawing of the player tracking module 44 is shown in
3. Serial Expansion Ports
The player tracking module 44 also includes two serial expansion ports 104 and 106. Each of the expansion ports 104 and 106 includes a differential to single-ended converter 116 and 118, respectively. In the preferred embodiment, these converters 116 and 118 are part number LTC490 manufactured by Linear Technology Corporation of Milpitas, Calif. The PT controller 98 communicates with each converter via two single-ended, serial signal lines: an input signal line and an output signal line. The converters convert the single ended signals appearing on these lines to differential signals. The differential signals, however, can be used as single-ended signals as is known in the art. The first expansion port 104 interfaces the player tracking node 44 with a large vacuum florescent display 102 (
4. Card Reader
Referring now to
The card reader also includes a printed circuit board 130 having a longitudinal opening to allow the guide rails 122 and 124 to be inserted therein in order to allow the printed circuit board 130 to be pushed up flush against a mounting plate 132 of the bezel 116, as shown in
Also mounted on the printed circuit board 130 are a plurality of light-emitting diodes 142, as shown in
Referring now to
The photodetectors 136 are comprised of a plurality of light-sensitive phototransistors PD1-PD8. The emitters of the phototransistors PD1-PD8 are all coupled to ground. The collectors of phototransistor PD1 and PD8 are connected together and to a conductor 148 by which the PT controller 98 senses light detected by either phototransistor PD1 or PD8. Phototransistors PD2 and PD7 are similarly connected with the collectors of each being connected to a conductor 150. The collectors of phototransistors PD3 and PD6 are also commonly connected to a conductor 152. The collectors of the center phototransistors PD4 and PD5, however, are connected to separate conductors 156 and 154, respectively. Also connected to each of the conductors 148-156 is a corresponding pullup resistor. In the preferred embodiment, the pullup resistors are included in a resistor pack 158. Each of the conductors 148-156 are connected to a connector 170, which is coupled to the PT controller 98 as described below.
Based on the above configuration of the phototransistors PD1 and PD8, only five conductors are required to sample all eight of the phototransistors. Without more information, however, the player tracking controller 98 would be unable to determine which of the two phototransistors commonly connected to a particular conductor, e.g., conductor 148, detected light. For example, if either phototransistor PD1 or phototransistor PD8 detect light, the voltage level on conductor 148 will drop from a high voltage of approximately 5 volts to a low voltage of approximately 0.7 volts. Without more information, the player tracking controller 98 would be unable to determine which of the two phototransistors, PD1 or PD8, actually sensed the light. According to the invention, however, the card 120, as shown in
The card 120 includes five rows of slots 152-160. The rows of slots 152-160 are arranged in a matrix with the corresponding slot locations within each of the rows being aligned in columns. Only the first slot 150 of row 152 cannot be aligned with any other slots, i.e., slot 150 is in a column all by itself. The individual slots within the rows of slots 152-160 encode unique player tracking information. Each slot represents a single binary bit in the player tracking information. Either one of two conventions can be used to encode the information. First, a slot can represent a binary 1 and no slot can represent a binary 0. Second, a slot can represent a binary 0 and no slot can represent a binary 1. The player tracking information can include: a unique player identification number, the casino issuing the card, player membership information, etc.
In the preferred embodiment, the card includes five rows of slots each having a maximum number of nine individual slots, thereby producing 45 possible slots. The first row of slots 152, however, is not used to encode player tracking information, but instead is used to synchronize the sampling of the player tracking information by the player tracking controller 98. Thus, only 36 slots are used to encode player tracking information in the preferred embodiment. This still allows 2{circumflex over ( )}36 possible combinations, which is more than adequate.
The PT controller 98 uses the first row 152 to synchronize the sampling as follows. The PT controller 98 continuously samples the outputs of PD4 and PD5 looking for a slot. If a slot is detected on either PD4 and PD5 and no other slots are detected by any other phototransistors the PT controller 98 determines that the detected slot must be slot 150. The PT controller 98 then continuously samples the output of the phototransistor that detected slot 150. Once a new slot is detected by that phototransistor, the PT controller 98 then samples the outputs of the other phototransistors, i.e., PD1-PD3 and PD6-PD8, on conductors 148, 150 and 152 for slots in of the other rows. Thus, the PT controller 98 synchronizes the sampling of the other rows of slots to the detection of a slot in the first row 152.
It is important for the card reader to detect the orientation of the card in order to correctly interpret the player identification information encoded on the card. The card reader detects the orientation of the card 120 by detecting the slot 150. If slot 150 is detected by phototransistor PD4, then the card reader knows that the card is in the orientation shown in
The card reader further includes a plurality of light-emitting diodes 142 that are mounted on the printed circuit board 130 and received in the recess 144 of the bezel 116, as shown in
The dual diodes are essentially treated as two individual diodes. The red diodes R in the dual diodes are driven by a driver circuit 162, while the green diodes G in the dual diodes are driven by another driver circuit 164. The driver circuits 162 and 164 are, in the preferred embodiment, two open collector drivers connected in parallel, as with driver 145. However, other equivalent driver circuits would be apparent to those skilled in the art.
The dual diodes are arranged in pairs with the anodes of one of the dual diodes being coupled to the supply voltage +5 V and the cathodes of the other dual diode being connected to the output of the corresponding driver circuit. Accordingly, the red diodes are commonly driven by driver circuit 162, which is responsive to a signal received from the PT controller 98 on conductor 166. Similarly, the green diodes are commonly driven by driver circuit 164, which is responsive to a signal received from the PT controller 98 on conductor 168. Therefore, the PT controller 98 can selectively actuate the red diodes, the green diodes or both by generating the corresponding signals on conductors 166 and 168.
All of the conductors over which the PT controller communicates with the card reader, i.e., 146-156 and 166-168, are connected to a connector 170 as shown in
Although the preferred embodiment of the card reader is an optical card reader, the invention is not limited to such. The lighted bezel can be used in conjunction with any form of card reader such as a magnetic card reader, a bar code reader, etc. The method of providing visual feedback to the player herein described is a general method which can be used with a plurality of cards and card readers.
5. Display
Referring now to
In the preferred embodiment, the display 102 includes a vacuum fluorescent display (VFD) 184, which is organized as a 16×192 display matrix. Such displays are well-known in the art of digital electronics. The VFD 184 is driven by a driver circuit 186, which includes a plurality of individual drivers serially interconnected. In the preferred embodiment, these serial drivers are part number UCN5818EPF-1, manufactured by Allegro Microsystems, Inc. of Worcester, Mass. The driver circuit 186 is connected to the VFD 184 by bus 188, which includes 160 individual conductors. The manner in which the 160 bus lines are connected between the driver circuit 186 and the VFD 184 is known in the art, and is therefore not described in detail herein.
The display controller 174 interfaces with the driver circuit 186 by a plurality of signal lines 190. These signal lines transmit the standard driver interface signals to the driver circuit 186. These signals include: a clock signal CLOCK, serial input data signal SDATA, a frame signal FRAME, a strobe signal STROBE, two output enable signals OE1/ and OE2/, a column clock signal COL CLOCK, and a column output enable signal COL OE/. These signals have well known functions in the display art and are therefor not discussed in detail. The signal names having a “/” represent active low signals while all other signals are active high. The display controller 174 generates these signals in the required sequence in order to serially clock the reformatted display data to the driver circuit. One of ordinary skill in the art could program the display controller 176 to generate these signals in order to display the desired message on the VFD 184 based on the foregoing description.
The display 102 also includes a serial interface 192. The serial interface 192 is the means by which the PT controller 98 communicates a player tracking message to the display 102. In the preferred embodiment, the serial interface 192 includes two opto-isolator circuits: one for the serial send data, the other for the serial transmission data. The display controller 174 is connected to the serial interface 192 over a two conductor serial bus 194, one conductor for receiving serial data from the serial interface 192, the other for transmitting serial data thereto. A connector 196 is also coupled to the serial interface 192. The connector 196 includes four terminals. Two of the connector terminals are dedicated to receiving serial input data and the other two terminals are dedicated to transmitting serial data. A cable (not shown) couples the display 102 to the player tracking module 44 between connectors 196 (
6. Discrete Input Section
The display 102 further includes a discrete input section 198. The discrete input section 198 is an interface between the discrete outputs of a gaming device and the display controller 174 much in the same way that the discrete machine interface 72 allows the data communication node to interface with a gaming device. Although in the preferred embodiment the discrete input section is unconnected to any discrete machine inputs, the discrete input section 198 allows the display 102 to operate as a stand-alone module for gaming devices in certain configurations. The discrete input section provides discrete input signals from an external device to the display controller 174 over a bus 200. The discrete input section 198 includes opto-isolator circuits such as part number TLP620 manufactured by Toshiba Corporation of Tokyo, Japan which provide single-ended input signals to the display controller 174.
Referring now to
The personality board 202 couples the data communication node 42 to a gaming device. The personality board 202 includes two connectors 204 and 206 and an identification circuit 208. The connector 204 couples to the data communication node 42, as described further below. The connector 206 connects to the particular gaming device. The components shown in
The personality board uniquely identifies the machine by providing both a configuration number, which indicates the type of gaming device that is connected to the connector 206 and a unique identification number, which is used by the system 10 to maintain records on the machine. The configuration number includes a six bit binary number which indicates the type of gaming device connected to the personality board 202. Each machine type is assigned a unique configuration number. This configuration number is encoded on lines CNFG0-CNFG5, which are connected to terminals 204Q-204V, respectively, of connector 204. Each line represents one bit of the binary configuration number. The individual lines are either tied to a supply voltage to represent a binary one or to ground to represent a binary zero. The six bit configuration number used in the preferred embodiment can encode up to 2{circumflex over ( )}6 different combinations and, therefore, different machine types. The configuration number for the embodiment shown in
The configuration lines CNFG0-CNFG5 are coupled to the inputs of parallel to serial converter 86 (
The configuration number is used by the DCN controller 46 as a means of interpreting the discrete input signals received from the machine through connector 206. Individual conductors coupled between connector 204 and 206 are labeled to correspond to the machine type having a configuration number 3CH. For a different machine type having a different configuration number, many of these conductors may have different functions. By providing a unique configuration number, the DCN controller can interpret the signals received on these lines accordingly.
The personality board 202 also includes an identification circuit 208 which provides a unique machine identification number to the data communication node 42. The unique identification number is stored in a nonvolatile memory 210 and provided to a terminal 204N on conductor ID. In the preferred embodiment, the nonvolatile memory 210 is a part number DS2224 manufactured by Dallas Semiconductor of Dallas, Tex. In the preferred embodiment, the nonvolatile memory 210 includes a 32 bit ROM having a factory-lasered unique serial number stored therein. This serial number, i.e., the machine identification number, can be read out of the memory 210 by the DCN controller 46 to uniquely identify the machine connected thereto. The protocol for reading the identification number out of the memory 210, as is described in the data sheet for the part, is well known in the art.
The identification circuit 208 includes a number of discrete components. The memory 210 has a zener diode 212 coupled across the power and ground terminals of 213 and 215 thereof. The identification circuit 202 also includes a first diode 214 coupled between the power terminal 213 and a data output terminal 217. The circuit 208 further includes a second diode 216 coupled between the data output terminal 217 and the ground terminals 215. A resistor 218 is interposed between the data output terminal 217 and the connector terminal 204N. The terminal 204N is coupled to a corresponding terminal 74N of connector 74 (
The discrete outputs from the machine, e.g., coin in, coin out, etc., are also supplied to the data communication node 42 via bus 220. The bus 220 connects connector 74 of the data communication node 42 and the connector 204 of the personality board 202 such that terminals having corresponding lettered suffixes are connected. For example, terminal 74C of connector 74 is connected to terminal 204C of connector 204 by a individual conductor within bus 220. All the other terminals are similarly connected by the bus 220.
The network interface 49 of the data communication node 42 is also coupled to the personality board by a bus 222, as shown in
The serial machine interface 60 is also coupled to the personality board 202 by a bus 224, as shown in
Although buses 220, 222, 224 and 226 have been described as separate buses, the individual conductors within these buses could, and are in the preferred embodiment, combined into a single bus that is connected between the data collection node 42 and the personality board 202. To connect the data collection node 42 and the personality board 202 a connector (not shown) is mounted on the data collection node 42 and a mating connector (not shown) is mounted on the personality board 202. The two connectors are then mated together to connect the data collection node 42 to the personality board 202. The personality board is then coupled to the corresponding gaming device by a cable 225 (
Referring now to
A second embodiment of the display driver is shown in
The display drivers are used by the data communication node 42 to activate a display on the gaming device which indicates that the machine is now in a bonus mode or condition.
As shown in
The floor controller is connected to the associated gaming devices by current loop networks. Because of the limitations of the current loop network, only a predetermined number of gaming devices can be supported on any one current loop network. In the preferred embodiment, each current loop network supports up to 64 gaming devices. In order for each floor controller to support more than this predetermined number of gaming devices, each floor controller is equipped with a communication board 246, as shown in
The communication board 246 includes eight separate microcontrollers 248A-248H. The microcontrollers communicate with the floor controller through ISA bus interface logic 247 over buses 249A and 249B. The microcontrollers are shown in a daisy-chain connection in
Each microcontroller is responsible for two current loop networks. Each microcontroller communicates with its associated gaming devices via two corresponding current loop networks. Two serial signal lines 251 connect each microcontroller to a current loop driver circuit 250. The driver circuit 250 provides the necessary current drive to support the current loop network. Each pair of serial signal lines 251 has a corresponding pair of current loop lines 253. The current loop driver circuit 250 can either be located on the communication board as shown in
In the preferred embodiment, the last microcontroller 248H is solely responsible for communicating with the floor controller microprocessor. All of the data received from the machines over the various current loop networks are passed along to the microcontroller 248H by the associated microcontroller. The microcontroller 248H analyses the data and determines whether the data needs to be communicated to the floor controller. If not, the last microcontroller records the communication but does not forward the data to the floor controller. This helps off-load some of the floor controller communication processing to the communication board.
The above-described system allows a casino in which the system is installed to run promotions on any properly equipped gaming machines while simultaneously gathering player tracking and accounting data from all machines. The system provides the capability for the casino to select which of the plurality of machines are used in any given promotion. The system further allows any number of different promotions to operate simultaneously.
Each promotion involves sending a reconfiguration command from the floor controller to a gaming device that has been selected to be part of a given promotion over the associated network. Upon receipt of the reconfiguration command, the gaming device reconfigures its payout schedule in accordance with the received reconfiguration command. As described above, reconfiguring a gaming device payout schedule, in the preferred embodiment, includes activating a bonus payout schedule that pays out bonus amounts in addition to the amount determined by the device payout table.
A partial list of the promotions according to the invention include, but are not limited to: a multiple jackpot wherein the gaming device reconfigures its payout to be a multiple of its default payout schedule; a bonus jackpot wherein the gaming device reconfigures its payout schedule to payout an additional bonus amount when certain conditions are met; and a progressive jackpot wherein two or more gaming devices are combined in a progressive jackpot having a progressive jackpot payout schedule. In addition to these, many other promotions are possible by the above-described system for controlling and monitoring a plurality of gaming devices.
The system 10 also allows for improved player tracking. As with standard player tracking, the above-described system monitors and reports how many coins are played by each player. The system 10, however, also includes the ability to record how long each player spends at each machine and the number of coins won, games played, and hand jackpots won by each player. All this information is stored on the database, which can be later analyzed for future targeted direct mailing campaigns. The player tracking according to the invention also allows the casino to schedule buses and other groups and measure their profitability. The system also allows for cashless play as well as advanced accounting and security features.
Another feature of the above-described system is jackpot announcements. The jackpot announcement feature displays a message on a reader board or display located in the casino which announces a jackpot as soon as a jackpot is won, i.e., as soon as the reels stop spinning. The floor controller generates the jackpot announcement once a DCN connected thereto indicates a jackpot is won. An example of such a message might be: “Now paying on machine 1342, a jackpot of $300.” With prior art data collection systems, the amount of the jackpot is only known after the payment is made. Even then the system must account for partial pays, hopper empty, etc.
An advantage of the current system over prior art systems is the ability to implement better tournament systems. In a slot tournament, players pay a fee to play. All play during the session is free. The players accumulate credits instead of cash. The person with the most credits at the end of the tournament wins. Games are usually manually altered to provide payouts of 200 to 300% to make the games more fun. The games are altered manually by replacing the read only memory (ROM) in the gaming devices.
One exciting aspect of tournament play is to see who is ahead. No current system can display this information in real time. This is because current systems can only measure winnings as they are added to the credit meter or paid from the hopper (some casinos use tournament tokens instead). Since credits are usually added at a rate of 10 per second, a 1,000 credit win can take 100 seconds to register. Casinos attempting to create display boards showing who is ahead are frustrated by the lag time. The jackpot announcement of the invention allows casinos to display the player with the most credits by comparing the number of credits for each player. This comparison and display is performed real time as each transaction is completed.
In order to implement each of these features, the various computers and microcontrollers each execute software or firmware. This software and firmware routines are described below. These routines are described with reference to accompanying flow charts. These flow charts would enable one of ordinary skill in the art of computer programming to write a corresponding computer program which the computer or microcontroller could execute.
1. Power up Procedure
Referring now to
Next the DCN controller checks the RAM in step 255 by reading the pattern of 1s and 0s back out of the RAM to ensure that the RAM is fully functional. If the RAM turns out to be defective the DCN controller goes into an endless loop in 256.
2. Reading Unique Identification Number
If the RAM is fully functional, the DCN then reads the unique identification number from the personality board. As described above, this unique identification number is stored in a nonvolatile memory 210 on the personality board. Reading the unique ID number out of the nonvolatile memory involves following the memory manufacturer's interface protocol as specified in the nonvolatile memory data sheet. The unique identification number provides a means for uniquely identifying the gaming device.
After the unique ID has been read from the personality board, the DCN processes the discrete machine inputs in step 260. This step will be described in further detail in Subsection 3, M
3. Monitoring Gaming Device Discrete Input
Referring now to
The DCN keeps track of the machine activity by maintaining several meters in memory. Each meter, in the preferred embodiment, includes six digits. Moreover, to improve the reliability of the system, the DCN maintains redundant backup copies of these meters with an order to replace the original meters in the event that the originals are corrupted. In step 268, the DCN increments the meters as required based on the discrete inputs. The meters are maintained even in the event that the DCN is disconnected from the floor controller. Once the DCN is reconnected to the floor controller, all the activity level information is then available. Step 268 will be discussed further below. Next, the DCN processes the drop door signal in step 270. The drop door signal DROP DOOR indicates that the drop door on the machine has been opened. This is an important event and is therefore processed separately.
In step 272, the DCN validates the meter values to determine whether the values stored in the meters are valid. The DCN checks whether the meter values are valid in step 274. In the preferred embodiment, a check sum is maintained for each meter value. Thus, the DCN in step 274 checks to see whether the check sum is correct based on the current meter value. If the meter values are okay, the discrete input monitoring step 260 is complete. If the meter values are not valid, the DCN replaces the meter values with the redundant back copy of the meter values in step 278, and then the step 260 is complete.
Referring now to
In step 286, the DCN sets the current message to the count down message. The count down message indicates to the player when he or she will be eligible for the bonus points. Finally, in step 288 the DCN sets the current bezel color and rate to a count down color and rate. This color and rate information is subsequently transmitted to the player tracking node for processing, as described further below. The countdown color indicates the bezel color and the count down rate indicates that flashing rate of the bezel color displayed during the count down message.
4. Processing Gaming Device Serial Interface
Referring now to
Any communication protocol can be used to implement this communication path over the serial machine interface, as is known in the art. An example of one such protocol uses a data packet including a command code, a message sequence number, a CRC, and a variable length message. In the preferred embodiment, either the DCN controller 46 or the machine can initiate communications over the serial machine interface. However, if the machine detects that the DCN is trying to send a message to the machine, the machine must abort its message and attempt to resend the message at a later time.
The preferred embodiment of the system supports many different reconfiguration commands. A partial list of the reconfiguration commands is given below in Table 1. These reconfiguration commands are sent from the DCN controller 46 to the machine over the serial machine interface wherein the machine reconfigures its payout schedule in accordance with the particular reconfiguration command. The reconfiguration commands do not originate with the DCN, instead the reconfiguration commands originate from the floor controller and are transmitted to a particular machine over the associated current loop network or the command can originate at one of the other computers on the high speed network. The DCN is simply responsible for forwarding the reconfiguration command onto the gaming device on receipt of the reconfiguration command over the associated current loop network coupled between the floor controller and the DCN.
The actual process of processing the machine serial interface begins in step 292 wherein the DCN polls the machine to determine its level of activity. This polling step includes sending a status message from the DCN to the machine over the serial machine interface. In response, the machine will send a packet of status information indicating the current amount of activity on the machine. The status information included in the response will depend on the type of machine that the DCN is communication with.
The data communication node 42, in step 294, waits for a reply to the status request. If a reply is received, the DCN indicates that the machine is “on line” in step 296 and processes the machine reply in 298. The step of processing the machine reply includes updating the meter values, as done when processing the discrete inputs. After the machine reply has been processed, the process 262 is complete.
If the DCN does not receive a reply from the machine in step 294, the DCN indicates that the machine is “off line”. The DCN will wait for a predetermined amount of time before deciding that the reply is not received. In the preferred embodiment, this predetermined period is approximately 110 milliseconds.
5. Processing Network Interface
Another step in the DCN power up procedure 252 is the step of processing the network interface 264. This step is described with reference to
Although each machine includes a unique identification number which could be used as the actual address for each DCN on the current loop, it is unnecessary to use the unique identification as the actual address because there are only a limited number of DCNs connected to each current loop. Accordingly, in the preferred embodiment of the invention, the floor controller uses a shorthand token representation of the DCN's unique identification number to address the DCN. In the preferred embodiment, a single byte address is used to address a DCN on any given current loop. This one-byte address allows up to 256 DCNs to be supported on any given current loop network. In the preferred embodiment, however, only 64 such DCNs are connected to a single current loop and therefore the single byte address is more than adequate. The single byte address substantially reduces the amount of traffic on the current loop network by reducing the number of bytes from four in the unique identification number to one for the shorthand token representation.
The floor controller is responsible for generating the unique single byte address for each data communication node on a given current loop network. The process of assigning unique single byte addresses to the DCNs is described below in Section C.
Once all the DCNs have been assigned a unique address, the DCN can begin monitoring the current loop network for messages addressed to it. If the DCN detects a message addressed to it, the DCN executes step 264. The DCN first checks to see whether the message is valid in step 304. This check is done by computing the CRC value of the message and comparing it to the CRC included with the message. If the two CRCs match, the message is valid and the DCN processes the network message in step 306. Processing the network message is described further below with reference to
Referring now to
Another type of message is one including configuration data for the DCN. This message allows the floor controller to implicitly set the DCN's memory to a fixed value. This message is used to override the DCN's internal variables, e.g., to get a DCN out of a lock-up condition, or to download new firmware to the DCN for execution. On receiving this type of message, the DCN simply overwrites its memory with the configuration data included in the configuration message in step 316. The DCN then builds an appropriate acknowledgment and transmits this acknowledgment message to the floor controller in step 320.
The other type of message is one sent in response to a DCN request. The DCN processes this data in step 318, which is described further in
The step of processing a floor controller message sent in response to a DCN request will now be described with reference to
The bonus type field of the data structure indicates the type of bonus state the machine is to be placed in. Examples of potential bonus modes include progressive/nonprogressive, multiple jackpot, or mystery jackpot. If the mystery jackpot is indicated, the mystery jackpot data included in the structure specifies the conditions under which the mystery jackpot is paid out. The mystery jackpot can be set to payout, e.g., after a certain number of coins in, handle pulls, which is specified by subfields of the mystery jackpot data.
The bonus time jackpot is a promotion wherein the machine pays out more than that dictated by its default payout schedule. In one embodiment of the bonus time promotion, the payout schedule of the machine can be modified to be a multiple of its default to payout schedule, as specified in subfield (A) of the bonus time data. This promotion can be used to encourage gaming activity during off-peak hours, e.g., midnight to 4 a.m. on weeknights. Alternatively, the bonus time promotion can be activated on a random basis. The timing of the multiple jackpot is specified by the casino on one of the computers connected to the network. The bonus time data also specifies the conditions under which the player becomes eligible for the bonus time jackpot. The subfield (B) of the bonus time data specifies whether the player is eligible for the bonus time data only if the player is playing the maximum coin in the machine. Subfield (C) limits the bonus time promotion to a predetermined number of seconds. This field limits the bonus time promotion to a predetermined number of seconds; if the player does not hit a jackpot within this specified time period, the bonus time promotion concludes. The minimum activity level can also be specified in subfield (D). This field can be used to specify the minimum activity level required by the player in order to be eligible for the bonus time jackpot. For example, the player can be required to play at least 20 coins over the last three minutes in order to be eligible for the bonus time jackpot. An indicator light on the player's machine can be used to indicate when the player reaches the minimum activity level and thereby becomes eligible for the bonus time jackpot.
In another embodiment of the bonus time promotion, a bonus amount is awarded in addition to the payout according to the default of the payout schedule of the machine. The amount of the bonus jackpot is specified in subfield (E) of the bonus time data. For example, this bonus time promotion might include five bonus amounts of $10, $25, $50, $100 and $500, which is specified by subfield (E). When a player hits a particular jackpot, whichever bonus amount is specified by the bonus amount subfield this amount is automatically paid out in addition to the payout amount determined by the machine's default payout schedule. This bonus time promotion can also be used in combination with subfields (C) and (D) to specify the conditions under which the player is eligible for this bonus time jackpot award.
After the DCN has stored the reconfiguration data in step 326, the DCN will then send the appropriate reconfiguration command to the machine over the serial machine interface in step 328. The machine, responsive to the received reconfiguration command, reconfigures its payout schedule in accordance with the received reconfiguration command. For example, if the reconfiguration command specifies a multiple jackpot condition, the machine will reconfigure its payout to be a multiple of its default payout schedule. The machine will reconfigure its payout schedule in a similar manner for the other bonus types.
The other type of data that can be included in a response from a DCN request is card data or player tracking data. This data is sent to the DCN in response to a status message from the DCN to the floor controller wherein the status message indicates that a player card has been inserted. Included in this message is the card ID number detected by the card reader. In response to this status message the floor controller will transmit a card insertion message to the DCN. The card insertion message includes information associated with the particular player ID number. An exemplary card insertion message data packet is listed below in Table 3.
Upon receipt of the card insertion message, the DCN stores the player's name and points in order for this information to be displayed on the VFD display associated with the player tracking node. Then, a DCN sets the current message to a data received message in step 334. Finally, a DCN sets the current bezel color and bezel rate to a data received bezel color and bezel rate in step 336. The bezel color specifies the bezel color to be displayed by the card reader and the bezel rate specifies the flashing rate of the card reader LEDs. This bezel information is subsequently transmitted to the player tracking node for processing thereby.
The final data type that can be included in the message sent from the floor controller in response to a DCN request is generically classified as other minor data. This data includes general system or DCN specific information such as display information.
6. Processing Player Tracking Interface
The next step in the DCN process is processing of the player tracking interface 266. The DCN maintains a variable that indicates what message is to be sent to the player tracking node. This variable is referred to as the current message variable. Before transmitting a message to the player tracking node, the DCN first checks this variable to see which of a plurality of messages should be sent to the player tracking node.
The process 266 begins in 340 by sending the current message to the player tracking node that is specified by the current message variable. In addition to the current message, the DCN sends the bezel color and bezel rate information to the player tracking node. The bezel color and bezel rate information could have been specified by the floor controller or by the DCN itself.
Next, the DCN determines the card status in step 342. If there is no card inserted in the card reader, the DCN sets the current message variable to an attract message. This message specifies that the player tracking node is to display a message which will attract players to the machine. Similarly, the DCN sets the current bezel color and bezel rate to an attract bezel color and rate in step 346. This attract color and rate is part of the attract message that will be sent to the player tracking node when the current message is sent.
If the DCN determines that a good card has been inserted in the card reader, the DCN processes the valid card in step 350. This step is described further below with reference to
If, however, the card status indicates that a bad card has been inserted, i.e., an invalid card number, the DCN sets the current message variable to specify a card error message in 352 and the DCN sets the current bezel color and bezel rate to a card error color and rate in 354. This card error information is included with the card error message that is sent to the player tracking node when the current message is sent.
7. Processing Card Insertion
Referring now to
If the card data has been received from the floor controller, the DCN then determines in step 366 whether player tracking has started for the particular player. If player tracking has not yet started, the DCN sets the current message variable to the data received message in step 368 and sets the current bezel color and rate to data received color and rate in step 370. If player tracking has started, the DCN processes the player tracking in step 372, as described with reference to
Processing player tracking 372 begins with the step of determining whether the player has received new points in 374. These points can be considered roughly as the equivalent of “frequent flyer miles” used by airlines. These points allow the system to run promotionals whereby individuals are given points or credit associated with their card that can be redeemed toward the purchase of goods or services offered by the casino. Typically these points are redeemed at a redemption counter in the casino for meals or clothing, for example. The points, therefore, are an additional inducement to encourage play.
The player tracking system of the invention allows the casino to determine how and when the player is issued points. The casino can specify the type and number of coins that must be played before a player is awarded a given number of points. The system uses this specified information to inform the player of his or her progress towards receiving additional points. The system encourages play by informing the player of how many additional coins must be played before receiving additional points. For example, a player who is only one coin away from receiving points, but who desires to stop playing, may decide to play “one last coin” in order to receive the points. The system informs the player by displaying a message on the vacuum florescent display indicating how many coins the player is away from receiving additional points.
Referring now to
If new points have been received, such as where the player has played a given number of coins, the DCN sets the current message variable to a points won message in step 382 and sets the current bezel color and rate to a points won color and rate in step 384. The points won message informs the player of the number of points won.
The above-described tracking process provides a means for providing visual feedback to the player inserting the card into the card reader. By modifying the bezel color and bezel rate, the data communication node provides immediate feedback to the player concerning the proper insertion of the card. If the player inserts the card properly into the card reader so that the card reader senses a valid user identification number, the card reader provides positive visual feedback to the user by illuminating the bezel. On the other hand, if the user improperly inserts the card so that the card reader cannot read the user identification number, the card reader can provide negative visual feedback to the player by illuminating the bezel with a different color and/or flashing rate. In the preferred embodiment, this positive visual feedback includes flashing the green LEDs to produce a flashing green signal around the card reader opening. The negative visual feedback includes flashing the red LEDs. A third combination color is used during the processing of the player tracking information. This process provides immediate feedback to the player concerning the insertion of the card in the card reader.
The system described above allows for improved player tracking by recording each and every machine transaction including: time of play, machine number, duration of play, coins in, coins out, hand paid jackpots and games played. The player tracking is conducted over the same network as the accounting data is extracted. This allows the invention to provide bonusing to certain individual players as well as during certain times. As with standard player tracking, the above-described system monitors and reports how many coins are played by each player. The system according to the invention, however, also includes the ability to record how long each player spends at each machine and the number of coins won, games played, and hand jackpots won by each player. The system is able to record all this information because the it operates on a transaction by transaction basis. Each transaction, whether it be a coin in, a handle pull, etc., is recorded by the system. Other prior art systems simply compile the player tracking information at the completion of play.
All the transaction information is stored on the database, which can be later analyzed for future targeted direct mailing campaigns. The player tracking according to the invention allows the casino to schedule buses and other groups and measure their profitability. Because the system records each transaction, the casino can reconfigure their casinos to better match the tastes and demands of their customers.
The improved player tracking according to the invention also allows the casino to calculate theoretical wins exactly because the system always includes the most current information. The operation of the player tracking procedure is described below.
1. Power up Procedure
The operation of the player tracking module will now be described with reference to
2. Processing DCN Interface
Referring now to
3. Processing Display Update
The process of updating the player tracking display is shown in
The player tracking controller then determines whether any such attribute information is found in the display message. If so, the player tracking controller sets up the display driver to incorporate the graphics mode specified by the attribute information. The player tracking controller then strips out any display attribute information from the display message in step 432 because the display attribute information is embedded in the display message. The remaining data in the display message is the actual text to be displayed by the player tracking display, e.g., the player's name. The player tracking controller then sends this text to the display in step 434, which is then displayed by the player tracking display.
4. Processing Bezel Update
The player tracking node is also responsible for updating the bezel, both in terms of its color and flashing rate. This process 412 is shown in
Next, the process determines the bezel rate as specified by the DCN. In a first case, the bezel rate is zero or off and thus the player tracking controller turns the LEDs off in step 442 in this case. If the bezel rate specifies a flashing rate, the player tracking controller flashes the bezel at the appropriate bezel rate in step 442. Flashing the bezel involves turning the LEDs on and off at the specified rate. This can be accomplished by a timer interrupt or a timing loop executed by the player tracking controller. The final option is that the rate can be infinite or effectively a solid bezel color. In this case, the player tracking controller simply leaves the card reader LEDs on in step 446. This completes the processing bezel update process 412.
5. Processing Card Reader
The next process step for the player tracking node is to process the card reader. This process 414 is shown in
If the player tracking controller determines that a valid card was inserted in the card reader, the player tracking controller sets a card status variable equal to good card. This card status is then subsequently transmitted to the DCN controller. Then, the player tracking controller sets a card ID variable equal to the identification number read by the card reader in step 454. The card status and the card ID provide the DCN with sufficient information to instigate the player tracking.
If, on the other hand, the card reader indicates that the card was read improperly or that the card is an invalid card for the card reader, the player tracking controller sets the card status variable to bad card in step 458 and the card ID variable is cleared in step 460. If neither a valid or invalid card condition was detected in 450, the player tracking controller sets the card status variable to no card in step 462 and clears out the card ID in 460.
1. Power up Procedure
Referring now to
The floor controller process 464 begins at step 466 by opening the database tables in the file server. As described above, the file server includes a commercially-available database program which stores the machine activity information as well as player tracking information and associated system characteristic parameters. This step 466 can also include fetching some or all of these system characteristics in order to trigger certain events such as bonus jackpots, as described below.
In step 468, the floor controller terminates any active player tracking sessions in the database. Because player tracking may have been in progress when the floor controller became inoperable, when the floor controller powers up or becomes operable, there may be player tracking sessions initially active. In this step, the floor controller terminates any such active player tracking sessions in order to place the database in an initial state.
Another step that the floor controller executes after becoming operable is to place an initial machine search message in an output message queue 470. This search message is used by the floor controller to determine which machines are connected to the floor controller. This output message is subsequently transmitted to all of the machines coupled to the floor controller using a global message format, as described below with reference to
The bulk of the work performed by the file server process 464 is performed in message processing step 472. In this step, the floor controller processes all messages sent to or received from the machines connected thereto. This step will be described further below with references to
The process 464 also includes a system monitoring step 474. This system monitoring step 474 administers certain system-wide events. These system-wide events include the counting-related events and bonusing events. The floor controller continuously checks to see whether any of these events have been triggered. If any event has been triggered, such as a bonusing event, the floor controller takes the appropriate action to handle the event. The event may be triggered by the time and day or by user intervention or other event. The system monitoring step 474 will be described further below with reference to
The final step in process 464 is for the floor controller to check for a termination condition in step 476. In the preferred embodiment, the floor controller checks to determine whether an ESCape key as pressed. If an ESC key was pressed, the floor controller terminates the process 464. If no ESC key was pressed, the floor controller loops back to step 472 wherein the message-processing step and the system monitoring step are repeated. The floor controller continues in the loop 472-476 until the termination condition is sensed.
2. Message Processing
As described above, the floor controller acts as a gateway between the machines connected thereto and the file server, as shown in
The first step in processing the messages is for the floor controller to send any messages that are queued-up in the output message queue to the appropriate data communication node in step 480. As described above, the output message queue is a simple data structure that is used to store any pending messages. Included in the message is a destination address by which the floor controller can determine which of the plurality of data communication nodes to send the message to. Next the floor controller receives any incoming messages from the data communication nodes coupled to the floor controller in step 482. Once an incoming message has been received, the floor controller parses through the message data included in the incoming message in steps 484 through 486. In the preferred embodiment, the floor controller parses through the message data one byte at a time. Thus, in step 484 the floor controller reads the next byte in the incoming message, and in step 486 the floor controller checks to see whether this is the last byte in the message. In the preferred embodiment, the message includes a message length field which indicates the number of data bytes included in the message. In this case, a floor controller in step 486 checks to see whether the number of bytes read in step 484 is equal to the number of bytes specified by the message length field.
Once the input message data has been parsed out of the incoming message, the floor controller takes the appropriate match in response to the message data in step 488. This step is described further below with reference to
Referring now to
The first type of message can be one which includes new meter information. The floor controller checks in step 498 to determine whether the message includes this type of information. If the message includes new meter information, the floor controller saves the new meter information locally in step 500. The floor controller maintains local copies of the meter information in order to minimize the amount of traffic on the high-speed network. Because the machine meters change so rapidly, forwarding this new meter information on to the file server each time one of these meters is altered would produce an excessive amount of network traffic on the high-speed network. Therefore, in the preferred embodiment, the floor controller saves this new meter information locally in step 500 and only forwards the new information on to the file server after a predetermined amount of time has elapsed.
Another type of message is one which requests data. The floor controller checks in step 502 to determine whether the message type is one requesting data. Typically, these data requests will be for player tracking information such as where a player inserts a card into a card reader whereupon the data communication associated therewith sends the identification number encoded on the card to the floor controller requesting the player tracking data associated with the player identification number. If the floor controller detects a data request in step 502, the floor controller looks up the requested data in the database on the file server in step 504. Also, in step 504, the floor controller marks a response pending in the transactions in progress structure to indicate that this requested data needs to be sent back to the DCN. As described above, the floor controller queues up outgoing messages responsive to the transactions in progress structure.
Another message type is one used by the floor controller to establish new machine addresses. The floor controller periodically checks to determine whether any new DCN has been coupled to its associated current loop networks in order to assign a unique address to that machine. In step 506, the floor controller checks to see whether the incoming message is in response to such a process. If the incoming message is in response to a machine search, the floor controller assigns a new machine address to the responding machine in step 508. The entire process of assigning new machine addresses is described below with reference to
Finally, the floor controller in step 510 handles any miscellaneous messages. These miscellaneous messages are used primarily for debugging and trouble-shooting the machines.
3. Assigning Gaming Device Addresses
As described above, in the preferred embodiment of the invention, the floor controller uses a shorthand token representation of the DCN's unique identification number to address the DCN. In the preferred embodiment, a single byte address is used to address a DCN on any given current loop. This one-byte address allows up to 256 DCNs to be supported on any given current loop network. In the preferred embodiment, only 64 such DCNs are connected to a single current loop network and therefore the single byte address is more than adequate. The single byte address substantially reduces the amount of traffic on the current loop network by reducing the number of bytes from four in the unique identification number to one for the shorthand token representation.
The floor controller is responsible for generating the unique single byte address for each data communication node on a given current loop network. The process 508 of assigning unique addresses to the DCNs on the current loop network is shown in
Next, the floor controller sends out a message to all of the DCNs on the current loop network in step 514. The floor controller communicates with the DCNs by using a standard communication protocol. In the preferred embodiment, this protocol defines a message format including a destination ID, a source ID, a message length, a data packet and a CRC. Other message formats could be used as well. Using this format, the floor controller can communicate with all of the DCNs on the current loop network by using a global destination address in the message. This global destination address would indicate to the DCNs that this message is intended for all DCNs on the current loop network. This global message would include two unique identification numbers that, taken together, define the range of unique identification numbers established in step 512.
The individual DCNs then checks to see whether their unique identification number falls within this range. If a DCN's unique identification number falls within this range and the DCN does not have an address assigned thereto, the DCN then responds to this global message by sending a reply message in response that includes the unique identification number of that DCN. In the event that more than one DCN has a unique identification number that falls within this range a network collision will occur and the message will be corrupted. The process 508 checks for this condition in step 516. This condition is indicated by an invalid CRC in the message.
In the event of a network collision, the floor controller can limit the range of unique identification numbers by repeating step 512 in the hope of eliminating this network contention.
If the response has a valid CRC, the floor controller assigns a unique address to the responding DCN, as identified by the unique identification number in the response, in step 518. The floor controller then transmits this address along with the corresponding unique identification number in an assignment message to all of the DCNs using a global destination address in step 520. The DCNs then process this message and in the event that the unique identification number included in the message corresponds to the DCN's unique identification number, the DCN adopts the address included in the message. Once the DCN has been assigned an address in this manner, the DCN will interpret all subsequent messages having a destination address equal to the assigned DCN address as being directed to that DCN. The above-described address assignment sequence is repeated for each of the remaining DCNs on the current loop network in step 522. The floor controller continues this process until the entire range of unique identification numbers has been covered and no more network collisions occur.
4. System Monitoring
Referring now to
The floor controller also monitors the locally-stored meter information in step 528. If the locally-stored information is changed, the floor controller saves the latest information to the data base in step 530. As described above, the floor controller saves the meter information locally in order to minimize the traffic to the file server over the high speed network.
The floor controller also monitors the system for certain event triggers in step 532. These triggers can be stored in the data base and fetched by the floor controller during its power-up procedures. These triggers indicate if and when certain events occur. Examples of event triggers include: the drop period, the end-of-day, the bonus period, etc. If an event trigger has occurred, the floor controller handles the event in step 534.
The handle event step 534 is shown in more detail in
The other type of event can be referred to as a bonusing event. The floor controller checks to see whether the event is a bonusing event in step 540. The bonusing events can also be triggered by the time of day. For example, the bonusing event may be triggered from midnight to 4:00 a.m. on weekdays. These bonusing periods can be specified in the data base. If the triggered event is a bonusing event, the floor controller inserts a corresponding reconfiguration message in the output message queue in step 542. The reconfiguration message includes a reconfiguration command that is sent to an appropriate machine. The machine, upon receiving the reconfiguration command, reconfigures its payout schedule in accordance with the received reconfiguration command. According to the invention, there are many different reconfiguration commands to implement a multiplicity of different bonusing events. One reconfiguration command specifies that the machine should reconfigure its payout schedule to be a multiple of its default payout schedule. This reconfiguration command can also specify that the multiple payout schedule should be limited to a predetermined percentage of the coins in. This reconfiguration command can further specify that the multiple payout schedule should be limited to only when the maximum coins are played. This reconfiguration command can further specify that the multiple payout schedule should be limited to payouts in a specified range. This reconfiguration command can also specify the multiple payout schedule should payout only when a predetermined level of player activity is reached.
Another reconfiguration command allows any number of machines on the network to be combined in a common jackpot having a common jackpot payout schedule, wherein the reconfiguration command reconfigures the selected machines to payout in accordance with the common jackpot payout schedule. In this case, the reconfiguration message would be queued up for each of the selected machines to be combined in a common jackpot. One example of a common jackpot is a progressive jackpot. Unlike the prior art progressive jackpot systems, however, the progressive jackpot according to the invention is not limited to a predetermined number of machines. In the prior art progressive jackpot systems, a bank of machines are connected to a common progressive jackpot controller and only those machines can be included in the progressive jackpot. In contrast, any machine on the network, including those connected to other floor controllers can be combined into a common progressive jackpot. Moreover, the number of progressive jackpots is not limited by the number of floor controllers since one floor controller can manage more than one progressive jackpot.
Another reconfiguration command permits the system to implement so-called “automatic mystery jackpots.” These “mystery” jackpots allow a machine to payout a mystery jackpot even when a jackpot was not won. Instead, the reconfiguration command can specify that the mystery jackpot is to occur after a certain number of coins, a certain number of handle pulls, or a variety of other conditions specified by the reconfiguration commands. These mystery bonuses provide the casino with another way to induce additional gaming activity.
5. Bonus Control
Referring now to
The method 550 begins in step 552 by disabling or turning off the bonuses in the individual machines. This is accomplished by sending a message to the individual DCNs to turn off or deactivate bonusing. Next, the floor controller monitors the activities of the individual machines connected thereto. This step includes monitoring the coins in and bonuses paid for the individual machines, as described above. In step 556, the floor controller modifies a bonus pool by a predetermined percentage of all coins played. The bonus pool is essentially a pool of monetary resources that can be allocated for bonus awards. In the preferred embodiment, a predetermined percentage of the monetary value of the coins played are added to the bonus pool. Also in this step, any bonuses paid by the gaming devices are also measured and subtracted from the bonus pool. The use of the bonus pool will become more apparent when the other steps are described hereinbelow.
In step 558, the floor controller determines whether or not bonusing is active. If bonusing is active, the floor controller next determines whether the bonus pool amount has dropped below a predetermined minimum level called the “turn-off” level in 560. This minimum amount or floor can be set by the casino and provides a buffer to account for large bonus awards and/or multiple bonus awards that could cause the bonus payout to exceed the bonus pool. Therefore, if the bonus pool drops below the turn-off level, the method 550 branches back to step 552 and turns off bonusing. As will described further below, the bonusing remains off until such time as the bonus pool builds up past another minimum level called the “turn-on” level.
Returning to step 558, if the bonus is currently not active, the floor controller determines at step 562 whether the bonus pool has reached a predetermined turn-on level. This turn-on level can also be set by the casino and provides a buffer above the turn-off level to insure that the bonusing does not behave erratically, i.e., bonusing rapidly switching between on and off. If the bonus pool is not above the turn-on level, bonusing is again turned off in step 552.
If the bonus pool has reached the turn-on level, the floor controller checks to see whether other bonus conditions are met at step 564. These bonus conditions can include, but are not limited to, a minimum period of time since the last bonus activation, a minimum level of play in the time period prior to the bonus pool reaching the turn on level, a predetermined time of day, or other predetermined conditions. These conditions give the casino additional control over the bonusing promotions. If the conditions are not met, the method 550 branches back to step 552 where the bonusing is again turned off. If, however, the conditions are met in step 564, the bonus is turned on at step 566 and the method 550 branches to step 554 where the machine activity is again monitored.
In the preferred embodiment, the method 550 is embodied in software that is executed by each of the floor controllers in the system. These floor controllers are then responsible for activating or deactivating the bonusing for the individual machines connected thereto. The system allows the floor controller to have multiple bonus pools and to have certain of the machines associated with a given bonus pool. Thus, the floor controller can implement multiple bonusing promotions simultaneously.
This system also allows for machines connected to different floor controllers to be combined into a single bonusing promotion. In this case, one of the floor controllers assumes primary responsibility for managing the bonus pool while the other floor controllers act as intermediaries between the primary floor controller and the machines connected to the other floor controllers. Thus, the system according to the invention allows for much greater flexibility in running bonusing promotionals than heretofore possible. Prior art systems required certain predetermined machines to be connected into a bank for any given bonus award such as a progressive bonus. The system according to the invention allows any machine in the casino to be combined in a bonus type situation. The system also insures that the bonusing promotionals will operate substantially in the black, i.e., the bonus pool is greater than the bonus payouts.
Having described and illustrated the principles of the invention in a preferred embodiment thereof, it should be apparent that the invention can be modified in arrangement and detail without departing from such principles. For example, although an Ethernet network was described in the preferred embodiment of the invention, other high-speed networks such as wireless networks could be used in place thereof. I claim all modifications and variation coming within the spirit and scope of the following claims.
This application is a continuation of prior application Ser. No. 09/827,870, filed Apr. 6, 2001, which is a continuation of prior application Ser. No. 08/922,046, filed Sep. 2, 1997, now U.S. Pat. No. 6,257,981, which is a continuation of application Ser. No. 08/465,717, filed Jun. 6, 1995, now U.S. Pat. No. 5,836,817, which is a divisional of application Ser. No. 08/322,172, filed Oct. 12, 1994, now U.S. Pat. No. 5,655,961.
Number | Date | Country | |
---|---|---|---|
Parent | 08322172 | Oct 1994 | US |
Child | 08465717 | Jun 1995 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 09827870 | Apr 2001 | US |
Child | 10932615 | Sep 2004 | US |
Parent | 08922046 | Sep 1997 | US |
Child | 09827870 | Apr 2001 | US |
Parent | 08465717 | Jun 1995 | US |
Child | 08922046 | Sep 1997 | US |