This invention relates to online gaming and, more specifically, to a method for establishing a wager for a game.
The Internet and the increasing availability of broadband services have led to the proliferation of online gaming. Currently, however, online gaming suffers from many drawbacks. Primary among these is that current online gaming fails to allow players to compete for tangible prizes in a secure environment that does not rely upon trust among the competitors. Moreover, the online gaming experience does not provide incentive for a player to become a dedicated patron of any particular gaming environment. As a result, online gaming remains a mere hobby for most players.
In a particular embodiment of the present invention, a system for establishing a wager associated with a game comprises a processor that receives information about a wager offer, wherein the wager offer is associated with an online game. The processor also receives information about a wager acceptance. The wager offer and the wager acceptance combine to form a wager, wherein the wager is associated with at least one wager parameter. The system further comprises a memory communicatively coupled to the processor and that stores information associated with the at least one wager parameter.
A particular advantage of one or more embodiments of the present invention is that a processor may receive information about a wager associated with an online game and present that information to a memory that stores the information. Particular embodiments may thus allow a processor to process and a memory to store information about a wager between two players of an online game, facilitating wagering associated with online play.
Another technical advantage of particular embodiments of the present invention is that a processor may process and a memory may store information about a wager associated with any number of types of online games. As an example only, in particular embodiments, a processor may process and a memory may store information about a wager associated with an online golfing game, an online casino game, an online adventure game, an online arcade games, an online sports games, or an online racing game. The processor and memory may thus facilitate wagering associated with online play of a number of different types of online games.
Another technical advantage of particular embodiments of the present invention is that a processor and memory that facilitate wagering associated with an online game may allow multiple users in different locations to wager over a network. Thus, particular embodiments may comprise a processor and memory that facilitate wagering over all or a part of the Internet or over a wireless network. These embodiments may allow users in different locations on a network to make a wager associated with an online game.
It will be understood that the various embodiments of the present invention may include some, all, or none of the enumerated technical advantages. In addition, other technical advantages of the present invention may be readily apparent to one skilled in the art from the figures, description, and claims included herein.
For a more complete understanding of the present invention and its advantages, reference is now made to the following description, taken in conjunction with the accompanying drawings, in which:
Network 100 couples clients 102, servers 104, and/or platform 106. Network 100 facilitates wireless or wireline communication between the components of system 10. Network 100 may, for example, communicate Internet Protocol (IP) packets, Frame Relay frames, Asynchronous Transfer Mode (ATM) cells, voice, video, data, and other suitable information between network addresses. Network 100 may include one or more local area networks (LANs), radio access networks (RANs), metropolitan area networks (MANs), wide area networks (WANs), interactive television networks, all or a portion of the global computer network known as the Internet, and/or any other communication system or systems at one or more locations.
Clients 102 comprise computer systems that include appropriate input devices, output devices, mass storage media, processors, memory, or other components for receiving, processing, storing, and/or communicating information with other components of system 10. As used in this document, the term “computer” is intended to encompass a personal computer, workstation, network computer, wireless data port, wireless telephone, personal digital assistant (PDA), one or more processors within these or other devices, or any other suitable processing device. It will be understood that there may be any number of clients 102 coupled to network 100. Clients 102 are generally operated by users to participate in gaming applications 114 hosted by server 104, either as players or spectators.
Server 104 comprises an electronic computing device that includes a monitor module 110, a gaming processor 112 that executes one or more gaming applications 114, and an interface 116 to communicate with platform 106. In a particular embodiment, server 104 further includes a lobby processor 118 that facilitates matching players of a particular gaming application 114. It should be understood that lobby processor 118 and gaming processor 112 may reside on the same or different server 104. Server 104 may be implemented using a general purpose personal computer (PC), a Macintosh, a workstation, a UNIX-based computer, a server computer, or any other suitable processing device. In general, each server 104 hosts the same or different gaming applications 114 for clients 102 over network 100, monitors game events 120 generated by clients 102 using a monitor module 110, and communicates event information 122 to platform 106 using interface 116.
In one embodiment, server 104 comprises a web server (or a pool of servers). One function of web server 104 is to allow a client 102 to participate in gaming applications 114 over or from the Internet using a standard user interface language such as, for example, the HyperText Markup Language (HTML). For example, server 104 and clients 102 may maintain and execute a browser or other suitable program for accessing and communicating information addressed by a uniform resource locator (URL) using network 100.
A gaming application 114 comprises any suitable game that may be played by one or more users of system 10. Examples of gaming applications 114 include sports games, board games, arcade games, strategy games, adventure games, casino games, card games, dice games, and any other suitable games that may be played using system 10.
Platform 106 comprises a central processing unit (CPU) associated with an operating system that executes instructions and manipulates information in accordance with the operation of system 10. The CPU of platform 106 maintains and executes the instructions to implement an event manager 130, a statistics manager 132, a profile manager 134, a lobby manager 136, a game advisor 138, a wager manager 140, and a funds manager 142. Although the various components of platform 106 are illustrated as separate modules, it should be understood that any suitable number and combination of engines or modules may be used to perform the various features and functionality of platform 106. Each module described above with reference to platform 106 comprises any suitable combination of hardware and software in platform 106 to provide the described function or operation of the module. For example, modules may include program instructions, and the associated memory and processing components to execute the program instructions. Also, modules associated with platform 106 may be separate from or integral to other modules.
Platform 106 further comprises a memory 150 that may take the form of volatile or non-volatile memory including, without limitation, magnetic media, optical media, random access memory (RAM), read-only memory (ROM), removable media, or any other suitable local or remote memory component. Memory 150 may be separate from or integral to other memory devices in system 10. In general, memory 150 stores event information 152, statistics information 154, profile information 156, and wager records 158 in any suitable format including, for example, XML tables, flat files, comma-separated-value (CSV) files, SQL tables, relational database tables, objects, and others.
In one aspect of operation, users of clients 102 participating in gaming applications 114 hosted by a server 104 engage in an enhanced services session with platform 106. Generally, platform 106 receives a request for enhanced services that is generated by a client 102 via an appropriate server 104. The request for enhanced services may be generated by the client 102 in response to a log-in event; a game event 120; input by a user of the client 102 such as, for example, instructions to initiate an enhanced services session; or any other suitable trigger.
In response to the request for enhanced services, platform 106 launches an enhanced services session with the particular client 102. In particular, platform 106 establishes one or more communication paths to the appropriate clients 102 and/or servers 104. In one embodiment, platform 106 establishes a communication path with the appropriate client 102 via an appropriate server 104. In another embodiment, platform 106 establishes a communication path with the appropriate client 102 using a proprietary web server (not shown). In yet another embodiment, platform 106 establishes a direct communication path with the appropriate client 102 using network 100. In all of these embodiments, the appropriate communication path is established such that platform 106 may provide enhanced services to the appropriate client 102.
The enhanced services session corresponds in time at least in part with the execution of the gaming application 114 in which the user of client 102 participates. During the enhanced services session, platform 106 may provide event management, statistics generation, and user profiling services to the user of client 102 with whom the enhanced services session is established. Other exemplary enhanced services include providing game advice, placing and settling wagers, and matching users of a gaming application 114 in an “intelligent lobby”. In this regard, platform 106 enriches the gaming experience of users participating in gaming applications 114 hosted by servers 104.
A particular advantage of system 10 is that platform 106 may simultaneously conduct enhanced services sessions with many clients 102 using the same or different servers 104. For example, platform 106 may conduct a first enhanced services session with one or more clients 102 connected to a first server 104 hosting a gaming application 114. Platform 106 may further conduct a second enhanced services session with the same or different clients 102 connected to a second server 104 hosting the same or different gaming application 114. The second enhanced services session may be initiated in response to a second request for enhanced services issued by the client 102 of the second server 104, and may correspond in time at least in part with the execution of the gaming application 114 in which the user participates. Moreover, the first enhanced services session may correspond in time at least in part with the second enhanced services session. In this regard, platform 106 may provide enhanced services to clients 102 coupled to many servers 104 simultaneously.
During an enhanced services session, platform 106 may provide different types of enhanced services to users of a client 102, such as game event management. While participating in a gaming application 114, a client 102 generally initiates many game events 120. A game event 120 comprises any combination of steps, moves, actions, such as an action undertaken by a user, or any other suitable events that occur within the context of a particular gaming application 114 that causes a change in the state of the gaming application 114. For example, in a golf gaming application 114, a game event 120 may comprise the selection of a golf club, the alignment of a golf shot, the execution of a golf shot, or any other golf-related activity performed by the user of the golf gaming application 114.
To provide game event management services to the appropriate client 102 during an enhanced services session, monitor module 110 of server 104 monitors the various game events 120 that are performed by a client 102 participating in a gaming application 114. Upon the performance of a game event 120, as determined by monitor module 110, interface 116 communicates corresponding event information 122 to platform 106. Event information 122 comprises data detailing the parameters of the corresponding game event 120. Event information 122 includes data detailing any number and combination of game events 120. Event information 122 may further comprise end-of-game data associated with a user of a gaming application 114, a gaming application 114, or both.
Event manager 130 of platform 106 processes event information 122 to generate event information 152. Event information 152 may comprise some or all of the data associated with event information 122 and generally comprises a log that may be used to reconstruct the sequence of game events 120 that occurred during the execution of a particular gaming application 114. In a particular embodiment, server 104 processes event information 122 to generate event information 152 prior to communicating it to platform 106. In this regard, server 104 filters event information 122. Event information 152 may be stored in memory 150 and is described in greater detail with respect to
As described above, platform 106 may conduct enhanced services sessions with many clients 102 using the same or different servers 104. With respect to game event management, therefore, event manager 130 may receive first event information 122 from a first server 104 monitoring the game events 120 of a first set of clients 102, and event manager 130 may further receive event information 122 from any number of other servers 104. For example, event manager 130 may receive second event information 122 from a second server 104 monitoring the game events 120 of a second set of clients 102. The first event information 122 details the parameters of game events 120 associated with the first set of clients 102 coupled to the first server 104 whereas the second event information 122 details the parameters of game events 120 associated with the second set of clients 102 coupled to the second server 104. Memory 150 stores first event information 152 as well as second event information 152.
In general, the first and second servers 104 may execute the same or different gaming applications 114 substantially simultaneously and, therefore, may communicate first and second event information 122 to platform 106 substantially simultaneously as well. In this regard, platform 106 may provide event management services to clients 102 participating in gaming applications 114 hosted by many different servers 104.
A particular advantage of system 10 is that game events 120 are monitored, and may even be processed, during the execution of the gaming application 114. Therefore, event information 152 comprises intra-game information and data. Such intra-game data generally provides meaningful insight into the execution of a gaming application 114 by a user. Moreover, such intra-game data may be used to generate statistics or compile user profiles, as described in greater detail below. As a result, platform 106 is able to provide real-time enhanced services to clients 102 using real-time data.
During an enhanced services session, platform 106 may provide another type of enhanced service to users of a client 102, such as statistics generation. In general, statistics manager 132 generates statistics information 154 based at least in part upon event information 152 (or 122). In a particular embodiment, statistics manager 132 generates statistics information 154 based upon previously generated statistics information 154. Statistics information 154 comprises data that is collected, sorted, organized, analyzed, or otherwise processed to define one or more quantitative and/or qualitative characteristics about a gaming application 114, a user of a gaming application 114, or both. Statistics information 154 may be stored in memory 150 and is described in greater detail with respect to
Statistics information 154 may be generated for particular users of clients 102 and for particular gaming applications 114. For example, statistics information 154 may be generated for different players of a backgammon gaming application 114. In this example, as each of the players triggers a game event 120 during the execution of the gaming application 114, statistics manager 132 generates statistics information 154 based at least in part upon the resulting event information 152. Statistics manager 132 may also generate statistics information 154 based upon end-of-game data communicated by server 104 about a gaming application 114.
In this regard, statistics information 154 is based not only upon data that is collected and/or determined after a gaming application 114 is completed, but statistics information 154 is also based upon real-time data generated from within the gaming application 114. Therefore, statistics information 154 reveals not only characteristics associated with the outcome of a gaming application 114, but also characteristics associated with how particular players play a gaming application 114. A particular advantage of this sort of real-time statistics generation is that platform 106 may then present statistics information 154 to users of clients 102 during the execution of a gaming application 114. The users of clients 102 may then use statistics information 154 to determine strengths and weaknesses of an opponent or the user; to modify a playing strategy; or to offer or accept a wager. All of this can be performed during and/or after the execution of a gaming application 114.
Another advantage of statistics manager 132 is that it may compare first statistics information 154, such as statistics information 154 associated with a particular user, with second statistics information 154, such as statistics information 154 associated with the same or different user. Platform 106 may then provide any number and combination of enhanced services to any number and combination of users based upon this comparison of statistics information 154. For example, platform 106 may audit the execution of a gaming application 114 by a particular user by comparing any combination of event information 152, statistics information 154, and profile information 156 associated with the user. Platform 106 may further measure any combination of event information 152, statistics information 154, and profile information 156 against certain predetermined thresholds associated with the user. In this regard, platform 106 may determine whether the user is playing a particular gaming application 114 at an expected skill level. Such an audit of player performance may reveal cheating or other anti-competitive behavior.
As described above, platform 106 may conduct enhanced services sessions with many clients 102 using the same or different servers 104. With respect to statistics generation, in one embodiment, statistics manager 132 may generate statistics information 154 based upon event information 122 received from a first server 104 monitoring the game events 120 of a first set of clients 102 participating in one or more gaming applications 114, and further based upon event information 122 received from the same server 104 or any number of other servers 104 monitoring the game events 120 of any number of the same or different clients 102 participating in the same or different gaming applications 114.
In this regard, the statistics information 154 generated by statistics manager 132 is robust and based upon a large sampling of data. Moreover, this technique allows statistics manager 132 to provide statistics generation services to clients 102 participating in gaming applications 114 hosted by many different servers 104. In other embodiments, the statistics information 154 may be based solely upon event information 152 (or 122) received from a particular server 104. This allows statistics manager 132 to generate statistics information 154 that is focused upon a particular user or gaming application 114.
During an enhanced services session, platform 106 may provide yet another type of enhanced service to users of clients 102, such as user profiling. In general, profile manager 134 generates profile information 156 for users of clients 102. Profile information 156 comprises a summary or analysis of any suitable qualitative and/or quantitative data that represents various features or characteristics about each particular user, such as, for example, financial data, statistical data, and user attributes. Profile manager 134 may generate profile information 156 based upon one or more of information and data entered by particular users; event information 152 (or 122); statistics information 154; and wager records 158. Profile information 156 may be stored in memory 150 and is described in greater detail with respect to
As described above, platform 106 may conduct enhanced services sessions with many clients 102 using the same or different servers 104. With respect to user profiling, profile manager 134 may generate profile information 156 based upon information and data received from clients 102 coupled to one or more different servers 104 at the same or different times. For example, profile manager 134 may generate profile information 156 based upon event information 122 (or 152) that is received from any number and combination of servers 104. In another example, profile manager 134 may generate profile information 156 based upon statistics information 154 compiled from event information 122 (or 152) that is received from any number and combination of servers 104.
Profile manager 134 may generate and/or update profile information 156 for particular users over time. For example, profile manager 134 may start generating profile information 156 for a particular user when a user first registers with system 10 and, thereafter, may update profile information 156 for that particular user each time the user participates in system 10—either as a player, a spectator, or a wagerer—using the same or different servers 104. Therefore, a user may play a backgammon gaming application 114 using a first server 104 and, at a later time, watch a chess gaming application 114 using a second server 104 and, at a still later time, wager on a golf gaming application 114 using a third server 104. Profile manager 132 may update profile information 156 for the user to include various characteristics about the user participating in each of these activities. With respect to playing a gaming application 114, for example, the profile information 156 may reflect how the user plays. With respect to watching a gaming application 114, for example, the profile information 156 may reflect what the user watches. With respect to wagering on a gaming application 114, for example, the profile information 156 may reflect how much the user prefers to wager.
Platform 106 uses profile information 156 to provide a host of other enhanced services, described in greater detail below. For example, lobby manager 136 may use profile information 156 to rank and/or match players of a particular gaming application 114. Game advisor 138 may use profile information 156 to provide advice to a player on how to play a particular gaming application 114. Wager manager 140 may use profile information 156 to provide a user of a client 102 with an opportunity to offer or accept a wager regarding a gaming application 114.
During an enhanced services session, platform 106 may provide yet another type of enhanced service to users of a client 102, such as matching users of a gaming application 114 in an “intelligent lobby”. Generally, a “lobby” is an online environment where players of gaming applications 114 meet one another and decide to play a gaming application 114 against each other. Lobby manager 136 creates an “intelligent lobby” in which players of gaming applications 114 are sorted, filtered, and presented to other players using profile information 156. Lobby processor 118 generally supports these efforts to match players of a gaming application 114. In a particular embodiment, lobby manager 136 matches players of gaming applications 114 against each other based at least in part upon profile information 156. In another embodiment, lobby manager 136 creates tournaments for gaming applications 114 by ranking players and arranging multiple rounds of competition using profile information 156. In this regard, lobby manager 136 creates a positive player experience by helping players find the right opponents.
During an enhanced services session, platform 106 may provide still another type of enhanced service to users of a client 102, such as providing game advice associated with a gaming application 114. Game advisor 138 presents game advice to players of a gaming application 114 during the execution of the gaming application 114 based upon various types of information about a player, an opponent, a wager, a gaming application 114, or any combination thereof. For example, game advisor 138 may provide game advice based upon any combination of event information 152 (or 122), statistics information 154, and profile information 156 of any suitable user of system 10. In a particular embodiment where a user may have a wager in place, game advisor 138 may provide game advice based upon the parameters of various wager records 158.
The game advice provided to a user generally comprises various options, strategies, suggestions, or any other suitable information that may be used to invoke a subsequent game event 120. In a particular embodiment, game advisor 138 may provide advice on whether to place and/or accept a wager, the parameters of the wager, and other wager-related information. A particular advantage of game advisor 138 is that the game advice is provided to the players during the execution of the gaming application 114 using real-time data.
As described above, platform 106 may conduct enhanced services sessions with many clients 102 using the same or different servers 104. With respect to game advice services, game advisor 138 may provide game advice to players of a gaming application 114 hosted by a first server 104 using information collected from the first server 104 or from a second server 104. For example, a player of a first chess game hosted by a first server 104 may receive game advice that is based upon game events 120 initiated by the same or different opponent playing a second chess game hosted by the first server 104 or the second server 104. The opponent may be currently playing or have previously played the second chess game. In this regard, game advisor 138 accesses a wider range of data to provide more robust game advice to players.
Moreover, game advisor 138 may provide first game advice to players of a first gaming application 114 and second game advice to players of a second gaming application 114. The first and second gaming applications 114 may be the same or different online games hosted by the same or different server 104. In this regard, game advisor 138 may provide different game advice to many different players of gaming applications 114 in system 10 at the same time.
During an enhanced services session, platform 106 may provide another type of enhanced service to users of a client 102, such as placing and settling wagers. Wager manager 140 facilitates placing and settling wagers among users of system 10. With respect to placing wagers, in one embodiment, wager manager 140 presents an appropriate graphical user interface, such as a “wager window” to a user during the execution of a gaming application 114. The wager window may be presented in response to a game event 120, event information 152, a request issued by a user, or any other suitable trigger. The wager window may be used to generate a wager offer.
The wager offer generally includes the parameters of the wager, such as the amount of the wager, the subject matter of the wager, a target of the wager offer, and the like. Wager manager 140 presents the wager offer to particular targets as specified in the wager offer, as specified by profile information 156, or according to any other suitable criteria. If one or more targets accept the wager offer, then wager manager 140 creates a corresponding number of wager records 158. Each wager record 158 defines the terms and conditions of the wager in various wager parameters, including the wager event, the wager value, and various wager conditions, and is stored by memory 150. The wager event is the subject matter of the wager, and generally involves a game event 120 associated with a gaming application 114. For example, the wager event may comprise an action performed during the execution of a gaming application 114 that changes the state of the gaming application 114. The outcome of a particular wager may be determined, at least in part, based upon the occurrence or non-occurrence of an associated wager event.
A particular advantage of wager manager 140 is that it allows a user to generate a wager offer before, during, or after the execution of a gaming application 114. This allows players to make a side bet, for example, during game play. By providing the GUI to the user without requiring the user to navigate to another web-site or to log-on with a separate server dedicated to establishing wagers, the ability to generate a wager offer is integrated into the gaming experience.
As described above, platform 106 may conduct enhanced services sessions with many clients 102 using the same or different servers 104. With respect to wagering services, wager manager 140 may facilitate wagers between clients 102 coupled to the same or different servers 104 and participating in the same or different gaming applications 114. For example, wager manager 140 may receive a wager offer from a user of client 102 coupled to a first server 104 for presentation to users of clients 102 coupled to the same first server 104 or to clients 102 coupled to any number of other servers 104. Moreover, wager manager 140 may receive an acceptance to the wager offer from users of clients 102 coupled to the same or different servers 104 and participating in the same or different gaming applications 114. In this regard, wager manager 140 provides a wider wagering audience for users of system 10.
With respect to settling wagers, in one embodiment, wager manager 140 determines the outcome of a wager based at least in part upon event information 152 (or 122) and the wager parameters specified in the corresponding wager record 158. For example, wager manager 140 may determine the outcome of a wager based upon event information 152 and a wager event specified in a wager record 158. The event information 152 (or 122) used by wager manager 140 is communicated by an appropriate server 104 and provides details about game events 120 that are relevant to the outcome of the wager. As a result of the real-time event monitoring capabilities of platform 106, wager manager 140 can determine the outcome of a wager in real-time and allows a user to formulate a wager based upon intra-game events 120. In particular embodiments, wager manager 140 in combination with funds manager 142 operates to transfer funds between accounts of participants of a wager based upon the determined outcome of the wager. This type of wager settlement may occur at any appropriate time after the outcome of the wager is determined.
Record identifier 270 comprises information used to identify a particular user profile of profile information 156. User identifier 272 comprises information used to identify the particular user of client 102 for whom a specific user profile of profile information 156 is maintained. In general, profile manager 134 maintains a user profile for each user of system 10. For each user profile, account information 274 comprises financial information such as, for example, credit limits, balance, credit history, and any other suitable financial information associated with a particular user. Statistics information 154 is illustrated in greater detail with respect to
Wagering parameters 276 comprise information identifying wager limits, current wagers, wager preferences, wager frequency, wager minimums and maximums, risk tolerance, and any other suitable wagering parameters associated with a particular user. User characteristics 278 comprise information identifying the playing style of a particular user. For example, user characteristics 278 may include the number of disconnects a particular user performs during the execution of a gaming application 114; the connection speed of a particular client 102 (e.g. broadband, or dial-up access); the average response time to perform a game event 120; evaluations of a particular user by other users of system 10; a ranking of the user among peer players for a particular gaming application 114; the geography of the particular user; and any other suitable characteristics about a particular user.
Selection criteria 280 comprises any suitable criteria used to select prospective opponents for a particular gaming application 114 such as, for example, wager criteria (e.g. wager size, wager type, wager frequency); skill criteria (e.g. skill level, ranking, skill weakness/strengths); player strategy (e.g. aggressive, conservative); and any other suitable selection criteria.
Wager parameters 308, 310, and 312 define the terms and conditions of the wager record 158. For example, wager event 308 comprises information used to identify a particular event, such as a game event 120, that determines the outcome of the wager. Wager value 310 comprises information used to identify the value of the particular wager record 158. Wager conditions 312 comprise information used to identify any other parameters associated with the wager. For example, wager conditions 312 may comprise time limits for the particular wager, various rules to be applied to the wager, and any other suitable wager parameter.
Platform 106 provides enhanced services to the user of the gaming application 114 during the enhanced services session at step 406. In particular, platform 106 may provide event management services, described in more detail with reference to
A particular advantage of system 10 is that platform 106 may simultaneously conduct enhanced services sessions with many clients 102 using the same or different servers 104. Therefore, steps 400a, 402a, and 404a illustrate that platform 106 conducts a first enhanced services session with a client 102 coupled to a first server. Steps 400b, 402b, and 404b illustrate that platform 106 conducts additional enhanced services sessions with any number of additional clients 102 coupled to the same or different servers 104. These additional enhanced services sessions may overlap in time with any portion of any other enhanced services session conducted by platform 106.
A particular advantage of system 10 is that platform 106 may conduct enhanced services sessions with many clients 102 using the same or different servers 104. With respect to game event management services, therefore, event manager 130 may receive first event information 122 from a first server 104 monitoring the game events 120 of a first set of clients 102, as described with reference to first path 420. Event manager 130 may further receive event information 122 from any number of other servers 104, as illustrated with reference to path 422. For example, event manager 130 may receive second event information 122 from a second server 104 monitoring the game events 120 of a second set of clients 102. Memory 150 stores first event information 152 and second event information 152, at step 424. Event manager 130 determines whether the particular gaming application 114 being monitored has ended at step 426. If not, execution returns to step 412. If so, execution terminates at step 428. Event information 152 may be used by other modules of platform 106 to provide enhanced services to users of system 10.
At step 484, game advisor 138 gathers information used to generate the game advice. Examples of this information include event information 152 associated with the gaming application 114 for which the game advice will be provided. This event information 152 may be associated with the current execution of the gaming application 114, or any previous execution of the gaming application 114, on the same or different server 104 by the same or different user. Game advisor 138 may further gather event information 152 associated with other gaming applications 114 currently or previously executed on the same or different server 104 by the same or different user. In this regard, game advisor 138 may analyze event information 152 from any combination of users, opponents, or other participants of the same or different gaming application 114 currently being executed or previously executed on the same or different server 104. In addition to event information 152, game advisor 138 may gather statistics information 154, profile information 156, and wager records 158 associated with any combination of users of system 10.
Execution proceeds to step 486, where game advisor 138 generates game advice based upon any combination of information gathered at step 484. In a particular embodiment, the game advice comprises wager advice such as, for example, whether to place and/or accept a wager, the parameters of the wager, and any other suitable wager-related information. Game advisor 138 communicates the game advice to one or more users at step 488. In general, the game advice is communicated during the execution of a gaming application 114 for which the game advice is provided. Execution terminates at step 490.
Referring to path 506, lobby manager 136 selects a first user at step 520 based upon, for example, profile information 156 associated with the first user and/or selection criteria 280 associated with any other user of system 10. Lobby manager 136 selects a second user at step 522 based upon, for example, profile information 156 associated with the second user and/or selection criteria 280 associated with the first user selected at step 520. Execution proceeds to step 524, where lobby manager 136 matches the first user selected at step 520 against the second user selected at step 522 in a competition associated with the execution of a particular gaming application 114 based upon profile information 156 and/or selection criteria 280 of the first and second users.
Referring to path 508, lobby manager 136 determines subsets of users at step 530 based upon, for example, profile information 156. For example, lobby manager 136 may determine a first subset of users and a second subset of users. From here, lobby manager 136 may match users from within particular subsets against each other in a competition associated with the execution of the gaming application 114, at step 532. For example, lobby manager 136 may match first and second users from the first subset of users and match third and fourth users from the second subset of users.
Alternatively, or in addition, lobby manager 136 may match users from among different subsets against each other in a competition associated with the execution of the gaming application 114, at step 534. For example, lobby manager 136 may match a first user from the first subset of users with a second user from a second subset of users. In this regard, lobby manager 136 may establish a tournament for a particular gaming application in which several users compete against each other in multiple rounds of competition. The users are generally selected based upon profile information 156 and/or selection criteria 280 associated with any combination of users.
Referring to path 510, lobby manager 136 identifies profile information 156 associated with a particular first user at step 540. Lobby manager 136 determines a subset of second users based upon, for example, selection criteria 280 and profile information 156, at step 542. For example, lobby manager 136 may determine the subset of second users by comparing selection criteria 280 associated with the first users identified at step 540 with profile information 156 associated with all of the other users. In another embodiment, lobby manager 136 determines the subset of second users by comparing selection criteria 280 associated with the second users with profile information 156 associated with the first user identified at step 540. In yet another embodiment, lobby manager 136 determines the subset of second users based at least in part upon profile information 156 associated with the first user and the second users, and selection criteria 280 associated with the first user and the second users.
At step 544, lobby manager 136 matches the first user selected at step 540 against a selected second user from the subset of second users selected at step 542. In one embodiment, lobby manager 136 selects the second user according to profile information 156 and selection criteria 280. In another embodiment, the first user identified at step 540 selects from among the subset of second users determined at step 542. In this regard, a user of system 10 can enter an “intelligent lobby” associated with a gaming application 114 and be presented with a list of suitable opponents from which the first user may select a particular opponent. Execution terminates at step 550.
At step 602, wager manager 140 receives a wager offer by a user of a gaming application 114. In one embodiment, the wager offer is generated by the user using the wager window presented at step 600. Wager manager 140 determines whether the wager offer received at step 602 is valid at step 604 based upon, for example, financial information stored in memory 150 and associated with the particular user that generated the wager offer. If the wager offer is invalid, as determined at step 604, wager manager 140 notifies the user at step 606. From here, execution either proceeds to step 600 where wager advisor 140 presents another wager window to the user so that the user may generate a new, valid, wager offer, or execution terminates at step 622. If the wager offer received at step 602 is determined to be valid at step 604, wager manager 140 presents the wager offer to a plurality of users of system 10 at step 608.
The particular users to whom the wager offer is presented may comprise any suitable subset of all users of system 10 based upon, for example, profile information 156 and/or selection criteria 280. In this regard, wager manager 140 presents the wager offer to those users of system 10 that are most likely to accept the wager. Wager manager 140 receives one or more wager acceptances at step 610. The wager offer and a wager acceptance combine to form a wager between a first user and a second user.
It should be understood that the first user and the second user may comprise players of a particular gaming application 114, spectators of a particular gaming application 114, or any other users of system 10. In one embodiment, at least one of the wager offer and the wager acceptance is received during the execution of a gaming application 114. In this regard, wager manager 140 facilitates intra-game wagering.
Wager manager 140 determines whether the wager acceptance received at step 610 is valid at step 612 based upon, for example, financial information associated with the user that accepted the wager offer. If the wager acceptance is determined to be invalid at step 612, execution proceeds to step 614 where a wager manager 140 notifies the user. From here, execution may return to step 608 where wager manager 140 may present the wager offer to users of system 10, or execution may terminate at step 622.
If the wager acceptance is determined to be valid at step 612, execution proceeds to step 616 where wager manager 140 reserves funds from each of the user's accounts into an escrow account. Wager manager 140 then generates a wager record 158 associated with the wager between the first user and the second user, at step 618.
The wager record 158 generally comprises a first user identifier, a second user identifier, and a plurality of wager parameters. For example, the wager parameters may include a wager event, a wager value, and wager conditions. The wager event generally comprises an action performed during the execution of a gaming application 114 that changes the state of the gaming application 114 and upon which the outcome of the wager between the first user and the second user is determined. Memory 150 stores the wager record 158 at step 620 according to a wager record identifier 270. Execution terminates at step 622.
Execution proceeds to step 654 where wager manager 140 determines whether the outcome of the wager is decided by event information 152 (or 122). In general, wager manager 140 determines the outcome of the wager at step 654 based upon wager parameters of the wager record 158 and event information 152 (or 122). For example, wager manager 140 determines the outcome of the wager by cross-referencing event information 152 (or 122) with wager parameters associated with the wager record 158. If the wager parameters necessary to determine the winner of the wager are not satisfied, as determined at step 654, execution returns to step 652 where wager manager 140 continues to receive event information 152 (or 122). If the wager parameters necessary to determine the winner of the wager are satisfied, as determined at step 654, execution proceeds to step 656 where wager manager 140 notifies the first and second users. A particular advantage of system 10 is that automatic verification of wagers based upon event information 152 (or 122) and wager parameters eliminates the problems associated with trust-based wagering systems. This type of automatic verification of wagers not only makes wagering easier, but it allows users to generate more detailed, intra-game, wagers.
Execution proceeds to step 658 where funds manager 142 transfers funds between an account of the first user and an account of the second user that participated in the determined wager. In one embodiment, funds manager 142 transfers the funds during the execution of the gaming application 114. In another embodiment, funds manager 142 transfers funds based upon the outcome of one or more other wagers between the first user and the second user. Execution terminates at step 660.
As described above, platform 106 may conduct enhanced services sessions with many clients 102 using the same or different servers 104. In one embodiment, a single server 104 may host multiple gaming applications 114 that are the subject of separate wagers. Various event information 152 associated with this server 104 may therefore be used by wager manager 140 to determine the outcomes of these separate wagers.
In another embodiment, separate servers 104 may host the same or different gaming application 114 that is the subject of separate wagers. Therefore, memory 150 may store a number of wager records 158 associated with users of clients 102 coupled to the same or different servers 104. These wager records 158 generally include a server identifier 306 indicating which servers 104 will communicate the event information 152 that may determine the outcome of the wager. With respect to settling wagers, wager manager 140 may receive first event information 152 associated with a first server 104 and second event information 152 associated with a second server 104. Wager manager 140 may then determine the outcome of a first wager based at least in part upon the first event information 152 and may determine the outcome of a second wager based at least in part upon the second event information 152.
To facilitate the determination of various wagers, the first event information 152 may further be associated with an identifier of the first server 104 and the second event information 152 may be associated with an identifier of the second server 104. In this regard, wager manager 140 may identify a first subset of wager records 158 using server identifier 306 and the identifier of the first server 104, and wager manager 140 may identify a second subset of wager records 158 using server identifier 306 and the identifier for the second server 104. In this regard, wager manager 140 can quickly filter through event information 152 to identify the event information 152 that is relevant for determining the outcome of a particular wager record 158.
Although the present invention has been described in detail, it should be understood that various changes, substitutions and alterations can be made hereto without departing from the sphere and scope of the invention as defined by the appended claims.
To aid the Patent Office, and any readers of any patent issued on this application in interpreting the claims appended hereto, applicants wish to note that they do not intend any of the appended claims to invoke ¶6 of 35 U.S.C. § 112 as it exists on the date of filing hereof unless “means for” or “step for” are used in the particular claim.
This application is a continuation of U.S. patent application Ser. No. 10/193,980 filed Jul. 12, 2002, claiming the benefit of U.S. Provisional Application No. 60/305,149 filed Jul. 13, 2001; U.S. Provisional Application No. 60/323,597 filed Sep. 20, 2001; U.S. Provisional Application No. 60/305,151 filed Jul. 13, 2001; U.S. Provisional Application No. 60/305,150 filed Jul. 13, 2001; U.S. Provisional Application No. 60/305,147 filed Jul. 13, 2001; U.S. Provisional Application No. 60/305,146 filed Jul. 13, 2001; and U.S. Provisional Application No. 60/323,598 filed Sep. 20, 2001.
Number | Date | Country | |
---|---|---|---|
60323598 | Sep 2001 | US | |
60323597 | Sep 2001 | US | |
60305149 | Jul 2001 | US | |
60305146 | Jul 2001 | US | |
60305150 | Jul 2001 | US | |
60305151 | Jul 2001 | US | |
60305147 | Jul 2001 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14285191 | May 2014 | US |
Child | 16699337 | US | |
Parent | 11335253 | Jan 2006 | US |
Child | 14285191 | US | |
Parent | 10193980 | Jul 2002 | US |
Child | 11335253 | US |