The invention is directed to systems, methods, and an apparatus for bidding in online auctions. Bids for advertising include an amount that is a function of an expected value-per-click and a fraction of a budget already spent for advertising slots.

Patent
   8046294
Priority
Jul 30 2007
Filed
Jul 30 2007
Issued
Oct 25 2011
Expiry
Apr 14 2029
Extension
624 days
Assg.orig
Entity
Large
4
4
EXPIRED
15. A computer system, comprising:
memory storing an algorithm;
processor to execute the algorithm to:
examine bids for advertising slots for a keyword search;
submit a bid amount for the advertising slots, the bid amount being a function of an expected value-per-click divided by a value of an exponential function of a fraction of a budget already spent;
allocate the advertising slots to bidders.
1. A method executed by a computer, comprising:
receiving, at a computer, bids for advertising at an online search auction;
calculating, by the computer, an amount to bid for the advertising, the amount equal to an expected value-per-click divided by a value of a function of a fraction of a budget already spent for advertising on previous bids at the online search auction; and
displaying, at a computer, advertisements in winning ad slots.
9. A non-transitory computer-readable medium having computer-readable program code embodied therein which when executed by a computer causes the computer to perform the following steps:
receiving bids for advertising slots for a network search query;
bidding for one of the advertising slots an amount of money that is an expected value-per-click divided by an exponential function of a fraction of a budget already spent for previous advertising slots;
displaying advertisements of bidders.
2. The method of claim 1 further comprising, placing a bid only when a highest bid among current bidders for the advertising is less than the expected value-per- click.
3. The method of claim 1, wherein an efficiency of each ad slot has an upper bound based on the expected value-per-click divided by a search engine minimum fee charge for receiving a slot to advertise.
4. The method of claim 1 further comprising, calculating an optimal amount of money to bid for the advertising based on a multiple-choice knapsack problem modeling of ad slots over time periods.
5. The method of claim 1 further comprising, modeling of a multiple-choice knapsack problem based on one of maximizing a total revenue of an advertiser over time, maximizing a total profit of the advertiser, or a total number of impressions.
6. The method of claim 1 further comprising:
modeling an online trading process of goods or services, wherein a trader has a budget constraint as an online knapsack problem;
solving a online trading problem using an algorithm developed for the online knapsack problem.
7. The method of claim 1 further comprising:
determining an optimal amount of money to bid for the advertising slot without having knowledge of other bids and click-through rates for advertising slots.
8. The method of claim 1 further comprising:
receiving keywords for a search query;
assessing the keywords to determine how much to bid for an advertising slot in order to maximize a return on investment for the search query.
10. The non-transitory computer-readable medium of claim 9, wherein the code further causes the computer to perform:
calculating when a maximum bid amount for the advertising slots is greater than the expected value-per-click.
11. The non-transitory computer-readable medium of claim 9, wherein the code further causes the computer to perform:
determining the amount of money to bid based on profit for winning the one of the advertising slots divided by a cost to win the one of the advertising slots.
12. The non-transitory computer-readable medium of claim 9, wherein the amount of money depends only on a value of keywords submitted for the network search query and the fraction of the budget already spent.
13. The non-transitory computer-readable medium of claim 9, wherein the code further causes the computer to perform:
determining an optimal amount to bid for the one of the advertising slots without utilizing information pertaining to (1) amounts of other bids received for the one of the advertising slots and (2) how frequently network search queries occur.
14. The non-transitory computer-readable medium of claim 9, wherein each of the advertising slots has a click-through rate that is defined as an expected number of clicks on an advertisement divided by a total number of impressions.
16. The computer system of claim 15, wherein the bid amount depends only on a value of keywords for the keyword search and the fraction of the budget already spent.
17. The computer system of claim 15 wherein the processor further executes the algorithm to:
place a bid only when a highest bid among current bidders for the advertising slots are less than the expected value-per-click.
18. The computer system of claim 15 wherein the processor further executes the algorithm to:
calculate an optimal amount of money to bid for one of the advertising slots without utilizing information of other bids and click-through rates for the advertising slots.
19. The computer system of claim 15 wherein the processor further executes the algorithm to:
calculate an amount to bid for one of the advertising slots in order to maximize a return on money budgeted for advertising at online auctions.
20. The computer system of claim 15 wherein the processor further executes the algorithm to:
calculate an amount of money to bid based on profit for winning one of the advertising slots divided by a cost to win the one of the advertising slots.
21. The computer system of claim 15 wherein the processor further executes the algorithm to:
calculate an optimal amount to bid for the advertising slots without utilizing information pertaining to a frequency of how often search queries are executed.
22. The computer system of claim 15, wherein each of the advertising slots has a click-through rate defined as an expected number of clicks on an ad divided by a total number of displays.

Online search engines provide a popular tool for searching keywords over the internet. Search engines and corresponding online auctions globally generate billions of dollars a year in revenue. The results page of a keyword search is therefore an effective place for advertisers to reach an engaged audience.

