The invention relates generally to computer systems, and more particularly to an improved system and method for making markets for a finite subset of orders placed across continuous and countably infinite outcome spaces.
A prediction market provides a central place where people may converge to place orders, such as a betting market for placing bets on the outcome of an event or a financial market for placing orders for trading commodities or securities of uncertain value. In a well-functioning market, the resulting prices can reflect a wealth of information about the expected value of the security, which, in ideal circumstances, may represent the sum total of all information available to all traders. In general, prediction markets can provide forecasts for some future events by aggregating information of participants.
When a future event is or can be treated as a continuous random variable, existing prediction market mechanisms may take one of the following two approaches. The continuous random variable may be discretized into a discrete random variable with finite exclusive outcomes and the probability mass function of the discrete random variable may be predicted. Or some statistic of the continuous random variable, such as the expectation, may be directly predicted. In either case, much information about the continuous random variable is not captured by existing prediction markets.
Other mechanisms in combinatorial prediction markets may provide forecasts of future events by attempting to aggregate more information, but result in dividing traders' attention on market information among an exponential number of outcomes of a joint random variable, making the likelihood of finding agreeable bilateral trades remote. In any case, existing combinatorial prediction markets deal with discrete and finite outcome space. Outcome spaces that are continuous or infinite are discretized into finite outcomes that only allow traders to bet on the finite outcomes. Such a restriction on outcome spaces hinders information aggregation. See for example, L. Fortnow, J. Kilian, D. M. Pennock, and M. P. Wellman, Betting Boolean-style: A Framework for Trading in Securities Based on Logical Formulas, Decision Support Systems, 39(1):87-104, 2004; and R. D. Hanson, Combinatorial Information Market Design, Information Systems Frontiers, 5(1):107-119, 2003.
What is needed is a system and method for prediction markets that may allow participants to trade on continuous or countable infinite outcomes that allow participants to express their information more freely. Such a system and method should be able to support traders for dealing with continuous or countably infinite outcome spaces directly in order to get more complete and refined information from traders.
Briefly, the present invention may provide a system and method for making markets for a finite subset of orders across continuous and countably infinite outcome spaces. To do so, a prediction market engine may be provided to support prediction markets by aggregating information about orders specifying continuous subspaces of the continuous outcome space and orders specifying a subset of a countably infinite set of outcomes. In an embodiment, a prediction market engine may include an operably coupled market maker engine for providing services for a market maker such as determining pricing for the orders, and the prediction market engine may also include an operably coupled auctioneer engine in an embodiment for providing services for an auctioneer such as determining quantities for the orders placed across continuous and countably infinite outcome spaces.
The present invention may provide a framework for making markets for a finite subset of orders across continuous and countably infinite outcome spaces. To do so, orders specifying continuous subspaces of the continuous outcome space or orders specifying a subset of a countably infinite set of outcomes may be received. The pricing and/or quantities for orders received may be determined, a response may be sent to traders indicating the pricing or quantities of orders for payment, and the amount owed for accepted orders may be collected. Winning accepted orders may be identified and payout may be made for winning accepted orders.
In an embodiment, a market maker may determine pricing for order received and send a response to traders indicating the price of orders to be accepted. In another embodiment, an auctioneer may determine the quantities of orders to accept and send a response to traders indicating the quantities of accepted orders. In either embodiment, a cost function of a continuous-outcome dynamic pari-mutuel market may be evaluated to determine orders to accept that specify a subspace of the continuous outcome space. And, in either embodiment, a cost function of an infinite-outcome dynamic pari-mutuel market may be evaluated to determine orders to accept that specify a subset of a countably infinite set of outcomes.
The present invention may support many applications for making markets for a finite subset of orders placed across continuous and countably infinite outcome spaces. An online financial application may use the present invention to make a market for trading commodities or securities of uncertain value. Or an application for a prediction market may use the present invention to forecast the likelihood of the occurrence of a particular event. Moreover, the present invention may accordingly be generally used for prediction markets where price discovery may be achieved by trading with sufficient liquidity. Such price discovery for a particular prediction market application may in turn be used to forecast the likelihood of the occurrence of a certain event.
Advantageously, such a prediction of the occurrence of a particular event may result in a better forecast of the event than other methods across many different settings including politics, sports and business. Other advantages will become apparent from the following detailed description when taken in conjunction with the drawings, in which:
The invention may be described in the general context of computer-executable instructions, such as program modules, being executed by a computer. Generally, program modules include routines, programs, objects, components, data structures, and so forth, which perform particular tasks or implement particular abstract data types. The invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in local and/or remote computer storage media including memory storage devices.
With reference to
The computer system 100 may include a variety of computer-readable media. Computer-readable media can be any available media that can be accessed by the computer system 100 and includes both volatile and nonvolatile media. For example, computer-readable media may include volatile and nonvolatile computer storage media implemented in any method or technology for storage of information such as computer-readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can accessed by the computer system 100. Communication media may include computer-readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. For instance, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media.
The system memory 104 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 106 and random access memory (RAM) 110. A basic input/output system 108 (BIOS), containing the basic routines that help to transfer information between elements within computer system 100, such as during start-up, is typically stored in ROM 106. Additionally, RAM 110 may contain operating system 112, application programs 114, other executable code 116 and program data 118. RAM 110 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by CPU 102.
The computer system 100 may also include other removable/non-removable, volatile/nonvolatile computer storage media. By way of example only,
The drives and their associated computer storage media, discussed above and illustrated in
The computer system 100 may operate in a networked environment using a network 136 to one or more remote computers, such as a remote computer 146. The remote computer 146 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer system 100. The network 136 depicted in
The present invention is generally directed towards a system and method for making markets for a finite subset of orders placed across continuous and countably infinite outcome spaces. More particularly, a framework for a prediction market may be provided for receiving orders specifying a continuous subspace of a continuous outcome space or orders specifying a subset of a countably infinite set of outcomes. A continuous outcome space may include the real number line, curves, or a high dimensional space. As used herein, a prediction market may mean an information market, a securities market, a contingent claims or contract market, an event market or futures, idea futures, an auction market, and so forth. Orders may mean herein any description of bets including terms of prices and shares, odds, payoff vectors, and the diverse array of descriptions practiced in financial and gambling circles. The pricing and/or quantities for orders received may be determined and a response may be sent to traders indicating the pricing or quantities of orders for payment. Winning accepted orders may be identified and payout may be made for winning accepted orders.
As will be seen, the framework may support a market maker in an embodiment for determining pricing for orders received and will also support an auctioneer in another embodiment for determining quantities for orders received. In various embodiments, the present invention may be generally used for a prediction market to forecast the likelihood of the occurrence of a certain event. As will be understood, the various block diagrams, flow charts and scenarios described herein are only examples, and there are many other scenarios to which the present invention will apply.
Turning to
In various embodiments, a computer 202, such as computer system 100 of
The prediction market engine 204 may provide services for supporting prediction markets that may aggregate information about predicted continuous random variables in order to allow participants of the prediction market to place a finite number of orders on continuous or countably infinite outcomes. In an embodiment, the orders 212 may be either a buy order or a sell order and may be represented by a description of the order for sale or purchase and may include a quantity and price. The order description may specify a commodity, a security, or more generally, the outcome of an event. The prediction market engine 204 may include a market maker engine 206 for providing services to make a market for placing a finite number of orders across continuous and countably infinite outcomes, and an auctioneer engine 208 for providing services to make a market for auctioning a finite number of orders placed across continuous and countably infinite outcomes. Each of these modules may also be any type of executable software code such as a kernel component, an application program, a linked library, an object with methods, or other type of executable software code.
There are many applications which may use the present invention for making markets for a finite subset of orders placed across continuous and countably infinite outcome spaces. For example, an online financial application may use the present invention to make a market for trading commodities or securities of uncertain value. Or an application for a prediction market may use the present invention to forecast the likelihood of the occurrence of a particular event. For instance, a policymaker seeking a forecast of the likelihood of where a hurricane may strike the coast may use the present invention for making a prediction market in which traders can trade securities of their own choices that specify a segment of the coast line and pay $1 if and only if the hurricane strikes land within the specified segment of the coast line. With sufficient liquidity, traders of the security may reflect their collective information about the value of the security and correspondingly about the likelihood where a hurricane may strike the coast. Those skilled in the art will appreciate that the present invention may accordingly be generally used for prediction markets where price discovery is a goal that may be achieved by trading with sufficient liquidity. Such price discovery for particular prediction market application may in turn be uses to forecast the likelihood of the occurrence of a certain event. Empirically, such prediction markets may often yield better forecasts of future events than other methods across many different settings including politics, sports and business.
There may be various ways for making markets for a finite subset of orders placed across continuous and countably infinite outcome spaces. For forecasting a future event as an example, the future event may be treated in an embodiment as a continuous random variable that may correspond to countably infinite exclusive outcomes. Alternatively, the future event may be treated in another embodiment as a continuous random variable that may correspond to a point on the real line. In yet another embodiment, the future event may be treated as a continuous random variable that may correspond to a point within a fixed interval.
In a DPM, traders who wager on the true outcome may split the total pool of money at the end of the market. However, the cost (price) of a single share varies dynamically according to some price functions, thus allowing trader to sell their shares prior to the determination of the outcome for profits or losses. A natural way for a market maker to set security (or order) prices in a DPM is to equate the ratio of prices of any two securities (or orders) with the ratio of the number of shares outstanding for the two securities (or orders). Consider {right arrow over (q)}=(q1, q2, . . . , qN) to denote a vector of shares outstanding for securities (or orders). Then, the total money wagered in the market may be denoted by the cost function,
and the instantaneous price may be denoted by the price function,
where κ is a free parameter.
If outcome i may happen and the quantity vector at the end of the market may be denoted as {right arrow over (q)}f, the pay-off for each share of the winning security may be denoted as
Returning to
and the price function
∀i. The trader's payment may equal the value differences in the cost function. However, strictly speaking function
∀i, does not represent price, but is more like a density function. The instantaneous price for buying an infinitely small number of a security for interval (a,b) may be determined using the price function
If the realized value of the random variable is x*, each share of a security on any interval that contains x* entitles its holder an equal share of the total money in the market. Thus, the payoff per share may be determined using the payout function,
where qf(y) is the number of outstanding shares for securities whose interval contains y at the end of the market.
In various embodiments, a market maker engine may accept the quantities specified by orders and determine the price using the cost and price functions of a continuous-outcome DPM and may accept quantity orders at a loss, in return for improving trader incentives, liquidity and price discovery. A market maker engine utilizing a continuous-outcome DPM can choose an initial quantity distribution q0(x) for bounding any loss to a finite loss. The price per share for buying a security on interval (a,b) is always less than or equal to κ√{square root over (b−a)}. If traders can bet on any non-empty open interval, the payoff per share may be bounded below by 0. If traders may be restricted to bet only on open intervals of size at least z, the payoff per share may be bounded below by
In various other embodiments, an auctioneer engine may accept bids as the price amount and may determine quantities of orders so that the auctioneer may not suffer any loss.
Those skilled in the art will appreciate that the present invention may also be applied to other continuous subspaces of a continuous output space, including real lines, curves, high dimensional spaces, and so forth. In addition to random forecast variables that have a continuous outcome space, many random forecast variables of interest have a countably infinite outcome space.
At step 404, the quantities and prices of orders to accept may be determined. The cost and price for the infinite-outcome DPM may be determined using the cost function
and the price function
where κ is a free parameter. In practice, the market maker engine does not need to record quantities and calculate prices for all infinite outcomes, but only for the finite number of infinite outcomes having outstanding shares.
The payoff per winning security if outcome i happens may be determined using the payout function
The loss of the market maker in an infinite-outcome DPM may generally be the cost to initiate the market and the market maker engine may choose a {right arrow over (q)}0 such that the loss cI({right arrow over (q)}0) may be finite. For instance, the market maker engine may start with a quantity vector that has only finite positive elements. Advantageously, payoff of a security in an infinite-outcome DPM may always be greater than or equal to κ and the price of a security may always be less than or equal to κ.
At step 506, a response indicating quantities and prices of orders may be sent to traders. The amount owed for orders accepted by traders may be collected at step 508. For instance, the amount owed for the orders may be collected using an electronic payment system such as a purchase order transaction system, electronic commerce system, or other type of online system that may accept payment.
At step 510, accepted orders that win may be identified. The winning amounts for accepted orders may be paid out at step 512. For contracts specifying an interval of the real-line, a market maker engine may determine the payout using the payout function of a continuous-outcome DPM as described above in conjunction with
At step 606, a response indicating quantities and prices of orders accepted may be sent to traders. The bid amount for orders accepted may be collected from traders at step 608. For instance, the bid amount for the orders may be collected using an electronic payment system such as a purchase order transaction system, electronic commerce system, or other type of online system that may accept payment.
At step 610, accepted orders that win may be identified. For example, a match may be found for a seller and buyer of an order according to auction rules and the winning bid amounts for accepted orders may be payed out at step 612. For contracts specifying an interval of the real-line, an auctioneer engine may determine the payout using the payout function of a continuous-outcome DPM as described above in conjunction with
Those skilled in the art will appreciate that other prediction market mechanisms may be used by a market maker engine or auctioneer engine to predict a random variable with continuous or countably infinite outcomes. For example, a logarithmic scoring rule for price and cost function may be defined to accommodate infinite and continuous outcomes. A logarithmic scoring rule for a continuous random variable may be defined as s(r(x))=blog(r(x)) when x may be the realized value for the random variable and r(x) may be the reported probability density function for the random variable evaluated at x. The corresponding cost function and price functions for a continuous logarithmic market scoring rule market maker may be
respectively
As in the continuous-outcome DPM, p(x) does not represent price, but is more like a density function. The instantaneous price for buying an infinitely small number of a security for interval (a,b) may be
If the realized value of the random variable may be contained by the interval (a,b), each share of the security entitles its holder to a payoff. However, the worst-case loss may be unbounded for a continuous logarithmic market scoring rule market maker even with the restriction on size of intervals.
In yet another embodiment, traders may propose to buy securities and the market maker or auctioneer may solve a linear programming problem to determine the quantities and prices of orders to accept. Consider an index set of orders Ot which the market receives at time t. Each order Ot may denote a triple (bi, qi, φi) , where bi denotes how much the trader is willing to pay for a unit share of security φi and qi may denote the number of shares of the security the trader wants to purchase at price bi. Naturally, biε(0,1) since a unit of the security may pay off at most $1 when the event is realized.
An order i may specify a continuous subspace if the outcome space may be continuous, for example, an interval on the real line, an area in a two dimensional plane, or a continuous segment of a curve. An order i may specify a subset of outcomes if the outcome space is countably infinite. The number of orders may be finite.
The set of orders Ot at time t may partition the outcome space into finite discrete states. Consider St to denote the state space at time t, and stεSt to denote a particular state. For example, if the outcome space may be the real line, after getting an order to buy 3 shares of interval (1,2) at price $0.6, the outcome space may be partitioned into 3 states, (−∞, 1], (1,2), and [2,+∞). If the order may be accepted, the trader may get $1 per share if state (1,2) is realized. The state space St may change with the set of orders Ot at time t.
Then an auctioneer engine or a market maker engine may solve a linear programming problem at each time point t when new orders come in, defined as follows:
≧c, ∀stεSt, 0≦xi≦1, ∀iεOt, where xi is the quantity accepted for order i, and the variable c is the maximum loss that the market maker is willing to bear. When c=0, the market may be essentially run by an auctioneer who does not bear any risk. When c<0, the market may be run by a market maker who is willing to subsidize the market for at most c dollars.
The mechanism can have different optimization objectives, such as total trading volume or worst-case loss. The objective of solving the linear programming problem defined as
∀stεSt, 0≦xi≦1, ∀iεOt is to maximize the total trading volume. In this case, the above linear programming problem assumes that orders are divisible. If xi's are indivisible, the auctioneer engine and the market maker engine may solve an integer programming problem at each time t defined as:
∀stεSt, xiε{0,1}, ∀iεOt.
Thus the present invention may provide prediction market mechanisms that may be used by a market maker engine or auctioneer engine to predict a random variable with continuous or countably infinite outcomes. The present invention may allow participants in prediction markets to trade on continuous or countable infinite outcomes and express their information more freely. Advantageously, such a system and method may support aggregation of more information from market participants for supporting market liquidity. Furthermore, by providing aggregation of more information, the prediction of the occurrence of a particular event may result in a better forecast of the event in any number of applications.
As can be seen from the foregoing detailed description, the present invention provides an improved system and method for making markets for a finite subset of orders across continuous and countably infinite outcome spaces. The present invention may support many applications for making markets for a finite subset of orders placed across continuous and countably infinite outcome spaces. For instance, an online financial application may use the present invention to make a market for trading commodities or securities of uncertain value. Such a system and method may support many applications for prediction markets to forecast the likelihood of the occurrence of a particular event. As a result, the system and method provide significant advantages and benefits needed in contemporary computing.
While the invention is susceptible to various modifications and alternative constructions, certain illustrated embodiments thereof are shown in the drawings and have been described above in detail. It should be understood, however, that there is no intention to limit the invention to the specific forms disclosed, but on the contrary, the intention is to cover all modifications, alternative constructions, and equivalents falling within the spirit and scope of the invention.