This invention is generally related to advertising. This invention is more specifically related to controlling the revenue generated by an advertising campaign.
Since the early 1990's, the number of people using the Internet has grown at a substantial rate. As more users take advantage of the Internet, they generate higher and higher volumes of traffic over the Internet. As the benefits of commercializing the Internet can be tremendous, businesses increasingly take advantage of this traffic by advertising their products or services on-line. Such advertising may appear in the form of advertisements on websites or digital television or on cellular telephones, which are comparable to rented billboard space on highways and in cities or commercials broadcasted during television or radio programs.
Before users browse to a particular web page on the Internet, there is much unknown to the advertisers that might advertise on that page and to advertising managers that may conduct advertising campaigns on the advertiser's behalf. Neither the advertisers nor the advertising managers know how many users will browse to particular web pages, and therefore do not know the volume of advertisements that will be viewed (the number of “impressions”). Further, is it not known how many users will select or “click” on each advertisement or if “actions”, e.g., sales or signing up new users, will result from each impression of an advertisement or what the ratio of clicks to actions may be.
Advertisers may be interested in impressions (e.g., if they are trying to increase awareness of a brand), clicks (e.g., if they are trying to provide more information about a product), or actions (e.g., if they are trying to make sales or get new users to sign up for services). Advertisers may be willing to pay for impressions, clicks, or actions, regardless of their interests. Therefore, in addition to wanting to predict impressions, clicks, and actions, one may want to predict other data related to an advertising campaign such as, for example, the ratio of impressions to clicks or actions or the ratio of clicks to actions. The predictions of such data related to advertising on the Internet may help advertisers, and the advertising managers placing advertisements on their behalf, assess the potential value of an advertisement.
In accordance with the invention, a system, apparatus, and method are presented for shaping a reference signal from an advertising campaign that allocates advertisements in digital or online advertising, the method comprising receiving a reference signal; sensing a volume of revenue generating events resulting from the advertising campaign; shaping the received reference signal to adjust for variations in the volume of revenue generating events conducted by the advertising campaign; and using the shaped reference signal to determine a control signal to control the allocation of advertisements.
In some embodiments a system, apparatus and method are presented for shaping a reference signal for an online or digital advertising campaign that allocates advertisements, the method comprising: receiving a reference signal; receiving a predicted pattern for a volume of revenue generating events conducted by the advertising campaign; providing parameters representing a volume of revenue generating events conducted by the advertising campaign value; shaping the received reference signal to adjust for the predicted pattern and the volume of revenue generating events conducted by the advertising campaign; and using the shaped reference signal to determine a control signal to control the allocation of advertisements.
Additional features and advantages of the invention will be set forth in part in the description which follows, and in part will be obvious from the description, or may be learned by practice of the invention. The features and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the appended claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory only and are not restrictive of the invention, as claimed.
The accompanying drawings, which are incorporated in and constitute a part of this specification, illustrate embodiments of the invention and together with the description, serve to explain principles of the invention.
Reference will now be made in detail to the present embodiments of the invention, examples of which are illustrated in the accompanying drawings. Wherever possible, the same reference numbers will be used throughout the drawings to refer to the same or like parts.
Typically, a digital or online advertising campaign consists of an advertiser designing an advertising campaign for one or more products or services in order to target the campaign to individuals interested in the product or service. Generally, there are three events that occur in relation to viewing an advertising campaign. The first is an “impression”. This occurs when an individual views an advertisement, and its cost to the advertiser is assessed as “cost per mille” (CPM) or cost per 1,000 impressions. The second is a “click,” which occurs when an individual clicks on an advertisement. The cost to the advertiser for a click is assessed as a “cost per click” (CPC). The third is an “action,” which occurs when an individual makes a purchase as a result of viewing the advertisement. Unlike an impression or click, which can be measured almost instantaneously, an action may occur at some time after an impression or click. The time interval between the impression or click and the action is called lag. The lag for different advertised products or services can vary significantly. For example, the lag for an automobile purchase will typically be longer than the lag for a DVD purchase. The cost of an action is assessed as “cost per action” (CPA).
In practice, an advertising manager places advertisements from at least one advertiser in a digital or online medium. Revenue is generated for the manager, for example, by measuring the volume of impressions, clicks or actions resulting from the placed advertisements and charging the advertiser the appropriate cost based on the CPM, CPC and CPA respectively.
Control systems 110 and 120 may regulate campaign activities by sending one or more control signals which may be determined based on information about those activities. The sent control signals may be based on feedback information. For the sake of clarity, the control system for revenue delivery control will now be discussed at the campaign level.
Sensor 330 may fetch data from campaign A plant 210 data flow in real time. Sensor 330 may then compute and send measurements to both controller 310 and plant estimator 320. For example, sensor 330 may output volume data relating to the number of impressions, clicks and/or actions recorded in a given period and the revenue that is generated during a given period.
Each advertising campaign can be described by a mathematical model defined by one or more plant parameters, representing certain aspects of the actual behavior of the advertising campaign. Plant estimator 320 may be configured to estimate unknown plant parameters. These plant parameter estimates may be based on plant input and output information. The plant input and output information may be reported to plant estimator 320 by sensor 330. Plant estimator 320 receives a control signal from controller 310, which may, for example, be an enhancement factor, an adjustment to a bid price, or an adjustment to a desired allocation of an advertising campaign. An output provided by plant estimator 320 is a set of plant parameters, generally denoted herein as plant parameter {circumflex over (θ)}, that can be used to estimate volume and/or revenue data of an advertising campaign. More generally, the set of plant parameters may contain an arbitrary number of parameters that capture various characteristics of the underlying plant. Further, the symbol “^” is included above “θ” to indicate that the plant parameters output by plant estimator 320 are themselves estimates. The nature and use of such plant parameters is described more fully below.
Controller 310 receives the above described reference signal that, in the present embodiment directed to revenue control, represents, for example, a desired revenue, a desired impression-to-click probability, a desired impression-to-conversion probability, a desired click-to-conversion probability, a desired relative revenue generated from different segments of system 200, a desired cumulative revenue, or a desired marginal revenue for the advertising manager. Controller 310 determines in accordance with the various inputs it receives and in accordance with the mathematical model, how to control advertising campaign A plant 210, represented by a control signal output from controller 310 to campaign A plant 210.
Pre-shape filter 410 may be configured to shape the received reference signal, e.g., desired revenue signal, to reflect changes in the inventory of available revenue producing events, and provide a correspondingly shaped reference signal 415. Feed-forward controller 420 is coupled to receive plant parameter {circumflex over (θ)} and may be configured to compute a pre-emptive control action based on changes in one or more plant parameters or the slope of the reference signal. Plant gain is defined as a relative impact on the plant when the control signal is changed. For example and without limitation, if the plant gain between control signal and revenue at some point is g and the control signal is increased by some amount d, then the revenue is expected to increase by approximately g multiplied by d. Plant gain estimator 430 is also coupled to receive plant parameter {circumflex over (θ)} and is configured to estimate the plant gain from the control signal output by controller 310 and its associated revenue. Feedback controller 440 is configured to determine a normalized incremental control action for a time period based on the shaped reference signal and a predicted cumulative revenue for the advertising campaign and generate a corresponding control signal. Integration and anti-windup filter 450 is configured to act to adjust and integrate the control signal generated by feedback controller 440 in accordance with the estimated plant gain from plant gain estimator 430. Revenue predictor 460 is coupled to receive output from sensor 330 and the plant parameter {circumflex over (θ)} and is configured to act to generate a prediction of the revenue generated by an advertising campaign during a time period.
Plant estimator 320 may provide reliable estimates for unknown parameters to feedback controller 440 so that controller 310 may predict the system behavior and tune its gains adaptively to achieve desired performance.
Control signals provided by controller 310 may be used to adjust the actual behavior of an advertising campaign so that it more closely matches a desired behavior or reference signal, e.g., desired revenue, of the advertising campaign. Such control signals may act to accelerate or decelerate the placement of advertisements for a given campaign depending on the behavior of the actual advertising campaign. Since different campaigns may have different behaviors, the control signals associated with individual campaigns may vary from one campaign to another. Furthermore, the control signals associated with a campaign may also vary with time.
Further details regarding configuration of pre-shape filter 410 are described next. If an advertising campaign measures impressions, then its associated plant parameters correspond to impression volume parameters. If the campaign measures the number of clicks, then its associated plant parameters correspond to click volume parameters. Additionally, if the campaign measures actions, then its associated plant parameters are of three types: 1) action volume parameters, 2) impression volume parameters, and 3) impression-to-action probability parameters.
When designing an advertising campaign, an advertiser may define certain desired behaviors for the campaign. Such desired behaviors may include the overall cost of the campaign, how much money to spend on a specific day, what time of day to show the advertisements, etc. Such specific desired behaviors are formulated by the advertising manager into a reference signal which can be defined for a variety of intervals. For example, a reference signal may define the advertiser's desired revenue, a desired impression-to-click probability, a desired impression-to-conversion probability, a desired click-to-conversion probability, desired relative revenue generated from different segments of system 200, desired cumulative revenue, or a desired marginal revenue spending over the course of a 24 hour or week long period. This reference signal, corresponds to the signal shown as “Reference Signal” in
Although the reference signal may represent the desired behavior for a campaign, it is difficult to meet all of an advertiser's objectives by matching the behavior of a campaign exactly to its reference signal. This is at least due to periodic behaviors that affect the occurrence of revenue producing events. For example, the time of day affects the number of users viewing a digital or online media because people in a given geographical region do not view the Internet uniformly at all hours of the day. As would be expected, for example, viewing is greatest during the waking hours. Thus the time of day affects the number of available revenue producing events an advertiser can obtain during a given time period.
A desired cumulative revenue rrefcum(k) for a campaign may be defined as a reference signal and, for example, be provided as a fixed ramp 600 as is shown in
It may be preferable for controller 310 to take into account fluctuations in the volume of Internet traffic and cause a campaign to generate larger revenue during hours when the availability of revenue producing events is large. In other words, revenue generation may be more profitable when the reference signal is not followed on an incremental basis. For example, it may be preferable for the reference signal to be tracked on a moving average or periodic basis.
Additionally and more generally, the reference signal need not be cumulative. A non-cumulative reference signal, also referred to herein as a marginal reference signal, may instead be defined. An example of such a marginal reference signal would be one that represents a desired daily revenue.
Referring again to
Pre-shape filter 410 may be used to shape the provided reference signal such that the shaped reference signal results in controller 310 providing a control signal with the smallest possible time-of-day behavior variation to track the provided reference signal on a moving average basis for a period of time, for example, a 24 hour period of time. If the campaign is desired to actually follow the provided reference signal on an increment-by-increment basis, then it may be preferable for pre-shape filter 410 not to shape the provided reference signal. Also, pre-shape filter 410 may be set so that it does not shape the provided reference signal when provided plant parameter θ is unreliable. This unreliability can occur, for example, in the initial stage of a campaign when little is known about the actual behavior of a campaign.
A model of the campaign revenue r(k) is set forth below in equation (1):
r(k)=η(k)wdaypart(k)eβ
In equation (1) η(k) is the CPU rate ($ per event) and ε(k) is a stationary and mean zero stochastic process wdaypart(k) is a binary variable capturing any day parting and has the effect of setting revenue r(k) to zero for any arbitrary hour k (if scheduling of advertisements is allowed in hour k, then wdaypart(k)=1, otherwise wdaypart(k)=0) . For example, some advertisers may wish their advertisement to be shown only on certain hours or days. For example, they may wish the advertisement to be shown only on Wednesday-Sunday between 2 and 8 pm. A campaign subject to this type of constraint may be called a ‘day-parted’ campaign. The terms β0, β1, φ1, and γ in equation (1) are plant parameters associated with revenue generating events (impressions, clicks, or conversions). More particularly, the term β0 represents an average volume level over time, the term βi, represents relative swings in volume throughout a time period, e.g., a day, the term φ1 represents a phase of a time-of-day pattern, and the term γ represents how the volume relates to the control signal. The value of γ may, for example, indicate how much the volume is likely to increase as the control signal is increased, and may differ from one campaign to another. The term u′(k)γ in equation (1) is the control signal output by controller 310 at time k. Additionally, while the present embodiment utilizes time increments in hours, embodiments consistent with the invention may be practiced with any desired time increment, e.g., seconds, minutes, days, etc.
By introducing the simplifying notations indicated below, equation (1) can be rewritten as:
r(k)=wdaypart(k)s(k|θ)g(u′(k)|θ) (2)
where
θ=[β0,β1,φ1,γ]T;
s(k|θ)=η(k)eβ
g(u′(k)|θ)=u′(k)γ;
The term g is introduced as a general notation of the relative impact on the volume when the control signal changes, i.e., the sensitivity of the revenue in response to changes in the control signal. The term T is a mathematical notation for ‘transpose’. The | between (k) and θ, for example, represents that the value of θ is based upon the value of (k). Thus, the term s(k|θ)) is intended to mean the function s evaluated at time point k conditioned on the knowledge of the parameter θ. Thus, equation (2) is a more general model of what is shown in equation (1). That is, equation (1) is an example of the model represented by equation (2). There are many other examples besides the example represented by equation 1, of the model of equation (2), such as examples that incorporate day-of-week periodicities and /or that incorporate refined time-of-day patterns. The term s represents seasonality. Seasonality as used herein is a generalization of time-of-day pattern. Examples of seasonality are time-of-day, day-of-week, day-of-month, and annual patterns. Note that when ε is small, s(k|θ) is approximately equal to s(k+24|θ) in the present embodiment.
The term rcum(k) is the cumulated value of r(k) and can be calculated as follows:
rcum(k)=rcum(k−1)+wdaypart(k)s(k|θ)g(u′(k|θ). (3)
Pre-shape filter 410 may be designed to shape the reference signal with the seasonality of s(k|θ). When θ is unknown, an estimate, {circumflex over (θ)}(k), can be used to approximate s(k|θ).
Pre-shape filter 410 can determine a pre-shaped reference signal in three steps. First, a basic shaped reference signal rrefcum,1(k) is determined. This signal may be subject to drift and bias. For example,
To obtain the basic shaped reference signal rrefcum,1(k), the periodicity of r(k) is introduced into the calculation of rrefcum(k)−rrefcum(k−1) so that:
rrefcum,1(k)−rrefcum,1(k−1)=c·wdaypart(k)s(k|{circumflex over (θ)}(k))rrefcum(k)−rrefcum(k−1) (4)
where c is introduced as part of the derivation of the final estimator. It may be used to ensure that the shaped reference on average equals the original reference signal. The term c is chosen such that:
Combining equations 4 and 5 yields:
and solving for c results in
When future values of rrefcum(k) and {circumflex over (θ)}(k) are unknown, it may be assumed that rrefcum(k+i) follows a fixed ramp and that {circumflex over (θ)}(k+i)={circumflex over (θ)}(k) for i=1, 2, . . . . , 23. For cases where this assumption is frequently violated, it may be desirable for the reference signal to not be pre-shaped. When rrefcum(k+i)−rrefcum(k−1+i) equals a constant, it is possible to cancel this factor from equation (7) and obtain the following:
Substituting this expression for c into equation (4) yields:
Equation (9) defines a recursive update scheme for rrefcum,1(k) that is initialized by using the first available rrefcum(k0), where k0 is the first hour period for which rrefcum is provided. As used herein, a recursive update scheme is a scheme that processes new data with the same computational effort independent of how much data has been previously processed. As previously mentioned, the basic shaped reference signal rrefcum,1(k) may be subject to drift away from rrefcum,1(k) because s(k|{circumflex over (θ)}(k)) is an approximation of s(k|θ(k)). Consequently, rrefcum,1(k) may not be a satisfactory choice for final shaped reference signal 415.
Drift may be avoided by re-initializing the shaped reference signal periodically or as needed. Periodic re-initialization may be accomplished according to the following scheme which, by way of example, uses a 24 hour long period. This scheme can be used instead of equation (9) to determine the drift free reference signal rrefcum,2(k):
Equation (10) is a recursive update formula in which rrefcum,2(k) is conveniently initialized by the first available rrefcum(k0), where k0 is the first hour period for which rrefcum is provided. The term rrefcum,2(k) may not be an unbiased approximation of rrefcum(k) when, for example, rrefcum,2(k)−rrefcum(k) is not equal to zero.
The bias of a reference signal may be adjusted by estimating the bias bbiasshaped in a separate filter that may be parallel wherein the filter may not rely on an accurate estimate of φ1 or any other plant parameter. To accomplish this, the following first order linear filter may be used, which in conjunction with the scheme for computing the final shaped reference signal rrefcum,shaped(k) is given by:
{circumflex over (b)}biasshaped(k)=λbiasshaped{circumflex over (b)}biasshaped(k−1)+(1−λbiasshaped)(rrefcum,2(k)−rrefcum(k)) (11)
rrefcum,shaped(k)=rrefcum,2(k)−{circumflex over (b)}biasshaped(k), (12)
where {circumflex over (b)}biasshaped (k) is the estimated bias, λbiasshaped is a bias estimation forgetting factor and rrefcum,2(k) is the biased shaped reference signal of equation (10). The value of the parameter λbiasshaped may be in the interval 0 to 1 and the relevance of its value is in the speed in which to estimate the bias. As λbiasshaped approaches 1 the estimate becomes slower but more robust. For example, setting λbiasshaped=0.95 may provide a desirable result.
With no prior information about plant 100, an initial estimate of the bias may be zero; hence set {circumflex over (b)}biasshaped(k0)=0, where k0 is the first time period for which the bias is computed. Combining equations (10) through (12) yields:
{circumflex over (b)}
bias
shaped(k)=λbiasshaped{circumflex over (b)}biasshaped(k−1)+(1−λbiasshaped)(rrefcum,2(k)−rrefcum(k)) (14)
rrefcm,shaped(k)=rrefcum,2(k)−{circumflex over (b)}biasshaped(k) (15)
Finally, replacing s(k+i|{circumflex over (θ)}(k)) with η(k+i)exp{circumflex over (β)}0+{circumflex over (β)}1sin(2π(k+i)/24+{circumflex over (φ)}1)+ε(k+i), and using the approximation ε(k+i)=0 and the assumption η(k+i)=η(k) for i=1, . . . , 23 yields:
{circumflex over (b)}
bias
shaped(k)=λbiasshaped{circumflex over (b)}biasshaped(−1)+(1−λbiasshaped)(rrefcm,2(k)−rrefcm(k)) (17)
rrefcum,shaped(k)=rrefcum,2(k)−{circumflex over (b)}biasshaped(k) (18)
Following the above calculation, pre-shape filter 410 generates final shaped reference signal 415 (step 530). Final shaped reference signal 415 may then be transmitted by pre-shape filter 410 to another component within controller 310, for example feedback controller 440.
The system elements are detailed below, according to one or more embodiments of the present invention. The advertisement generating component 902 can be a machine such as a personal computer with picture making software to create advertisements suitable for display on websites. The ad-server 904 can be one or more ad-server computers capable of receiving the advertisements and the instructions about where and when to serve them and carrying out these instructions. Ad server may function as an advertising manager as discussed herein. Network 901 may include a website that has agreed, possibly in return for payment, to display the advertisements served by the ad-servers or advertising managers. Network 901 may also include one or more users that view the websites and that are therefore also viewing the advertisements. The click/impression log analyzer 910 is a click/impression analyzer used to determine the results of the showing(s) of the advertisements. The database 912 can be a database used to store the results of the showing(s) of the advertisements. The computer 914 can be a control-related computer used to handle the scheduling of the ads and to provide instructions to the ad-servers, and or implemented consistent with this invention.
Other embodiments of the invention will be apparent to those skilled in the art from consideration of the specification and practice of the invention disclosed herein. It is intended that the specification and examples be considered as exemplary only, with a true scope and spirit of the invention being indicated by the following claims.
Number | Name | Date | Kind |
---|---|---|---|
5227874 | Von Kohorn | Jul 1993 | A |
5446919 | Wilkins | Aug 1995 | A |
6006197 | d'Eon et al. | Dec 1999 | A |
7039599 | Merriman et al. | May 2006 | B2 |
7212974 | Kilbank | May 2007 | B2 |
20030033405 | Perdon et al. | Feb 2003 | A1 |
20030225738 | Ternoey et al. | Dec 2003 | A1 |
20050086605 | Ferrer et al. | Apr 2005 | A1 |
20050096950 | Caplan et al. | May 2005 | A1 |
20060085419 | Rosen | Apr 2006 | A1 |
20060122879 | O'Kelley | Jun 2006 | A1 |
20060224447 | Koningstein | Oct 2006 | A1 |
20070027754 | Collins et al. | Feb 2007 | A1 |
20070118425 | Yruski et al. | May 2007 | A1 |
20070244760 | Bodnar et al. | Oct 2007 | A1 |
20070261072 | Boulet et al. | Nov 2007 | A1 |
20080052140 | Neal et al. | Feb 2008 | A1 |
20090157442 | Tesler | Jun 2009 | A1 |