Using an automated auction mechanism, search engines sell the right to place ads next to keyword results and alleviate the auctioneer from the burden of pricing and placing ads. The intent of the consumer is matched with that of the advertiser through an efficient cost/benefit engine that favors advertisers who offer that which consumers seek.

On the advertising side, companies spend billions of dollars each year in marketing with an increasingly large portion of that money dedicated to search engine marketing. Since such large sums of money are being spent, advertisers strive to strategically bid against competing advertisers while maximizing return for advertising dollars.

FIG. 1 illustrates an exemplary data processing network in accordance with an exemplary embodiment.

FIG. 2 illustrates an exemplary search engine and bid optimization engine in accordance with an exemplary embodiment.

FIG. 3 illustrates an exemplary flow diagram in accordance with an exemplary embodiment.

Exemplary embodiments are directed to systems, methods, and apparatus for budget constrained bidding in online keyword auctions. Exemplary embodiments optimize bids for advertisings bidding in a competitive environment for advertising slots in an online auction.

One embodiment is directed to sponsored search auctions hosted by search engines that allow advertisers to select relevant keywords, allocate budgets to those terms, and bid on different advertising positions for each keyword in a real-time auction against other advertisers. Exemplary embodiments provide optimal bid management of advertising budgets, especially for large advertisers who need to manage thousands of keywords and spend tens of millions on such advertising.

In one embodiment, optimization of bid management is cast as an online (multiple choice) knapsack problem and corresponding algorithms for the online knapsack problem achieve a provably optimal competitive ratio. This allows for the optimization of the bidding process, while optimizing bids to best achieve the goals of the program. To maximize revenue from sponsored search advertising, the bidding strategy can be oblivious (i.e., without knowledge) of other bidder's prices and/or click-through-rates for those positions. Further, bidding algorithms in accordance with exemplary embodiments are evaluated using both synthetic data and real bidding data obtained from online websites.

FIG. 1 illustrates an exemplary system or data processing network 10 in which exemplary embodiments are practiced. The data processing network includes a plurality of computing devices 20 in communication with a network 30 that is in communication with one or more computer systems or servers 40.

For convenience of illustration, only a few computing devices 20 are illustrated. The computing devices include a processor 12, memory 14, and bus 16 interconnecting various components. Exemplary embodiments are not limited to any particular type of computing device or server since various portable and non-portable computers and/or electronic devices may be utilized. Exemplary computing devices include, but are not limited to, computers (portable and non-portable), laptops, notebooks, personal digital assistants (PDAs), tablet PCs, handheld and palm top electronic devices, compact disc players, portable digital video disk players, radios, cellular communication devices (such as cellular telephones), televisions, and other electronic devices and systems whether such devices and systems are portable or non-portable.

The network 30 is not limited to any particular type of network or networks. The network 30, for example, can include one or more of a local area network (LAN), a wide area network (WAN), and/or the internet or intranet, to name a few examples. Further, the computer system 40 is not limited to any particular type of computer or computer system. The computer system 40 may include personal computers, mainframe computers, servers, gateway computers, and application servers, to name a few examples.

Those skilled in the art will appreciate that the computing devices 20 and computer system 40 connect to each other and/or the network 30 with various configurations. Examples of these configurations include, but are not limited to, wireline connections or wireless connections utilizing various media such as modems, cable connections, telephone lines, DSL, satellite, LAN cards, and cellular modems, just to name a few examples. Further, the connections can employ various protocols known to those skilled in the art, such as the Transmission Control Protocol/Internet Protocol (“TCP/IP”) over a number of alternative connection media, such as cellular phone, radio frequency networks, satellite networks, etc. or UDP (User Datagram Protocol) over IP, Frame Relay, ISDN (Integrated Services Digital Network), PSTN (Public Switched Telephone Network), just to name a few examples. Many other types of digital communication networks are also applicable. Such networks include, but are not limited to, a digital telephony network, a digital television network, or a digital cable network, to name a few examples. Further yet, although FIG. 1 shows one exemplary data processing network, exemplary embodiments can utilize various computer/network architectures.

For convenience of illustration, an exemplary embodiment is illustrated in conjunction with a search engine. This illustration, however, is not meant to limit embodiments with search engines. Further, exemplary embodiments do not require a specific search engine. The search engine can be any kind of search engine now known or later developed. For example, exemplary embodiments are used in conjunction with existing search engines (such as PageRank and variations thereof) or search engines developed in the future.

FIG. 2 illustrates an exemplary system 200 that includes a search engine 202 and bid optimization engine 204. As one example, the search engine 202 and bid optimization engine 204 are programs stored in the memory of computer system 40. The search engine enables a user to request information or media content having specific criteria. The request, for example, can be entered as keywords or a query. Upon receiving the query, the search engine 202 retrieves documents, files, or information relevant to the query. The bid optimization engine 204 optimizes bids for advertising slots when the search results are displayed to a user.

For simplicity of illustration, the search engine 202 includes a web crawler 210, a search manager 220, and a ranking algorithm 230 coupled to one or more processors 245 and a database 240. The bid optimization engine 204 includes a bid optimizing algorithm 260 coupled to one or more processors 270. The search engine 202 and bid optimization engine 204 are discussed in connection with the flow diagram 300 of FIG. 3.

