ONLINE ADVERTISING CAMPAIGN CONTROLLER TO ORCHESTRATE ALLOCATION OF ADS
20170228766 · 2017-08-10
Inventors
Cpc classification
G06Q30/0201
PHYSICS
International classification
Abstract
Ad segments on a Web page are filled with ads that are served by a service provider operating between a user computer and publisher on one end and multiple ad serving entities on the other. The ads include those served by publisher ad server and also real time bidding. An offline campaign controller orchestrates the allocation of guaranteed and real time bidding by monitoring performance of the direct sold campaigns and generating updates to targeting parameters of UOE ad campaign and rules for an edge server. When a direct sold campaign is on track, the updates on UOE campaign permits an ad segment to be considered for real time bidding.
Claims
1. A system for holistically serving an ad to an ad segment on a Web page being viewed by a user, the system comprising: an ad server, an edge server, and an offline controller; the edge server configured to determine, for each ad segment, whether to send an impression request to the ad server for real time bidding or to at least one guaranteed ad server; the ad server configured to receive impression requests from the edge server and perform real time bidding; and the offline controller arranged to monitor the at least one guaranteed ad sever and provide updates to adjust the operation of the edge server and the ad server, wherein the offline controller is configured to: monitor the on-time schedule indicator (OSI) of a direct sold campaign in the at least one guaranteed ad server wherein the direct sold campaign has a guaranteed number of impressions at a guaranteed price; generate updates to configuration targeting parameters of the ad campaign in the at least one guaranteed ad server; and generate updates to rules and campaign data for the edge server to determine whether to send an impression of an ad segment for real time bidding based on the OSI; wherein if the guaranteed ad campaign is on track, updates are generated by the offline controller to consider the ad segment for real time bidding; and wherein the if the guaranteed ad campaign is not on track, the ad segment is served via the at least one guaranteed ad server; wherein the offline controller is not part of the edge server; and wherein the offline controller is not part of the at least one guaranteed ad servers; wherein the offline controller comprises a separate server operating offline from the edge server and the at least one guaranteed ad server; wherein if the campaign is not on track one or more parameters are updated to serve the ad segment via the at least one guaranteed ad server; and wherein the offline controller uses an API to configure information in the at least one guaranteed ad server, including updating targeting parameters for the ad segment; wherein the ad segment of the Web page is tagged with a optimization tag for a campaign and the optimization tag further determines parameters of the real time bidding; wherein the offline controller generates updates for a real time bidding engine associated with the edge server to consider the ad segment for real time bidding; wherein the offline controller configures geographic targeting of the campaign based on the OSI of other applicable direct sold campaigns based on geographic location associated with the user; wherein a direct sold campaign has a campaign name, number of impressions, budget, targeting parameters, geographic parameters, browser, OS, and device types; wherein a direct sold campaign has a campaign name, number of impressions, budget, targeting parameters, geographic parameters, browser, OS, and device types.
2. The system of claim 1, further comprising selecting a real time bidding floor to be at least equal or higher than a price per ad of the direct sold campaign.
3. A system for holistic ad serving in a network environment having individual users viewing one or more web pages published by a publisher comprising: an ad server supporting real time bidding; an edge server configured to determine, for each ad segment, whether to send an impression request to the ad server for real time bidding or to at least one guaranteed ad server; and a controller of an offline server configured to: receive data from one or more guaranteed ad servers indicative of whether or not a direct sold advertising campaign is on track along with campaign targeting information, wherein the direct sold advertising campaign has a guaranteed number of impressions at a guaranteed price; generate updates to targeting parameters for the guaranteed ad servers for real time bidding campaign based on whether the direct sold advertising campaign is on track; and generate updates and rules to instruct the edge server to send impressions for real time bidding if the direct sold advertising campaign is on track; the edge server configured to: receive impressions at the edge server from web pages published by a publisher, and decide whether to submit the impression for real time bidding or to a guaranteed ad server associated with the direct sold advertising campaign; wherein the controller is not part of the edge server; and wherein the controller is not part of the one or more guaranteed ad server; wherein the offline campaign controller comprises a separate server operating offline from the edge server and the at least one guaranteed ad server; wherein if the campaign is not on track one or more parameters are updated to serve the ad segment via the at least one guaranteed ad server; and wherein the offline controller uses an API to configure information in the at least one guaranteed ad server, including updating targeting parameters for the ad segment; wherein the controller comprises an Extract, Transform and Load (ETL) unit to extract, from the at least one guaranteed ad server, campaign configuration details, targeting parameters, and publisher specific details including an On Schedule Indicator (OSI) or other metrics regarding whether a campaign is on track; wherein the controller includes a data learning and rule adjustment module; and wherein the controller comprises an Extract, Transform and Load (ETL) unit to extract, from the at least one guaranteed ad server, campaign configuration details, targeting parameters, and publisher specific details including an On Schedule Indicator (OSI) or other metrics regarding whether a campaign is on track.
4. A method of holistically serving an ad to an ad segment on a Web page being viewed by a user by either of publisher ad server or real time bidding, the Web page published by a publisher, the method comprising: monitoring, at a controller, the on-time schedule indicator (OSI) of a direct sold campaign in at least one guaranteed ad server; generating, at a controller, updates to configuration targeting parameters of the ad campaign in the at least one guaranteed ad server; and generating, at the controller, updates to rules and campaign data for an edge server to determined whether to send an impression to a unified optimization engine (UOE) for real time bidding based on the OSI.
5. The method of claim 4, wherein the controller uses an API to configure information in the at least one guaranteed ad server, including updating targeting parameters for the ad segment.
6. The method of claim 4, wherein the ad segment of the Web page is tagged with a optimization tag for a campaign.
7. The method of claim 6, wherein a write API command to the at least one guaranteed ad server and the optimization tag further determines parameters of the real time bidding.
8. The method of claim 4, wherein the direct sold campaign has a guaranteed number of impressions at a guaranteed price and the controller generates updates for UOE campaign to consider the ad segment for real time bidding.
9. The method of claim 4, wherein the controller configures geographic targeting of the UOE campaign based on the OSI of other applicable direct sold campaigns for that geo location.
10. The method of claim 4, wherein a direct sold campaign has a campaign name, number of impressions, budget, targeting parameters, geo, browser, OS, and device types.
11. The method of claim 4, wherein the controller is a separate server operating offline from the edge server and the at least one guaranteed ad server.
12. The method of claim 4, further comprising selecting a real time bidding floor to be at least equal or higher than the direct sold campaign.
13. The method of claim 4, wherein the offline controller pulls data from the at least one guaranteed ad server.
14. A method of holistically serving an ad to an ad segment on a Web page being viewed by a user by either of publisher ad server or real time bidding, the Web page published by a publisher, the method comprising: monitoring, at an offline controller, a direct sold campaign in at least one publisher ad server, the direct sold campaign having a guaranteed price and a guaranteed number of impressions; determining, at the offline controller, whether the direct sold campaign is on track to serve the guaranteed number of impressions; and generating, at the offline controller, updates to configuration targeting parameters of the UOE ad campaign in the publisher ad server, wherein the controller updates targeting parameters for the ad segment based on whether the direct sold campaign is on track to control whether the ad is served from publisher ad server or real time bidding; generating, at the controller, updates to rules and campaign data for an edge server to determine whether to send an impression to an ad server for real time bidding; wherein the offline controller generates updates for an on-track UOE campaign to consider the ad segment for real time bidding. wherein the ad segment of the Web page is tagged with a optimization tag for an ad campaign.
15. The method of claim 14, wherein the offline controller configures geographic targeting of the ad campaign based on an on schedule indicator of other direct sold campaigns in publisher ad server
16. The method of claim 14, wherein the offline controller pulls data from the at least one publisher ad server.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
[0011] The invention and the advantages thereof may best be understood by reference to the following description taken in conjunction with the accompanying drawings in which:
[0012]
[0013]
[0014]
[0015]
[0016] In the drawings, like reference numerals are sometimes used to designate like structural elements. It should also be appreciated that the depictions in the figures are diagrammatic and not to scale.
DETAILED DESCRIPTION OF THE INVENTION
[0017] Methods and systems for controlling an advertising campaign are described in which orchestrate allocation of impressions between publisher ad server and real time bidding. An individual ad campaign may, for example, include a number of impressions, a budget, targeting parameters such as geographic (geo) parameters, latitude & longitude, browser parameters, operating system (OS) parameters, and devices parameters (e.g., mobile device).
[0018]
[0019] When a user views a publisher's website, an individual web page includes tags to serve an ad segment to a corresponding location on the web page. Ad tags are provided that support a holistic option of providing either of real time bidding or a direct sold ad. That is, a publisher places UOE tags as campaigns in the publisher ad server (e.g., DART/DFP). The ad tags are issued by an ad serving company to a publisher and can be used for both UOE and direct sold ad campaigns. That is, the ad tags are recognized by guaranteed ad servers such as DART/DFP. An exemplary UOE Tag format for an optimization engine of PubMatic, Inc. is as follows:
TABLE-US-00001 <script type=“text/javascript”> document.write(‘<script type=“text/javascript” src=“http://haso.pubmatic.com/ads/DFPL/PMHimpaEngine.html?site =%esid!;zone= %epid!;pubid=34576;network=N6581;adtype=1;sname=%s;sz=%% WIDTH%%x% %HEIGHT%%;ord=’+%%CACHEBUSTER%%+‘”><Vscript>’); </script>
[0020] In particular, the use of real time bidding may sometimes beat a publisher's guaranteed campaign. However, in a holistic approach, the direct sold campaign must also remain on-track. A write API may be used to configure targeting information in the publisher ad server.
[0021] The edge server 205 includes a rules engine that includes rules for features such as impression frequency and priority. The edge server 205 generates optimization tags with floor bids that are passed to the ad server 215. The ad server 215 is responsible for various metadata functions and includes rules and data for ad tags, impression caps, frequency, caps, geo targeting and many other parameters. A floor price may be set for the demand side platforms (DSPs) 280, which may include ad networks bidding on ad segments. As one example, the floor price may be set to be a value greater than a guaranteed price. This floor price may be a fixed value or be determined based on historical data and demand trends to optimize revenue. For example, the highest bid above the floor price may be selected as a winning bid. However, more generally additional criteria may be imposed on the bidding process and/or other types of bidding schemes may be employed.
[0022] A campaign controller 240 is provided. The campaign controller 240 is parallel sub-system. The campaign controller is not part of the edge server, ad server, or publisher ad server. The campaign controller 240 may be implemented as a server-based sub-system. The campaign controller 240 includes an Extract, Transform and Load (ETL) unit 242 that extracts campaign configuration details, targeting parameters, publisher specific details, and other information, including an On Schedule Indicator (OSI) or other metrics regarding whether a campaign is on track in the publisher ad server 250. This information may be provided directly or indirectly to an Allocation Orchestrator unit 244. The Allocation Orchestrator unit 244 includes modules for data learning and rule adjustments. The allocation orchestrator unit 244 generates updates to configuration parameters for the publisher ad server 250. Additionally, the allocation orchestrator unit 244 generates updates to the rules and campaign data used by the edge server 205. Additional data updates may be provided by the Allocation orchestrator unit 244 to the ad server 215.
[0023] One aspect is that the allocation orchestrator unit 244 provides frequent updates to the edge server 205 and the publisher ad server 250. The updates may, for example, be provided on a periodic basis, such as daily, hourly, etc. Alternatively, the updates may be provided based on the changes to the UOE campaign in the publisher ad server 250. For example if the campaign is in a comparatively stable regime then no updates may be required. However, in this example the updates may be generated in response to detecting changes in the campaign, such as changes in the OSI. It will be understood that noise filtering, predictive, and trend analysis may also be optionally performed on the data received from the publisher ad server to optimize performance. For example historical data and statistical techniques may be employed to generate a better indicator of whether the campaign will remain on track for a select interval of time.
[0024] As illustrated, an incoming impression is received by the edge server 205 when publisher ad server chooses UOE campaign over direct sold campaigns, which makes a decision whether to send it to the ad server for real time bidding optimization or to passed back impression to the publisher ad server. One criterion that may be used is whether the direct sold campaign is on track. If the direct sold campaign is not on track, the impression is not considered for optimization via real time bidding and is thus not considered for real time bidding.
[0025] Suppose as an example that the direct sold campaign is on track and the price is $2 per mil for the direct sold campaign. In this example, the impression may be sent by the edge server to the ad sever for real time bidding with a floor price>$2. Suppose no bids are greater than the floor price. Then in this case the publisher ad server will serve the impression.
[0026] As an example suppose that the UOE campaign is initially disabled in the publisher ad server (e.g., DART/DFP). The campaign controller checks that for the geographical (geo) location of Canada, there are 20 applicable campaigns, out of which 5 are critical. The campaign controller then checks the OSI of these campaigns and determines that all of these campaigns are on track for delivery. The campaign controller then configures the geo “Canada” for the UOE campaign and enables it. As previously discussed, this may be performed using a write API to configure the targeting parameters associated with the UOE tags of the campaign. The publisher ad server (e.g., DART/DFP) starts allocating impressions from geo ‘Canada’ to the UOE campaign. At the edge server, all impressions are considered for monetization (real time bidding) as the OSI of the critical campaigns is on track.
[0027]
[0028]
[0029] Although illustrative embodiments and applications of this invention are shown and described herein, many variations and modifications are possible which remain within the concept, scope, and spirit of the invention, and these variations would become clear to those of ordinary skill in the art after perusal of this application. Accordingly, the embodiments described are to be considered as illustrative and not restrictive, and the invention is not to be limited to the details given herein, but may be modified within the scope and equivalents of the appended claims.