A portion of the disclosure of this patent document contains material which is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent disclosure, as it appears in the Patent and Trademark Office patent files or records, but otherwise reserves all copyright rights whatsoever. Copyright 2020, Scientific Games International, Inc.
The present invention relates generally to gaming systems, apparatus, and methods and, more particularly, to image analysis of gaming environments for establishing links between players and gaming elements, such as tokens or gaming devices.
Casino gaming environments are dynamic environments in which the actions of players and/or casino operators may affect subsequent actions, the state of the gaming environment, and/or the state of the player. For example, a player may be associated with one or more tokens that are used to place wagers on a wagering game. Based on the outcome of the placed wagers, a credit balance of the player as represented by the remaining tokens held by the player may change, which may influence subsequent wagers by the player. A multitude of other changes may occur at any given time. To effectively manage such a dynamic environment, the casino operators may employ one or more tracking systems or techniques to monitor aspects of the casino gaming environment, such as credit balance, player account information, and the like. The tracking systems may generate a historical record of these monitored aspects to enable the casino operators to facilitate, for example, a secure gaming environment, enhanced game features, and/or enhanced player features (e.g., rewards and benefits to known players with a player account).
At least some of the tracking systems may be used to monitor games with a plurality of players in which each player may place a respective wager. For example, the tracking systems may be used to monitor card-based games at a casino gaming table. The tracking systems may monitor one or more aspects of the card-based game to aid a dealer in tracking game progression, enforcing rules, and/or managing payouts. However, at least some known tracking systems may be limited in their ability to monitor the game because the tracking systems are configured to monitor specific, predetermined areas of the casino table. The predetermined areas are used to provide context to the data collected by the tracking systems, such as which player placed a wager. In instances in which back-betting (also referred to herein as “back wagers”) is allowed, the players may not be limited to the seats or other predetermined areas of the casino gaming table, which may reduce the effectiveness of these known tracking systems in providing accurate data and may potentially create security issues in which unmonitored back wagers are provided using fake tokens.
Accordingly, a new tracking system that is adaptable to the dynamic nature of casino gaming environments is desired.
According to one aspect of the present disclosure, system for tracking players and tokens in a casino gaming environment is provided. The system including at least one image sensor that captures image data of a gaming table and a player area associated with the gaming table, and a tracking controller communicatively coupled to the image sensor to receive the captured image data. The tracking controller detects a player occupying the player area and a token set from the captured image data at least by applying at least one image neural network model to the captured image data to generate at least one key player data element for the player and to generate at least one key token data element for the token set, generates a player data object representing physical characteristics of the player based on the key player data elements, links the player data object to a player identifier associated with the player, generates a token identifier for the detected token set based on the key token data elements, and links the token identifier to the player data object based on a physical relationship between the player and the token set indicated by the key player data elements and the key token data elements.
According to another aspect of the disclosure, a method for tracking players and tokens in a casino gaming environment is provided. The method includes capturing, by an image sensor, image data of a gaming table and a player area associated with the gaming table, receiving, by a tracking controller, the captured image data from the image sensor, detecting, by the tracking controller, a player occupying the player area and a token set from the captured image data at least by applying at least one image neural network model to the captured image data to generate at least one key player data element for the player and to generate at least one key token data element for the token set, generating a player data object representing physical characteristics of the player based on the at least one key player data element, linking, by the tracking controller, the player data object to a player identifier associated with the player, generating, by the tracking controller, a token identifier for the detected token set based on the at least one key token data element, and linking, by the tracking controller, the token identifier to the player data object based on a physical relationship between the player and the token set indicated by the at least one key player data element and the at least one key token data element.
According to yet another aspect of the disclosure, a tracking controller for a casino gaming environment is provided. The tracking controller includes a communication device communicatively coupled to an image sensor that captures image data of a gaming table and a player area associated with the gaming table, at least one processor, and a memory device communicatively coupled to the at least one processor. The memory device stores computer-executable instructions that, when executed by the at least processor, cause the tracking controller to detect a player occupying the player area and a token set from the captured image data at least by applying at least one image neural network model to the captured image data to generate at least one key player data element for the player and to generate at least one key token data element for the token set, generate a player data object representing physical characteristics of the player based on the at least one key player data element, link the player data object to a player identifier associated with the player, generate a token identifier for the detected token set based on the at least one key token data element, and link the token identifier to the player data object based on a physical relationship between the player and the token set indicated by the at least one key player data element and the at least one key token data element.
Additional aspects of the invention will be apparent to those of ordinary skill in the art in view of the detailed description of various embodiments, which is made with reference to the drawings, a brief description of which is provided below.
While the invention is susceptible to various modifications and alternative forms, specific embodiments have been shown by way of example in the drawings and will be described in detail herein. It should be understood, however, that the invention is not intended to be limited to the particular forms disclosed. Rather, the invention is to cover all modifications, equivalents, and alternatives falling within the spirit and scope of the invention as defined by the appended claims.
While this invention is susceptible of embodiment in many different forms, there is shown in the drawings and will herein be described in detail preferred embodiments of the invention with the understanding that the present disclosure is to be considered as an exemplification of the principles of the invention and is not intended to limit the broad aspect of the invention to the embodiments illustrated. For purposes of the present detailed description, the singular includes the plural and vice versa (unless specifically disclaimed); the words “and” and “or” shall be both conjunctive and disjunctive; the word “all” means “any and all”; the word “any” means “any and all”; and the word “including” means “including without limitation.”
For purposes of the present detailed description, the terms “wagering game,” “casino wagering game,” “gambling,” “slot game,” “casino game,” and the like include games in which a player places at risk a sum of money or other representation of value, whether or not redeemable for cash, on an event with an uncertain outcome, including without limitation those having some element of skill. In some embodiments, the wagering game involves wagers of real money, as found with typical land-based or online casino games. In other embodiments, the wagering game additionally, or alternatively, involves wagers of non-cash values, such as virtual currency, and therefore may be considered a social or casual game, such as would be typically available on a social networking web site, other web sites, across computer networks, or applications on mobile devices (e.g., phones, tablets, etc.). When provided in a social or casual game format, the wagering game may closely resemble a traditional casino game, or it may take another form that more closely resembles other types of social/casual games.
As used herein, a “back wager” is a wager provided by a passive participant of a wagering game sometimes referred to herein as a “back player” or “passive player.” Unlike an active participant that may perform actions beyond wagering (e.g., drawing cards), a passive player may not have any control in the game beyond what player, outcome, or other aspect on which the back wager is provided. In certain embodiments, the back players may have some form of active participation that is differentiated from the active participation of an active player. For example, a base game feature may only include participation by active players, while a bonus game feature of the wagering game may include the back players as active participants.
In some embodiments, back wagers may be placed on active players such that a winning outcome for the active player causes the associated back wagers to result in payouts. The payouts may be based on a payout table of the wagering game or a dedicated payout table for back wagers. In other embodiments, the back wagers may be placed irrespective of the active players, such as back wagers on the occurrence of a particular outcome or card sequence (e.g., royal flush). It is to be understood that several forms of back wagers (including the ones described above) may be present within a wagering game. The placement and resolution of the back wagers may occur before, after and/or concurrent to the placement and resolution of active wagers depending upon the rules and nature of the wagering game.
Systems and methods described herein facilitate tracking of players and game elements within a gaming environment. In particular, the systems and methods described herein may (i) capture image data of a gaming table and an associated player area, (ii) analyze the captured image data at least using one or more imaging deep neural networks and/or other imaging analysis tools to translate the captured image data into key data elements representing aspects of players and gaming tokens detected in the image data, and (iii) by analyzing the key data elements and determining a physical relationship between the tokens and a player (e.g., tokens secured in the player's hand), linking the tokens to the player.
Linking tokens to a player may facilitate, for example, improved payout tracking, especially for games in which participation is not limited to players seated at the gaming table. That is, players may be able to participate in such games through back wagers. The number of back players and/or the positioning of the back players (i.e., the back players may move during play of the game) may cause confusion for the dealer when determining payouts. The systems and methods described herein may provide the dealer with an indication of the correct recipient of a particular payout. In at least some embodiments, the systems and methods described herein may facilitate improved security against counterfeit gaming tokens, which may be another risk in games with back wagers. If a counterfeit gaming token is detected, the systems and methods described herein may store a historical record of the token, which may be used to trace back to the original player of the counterfeit token.
Furthermore, the systems and methods described herein may enable improved player tracking for player accounts by reducing the burden on the player and/or dealer to indicate to a player tracking system the player's identity. That is, in at least some known player tracking systems, the player may be required to swipe a card associated with the player's account to “card-in” at the gaming table, and otherwise the player's participation may not be recorded to his or her player account. The card-in requirement may forgotten and/or inconvenient to some players (particularly to back players that may not have easy access to a card-in device at the gaming table), and thus eliminating or otherwise reducing this requirement may improve player tracking.
The gaming area 101 is an environment in which one or more casino wagering games are provided. In the example embodiment, the gaming area 101 is a casino gaming table and the area surrounding the table (an example of which is shown in
The game controller 102 is configured to facilitate, monitor, manage, and/or control gameplay of the one or more games at the gaming area 101. More specifically, the game controller 102 is communicatively coupled to at least one or more of the tracking controller 104, the sensor system 106, the tracking database system 108, a gaming device 110, an external interface 112, and/or a server system 114 to receive, generate, and transmit data relating to the games, the players, and/or the gaming area 101. The game controller 102 may include one or more processors 116, memory devices 118, and a communication device 120 to perform the functionality described herein. More specifically, the memory devices 118 store computer-readable instructions that, when executed by the processors 116, cause the game controller 102 to function as described herein, including communicating with the devices of the system 100 via the communication device 120.
The game controller 102 may be physically located at the gaming area 101 as shown in
The gaming device 110 is configured to facilitate one or more aspects of a game. For example, for card-based games, the gaming device 110 may be a card shuffler, shoe, or other card-handling device. The external interface 112 is a device that presents information to a player, dealer, or other user and may accept user input to be provided to the game controller 102. In some embodiments, the external interface 112 may be a remote computing device in communication with the game controller 102, such as a player's mobile device. The server system 114 is configured to provide one or more backend services and/or gameplay services to the game controller 102. For example, the server system 114 may include accounting services to monitor wagers, payouts, and jackpots for the gaming area 101. In another example, the server system 114 is configured to control gameplay by sending gameplay instructions or outcomes to the game controller 102. It is to be understood that the devices described above in communication with the game controller 102 are for exemplary purposes only, and that additional, fewer, or alternative devices may communicate with the game controller 102, including those described elsewhere herein.
In the example embodiment, the tracking controller 104 is in communication with the game controller 102. In other embodiments, the tracking controller 104 is integrated with the game controller 102 such that the game controller 102 provides the functionality of the tracking controller 104 as described herein. Like the game controller 102, the tracking controller 104 may be a single device or a distributed computing system. In one example, the tracking controller 104 may be at least partially located remotely from the gaming area 101. That is, the tracking controller 104 may receive data from one or more devices located at the gaming area 101 (e.g., the game controller 102 and/or the sensor system 106), analyze the received data, and/or transmit data back based on the analysis.
In the example embodiment, the tracking controller 104, similar to the example game controller 102, includes one or more processors 122, a memory device 124, and at least one communication device 126. The memory device 124 is configured to store computer-executable instructions that, when executed by the processor(s) 122, cause the tracking controller 104 to perform the functionality of the tracking controller 104 described herein. The communication device 126 is configured to communicate with external devices and systems using any suitable communication protocols to enable the tracking controller 104 to interact with the external devices and integrates the functionality of the controller 104 with the functionality of the external devices. The tracking controller 104 may include several communication devices 126 to facilitate communication with a variety of external devices using different communication protocols.
The tracking controller 104 is configured to monitor at least one or more aspects of the gaming area 101. In the example embodiment, the tracking controller 104 is configured to monitor at least the players within the gaming area 101, the gaming tokens within the area 101, and the relationship between each monitored player and each monitored stack of gaming tokens. The tokens may be any physical object (or set of physical objects) used to place wagers. As used herein, the term “stack” refers to one or more gaming tokens physically grouped together. For circular tokens typically found in casino gaming environments, these may be grouped together into a vertical stack. In another example in which the tokens are monetary bills and coins, a group of bills and coins may be considered a “stack” based on the physical contact of the group with each other and other factors as described herein.
In the example embodiment, the tracking controller 104 is communicatively coupled to the sensor system 106 to monitor the gaming area 101. More specifically, the sensor system 106 includes one or more sensors configured to collect sensor data associated with the gaming area 101, and the tracking system 104 receives and analyzes the collected sensor data to detect and monitor players and tokens. The sensor system 106 may include any suitable number, type, and/or configuration of sensors to provide sensor data to the game controller 102, the tracking controller 104, and/or another device that may benefit from the sensor data.
In the example embodiment, the sensor system 106 includes at least one image sensor 128 that is oriented to capture image data of players and tokens in the gaming area 101. In one example, the sensor system 106 may include a single image sensor 128 that monitors the gaming area 101. In another example, the sensor system 106 includes a plurality of image sensors 128 that monitor subdivisions of the gaming area 101. The image sensor 128 may be part of a camera unit of the sensor system 106 or a three-dimensional (3D) camera unit in which the image sensor 128, in combination with other image sensors 128 and/or other types of sensors, may collect depth data related to the image data, which may be used to distinguish between objects within the image data. The image data is transmitted to the tracking controller 104 for analysis as described herein. In some embodiments, the image sensor 128 is configured to transmit the image data with limited image processing or analysis such that the tracking controller 104 and/or another device receiving the image data performs the image processing and analysis. In other embodiments, the image sensor 128 may perform at least some preliminary image processing and/or analysis prior to transmitting the image data. In such embodiments, the image sensor 128 may be considered an extension of the tracking controller 104, and as such, functionality described herein related to image processing and analysis that is performed by the tracking controller 104 may be performed by the image sensor 128 (or a dedicated computing device of the image sensor 128). In certain embodiments, the sensor system 106 may include, in addition to or instead of the image sensor 128, one or more sensors configured to detect objects, such as time-of-flight sensors, radar sensors (e.g., LIDAR), and the like.
The tracking controller 104 is configured to establish data structures relating to each player and token stack detected in the image data from the image sensor 128. In particular, in the example embodiment, the tracking controller 104 applies one or more image neural network models during image analysis that are trained to detect aspects of players, tokens, and/or combinations thereof. Neural network models are analysis tools that classify “raw” or unclassified input data without requiring user input. That is, in the case of the raw image data captured by the image sensor 128, the neural network models may be used to translate patterns within the image data to data object representations of, for example, tokens, faces, hands, etc., thereby facilitating data storage and analysis of objects detected in the image data as described herein.
At a simplified level, neural network models are a set of node functions that have a respective weight applied to each function. The node functions and the respective weights are configured to receive some form of raw input data (e.g., image data), establish patterns within the raw input data, and generate outputs based on the established patterns. The weights are applied to the node functions to facilitate refinement of the model to recognize certain patterns (i.e., increased weight is given to node functions resulting in correct outputs), and/or to adapt to new patterns. For example, a neural network model may be configured to receive input data, detect patterns in the image data representing human faces, and generate an output that classifies one or more portions of the image data as representative of human faces (e.g., a box having coordinates relative to the image data that encapsulates a face and classifies the encapsulated area as a “face” or “human”).
To train a neural network to identify the most relevant guesses for identifying a human face, for example, a predetermined dataset of raw image data including human faces and with known outputs is provided to the neural network. As each node function is applied to the raw input of a known output, an error correction analysis is performed such that node functions that result in outputs near or matching the known output may be given an increased weight while node functions having a significant error may be given a decreased weight. In the example of identifying a human face, node functions that consistently recognize image patterns of facial features (e.g., nose, eyes, mouth, etc.) may be given additional weight. The outputs of the node functions (including the respective weights) are then evaluated in combination to provide an output such as a data structure representing a human face. Training may be repeated to further refine the pattern-recognition of the model, and the model may still be refined during deployment (i.e., raw input without a known data output).
At least some of the neural network models applied by the tracking controller 104 may be deep neural network (DNN) models. DNN models include at least three layers of node functions linked together to break the complexity of image analysis into a series of steps of increasing abstraction from the original image data. For example, for a DNN model trained to detect human faces from an image, a first layer may be trained to identify groups of pixels that may represent the boundary of facial features, a second layer may be trained to identify the facial features as a whole based on the identified boundaries, and a third layer may be trained to determine whether or not the identified facial features form a face and distinguish the face from other faces. The multi-layered nature of the DNN models may facilitate more targeted weights, a reduced number of node functions, and/or pipeline processing of the image data (e.g., for a three-layered DNN model, each stage of the model may process three frames of image data in parallel).
In at least some embodiments, each model applied by the tracking controller 104 may be configured to identify a particular aspect of the image data and provide different outputs such that the tracking controller 104 may aggregate the outputs of the neural network models together to identify and link players and tokens as described herein. For example, one model may be trained to identify human faces, while another model may be trained to identify the bodies of players. In such an example, the tracking controller 104 may link together a face of a player to a body of the player by analyzing the outputs of the two models. In other embodiments, a single DNN model may be applied to perform the functionality of several models.
As described in further detail below, the tracking controller 104 may generate a player data object and/or a token data object for each player and token, respectively, identified within the captured image data by the DNN models. The player and token data objects are data structures that are generated to link together data associated with a corresponding player or token. For example, the outputs of several DNN models associated with a player may be linked together as part of the player data object.
It is to be understood that the underlying data storage of the player and token data objects may vary in accordance with the computing environment of the memory device or devices that store the data object. That is, factors such as programming language and file system may vary the where and/or how the data object is stored (e.g., via a single block allocation of data storage, via distributed storage with pointers linking the data together, etc.). In addition, some data objects may be stored across several different memory devices or databases.
In the example embodiment, the player data objects include a player identifier, and the token data objects include a token identifier. The player and token identifiers uniquely identify a player or stack of tokens, respectively, such that the data stored within the player and token data objects is tied to the player or stack of tokens. In at least some embodiments, the player identifier and/or the token identifier may be incorporated into other systems or subsystems. For example, a player account system may store player identifiers as part of player accounts, which may be used to provide benefits, rewards, and the like to players. In certain embodiments, the player identifier and/or the token identifier may be provided to the tracking controller 104 by other systems that may have already generated the identifiers.
In at least some embodiments, the player data objects, the player identifiers, the token data objects, and/or the token identifiers may be stored by the tracking database 108. The tracking database 108 includes one or more data storage devices that store data from at least the tracking controller 104 in a structured, addressable manner. That is, the tracking database 108 stores data according to one or more linked metadata fields that identify the type of data stored and can be used group stored data together across several metadata fields. The stored data is addressable such that stored data within the tracking database 108 may be tracked after initial storage for retrieval, deletion, and/or subsequent data manipulation (e.g., editing or moving the data). The tracking database 108 may be formatted according to one or more suitable file system structures (e.g., FAT, exFAT, ext4, NTFS, etc.).
The tracking database 108 may be a distributed system (i.e., the data storage devices are distributed to a plurality of computing devices) or a single device system. In certain embodiments, the tracking database 108 may be integrated with one or more computing devices configured to provide other functionality to the system 100 and/or other gaming systems. For example, the tracking database 108 may be integrated with the tracking controller 104 or the server system 114.
In the example embodiment, the tracking database 108 is configured to facilitate a lookup function on the stored data for the tracking controller. The lookup function compares input data provided by the tracking controller 104 to the data stored within the tracking database 108 to identify any “matching” data. It is to be understood that “matching” within the context of the lookup function may refer to the input data being the same, substantially similar, or linked to stored data in the tracking database 108. For example, if the input data is an image of a player's face, the lookup function may be performed to compare the input data to a set of stored images of historical players to determine whether or not the player captured in the input data is a returning player. In this example, one or more image comparison techniques may be used to identify any “matching” image stored by the tracking database 108. For example, key visual markers for distinguishing the player may be extracted from the input data and compared to similar key visual markers of the stored data. If the same or substantially similar visual markers are found within the tracking database 108, the matching stored image may be retrieved. In addition to or instead of the matching image, other data linked to the matching stored image may be retrieved during the lookup function, such as a player account number, the player's name, etc. In at least some embodiments, the tracking database 108 includes at least one computing device that is configured to perform the lookup function. In other embodiments, the lookup function is performed by a device in communication with the tracking database 108 (e.g., the tracking controller 104) or a device in which the tracking database 108 is integrated within.
The playing surface 202 includes markings or indicia to define functionality for particular portions of the playing surface 202. For example, the playing surface 202 includes a dealer area 206 and a plurality of player bet areas 208. In other embodiments, the playing surface 202 may include other suitable markings or indicia, which may be at least partially dictated by the type of game, the number of possible players, the game features, and other factors associated with the gaming table 200.
In the example embodiment, the dealer area 206 is an area that is managed by a dealer 201. For example, gaming devices (e.g., a card-handling device) may occupy the dealer area 206 for the dealer 201 to operate. In another example, community cards may be dealt within the dealer area 206. In the example embodiment, the dealer area 206 includes a wide-angle camera 210 of an sensor system (e.g., the sensor system 106, shown in
Each player bet area 208 is associated with a player position (indicated in
In at least some embodiments, the game conducted at the gaming table 200 may include back wagers to enable back players 205 to passively participate in the game. In the example embodiment, the back wager is linked to the outcome of one of the active players 203—if the associated active player 203 achieves a winning outcome in the game, a payout is provided to the back player 205 for the back wager. To place the back wager, the back player 205 places one or more tokens within the player bet area 208 of one of the active players 203. With respect to the example playing surface 202, back wagers intermingle with wagers placed by the active players 203 within the player bet area 206. In some embodiments, the number of wagers associated with a particular active player 203 may be limited to reduce the complexity of payout determination as described herein. In other embodiments, the player bet areas 206 may include additional indicia to distinguish between active wagers placed by the active players 203 and back wagers placed by the back players 205.
In the example embodiment, the wagers are placed for a given round or hand of the game prior to an outcome of the round. After the outcome is determined, any winning outcomes are identified, and payouts may be provided for any wagers associated with the winning outcomes. More specifically, if a winning outcome for one of the active players 203 is identified, the active wager of the winning active player 203 and any back wagers associated with the winning active player 203 result in payouts while wagers associated with non-winning outcomes may not receive payouts. The payouts may be fixed (i.e., the outcome has a predetermined payout amount) or at least partially a function of the wager amount and payout multiplier or ratio associated with the winning outcome specified by one or more payout tables. For example, a winning outcome may be associated with a 2× payout multiplier, and the payout is two times the wager amount. In some embodiments, active players 203 and back players 205 may have different fixed payouts or pay tables for a particular winning outcome. In other embodiments, the same fixed payouts or pay tables may apply to both active players 203 and back players 205.
To resolve the payouts, the dealer 201, with or without assistance from one or more devices monitoring the gaming table 200 (e.g., the game controller 102, shown in
In existing systems, back wagers may increase the complexity of payout attribution. That is, unlike active players 203 that remain in a fixed position and are distinguishable through the indicia of the playing surface (e.g., the player positions are distinguishable by the numbers within the player bet areas 208), back players 205 are largely untethered to the gaming table 200. The back players 205 may move during play of the game, or the player area 204 may be occupied by a relatively large number of back players 205 and/or non-participating observers. If the dealer 201 does not remember the face of each back player 205 associated with each and every back wager, the dealer 201 may have difficultly attributing payouts to the correct back player 205. This may result in bad faith players collecting payouts in place of other back players 205, and/or indirect awards (e.g., awards from player tracking systems for participation in the game) may be incorrectly attributed to the wrong player.
Moreover, some playing surfaces (including the playing surface 202) may not distinguish between the active wagers and the back wagers associated with a particular player bet area 208, which may result in problems similar to those described above between back players 205 when using existing player tracking systems. For example, for player tracking systems that identify players through a “card-in” process (e.g., the player swipes a player card at the gaming table 200 to check-in), the lack of distinguishable indicia between back wagers and active wagers may result in the active player 203 unfairly collected player tracking awards for both his or her active wager and any associated back wagers. These issues posed by at least some existing tracking systems are at least partially a result of the tracking being tethered to the playing surface 202, either through the tracking being performed via sensors integrated within the table 200 or the tracking systems being reliant upon each player position being associated with a single player.
Accordingly, the systems and methods described herein facilitate tracking of players, tokens, and the relationship between players and tokens irrespective of the playing surface 202. More specifically, a video stream of image data is captured by the camera 210 and is sent to the tracking controller 104 (shown in
In the example embodiment, the image sensor 128 is configured to capture 402 a video stream of image data 302 of the gaming area 101 (shown in
The image data 302 may be continuously captured at a predetermined framerate or periodically. The image data 302, for the purposes of this disclosure, is considered “raw” image data in the sense that no object detection and classification is performed by the image sensor 128, though other metadata (e.g., timestamps) and image processing may be included with the image data 302. The image data 302 is transmitted 404 to the tracking controller 104 for image processing and analysis.
In at least some embodiments, the tracking controller 104 stores the received image data 302 in a video buffer (e.g., within a memory device, such as the memory device 124, shown in
In the example embodiment, several neural network models 304 are implemented together by the tracking controller 104 to extract different features from the image data 302. That is, the neural network models 304 may be trained to identify particular characteristics of tokens and players. For example, one neural network model 304 may be trained to identify human faces, while another neural network model 304 may be trained to identify human torsos. Specific examples of such image neural network models 304 are described in further detail below with respect to
Although the output of the image neural network models 304 may vary depending upon the specific functionality of each model 304, the outputs generally include one or more data elements that represent a physical feature or characteristic of a person or object in the image data 302 in a format that can be recognized and processed by tracking controller 104 and/or other computing devices. For example, one example neural network model 304 may be used to detect the faces of players in the image data 302 and output a map of data elements representing “key” physical features of the detected faces, such as the corners of mouths, eyes, nose, ears, etc. The map may indicate a relative position of each facial feature within the space defined by the image data 302 (in the case of a singular, two-dimensional image, the space may be a corresponding two-dimensional plane) and cluster several facial features together to distinguish between detected faces. The output map is a data abstraction of the underlying raw image data that has a known structure and format, which may be advantageous for use in other devices and/or software modules.
In the example embodiment, applying the image neural network models 304 to the image data 302 causes the tracking controller 104 to generate 408 one or more key player data elements 306 and/or key token data elements 308. The key player data elements 306 and the key token data elements 308 are the outputs of the image processing (including the models 304). Other suitable image processing techniques and tools may be implemented by the tracking controller 104 in place of or in combination with the neural network models 304. As described above, the key data elements 306, 308 represent one or more physical characteristics of the players (e.g., a face, a head, a limb, an extremity, or a torso) and tokens detected in the image data 302. The key data elements 306, 308 may include any suitable amount and/or type of data based at least partially on the corresponding neural network model 304. At least some of the key data elements 306, 308 include position data indicating a relative position of the represented physical characteristics within a space at least partially defined by the scope of the image data 302.
Key data elements 306, 308 may include, but are not limited to, boundary boxes, key feature points, vectors, wireframes, outlines, pose models, and the like. Boundary boxes are visual boundaries that encapsulate an object in the image and classify the encapsulated object according to a plurality of predefined classes (e.g., classes may include “human”, “tokens”, etc.). A boundary box may be associated with a single class or several classes (e.g., a player may be classified as both a “human” and a “male”). The key feature points, similar to the boundary boxes, classify features of objects in the image data 302, but instead assign a singular position to the classified features. In certain embodiments, the tracking controller 104 may include neural network models 304 trained to detect objects other than the players and the tokens.
Although the key data elements 306, 308 are described above as outputs of the neural network models 304, at least some key data elements 306, 308 may be generated using other object detection and/or classification techniques and tools. For example, a 3D camera of the sensor system 106 (shown in
After the key player data elements 306 and the key token data elements 308 are generated 408, the tracking controller 104 is configured to organize the key player data elements 306 and/or the key token data elements 308 to identify each respective player and token set. That is, the tracking controller 104 may be configured to assign the outputs of the neural network models 304 to a particular player or token set based at least partially on a physical proximity of the physical characteristics represented by the key player and token data elements 306, 308.
In the example embodiment, the tracking controller 104 is configured to generate 410 a player data object 310 associated with a player based at least partially on the key player data elements 306. The player data object 310 is a structured allocation of data storage (i.e., a plurality of predefined data elements and corresponding metadata) that is attributed to a single player such that the tracking controller 104 may store data associated with the player from various sources (e.g., the different neural network models 304) together as the player data object 310. In some embodiments, the key player data elements 306 are stored within the player data object 310. In other embodiments, the tracking controller 104 may generate data based on the key player data elements 306 to be stored within the player data object 310, such as an aggregate pose model representing a combination of the key player data elements 306. In the example embodiment, the player data object 310 is linked 412 to a player identifier 312 uniquely associated with the player. The player identifier 312 may be generated by the tracking controller 104 or may be retrieved from another system or device that stores player identifiers.
For example, the player identifier 312 may be stored by a player account system as part of a player account associated with the player. In such an example, to retrieve the player identifier 312, the tracking controller 104 may transmit a request to the player tracking system including biometric data, such as an image of the player's face and/or key player data elements 306, which can be used to identify the player. The player tracking system may transmit the player identifier 312 back to the tracking controller 104 if a match is found. If no matching player account is found, the tracking controller 104 may generate the player identifier 312.
In another example, historical player data objects may be stored in a database, such as the tracking database system 108. In the example embodiment, the tracking database 108 stores historical player data 314 that is generated and/or collected by the tracking controller. The historical player data 314 may include, but is not limited to, historical key data elements, historical player data objects, and/or historical player identifiers. The tracking controller 104 may be configured to compare data from the player data object 310 to the historical player data objects stored in the tracking database system 108 to determine whether or not the player data object 310 (and the associated player) matches a previously generated player data object. If a match is found, the player identifier 312 and/or other suitable historical data may be retrieved from the tracking database system 108 to be included with the player data object 310. If no match is found, the player identifier 312 may be generated by the tracking controller 104 to be included with the player data object 310. In other embodiments, the player data object 310 may not be generated 410 prior to a comparison with the historical player data stored by the tracking database system 108. That is, the key player data elements 306 may be compared to the stored player data within the tracking database system 108 to determine whether or not a player data object 310 associated with the player has been previously generated 410. If a matching player data object 310 is found, the matching player data object 310 may be retrieved and updated with the key player data elements 306. If no match is found, the player data object 310 is then generated 410.
In some embodiments, the system 100 may facilitate anonymized player tracking through image tracking, thereby enabling players that do not wish to provide their name or other personal identifiable information to potentially gain at least some benefits of a player account while improving the management of the game environment via enhanced gameplay tracking. That is, if a player does not have a player account, the player may still be tracked using biometric data extracted from the image data 302 and may receive benefits for tracked gameplay, such as an award for historical performance and/or participation of the player. The biometric data is data that, through one or more detected physical features of the player, distinguishes the player from others. The biometric data may include, but is not limited to, the key player data elements 306 and/or data derived from the key player data elements 306.
In embodiments with anonymized player tracking, the tracking controller 104 may determine that no existing player account is associated with the player, and then generates 412 the player identifier 312 or retrieves the player identifier 312 from historical player data within the tracking database system 108. The anonymized player identifier 312 may be temporarily associated with the player until a predetermined period of time or a predetermined period of inactivity (i.e., the player is not detected or has not participated in a game over a period of time) has expired. Upon expiration, the player data object 310 and/or the player identifier 312 may be deleted from storage, and the player identifier 312 is reintroduced into a pool of available player identifiers to be assigned to other players.
In the example embodiment, the tracking controller 104 is configured to generate 414 a token identifier 316 for the token stack based on the key token data elements 308. Like the player identifier 312, the token identifier 316 uniquely identifies the token stack. The token identifier 316 may be used to link the token stack to a player as described in detail below. The tracking controller 104 may generate other data based on the key token data elements 308 and/or other suitable data elements from external systems (e.g., the sensor system 106, shown in
In the example embodiment, the tracking controller 104 is configured to link 416 the token set and player together in response to determining the player is the owner or originator of the token set. More specifically, the tracking controller 104 detects a physical proximity between physical characteristics represented by the key player data elements 306 and the key token data elements 308, and then links the token identifier 316 to the player data object 310. The physical proximity may indicate, for example, that the player is holding the token set within his or her hand. In one example, the physical proximity is determined by comparing positional data of the key token data elements 308 to positional data of one or more player data objects 310 associated with players present in the image data 302.
In the example embodiment, the linking 416 is performed by storing the token identifier 316 with or within the player data object 310. The player data object 310 may be configured to store one or more token identifiers 316 at a given time to enable multiple token sets to be associated with the player. However, in some embodiments, each token identifier 316 may be linked to a single player data object 310 at a given time to prevent the token set from being erroneously attributed to an intermediate player. As used herein, an “intermediate player” is a player that may handle or possess the token set between the player and a bet area. For example, a back player may pass his or her tokens to an active player to reach a bet area on the gaming table. In this example, the active player has not gained possession of the tokens, but is merely acting as an intermediate to assist the back player in placing a wager. Even though the tracking controller 104 may detect a physical relationship or proximity between the token set and the intermediate player, the previous link by the original player and the token set may prevent the tracking controller from attributing the token set to the intermediate player.
Linking 416 the token set to a particular player may have several advantages. For example, a payout process may be improved by providing a dealer with improved information regarding (i) who placed which wager and (ii) at least some identifiable information for locating the winning players for the payout. That is, the game controller 102 and/or the tracking controller 104 may monitor play of the game at the game table, determine an outcome of the game, and determine which (if any) wagers are associated with a winning outcome resulting in a payout. The tracking controller 104 may transmit a payout message 318 to the game controller 102 and/or a dealer interface (not shown) to visually indicate to the dealer the one or more players associated with the winning outcome wagers. The payout message 318 may include an indication of the winning players such as, but not limited to, an image of the player's face, the player's name, a nickname, and the like. In certain embodiments, the tracking controller 104 may include a display, a speaker, and/or other audiovisual devices to present the information from the payout message 318.
In at least some embodiments, the tracking controller 104 is configured to generate one or more tracking messages 320 to be transmitted to one or more external devices or systems. More specifically, the functionality of other systems in communication with the tracking controller 104 may be enhanced and/or dependent upon data from the tracking controller 104. In the example embodiment, the tracking message 320 is transmitted to the server system 114. The tracking messages 320 are data structures having a predetermined format such that the tracking controller 104 and a recipient of the tracking message 320 can distinguish between data elements of the tracking message 320. The contents of the tracking messages 320 may be tailored to the intended recipient of the tracking message, and tracking messages 320 transmitted to different recipients may differ in the structure and/or content of the tracking messages 320.
In one example, a player account system in communication with the tracking controller 104 may receive the tracking message 320 to identify any players with player accounts present within the gaming environment monitored by the tracking controller 104. In such an example, the tracking message 320 may include location data 322 indicating a location of the player. The location data 322 may indicate the area monitored by the tracking controller 104, or the location data 322 may include further details of the player's location, such as an approximate location of the player within the area monitored by the tracking controller 104 based at least partially on the positions of the key player data elements 306 of the player. In another example, the tracking message 320 may be transmitted to the game controller 102 and/or an accounting system for monitoring wagers, payouts, and the players associated with each wager and payout.
In at least some embodiments, the tracking controller 104 is configured to generate annotated image data 324. The annotated image data 324 may be the image data 302 with at least the addition of graphical and/or metadata representations of the data generated by the tracking controller 104. For example, if the tracking controller 104 generates a bounding box encapsulating a token set, a graphical representation of the boundary box may be applied to the image data 302 to represent the generated boundary box. The annotated image data 324 may be an image filter that is selectively applied to the image data 302 or an altogether new data file that aggregates the image data 302 with data from the tracking controller 104. The annotated image data 324 may be stored as individual images and/or as video files. The annotated image data 324 may be stored in the tracking database system 108 as part of the historical player data 314.
In one example, the annotated image data 324 may be used to track counterfeit tokens back to its origin. At least some counterfeit tokens may be introduced and may go undetected until a token counting process is performed (e.g., at the end of the day). With known systems, it may be difficult to locate and identify the player that introduced the counterfeit tokens. When the counterfeit tokens are detected, the annotated image data 324 may be retrieved to identify the counterfeit tokens in the annotated image data 324 and track the counterfeit tokens back to the player that introduced them.
In the example embodiment, the player data object 310 and the token identifier 316 may be stored in the tracking database system 108 as subsequent image data 302 is retrieved from a video buffer of the tracking controller 104 and/or the image sensor 128 to process. Key player data elements and key token data elements from the subsequent image data 302 may be compared to the player data object 310 and the token identifier 316 to determine whether or not the player or token set have previously been identified. In some embodiments, the player data object 310 may updated with new key player data elements from the subsequent image data 302. In certain embodiments, the data from the player data object 310 may be retrieved instead of generating at least some key player data elements and/or other data related to the player, such as the player identifier 312.
The following figures illustrate several examples of the image processing performed by the tracking controller 104 at a gaming table. That is, the following figures illustrate several example images captured by an image sensor (e.g., the image sensor 128, shown in
In the example embodiment, the player 502 possesses a token set 506 for placing wagers. In other examples, the player 502 may possess a plurality of token sets 506 and/or token sets 506 having a different number of tokens. In the frame 500, the player 502 maintains the token set 506 near himself on the gaming table 504, whereas, in the frame 600, the player 502 has moved the token set 506 on the gaming table 504 to a betting or wagering area to wager the token set 506. If the frame 500 is assumed to be the precursor to the frame 600 in this example, intermediate frames may depict the player 502 physically engaging (e.g., picking up, pushing, etc.) the token set 506 to move the token set 506 within the betting area marked on the gaming table 504. Subsequent frames after the frame 600 may depict the player 502 releasing the token set 506 from his hand and moving his hand away from the token set 506 to participate in the game.
In the example embodiment, the frames 500, 600 include graphical representations of key data elements associated with the token set 506. More specifically, the tracking controller 104 has (i) analyzed the frames 500, 600 by applying one or more neural network models trained to identify token sets and (ii) generated a boundary box 508 that encapsulates the token set 506 within the frames 500, 600. The boundary box 508 may be a visual or graphical representation of one or more underlying key token data elements. For example, and without limitation, the key token data elements may specify coordinates within the frames 500, 600 for each corner of the boundary box 508, a center coordinate of the boundary box 508, and/or vector coordinates of the sides of the boundary box 508. Other key token data elements may be associated with the boundary box 508 that are not used to specify the coordinates of the box 508 within the frames 500, 600, such as, but not limited to, classification data (i.e., classifying the object in the frames 500, 600 as a “token set”) and/or value data (e.g., identifying a value of the token set 506).
The position of the boundary box 508 is updated for each frame analyzed by the tracking controller 104 such that a particular token set 506 can be tracked over time. The key token data elements may be used to distinguish between two token sets detected within a frame. For example, if one token set contains three red tokens while a second token set contains five green tokens, the key token data elements for the two token sets may include distinguishable data indicating the color and/or size of the respective token sets. In at least some embodiments, the tracking controller 104 compares key token data elements generated for a particular frame to key token data elements of previously analyzed frames to determine if the token set 506 has been previously detected. The previously analyzed frames may include the immediately preceding frames over a period of time (e.g., ten seconds, one minutes, or since the game has started) and/or particular frames extracted from a group of analyzed frames to reduce the amount of data storage and reduce the data processing required to perform the comparison of the key token data elements.
In the example embodiment, the image processing and analysis dedicated to token sets may be limited in scope in comparison to the image processing and analysis dedicated to players detected in captured image data, thereby enabling the systems described herein to devote computing, memory, storage, and/or other resources to enhanced player tracking capabilities and automatic association of tokens to players.
In the example embodiment, the tracking controller 104 is configured to detect three aspects of players in captured image data: (i) faces, (ii) hands, and (iii) poses. As used herein, “pose” or “pose model” may refer physical characteristics that link together other physical characteristics of a player. For example, a pose of the player 502 may include features from the face, torso, and/or arms of the player 502 to link the face and hands of the player 502 together. The graphical representations shown include a left hand boundary box 702, a right hand boundary box 704, a pose model 706, a face or head boundary box 708, and facial feature points 710 (shown in
The hand boundary boxes 702, 704, similar to token boundary box 508, are the outputs of one or more neural network models applied by the tracking controller 104. In the example embodiment, the tracking controller 104 is configured to distinguish between right and left hands (as indicated by the respective ‘L’ and ‘R’ on the hand boundary boxes 702, 704). In other embodiments, the tracking controller 104 may not distinguish between left and right hands. The classification of the hands detected in captured image data may be by default a “hand” classification and, if sufficiently identifiable from the captured image data, may further be classified into a “right hand” or “left hand” classification. As described in further detail herein, the hand boundary boxes 702, 704 may be associated with the player 502, which is illustrated by the ‘2’ added to the hand boundary boxes 702, 704, where ‘2’ is a player identifier of the player 502.
In the example embodiment, the pose model 706 is used to link together outputs from the neural network models to associate the outputs with a single player (e.g., the player 502). That is, the key player data elements generated by the tracking controller 104 are not associated with a player immediately upon generation of the key player data elements. Rather, the key player data elements are pieced or linked together to form a player data object as described herein. The key player data elements that form the pose model 706 may be used to find the link between the different outputs associated with a particular player.
In the example embodiment, the post model 706 includes pose feature points 712 and connectors 714. The pose feature points 712 represent key features of the player 502 that may be used to distinguish the player 502 from other players and/or identify movements or actions of the player 502. For example, the eyes, ears, nose, mouth corners, shoulder joints, elbow joints, and wrists of the player 502 may be represented by respective pose feature points 712. The pose feature points 712 may include coordinates relative to the captured image data to facilitate positional analysis of the different feature points 712 and/or other key player data elements. The pose feature points 712 may also include classification data indicating which feature is represented by the respective pose feature point 712. The connectors 714 visually link together the pose feature points 712 for the player 502. The connectors 714 may be extrapolated between certain pose feature points 712 (e.g., a connector 714 is extrapolated between pose feature points 712 representing the wrist and the elbow joint of the player 502). In some embodiments, the pose feature points 712 may be combined (e.g., via the connectors 714 and/or by linking the feature points 712 to the same player) by one or more corresponding neural network models applied by the tracking controller 104 to captured image data. In other embodiments, the tracking controller 104 may perform one or more processes to associate the pose feature points 712 to a particular player. For example, the tracking controller 104 may compare coordinate data of the pose feature points 712 to identify a relationship between the represented physical characteristics (e.g., an eye is physically near a nose, and therefore the eye and nose are determined to be part of the same player).
At least some of the pose feature points 712 may be used to link other key player data elements to the pose model 706 (and, by extension, the player 502). More specifically, at least some pose feature points 712 may represent the same or nearby physical features or characteristics as other key player data elements, and based on a positional relationship between the pose feature point 712 and another key player data element, a physical relationship may be identified. In one example described below, the pose feature points 712 include wrist feature points 716 (shown in
In the example embodiment, the tracking controller 104 sets 1002 a wrist feature point of a pose model as the hand of interest. That is, the coordinate data of the wrist feature point and/or other suitable data associated with the wrist feature point for comparison with key player data elements associated with hands are retrieved for use in the method 1000. In addition to establishing the wrist feature point as the hand of interest, several variables are initialized prior to any hand comparison. In the example embodiment, the tracking controller 104 sets 1004 a best distance value to a predetermined max value and a best hand variable to ‘null’. The best distance and best hand variables are used in combination with each other to track the hand that is the best match to the wrist of the wrist feature point and to facilitate comparison with subsequent hands to determine whether or not the subsequent hands are better matches for the wrist. The tracking controller 104 may also set 1006 a hand index variable to ‘0’. In the example embodiment, the key player data elements associated with each hand within the captured image data may be stored in an array such that each cell within the hand array is associated with a respective hand. The hand index variable may be used to selectively retrieve data associated with a particular hand from the hand array.
At step 1008, the tracking controller 104 determines whether or not the hand index is equal to (or greater than, depending upon the array indexing format) the total number of hands found within the captured image data. For the initial determination, the hand index is 0, and as a result, the tracking controller 104 proceeds to set 1010 a prospective hand for comparison to the hand associated with the first cell of the hand array (in the format shown in
The tracking controller 104 determines 1012 whether or not the wrist feature point is located within the hand boundary box of the hand from the hand array. If the wrist feature point is located with the hand boundary box, then the hand may be considered a match to the wrist and the player. In the example embodiment, the tracking controller may then set 1014 the hand as the best hand and return 1024 the best hand. The best hand may then be associated with the pose model and stored as part of the player data object of the player (i.e., the hand is “linked” to the player). Returning 1024 the best hand may terminate the method 1000 without continuing through the hand array, thereby freeing up resources of the tracking controller 104 for other functions, such as other iterations of the method 1000 for different wrist feature points and pose models. In other embodiments, the tracking controller 104 may compare the wrist feature point to each and every hand prior to returning 1024 the best hand irrespective of whether the wrist feature point is located within a hand boundary box, which may be beneficial in image data with crowded bodies and hands.
If the wrist feature point is not determined to be within the hand boundary box of the current hand, the tracking controller calculates 1016 a distance between the center of the hand boundary box and the wrist feature point. The tracking controller 104 then compares 1018 the calculated distance to the best distance variable. If the calculated distance is less than the best distance, the current hand is, up to this point, the best match to the wrist feature point. The tracking controller 104 sets 1020 the best distance variable equal to the calculated distance and the best hand to be the current hand. For the first hand from the hand array, the comparison 1018 may automatically progress to setting 1020 the best distance to the calculated distance and the best hand to the first hand because the initial best distance may always be greater than the calculated distance. The tracking controller 104 then increments 1022 the hand index such that the next hand within the hand array will be analyzed through steps 1010-1022. The hand index is incremented 1022 irrespective of the comparison 1018, but step 1020 is skipped if the calculated distance is greater than or equal to the best distance.
After each hand of the hand array is compared to the wrist feature point, the hand index is incremented to value beyond the addressable values of the hand array. During the determination 1008, if the hand index is equal to the total number of hands found (or greater than in instances in which the first value of the hand array is addressable with a hand index of ‘1’), then every hand has been compared to the wrist feature point, and the best hand to match the wrist feature point may be returned 1024. In certain embodiments, to avoid scenarios in which the real hand associated with a wrist is covered from view of the capture image data and the best hand as determined by the tracking controller is relatively far away from the wrist, the tracking controller 104 may compare the best distance associated with the best hand to a distance threshold. If the best distance is within the distance threshold (i.e., less than or equal to the minimum distance), the best hand may be returned 1024. However, if the best distance is greater than the distance threshold, the best hand variable may be set back to a ‘null’ value and returned 1024. The null value may indicate to other modules of the tracking controller 104 and/or other devices that the hand associated with the wrist is not present in the captured image data.
In the example embodiment, to initiate the method 1100, the tracking controller 104 may retrieve or be provided inputs associated with a face detected in captured image data. More specifically, key player data elements representing a face and/or head are used to link the face to a pose model representing a body detected in the captured image data. The key player data elements representing the face may include a face or head boundary box and/or face feature points. The boundary box and/or the face feature points may include coordinate data for identifying a location of the boundary box and/or the face feature points within the captured image data. The pose model may include pose feature points representing facial features (e.g., eyes, nose, ears, etc.) and/or physical features near the face, such as a neck. In the example embodiment, the inputs associated with the face include a face boundary box and facial feature points representing the eyes and nose of the face. Each pose includes pose feature points representing eyes and a nose and including coordinate data for comparison with the inputs of the face.
To initialize the method 1100, the tracking controller 104 sets 1102 a best distance variable to a predetermined maximum value and a best pose variable to a ‘null’ value. Similar to the hand array described with respect to
The tracking controller 104 then determines 1106 if the pose index is equal to (or greater than for arrays with an initial index value of ‘1’) a total number of poses detected in the captured image data. If the pose index is determined 1106 not to be equal to the total number of poses, the tracking controller 104 progress through a comparison of each pose with the face. The tracking controller 104 sets 1108 the current pose to be equal to the pose stored in the pose array at the cell indicated by the pose index. For the first comparison, the current pose is stored as ‘POSE[0]’ according to the syntax shown in
In the example embodiment, the tracking controller 104 compares 1110 the pose feature points representing a pair of eyes and a corresponding nose to the face boundary box of the face. If the pose feature points representing the eyes and nose are not within the face boundary box, the pose is unlikely to be a match to the face, and the tracking controller 104 increments 1112 the pose index such that the comparison beginning at step 1108 begins again for the next pose. However, if the pose feature points are within the face boundary box, the tracking controller 104 then calculates 1114 a distance from the pose feature points and facial feature points. In the example embodiment, Equation 1 is used to calculate 1114 the distance D, where left_eyep, right_eyep, and nosep are coordinates of pose feature points representing a left eye, a right eye, and a nose of the pose model, respectively, and where left_eyef, right_eyef, and nosef are coordinates of facial feature points representing a left eye, a right eye, and a nose of the face, respectively.
D=|left_eyep−left_eyef|+|right_eyep−right_eyef|+|nosep−nosef| (1)
In other embodiments, other suitable equations may be used to calculate 1114 the distance. The tracking controller 104 then compares 1116 the calculated distance to the best distance variable. If the calculated distance is greater than or equal to the best distance, the pose is determined to not be a match to the face, and the pose index is incremented 1112. However, if the calculated distance is less than the best distance, the current pose may be, up to this point, the best match to the face. The tracking controller 104 may then set 1118 the best distance to the calculated distance and the best pose variable to the current pose. For the first pose compared to the face within steps 1106-1118, the first pose may automatically be the assigned as the best pose because the of the initialized values of step 1102. The tracking controller 104 then increments 1112 the pose index to continue performing steps 1106-1118 until every pose within the pose array has been compared. Once every pose has been compared, the pose index will be equal to or greater than the total number of detected poses, and therefore the tracking controller 104 determines 1106 that the method 1100 is complete and returns 1120 the best pose to be linked to the face.
Unlike the method 1000, the method 1100 does not include steps to conclude the comparison loop (i.e., steps 1106-1118) until every pose has been compared to ensure that an early ‘false positive’ within the pose array does not result in the method 1100 ending without locating the best possible pose to link to the face. However, it is to be understood that the method 1100 may include additional and/or alternative steps to conclude the comparison loop without comparing every pose, particularly in embodiments in which (i) resource allocation of the tracking controller 104 may be limited due to number of parallel processes, time constraints, etc., and/or (ii) a reasonable amount of certainty can be achieved in the comparison loop that a pose is linked to the face similar to steps 1012 and 1014 in
The method 1100 further includes protections against situations in which the body associated with the face is obscured from the captured image data, and the face is erroneously linked to a different pose. More specifically, the comparison 1110 requires at least some positional relationship between the pose and the face to be in consideration as the best pose to match the face. If the body associated with the face is obscured, there may not be a pose model associated with the body in the pose array. If every pose ‘fails’ the comparison 1110 (i.e., progressing directly to step 1112 to increment the pose index), the best pose returned 1120 by the tracking controller 104 may still be the initialized ‘null’ value, thereby indicating a matching pose for the face has not been detected.
The methods 1000, 1100 of
With respect again to
In response to determining that the new key player data elements are associated with the previously generated player data object, the tracking controller 104 may further determine if the player data object should be updated based on the new key player data elements. For example, the player 502 has moved between frame 500 and frame 600, and coordinate data of the key player data elements may be updated to reflect the positional change of the player 502 within the image data. In some embodiments, updating the player data object may result in data stored within the player data object being replaced with new data. In other embodiments, the player data object may include a historical record of changes and updates to the data stored within the player data object to facilitate historical tracking and recreation of the player. In certain embodiments, the player data object may not change, but related data generated by the tracking controller 104 (e.g., annotated image data) may be updated in response to the new key player data elements. Although the foregoing is described with respect to players and player data objects, it is to be understood that the same or similar functionality may be performed for token sets.
In response to receiving image data of a gaming area including a token set, the tracking controller 104 generates 1202 one or more key token data elements associated with the token set. The key token data elements may facilitate distinguishing the token set from at least some other token sets. That is, the token set may not be distinguished from other token sets having the same makeup (i.e., same number of tokens, same colors, etc.), but may be at least distinguishable from other token sets having different makeups. In the example embodiment, the tracking controller 104 compares the generated key token data elements to historical key token data elements to determine 1204 whether or not the token set is associated with a previously generated token identifier. If the comparison results in a determination 1204 that the token set does not have a previously generated token identifier, the tracking controller 104 generates 1206 a token identifier for use in linking the token set to a player as described herein.
If the comparison results in a determination 1204 that the token set is associated with a token identifier, the tracking controller 104 further determines 1208 whether or not the token identifier is currently associated or linked to a player. In one example, the tracking controller 104 performs a lookup function to compare the token identifier to a plurality of player data objects that can store or be linked to one or more token identifiers. If the token identifier is already associated with a player, then the method 1200 is concluded to prevent the token set from being linked to multiple players at a time. Linking a single token set to multiple players may cause issues with attributing wagers, payouts, and other awards (e.g., player points for player accounts) to the correct player.
If the token identifier is not currently associated with a player or the tracking controller 104 generates 1206 the token identifier, the tracking controller 104 then prepares for a comparison loop similar to the method 1000, 1100 shown in
The tracking controller 104 determines 1212 whether or not the hand index is equal to (or greater than, depending upon array syntax) the total number of hands in the image data. If the hand index is less than the total number of hands, the current hand is set 1214 to the hand indicated in the hand array by the hand index. In the example embodiment, the hand array includes at least coordinate data of a hand boundary box for each hand, and the key token data elements include coordinate data associated with the token set. For example, the key token data elements may specify coordinates within the image data of a token boundary box or a center of the token set.
The tracking controller 104 compares the coordinate data of the current hand to the coordinate data of the token set to determine any physical relationship between the hand and the token set. In the example embodiment, the tracking controller 104 determines 1216 whether or not the token set is within the hand boundary box of the current hand based on the comparison. If the token set is within the hand boundary box, a physical relationship may be present between the hand and the token set. That is, the hand may be gripping, holding, touching, or otherwise near the token set such that possession of the token set is attributed to the hand and the corresponding player. More specifically, the best hand variable is set 1218 to the current hand, and the token identifier is linked 1220 to the player data object associated with the best hand (i.e., the current hand) to conclude the method 1200. The method 1200 may be concluded without further comparison between the token set and other hands of the hand array.
If the token set is not within the hand boundary box of the current hand, the tracking controller 104 calculates 1222 a distance between the hand and the token set. That is, in one example, the distance is calculated 1222 between a central coordinate of the hand boundary box of the current hand and a central coordinate of the token boundary box of the token set. The calculated distance is compared to the best distance variable to determine 1224 whether or not the calculated distance is less than the best distance. If the calculated distance is determined 1224 to be less than the best distance, the best hand is set 1226 to the current hand and the best distance is set to the calculated distance for comparison with subsequent hands of the hand array. Irrespective of the determination 1224, the tracking controller 104 increments 1228 the hand index to retrieve the next hand of the hand array for the comparison loop (i.e., steps 1212-1228).
If the hand index is incremented to equal the total number of hands, every hand in the hand array has been compared, and the tracking controller 104 progresses from the determination 1212 to link 1220 the token identifier to the player data object associated with the best hand from the hand array. In certain embodiments, additional steps may be performed to prevent token sets that are not associated with any player to be erroneously associated with a player. More specifically, the tracking controller 104 may compare the best distance to a distance threshold prior to linking 1220 the token identifier to a player data object. If the best distance is less than or equal to the distance threshold, the token identifier is linked 1220 to the player data object. However, if the best distance is greater than the distance threshold, the tracking controller 104 may prevent the token identifier from being linked 1220 to the player data object.
In certain embodiments, the comparison loop (steps 1212-1228) may be reduced to reduce the resource burden and/or speed of the method 1200. For example, steps 1222-1226 may be removed from the method 1200 such that the token set is linked to a hand only if the token set is determined 1216 to be within a hand boundary box of the hand. In another example, the determination 1216 and step 1218 may be removed from the method 1200.
As mentioned previously, token identifiers may be linked to player data objects on a temporary basis because token sets may be dynamically created, changed, or otherwise removed both inside and out of the gaming environment. In the example embodiment, the token set may be linked to a player for a period of time and/or a period of inactivity. The period of time may be an hour or a round of the game conducted at the gaming table. In one example, wagers are placed at the gaming table for a round of the game, and payouts for the round may be distributed using tokens from the token set such that token sets of the wagers are redistributed to players and new token sets may be formed. In such an example, new token identifiers may be applied after each round of player. A period of inactivity may be defined as a period in which the token set is not used within the game or a period in which the token set is not detected in image data. In certain embodiments, a historical record of token identifiers may be stored with each player data object such that a timeline of the player or certain tokens (e.g., counterfeit tokens) may be traced over time.
With respect to
The frame 1300 depicts the active player 1306 turning away from the gaming table 1308 and towards the back player 1302. The right hand of the back player 1302 is gripping the token set 1304 from above and is extended towards the active player 1306 to be deposited in the right hand of the active player 1306. Subsequent to the frame 1300, in this example, the active player 1306 then takes the token set 1304 from the back player 1302 and deposits the token set 1304 on the gaming table 1308 to indicate a wager placed by the back player 1302 on the game conducted at the gaming table 1308. The exchange between the back player 1302 and the active player 1306 may be necessitated due to the back player 1302 having limited access to the gaming table 1308 himself or herself (e.g., other players blocking the back player 1302 from accessing the gaming table 1308, etc.).
Within the frame 1300, the back player 1302 is partially obscured by the active player 1306, thereby limiting the amount of key player data elements generated for the back player 1302 relative to the amount of key player data elements generated for the active player 1306. However, the reduced amount of key player data elements may not prevent the player data object associated with the back player 1302. Rather, if subsequent frames reveal more the back player 1302, the player data object may be updated to include the additional key player data elements generated by the tracking controller 104.
In the example embodiment, at least one neural network of the tracking controller 104 may be in a partially trained state that is not configured yet to recognize the exchange between the players 1302, 1306. That is, due to the proximity and differing orientations of the hands exchanging the token set 1304, the tracking controller 104 does not identify the right hand of the active player 1306 (evidenced in the frame 1300 by the absence of a hand boundary box encapsulating the hand), and the tracking controller 104 attributes the right hand of the back player 1302 to the active player 1306, where ‘R2’ indicates the hand is a right hand of a player with the player identifier of ‘2’.
In this example, the generated key player data elements and the graphical representations shown indicate the tracking controller 104 (and the underlying neural networks) have undergone a training process in which training data (i.e., inputs with known outputs) is processed through the neural networks, and error correction is performed to tune the neural networks to correctly identify particular objects, such as hands and token sets. However, in a dynamic environment such as a gaming environment, situations may arise that the training process has not fully prepared the tracking controller 104 to recognize. To adapt to these situations, the feedback loop nature of the neural networks may be harnessed to identify errors, perform error correction, and, in response to persistent error correction, begin to identify the previously unidentified or misidentified objects. For example, subsequent frames may reveal to the tracking controller 104 that the hand attributed to the active player 1306 is in fact a hand of the back player 1302, and the right hand of the active player 1306 may be detected. The tracking controller 104 may perform error correction with respect to the outputs associated with the frame 1300 within the neural network models to attempt to reduce errors in similar, subsequent situations. The automated nature of the feedback loop of the neural network models, in combination with thorough and extensive training, may enable the system to provide robust and adaptable object detection, classification, and interaction within image data of a gaming environment.
The exchange shown in the frame 1300 may create problems in existing tracking systems for linking players and tokens together. More specifically, table-based tracking systems (i.e., sensors embedded into the gaming table 1308) may not be able to accurately attribute a token set placed on the gaming table 1308 due to limitations such as limited table indicia to distinguish between players or an inability to identify and track back players, particularly when the token sets of the back players may be passed to an intermediate player prior to placement on the gaming table 1308. A dealer monitoring the gaming table 1308 and players participating in the game may be performing several duties at once to conduct the game, and thus may be limited in his or her ability to correctly attribute and track token sets to players (particularly in situations in which the dealer enters the wagers into a system for tracking historical wagering, gameplay, and payouts).
As described with respect to
Other suitable techniques may be employed by the tracking controller 104 in addition to or in place of the technique described in
The ownership of the token set 1304 may be temporary to account for ownership changes and/or changes to the composition of the token set itself 1304. That is, payouts the redistribute wagered token sets or adding or removing tokens from the token set 1304 may result in new links to be formed between the resulting token sets and the players. The link between the token sets and players may be automatically removed in response to one or more events, such as conclusion of a payout process for a round of the game conducted at the gaming table 1308 or one or more outcomes of the game, and/or may be terminated in response to expiration of a period of time and/or a period of inactivity.
The foregoing systems and methods describe player and token tracking within gaming environments that may be adaptable to the dynamic nature of the environment. It is to be understood that other suitable items or people may to detected, tracked, and/or linked to other detected objects. For example, game pieces that are not used to represent wagers may be tracked and linked to players in a fashion similar to the token sets described above.
Each of these embodiments and obvious variations thereof is contemplated as falling within the spirit and scope of the claimed invention, which is set forth in the following claims. Moreover, the present concepts expressly include any and all combinations and subcombinations of the preceding elements and aspects.
This application claims the benefit of priority of U.S. Provisional Patent Application Ser. No. 62/888,708, filed Aug. 19, 2019, the contents of which are hereby incorporated by reference in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
5103081 | Fisher et al. | Apr 1992 | A |
5451054 | Orenstein | Sep 1995 | A |
5757876 | Dam et al. | May 1998 | A |
5870493 | Vogl | Feb 1999 | A |
6460848 | Soltys et al. | Oct 2002 | B1 |
6514140 | Storch | Feb 2003 | B1 |
6517435 | Soltys et al. | Feb 2003 | B2 |
6517436 | Soltys et al. | Feb 2003 | B2 |
6520857 | Soltys et al. | Feb 2003 | B2 |
6527271 | Soltys et al. | Mar 2003 | B2 |
6530836 | Soltys et al. | Mar 2003 | B2 |
6530837 | Soltys et al. | Mar 2003 | B2 |
6533276 | Soltys et al. | Mar 2003 | B2 |
6533662 | Soltys et al. | Mar 2003 | B2 |
6579180 | Soltys et al. | Jun 2003 | B2 |
6579181 | Soltys et al. | Jun 2003 | B2 |
6595857 | Soltys et al. | Jul 2003 | B2 |
6663490 | Soltys et al. | Dec 2003 | B2 |
6688979 | Soltys et al. | Feb 2004 | B2 |
6712696 | Soltys et al. | Mar 2004 | B2 |
6758751 | Soltys et al. | Jul 2004 | B2 |
7011309 | Soltys et al. | Mar 2006 | B2 |
7124947 | Storch | Oct 2006 | B2 |
7316615 | Soltys et al. | Jan 2008 | B2 |
7753781 | Storch | Jul 2010 | B2 |
7771272 | Soltys et al. | Aug 2010 | B2 |
8130097 | Knust et al. | Mar 2012 | B2 |
8285034 | Rajaraman et al. | Oct 2012 | B2 |
8606002 | Rajaraman et al. | Dec 2013 | B2 |
8896444 | Knust et al. | Nov 2014 | B1 |
9165420 | Knust et al. | Oct 2015 | B1 |
9174114 | Knust et al. | Nov 2015 | B1 |
9378605 | Koyama | Jun 2016 | B2 |
9511275 | Knust et al. | Dec 2016 | B1 |
9795870 | Ratliff | Oct 2017 | B2 |
9889371 | Knust et al. | Feb 2018 | B1 |
10032335 | Shigeta | Jul 2018 | B2 |
10096206 | Bulzacki et al. | Oct 2018 | B2 |
10192085 | Shigeta | Jan 2019 | B2 |
10242525 | Knust et al. | Mar 2019 | B1 |
10242527 | Bulzacki et al. | Mar 2019 | B2 |
10380838 | Bulzacki et al. | Aug 2019 | B2 |
10398202 | Shigeta | Sep 2019 | B2 |
10403090 | Shigeta | Sep 2019 | B2 |
10410066 | Bulzacki et al. | Sep 2019 | B2 |
10493357 | Shigeta | Dec 2019 | B2 |
10529183 | Shigeta | Jan 2020 | B2 |
10540846 | Shigeta | Jan 2020 | B2 |
10580254 | Shigeta | Mar 2020 | B2 |
10593154 | Shigeta | Mar 2020 | B2 |
10600279 | Shigeta | Mar 2020 | B2 |
10600282 | Shigeta | Mar 2020 | B2 |
10665054 | Shigeta | May 2020 | B2 |
10706675 | Shigeta | Jul 2020 | B2 |
10720013 | Main, Jr. | Jul 2020 | B2 |
10741019 | Shigeta | Aug 2020 | B2 |
10748378 | Shigeta | Aug 2020 | B2 |
10755524 | Shigeta | Aug 2020 | B2 |
10755525 | Shigeta | Aug 2020 | B2 |
10762745 | Shigeta | Sep 2020 | B2 |
10825288 | Knust et al. | Nov 2020 | B1 |
10832517 | Bulzacki et al. | Nov 2020 | B2 |
10846980 | French et al. | Nov 2020 | B2 |
10846985 | Shigeta | Nov 2020 | B2 |
10846986 | Shigeta | Nov 2020 | B2 |
10846987 | Shigeta | Nov 2020 | B2 |
20050059479 | Soltys et al. | Mar 2005 | A1 |
20060019739 | Soltys et al. | Jan 2006 | A1 |
20060177109 | Storch | Aug 2006 | A1 |
20090118022 | Lyons | May 2009 | A1 |
20100093429 | Mattice | Apr 2010 | A1 |
20180053377 | Shigeta | Feb 2018 | A1 |
20180061178 | Shigeta | Mar 2018 | A1 |
20180068525 | Shigeta | Mar 2018 | A1 |
20180075698 | Shigeta | Mar 2018 | A1 |
20180114406 | Shigeta | Apr 2018 | A1 |
20180211110 | Shigeta | Jul 2018 | A1 |
20180211472 | Shigeta | Jul 2018 | A1 |
20180232987 | Shigeta | Aug 2018 | A1 |
20180239984 | Shigeta | Aug 2018 | A1 |
20180336757 | Shigeta | Nov 2018 | A1 |
20190043309 | Shigeta | Feb 2019 | A1 |
20190088082 | Shigeta | Mar 2019 | A1 |
20190102987 | Shigeta | Apr 2019 | A1 |
20190147689 | Shigeta | May 2019 | A1 |
20190172312 | Shigeta | Jun 2019 | A1 |
20190188957 | Bulzacki et al. | Jun 2019 | A1 |
20190188958 | Shigeta | Jun 2019 | A1 |
20190236891 | Shigeta | Aug 2019 | A1 |
20190259238 | Shigeta | Aug 2019 | A1 |
20190266832 | Shigeta | Aug 2019 | A1 |
20190318576 | Shigeta | Oct 2019 | A1 |
20190320768 | Shigeta | Oct 2019 | A1 |
20190333322 | Shigeta | Oct 2019 | A1 |
20190333323 | Shigeta | Oct 2019 | A1 |
20190333326 | Shigeta | Oct 2019 | A1 |
20190340873 | Shigeta | Nov 2019 | A1 |
20190344157 | Shigeta | Nov 2019 | A1 |
20190347893 | Shigeta | Nov 2019 | A1 |
20190347894 | Shigeta | Nov 2019 | A1 |
20190362594 | Shigeta | Nov 2019 | A1 |
20190371112 | Shigeta | Dec 2019 | A1 |
20200034629 | Vo et al. | Jan 2020 | A1 |
20200035060 | Shigeta | Jan 2020 | A1 |
20200118390 | Shigeta | Apr 2020 | A1 |
20200122018 | Shigeta | Apr 2020 | A1 |
20200175806 | Shigeta | Jun 2020 | A1 |
20200202134 | Bulzacki et al. | Jun 2020 | A1 |
20200226878 | Shigeta | Jul 2020 | A1 |
20200234464 | Shigeta | Jul 2020 | A1 |
20200242888 | Shigeta | Jul 2020 | A1 |
20200258351 | Shigeta | Aug 2020 | A1 |
20200265672 | Shigeta | Aug 2020 | A1 |
20200273289 | Shigeta | Aug 2020 | A1 |
20200294346 | Shigeta | Sep 2020 | A1 |
20200302168 | Vo et al. | Sep 2020 | A1 |
20200342281 | Shigeta | Oct 2020 | A1 |
20200349806 | Shigeta | Nov 2020 | A1 |
20200349807 | Shigeta | Nov 2020 | A1 |
20200349808 | Shigeta | Nov 2020 | A1 |
20200349809 | Shigeta | Nov 2020 | A1 |
20200349810 | Shigeta | Nov 2020 | A1 |
20200349811 | Shigeta | Nov 2020 | A1 |
20200364979 | Shigeta | Nov 2020 | A1 |
20200372746 | Shigeta | Nov 2020 | A1 |
20200372752 | Shigeta | Nov 2020 | A1 |
Entry |
---|
US 10,854,041 B2, 12/2020, Shigeta (withdrawn) |
Number | Date | Country | |
---|---|---|---|
20210056804 A1 | Feb 2021 | US |
Number | Date | Country | |
---|---|---|---|
62888708 | Aug 2019 | US |