According to block 310, the web crawler 210 crawls or searches the network and builds an associated database 240. The web crawler 210 is a program that browses or crawls networks, such as the internet, in a methodical and automated manner in order to collect or retrieve data for storage. For example, the web crawler can keep a copy of all visited web pages and indexes and retain information from the pages. This information is stored in the database 240. Typically, the web crawler traverses from link to link (i.e., visits uniform resource locators, URLs) to gather information and identify hyperlinks in web pages for successive crawling.

One skilled in the art will appreciate that numerous techniques can be used to crawl a network, and exemplary embodiments are not limited to any particular web crawler or any particular technique. As one example, when web pages are encountered, the code comprising each web page (e.g., HyperText Markup Language or HTML code) is parsed to record its links and other page information (example, words, title, description, etc.). A listing is constructed containing an identifier (example, web page identifier) for all links of a web page. Each link is associated with a particular identifier. The listing is sorted using techniques known in the art to distinguish the web pages and respective links. The relationship of links to the parsed web pages and the order of the links within a web site are maintained. After sufficient web sites have been crawled, the recorded or retrieved information is stored in the database 240.

Once the database 240 is created, the search engine 202 can process search queries and provide search results. One skilled in the art will appreciate that numerous techniques can be used to process search queries and provide search results, and exemplary embodiments can be utilized with various techniques.

According to block 320, the bid optimization engine 204 receives information from an advertiser concerning the placement of ads for online auctions. By way of example, this information includes, but is not limited to, one or more of keywords, a budget, and a time period for utilizing the budget.

By way of example, suppose there are N+1 bidders {0, . . . ,N} interested in a single keyword. Bidder 0 is the default advertiser, and he wants to maximize his profit over a period of time T. Let V denote the expected value-per-click for the default advertiser, and he has a budget of B over time period T (e.g. if T is 24 hours, B is the daily budget). Here the budget constraints is a hard constraint, in the sense that once exhausted, it cannot be refilled; budget remaining at the end of the period T is taken away. Once a bidder exhausts his budget, he leaves the auction.

According to block 330, the search manager 220 receives a query (such as keywords) from a user or computing device (such as computing device 20 in FIG. 1). The search manager 220 can perform a multitude of different functions depending on the architecture of the search engine. By way of example and not to limit exemplary embodiments, the search manager 220 tracks user sessions, stores state and session information, receives and responds to search queries, and coordinates the web crawler and ranking algorithm, to name a few examples.

According to block 340, the search engine retrieves and ranks the search query. By way of example, the search engine 202 accesses the database 240 to find or retrieve information that correlates to the query. As an example, the search manager 220 could retrieve from the database 240 all web sites that have a title and description matching keywords in the query. The search manager 220 then initiates the ranking algorithm 230 to score and rank the information (for example, the retrieved web sites) retrieved from the database 240.

According to block 350, the bid optimization, engine 204 optimizes bids on advertising positions against other advertisers. Generally, for each keyword and each time period, exemplary embodiments determine how much money an advertiser should bid to obtain a slot or advertising position on the search results page in order to maximize return on investment (ROI).

In one embodiment, for each user click on its ad, the advertiser obtains revenue that is the expected valise-per-click and a profit that is equal to the difference between revenue and cost. The advertiser (or the agent on behalf of the advertiser) has a budget constraint and would like to maximize either the revenue or the profit. These budget constraints arise out of the ordinary operational constraints of the firm and its interactions with its partners, as well as being a generic feature of keyword auction services themselves.

One embodiment uses competitive analysis to evaluate bidding strategies and compares results with the maximum profit attainable by the omniscient bidder who knows the bids of all the other users ahead of time. This competitive analysis framework has been used in the worst-case analysis of online algorithms and helps to convert the problem of devising bidding strategies to designing algorithms for online knapsack problems. The most general online knapsack problem admits no online algorithms with any non-trivial competitive ratio, the auction scenario suggests a few constraining assumptions that enable exemplary embodiments to provide optimal online algorithms.

The bidding strategies suggested by the online algorithms and in particular the bidding strategy for revenue maximization can be stated as follows:

Here V is the expected value-per-click of the keyword, and ψ(z) is a continuous function of z specified later. Thus the bidding price depends only on the value of the keyword and the fraction of budget spent. The strategy is oblivious in the sense that it does not need to consider other players' bids or how frequently queries arrive.

According to block 360, a determination is made of the results of the bid from advertisers and slots are allocated to the bidders. By way of example, the bidding strategies in accordance with exemplary embodiments are based on the current policy used by search engines to display their ads. For instance, embodiments assume that at each query of a keyword, the highest bidder gets first position, the second highest gets the second position and so on. Moreover, the pricing scheme is the generalized second price scheme where the advertiser in the i-th position pays the bid of the (i+1)-th advertiser whenever the former's ad is clicked on.

