Casinos propose a wide variety of gambling activities to accommodate players and their preferences. Some of those activities reward strategic thinking while others are impartial, but each one of them obeys a strict set of rules that favours the casino over its clients.
The success of a casino relies partially on the efficiency and consistency with which those rules are applied by the dealer. A pair of slow dealing hands or an undeserved payout may have substantial consequences on profitability.
Another critical factor is the consistency with which those rules are respected by the player. Large sums of money travel through the casino, tempting players to bend the rules. Again, an undetected card switch or complicity between a dealer and a player may be highly detrimental to profitability.
For those reasons among others, casinos have traditionally invested tremendous efforts in monitoring gambling activities. Initially, the task was performed manually, a solution that was both expensive and inefficient. However, technological innovations have been offering advantageous alternatives that reduce costs while increasing efficiency.
One such innovation provides for monitoring games through overhead video cameras. Although its potential has never been doubted, several issues remain to be solved. For instance, performing repetitive optical recognition on consecutive images in a video stream can be processing intensive. Another challenge is that gaming objects might occasionally be partially or entirely occluded from an overhead camera view. A playing card can be occluded because of the dealer's clothing, hands or other gaming objects. Yet another issue is that cards and card hands that are moved on the table can result in blurred images. Sometimes, due to space constraints a dealer may place playing card hands such that two or more playing card hands have some overlap even though ideally there should not be any overlap between distinct playing card hands. There could be other objects on the table, such as patterns on dealer clothing that may appear somewhat similar to a playing card shape and consequently result in erroneous playing card detection (“false positives”). The disclosed invention seeks to alleviate some of these problems and challenges with respect to overhead video camera based game monitoring.
It is unreasonable to expect any gaming object positioning and identification system to be perfect. There are often scenarios where a game tracking method must analyze ambiguous gaming object data in determining the game state and game progress. For instance, an overhead video camera based recognition system can produce ambiguous or incomplete data caused by playing card occlusion, movement, false positives, dealer mistakes and overlapping of card hands. Other systems involving RFID embedded playing cards could produce similar ambiguity relating to position, movement, distinction of separate card hands, dealer mistakes false positives etc. The disclosed invention seeks to alleviate some of the challenges of ambiguous data by providing methods to improve robustness of game tracking.
One of the most important aspects of table game monitoring consists in recognizing playing cards, or at the very least, their value with respect to the game being played. Such recognition is particularly challenging when the central region of a playing card is undetectable within an overhead image of a card hand, or more generally, within that of an amalgam of overlapping objects. Current solutions for achieving such recognition bear various weaknesses, especially when confronted with those particular situations.
U.S. patent application Ser. No. 11/052,941, titled “Automated Game Monitoring”, by Tran, discloses a method of recognizing a playing card positioned on a table within an overhead image. The method consists in detecting the contour of the card, validating the card from its contour, detecting adjacent corners of the card, projecting the boundary of the card based on the adjacent corners, binarizing pixels within the boundary, and counting the number of pips to identify the value of the card. While such a method is practical for recognizing a solitary playing card, or at least one that is not significantly overlapped by other objects, it may not be applicable in cases where the corner or central region of the card is undetectable due to the presence of overlapping objects. It also does not provide a method of distinguishing between face cards.
A paper titled “Introducing Computers to Blackjack: Implementation of a Card Recognition System Using Computer Vision Techniques”, written by G. Hollinger and N. Ward, proposes the use of neural networks to distinguish face cards. The method proposes determining a central moment of individual playing cards to determine a rotation angle. This approach of determining a rotation angle is not appropriate for overlapping cards forming a card hand. They propose counting the number of pips in the central region of the card to identify number cards and to identify that a card is a face card. This approach of pip counting or analyzing the central region of a card will not be feasible when a card is significantly overlapped by another object.
Several references propose to achieve such recognition by endowing each playing card with detectable and identifiable sensors. For instance, U.S. patent application Ser. No. 18/823,051, titled “Wireless monitoring of playing cards and/or wagers in gaming”, by SOLTYS, discloses playing cards bearing a conductive material that may be wirelessly interrogated to achieve recognition in any plausible situation, regardless of visual obtrusions. One disadvantage of their implementation is that such cards are more expensive than normal playing cards. Furthermore, adhering casinos would be restricted to dealing such special playing cards instead of those of their liking.
Another important aspect of table game monitoring consists in identifying which dealer is dealing at which table. Current solutions for tracking dealers employ card readers at each table that require the dealer to swipe a card containing a magnetic strip or a barcode. A product called MP21 offered by Bally Gaming has an electronic data entry device embedded into the table and requires a dealer to “log in” at the table by entering their ID. A problem with having an electronic device, such as the MP21 data entry device, at the table is that it does not seamlessly integrate into the existing table environment. These additional devices can make the customers at the table somewhat uncomfortable or suspicious. Furthermore, these devices require wiring and computing resources located at the table or near the table. A more traditional method of tracking dealers is by using a pre-determined dealer rotation schedule. A problem with this traditional method is that it is not accurate. Dealers do not always end their shift at a table at an exact predetermined time.
Another important aspect of table game monitoring consists in identifying when a deck(s) of cards are shuffled and a “fresh” deck(s) or shoe has been started. Tracking when a shuffle happens is important because the information is necessary for tracking deck count and deck penetration, which are essential to security surveillance (for catching card counters for instance). A product called MP21 offered by Bally Gaming has an electronic data entry device embedded into the table and requires a dealer to press a button at the table when a dealer introduces a fresh set of decks into game play. The issues with having electronic buttons or data entry devices at the table have been discussed in the previous paragraph.
Several references propose tracking playing cards and game outcomes by applying image processing to video captured by an overhead camera. For instance, U.S. patent application Ser. No. 11/052,941, titled “Automated Game Monitoring”, by Tran, discloses a method of recognizing a playing card positioned on a table within an overhead image and tracking a game based on recognized playing cards. An issue with such methods is that occasionally a pit supervisor may take playing cards out of the discard rack and place them back on the table in order to resolve a dispute with the customer. When the used playing cards are placed back on the table, the automated tracking system can assume that a new game has started and begin tracking a game erroneously.
It would be desirable to be provided with a method of tracking card games in an efficient manner from ambiguous sets of game data.
It would also be desirable to be provided with a method of recognizing playing cards that are in an overlapping formation in a card hand.
It would also be desirable to be provided with a method of registering a dealer at a game table in a seamless and automatic manner.
It would also be desirable to be provided with a method of detecting that a new or freshly shuffled set of playing card decks is being introduced at a game table.
It would also be desirable to be provided with a system for detecting that a set of cards placed on the table are not meant to be tracked as a new game.
According to a first embodiment of the present invention, there is provided a method of monitoring the progress of a game on a game table by efficiently establishing game states achieved during the progress, wherein each one of the states is defined by a plurality of state parameters, comprising: acquiring game data while the game is in progress; determining values of some of the parameters from at least the data and rules of the game to establish an unresolved state of the game; and updating values of at least some of the parameters from the data, the rules, and the values defining the unresolved state to establish a subsequent state of the game.
According to another embodiment of the present invention, there is provided a method of establishing boundaries of a visible portion of one of two overlapping playing cards within an image of a gaming region comprising: locating positioning features of each of the cards within the image; establishing a position order of the cards with respect to a reference point according to the features; determining whether the one playing card is overlapped according to the order and a set of rules for laying the cards; projecting edges of the one playing card, and those of the other of the cards if the one is overlapped according to results of the determining; establishing the boundaries according to the projected edges; and applying the boundaries for the purpose of recognizing the one playing card.
According to another embodiment of the present invention, there is provided a method of determining an identity of a partially visible playing card within an overhead image of a gaming region comprising: delimiting a visible portion of the card within the image; searching for pips within the portion; establishing a pip profile according to results of the searching; and determining the identity according to the profile.
According to another embodiment of the present invention, there is provided a method of generating a control signal on a game table comprising: provoking a predetermined object placement on the table; capturing an overhead image of the placement; detecting the placement within the image; and providing a control signal in response to the detecting for monitoring purposes.
According to another embodiment of the present invention, there is provided a method of managing parameters for tracking playing cards dealt from a card deck on a game table comprising: placing a cut card within the deck; dealing some playing cards of the deck on the table; recognizing the cards as they are dealt on the table; recording card tracking parameter values as the cards are recognized; dealing the cut card; recognizing the cut card as it is dealt on the table; resetting the values in response to the recognizing the cut card; and shuffling the deck in response to the recognizing the cut card, whereby the values are seamlessly recorded and reset according to game procedures for the purpose of determining game statistics.
For a better understanding of embodiments of the present invention, and to show more clearly how it may be carried into effect, reference will now be made, by way of example, to the accompanying drawings which aid in understanding and in which:
In the following description of exemplary embodiments we will use the card game of blackjack as an example to illustrate how the embodiments may be utilized.
Referring now to
An example of a bet being placed by the player 14 is shown as chips 28a within a betting region 26a. The dealer 16 utilizes a chip tray 30 to receive and provide the chips 28. An optional feature is a player identity card 34, which may be utilized by the present invention to identify the player 14.
At the beginning of every game, the players 14 that wish to play place their wager, usually in the form of the chips 28, in the betting regions 26 (also known as betting circles or wagering areas). The chips 28 can be added to the betting regions 26 during the course of the game as per the rules of the game being played. The dealer 16 then initiates the game by dealing the playing cards 18, 22. Playing cards can be dealt either from the dealer's hand, or from a card dispensing mechanism such as the shoe 24. The shoe 24 can take different embodiments including non-electromechanical types and electromechanical types. The shoe 24 can be coupled to an apparatus (not shown) to read, scan or image cards being dealt from the shoe 24. The dealer 16 can deal the playing cards 18, 22 into the dealing area 20. The dealing area 20 may have a different shape or a different size than shown in
During the progression of the game, the playing cards 18, 22 may appear, move, or be removed from the dealing area 20 by the dealer 16. The dealing area 20 may have specific regions outlined on the table 12 where the cards 18, 22 are to be dealt in a certain physical organization otherwise known as card sets or “card hands”, including overlapping and non-overlapping organizations.
For the purpose of this disclosure, chips, cards, card hands, currency bills, player identity cards and dice are collectively referred to as gaming objects. In addition the term “gaming region” is meant to refer to any section of the gaming table 12 including the entire gaming table 12.
Referring now to
The imaging system 32 utilizes periodic imaging to capture a video stream at a specific number of frames over a specific period of time, such as for example, thirty frames per second. Periodic imaging can also be used by the imaging system 32 when triggered via software or hardware means to capture an image upon the occurrence of a specific event. An example of a specific event would be if a stack of chips were placed in one of the betting regions 26. An optical chip stack or chip detection method utilizing the overhead imaging system 40 can detect this event and can send a trigger to the lateral imaging system 42 to capture an image of the one betting region 26. In an alternative embodiment the overhead imaging system 40 can trigger an RFID reader to identify the chips. Should there be a discrepancy between the two means of identifying chips the discrepancy can be flagged.
Referring now to
An optional case 54 encloses the overhead imaging system 40 and if so provided, includes a transparent portion 56, as shown by the dotted line, so that the imaging devices 50 may view a gaming region.
Referring now to
An optional case 60 encloses the lateral imaging system 42 and if so provided includes a transparent portion 62, as shown by the dotted line, so that the imaging devices 50 may view a gaming region.
The examples of the overhead imaging system 40 and the lateral imaging system 42 are not meant by the inventors to restrict the configuration of the devices to the examples shown. Any number of the imaging devices 50 may be utilized and if a case is used to house the imaging devices 50, the transparent portions 56 and 62 may be configured to scan the desired gaming regions.
According to one embodiment of the present invention, a Calibration Module assigns parameters for visual properties of the gaming region.
Referring back to
In a step 504, coefficients for perspective correction are calculated. Such correction consists in an image processing technique whereby an image can be warped to any desired view point. Its application is particularly useful if the overhead imagers are not located directly overhead and the view of the gaming region is slightly warped because of an angled viewpoint. A perfectly overhead view point would be best for further image analysis. A checkerboard or markers on the table may be utilized to assist with calculating the perspective correction coefficients.
Subsequently, in a step 506, the resulting image is displayed to allow the user to select specific points or regions of interest within the gaming area. For instance, the user may select the position of betting spots and the region encompassing the dealer's chip tray. Other specific regions or points within the gaming area may be selected.
In the next step 508, camera parameters such as shutter value, gain value(s) are calculated and white balancing operations are performed. Numerous algorithms are publicly available to one skilled in the art for performing camera calibration.
In a step 510, additional camera calibration is performed to adjust the lens focus and aperture.
Once the camera calibration is complete and according to a step 512, an image of the table layout, clear of any objects on its surface, is captured and saved as a background image. Such an image may be for detecting objects on the table. The background image may be continuously captured at various points during system operation in order to have a most recent background image.
In a step 514, while the table surface is still clear of objects additional points of interest such as predetermined markers are captured.
In the final step 516, the calibration parameters are stored in memory.
It must be noted that the calibration concepts may be applied for the lateral imaging system as well as other imaging systems.
In an optional embodiment, continuous calibration checks may be utilized to ensure that the initially calibrated environment remains relevant. For instance a continuous brightness check may be performed periodically, and if it fails, an alert may be asserted through a feedback device indicating the need for re-calibration. Similar periodic, automatic checks may be performed for white balancing, perspective correction, and region of interest definition.
As an example, if lighting in the gaming region changes, calibration may need to be performed again. A continuous brightness check may be applied periodically and if the brightness check fails, an alert may be asserted through one of the feedback devices indicating the need for re-calibration. Similar periodic, automatic checks may be performed for white balancing, perspective correction, and the regions of interest.
In an optional embodiment, a white sheet similar in shade to a playing card surface may be placed on the table during calibration in order to determine the value of the white sheet at various points on the gaming table and consequently the lighting conditions at these various points. The recorded values may be subsequently utilized to determine threshold parameters for detecting positions of objects on the table.
It must be noted that not all steps of calibration need human input. Certain steps such as white balancing may be performed automatically.
In addition to the imaging systems described above, exemplary embodiments may also make use of RFID detectors for gambling chips containing an RFID.
Referring now to
The Modules 80 to 94 communicate with one another through a network 96. A 180 Mbps Ethernet Local Area Network or Wireless Network can be used as a digital network. The digital network is not limited to the specified implementations, and can be of any other type, including local area network (LAN), Wide Area Network (WAN), wired or wireless Internet, or the World Wide Web, and can take the form of a proprietary extranet.
A Controller 98 such as a processor or multiple processors can be employed to execute the Modules 80 to 94 and to coordinate their interaction amongst themselves, with the imaging system 32 and with input/output devices 100, the optional shoe 24 and the optional RFID detectors 70. Further, the Controller 98 utilizes data stored in a database 102 for providing operating parameters to any of the Modules 80 to 94. The Modules 80 to 94 may write data to the database 102 or collect stored data from the database 102. The Input/Output devices 100, such as a laptop computer, may be used to input operational parameters into the database 102. Examples of operational parameters are the position coordinates of the betting regions 26 on the gaming table 12, position coordinates of the dealer chip tray 30, game type and game rules.
Before describing how the present invention may be implemented we first provide some preliminary definitions. Referring now to
Referring now to
In
Still referring to
Referring now to
It is important to note that the order of cards in the card hands is instrumental in determining which card overlaps which. For example, when we have three overlapped cards in a hand, there will likely be more than one area of overlap. In such a scenario, we begin with the card that is likely the most recent card in the hand (closest to the dealer in most cases) and assume that the entire pip pattern is visible for this most recent card. We then determine the area of overlap where this card overlaps the next underlying card. We recognize that this second card is fully visible except for the region of overlap it has with the first (most recent) card and extract the appropriate partial pip pattern. We then move on to the third card (usually farther from the dealer location than the first two cards) and recognize that the second card overlaps this third card and detect the area of overlap. Once the area of overlap with the second card has been detected, the remaining visible partial pip pattern for the third card can be extracted.
It must also be noted that in certain situations a casino dealer may deal the cards of a hand in a V-formation as illustrated in
Now referring back to
Still referring to
The method will now be described with respect to
In the first step, and in reference to
In the second step, and still in reference to
In the third step, and still in reference to
Subsequently, still in reference to
Moving on to the card 1302, the boundaries of its visible portion are determined to be detected edge segments 1408, 1410, 1420, and 1422 as well as the projected edge segments 1424 and 1426 of the card 1300, and the projected edge segments 1432 and 1434 of the card 1302. This correspondence is also justified by the previously established order. Indeed, the card 1302 holds the second position, and therefore, is overlapped by the card 1300, which holds the first position.
Finally, the boundaries of the visible portion of the card 1304 are determined to be its detected edges and edge segments 1412, 1414, 1416, and 1418 as well as the projected edge segments 1432, and 1434 of the card 1302. Once again, this correspondence is justified by the previously established order. Indeed, the card 1304 holds the third position, and therefore, is overlapped by the card 1302, which holds the second position.
Since all three cards 1300, 1302, and 1304 of the card hand have been processed, the coordinates of the boundaries of their visible portion are provided for recognition purposes.
According to one embodiment, the provided coordinates are used to analyze each of the visible portions individually within the captured image of the hand of cards in view of identifying the cards 1300, 1302, and 1304.
According to another embodiment of the present invention the provided coordinates are used to extract the visible portions of the cards 1300, 1302, and 1304 from the captured image of the hand of cards. The extracted portions are individually analyzed in order to identify the corresponding cards 1300, 1302, and 1304.
According to one embodiment of the present invention, card corners are detected instead of card edges, and the detected corners are applied to project corresponding card edges. According to another embodiment, card corners are detected in conjunction with card edges.
According to another embodiment of the present invention, card corners are detected, and cards bearing three detected corners are considered to occupy one of the first and last positions in the order, while other cards are considered to occupy an intermediate position.
The invention is also useful for distinguishing playing cards that are fanned out for the purpose of deck checking, as illustrated in
In a step 1600, a visible portion of the card is delimited within the image according to the method illustrated in
In a step 1602, the previously delimited portion is searched for pips.
In a step 1604, a pip profile is established according to results of the step 1602. The pip profile indicates the number of detected pips, the position of each detected pip with respect to the other detected pips, as well as the position of each pip with respect to positioning features of the corresponding card.
In a step 1606, the pip profile is analyzed to determine a preliminary identity of the card. The rank of the card is determined by analyzing the number of the position of each detected pip with respect to the other detected pips, as well as the position of each pip with respect to positioning features of the corresponding card. Although the card itself is partially visible, its pip constellation may be entirely visible, in which case the rank of the card is determined unambiguously. However, if its pip constellation is only partially visible, the detected pips may not be sufficient to determine the rank of the card unambiguously, in which case several candidate ranks may be proposed.
A fully visible pip profile indicating that no pips were detected is considered to belong to a card of rank Jack, Queen, or King.
In a step 1608, an index of the card is detected within the image.
In a step 1610, an index profile is established according to the previously detected index. The profile details features of the detected index.
In a step 1612, the identity of the card is determined according to the index profile and the preliminary identity established in the step 1606.
According to one embodiment of the present invention, if the card is known to be entirely visible, its pip profile may be restricted to the number of detected pips, and features of the detected pip. The suit of the card is optionally determined from the shape of the detected pips while the rank of the card is determined from the number of detected pips.
According to one embodiment of the present invention, the pip profile established in the step 1604 also indicates the shape of the detected pips. According to the same embodiment, in the step 1606, the suit of the card is determined by analyzing the recorded shape of the detected pips.
According to a preferred embodiment of the present invention, the step 1612 is performed by selecting one of several candidates established in the step 1606 according to the analysis of the index profile.
According to another embodiment, the step 1612 is performed by analyzing the index profile and comparing the results of the analysis to the preliminary identity established in the step 1606.
According to another embodiment, a reliability of the preliminary identity established in the step 1606 is evaluated. If the preliminary identity is deemed reliable, it is considered to be the final identity of the card, and the steps 1608, 1610, and 1612 are not performed. Otherwise, the steps 1608, 1610, and 1612 are performed.
According to another embodiment, if the preliminary identity established in the step 1606 proposes no more than one candidate, it is considered to be reliable as the final identity of the card, and the steps 1608, 1610, and 1612 are not performed.
According to another embodiment of the present invention, a pip region is delimited within the visible portion from the position features of the card. The step 1602 is performed exclusively within the region and therefore, more efficient.
According to another embodiment of the present invention, the step 1600 consists in: determining the positioning features of the partially visible card as well as those of the overlapping card; projecting the edges of the cards in order to identify an area of overlap; and subtracting the area from an area delimited by the edges of the partially visible card in order to delimit the visible portion, whereby the visible portion is delimited with less accuracy but within a lesser amount of time.
Although the invention has been described within the context of a playing card overlapped by one or several other playing cards, it may very well be applied to a playing card overlapped by other combinations of gaming objects.
The method will now be described with reference to
In the first step, a visible portion of the cards 1700 and 1702 is delimited according to the method illustrated in
In the second step, pips are searched within the previously delimited visible portions of the cards 1700, 1702, 1704, and 1706. Three pips 1708 are detected within the visible portion of the card 1700, three pips 1710 are detected within the visible portion of the card 1702, three pips 1712 are detected within the visible portion of the card 1704, and four pips 1714 are detected within the visible portion of the card 1706.
In the third step, a pip profile is established for each of the cards 1700, 1702, 1704, and 1706 according to the previously identified pips 1708, 1710, 1712, and 1714.
The pip profile of the card 1700 indicates that the three pips 1708 were detected. It also details the position of each of the pips 1708 with respect to the other pips 1708, as well as the position of each of the pips 1708 with respect to positioning features of the card 1700.
The pip profile of the card 1702 indicates that the three pips 1710 were detected. It also details the position of each of the pips 1708 with respect to the other pips 1710, as well as the position of each of the pips 1710 with respect to positioning features of the card 1702.
The pip profile of the card 1704 indicates that the three pips 1712 were detected. It also details the position of each of the pips 1712 with respect to the other pips 1712, as well as the position of each of the pips 1712 with respect to positioning features of the card 1704.
The pip profile of the card 1706 indicates that the four pips 1714 were detected. It also details the position of each of the pips 1714 with respect to the other pips 1714, as well as the position of each of the pips 1714 with respect to positioning features of the card 1706.
In the fourth step, a preliminary identity is determined for each of the cards 1700, 1702, 1704, and 1706 from their respective and previously established pip profiles.
More specifically, since the cards 1702 and 1706 are known to be entirely visible, their respective rank is determined accurately. The rank of the card 1702 is identified as Three according to the number of the detected pips 1708, the position of each of the pips 1708 with respect to the other pips 1708, as well as the position of each of the pips 1708 with respect to the positioning features of the card 1702. Similarly, the rank of the card 1706 is identified as Four according to the number of the detected pips 1714, the position of each of the pips 1714 with respect to the other pips 1714, as well as the position of each of the pips 1714 with respect to the positioning features of the card 1706.
Although the card 1704 is known to be overlapped, it benefits from a unique pip profile that may only belong to a card of rank Three. As for the card 1700, it is known to be overlapped and its pip profile is not unique; it may belong to a card of rank Four or Five. As a result, the preliminary identity of the card 1700 is comprised of two candidates: a Four or a Five.
In the fourth step, the respective indexes 1716, 1718, 1720, and 1722 of the cards 1700, 1702, 1704, and 1706 are detected.
The fifth step consists in establishing an index profile for each of the cards 1700, 1702, 1704, and 1706 according to their respective and previously detected indexes 1716, 1718, 1720, and 1722 where each profile details features of a corresponding index.
The sixth and final step consists in determining a definite identity of each of the cards 1700, 1702, 1704, and 1706 according to its respective and previously established index profile and preliminary identity. The card 1700 is recognized as a Five of Diamonds, the card 1702, as a Four of Diamond, the card 1704, as a Three of Diamonds, and the card 1706, as a Three of Diamonds.
According to one embodiment of the present invention, since the card 1702 is known to be entirely visible, its pip profile details the features and number of detected pips 1710. The suit of the card is determined from the features of the detected pips 1710, while its rank is determined from the number of detected pips 1710. Similarly, since the card 1706 is known to be entirely visible, its pip profile details the features and number of detected pips 1714. The suit of the card is determined from the features of the detected pips 1714, while its rank is determined from the number of detected pips 1714.
According to the preferred embodiment of the present invention, the final identity of the card 1700 is determined by performing an index analysis, and selecting one of the two candidates proposed by the preliminary identity, namely the Five of Diamonds, according to results of the analysis. More concretely, a pre-trained statistical classifier trained specifically to distinguish between the two candidates, namely the Four (4) and the Five (5), analyzes the index profile, and selects the appropriate candidate. It is important to note that a statistical classifier trained to distinguish between a limited number of candidate ranks is usually more accurate and efficient than a statistical classifier trained to distinguish between all thirteen ranks. Therefore, although the pip analysis performed according to the present invention does not always result in an accurate identity of a playing card, it does limit the number of candidate ranks, and allows the use of specialized statistical classifiers, thereby increasing recognition efficiency and accuracy.
According to another embodiment, the final identity of each of the cards 1700, 1702, 1704, and 1706 is determined by analyzing its respective index profile, and comparing the results of the analysis to the preliminary identity.
According to another embodiment, since the cards 1702 and 1706 are known to be entirely visible, their preliminary identity is considered to be their final identity. Consequently, the cards 1702 and 1706 are not subjected to index analysis.
According to another embodiment, since the preliminary identity of the cards 1702, 1704, and 1706 proposes no more than one candidate, it is considered to be their final identity. Consequently, the cards 1702, 1704, and 1706 are not subjected to index analysis.
The IP Module 80 may be implemented in a number of different ways. In a first embodiment, overhead imaging system 32 (see
Referring now to
Now referring to
Moving to a step 1902 the process waits to receive an overhead image of a gaming region from overhead imaging system 40. At a step 1904 a thresholding algorithm is applied to the overhead image in order to differentiate playing cards from the background to create a threshold image. A background subtraction algorithm may be combined with the thresholding algorithm for improved performance. Contrast information of the playing card against the background of the gaming table 12 can be utilized to determine static or adaptive threshold parameters. Static thresholds are fixed while dynamic thresholds may vary based upon input such as the lighting on a table. The threshold operation can be performed on a gray level image or on a color image. A step 1904 requires that the surface of game table 12 be visually contrasted against the card. For instance, if the surface of game table 12 is predominantly white, then a threshold may not be effective for obtaining the outlines of playing cards. The output of the thresholded image will ideally show the playing cards as independent blobs such as the blob 800 illustrated in
In a next step 1906, a contour, such as the contour 802 illustrated in
Once the contours have been obtained processing moves to a step 1908 where shape analysis is performed in order to identify contours that are likely not cards or card hands and eliminate these from further analysis. By examining the area of the contour and the external boundaries, a match may be made to the known size and/or dimensions of cards. If the contour does not match the expected dimensions of a card or card hand it can be discarded.
Moving next to a step 1910, line segments, such as the line segments 804 illustrated in
Moving to a step 1912, one or more corners of cards, such as the corners 806 illustrated in
Moving to a step 1914, based on known dimensions of a playing card and based on positioning features (the line segments and/the corner points), card boundaries are projected and areas of card overlap, such as an area 812 illustrated in
Moving to a step 1916, the card corners are utilized to obtain a ROI encompassing a card index located near the card corner, such as the ROI 808 illustrated in
Moving to a step 1918, the ROI information and card overlap areas for each card and card hand are sent to the Identity Module for further analysis.
Finally moving to a step 1920 the method waits for a new image.
Referring to
Moving to a step 2004, partial pip patterns can be extracted from the non-overlapped areas of the card hand. One method to detect the partial pip pattern is to perform a threshold operation in the non-overlapped card area in order to determine blobs representing the pips. Filtering operations such as erosion/dilation and smoothing operations can then be performed to improve the smoothness and continuity of the blobs. Blobs can then be classified as pip or not pip based on their dimensions (size/width/height etc.). The resulting pip blobs can be further analyzed using a template matching method to determine the suit. Once the suit of the pips has been determined, their relative positions with respect to each other (distance/angle) can be utilized to determine the partial pip pattern.
After detecting the partial pip pattern in a step 2004, we move to a step 2006 where we determine possible candidates for the card value based on the partial pip pattern. As an example, with reference to
Referring back to
Now referring to
Referring back to a step 2008 of
In a next step 2010, we check to see if there are any more cards in the image to recognize and if there are more cards remaining we repeat the recognition process starting at the step 2004. Otherwise, we output the identities of the cards and move to the step 2002 to wait for a new image and new ROI and Card Overlap Area information.
An advantage of recognizing the partial pip pattern before applying template matching is that it narrows down the possible identity of the card. Consequently, fewer template matches need to be done to recognize the index, thus speeding up the recognition process. By narrowing the number of card identity candidates, it also helps improve recognition accuracy. Importantly, the method helps determine the value of the playing card when it is partially occluded.
Optionally, in a step 2008, the ROI may be pre-processed to improve recognition results. Examples of ROI pre-processing steps include thresholding the image in the ROI and/or histogram normalization. Rotation of the ROI may also be performed in order to obtain an upright index orientation. Examples of other recognition algorithms that may be utilized with the present invention include, Support Vector Machines, Hidden Markov Models and Bayesian Networks. A combination of recognition algorithms may be used to improve accuracy of recognition.
It is important to note that the index recognition step can optionally be skipped for cards where the entire pip pattern is visible and consequently the card can be recognized from the pip pattern alone. Index recognition is needed when the entire pip pattern is not visible.
We shall now describe the function of the Intelligent Position Analysis and Tracking Module (IPAT Module) 84 (see
We shall now discuss the functionality of the game tracking (GT) module 86 shown in
For the purposes of the following description, a game state is defined by a plurality of state parameters such as the identity of a playing card dealt on the gaming table or an amount wagered by a player.
The GT module 86 can have a single state embodiment or a multiple state embodiment. In the single state embodiment, at any given time in a game, one valid current game state is maintained by the GT module 86. When faced with ambiguity of game state, the single state embodiment forces a decision such that one valid current game state is chosen. In the multiple state embodiment, multiple possible game states may exist simultaneously at any given time in a game, and at the end of the game or at any point in the middle of the game, the GT module 86 may analyze the different game states and select one of them based on certain criteria. When faced with ambiguity of game state, the multiple state embodiment allows all potential game states to exist and move forward, thus deferring the decision of choosing one game state to a later point in the game. The multiple game state embodiment can be more effective in handling ambiguous data or game state scenarios.
In order to determine states, the GT module 86 examines data frames. Data frames comprise data on an image provided to the GT module 86 from the IP module 80 and the IPAT module 84. Referring now to
A data frame may include the following data:
The GT module 86 utilizes data frames as described with regard to
A stored game state may be valid or invalid. A valid state is a state that adheres to the game rules, whereas an invalid state would be in conflict with the game rules. During the game tracking process, it is possible that the current game state cannot account for the key event in the current data frame 2208 being analyzed. The data frame 2208 can contain information that is in conflict with the game rules or the current game state. In such an event, the current game state may be updated to account for the data in the frame 2208 as accurately as possible, but marked as an invalid state. As an example in Blackjack, a conflicting data frame would be when the IP module 80 or IPAT module 84 indicates that the dealer has two cards, while one of the players only has one hand with one card, which is a scenario that conflicts with Blackjack game rules. In this example, the dealer hand in the game state is updated with the second dealer card and the game is set to invalid state.
In the event of an invalid state or data frames with conflicting information, ambiguity resolution methods can be utilized to assist in accurately determining valid states. An embodiment of the present invention utilizes either or a combination of back tracking, forward tracking, and multiple game states to resolve ambiguities.
To further explain how backtracking may be utilized to resolve ambiguity with regard to key events and states we refer now to
The use of backward tracking requires the system to store in memory previous game states and/or previous data frames. The number of temporally previous game states or data frames to be stored in memory can be either fixed to a set number, or can be variable, or determined by a key event.
Game states continue to be established until the game ends at game state 2312 and reset 2314 occurs to start a new game state 2300.
Referring now to
The forward tracking method requires the front buffer 2202 (see
Game states continue to be established until the game ends at game state 2412 and reset 2414 occurs to start a new game state 2400.
Although backward tracking and forward tracking have been described as separate processes, they may be utilized in conjunction to resolve ambiguous data. If either one fails to establish a valid state, the other may be invoked in an attempt to establish a valid state.
Referring now to
At a step 2508 the positioning features and identities of cards and card hands in the data frame are matched to the card hands stored in the current game state. The matching process can take on different embodiments such as priority fit. In the case of priority fit, card hands in the game state are ordered in priority from the right most hand (from the dealer's perspective) to the left most hand. In this ordering, the card hand at the active betting spot that is located farthest to the right of the dealer would have the highest pre-determined priority in picking cards/card hands in the data frame to match to itself. The right most card hand in the game state would pick the best match of cards/card hands from the data frame, after which the second right most card hand in the game state would get to pick the matching cards/card hands from the remaining cards/card hands in the data frame.
In an alternate embodiment of matching, a best fit approach can be used in order to maximize matching for all card hands in a game state. In the best fit approach, no specific card hand or betting location is given pre-determined priority.
In some cases a perfect match with no leftover unmatched cards or card hands occurs. This indicates that the incoming data frame is consistent with the current game state and that there has been no change in the game state.
Moving now to a step 2510 a determination is made as to whether there are any unmatched cards or card hands left from the previous step. If there are no unmatched cards or card hands the process returns to the step 2502. Unmatched cards or card hands may be an indication of a change in the game state. At a step 2512, the unmatched cards or card hands are analyzed with respect to the rules of the game to determine a key event. At a step 2514, if the determined key event was valid, the next game state is established at a step 2516, after which the process returns to the step 2502. Returning to the step 2514, if the key event is invalid or ambiguous then processing moves to a step 2518 where an ambiguity resolution method such as backtracking or forward tracking may be applied in an effort to resolve the ambiguity. At a step 2520 a test is made to determine if the ambiguity is resolved. If so, processing moves to the step 2516 otherwise if the ambiguity is not resolved, then a next game state cannot be established and as a result, processing returns to the step 2502 and waits for the next frame.
We shall now discuss how backward tracking (shown as feature 2308 of
The backward tracking process starts at step 2600 by initializing counter “i” to 1 and initializing “n” to the predetermined maximum number previous game states to backtrack to. In the next step 2602 the ambiguous key event from the single state tracking process (step 2514 of
Backward tracking can be used to track to previous frames, in order to look for a valid key event, or to track to previous valid game states.
Referring now to
It is also possible that backward tracking may not be able to account for certain key events, in which case other conflict resolution methods described next can be utilized.
We shall next discuss forward tracking in more detail. Forward tracking requires a front buffer 2202 of
Referring now to
Referring now to
After forward tracking has been done, the data frame that produced the key event that resolved the ambiguity can be established as the current frame 2208 (see
A particularly useful application of forward tracking can be to minimize the effects of temporary occlusion of gaming objects that can happen during a game as the dealer moves her physical hand across the table, or when there is shaking or vibration of the image of the table. In this alternate application of forward tracking, we can detect if a gaming object has been removed or temporarily occluded by looking in the front buffer of data frames. As an example, assume that a specific card “C” is present at a certain location “X” in a data frame. If the card C is absent at location X from the next data frame, then either card C has been removed from the table, or moved to a different location, or it has been temporarily occluded. We can look into the front buffer of frames to see if card C is present in location X in any of the frames in the front buffer. If card C is present at location X in a front buffer frame, it is very likely that card C is just temporarily occluded and that it has not been moved or removed. Therefore, by performing this analysis, we can insert card C at location X back into the intermediate data frames where card C was missing, thus reducing the chance of ambiguous game states. In this manner, the use of forward buffer can be utilized to mitigate the ambiguity effects of temporary occlusion/disappearance of cards (or other gaming objects) on the gaming table.
Another method that can be used for ambiguity resolution is forward-event waiting. Instead of looking in the front buffer frames for a key event that resolves an ambiguity with respect to the current state, the forward-event waiting method can mark a card hand as being ambiguous and then continue processing the next frame and making game state updates. The ambiguity can be resolved when a specific event relevant to the ambiguous hand is detected at some point in the future. Optionally the ambiguous card hand can have a range within which to look for the specific event that resolves the ambiguity. The range can be a predetermined number of frames, predetermined period of time, or predetermined two events. For example, it can be implemented as a counter that counts the number of frames for which the method “waits” for the ambiguity to be resolved. The counter can have a maximum predetermined number of frames. The range can also be defined by predetermined events such as game start, game end, game play etc. . . . We can look for a relevant key event that resolves the ambiguity within this range. The forward-event waiting method is more suited to card hand ambiguities that can be resolved by game events that can happen much later in the game instead of within a predetermined time window. The forward-event waiting ambiguity resolution can be used together with forward tracking and backward tracking for higher game tracking accuracy.
Tracking “surrendered” hands in Blackjack is an example that is particularly well suited for the forward-event waiting method. In this example the forward-event waiting method with a range of two predetermined game events is utilized. In Blackjack a player has the choice to fold their hand, at the cost of half their original bet. This process is called surrender. Once all players have two cards, and the dealer has one card, the players have an option to surrender their hand. Once there is a game play event (if any player has more than two cards, or has more than one hand due to splits, or the dealer has two or more cards), the player loses the option to surrender. The forward-event waiting ambiguity resolution method can be used to track surrendered hands. Usually when a card hand is missing in the incoming data frame, it could either be removed as the player surrendered her hand, or it could be temporarily occluded by the dealer or some other object. A card hand can sometimes be occluded for a long period of time, for instance when a dealer is speaking to a player and his shirt sleeve is occluding the player's two card hand. In these types of situations, forward tracking may not be effective and consequently forward-event waiting can be used.
In one embodiment of using forward-event waiting to track surrendered hands, the method marks all initial two card hands as ambiguous (the card hands are set to surrender by default) from the start of the game play event (if any player has more than two cards, or has more than one hand due to splits, or the dealer has two or more cards). As new data frames are received, the ambiguity resolution for every hand is simply the detection of the hand in the current data frame. If an ambiguous hand is detected in the current data frame, it is resolved as being ‘not surrendered’. On the event of a game end, all ambiguous hands that weren't detected in the period from the start of the game play event to the game end event, are marked as “surrendered”. Most likely, the hand was not detected because the player surrendered the hand, and it was discarded from the table. Resolving surrendered hands by forward tracking up to a particular data frame may not be as accurate, since a hand could inaccurately be marked as surrender if it was being occluded in the limited set of forward data frames being examined. Therefore, the forward-event waiting based ambiguity resolution is the preferred embodiment to track surrendered hands. In this example the forward-event waiting utilizes a range of two predetermined game events—game play event and game end event.
It is important to note the differences between forward tracking and forward-event waiting for ambiguity resolution. In forward tracking, an attempt is made to resolve the ambiguous card hand (or game state) using game event information from data frames in the front buffer. The next frame is analyzed only after it has been determined if the card hand ambiguity can be resolved or not. In forward-event waiting, the method marks a card hand as ambiguous and continues processing subsequent frames and updating card hands (and game states). The ambiguous card hand is resolved when an appropriate game event is detected in the future to resolve the ambiguity. Forward tracking is well suited for certain types of ambiguities. As an example, forward tracking is well suited to minimize the effects of temporary occlusion of gaming objects. As an example, forward event waiting is well suited for detecting a player hand surrender.
As mentioned hereinabove, a “game state” is defined by a plurality of game state parameters. For the purposes of the following description, if each of the parameters has a resolved value, the corresponding game state is said to be “resolved”. Otherwise, the corresponding game state is said to be “unresolved”.
In a step 3000, game data is acquired. According to the preferred embodiment of the present invention, the step consists in obtaining information from the IPAT module 84 and IP module 80, and optionally the bet recognition module 88. Subsequently, in a step 3002, it is determined whether a current state of the game is resolved. If the current state is found to be unresolved in the step 3002, it is determined whether the current state of the game is resolvable from a current set of captured data and a set of game rules in accordance to a step 3004. If the current state of the game is found to be resolvable in the step 3004, it is resolved in a step 3006.
If the current state is found to be resolved in the step 3002, or if the current state of the game is not found to be resolvable in the step 3004, it is determined whether a new state of the game is to be established in accordance with a step 3008. If no new state of the game is to be established, the method returns to the step 3000.
However, if it is found that a new state of the game is to be established in the step 3008, it is determined whether the current state of the game is resolved in accordance to a step 3010.
If the current state of the game is found to be resolved in the step 3010, the resolved current state of the game, the data captured in the step 3000, and the rules of the game are processed to create a new current state of the game in accordance to a step 3012. Subsequently, the method returns to the step 3000.
However, if the current state of the game is found to be unresolved in the step 3010, the unresolved state of the game, the data captured in the step 3000, and the rules of the game processed to create a new current state of the game in accordance to a step 3014. Subsequently, the method returns to the step 3000.
As a result, and according to the present invention, the occurrence of an unresolved state does not interrupt the establishment of subsequent game states. Game state parameters are continuously updated and the progress of the game is continuously monitored insofar as possible from the provided data.
According to one embodiment of the present invention, casino personnel may request for a latest, if incomplete, set of game state parameter values to be displayed on a monitor regardless of any occurrence of unresolved game states prior to the request.
Forward-event waiting will now be described with reference to
Returning to
In another embodiment, a vision based bet recognition system can be employed in conjunction with the other Modules of this system. There are numerous vision based bet recognition embodiments, such as those described in U.S. Pat. No. 5,782,647 to Fishbine et al.; U.S. Pat. No. 5,183,081 to Fisher et al; U.S. Pat. No. 5,548,110 to Storch et al.; and U.S. Pat. No. 4,814,589 to Storch et al. Commercially available implementations of vision based bet recognition, such as the MP21 system marketed by Bally Gaming or the BRAVO system marketed by Genesis Gaming, may be utilized with the invention.
The Bet Recognition Module 88 can interact with the other Modules to provide more comprehensive game tracking. As an example, the GT Module 86 can send a capture trigger to the Bet Recognition Module 88 at the start of a game to automatically capture bets at a table game.
Referring to
Optionally the system can recognize special player identity cards with machine readable indicia printed or affixed to them (via stickers for example). The machine readable indicia can include matrix codes, barcodes, identity numbers or other identification indicia.
Optionally, biometrics technologies such as face recognition can be utilized to assist with identification of players.
Referring now to
We will now discuss the functionality of the Surveillance Module 92 illustrated in
Referring now to
The Surveillance Module 92 can replay certain video sequences relating to gaming events based on a selection of a game event.
We shall now discuss the Analysis and Reporting Module 94 of
Output, including alerts and player compensation notifications, can be through output devices such as monitors, LCD displays, or PDAs. An output device can be of any type and is not limited to visual displays and can include auditory or other sensory means. The software can potentially be configured to generate any type of report with respect to casino operations.
It is important to note that although the step 4000 was described as performed by a dealer, it may very well be performed by an appropriate casino employee or patron.
According to a preferred embodiment of the invention, a predetermined object placement consists in the placement of one of several ID cards on the game table, where each ID card designates a different game event.
Referring to
In the illustrated and preferred embodiment, the machine readable code consists in a numeric code. However, according to alternate embodiments of the present invention, other machine readable codes are utilized such as symbolic codes, alphanumeric codes, patterns, bar codes, matrix codes, and color codes. As an example, most cut cards are of solid color and are usually yellow or orange. This solid color can be utilized to recognize the cut card.
It is important to note that different card types can bear different machine readable codes. For instance, according to one exemplary embodiment of the present invention, the Dealer ID card 4100 bears a numeric code, the Shuffle card 4102 consist of a blank cut card that is orange in color, and the Pause card 4104 bears a symbolic code.
The Dealer ID card 4102 serves the purpose of identifying a dealer assigned to a monitored game table. According to a preferred embodiment of the present invention, each dealer is provided with a Dealer ID card bearing a unique, machine readable, numeric code. Prior to performing her first dealing operation on a game table, a dealer places her Dealer ID card on the game table such that the unique, numeric code is visible to an overhead camera. The IP Module 80 identifies and provides the unique numeric code to the Dealer Tracking Module 95 which, in turn, records the provided code in the database 182 such that subsequent tracked games are associated to the identified dealer. After performing her last operation, the dealer removes her Dealer ID card from the table such that subsequently tracked games are associated with a following dealer.
According to one embodiment of the present invention, and referring to
Traditionally, a dealer uses a cut card to demarcate a deck of cards into two sets. As the game progresses, the dealer withdraws cards from the deck until she reaches the cut card, at which point she is required to shuffle the entire deck of cards. Such an event is critical in the process of tracking playing cards as it introduces a new deck of cards to the game table. According to the present invention, when the dealer reaches the cut card, she places the Shuffle card 4102 on the table, such that its machine readable code is visible to the overhead camera. The IP Module 80 identifies and provides the code to the GT Module 86.
According to a preferred embodiment of the present invention, the GT Module 86 marks the next round of games as starting with a new deck of cards and resets the card deck's count and penetration upon receiving the code.
According to another embodiment of the present invention, the GT Module 86 records the occurrence of a card shuffle upon receiving the code.
Once the Shuffle card 4102 is placed on the game table, the dealer may either shuffle the existing deck of cards or discard the deck and introduce a new one to the game table.
According to a preferred embodiment of the invention, the Shuffle card 4102 is used as a cut card. However, according to another embodiment, the Shuffle card 4102 and the cut cards are two distinct cards.
Finally, the Pause card 4104 is used whenever game operations are to be halted. For instance, when a dispute arises at the game table, a pit supervisor may “back up a hand”, a process that consists in removing playing cards from the discard rack and placing them back on the game table. Such an event is critical in the process of tracking playing cards as previously discarded playing cards momentarily recover their positions on the game table. According to the present invention, when a pit supervisor wishes to “back up a hand”, she places the Pause card 4104 on the table such that its machine readable code is visible to the overhead camera. The IP Module 80 identifies and provides the code to the GT Module 86.
According to a preferred embodiment of the present invention, the GT Module 86 suspends game tracking activities upon receiving the code. Once the dispute is resolved, the pit supervisor removes the previously discarded cards from the table, places these cards in the discard rack, and removes the Pause card 4104 from the table.
According to one embodiment of the present invention, the suspension lasts a predetermined amount of time. For instance, it may last 191 seconds from the moment the Pause card 4106 was identified by the IP Module 80. According to another embodiment, the suspension may hold until the Pause Card 4106 is removed from the table. Once the suspension ends, game tracking operations are resumed.
According to yet another embodiment of the present invention, the GT Module 86 records the game interruption in response to receiving the code.
According to one embodiment of the present invention, and in reference to
According to one embodiment of the present invention, the IP Module 80 identifies the Shuffle cards 4102 and the Pause cards 4106 by analyzing overhead images of a gaming region.
According to another embodiment of the present invention, the IP Module 80 identifies the Shuffle cards 4102 by using the card shoe 24, which is capable of reading cut cards as they are dealt on the gaming table 12.
Although not shown in
The terms imagers and imaging devices have been used interchangeably in this document. The imagers can have any combination of sensor, lens and/or interface. Possible interfaces include, without limitation, 18/180 Ethernet, Gigabit Ethernet, USB, USB 2, FireWire, Optical Fiber, PAL or NTSC interfaces. For analog interfaces such as NTSC and PAL a processor having a capture card in combination with a frame grabber can be utilized to get digital images or digital video.
The image processing and computer vision algorithms in the software can utilize any type or combination or color spaces or digital file formats. Possible color spaces include, without limitation, RGB, HSL, CMYK, Grayscale and binary color spaces.
The overhead imaging system may be associated with one or more display signs. Display sign(s) can be non-electronic, electronic or digital. A display sign can be an electronic display displaying game related events happening at the table in real time. A display and the housing unit for the overhead imaging devices may be integrated into a large unit. The overhead imaging system may be located on or near the ceiling above the gaming region.
Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims.
The present application claims priority from U.S. provisional patent applications No. 60/736,334, filed Nov. 15, 2005; 60/760,365, filed Jan. 20, 2006; 60/808,952, filed May 30, 2006, 60/809,330 filed May 31, 2006 and 60/814,540 filed Jun. 19, 2006.
Number | Date | Country | |
---|---|---|---|
60736334 | Nov 2005 | US | |
60760365 | Jan 2006 | US | |
60808952 | May 2006 | US | |
60809330 | May 2006 | US | |
60814540 | Jun 2006 | US |