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 document or the patent disclosure as it appears in the Patent and Trademark Office patent file or records, but otherwise reserves all copyright rights whatsoever. The following notice applies to the software and data as described below and in the drawings referred to herein: Copyright 2006, Cyberscan Technology, Inc., All Rights Reserved.
The subject matter of the present application is related to the subject matter of commonly assigned and co-pending patent application entitled “Regulated Gaming—Compartmented Freelance Code,” Atty. Docket No. CYBS6004A and is also related to the subject matter of commonly assigned and co-pending patent application entitled “Regulated Virtual Display,” Atty. Docket No. CYBS6004B, each application of which is being filed on even date herewith.
This invention relates generally to the field of regulated pay computer-controlled games, either games of skills or games of chance and more particularly to the field of integrating, certifying and downloading games developed by multi-parties and of building relationships between players and game operators to promote the games.
Presently game regulation essentially considers a slot machine as a standalone piece of equipment supplied entirely by a single vendor (e.g. IGT, WMS, Bally). Although standards now allow for some vendor interoperability between peripheral devices (e.g. hopper, bill accepter, ticket printer) and a central accounting system (e.g. IGT/GSA SAS Standard Accounting System protocol), a slot machine as delivered comprises essentially proprietary components developed and manufactured by a single supplier. In particular, game regulators have made no attempt to adapt their standards to enable the suppliers to leverage on the extraordinary multimedia capabilities of the PC platform and the advances in distributed network security. Consequently, the operating system and game software controlling a slot machine are proprietary and almost entirely developed by the supplier's software programmers, such as to meet regulatory requirements that are out of sync with main stream computing. It is worrying to see that current gaming regulation leaves no choice to the suppliers but to modify the source code of their operating system (e.g. Linux). This prevents them from continually benefiting from security peer review and from associated security upgrades developed by operating system experts. Consequently, the operating system of such gaming machines is considerably weakened and fractured, exposing the suppliers and game operators to stealth and focused hacking attacks.
It is reasonable to believe that sooner or later the standards formulated by the Trusted Computer Group (TCG) to secure distributed computer network will be adopted by game regulators. Therefore, well architectured and security-hardened commercial multimedia operating systems may be used by slot machine vendors, without needing to hack the kernel source code.
As an immediate result of adopting industry security standards, the vendors may allocate more resources to develop more attractive games and enable their download from a central system. However, present game regulation is such that the entire game software may only be developed by the slot supplier himself, thus significantly impeding suppliers from offering games inspired or derived from the best-of-breed and phenomenally popular game titles available on Xbox and PlayStation, or other games developed by freelance game developers. It is unlikely that the culture inside a slot manufacturer's game software engineering department would ever attract creative minds to create games on par with what is and will be available in the main stream gaming arena.
The path for freelance game development companies that would be looking at introducing their games and game technologies into the highly regulated casino marketplace has traditionally been a narrow and tortuous one. Historically, such companies have held only three real options: (a) to partner with an established casino game manufacturer such as IGT, Bally or WMS, (b) to sell their designs to an established game manufacturer, or (c) to attempt to create their own casino game manufacturing company. All of these paths are difficult to tread. For example, large legacy gaming companies have their own game creation studio, fully staffed with trained artists and trained software developers. As such, they are generally reluctant to introduce truly visionary game designs into their gaming libraries, as they have achieved a longstanding history of profitability with more conservative games revolving essentially around boring fruit-machine-like games, poker games and secondary games such as Wheel of Fortune and Mystery Jackpot.
A further limitation of the existing casino gaming marketplace is that game developers looking to start their own casino game manufacturing companies face several key obstacles, the most important of which being the lengthy and prohibitively expensive regulatory process that must be navigated to gain even a precarious foothold in the casino gaming market.
Most of all and sadly enough, there is no dialog between the game regulators and innovative gaming companies that would otherwise enter the regulated gaming market. This is because such innovative gaming companies most often do not have the coveted game license, which is required in every state. Therefore, promising freelance game development companies (such as those developing dazzling games for console-type platforms such as the Xbox and PlayStation for example or those developing PC-based games) that would be looking at introducing variants of their games into the highly regulated casino marketplace are, in effect, completely shut out. Indeed, the dazzling graphics rendered in such games rely upon constantly evolving PC and game console hardware and software technologies, including operating systems such as Microsoft Windows XP and forthcoming Vista. To their defense, the attitude of gaming regulators is understandable, as these game technologies are not well adapted for the highly regulated gaming environment, mainly because of security issues.
The Gaming Standard Association (GSA) is not helping the situation as it is formed by members that are in majority representatives of the influential established casino game manufacturers that have little interest in changing whatsoever. The gaming certification labs that are subcontracted by equipment suppliers to test and certify that their equipment meets applicable game regulation do indeed set gaming standards. These gaming certification labs also do not attempt to assume a leadership role to adapt their standards to lay the foundations on which new computer technologies could meet the security standards for the regulated gaming market. For these reasons, the progress that has been achieved in general computer security has gone largely unnoticed and innovative gaming companies are still barred from offering innovative gaming technologies. The legacy game manufacturers' stranglehold on casino gaming has excluded visionary game designers from fully participating in this market and has prevented game operators from offering the public the best possible games.
In is an object of the present invention to enable freelance game developers to offer dazzling electronic games to the regulated casino gaming marketplace. It is another object of the present invention to ensure that the freelance game developers receive compensation that is commensurate with the success of their games. A still further object of the present invention is to provide game operators with timely information to enable them to tailor their regulated game offerings based on demand and/or popularity of identical trial games that use only simulated money and that are made available to the public over an Internet portal. It is a further object of the present invention to provide players with the location of the casinos offering their favorite game(s) for playing with real money, together with the promotions offered if any. It is yet another object of the present invention to provide game operators with the contact information of the players and their list of favorite trial games, to enable them to offer incentives and to attract them to their casino. Another object of the present invention is to offer freelance game developers a method for developing, integrating licensing tags, testing and certifying secure downloadable electronic games, such that an unprecedented generation of advanced electronic games may be offered to players in casinos on a relatively short timetable.
It is another object of the invention to offer players, operators, licensed developers and freelance developers search means to query the regulated gaming exchange and obtain results structured according to the formulated query and related results (popularity ratings, most often requested queries, general promotional offers and specifically targeted promotional offers, for example).
In is another object of the present invention to offer the freelance game developers a compartmented architecture for developing, integrating licensing tags, testing and certifying secure downloadable electronic games such that an unprecedented generation of dazzling electronic games may be offered to players in regulated gaming places on a relatively short timetable. In is a further object of the present invention to ensure that the freelance game developers receive compensation based on the success of their games.
Accordingly, an embodiment of the present invention is compartmented system architecture and associated methods for enabling freelance game developers to (a) integrate their game software together with the gaming manufacturer software and (b) tag their software such as to receive compensation based on the success of their games. The combined tagged freelance software and gaming manufacturer software may rapidly pass through certification testing and be downloaded overnight to a large number of gaming machines such as to offer players in casinos an unprecedented choice of new generation electronic games within a relatively short timetable.
Compartmenting for totally isolating the graphics-rich freelance (and outcome-free) code from the slot supplier (and outcome-determining) code is obtained, according to an embodiment of the present invention, by adopting a blue-screening paradigm wherein the freelance code executes in a process sandbox and renders its entertainment outcome-free graphics in a totally isolated background display plane while the slot supplier code renders its accounting graphics and outcome graphics in a foreground display plane as small graphics gadgets over a neutral plane. The foreground and background display planes are mixed together using the pervasive blue-screening paradigm used in TV studio programs, and foreground moving outcome graphics gadgets are synchronized in real-time with the moving outcome-free background graphics.
Outcome-Free Graphics Background
The entertainment “outcome-free graphics” background (A) and the synchronized moving “outcome graphics gadgets” foreground (B) is best understood using a horse racing game as an example. The horse racing animation may be rendered in a background plane by the freelance code executing in a process sandbox using pre-recorded video or realistic real-time 3D animation. The rendering is such that each horse number indicia usually printed on the horse's saddle blanket is totally obfuscated or otherwise obscured. Consequently, it impossible when watching the rendered horse race to determine which horse is leading and will likely win the race, and what the order of the other horses will be across the finish line. In addition, other features that may help in identifying the horse such as the jockey's jacket color and horse skin color may also be obfuscated. Moreover, the voice-over or sound may not give any indication of the leading horses. Thus, the background plane may constitute a dazzling entertaining scene, complete with realistic sound of hooves and cheering crowds, that is free from any markings (i.e. numbers, colors, shapes) that would reveal or otherwise suggest the outcome of the race.
According to an embodiment of the present invention, the horse (or other race or entrant or team player) number indicia (which gives an indication of the outcome of the game) may be rendered in a foreground plane as graphic gadgets by the certified slot supplier code executing in a process sandbox isolated from the uncertified freelance process running in another sandbox. In addition, according to embodiments of the present invention, the motion, displacement and animation of each graphic gadget is synchronized with the freelance background such that each graphic gadget is rendered over a predetermined target (in the horse race example developed herein, a predetermined horse saddle blanket). The combined background and foreground scene then gives the viewer the capability to identify the leading horses. Similarly, the jockey's jacket colors, horses' true color and other features may be rendered in the same synchronized manner. A game outcome process seeded by a random number generator may provide the graphics gadgets with the random numbers that will be used to render the random indicia on the horse saddle blanket.
Motion Synchronization
The motion synchronization of outcome gadgets over the associated obfuscated area in the outcome-free animation background scene may be carried out, according to embodiments of the present invention, via pre-computed trajectory paths or frame-by-frame. The motion synchronization may utilize, without limitation, one or more of the following technologies and/or methods: a 2D trajectory path, a 3D trajectory path, location, scale, rotation, velocity and/or camera angle, for example. The computer processing and rendering of the outcome-free animation background (e.g. an XBOX or other game console or a PC) may be separate from the slot machine controller (e.g. a PC) processing the game outcome and rendering the outcome gadgets. A dual-ported video-mixer may combine the outcome-free animation background and the outcome graphic gadgets, the motion synchronization being carried out (a) via a suitable direct interface between the two computers using remote procedure call (RPC), Microsoft .NET Remoting (for example) or an IP service, or (b) by real-time image analysis and tracking under the control of the slot machine supplier software using the motion capture paradigm used in cinematography, for example. The dual-ported video-mixer may be a custom ASIC.
Outcome Graphic Gadget Rendering
The graphic gadget may render the horse number and other outcome related features using direct (a) 2D polyline/bezier draw and color fill, (b) triangles and color fill and/or (c) texturing. Path, location, scaling, rotation, 2D projection, illumination sources and other viewing attributes may be provided directly by the freelance software through a secure interface or may be derived from the freelance graphics by motion capture and capture of other scene attributes. Other overlay rendering technique may be used. Rendering of an outcome onto a 2D target is called hereafter a “2D outcome asset.”
An embodiment of the invention includes a freelance software that exposes through a secure interface a “neutral” 3D animated geometry (via a surface, NURBS curves or other 3D modeling technique) on which the graphic gadget would project a 3D skin. Rendering of an outcome onto a 3D target is hereafter called a “3D outcome asset.” For example, the freelance software may expose a neutral sphere located in space together with scale and rotation attributes, and the graphic gadget may render a skin projection representing the planet earth, the moon, mars, or any other planet as determined by a game outcome. A given planet, in this example, would be 3D asset. Similarly, the freelance software may expose a “cavity” surface located in space together with scale, rotation, etc. . . . in which the gadget may render a 3D fruit such as a cherry, a strawberry, a banana etc., as determined by a game outcome. A given fruit is a 3D asset. Rendering a skin over a surface is commonly practiced in 3D modeling for industrial design (refer to www.rhino3d.com), for example.
Accounting Meters
Other video assets such as the accounting meters may be controlled and rendered by the slot machine supplier software. Interactive video assets having a role in the outcome determination such as wager selections, line selection, chip selection and the bet button may also be controlled and rendered by the slot machine supplier software. Graphic gadgets may be used to render the accounting meters and the interactive video assets, and to activate the interactive video assets.
Space Controller
The rendering of all the animated outcome graphic gadgets may be controlled by a space controller ensuring that they appears at the proper location with the proper viewing attributes for a seamless integration with the dazzling entertainment background.
Playback
For each bet session, the identifiers of all the associated outcome assets together with their paths and viewing attributes as well as the identifier of the background animation may be recorded such that a playback of the complete bet session may be replayed. This may be used for dispute resolution during a player complaint.
Regulatory
The freelance binary code may execute in a process sandbox and may render its entertainment outcome-free graphics in a totally isolated background video plane. The software code that is responsible for producing the game outcome and rendering the game outcome assets is totally under the control of the slot supplier and may not be interfered with by unauthorized processes. Consequently, the freelance code need not be subjected to a full regulatory certification cycle, in which traditionally the entire source code is submitted to the lab, examined, compiled and tested according to stringent test cases. The freelance code may be classified similarly to a commercial operating system that is not subjected to full regulatory certification cycle.
Gaming Exchange
The present Regulated Gaming Exchange or Gaming Exchange Portal enables freelance game developers to offer new and dazzling electronic games to the regulated gaming marketplace and to receive compensation based on the success of their games. The games may be available as an unregulated trial download that allows wagering using only simulated or virtual money. Operators of regulated gaming machines may also download regulated versions of the same games from the Regulated Gaming Exchange for execution on regulated gaming machines. Usage metrics may be collected to determine the popularity of the unregulated trial games. The regulated gaming exchange may include a first repository that is selectively accessible to home players over a computer network, and a second repository that is selectively available over the computer network to operators of regulated gaming machines. The first repository may store an unregulated first version of a game that is configured for game play on a home computing device such as a computer or gaming console, for example. The unregulated first version of the game may be uncertified by a gaming software certification laboratory and may include a first outcome-free game portion and a first outcome-bearing game portion. The unregulated first version of the game is configured, according to embodiments of the present invention, to enable wagering only with virtual money.
The second repository may store a regulated second version of the game that is configured for game play on a regulated gaming machine and that is certified by the gaming software certification laboratory. The regulated second version of the game may include a second outcome-free game portion and a second outcome-bearing game portion. In contrast to the first version of the game, the second version of the game being may be configured to enable wagering with real money. The second outcome-free game portion may be substantially identical to the first outcome-free game portion.
Search Portal
The regulated gaming Exchange portal may include search functionalities, enabling players, freelance developers or game operators to formulate and receive answers for their search queries. A master index of information within the Regulated Gaming Exchange Portal may be generated, to offer search results in a speedy manner. For example, some of the information that may be indexed may include game attributes such as the game type (e.g. fruit type X, poker type Y, etc. . . . ), the game theme (e.g. English, Chinese, Christmas, Easter, Birthday, Marriage, beginner, advanced, etc.), the return to player (RTP) factor (e.g. 92%, 94%, 98%), the denomination (e.g. 1¢, 5¢, 10¢, 50¢, $1, $10, $50) and the volatility (e.g. high, low, medium, that is win small amounts frequently or win larger amounts less often). In addition to usage metrics, the statistics may be kept on the frequency of download for each game and the geographic distribution of such downloads.
Advertising sensing technology may be implemented in the Regulated Gaming Exchange to enable game operators and freelance developers to display relevant ads on their content pages to offer home players an opportunity to follow links to examine casino promotions and freelance full size unregulated version of the games. The history of the queries of each player combined with their usage metrics may be analyzed to derive intelligence therefrom relative to their preferences, to enable the ads and associated links to be tailored to the players.
Accordingly, an embodiment of the present invention is a method of developing and distributing a game. The method may include steps of developing a first outcome-free game portion; developing a first outcome-bearing game portion that is configured to enable waging using only virtual money and that is associated with the developed first outcome-free game portion; merging the first outcome-free game portion and the first outcome-bearing game portion to obtain an unregulated first version of the game; a first making step to make the unregulated first version of the game available for download to at least one home computing device; developing a second outcome-free game portion that is substantially identical to the first outcome-free game portion; developing a second outcome-bearing game portion that is configured to enable wagering using real money and that is associated with the developed second outcome-free game portion; merging the second outcome-free game portion and the second outcome-bearing game portion to obtain a regulated second version of the game to be submitted to a gaming software certification laboratory; obtaining certification of the regulated second version of the game from the gaming software certification laboratory, and a second making step to make the regulated second version of the game available for download into at least one regulated gaming machine.
The obtaining step may be carried out such that source code of the second outcome-free game portion is not submitted to the gaming software certification laboratory. The developing steps may be carried out such that the unregulated first version of the game is configured to not make use of Internet communication and Internet display technologies to execute and play on the home computing device. The developing steps may be carried out such that the first outcome-free portion of the unregulated first version of the game is configured to not make use of Internet communication and Internet display technologies to execute and play on the home computing device. The developing steps may be carried out such that a graphics portion of the unregulated first version of the game is configured to not make use of Internet communication and Internet display technologies to execute and play on the home computing device. The first making step may be carried out such that after the unregulated first version of the game is downloaded to the home computing device, the unregulated first version of the game does not make use of Internet communication and Internet display technologies to execute and play on the home computing device, such Internet communication technologies may include (without limitation) an HTTP Request, an HTTP Reply, a cookie and a Secure Socket Layer (SSL), for example. The Internet display technologies may include (without limitation) an Internet browser, HTML, a Java Scrip, a Java applet, a Scriptlet, an ActiveX control, a plug-in, a pop-up and/or a cookie, for example.
The developing steps may be carried out such that the first outcome-free game portion of the unregulated first version of the game is identical to the second outcome-free game portion of the regulated second version of the game. The developing steps may be carried out such that source code of the first outcome-free game portion of the unregulated first version of the game is substantially identical to source code of the second outcome-free game portion of the regulated second version of the game. The developing steps may be carried out such that source code of the first outcome-free game portion of the unregulated first version of the game is identical to source code of the second outcome-free game portion of the regulated second version of the game. The developing steps may be carried out such that executable code of the first outcome-free game portion of the unregulated first version of the game is substantially identical to executable code of the second outcome-free game portion of the regulated second version of the game. The developing steps may be carried out such that executable code of the first outcome-free game portion of the unregulated first version of the game is identical to executable code of the second outcome-free game portion of the regulated second version of the game.
The first making step may include uploading the unregulated first version of the game into a first repository that is selectively accessible from a predetermined computer site over a computer network and the second making step may include uploading the regulated second version of the game into a second repository that is selectively accessible through the predetermined computer site. The predetermined computer site may include, for example, an Internet portal.
The developing steps may be carried out such that the source of randomization used in the unregulated first version of the game is different than the source of randomization used in the regulated second version of the game. The developing steps may be carried out such that the unregulated first version of the game is configured to store critical meters in a different type of non-volatile storage media than is the regulated second version of the game. The developing steps may be carried out such that the executable code of the unregulated first version of the game is configured to store critical meters in a different type of non-volatile storage media than is the executable code of the regulated second version of the game. The developing steps may be carried out such that the unregulated first version of the game is substantially identical to the regulated second version of the game, except that the regulated second version of the game (a) allows for wagering using real money, (b) uses a certified source of random outcome, (c) stores critical meters on certified non-volatile memory, (d) provides functionality for player dispute resolution and/or (e) communicates with a central game management system. The developing steps may be carried out such that the source code of the unregulated first version of the game is substantially identical to the source code of the regulated second version of the game, except that the source code of the regulated second version of the game (a) allows for wagering using real money, (b) uses a certified source of random outcome, (c) stores critical meters on certified non-volatile memory, (d) provides functionality for player dispute resolution and/or (e) communicates with a central game management system. The developing steps may be carried out such that each software component of the unregulated first version of the game is code-signed with a unique certificate and the home computing device is configured with associated software restriction policies. The developing steps may be carried out such that each software component of the regulated second version of the game is code-signed with a unique certificate and the regulated gaming machine is configured with associated software restriction policies.
The method may further may include a step of receiving usage metrics of game play of the unregulated first version of the game played on the home computing device. The method may also include a step of receiving contact details of a player of the unregulated first version of the game. A step of receiving a preference profile of a player of the unregulated first version of the game may also be carried out. The preference profile of the player of the unregulated first version of the game may be sent to the gaming machine. A step may be carried out of enabling the regulated second version of the game to be configured according to the preference profile. The received usage metrics may be stored on a predetermined computer site and the stored usage metrics may be made available to an operator of the regulated gaming machine, a developer of the regulated second version of the game, a developer of the first and second outcome-free game portions and/or a developer of the unregulated first version of the game, for example. A step may be carried out of the operator of the regulated gaming machine selecting one or more regulated second versions of the game or games for download to one or more regulated gaming machines in accordance with the usage metrics. The method may also include a step of modifying the first outcome-free game portion of the unregulated first version of the game in accordance with the usage metrics. The method may also include a step of sending promotional information to players of the unregulated first version of the game having provided their contact details. A notice of availability of the regulated second version of the game on regulated gaming machines may be sent to players of the unregulated first version of the game. The method may also include a step of making the predetermined computer site accessible to a plurality of operators of regulated gaming machines. The predetermined computer site may also be made accessible to a plurality of freelance game developers. The regulated second version of the game may be made available for download by a plurality of operators of regulated gaming machines from the predetermined computer site. A step may be carried out of enabling uploads of unregulated first versions of games to the predetermined computer site.
The method may also include a step of configuring the predetermined computer site such that the stored usage metrics are selectively available to operators of regulated gaming machines. A step may be carried out of configuring the predetermined computer site such that the stored usage metrics are selectively available to freelance game developers. The predetermined computer site may be configured such that the stored usage metrics are selectively available to players playing on their home computing devices. The home computing device may be, for example, a personal computer (PC), a mobile computer or a game console. The method may also include steps of code signing with a unique certificate each software component of the second outcome-free game portion that is merged into the regulated second version of the game, maintaining a list of the unique certificates associated with the second outcome-free game portion developed by at least one freelance developer, producing an audit log of regulated second versions of the game played on the regulated gaming machine, the audit log containing traces of the unique certificates recorded when each code signed software component may be executed, and deriving usage metrics of played regulated second versions of the game from the audit logs using the traces of the unique code signing certificates. A step may be carried out to maintain an accounting of an amount to pay the freelance game developer(s) according to the derived usage metrics. The gaming exchange may further include a database and a search engine, and the method further may include a step of the search engine receiving search queries from the home player, the game operator and/or the game developer and retrieving data from the database. The search engine may further carry out steps of crawling the first and second repositories, generating at least one index of a plurality of documents found during the crawling step that contain human readable game information for each game, and recording the at least one index into the database. The method may include a step of recording in the database, and making available to the search engine, usage metrics of players, promotions offered by casinos, list of games offered by casinos, advertising offered by freelance developers, attributes of the games available in the gaming exchange and/or download metrics, for example.
Another embodiment of the present invention is a regulated gaming exchange. Such a regulated gaming exchange may include a first repository selectively accessible to home players over a computer network, the first repository storing an unregulated first version of a game that is configured for game play on a home computing device, the unregulated first version of the game being uncertified by a gaming software certification laboratory and including a first outcome-free game portion and a first outcome-bearing game portion, the unregulated first version of the game being configured to enable wagering only with virtual money; a second repository selectively accessible over the computer network to operators of regulated gaming machines, the second repository storing a regulated second version of the game that is configured for game play on a regulated gaming machine and that may be certified by the gaming software certification laboratory and including a second outcome-free game portion and a second outcome-bearing game portion, the second version of the game being configured to enable wagering with real money, the second outcome-free game portion being substantially identical to the first outcome-free game portion.
Source code of the second outcome-free game portion need not be submitted to the gaming software certification laboratory. The unregulated first version of the game may be configured to not make use of Internet communication and Internet display technologies to execute and play on the home computing device. The first outcome-free portion of the unregulated first version of the game may be configured to not make use of Internet communication and Internet display technologies to execute and play on the home computing device. A graphics portion of the unregulated first version of the game may be configured to not make use of Internet communication and Internet display technologies to execute and play on the home computing device. The unregulated first version of the game may be configured to not make use of Internet communication and Internet display technologies to execute and play on the home computing device. The Internet communication technologies may include (without limitation) an HTTP Request, an HTTP Reply, a cookie and/or a Secure Socket Layer (SSL), for example. The Internet display technologies may include (without limitation), an Internet browser, HTML, a Java Scrip, a Java applet, a Scriptlet, an ActiveX control, a plug-in, a pop-up and/or a cookie, for example. The first outcome-free game portion of the unregulated first version of the game may be identical to the second outcome-free game portion of the regulated second version of the game. Source code of the first outcome-free game portion of the unregulated first version of the game may be substantially identical to source code of the second outcome-free game portion of the regulated second version of the game. Source code of the first outcome-free game portion of the unregulated first version of the game may be identical to source code of the second outcome-free game portion of the regulated second version of the game. Executable code of the first outcome-free game portion of the unregulated first version of the game may be substantially identical to executable code of the second outcome-free game portion of the regulated second version of the game. Executable code of the first outcome-free game portion of the unregulated first version of the game may be identical to executable code of the second outcome-free game portion of the regulated second version of the game.
The first repository and the second repository may be selectively accessible at a predetermined computer site. The predetermined computer site may include an Internet portal, for example. The source of randomization in the unregulated first version of the game may be different than the source of randomization in the regulated second version of the game. The unregulated first version of the game may be configured to store critical meters in a different type of non-volatile storage media than is the regulated second version of the game. The executable code of the unregulated first version of the game may be configured to store critical meters in a different type of non-volatile storage media than is the executable code of the regulated second version of the game. The game software of the unregulated first version of the game may be substantially identical to a game software of the regulated second version of the game, except that the regulated second version of the game (a) allows for wagering using real money, (b) uses a certified source of random outcome, (c) stores critical meters on certified non-volatile memory, (d) provides functionality for player dispute resolution and/or (e) communicates with a central game management system. The source code of the unregulated first version of the game may be substantially identical to a source code of the regulated second version of the game, except that the regulated second version of the game (a) allows for wagering using real money, (b) uses a certified source of random outcome, (c) stores critical meters on certified non-volatile memory, (d) provides functionality for player dispute resolution and/or (e) communicates with a central game management system. Each software component of the unregulated first version of the game may be code-signed with a unique certificate and the home computing device may be configured with associated software restriction policies. Each software component of the regulated second version of the game may be code-signed with a unique certificate and the gaming machine may be configured with associated software restriction policies. The first and/or second repositories may include selectively accessible usage metrics of game play of the unregulated first version of the game played on the home computing device. The first and/or second repositories may include selectively accessible contact details of a player of the unregulated first version of the game on the home computing device. The first and/or second repositories may include a selectively accessible preference profile of a player of the unregulated first version of the game on the home computing device.
The regulated second version of the game may be configurable according to the preference profile. The usage metrics may be stored on a predetermined computer site and may be selectively available to an operator of the regulated gaming machine, a developer of the regulated second version of the game, a developer of the first and second outcome-free game portions and/or a developer of the unregulated first version of the game, for example. The first outcome-free game portion of the unregulated first version of the game may be modified according to the usage metrics. The predetermined computer site may include promotional information to be sent to players of the unregulated first version of the game having provided their contact details. The predetermined computer site may include a notice of availability of the regulated second version of the game on regulated gaming machines to be sent to players of the unregulated first version of the game. The predetermined computer site may be selectively accessible to a plurality of operators of regulated gaming machines. The predetermined computer site may be accessible to a plurality of freelance game developers. The regulated second version of the game may be available for download by a plurality of operators of regulated gaming machines from the predetermined computer site. The predetermined computer site may be configured to enable uploads of unregulated first versions of games. The predetermined computer site may be configured such that the stored usage metrics are selectively available to operators of regulated gaming machines. The predetermined computer site may be configured such that the stored usage metrics are selectively available to freelance game developers. The predetermined computer site may be configured such that the stored usage metrics are selectively available to players playing on their home computing devices. The home computing device may be a personal computer (PC), a mobile computer or a game console, for example.
The central management system may be further configured to generate the usage metrics of played regulated second versions of the game by code signing with a unique certificate each software component of the second outcome-free game portion that is merged into the regulated second versions of the game, maintaining a list of the unique certificates associated with the second outcome-free game portion developed by at least one freelance developer, producing an audit log of regulated second versions of the game played on the regulated gaming machine, the audit log containing traces of the unique certificates recorded when each code signed software component is executed, and deriving the usage metrics of played regulated second versions of the game from the audit logs using the traces of the unique code signing certificates. The game operator may be further configured to maintain an accounting of an amount to pay the freelance game developer(s) according to the derived usage metrics. A database and search engine may also be provided, the search engine being configured to receive search queries from the home player, the game operator and/or the game developer, and to retrieve data from the database. The search engine may be further configured to crawl the first and second repositories and to generate at least one index of a plurality of documents containing human readable game information for each game and to record the index into the database. The database may be further configured to record and to make available to the search engine usage metrics of players, promotions offered by casinos, list of games offered by casinos, advertising offered by freelance developers, attributes of the games available in the gaming exchange and/or download metrics, for example.
According to yet another embodiment, the present invention is a method of distributing a regulated game for regulated gaming machines. The method may include steps of a first receiving step for receiving an unregulated first version of a game including a first outcome-free game portion and a first outcome-bearing game portion, the received unregulated first version of the game being configured to enable wagering using only virtual money; a first making step to make the received unregulated first version of the game available for download to a plurality of home computing devices; a second receiving step for receiving a regulated second version of the game including a second outcome-free game portion and a second outcome-bearing game portion, the regulated second version of the game being configured to enable wagering using real money, the second outcome-free game portion being substantially identical to the first outcome-free game portion; a second making step to make the regulated second version of the game selectively available for download to a regulated gaming machine.
The regulated second version of the game in the second receiving step may be certified by a gaming software certification laboratory. The first receiving step may be carried out such that source code of the second outcome-free game portion is not submitted to a gaming software certification laboratory. The first receiving step may be carried out with the unregulated first version of the game being configured to not make use of Internet communication and Internet display technologies to execute and play on the home computing device. The first receiving step may be carried out with the first outcome-free portion of the unregulated first version of the game being configured to not make use of Internet communication and Internet display technologies to execute and play on the home computing device. The second receiving step may be carried out with the graphics portion of the unregulated first version of the game being configured to not make use of Internet communication and Internet display technologies to execute and play on the home computing device. The Internet communication technologies may include (without limitation) an HTTP Request, an HTTP Reply, a cookie and/or a Secure Socket Layer (SSL), for example. The Internet display technologies may include (without limitation) an Internet browser, HTML, a Java Scrip, a Java applet, a Scriptlet, an ActiveX control, a plug-in, a pop-up and/or a cookie, for example. The first and second receiving steps may be carried out such that the first outcome-free game portion of the unregulated first version of the game is identical to the second outcome-free game portion of the regulated second version of the game. The first and second receiving steps may be carried out such that source code of the first outcome-free game portion of the unregulated first version of the game is substantially identical to source code of the second outcome-free game portion of the regulated second version of the game. The first and second receiving steps may be carried out such that source code of the first outcome-free game portion of the unregulated first version of the game is identical to source code of the second outcome-free game portion of the regulated second version of the game. The first and second receiving steps may be carried out such that executable code of the first outcome-free game portion of the unregulated first version of the game is substantially identical to executable code of the second outcome-free game portion of the regulated second version of the game. The first and second receiving steps may be carried out such that executable code of the first outcome-free game portion of the unregulated first version of the game is identical to executable code of the second outcome-free game portion of the regulated second version of the game.
The method may also include a step of storing the received unregulated first version of the game in a first repository that is selectively accessible from a predetermined computer site over a computer network and a step of storing the received regulated second version of the game in a second repository that is selectively accessible through the predetermined computer site. The predetermined computer site may include an Internet portal. The first and second receiving steps may be carried out such that the source of randomization used in the regulated second version of the game is different than the source of randomization used in the unregulated first version of the game. The developing steps may be carried out such that the regulated second version of the game is configured to store critical meters in a different type of non-volatile storage media than is the unregulated first version of the game. The developing steps may be carried out such that the executable code of the regulated second version of the game is configured to store critical meters in a different type of non-volatile storage media than is the executable code of the regulated second version of the game. The first and second receiving steps may be carried out such that the game software of the regulated second version of the game is substantially identical to the game software of the unregulated first version of the game, except that the regulated second version of the game (a) allows for wagering using real money, (b) uses a certified source of random outcome, (c) stores critical meters on certified non-volatile memory, (d) provides functionality for player dispute resolution and/or (e) communicates with a central game management system, for example. The first and second receiving steps may be carried out such that the source code of the regulated second version of the game is substantially identical to the source code of the unregulated first version of the game, except that the regulated second version of the game (a) allows for wagering using real money, (b) uses a certified source of random outcome, (c) stores critical meters on certified non-volatile memory, (d) provides functionality for player dispute resolution and/or (e) communicates with a central game management system. The first and second receiving steps may be carried out such that each software component of the unregulated first version of the game is code-signed with a unique certificate and the home computing device is configured with associated software restriction policies. The first and second receiving steps may be carried out such that each software component of the regulated second version of the game is code-signed with a unique certificate and the regulated gaming machines is configured with associated software restriction policies. The method may also include a step of receiving usage metrics of game play of the unregulated first version of the game played on the home computing device. A step may be carried out of receiving contact details of a player of the unregulated first version of the game on the home computing device. A preference profile of a player of the unregulated first version of the game may be received on the home computing device. The method may also include a step of sending the preference profile of the player of the unregulated first version of the game to the regulated gaming machine. The regulated second version of the game may be configured according to the preference profile. The received usage metrics may be stored on a predetermined computer site and the stored usage metrics may be made available to an operator of the regulated gaming machine, a developer of the regulated second version of the game, a developer of the first and second outcome-free game portions and/or a developer of the regulated second version of the game, for example. A step may be carried out of the operator of the regulated gaming machine selecting the regulated second version of the game for download to the regulated gaming machine in accordance with the usage metrics. The method may also include a step of modifying the second outcome-free game portion of the regulated second version of the game in accordance with the usage metrics. The method may also include a step of sending promotional information to players of the unregulated first version of the game having provided their contact details. A notice of availability of the regulated second version of the game on the regulated gaming machine may be sent to players of the unregulated first version of the game. A step may be carried out of making the predetermined computer site accessible to a plurality of operators of regulated gaming machines. A step may also be carried out of making the predetermined computer site accessible to a plurality of freelance game developers. The regulated second version of the game may be made available for download by a plurality of operators of regulated gaming machines from the predetermined computer site. Uploads of regulated second versions of games may be carried out to the predetermined computer site. The method may further include a step of configuring the predetermined computer site such that the stored usage metrics are selectively available to operators of regulated gaming machines. A step of configuring the predetermined computer site may be carried out such that the stored usage metrics are selectively available to freelance game developers.
The method may also include a step of configuring the predetermined computer site such that the stored usage metrics are selectively available to players playing on their home computing devices. The home computing device may be, for example, a personal computer (PC), a mobile computer or a game console. The method may also include code signing with a unique certificate each software component of the second outcome-free game portion that is merged into the regulated second versions of the game; maintaining a list of the unique certificates associated with the second outcome-free game portion developed by at least one freelance developer; producing an audit log of regulated second versions of the game played on the regulated gaming machine, the audit log containing traces of the unique certificates recorded when each code signed software component may be executed, and deriving usage metrics of played regulated second versions of the game from the audit logs using the traces of the unique code signing certificates. The method may also include a step of maintaining an accounting of an amount to pay the freelance game developer(s) according to the derived usage metrics. The gaming exchange may further include a database and a search engine, and the method further may include a step of the search engine receiving search queries from the home player, the game operator and/or the game developer and retrieving data from the database. The search engine may further carry out steps of crawling the first and second repositories, generating at least one index of a plurality of documents found during the crawling step that contain human readable game information for each game, and recording the index into the database. The method may also include a step of recording in the database, and making available to the search engine, usage metrics of players, promotions offered by casinos, list of games offered by casinos, advertising offered by freelance developers, attributes of the games available in the gaming exchange and/or download metrics, for example.
Reference will now be made in detail to the construction and operation of preferred implementations of the present invention illustrated in the accompanying drawings. The following description of the preferred implementations of the present invention is only exemplary of the invention. The present invention is not limited to these implementations, but may be realized by other implementations.
Keeping the foregoing in mind, according to an embodiment of the invention, a horse racing graphic animation (which may be and/or include, for example, a video playback) controlled by a process 104 may be rendered in a video plane 102. The animation scene in
A process sandbox is a term commonly employed in computer technology to denote that the running process is given restricted memory access and restricted execution permissions such as not to interfere with other resources (e.g. processes, memory, disk storage, video, etc. . . . ) outside defined boundaries. (The process sandbox technique is also commonly known in the US army software requirement as secure compartmenting for a multilevel secure operating system as defined in the DoD 5200.28-STD standard and the associated Orange book and the rainbow series. The process sandbox technique is being further researched at Microsoft Research under the “Singularities” and “Virtualization” initiatives wherein Software Isolated Processes (SIPs) communicate and interact via “channels” and “contracts” which provide a fully defined and protected security partitioning for inter-process communication and wherein virtualization of the Windows operating system will be controlled by the “HyperVisor” virtualization engine; these technologies are likely to be released after Windows Vista. The process sandbox technique is also commonly referred as strong process isolation). This may be achieved using advanced and secure resource management such as, but not limited to, hardware enforced memory management, ACL (Access Control List), trusted computing base (i.e. implementing security initiatives of the TCG Trusted Computing Group: TPM, TNC, secure BIOS, secure storage, etc. . . . or equivalent technologies), software restriction policy, anti-virus, kernel virtualization, I/O virtualization, and other security mechanisms embedded in advanced 64-bit CPU. In addition, forthcoming graphics controllers comprising embedded hardware security module may ensure that no process may access unauthorized video resources. Consequently, the executing freelance software cannot interfere with the regulated software installed or executing on the gaming controller, including unauthorized writing and reading of information to/from the video display and hidden video display cache.
Accordingly and according to an embodiment of the present invention, the outcome-free game software or processes may be configured to execute in a first process sandbox in which it is given compartmented memory access and/or compartmented execution permissions. The outcome-free game software or processes may be configured to execute in a first process sandbox that may include, for example, strong process isolation, DoD 5200.28-STD multilevel security, Microsoft Software Isolation Process (SIP) and/or JAVA sandbox. Likewise, the outcome-providing game software or processes may be configured to execute in a second process sandbox in which it is given compartmented memory access and/or compartmented execution permissions. For example, the outcome-providing game software may be configured to execute in a second process sandbox that may include, for example, process isolation, DoD 5200.28-STD multilevel security, Microsoft Software Isolation Process (SIP) and/or JAVA sandbox.
As shown in
The horse number indicia 126, 128 may be rendered in a video plane 220 as graphic gadgets (in the exemplary embodiment shown in
As may be apparent to those of skill in the art of video graphics animation and synchronization, other synchronization schemes may be employed that rely on a direct programming interface, either frame-by-frame, by sequence of frames or for the entire animation sequence. For example, if the animation is a replay of a pre-recorded animation, the overall path for each target may be provided via the programming interface.
The outcome gadgets may display outcome-bearing information such as, but not limited to, identification marks, numerals, shapes and colors. The meters gadgets may display the meters of the games such as but not limited to credit, last win and denomination. The interaction gadgets may be the visible or invisible graphic objects with which the player may interact such as, but not limited to, a bet button, wager selection, denomination selection, lines selection, chips, help button and cash-out button. Help and prize matrix may be interaction gadgets.
The graphics objects and gadgets may be displayed anywhere on the video display(s) of the gaming machine with any viewing attributes such as location, scale, orientation, illumination (one or several light sources), opacity and plane position (on top, in back, in between, etc.). Gadgets may be rendered in rectangular or non-rectangular windows, or in sprites. Gadgets may be rendered as full 3D animated objects.
The display rendering of all the gadgets on the video display is controlled by a space controller 510 that is configured to coordinate all the 2D/3D viewing attributes of each of the graphic objects and gadgets such as to enable the player to experience a seamless game session. Hereafter, the 2D/3D viewing attribute of each gadget or graphic object is referenced as “path” 530, 534, 540 and 542 in
The presentation style or “skin” of the entertainment gadgets, meter gadgets and the interaction gadgets may be customized by the player and/or by the game operator without requiring any regulatory software re-testing. The customization available to the players and/or to the game operator is limited, to remain in regulatory compliance. Young computer users and gamers who are used to be provided with “skin-able” programs and games such as music players and even the entire Microsoft Windows visual appearance (i.e. Aero in Windows Vista) may, therefore, customize the skin of all the display windows and gadgets (entertainment, meters, interactive) and choose their size, location, opacity and dynamic zoom-in/zoom-out (the meters may be visible in small size or with high transparency during game action and may appear in large size and high opacity when the outcome is given). The gadgets may be dock-able via a push-pin icon, and/or de-docked and removed when the pin is removed. In a multi-display gaming machine, the player or the operator may freely choose on which panel to display the various graphics objects or alternatively may choose to combine the panels to make a larger virtual display. Interactive controls (suggested at 1312 in
The space controller 510 may receive the outcome targets path and viewing parameters 532 directly from the entertainment graphics objects 502 or alternatively may derive them via a motion capture process 512. The entertainment graphics objects 502 may receive a start command 530 from the space controller 510 to start viewing the entertainment animation, when the bet button is pressed, for example.
The outcome engine 516 may receive a bet command 550 from the space controller and obtain the raw random numbers 560 from the random number generator 518. The outcome engine may receive player credits via Ticket-In 522 or any other common payment instrument and cash-out via Ticket-Out 524 or other payment instrument. An audit engine 520 may securely store a trace of all regulatory data 558, in NVRAM for example. A history process 526 may record all graphic activity 552 and associated outcome data 554 during a game session, and forward them at 556 to a history playback process 514 such that the space controller may playback a complete game session when required in order to resolve player disputes.
For illustration,
Similarly, in a cosmic voyager game wherein a spacecraft exits light speed travel as it approaches its destination, the planet where it would land is revealed. The planets may be rendered as neutral/blind 3D spheres 610 by the freelance entertainment graphics objects 502. The 3D spheres 610 are 3D outcome targets that are each being passed 532 as a 3D model to the space controller 510 together with their associated viewing attributes. In the example of
Accordingly, it is believed desirable to allow casino players to change various aspects of the displayed games to suit their mood, preferences and the available video display real-estate (i.e. single display, multi-display, ultra-high resolution display, plasma display, etc. . . . ). Players, according to further aspects of embodiments of the present invention, may change the style or skin interactively of various game elements and operators may control the parameters centrally or locally via configuration files or centrally federated policies. Player's individually chosen styles may be saved and later recovered and retrieved using, without limitation, a player card or from a central player account. As discussed below and according to further embodiments of the present invention, players may configure their favorite styles and skins on their computers at home and may thereafter retrieve such parameters on the casino floor.
According to an embodiment of the present invention illustrated in
It is to be noted that one or more of the interaction means and elements of
Each group of graphic objects may be controlled by a separate controlling process executing in a process sandbox. As an immediate benefit, the software controlling each group of graphic objects may be controlled by a partitioned software having a well defined application programming interface (API) developed by an independent software group or software vendor. The end-to-end security principles described in the commonly assigned and co-pending patent application Ser. No. 10/520,831, filed Jan. 5, 2005, entitled “Secure Game Download,” and commonly assigned and co-pending patent application Ser. No. 10/789,975, filed Feb. 27, 2004, entitled “Dynamic Configuration of a Gaming System” may be fully applied. Both of the aforementioned patent applications are hereby incorporated herein by reference in their entirety. In addition, the modular principles described in commonly assigned U.S. Pat. No. 6,916,247, entitled “Modular Entertainment And Gaming Systems”, commonly assigned U.S. Pat. No. 6,908,391, entitled “Modular Entertainment And Gaming System Configured To Boot Its Operating System And/Or Application Software From A Remote Device,” commonly assigned and co-pending application Ser. No. 10/120,635, filed Apr. 10, 2002, entitled “Modular Entertainment And Gaming Systems Configured To Consume And Provide Network Services,” and U.S. Pat. No. 6,945,870, entitled “Modular Entertainment And Gaming System Configured To Capture Raw Biometric Data And Responsive To Directives From A Remote Server,” may be applied to great advantage and the controlling process for a particular group of graphic objects may be controlled by a process located in a central computer (such as shown at reference numeral 1556 in
Alternatively and as shown in
Later generation graphic platform such as Microsoft Windows Platform Foundation (WPF), WinFX, .NET Framework 3.0 and XNA Game Studio Express for Windows Vista and Windows XP, together with associated new generation of graphic design tools such as Microsoft Expression suite (in which graphics are no longer bound by raster technology but are fully scalable using vector graphics), may allow creative minds to develop dazzling graphics. Microsoft's Visual Studio Express is aiming to democratize application development by putting development tools into the hands of novice and hobbyist programmers. Microsoft officials hope XNA Game Studio Express will democratize game development by delivering the necessary tools to hobbyists, students, independent developers and studios to help them more readily create games for the Xbox 360. This democratization will enable game players to more easily become game developers, company officials said. And by joining a “creators club” for an annual subscription fee of $99, developers will be able to build, test and share their games on Xbox 360 and access other materials to help them develop games for the Microsoft platform, Microsoft said. Code signing each module with an individual certificate would enable end-to-end security throughout the life cycle of the game and ensure that freelance developers are rewarded in accordance with the success of their games or plug-ins. This may be accomplished by examining the audit logs containing a trace of the certificate ID for each module executed. Individual modules of the games (and not the entire game) may be replaced via central download to speed up and reduce cost of ownership.
The virtual display architecture detailed herein accommodates any number and size of display panels that may be fitted or connected to a gaming machine including, but not limited to, large format plasma displays, 3D displays, projection displays and interactive 3D projection displays such as Microsoft “Touchlight” technology that lets users move and manipulate three-dimensional images with their hands. The virtual display architecture detailed herein may also accommodate technologies such as Microsoft's “PhotoSynth”, which constructs a user navigable 3-D environment from a plurality of 2-D pictures or technologies such as Total Immersion's D° Fusion technology, which seamlessly blends video and 3-D computer generated constructs and animation together. One or a plurality of displays may be remote from the gaming machine, the remote display being controlled by a network connected controller. Such a display may advantageously be a large size plasma display controlled by a PC or an XBOX 360 game console, for example. The network inter-process communication between the gaming machine and the remote display controlled by a XBOX 360 may use the Microsoft MCML language (Media Center Markup Language) or the Microsoft XNA (http://msdn.microsoft.com/directx/xna/). The network connected remote display may be shared between a plurality of gaming machines, each gaming machine controlling at least one graphic objects via network inter-process connection. The end-to-end secure code download principles using code signing and software restriction policy may be advantageously applied to download the necessary network inter-process code. The virtualization of remote large size advanced technology displays shared between a plurality of gaming machines may allow freelance developers to offer dazzling interactive video billboards driven directly by the games played on the gaming machines. One or a plurality of displays may be remote from the gaming machine, the remote display being controlled by a network connected controller. Such a display may advantageously be a large size plasma display controlled by a PC or, an XBOX 360 game console, a Microsoft media extender or equivalent, for example. The network inter-process communication between the gaming machine and the remote display controlled by a XBOX 360 or media extender may use the Microsoft MCML language (Media Center Markup Language), the Microsoft XNA (http://msdn.microsoft.com/directx/xna/) or the Microsoft “Media Extender” framework, for example. The network connected Media Extender device may an XBOX, a PC, a tablet device, a mobile PC, a palmtop PC, a Windows Smartphone or a wired/wireless media player such the Microsoft “Zune” media player. The network connected remote display may be shared between a plurality of gaming machines, each gaming machine controlling at least one graphic objects via network inter-process connection. The end-to-end secure code download principles using code signing and software restriction policy may be advantageously applied to download the necessary network inter-process code. The virtualization of remote large size advanced technology displays shared between a plurality of gaming machines may allow freelance developers to offer dazzling interactive video billboards driven directly by the games played on the gaming machines. The display virtualization to remote hand-held personal computer devices (e.g. SmartPhone, Zune, etc.) connected to a single gaming machine or shared between a plurality of gaming machines may allow freelance developers to offer visually enticing interactive distributed video billboards driven directly by the games played on the gaming machines.
According to an embodiment of the present invention, players 1526 of the unregulated downloaded trial games may opt to provide information (such as a list of the players' favorite games, for example) to the Gaming Exchange Portal 1500 to enable casino operators and/or select others to offer incentives to attract them to their casino. Alternatively, consent to providing such information may be a pre-condition to downloading and/or playing the trial unregulated games 1536.
Freelance game developers 1502 may enrich the gaming exchange portal 1500 by adapting popular gaming titles 1506 played on PCs or game consoles such as 1508 GameCube, PlayStation and XBOX for play on the floor 1511 of the casino 1510 or by using their experience and expertise to create new unregulated games specifically for the casinos. In this manner, freelance game developers 1502 drive the exchange portal 1500 by adapting popular gaming titles for play on the casino floor or by using their experience and expertise to create new games 1506 specifically for the casino (all games are preferably configured with a standard API). The existing games adapted (with permission) by the freelance developers may originate from the game library of popular console type gaming platforms, such as Microsoft's XBOX or XBOX 360, Sony's Playstation or Nintendo's GameCube (for example), as shown at 1506 or any future gaming system. Games specifically developed for, e.g., the PC or Apple platforms may also be adapted as described above. Alternatively, wholly new games may be developed by the freelance developers. Alternatively still, the makers (or licensees) of such gaming consoles may adapt existing games within their games library in-house in the manner described herein. Once such new or adapted (modified) games are created, the freelance (or in-house) game developers may submit a copy of the new or adapted game along two paths; namely, an unregulated path 1538 and, in cooperation with a licensed game developer 1504 (e.g. Cyberscan, WMS, Bally, etc.), a regulated path 1540.
Such unregulated first versions of games developed by the freelance game developers or others are preferably such that they do not make use of Internet communication and Internet display technologies to execute and play on the home computing device 1528. That is, the unregulated first versions of the games (in contradistinction to the regulated and certified second versions of the same games) preferably do not use Internet communication technologies such as (for example, and without limitation) HTTP Requests, HTTP Replies, cookies and/or Secure Socket Layers (SSL) to play or execute on the player's home computing device 1528 (whether before or after the player has downloaded a copy thereof). Similarly, the unregulated first versions of the games (in contradistinction to the regulated and certified second versions of the same games) preferably do not use Internet display technologies such as (for example and also without limitation) the use of Internet browsers, HTML, Java Scrips, Java applets, Scriptlets, ActiveX controls, plug-ins, pop-ups and/or cookies to ply or operate the games.
In particular, the first outcome-free portion of the unregulated first version of the game is preferably configured to not make use of Internet communication and/or Internet display technologies to execute and play on the home computing device. Similarly, the graphics portions of the unregulated first version of the game is preferably configured to also not make use of Internet communication and/or Internet display technologies to execute and play on the home computing device.
Downloading (but not execution and playing) of the unregulated first versions of games developed by the freelance may, however, make use of Internet communication technologies and Internet display technologies.
Returning now to
According to an embodiment of the present invention, the regulated version of the game submitted along path 15391540 comprises the merging of the outcome-free game software of the freelance game developer and the outcome-bearing game software of the licensed game developer that is then submitted to an independent certification lab 1542 to ensure that it meets all gaming and security standards. Once certification is granted, the now certified game 1544 may be loaded into a regulated games repository 1550 of a selectively accessible predetermined computer site (such as a Web site, for example). Gaming machines 1514 located on the floor 1511 of the casino 1510 may then access the certified and regulated games loaded in the regulated games repository 1550 and such games offered to the casino players 1512. As may be required by regulation, the regulated games of the regulated games repository 1550 may be first downloaded to the central system 1556 before being made available to the gaming machines 1514 to allow for a centrally federated enforcement of policies. Alternatively, such certified and regulated games may be made available over a computer network to other computing devices located in other venues (such as hotel rooms or cruise ship staterooms, for example), subject to appropriate security measures and regulatory approval. Suitable means for providing regulated gaming to guest rooms in the hospitality industry are described in commonly assigned and co-pending patent application Ser. No. 11/456,763, filed Jul. 11, 2006, entitled “In-Room Gaming”, which is hereby incorporated herein by reference in its entirety.
As shown in
In direct contrast, a player of an unregulated game according to embodiments of the present invention downloaded from the exchange 1500 onto his or her home computer or home computing device 1528 (which may include a branded gaming console) will have much the same gaming experience when he or she plays at home as when he or she plays the regulated and certified version of the same game on a regulated gaming machine in a casino or other gaming establishment (but for the wagering aspects of the game which, on the regulated gaming machine, include playing for real money or other tangible value). Usage metrics 1534 from this process may be used to structure game offering menus on the casino floor 1511 such that the most popular gaming titles are front-loaded.
On the floor 1511 of the casino 1510, each gaming machine 1514 records its regulatory meters from which usage metrics 1520 of gaming titles may be derived. An embodiment of the invention may rely on code-signing of game code according to the principles set out in the commonly assigned and co-pending patent application Ser. No. 10/520,831, filed Aug. 12, 2005, entitled “Secure Game Download”, which is hereby incorporated herein by reference in its entirety. A trusted audit trail may also be splashed in the event log. Embodiments of the present invention may allocate an individual PKI certificate to each executable software component of the certified and regulated games and to each of their versions, binding the PKI certificate to the executable software and associating a distinctive policy for each PKI certificate. The PKI certificate's “Subject Name” (or “Issued to” field, or “CommonName” field) may be a concatenation of the software component identification, its version number and optionally other identification characters, for example. In this manner, the “subject name” may also comprise an embedded secure license identifier of the developer for license tracking. Therefore, examination of the game audits reveals the detailed metrics 1520 of each played game and statistics may be generated in order to reward the freelance game developers 1502 with financial compensation as shown at 1522 in accordance with the popularity of their games. Thanks to End-to-End Download Security and Embedded Secure License Identifiers, developers will receive financial compensation in accordance with game success.
A new game submitted along path 1540 may include outcome-free code and outcome-bearing code. The outcome-free code may be developed by the freelance game developers 1502 and the outcome-bearing code may be developed by the supplier game developers 1504, as detailed above. It is to be understood that variations are possible, as those of skill in this art may appreciate. For example, embodiments of the present invention provide for both the outcome-free code and the outcome-bearing code being developed by the same entity, be it the freelance code developers or the supplier game developers. In order to be permitted to enter the regulatory certification cycles, the supplier game developers may take delivery of the outcome-free code developed by the freelance game developers 1502 and may submit the entire code that makes up the new game submitted along path 1540 (i.e., the outcome-free code and the outcome-bearing code) to the certification lab 1542. The outcome-free code may include code that need not be submitted to the certification lab 1542 in source code form. The outcome-bearing code (and the outcome-free code, if needed) may be submitted to the certification lab 1542 in any manner or may be submitted as disclosed in commonly assigned and co-pending patent application Ser. No. 11/251,628, filed Oct. 14, 2005, entitled “Universal Method For Submitting Gaming Machine Source Code Software To A Game Certification Laboratory”, which is hereby incorporated herein by reference in its entirety.
Although less secure than the “compartmented” freelance code described earlier in this specification, another embodiment of the present invention may include submitting to the certification lab an outcome-determining-free game software that includes only graphic rendering code, such as macromedia .swf files for example. Although .swf files do render outcome graphically (i.e. may render a winning number on the video display in response to a provided outcome code) via a Macromedia flash players installed in the gaming machines and in the home computer devices, they do not determine the outcome. The outcome determining game software is a separate code that is developed by the licensed game developer and that is submitted to the gaming software certification laboratory in source code form. The .swf files are derived from the Macromedia Director Studio (a graphic animation studio), are not produced directly by a human programmer and are not directly executable (can only be rendered via a Flash player, noting that the Flash player does not necessary require an Internet web browser to render graphic animations). Consequently, the gaming software certification laboratory may not examine any outcome-determining-free source code. A freelance developer may provide .swf outcome-determining-free files (or equivalent from a different graphic animation studio) for the purpose of the regulated gaming exchange invention described herein. The outcome-determining-free approach is notably adopted by Cyberscan in UK and early deployments in USA for their regulated gaming machines.
The regulated new game 1544 certified by the lab 1542 may be transferred to the gaming exchange portal 1500 in a “regulated games repository” 1550 that contains a plurality of regulated games available for download to authorized parties. A copy of a regulated game 1518 may be downloaded from the regulated games repository 1550 by an operator of the casino 1510 for deployment in the gaming machines 1514 of the casino 1510 after determining (from the usage and popularity metrics 1516, for example) that this game is likely a good fit in his casino for a predetermined profile of players. In turn, the operator of the casino 1510 may send promotional information 1554 (such as casino locations carrying the new game and vouchers) to the gaming exchange portal 1500, to enable the promotional information to be forwarded to the appropriate players 1526 via email or other channels in accordance, for example, with the usage metrics 1534 obtained from the registered players 1526 and their contacts details and preferences 1552, as such players have previously played the unregulated trial version of the game 15301532, on their home computers 1528, for example.
The gaming exchange portal 1500 may be configured to deploy policies such as active directory policies (or equivalent ADM policy scripts) to the player's home computer 1528 such as to enforce software installation policies (SIP) and software restriction policies (SRP) in accordance with the principles detailed in commonly assigned and co-pending patent application Ser. No. 10/789,975, filed Feb. 27, 2004, entitled “Dynamic Configuration Of A Gaming System”, which is hereby incorporated herein by reference in its entirety, in order to offer the player some confidence that the origin of the software is from a reputable source, to ensure proper updating of new game software components and to revoke obsolete game software components. Policies may be used to ensure the proper localization variant of the game is executed by the player in accordance with local regulation. Indeed, the player may choose the localization variant of the applicable state where he wishes to try the game or play (for real money or other value) at his or her preferred casino.
A player 1526 playing his or her favorite game on his home computer 1528 may select various presentation preferences such as those described above for “Virtual Display” and store his or her preferences in a player profile, on a local storage or on the gaming exchange portal 1500. When the player 1526 travels to a casino 1510, the player may play his favorite game on a gaming machine 1514 and may also retrieve his or her preferences from the stored player profile. In this manner, the game played on the gaming machine 1514 within the casino 1510 (or other location) appears as it did on his or her home computer 1528—that is, with his or her preferences incorporated in the displayed graphics of the game and/or game play.
Advertising sensing technology may be implemented such as Google AdSense as a fast and easy way for game operators and freelance developers to display relevant ads on their result content pages to offer home players an opportunity to follow links to examine casino promotions 1618 and freelance full size unregulated version of the games 1652. The history of the queries 1630 of each player combined with their usage metrics 1626 may be analyzed to derive intelligence therefrom relative to their preferences, such that the ads and associated links may be tailored according to what the visiting players are looking for.
The database and search engine 1606 may also contain the player profiles 1552 and queries may be formulated to derive intelligence on the most popular player profiles.
The players at home 1624 may formulate a search query 1630 by entering selected game attributes via a search page which is forwarded to the database and search engine 1606. The search engine 1606 may then return a search response 1632 to the player. Freelance developers 1644 may also formulate a search query 1648 by entering selected game attributes via a search page which is forwarded to the database and search engine 1606. The search engine 1606 would then returns a search response 1650. Similarly, the game operator 1610 may formulate search queries and get search responses. A player 1616 on the casino floor 1612 may formulate search queries and obtain search responses whenever the casino operator 1610 provides facilities to access the game exchange portal search engine 1606. Access may be provided to the players directly via the gaming machine 1614 or via auxiliary consoles disposed on the casino floor.
The gaming operator 1610 may, for security reasons, provide an internal database and search engine 1656 connected to the central management system 1654 that provides the same functions as the external database and search engine 1606, and allow the players 1616 to formulate queries related to games and promotions.
While the foregoing detailed description has described preferred embodiments of the present invention, it is to be understood that the above description is illustrative only and not limiting of the disclosed invention. Those of skill in this art will recognize other alternative embodiments and all such embodiments are deemed to fall within the scope of the present invention. Thus, the present invention should be limited only by the claims as set forth below.
Number | Name | Date | Kind |
---|---|---|---|
4593904 | Graves | Jun 1986 | A |
4695053 | Vazquez, Jr. et al. | Sep 1987 | A |
5342049 | Wichinsky et al. | Aug 1994 | A |
5823873 | Moody | Oct 1998 | A |
6012983 | Walker et al. | Jan 2000 | A |
6019374 | Breeding | Feb 2000 | A |
6050895 | Luciano, Jr. et al. | Apr 2000 | A |
6077163 | Walker et al. | Jun 2000 | A |
6244957 | Walker et al. | Jun 2001 | B1 |
6267669 | Luciano, Jr. et al. | Jul 2001 | B1 |
6283474 | de Keller | Sep 2001 | B1 |
6409597 | Mizumoto | Jun 2002 | B1 |
6508709 | Karmarkar | Jan 2003 | B1 |
6517433 | Loose et al. | Feb 2003 | B2 |
6522312 | Ohshima et al. | Feb 2003 | B2 |
6551187 | Jaffe | Apr 2003 | B1 |
6645075 | Gatto et al. | Nov 2003 | B1 |
6674448 | Garahi et al. | Jan 2004 | B1 |
6761632 | Bansemer et al. | Jul 2004 | B2 |
6811482 | Letovsky | Nov 2004 | B2 |
6862696 | Voas et al. | Mar 2005 | B1 |
6908391 | Gatto et al. | Jun 2005 | B2 |
6916244 | Gatto et al. | Jul 2005 | B2 |
6916247 | Gatto et al. | Jul 2005 | B2 |
6945870 | Gatto et al. | Sep 2005 | B2 |
20010031656 | Marshall et al. | Oct 2001 | A1 |
20020147040 | Walker et al. | Oct 2002 | A1 |
20030078101 | Schneider et al. | Apr 2003 | A1 |
20030100369 | Gatto et al. | May 2003 | A1 |
20030211881 | Walker et al. | Nov 2003 | A1 |
20040087357 | Johnson | May 2004 | A1 |
20040102238 | Taylor | May 2004 | A1 |
20040198496 | Gatto et al. | Oct 2004 | A1 |
20050114774 | Berryman | May 2005 | A1 |
20050282637 | Gatto et al. | Dec 2005 | A1 |
20060100010 | Gatto et al. | May 2006 | A1 |
20080032794 | Ware | Feb 2008 | A1 |
Number | Date | Country | |
---|---|---|---|
20080070666 A1 | Mar 2008 | US |