In one embodiment, bidders bid on the keyword, and are allowed to change their bids at any moment of time. One assumption is that the bids are very small compared to the budget of Bidder 0. As soon as a query for the keywords arrives, the search engine allocates S slots to bidders as follows: It takes the S highest bids, b1≧b2≧ . . . ≧bS and displays s-th bidder's ad in slot s. Moreover, if any user clicks on the ad at the s-th slot, the search engine charges the s-th bidder a price bs+1, if s<S or a minimum fee bmin (for example, 10¢). Hence, it can be assumed that all the bids are at least bmin.

Each slot s has a click-through rate α(s), which is defined as the expected number of clicks on an ad divided by the total number of impressions (displays). Usually α(s) is a decreasing function of s. Each time his ad in slot s is clicked. Bidder 0 gets a profit of V−bs+1 where bs+1 is the bid of the advertiser in the (s+1)-th slot or bmin if s=S. Suppose the time interval T is discretized into periods {1,2, . . . , T}, such that, within a single time period t, no bidder changes his bid. Let X(t) denote the expected number of queries for the keyword in time period t. Moreover, suppose Bidder 0 can make his bid in time period t after seeing all other bidders' bids. This assumption does not matter much and is mainly for explanation purposes. The problem faced by Bidder 0 is to decide, how much to bid at each time period t in order to maximize its profit while keeping its total cost within its budget.

According to block 370, the ranked information is then displayed to the user or provided to the computing device. Further, the ads are displayed with the search results according to the bid results. The information is displayed, for example, in a hierarchical format with the most relevant information (for example, webpage with the highest score) presented first and the least relevant information (for example, webpage with the lowest score) presented last. The ads are displayed according to the winning bids (i.e., the ad with the highest bid being displayed first, the ad with the next highest bid being displayed second, etc.).

If a modified or new search is requested, according to block 380, then the flow diagram loops back to block 330; otherwise, the flow diagram waits for new search requests 390.

Exemplary embodiments are further described below with headings provided for various sections.

Bidding Strategies and Knapsack Problems

If bids of all the agents are known at each time period, then the best bidding strategy corresponds to solving an offline knapsack problem. To illustrate this concept, discussion begins with a single-slot case where there is only one ad slot. At each time period t, let b(t) be the maximum bid on the keyword among bidders 1 to N. The omniscient bidder knows all the bids {b(t)}Tt=1. To maximize his profit, the omniscient bidder should bid higher that b(t) at those time periods which give him maximum profit and keep his total cost within budget. Winning at time t costs him w(t)=b(t) X(f)α and earns him profit π(t)=(V=b(t))X(t)α, where X(t)α is the number of clicks at time period t. Thus, the omniscient bidder should choose time periods S ⊂ T to maximize π(S)=ΣtεS π(t) satisfying the constraint w(S)=ΣtεS w(t)≦B. This is a standard instance of the classic 0/1 knapsack problem, which is defined as following: Given a knapsack of capacity B and T items of profit and weight (π(t), w(t)) for 1≦t≦T, select a subset of items to maximize the total profit with total weight of selected items bounded by B. For the case of maximizing revenue, it is similar except that π(t)=VX(t)α for each item t. However, for the keyword auction problem, items arrive in an online fashion. At each period t, Bidder 0 has to make a decision of either overbidding b(t) or not. Bidder 0 does not know the future, and furthermore, it could neither recall time instances gone nor revoke its decision of outbidding later. Thus designing a bidding strategy corresponds to designing an algorithm for the online knapsack problem.

The case of multiple slots is captured by the online version of a variant of the classical knapsack problem, the multiple-choice knapsack problem. This topic is more fully discussed below in the section entitled Multiple-Slot Auctions and Online MCKP.

The knapsack problem is a classical problem in operations research and theoretical computer science. For this discussion, two reasonable assumptions are made on the items of the knapsack, which allow development of interesting online algorithms. The assumptions are stated below and justified in the section entitled Single-Slot Auctions and Online Knapsack Problems.

The assumptions are:

Results

In the case of single-slot auctions, the bidding strategy corresponds to online algorithms for the classical 0/1 knapsack problem. One embodiment is an algorithm for the online knapsack problem with competitive ratio ln(U/L)+1, and also a matching lower bound of ln(U/L)+1. Therefore an exemplary embodiment algorithm is provably optimal in the worst case sense. The online knapsack algorithm is translated into a bidding strategy for the single-slot auction. These strategies are oblivious, and thus work even if other bidders' bids were not known. It also implies that the strategy is an approximate dominant strategy in the sense that it is an approximate best response to any bid profile of other bidders.

As discussed below, results are extended to the case of multiple-slot auctions. One embodiment gives a (ln(U/L)+2)-competitive online algorithm for a variant of the classical knapsack problem called the multiple-choice knapsack problem (MCKP). The algorithm is translated for Online-MCKP to bidding strategies for the multiple-slot case in order to obtain both profit-maximizing and revenue-maximizing bidding strategies. The profit maximizing strategy is not oblivious and requires knowledge of other players' bids and also the click-through-rates of all slots. The revenue-maximizing strategy remains oblivious.

The reason why the multiple-slot profit-maximizing strategy turns non-oblivious is subtle: It might be more profitable for an advertiser to appear in a less desirable (lower) slot and pay less than appearing in a higher slot which gives more clicks.

For ease of explanation, discussion is restricted to a single keyword. Exemplary embodiments, though, extend to the general case of multiple keywords and multiple slots per keyword, with V replaced by Vmax, the maximum valuation-per-click among all the keywords.

One embodiment implements these bidding strategies and evaluates them using both synthetic bidding data and real bidding data obtained from an online website. One embodiment modifies the strategy by adding a sniping heuristic, which while maintaining the same theoretical bounds, performs much better empirically. One embodiment also utilizes parameter tuning for the performance of bidding algorithms.

Single-Slot Auctions and Online Knapsack Problems

In this section, an embodiment focuses on single-slot auctions and the corresponding online knapsack problem. One embodiment utilizes algorithms for the online knapsack problem and translates them back into bidding strategies for single-slot keyword auctions. Before presenting the algorithms, an explanation of the previous assumptions is provided.

Recall that the unique item at time period t has a weight w(t) and a profit π(t) where:
w(t)≡b(t)X(t)α, π(t)≡(V−b(t))X(t)α.

For revenue maximization, π(t) corresponds to the revenue of winning the bid, thus π(t)=VX(t)α. Here X(t)α is the number of expected clicks on the displayed ad in time period t. The first assumption of w(t)<<B follows since the budget of the agent is usually much larger than the money spent in small time periods as the bids are small. For the second assumption, separation is made into two cases. In the case of profit maximization, since π(t)/w(t)=V/b(t)−1, it suffices to set U=V/bmin−1. To get a lower bound on the profit-to-weight ratio, it is noted that if b(t) is close to V, then not too much is lost by not bidding at those time intervals. Specifically, if a bid is made of only when b(t)≦V/(1+ε) for some fixed ε>0, the maximum amount of profit lost from not bidding in these time periods is bounded by εB. If ε is small, then the profit loss can be negligible. In other words, one embodiment sets L=ε and ignores all items with efficiency smaller than ε. This results in a maximum profit loss of εB, and it will not affect much the algorithm performance if the total profit of the algorithm is relatively large. In the case of revenue maximization, then π(t)/w(t)=V/b(t). Here it suffices to set U≡V/bmin. For the lower bound with revenue maximization, it is reasonable to assume that the optimum strategy would not bid when b(t) is higher than V. This holds when there are enough items with value-to-cost ratio at least 1 to consume the entire budget. Otherwise, the optimal solution needs to take items which cost more than their value, and the budget seems unnecessarily large. Therefore, assuming that the optimum never bids when b(t) is higher than V, we only need to consider items with efficiency at least 1, i.e., set L=1.

The Online Knapsack Problem

Given an online algorithm A, we say that A is c-competitive (has a competitive ratio of c) if for any input sequence of items σ, we have OPT(σ)≦c A (σ), where A(σ) is the profit of A given σ, and OPT(σ) is the maximum profit obtained by any offline algorithm with the knowledge of σ.

For all items t, w(t)<<B and L≦π(t)/w(t)≦U. Given the lower bound L and upper bound U for item efficiency, it is verifiable that the algorithm which keeps selecting items until the knapsack is full gives a competitive ratio of U/L. Next the algorithm for the online knapsack problem is presented, which achieves an optimal competitive ratio bound ln(U/L)+1. In the remainder of the discussion, e denotes the base of the natural logarithm,

Algorithm: Online KP Threshold

Let Ψ(z)≡(Ue/L)z(L/e). At time t, let z(t) be the fraction of capacity filled, pick element t iff:
π(t)/w(t)≧Ψ(z(t)).

Observe that for z ε[0, z], where z≡1/ln(Ue/L), Ψ(z)≦L, thus the algorithm will pick all items available until z fraction of the knapsack is filled, When z=1, Ψ(z)=U, and since Ψ is strictly increasing, the algorithm will not spend more than its budget.

The above algorithm uses just one threshold function to select items, and the threshold function is a specialized exponential function of its capacity filled.

As a theorem, for any input sequence σ, if A(σ) is the profit obtained by ONLINE-KP-THRESHOLD and OPT (σ) is the maximum profit that can be attained, then:
OPT(π)≦A(σ)(ln(U/L)+1).

In other words, the above algorithm has a competitive ratio of ln(U/L)+1.

Bidding Strategies for Single-Slot Auctions

We now construct the bidding strategies suggested by the algorithm ONLINE-KP-THRESHOLD. Consider the profit-maximizing case first. An assumption is made that b(t)≦V/(1+ε) for some ε. Set U=V/bmin−1 and L=ε. At time t, suppose Bidder 0 spent z(t) fraction of its budget. This corresponds to the fact that z(t) fraction of the knapsack is filled. As per the algorithm, Bidder 0 must win the bid if and only if the efficiency of the next bid is at least Ψ(z(t)). That is, Bidder 0 must bid higher than b(t) iff(V−b(t))/b(t)≧Ψ(z(t)) or equivalently, b(t)≦V/(1+Ψ(z(t))), which means bidding V/(1+Ψ(z(t))) suffices. The bidding strategy is stated below:

Bidding Strategy: PROFIT-MAXIMIZING SINGLE-SLOT

Fix ε>0. Let Ψ(z)≡(Ue/ε)z (ε/e).

At time t, if fraction of budget spent is z(t), then bid
b0(t)=V/(1+Σ(z(t))).

The above bidding strategy for profit-maximization single-slot auctions has the following performance guarantee: For any fixed ε>0, let Profit denote the profit obtained by the profit-maximizing bidding strategy, then
OPT≦εB+ln(e(V−bmin)/(ε bmin))·Profit
where bmin is the minimum bid required of the system and OPT is the maximum profit obtained by the omniscient bidder.

Similarly, using U=V/bmin and L=1, the following revenue-maximizing bidding strategy is obtained:

Bidding Strategy: REVENUE-MAXIMIZING SINGLE-SLOT

At time t, if fraction of budget spent is z(t), then bid
b0(t)=V/Ψ(z(t)).

Here, let Revenue be the revenue obtained by the revenue-maximizing bidding strategy and OPT be the maximum revenue obtained by the omniscient bidder. Assuming that OPT does not contain any item t with b(t)>V, then
OPT≦ln(eV/bmin)·Revenue
where bmin is the minimum bid requirement of the auction system.

Multiple-Slot Auctions and Online MCKP

Exemplary embodiments extend to the case of multiple slots. The strategy in the multiple-slot case corresponds to the online multiple-choice knapsack problem. The multiple-choice knapsack problem (MCKP) is the generalization of the knapsack problem: Given a knapsack of capacity B, and T sets of items N1, N2, . . . NT, the goal is to choose at most one item from each set to maximize value and not exceed the knapsack capacity. In the online version, the sets come online and we need to make our decision on the fly. Items once picked cannot be disposed, and sets cannot be recalled.

Next it is shown how to model the multiple-slot keyword auction problem into Online MCKP. Once again, the budget corresponds to the capacity of the knapsack. At each time period t, let b1(t)≧b2(t)≧ . . . ≧bS(t) be the S highest bids. To win slot s, bidder 0 needs to bid bs(t). This incurs a cost ws(t) and a profit πS(t) where
ws(t)≡bs(t)X(t)α(s), πS(t)≡(V−bs(t))X(t)α(s),
and α(s) is the click-through-rate of slot s. The S slots at each time period correspond to the set arriving at time t. Since Bidder 0 can win at most one slot at each time period, the omniscient bidder needs to solve the multiple-choice knapsack problem while Bidder 0 needs to solve the online multiple-choice knapsack problem. Once again, assume that (1) ws(t)<<B and (2) L≦πs(t)/ws(t)≦U for all s, t.

Algorithm for Online MCKP

The algorithm for online-MCKP is similar to that for Online-KP, which is stated below:

Algorithm ONLINE-MCKP-THRESHOLD

Let Ψ(z)≡(Ue/L)z(L/e),

At time t, let z(t) denote the fraction of capacity filled,

E t = { s N 1 | π s ( t ) w s ( t ) Ψ ( z ( t ) ) }

pick element s ε E1 with maximum πs(t).

This algorithm has a competitive ratio of ln(U/L)+2.

Bidding Strategies for Multiple-Slot Auctions

For multiple-slot auctions, consideration is given to the profit-maximizing case first. As in the single-slot case, we only consider slots with bs(t)≦V/(1+ε) for all s,t. This implies that the efficiency of each bid is upper bounded by U=V/bmin−1 and lower bounded by ε. So the following bidding strategy is obtained:

Bidding Strategy PROFIT-MAXIMIZING MULTIPLE-SLOT

Fix ε>0. Let Ψ(z)≡(Ue/ε)z(ε/e).

At time t, let z(t) be fraction of budget spent,
Et≡{s|bs(t)≦V/(1+Ψ(z(t)))},

bid bs(t) where s=arg maxsεEt(V−bs(t))α(s).

Note that the bidding strategy is still oblivious of X(t), however it now requires knowing the bids bs(t) and also α(s). The above bidding strategy has a performance guarantee, stated as the following theorem: Let Profit denote the profit obtained by our profit-maximizing bidding strategy. Then for any ε>0,
OPT≦εB+(ln(V/ε bmin)+2)Profit
where bmin is the minimum bid required of the system and OPT is the maximum profit obtained by the omniscient bidder.

For revenue maximization, the bidding strategy is similar to profit maximization except that it can actually find the slot s in time t to maximize the revenue. This is because, the revenue obtained on bidding bs(t) is VX(t)α(s). Given that α(s) is a decreasing function, maximizing VX(t)α(s) is equivalent to minimizing s, i.e., to find the rank s as low as possible. Since the efficiency condition imposes that the winning slot has bs(t)≦V/Ψ(z(t)), the bid should be equal to this. Thus a bidding strategy exists for revenue-maximizing multiple-slot auctions which are the same as that for single-slot auctions, which has the desirable property of obliviousness.

Strategy Modification

Embodiments can be modified to have improved empirical performance. As a negative, the strategy (which is described in the following) does not remain oblivious any more: it requires knowledge of X(t), the traffic function and also α, the click through-rate of the slot.

A weakness can occur if the strategy is unaware of the time remaining in the auction. It stops overbidding too early, missing out possible advantageous bids later on. Thus a potential performance improvement is snipping towards the end of the auction. At time t, suppose the fraction of budget remaining is y(t)=1−z(t). Moreover assume future click traffic X(τ)α for τ>t is known. With this assumption, a modified bid strategy is:

Bidding Strategy: PROFIT-MAXIMIZING SINGLE-SLOT WITH SNIPING

Fix ε>0. Let Ψ(z)≡(Ue/tCS)z(tCS/e).

At time t, if fraction of budget spent is z(t), bid

max { V 1 + Ψ ( z ( t ) ) , min { V , ( 1 - z ( t ) ) B t T X ( τ ) α τ } } .

In one embodiment, this strategy performs better than the original strategy, although it requires the knowledge of X(t) and α.

The above sniping heuristic can be generalized to the multiple-slot case and it is formally described below:

Bidding Strategy: Multiple-Slot with Sniping.

At time t, let z(t) denote fraction of budget spent ρ=Ψz(t)).

For each slot s,

if b s ( t ) ( 1 - z ( t ) ) B α ( s ) t T X ( τ ) τ , ρ = min { ρ , π s ( t ) w s ( t ) } E t = { s | π s ( t ) w s ( t ) ρ }

bid bs(t) where s ε E, with max πs(t).

Exemplary embodiments are thus directed to budget constrained bidding strategies in keyword auctions. Embodiments include a single keyword case and strategies for both single-slot and multiple-slot cases. In the case of single-slot auctions, one embodiment provides oblivious strategies for both profit and revenue maximizations. The obliviousness is a desirable property in any bidding strategy. In the multiple-slot case, one embodiment has a strategy for profit maximization wherein it is no longer oblivious and requires knowledge of the various bids and click-through-rates of slots. However, for revenue maximization, it still remains oblivious.

Exemplary embodiments can be extended to the general case where there are multiple keywords and each keyword has multiple positions. The competitive ratio would now have V replaced by Vmax, where Vmax is the maximum valuation for all keywords.

In one exemplary embodiment, one or more blocks in the flow diagrams are automated. In other words, apparatus, systems, and methods occur automatically. As used herein, the terms “automated” or “automatically” (and like variations thereof) mean controlled operation of an apparatus, system, and/or process using computers and/or mechanical/electrical devices without the necessity of human intervention, observation, effort and/or decision.

The flow diagrams in accordance with exemplary embodiments are provided as examples and should not be construed to limit other embodiments within the scope of embodiments. For instance, the blocks should not be construed as steps that must proceed in a particular order. Additional blocks/steps may be added, some blocks/steps removed, or the order of the blocks/steps altered and still be within the scope of the invention. Further, blocks within different figures can be added to or exchanged with other blocks in other figures. Further yet, specific numerical data values (such as specific quantities, numbers, categories, etc.) or other specific information should be interpreted as illustrative for discussing exemplary embodiments. Such specific information is not provided to limit the exemplary embodiments.

Various exemplary embodiments are implemented as one or more computer software programs. The software is implemented as one or more modules (also referred to as code subroutines, or “objects” in object-oriented programming). The location of the software (whether on the client computer or elsewhere) will differ for the various alternative embodiments. The software programming code, for example, can be accessed by the processor of the computing device 20 and computer system 40 from long-term storage media of some type, such as a CD-ROM drive or hard drive. The software programming code can be embodied or stored on any of a variety of known media for use with a data processing system or in any memory device such as semiconductor, magnetic and optical devices, including a disk, hard drive, CD-ROM, ROM, etc. The code can be distributed on such media or can be distributed to users from the memory or storage of one computer system over a network of some type to other computer systems for use by users of such other systems. Alternatively, the programming code can be embodied in the memory and accessed by the processor using the bus. The techniques and methods for embodying software programming code in memory, on physical media, and/or distributing software code via networks are well known and will not be further discussed herein.

The above discussion is meant to be illustrative of the principles and various exemplary embodiments. Numerous variations and modifications will become apparent to those skilled in the art once the above disclosure is fully appreciated. It is intended that the following claims be interpreted to embrace all such variations and modifications.

Lukose, Rajan, Zhou, Yunhong, Chakrabarty, Deeparnab

Patent Priority Assignee Title
10607248, Apr 18 2017 Time-consuming sale process
11037228, Feb 22 2016 EL TORO COM, LLC Automated bidding on auctioned content
11449902, Feb 22 2016 EL TORO.COM, LLC Automated submission for solicited application slots
11790439, Feb 22 2016 EL TORO.COM, LLC Automated bidding on auctioned content
Patent Priority Assignee Title
7035812, May 28 1999 R2 SOLUTIONS LLC System and method for enabling multi-element bidding for influencing a position on a search result list generated by a computer network search engine
20020156667,
20040088241,
20070130004,
///////////////////////
Executed onAssignorAssigneeConveyanceFrameReelDoc
Jul 30 2007Hewlett-Packard Development Company, L.P.(assignment on the face of the patent)
Jul 30 2007LUKOSE, RAJANHewlett-Packard Development Company, LPASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0196090185 pdf
Jul 30 2007CHAKRABARTY, DEEPARNABHewlett-Packard Development Company, LPASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0196090185 pdf
Jul 30 2007ZHOU, YUNHONGHewlett-Packard Development Company, LPASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0196090185 pdf
Oct 27 2015HEWLETT-PACKARD DEVELOPMENT COMPANY, L P Hewlett Packard Enterprise Development LPASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0370790001 pdf
Apr 05 2017Hewlett Packard Enterprise Development LPENTIT SOFTWARE LLCASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0427460130 pdf
Sep 01 2017MICRO FOCUS US , INC JPMORGAN CHASE BANK, N A SECURITY INTEREST SEE DOCUMENT FOR DETAILS 0441830718 pdf
Sep 01 2017Borland Software CorporationJPMORGAN CHASE BANK, N A SECURITY INTEREST SEE DOCUMENT FOR DETAILS 0441830718 pdf
Sep 01 2017Attachmate CorporationJPMORGAN CHASE BANK, N A SECURITY INTEREST SEE DOCUMENT FOR DETAILS 0441830718 pdf
Sep 01 2017NetIQ CorporationJPMORGAN CHASE BANK, N A SECURITY INTEREST SEE DOCUMENT FOR DETAILS 0441830718 pdf
Sep 01 2017SERENA SOFTWARE, INC JPMORGAN CHASE BANK, N A SECURITY INTEREST SEE DOCUMENT FOR DETAILS 0441830718 pdf
Sep 01 2017ARCSIGHT, LLCJPMORGAN CHASE BANK, N A SECURITY INTEREST SEE DOCUMENT FOR DETAILS 0441830718 pdf
Sep 01 2017ENTIT SOFTWARE LLCJPMORGAN CHASE BANK, N A SECURITY INTEREST SEE DOCUMENT FOR DETAILS 0441830718 pdf
Sep 01 2017MICRO FOCUS SOFTWARE, INC JPMORGAN CHASE BANK, N A SECURITY INTEREST SEE DOCUMENT FOR DETAILS 0441830718 pdf
May 23 2019ENTIT SOFTWARE LLCMICRO FOCUS LLCCHANGE OF NAME SEE DOCUMENT FOR DETAILS 0500040001 pdf
Jan 31 2023JPMORGAN CHASE BANK, N A NetIQ CorporationRELEASE OF SECURITY INTEREST REEL FRAME 044183 07180627460399 pdf
Jan 31 2023JPMORGAN CHASE BANK, N A MICRO FOCUS SOFTWARE INC F K A NOVELL, INC RELEASE OF SECURITY INTEREST REEL FRAME 044183 07180627460399 pdf
Jan 31 2023JPMORGAN CHASE BANK, N A Attachmate CorporationRELEASE OF SECURITY INTEREST REEL FRAME 044183 07180627460399 pdf
Jan 31 2023JPMORGAN CHASE BANK, N A SERENA SOFTWARE, INC RELEASE OF SECURITY INTEREST REEL FRAME 044183 07180627460399 pdf
Jan 31 2023JPMORGAN CHASE BANK, N A MICRO FOCUS US , INC RELEASE OF SECURITY INTEREST REEL FRAME 044183 07180627460399 pdf
Jan 31 2023JPMORGAN CHASE BANK, N A Borland Software CorporationRELEASE OF SECURITY INTEREST REEL FRAME 044183 07180627460399 pdf
Jan 31 2023JPMORGAN CHASE BANK, N A MICRO FOCUS LLC F K A ENTIT SOFTWARE LLC RELEASE OF SECURITY INTEREST REEL FRAME 044183 07180627460399 pdf
Jan 31 2023JPMORGAN CHASE BANK, N A MICRO FOCUS LLC F K A ENTIT SOFTWARE LLC RELEASE OF SECURITY INTEREST REEL FRAME 044183 05770635600001 pdf
Date Maintenance Fee Events
Mar 25 2015M1551: Payment of Maintenance Fee, 4th Year, Large Entity.
Jun 17 2019REM: Maintenance Fee Reminder Mailed.
Dec 02 2019EXP: Patent Expired for Failure to Pay Maintenance Fees.


Date Maintenance Schedule
Oct 25 20144 years fee payment window open
Apr 25 20156 months grace period start (w surcharge)
Oct 25 2015patent expiry (for year 4)
Oct 25 20172 years to revive unintentionally abandoned end. (for year 4)
Oct 25 20188 years fee payment window open
Apr 25 20196 months grace period start (w surcharge)
Oct 25 2019patent expiry (for year 8)
Oct 25 20212 years to revive unintentionally abandoned end. (for year 8)
Oct 25 202212 years fee payment window open
Apr 25 20236 months grace period start (w surcharge)
Oct 25 2023patent expiry (for year 12)
Oct 25 20252 years to revive unintentionally abandoned end. (for year 12)