SYSTEM AND METHOD FOR ACCOUNT INGESTION
A system is provided for ingesting existing advertising networks and/or advertising campaigns. According to some embodiments, advertising networks and/or campaigns comprise thousands of digital based advertisements or placements, that are constantly being called by content provider systems, constantly being delivered to hundreds of thousands of end user computer systems, accompanied by constantly updating reporting data and analytic data to manage the placements. Various embodiments, are specially configured to enable users to capture existing placement information (e.g., user interface design elements, execution rules, attribution information, etc.) and translate the existing digital objects from a variety of platforms, formats, etc. into a commonly managed interface and enhanced data structure. Translation into the enhanced data structure enables automatic management conventional systems cannot deliver.
This application is a continuation-in-part of and claims priority under §120 to U.S. patent application Ser. No. 15/166,815, entitled “GRAPHICAL USER INTERFACE FOR HIGH VOLUME DATA ANALYTICS,” filed on May 27, 2016; and is a continuation-in-part of and claims priority under §120 to U.S. patent application Ser. No. 15/166,852, entitled “SYSTEM FOR HIGH VOLUME DATA ANALYTIC INTEGRATION AND CHANNEL-INDEPENDENT ADVERTISEMENT GENERATION,” filed on May 27, 2016; each of which applications claims priority under 35 U.S.C. §119(e) to U.S. Provisional Application Ser. No. 62/168,303 entitled “GRAPHICAL USER INTERFACE FOR HIGH VOLUME DATA ANALYTICS,” filed on May 29, 2015, U.S. Provisional Application Ser. No. 62/190,451 entitled “SYSTEM AND METHOD FOR ACCOUNT INGESTION,” filed on Jul. 9, 2015, U.S. Provisional Application Ser. No. 62/208,241 entitled “SYSTEM FOR HIGH VOLUME DATA ANALYTICS AND DATA INGESTION,” filed on Aug. 21, 2015, and U.S. Provisional Application Ser. No. 62/239,145 entitled “SYSTEM FOR HIGH VOLUME DATA ANALYTIC INTEGRATION AND CHANNEL-INDEPENDENT ADVERTISEMENT GENERATION,” filed on Oct. 8, 2015; and this application claims priority under 35 U.S.C. §119(e) to U.S. Provisional Application Ser. No. 62/190,451 entitled “SYSTEM AND METHOD FOR ACCOUNT INGESTION,” filed on Jul. 9, 2015, U.S. Provisional Application Ser. No. 62/208,241 entitled “SYSTEM FOR HIGH VOLUME DATA ANALYTICS AND DATA INGESTION,” filed on Aug. 21, 2015, and U.S. Provisional Application Ser. No. 62/239,145 entitled “SYSTEM FOR HIGH VOLUME DATA ANALYTIC INTEGRATION AND CHANNEL-INDEPENDENT ADVERTISEMENT GENERATION,” filed on Oct. 8, 2015, all of which applications are incorporated herein by reference in their entirety.
BACKGROUNDA variety of platforms exist to manage complex advertising networks. Under many conventional approach no unified management system integrates management systems having different formats, different analysis metrics, and different functionality or control operations. Further, portability of existing networks is severely limited by the differing format and differing operations established to manage the existing network.
SUMMARYAccording to various aspects, a system is provided for ingesting existing advertising networks and/or advertising campaigns. According to some embodiments, advertising networks and/or campaigns comprise thousands of digital based advertisements or placements, that are constantly being called by content provider systems, constantly being delivered to hundreds of thousands of end user computer systems, accompanied by constantly updating reporting data and analytic data to manage the placements. Various embodiments, are specially configured to enable users to capture existing placement information (e.g., user interface design elements, execution rules, attribution information, etc.) and translate the existing digital objects from a variety of platforms, formats, etc. into a commonly managed interface.
In one embodiment, the system is specially configured to capture existing advertisements, advertising campaigns, or any existing marketing accounts (e.g., from a first second, third, forth, etc. platform (e.g., each having different formats and execution rules)), and aggregate, translate, and/or associate the existing information into a single automated management system. Various embodiments of the ingestion system enable users to port large advertising campaigns or large volumes of advertisements into an automated management system. According to some implementations, it is also realized that a need exists not only for porting advertisements or advertising campaigns between service providers, but also a need exists to effectively port historic data generated by different service providers. According to one embodiment, in order for such transitions to be effective, various embodiments enable immediate use of the ported historic data to optimize and/or automate execution of advertisements and/or advertising networks and management functions (e.g., end spend, modify advertisement, bid up position, etc.).
In various embodiments, the ingestion system is configured to capture and translate advertising information from a first provider format into a destination format associated with an automated management and performance analysis system. The destination format is configured to enable predictive optimizations on the execution and management of individual advertisements, groups of advertisements, and entire advertising campaigns.
Conventional systems attempt to provide for portability of advertising campaigns between providers. These systems provide for moving advertisements, however, conventional systems typically fail to integrate historical data into any new functionality provided, among other issues. Accordingly, various embodiments of the ingestion system are configured to translate historical data into a format usable by a destination management system. In some embodiments, after porting advertising campaigns by the ingestion system, the new management system can operate on historical data to predict performance and/or optimize execution of advertisements. After the ingestion system has translated an advertising campaign, the destination management system can then enable any level of service. For example, the destination management system can incorporate, or not, historical data into performance predictions, determinations of bid value, automated bidding control, shutting down advertisements, creating new advertisements, etc. According to one embodiment, user roles are defined and the destination management system to provide varying levels of automated assistance and analysis information. In some embodiments, regardless of the service level being employed, the ingestion system captures and associates any historical information made available by the first service provider with the destination management system format, so that all the historic information is later usable
According to one embodiment, the ingestion system is specially configured to capture advertisement data (e.g., existing ads, performance values, historic information, any management rules, etc.) for a service provider having a first format for data organization. In some embodiments, the first format can be pre-defined and the ingestion system can translate or associate the first formation to a destination format for advertising data. In one example, the system is specially configured to capture information from the known FACEBOOK platform. The ingestion system is configured to translate and/or associate any available advertising information into the destination format, and store any of the translated and/or associated advertisements and/or historical information on a destination advertisement management system. In further embodiments, how the historic information is employed by the destination advertisement management system depends on an assigned user role and service level.
According to one aspect a system for ingesting data structures in a first format to a destination format is provided. The system comprises at least one processor operatively connected to a memory, the at least one processor when executing, is configured to identify an existing account at a first service provider, the existing account associated with a first data structure format, capture authentication information for accessing the first service providers, use the authentication information, accessing advertising data stored in the first data format and map the advertising data to a destination data format, generate performance information responsive to mapping historical advertising data in the destination data format, automatically create corresponding placements associated with the historical advertising data and execution parameters for respective placements (e.g., bid rules, stop conditions, start conditions, valuation parameters, etc.), and manage, automatically, the respective placements with the ingestion system, wherein managing the respective placements includes an act of communicating by the at least one processor operation instructions to the first service provider that trigger the first service provider system to control (e.g., increase bid value, decrease bid value, stop the placement, start the placement, modify the appearance of the placement, etc.) the placement on the first provider system.
According to one embodiment, the system is further configured to enable dynamic generation of performance information responsive to user selection of data dimension (e.g., data fields, data descriptors, metadata fields, etc.). According to one embodiment, the system is further configured to generate performance information on multi-dimensional groupings of the advertising data. According to one embodiment, the system further comprises a user interface (“UI”) component configured to display high volume data analytics. According to one embodiment, the UI component is further configured to receive historical advertising metrics, analyze and group the historical advertising metrics into an advertising demographic hierarchy (e.g., advertising location, advertising target, advertising type, age group, budget pool, strategy group, ad set, individual placement, gender, custom audience, relationship, among others) configured for display in a selectable visual interface. According to one embodiment, the UI component is further configured to dynamically generate visual displays on the historical advertising metrics responsive to user selection of information dimensions (e.g., descriptive information for the advertisements or information associated with the advertisements) associated with one or more advertisements in the selectable visual interface. According to one embodiment, the UI component is configured to display information dimensions associated with advertisements in a selectable pivot table display. According to one embodiment, UI component is further configured to receive current advertising metrics, analyze and group the current advertising metrics into an advertising demographic hierarchy (e.g., advertising location, advertising target, advertising type, age group, budget pool, strategy group, ad set, individual placement, gender, custom audience, relationship, among others) configured for display in a selectable visual interface.
According to one embodiment, the UI component is further configured to dynamically generate visual displays on the historical advertising metrics responsive to user selection of information dimensions (e.g., descriptive information for the advertisements or information associated with the advertisements) associated with one or more advertisements. According to one embodiment, the UI component is further configured to dynamically generate visual displays on historical advertising metrics imported from outside providers in conjunction with current advertising metrics on advertisements managed by a destination system. According to one embodiment, the UI component is further configured to dynamically generate the visual displays of historic and current advertising metrics responsive to user selection of information dimensions (e.g., descriptive information for the advertisements or information associated with the advertisements) associated with one or more advertisements. According to one embodiment, the UI component is further configured to display summary information for the advertising metrics in each level of an advertising demographic hierarchy (e.g., advertising location, advertising target, advertising type, age group, budget pool, strategy group, ad set, individual placement, gender, custom audience, relationship, among others).
According to one embodiment, the UI component is further configure to generate a navigable user interface display including at least one selectable drawer associated with a hierarchical group of advertising metrics (e.g., site, budget pool, strategy group, ad set, placement, among other options), wherein the at least one selectable drawer includes a display of a title of a respective hierarchical group; and wherein the at least one selectable drawer is associated with a respective summary view of the advertising metrics within the hierarchical group. According to one embodiment, at least one processor is further configured to: access the advertising data via an advertising API associated with a social networking provider (e.g., FACEBOOK, TWITTER, PINTEREST, etc.).
According to one aspect a method for ingesting data structures in a first format to a destination format is provided. The method comprises identifying, by at least one processor, an existing account at a first service provider, the existing account associated with a first data structure format, capturing, by the at least one processor, authentication information for accessing the first service providers, using, by the at least one processor, the authentication information, accessing, by the at least one processor, advertising data stored in the first data format and mapping the advertising data to a destination data format, generating, by the at least one processor, performance information responsive to mapping historical advertising data in the destination data format.
According to one embodiment, the method includes dynamically generating performance information responsive to user selection of data dimension (e.g., data fields, data descriptors, metadata fields, etc.). According to one embodiment, the act of generating includes an act of generating performance information on multi-dimensional groupings of the advertising data. According to one embodiment, the method further comprises accessing the advertising data via an advertising API associated with a social networking provider (e.g., FACEBOOK, TWITTER, PINTEREST, etc.). According to one embodiment, the method further comprises displaying high volume data analytics via a user interface component. According to one embodiment, the method further comprises configuring the UI component to receive historical advertising metrics, analyzing and grouping the historical advertising metrics into an advertising demographic hierarchy (e.g., advertising location, advertising target, advertising type, age group, budget pool, strategy group, ad set, individual placement, gender, custom audience, relationship, among others) configured for display in a selectable visual interface.
Still other aspects, embodiments, and advantages of these example aspects and embodiments, are discussed in detail below. Moreover, it is to be understood that both the foregoing information and the following detailed description are merely illustrative examples of various aspects and embodiments, and are intended to provide an overview or framework for understanding the nature and character of the claimed aspects and embodiments. Any embodiment disclosed herein may be combined with any other embodiment in any manner consistent with at least one of the objectives, aims, and needs disclosed herein, and references to “an embodiment,” “some embodiments,” “an alternate embodiment,” “various embodiments,” “one embodiment” or the like are not necessarily mutually exclusive and are intended to indicate that a particular feature, structure, or characteristic described in connection with the embodiment may be included in at least one embodiment. The appearances of such terms herein are not necessarily all referring to the same embodiment. Various aspects, embodiments, and implementations discussed herein may include means for performing any of the recited features or functions.
Various aspects of at least one example are discussed below with reference to the accompanying figures, which are not intended to be drawn to scale. The figures are included to provide an illustration and a further understanding of the various aspects and examples, and are incorporated in and constitute a part of this specification, but are not intended as a definition of the limits of a particular example. The drawings, together with the remainder of the specification, serve to explain principles and operations of the described and claimed aspects and examples. In the figures, each identical or nearly identical component that is illustrated in various figures is represented by a like numeral. For purposes of clarity, not every component may be labeled in every figure. In the figures:
According to one embodiment, an ingestion system is configured to automate capture of advertisement information from the known FACEBOOK platform. In other embodiments, the ingestion system is configured to automate capture of advertisement information from other systems (e.g., GOOGLE, YAHOO, etc.). Shown in
UI I100 is configured to walk the user through a first phase of the ingestion process (e.g., Setup Import I102). At I104, the user is prompted to identify the site for which the user wishes to import the advertising data. The site specified by the user is used by the destination system to define an advertising site and associate the site with any number of advertisements, that can be further organized by budget pool. Each budget pool represents a logical organization of advertisements that can be managed together (e.g., manage advertising spent by budget pool, view revenue by budget pool, accounting by budget pool, etc.). At I106, the user is prompted to assign a budget pool to the information to be imported. In various embodiments, the budget pool associated for each advertisement is an editable field that the user can modify, for example, after import. At I108, the user is prompted to specify a time window for the information to be imported. In some embodiments, the time window may be specified via a drop-down menu containing popular choices for time window input values such as “last 28 days”, or “last 7 days”, or any suitable time window value for the user's ingestion process. In
UI I120 illustrates an example display for facilitating capture and configuration of existing advertising actions from, for example, a FACEBOOK account. The UI is configured to organize actions from the service provider and the management system into sections of the display. For example, at I124 the UI displays available system actions, and applies an ordering to those actions the system determines to be of the most importance. According to one embodiment, the ingestion system is configured to analyze an advertising account of another provider (e.g., a FACEBOOK account) and identify advertising actions configured on that account. For example, advertising actions can be defined based on rules. The rules can be defined with conditions and at least one action to take, responsive to the condition occurring or not occurring.
According to one embodiment, the system is configured to automatically identify system based actions (e.g., defined by programmatic language, logical execution conditions, visual based programming, etc.) to identify a condition predicate (e.g., a test condition) and a resulting operation tied to the condition predicate. The resulting operation can include complex management functions, individual actions to take with respect to a placement (e.g., pause placement, bid up placement, bid down placement, etc.), or trigger status change (e.g., alert to management, increase value, decrease value, etc.). In some examples, the ingestion system is specially configured to parse displays on an access system to identify execution logic or condition statements and match that execution logic and/or condition statements to potential operations to be performed on placements. Matching between existing operations and ingested operations can be executed based on a target platform. For example, a known platform may have a multitude of known actions. Some of the known actions may include consistent formats that can be used to reduce execution complexity during matching. Known operations can be searched first for matches before any complex matching logic or machine learning based approaches to identifying and implementing ingested actions.
In some embodiments, the ingestion system list identifies service provider actions and presents an ordering of the available system actions in the UI at I126. In one embodiment, the system can be configured to organize the service provider actions into management system actions based on whether each action is important for performance. In yet other embodiments, the ingestion system can apply different weightings based on defined rules or information extracted from historical performance and generate an ordering based on weighted evaluations (e.g., the system assigns the highest weight to predefined actions, the next weight value to most triggered actions, etc.)
Returning to the example UI I120, the system is configured to automatically identify the highest ranked actions and display those actions in window I126. The UI I120 specifies that the actions will be used by the destination system to optimize advertising performance and/or management. In further embodiments, the destination system can limit the number of actions that are considered in generating optimization and/or analytic information.
According to one embodiment, the ingestion system is configured to capture any action in window I126, so that each action will be captured by the destination system. However, as indicated in the UI 120 (at I128—“actions below this line cannot be used for optimization”), some actions will only be made available for reporting of the action but not for use in optimizing management of the advertisement(s). Selection of I130 triggers the ingestion system to transition to a next phase of the ingestion process which may include, e.g., downloading of the advertisement information (e.g., ads, rules, performance, historic performance data, etc.).
According to one embodiment, the ingestion engine 104 and/or system 100 can include components specifically configured to execute functions as part of a process of capturing advertising data from one or more advertising service providers for use in a destination advertisement system. For example, the system can include an authorization component 106 configured to use account information 102 to authorize the system to capture information from an outside service provider. In another example, the system and/or ingestion engine 104 can include a user interface component 110. The user interface component can be configured to generate user interfaces that facilitate capture of existing advertising information (e.g., as described in
In further embodiments, the ingestion system 100 and/or ingestion engine 104 can also include a translation component 108. The translation component 108 can be configured to build associations between a first provider format for advertising data and a destination formation for advertising data. In some examples, the translation component includes information on data structures used by a first provider (e.g., FACEBOOK) and mappings to data structures used in on the destination system. The translation can then capture and fill destination formatted data structures containing all of the previous advertising information. In further embodiments, the translation component 108 enables the destination system to use the historical advertising information as if it were originally created on the destination system.
According to one embodiment, FACEBOOK is configured with a strict object hierarchy in their data model. Each advertising account contains Campaigns, which contain Ad Sets, which contain Ads. In conventional implementation targeting, budgeting, and bidding are allowed at the adset level in their data model, and further ads are unique only in creative (and may also contain override bids). By ingesting existing advertisements (e.g., into ingestion system of
When, for example, a Facebook Ad account is imported, the data structures corresponding to the Ad account are mapped to placements (e.g., individual ad objects) that are collected (e.g., automatically organized) into an “ingestion” Budget Pool and Strategy Group, and can later be moved according to whatever campaign management strategy suits the customer. The system can automatically manage the placements via the ingestion budget pool and strategy group, and also provide user interface prompts to enable end users to move placements into different groups and pools or create new strategy groups or budget pools. The system is configured to automatically manage any level of the end mapping organization structures holding the placements. In one embodiment, the ingestion system maps each of the data structure elements from the FACEBOOK data models into the placement hierarchy of the ingestion system via table based mappings.
According to various embodiments, the ingestion system 100 or subsystem 202 can be configured to execute a variety of functions to capture existing advertisement information. An example process flow for capturing information from an outside advertising provider is described below. In one embodiment, the ingestion system 100 or subsystem 202 can be specially programmed to execute the example process flow. In other alternatives the integrated system 200 can executed the example process flow. Other embodiments can execute different process flow and can execute different process flows based on the outside provider.
Example Embodiments for Vendor Specific ImplementationIn one embodiment, users select functions for FACEBOOK Ad Account Import. The functions enable ingestion of ads, ad campaigns (groupings of ads), creative assets or “creatives”, and more from Power Editor, Ads Manager, or even another preferred marketing developer (“PMD”) (for example as long the assets were on the Open Graph—Open Graph is a protocol that enables web pages to become a rich data object in a social graph. For FACEBOOK, Open Graph enables any web page to have the same functionality as other objects on the FACEBOOK platform). Power Editor, Ads Manager, or PMD are advertising management systems, and their respective information can be ported via the ingestion system in the destination format.
Once the advertising data is imported into the destination format, the destination system (e.g., 204,
In some embodiments, new performance analysis data structures and information are made available once the historic advertising information is imported and/or translated. For example, new data and attributes can include:
-
- Strategy Group CPA Limit—The CPA goal associated with a Strategy Group using CPA bidding
- Strategy Group Max Bid—The maximum bid value over the course of the campaign
- Strategy Group Yield Goal—The target goal set up within the Strategy Group
- Budget Pool Lifetime Budget—The amount of lifetime spend allocated for a Budget Pool
According to one embodiment, these new attributes enable additional insight and algorithmic over strategy control groups and budget pools that are not available in other advertising systems (e.g., FACEBOOK). Other additional features include interactive displays for creative group dialog box—users can view more content within the creative group organizational units within advertising networks and/or budget pools. The dialogue boxes include drop down selection of data and metrics allowing users to pivot information displays dynamically.
Aspects of the present disclosure relate to some benefits of some embodiments, and implementation associated with ingesting advertisements from the known FACEBOOK platform. The following examples include various steps implemented in some embodiments for ingesting data from FACEBOOK accounts. The following embodiments and example process flows describe user scenarios, data flows, and integration with publically available FACEBOOK APIs that enable processing and downloading of the advertisement data made available on the FACEBOOK platform. Different embodiments can provide different flows, and interactions with other service providers can also require integration with other APIs. However, the following example flows are used to illustrate aspects of the invention and the invention should not be limited to the following examples.
In a first example flow, a process to ingest and sync FACEBOOK Ad account data into Nanigans Ad Engine is described. In this example, FACEBOOK Ad Account ingestion will download existing ads running in Power Editor into Ad Engine for consolidation, analysis, and more. Some of the benefits customers may receive from utilizing FACEBOOK Ad Account ingestion are:
-
- Consolidate FACEBOOK Ad Campaign Reporting: Easily view all FACEBOOK Ad campaign information in one solution, and take advantage of Nanigans advanced Business Intelligence capabilities using Performance Analysis.
- Aggregate Campaign Data for Any Attribute/Metric: Utilize any of the 80+ reporting attributes available within Performance Analysis to drill-down into campaign and ad performance using an excel like pivot table that offers speed and flexibility in your reporting. Seamlessly compare performance of different creatives with the numerous attributes available in Performance Analysis.
- Utilize ROI-Driven Budgeting and Optimization: For any further ad campaigns created in Ad Engine you can take advantage of Nanigans automation algorithms for budgeting and optimization to help make the most of every ad dollar.
- Automate Ad Creation; Testing, and Bidding: Using Nanigans Ad Engine you can define the elements of a campaign (image, copy, targeting, etc.) and Ad Engine will automatically build all of the available ad combinations for you. In addition, after you define your campaign goals, Ad Engine will automatically bid and budget accordingly to maximize your campaign performance.
In this example, FACEBOOK Ad Account ingestion will download existing ads that are running in Power Editor and create a new Budget Pool inside Ad Engine for all of the placement data, then automatically create Goals and Rules for each different Ad Type. All historical data can be found within performance Analysis. Any creative such as images, etc. that was used within ads will be automatically downloaded and can be used within newly created Ad Plans. Additionally, this ingestion process allows users to take current ads managed in Power Editor and manage them within Ad Engine via Goals and Rules without having to repush or make changes to the ads.
Step 601: Selecting an Ad Account:
-
- From the Ad Account page you will see a new option next to credentials to “Import”.
- Selecting Import will kick-off a wizard to import data from your FACEBOOK Ad Account into Nanigans Ad Engine.
Step 602: Site Selection:
-
- Select a site you would like to import data for.
Step 603: Settings and Review:
-
- Ensure all of your FACEBOOK Ad Account and Site data is correct and select the time period for data to import.
- The options for importing time periods into Ad Engine are:
- 7 Days (previous 7 days from current date)
- 28 Days
- 90 Days
- Lifetime (includes all Power Editor data from the life of the FACEBOOK Ad Account)
Step 604: Conversion Setup:
-
- Select and prioritize up to 7 conversion events for optimization, and 8 for reporting.
- By default all conversion events are setup with 28 day click, 1 day impression attribution window. The attribution window can be adjusted in the Conversion Setup window.
- Note: Ad Engine can be configured to automatically select some conversions for optimization and reporting based on site setup and FACEBOOK Account. The UI enables re-ordering and removing these conversions as necessary.
Step 605: Downloading Data into Ad Engine:
-
- In this step data will begin to be downloaded from FACEBOOK and imported into Ad Engine. The progress bar will show you how much of the process of downloading has been completed.
- Under the progress bar Ad Engine will highlight key features of the product with helpful “how to's” on how to begin utilizing each feature. You can exit this download window while in progress and the download will occur in the background. A button will appear in the top-right bar of Ad Engine next to Notifications, clicking this will recall the wizard so you can view the progress of downloading data.
Step 606: Finalizing Data Import:
-
- Once all of your FACEBOOK Ad Account data has been downloaded the final step of the process is to Review and Confirm your data. Ad Engine will display the following data once the download has been completed:
- Ads Currently Live
- Total Ads imported
- Average Daily Spend
- Graph (will show either Spend, Impressions or Clicks for imported time period)
- Once you have confirmed your data, you can view all FACEBOOK ad account information within Performance Analysis by clicking the blue “OK, Take Me To Reporting” button.
- Once all of your FACEBOOK Ad Account data has been downloaded the final step of the process is to Review and Confirm your data. Ad Engine will display the following data once the download has been completed:
In the example of process flow above, Performance Analysis is a feature that may enable advertisers to quickly get a holistic picture of campaign performance. Featuring an advanced pivot table, Performance Analysis, enables quick visualization and dive-into deep campaign metrics and view just the data that matters to you. In addition to viewing and saving custom reports—you can directly optimize and take action within your ad campaigns from Performance Analysis.
Another feature described in the example process flow above is Automatic Ad Building. Using Nanigans Ad Engine you no longer have to manually create every ad placement. Simply define the elements of your campaign—such as image, ad copy, link, and targeting then Ad Engine will automatically build all of the possible combinations for the ad types you specify. Whether you are creating 10 ads, or 10,000 ads Ad Engine saves you time building your ads and then optimizing for your business goals.
A third feature of the Nanigans Ad Engine described in this example is Revenue Optimization. Nanigans may enable one to optimize ad campaigns using Predictive Lifetime Value™ (pLTV) for the acquisition of profitable customers that lead to immediate and long term ROI. Move beyond proxy metrics to real results using Ad Engine and our algorithms that help you minimize spend, and maximize revenue.
Scheduling is a fourth feature described in this example process. Nanigans Ad Engine offers the flexibility to schedule your ad campaign for specific hours, days, weeks, or months. Whether you want to run a campaign only during weekdays, only on weekends, or only during business hours you have the ability to run your ad campaign within Ad Engine and have the system automatically determine when it is optimal to do so.
A fifth feature, FBX Product Feeds, allows one to manually upload a spreadsheet, or specify an automated product feed and automatically create ads within FACEBOOK Exchange (FBX). Using Ad Engine and FBX you gain the benefit of dynamically resizing product images to optimize display settings for placements automatically.
A sixth feature, Reporting API, automatically pulls-in reporting data and syncs it within your internal business systems. The Nanigans reporting API enables you to automatically pull campaign data and sync it within your own internal business systems as often as you want it. Whether you want holistic campaign data or event-level information for targeting you can seamlessly get this information from the Nanigans Reporting API.
Dashboard is another feature used in this example process, where a customer may get a snapshot of performance marketing data that is important to your business such as spend, ad type, and placement location across all ad campaigns. No diving into reporting, or collecting data—the Ad Engine dashboard gives you a holistic view of all your advertising information in one place.
The sales and onbrading process flow beings with
-
- Step 701: Question: “Would you like to import existing account data to Ad Engine”: received response options “Yes” or “Not Now”;
- if “Not Now” exit flow; else
- Step 702: If “Yes” the user is presented with a screen that has them either select an existing site or create a new site;
- new site flow includes generating a new site object under which the advertising information is organized;
- Step 703: Post site selection or Creation, “Campaign Options” appears:
- a name option is display for user input or selection of the budget pool and for the template that system utilizes;
- advanced options will include a time window of data to download. Options are 7 days, 14 days, 28 days, and 90 days (other embodiments enable time windows of one year or more—in one example default is 90 days);
- system displays “Go Back” option and “Continue to Next Step” option for user selection;
- Step 704: Action Set Up (system queries account level of FACEBOOK data to find all existing actions (including inactive);
- a user interface screen appears for the users to order the system identified actions (ordered action are used by the system to create a light weight funnel (i.e., filter) for optimization);
- system displays “Select Actions to Track” option and present default order by sum of actions (see, e.g.,
FIG. 5C );- Example of default ordering includes—largest sum of actions to smallest sum of action when presenting the list
- users can re-order the actions via drag and drop and/or trash ones they don't want to insert into tracking orders;
- in one example user has two options one for “reset” which restores any changes and “Ok, I got it. Let's move on and review everything”;
- in some embodiments, a default set of assumption are made for flow execution at step 704—the default assumption can include any one or more of:
- for actions—app install/mobile app install, offsite conversion, link click, page like, and for engagement actions—pushed out;
- Step 705: Data downloading:
- while the data is downloading, show a progress bar (if progress can be calculated);
- the dialog can include text for example “This may take a few minutes. We will send you an e-mail when the download is complete.”;
- in another example, under the progress bar, show a carousel-esque scrolling photo panel of 5 or so advertisement management features;
- Step 706: data is downloaded: once the data is imported, an email goes out to the user to let them know the data is imported and they need to come in and complete set up. Also this message appears on screen if the user has not closed the browser window. This Screen shows the sum of total spend Imported, the daily spend for the last 7 days, the number of ads imported, with a breakout of how many of them are “active.” User provide option to move forward “Ok, just one more step”;
- Step 707: Review: next a screen shows a review panel with metadata, ad count and spend and the mapped actions (mapped action refer to actions identified by definition on the system as conversion events), and a graph of the last 7 days of spend; option: “Ok, take me to Reporting”;
- Step 708: Product Tour—the user is shown Performance Analysis and a light overview via app cues sits on top of New PA that covers: reporting, bidding, budgeting, and additional features offered by the destination system (e.g., Nanigans Ad Engine)
- Step 701: Question: “Would you like to import existing account data to Ad Engine”: received response options “Yes” or “Not Now”;
-
- Step 801: sign up form. The form can request name, company, email address, password, site name, vertical, direct or agency, and terms of service to accept. The company name becomes client identifier, site specified name is use to populate the site name filed (also used as application id), email validation email is sent on the completion of this step contains a code. To conclude user is provided option, “Continue Sign Up.”
- Step 802: Validation—includes display of an input box for the code that is emailed in the previous step:
- Options for “Back” and “Next” are shown—next is grayed out until the input boxes are filled in;
- Step 803: FACEBOOK Account Set Up: button for “Link FACEBOOK Account to Ad Engine” is shown;
- one example used oAuth protocols to generated a pop up display to input authentication information for FACEBOOK account and data capture;
- once the account is authorized, the option to Name the account gains focus and an input box is show for name;
- validation that an email address is there;
- user is then show options “Back” and “All Set! Let's keep going”;
- Step 804: Start Data Import: display splash page and message “We will now start downloading your Ad Account, this may take a few minutes. We will send you an email when the download is complete”;
- a small hyper link button to toggle advanced options exists;
- advanced options are configured to let the user select time window of data to download. Options are 7, 14, 28 and 90 (in days). An example default is 28 days;
- user shown option “Let's Go!” to continue;
- Step 805: data downloading: while the data is downloading, show a progress bar;
- under the progress bar, show a carousel-esque scrolling photo panel of 5 or so destination system features (e.g., Nanigans AdEngine features—performance analytics, cohort, dashboard, etc.);
- Step 806: Action Set Up: screen appears for the users to order their FACEBOOK actions to create a light weight funnel (filter);
- example advancement includes a “Select Actions to Track” option shown in display;
- UI can include default order by sum of actions, largest to smallest when presenting the list where users can re-order the actions via drag and drop and trash ones they don't want to insert into tracking orders;
- to continue user shown two options one for “reset” to restores any changes that were done to the order and “Ok, I got it. Let's move on and review everything”;
- Step 807: Your Data is downloaded: once the data is imported, an email goes out to the user—summary information can be displayed here to show the sum of total spend imported, the daily spend for the last 7 days, the number of ads imported, with a breakout of how many of them are “active.”;
- example option to advance in flow—select “Ok, just one more step”;
- Step 808: Review: next a screen shows a review panel with naming conventions, Ad Count and Spend and the mapped actions;
- example to advance flow—user presented options for “Back” or “Ok, take me to Reporting”;
- Step 809: Product Tour—the user can be shown features of the destination management system, including for example, performance analysis and a detailed overview via application cues of reporting functions, bidding, budgeting functions, and additional features offered by the system (e.g., Nanigans' Ad Engine)
- Step 810: follow up—upon completion of the wizard (i.e., steps 801-809) the user is placed fully into the product; a “Congratulations Email” is sent and the user can analyze the imported data used the new features provides by the destination advertising management system.
Examples of general data flow elements for ingestions include (any number or combination of the follow elements can be used in various process flows):
-
- a boolean option display requesting download existing (live) ad groups and associated data;
- data download options includes trailing time options, 7 days, 14 days, 28 days, and 90 days with default to 28 days;
- other examples enable download all data (not time range input);
- trigger oAuth 2.0—display a window to grab the username and password; and
- authorization process can be implemented to remain on destination system web site, i.e. retrieve data from target systems rather than transition and capture.
In other examples, ingestion process execution can also include universal object creation—to make sure all the meta data tied to a placement exists. For example, data fields created for universal objects can include: Ad Plan (hidden object); “Allocation” (‘Simple’ template), Ad Plan Policy object aka Strategy Group; Budget Pool (new BP—require naming in flow, no daily budget needs to be set in advance); Ad Plan Pricing; Pricing.
In further examples, advertising campaign downloads can include operations to fetch campaign names, id, objective, and status. Adset downloads can include operations to fetch adset names, id, status, budget_cents, start_date, end_date, and parent_campaign_id. Once captured, the process can execute mapping operations to find parent data objects in the destination system and associate the preceding fields into a structure table. Query ad group from downloaded information to obtain: ad group end point to find ads and fetch adgroup name, id, status, bid_cents, and objective. Once captured, the process can execute operations to find a parent data object on the destination system and write structure_id row to a placements table and put row in placement_set_links table, as well as placement_relations, and placement_pricings. Additional operations are configured to detect “ad type” (this is in the creative object as define by FACEBOOK). In one example, the system is configured to operate as a reverse compiler to take FACEBOOK specialized data and map it to sets. According to one embodiment, a set is a data model object which includes FACEBOOK's creative and also includes targeting data. Using a broader (i.e. more inclusive data model) enables functionality across a plurality of advertising systems that extend the options available through various conventional systems. When the destination system (e.g., Nanigans' AdEngine) deploys ads, the ads are compiled or pushes from the universal data objects into the FACEBOOK data model. Ingestion reverses this approach and translated FACEBOOK's data model into the universal form of the destination system.
In further examples, responsive to importing creatives (FACEBOOK data object), the system captures: Title, Body, Image, Post Text, Caption, Description, and post id and maps to the universal data object. Also captured and mapped are conversion specification data, tracking specification data, keyword sets and any virtual target creations. Additional details can be captures and mapped, including: page posts, add to Library.opengraph_actions and objects tables based on conversion, specifications and/or tracking specifications.
Other data capture based actions can include:
-
- set Creation
- use each element to create records in “sets” table, set_details too . . . and update placement—relations
- placement record creation and incorporate assorted links
- Bid, bid type and budget fetch from ad group and campaign
- ad plan set links (site_id, ad_plan_id, set_id, etc.)
- create actions
- scan all the “actions” across the graph, create a list of “actions”
- present list of actions in order for the user to select to set up, allow the users to drag and drop them in a stack rank order to create the “funnel” concept
- fetch stats: if possible fetch stats in hourly intervals for the select time period, and if not, fetch daily stats and note during the import process hourly stats won't be available historically but will be there going forward.
- set Creation
Historic data may be captured and associated with data structures on the destination system to enable dynamic and interactive displays of the historic data. The interfaces can be configured to merge current data with historic data to facilitate user access to information. The dynamic displays can be responsive to user selection of data dimensions (e.g., information associated with ads, metadata, further information associated with the descriptive information, etc.). In some embodiments, the system generates interfaces that enable easy selection of data dimensions (e.g., right click to add available data dimensions, or drag and drop data descriptors into a visual display). The interfaces can then dynamically generate and redisplay advertisement information as new data dimensions are incorporated, removed, repositions, and/or re-ordered. In some embodiments, the interfaces may be browser-based applications written in a variety of programming language including, but not limited to Java, Javascript, PHP, among others. Such an architecture (e.g., the Data Analytics and Workflow Architecture) may be designed to handle many events in a scalable manner. Raw data may be stored in a relational database (e.g., MySQL) as the vast majority of the data is relational in nature and databases such as MySQL provide ACID transactions.
According to one embodiment, to achieve the performance required and support multi-tier pivoting, the system may be configured to load all of the required MySQL data into memory. In one embodiment, the system may break the information (e.g., data dimensions) into two types:
-
- Placement metadata such as creative, and audience
- Performance time based data
Placement metadata may be stored in memory and, according to one embodiment, the placement metadata is immutable. Loading this data often requires joins across many tables and can be slow, however, it is appreciated that once in memory, the data can be accessed very quickly. Recent performance data may be kept in memory while older data is retained based on user access. The data may be refreshed regularly, or changes to data may be streamed into the architecture to ensure the query results represent real-time metrics.
A query engine acts upon the data in memory using data agnostic actions (i.e. group, sort, where, having). In one example, because the data volumes for advertising metrics are so large, an infrastructure may be provided that is capable of handling billions of events and aggregating the information into displays that are capable of being acted upon in real time by users (e.g., ad managers). Information may be aggregated and for use in pivot tables that can be presented to users within a management interface. Such pivot tables may access a tree-like data structure having multi-layer aggregation that permits attribute and metric filtering at any layer. To this end, a custom procedural query engine may be provided that is capable of generating this tree-like structure. The infrastructure itself may be underpinned by a dynamically balanced fault tolerant server structure. For example, a load balancer may be provided that distributes load to one or more nodes which performs various functions (such as tree generation/management and SQL operations on a MySQL database).
It is noted that, according to one implementation, the data model and data access layers are completely decoupled from the query engine. The paths given to the query engine refer to fields within the object using reflection and support expressions against those fields. This allows for using the architecture to analyze other future data objects beyond just placements.
The query engine may use a procedural language to process the data. Below is an example:
- GET(1234)
- WHERE(EQUAL,placement.audience.minage,15)
- GROUP(placement.audience.gender,placement.creative.title)
- SORT(0,placement.creative.image,DESC,placement.bidtype,ASC)
- ATTACH(1234,TODAY,HOUR)
- HAVING(1,GREATER_THAN,placementperformance.clicks/placementperformance.impressions,0.5)
In this case, placement metadata for site 1234 is utilized and first filters out any placements whose audience's minimum age is 15. The results are then grouped by audience gender and creative title and sorted by image and bid type. Attach then combines metadata with today's time based performance data and groups it by hour. Finally, the having step filters any aggregate data for each hour to only include those whose click through rate is greater than 50%. Data is represented as a tree with aggregate summaries at each non-leaf node. The result is that loading Placement Analysis for a customer in a conventional architecture with 1 million placements would take between 20-30 minutes, while the architecture is capable of executing a more complex query in under 2 seconds.
According to one embodiment, the system presents a unified user interface layer 310 that is presented to users of the system. The user interface layer 310 is configured to organize and display the variety of summary views 312; and any management functions 316 and/or views.
Further, various aspects of the invention may be practiced with one or more advertising automation systems shown by way of example in
According to one embodiment,
As illustrated, each of the example sources communicate with a set of servers, for example in the second layer of the figure (e.g., the “web queue tier” at 408). The web queue tier 408 includes globally distributed web servers which provide load distribution, queuing, and cookie management, so that the end user's browser or mobile app is not slowed down waiting for the completion of the attribution process (e.g., data tracking and identification of associated users and/or actions).
In one example the web queue tier is a set of servers implementing user resolution and attribution operations. User Resolution at 410 includes a plurality of servers configured to utilize tokens collected by the data sources to synthesize an internal identifier which is unique to each user. According to one embodiment, the synthesizing of the internal identifier does not connect to identifiable information about that user, but rather provides a way to connect events over time to determine which interaction events should be aggregated together for performance reporting. In Attribution Management 412, a group of servers are configured to evaluate each tracked interaction in light of a respective user's history in order to determine which advertisements or content, if any, should receive credit for causing the interaction. According to one embodiment, the system currently implements a “last touch” attribution model, but others are possible (e.g., first touch attribution model, weighted attribution models, hybrid attribution models, among other options). For mobile app interactions, various embodiment of the system are configured to automatically query other servers via mobile measurement partnership (“MMP”) APIs to determine the best attribution. Based on the data returned form MMP APIs, the system identifies a best attribution (e.g., based on determining a level of influence for each attribution contributor) and stores the attribution information.
According to some embodiments, the user interface layer 310 is configured to generate and present tailored views to end users, where the views include navigable visualizations of advertising data. For example, the user interface layer can generate a user interface that is a data-centric pivot table that allows dynamic navigation into more specific information, such as ad placement information through navigable data representations, wherein each data representation can be selected in the user interface to dynamically alter the data displayed or navigate into further detailed selections.
For example, a user may be presented an interface that allows a user to navigate through performance analysis data (e.g., ad placement performance information) to locate specific ads and their performance within a hierarchical view. The specific ad information that is displayed may include performance information specific to the filters used to navigate to the specific ad. Such an interface is beneficial, as it permits an advertising manager to quickly locate relevant ad placement details through a data-driven interface. In one embodiment, the interface may include the ability to present an inline summary of the ad placement within a tabular view of the performance data. Summary information associated with the displayed ads may be changed depending on the filters or other user selections within the interface. Such capabilities may permit a user (an advertising manager or other user type that manages ad placements) to quickly locate relevant ads within the user interface that relate to the displayed placement performance data.
In further embodiments, the system can be configured to combine this information with data drawn from advertising publisher APIs (e.g., 424) and RTB data streams (e.g., 432), as well as various advertiser data sources (e.g., conveying conversion events at 434), such as customer relation management (“CRM”) systems (e.g., 428) and product and inventory feeds (e.g., 426).
Various embodiments of the system enable one or more of or any combination of: processing and rendering of analytics on 600 million conversion events each day; globally (DNS) balanced web tier; manage cookies; handle redirects and containers; accept and queue events; user resolution; horizontally scalable processing; multiple tokens and/or levels of authority for accessing and/or visualizing data; device bridging by first party ID; MMP API integrations; bridge click-to-install gap; attribution management—for example, based on user impression/click/event history; in another example attribute is defined by last click but other models possible. Further embodiments enable one or more of or any combination of: processing 600 million conversions/day; 300 thousand RTB events/second; 400 million user records; 300 million feed elements; 30 million MMP API data rows/day; mixed granularity (e.g., by event, user, product, ad time); storing real-time structured data, for user management, attribution, RTB match; execute map/reduce and/or ETL frameworks; which can be used for modeling and exploration; and can include low latency rollups (e.g., information aggregations) which provide merged cohort data with time information, which the system can use for reporting and/or API decisions.
Yet other embodiments are configured to execute one or more or any combination of the following: unique interface paradigm which provides visualization of live performance context data while executing management functions, editing existing placements, etc.; context-specific actions and visualizations for live campaigns and directly integrate live analytics views; fast, configurable analytics interface responsive to user input; API triggering responsive to user interface input; multi-layer, multi-dimensional aggregation of performance/placement data; comprehensive ad attributes and metrics; powerful sorting and filtering in responsive user interface; variable time frames and granularity associated with data aggregates accessible and tunable in the user interface; graphic and tabular views; near real-time reporting (e.g., with hour granularity, minute granularity, etc.); and tailored performance even for large campaigns and wide time windows. Still other embodiments enable one or more of or any combination of: a custom procedural query engine; queries against generic object hierarchy; building result trees with multi-layer aggregation and, for example, loading of tree segments to optimize fast visualization; attribute and metric filtering at any tree layer; persistent result set management; smart object/data and result set caches to optimize visualizations; pre-loading of frequently used data; object definition and data access plug-ins; client-side data browser and object manager; interfaces to server API for analytics access; smart client-server scrolling (e.g., incremental loading of data); dynamic attribute and metric panels; context/selection-specific action menus and panels; load and pivot ad-level lifetime campaign data visualized in under one second; remains responsive for time-based analysis over GBs of data; and a dynamically load balanced, fault tolerant cluster.
In one embodiment, the query engine implements in-memory queries against aggregate advertising data (e.g., loaded from
The analytics user interfaces cane be implemented through a javascript client side app (e.g., 460) with a corresponding server-side API (e.g., 458) that interfaces with the query engine (e.g., 456). The JS app issues data requests to the API (e.g., 458) as users configure aggregation, filtering, and date range settings, and then manages data fetched via the API from the matching result sets to provide high performance on the client while operating within reasonable client memory limits.
According to one aspect, the user interface is specially configured to manage, aggregate, and dynamically select data for visualization responsive to constantly updating data feeds (e.g., live placement data associated with an advertising network). The dynamic nature of the received data allows a user to selectively control their view of the changing data, for example by creating and saving user interface views. In one implementation, a database management component is configured to receive the dynamic data feeds, translate the dynamic data feeds into standardized formats, and group the dynamic data into selectable and displayable elements.
According to another aspect of the present invention, a visualization interface may be provided that includes a web-enabled pivot table used to analyze and present ad performance data. According to one embodiment, advertisers may use a pivot table to view, sort through, and visualize multiple dimensions of advertising or groups of advertising data. Such tables, according to various embodiments, are configured with the attributes and metrics that are specifically tailored to user's needs by adding predefined audiences, creative elements, data-related attributes or placement details, followed by the metrics that determine campaign success. Once the selections within the interface have been made, the user may be permitted to simply drag and drop displayed elements to re-order metrics and/or to create a customized campaign dashboard. Such interfaces may be modified to include a summary view associated with a specific ad within the table based on specific user selections within the pivot table. This permits, for example, a user to selectively create a dashboard using certain metrics while at the same time seeing the specific ad placements and their associated summaries according to the configured dashboard. For instance, if an advertiser wants to see which creative was performing the best, the user is permitted to sort by key metrics (e.g., ROI, LTV, CTR, CPC, etc.) and locate specific summary view information relating to those placements.
In various embodiments, the system includes a predictive, analytics, and optimization executables interposed between an advertisement representation layer and the campaign configuration layer. The predictive, analytics, and optimization layer may be configured to provide one or more advertisement parameter suggestions automatically. In various embodiments the destination format is configured to enable predictive optimizations on the execution and management of individual placements, budget pools, strategy groups, and entire advertising campaigns. In some embodiments, after ingesting advertising campaigns, a new management system can operate on historical data to predict performance and/or optimize execution of advertisements and/or make one or more suggestions. Automation enables the system to distinguish between ads that have good value (methods and systems for determining value are described in Co-Pending U.S. patent application Ser. No. 14/324,992, entitled PREDICTING CONSUMER LIFETIME VALUE, filed on Jul. 7, 2014, which is incorporated by reference herein in its entirety), and ads that are likely throwing money away—equally important, in some examples, is that the system can convey high volumes of data to an end user, understandably and manageably, through customized displays.
The system and UIs provided enable definition of advertising parameters for any ad placement. The UI can include contextual displays of a plurality of existing placements and the associated data can be captures and used to population data fields for the parameters for an ad placement. As the parameters are defined they can be passed through a gatekeeper server, which can be configured to reduce the received parameters to a core ad or placement representation, which can be used to establish a management ad representation configured to enable management of a plurality of channel specific ads or placements and/or associated functions, where the placements can be generated from the core representation. In one example, the management placement representation is configured to enable management across, for example FACEBOOK via an API, FACEBOOK EXCHANGE, MOPUB, TWITTER, etc. Each modification to the placement and/or execution of a management function (e.g., bid up, bid down, pause, re-target audience, re-deploy placement, etc.) can return performance information from the respective channels and map to data structures native to the ingestions system. The UI can be configured to visualize the returned information, for example, using the management placement representation.
According to some embodiments, historical data can take a while to ingest, and the machine learning model is configured to wait until the data is available. In some example accounts take less than a day to ingest, although large accounts can take substantially longer. According to some embodiments, data analysis is available for whatever data has completed ingest (e.g., a complete advertisement has been ingested) as the ingest is in process, but the system is configured to provide automatic operations as recommendations until the entire ingestion process has been completed. In another embodiment, the user can specify on the system, and the system is configured to automatically control, advertisements as they are ingested (and entire ingestion not complete), an options for the system to take over automatic control during ingestion.
For example, according to one embodiment, an interface may be provided that is a data-centric pivot table that allows dynamic navigation into more specific information, such as ad placement information. For instance, a user may be presented an interface that allows a user to navigate through performance analysis data (e.g., ad placement performance information) to locate specific ads and their performance within a hierarchical view. The specific ad information that is displayed may include performance information specific to the filters used to navigate to the specific ad. Such an interface is beneficial, as it permits an advertising manager to quickly locate relevant ad placement details through a data-driven interface. In one embodiment, the interface may include the ability to present an inline summary of the ad placement within a tabular view of the performance data. Summary information associated with the displayed ads may be changed depending on the filters or other user selections within the interface. Such capabilities may permit a user (an advertising manager or other user type that manages ad placements) to quickly locate relevant ads within the user interface that relate to the displayed placement performance data.
Various aspects and functions described herein may be implemented as specialized hardware or software components executing in one or more specialized computer systems. There are many examples of computer systems that are currently in use that could be specially programmed or specially configured. These examples include, among others, network appliances, personal computers, workstations, mainframes, networked clients, servers, media servers, application servers, database servers, and web servers. Other examples of computer systems may include mobile computing devices (e.g., smart phones, tablet computers, and personal digital assistants) and network equipment (e.g., load balancers, routers, and switches). Examples of particular models of mobile computing devices include iPhones, iPads, and iPod Touches running iOS operating systems available from Apple, Android devices like Samsung Galaxy Series, LG Nexus, and Motorola Droid X, Blackberry devices available from Blackberry Limited, and Windows Phone devices. Further, aspects may be located on a single computer system or may be distributed among a plurality of computer systems connected to one or more communications networks.
For example, various aspects, functions, and processes may be distributed among one or more computer systems configured to provide a service to one or more client computers, or to perform an overall task as part of a distributed system, such as the distributed computer system 900 shown in
Referring to
As illustrated in
The memory 912 stores programs (e.g., sequences of instructions coded to be executable by the processor 910) and data during operation of the computer system 902. Thus, the memory 912 may be a relatively high performance, volatile, random access memory such as a dynamic random access memory (“DRAM”) or static memory (“SRAM”). However, the memory 912 may include any device for storing data, such as a disk drive or other nonvolatile storage device. Various examples may organize the memory 912 into particularized and, in some cases, unique structures to perform the functions disclosed herein. These data structures may be sized and organized to store values for particular data and types of data.
Components of the computer system 902 are coupled by an interconnection element such as the interconnection element 914. The interconnection element 914 may include any communication coupling between system components such as one or more physical busses in conformance with specialized or standard computing bus technologies such as IDE, SCSI, PCI and InfiniBand. The interconnection element 914 enables communications, including instructions and data, to be exchanged between system components of the computer system 902.
The computer system 902 also includes one or more interface devices 916 such as input devices, output devices and combination input/output devices. Interface devices may receive input or provide output. More particularly, output devices may render information for external presentation. Input devices may accept information from external sources. Examples of interface devices include keyboards, mouse devices, trackballs, microphones, touch screens, printing devices, display screens, speakers, network interface cards, etc. Interface devices allow the computer system 902 to exchange information and to communicate with external entities, such as users and other systems.
The data storage element 918 includes a computer readable and writeable nonvolatile, or non-transitory, data storage medium in which instructions are stored that define a program or other object that is executed by the processor 910. The data storage element 918 also may include information that is recorded, on or in, the medium, and that is processed by the processor 910 during execution of the program. More specifically, the information may be stored in one or more data structures specifically configured to conserve storage space or increase data exchange performance. The instructions may be persistently stored as encoded signals, and the instructions may cause the processor 910 to perform any of the functions described herein. The medium may, for example, be optical disk, magnetic disk or flash memory, among others. In operation, the processor 910 or some other controller causes data to be read from the nonvolatile recording medium into another memory, such as the memory 912, that allows for faster access to the information by the processor 910 than does the storage medium included in the data storage element 918. The memory may be located in the data storage element 918 or in the memory 912, however, the processor 910 manipulates the data within the memory, and then copies the data to the storage medium associated with the data storage element 918 after processing is completed. A variety of components may manage data movement between the storage medium and other memory elements and examples are not limited to particular data management components. Further, examples are not limited to a particular memory system or data storage system.
Although the computer system 902 is shown by way of example as one type of computer system upon which various aspects and functions may be practiced, aspects and functions are not limited to being implemented on the computer system 902 as shown in
The computer system 902 may be a computer system including an operating system that manages at least a portion of the hardware elements included in the computer system 902. In some examples, a processor or controller, such as the processor 910, executes an operating system. Examples of a particular operating system that may be executed include a Windows-based operating system, such as, Windows NT, Windows 2000 (Windows ME), Windows XP, Windows Vista or Windows 7, 8, or 10 operating systems, available from the Microsoft Corporation, a MAC OS System X operating system or an iOS operating system available from Apple Computer, one of many Linux-based operating system distributions, for example, the Enterprise Linux operating system available from Red Hat Inc., a Solaris operating system available from Oracle Corporation, or a UNIX operating systems available from various sources. Many other operating systems may be used, and examples are not limited to any particular operating system.
The processor 910 and operating system together define a computer platform for which application programs in high-level programming languages are written. These component applications may be executable, intermediate, bytecode or interpreted code which communicates over a communication network, for example, the Internet, using a communication protocol, for example, TCP/IP. Similarly, aspects may be implemented using an object-oriented programming language, such as .Net, SmallTalk, Java, C++, Ada, C# (C-Sharp), Python, or JavaScript. Other object-oriented programming languages may also be used. Alternatively, functional, scripting, or logical programming languages may be used.
Additionally, various aspects and functions may be implemented in a non-programmed environment. For example, documents created in HTML, XML or other formats, when viewed in a window of a browser program, can render aspects of a graphical-user interface or perform other functions. Further, various examples may be implemented as programmed or non-programmed elements, or any combination thereof. For example, a web page may be implemented using HTML while a data object called from within the web page may be written in C++. Thus, the examples are not limited to a specific programming language and any suitable programming language could be used. Accordingly, the functional components disclosed herein may include a wide variety of elements (e.g., specialized hardware, executable code, data structures or objects) that are configured to perform the functions described herein.
In some examples, the components disclosed herein may read parameters that affect the functions performed by the components. These parameters may be physically stored in any form of suitable memory including volatile memory (such as RAM) or nonvolatile memory (such as a magnetic hard drive). In addition, the parameters may be logically stored in a propriety data structure (such as a database or file defined by a user space application) or in a commonly shared data structure (such as an application registry that is defined by an operating system). In addition, some examples provide for both system and user interfaces that allow external entities to modify the parameters and thereby configure the behavior of the components.
Based on the foregoing disclosure, it should be apparent to one of ordinary skill in the art that the embodiments disclosed herein are not limited to a particular computer system platform, processor, operating system, network, or communication protocol. Also, it should be apparent that the embodiments disclosed herein are not limited to a specific architecture or programming language.
It is to be appreciated that embodiments of the methods and apparatuses discussed herein are not limited in application to the details of construction and the arrangement of components set forth in the following description or illustrated in the accompanying drawings. The methods and apparatuses are capable of implementation in other embodiments and of being practiced or of being carried out in various ways. Examples of specific implementations are provided herein for illustrative purposes only and are not intended to be limiting. In particular, acts, elements and features discussed in connection with any one or more embodiments are not intended to be excluded from a similar role in any other embodiments.
Also, the phraseology and terminology used herein is for the purpose of description and should not be regarded as limiting. Any references to embodiments or elements or acts of the systems and methods herein referred to in the singular may also embrace embodiments including a plurality of these elements, and any references in plural to any embodiment or element or act herein may also embrace embodiments including only a single element. References in the singular or plural form are not intended to limit the presently disclosed systems or methods, their components, acts, or elements. The use herein of “including,” “comprising,” “having,” “containing,” “involving,” and variations thereof is meant to encompass the items listed thereafter and equivalents thereof as well as additional items. References to “or” may be construed as inclusive so that any terms described using “or” may indicate any of a single, more than one, and all of the described terms.
Having thus described several aspects of at least one embodiment of this invention, it is to be appreciated that various alterations, modifications, and improvements will readily occur to those skilled in the art. Such alterations, modifications, and improvements are intended to be part of this disclosure, and are intended to be within the spirit and scope of the invention. Accordingly, the foregoing description and drawings are by way of example only.
Claims
1. A system for ingesting data structures in a first format to a destination format, the system comprising:
- at least one processor operatively connected to a memory, the at least one processor when executing, is configured to:
- identify an existing account at a first service provider, the existing account associated with a first data structure format;
- capture authentication information for accessing the first service providers;
- use the authentication information, accessing advertising data stored in the first data format and map the advertising data to a destination data format;
- generate performance information responsive to mapping historical advertising data in the destination data format;
- automatically create corresponding placements associated with the historical advertising data and execution parameters for respective placements; and
- manage, automatically, the respective placements with the ingestion system, wherein managing the respective placements includes an act of communicating by the at least one processor operation instructions to the first service provider that trigger the first service provider system to control the placement on the first provider system.
2. The system according to claim 1, wherein the system is further configured to enable dynamic generation of performance information responsive to user selection of data dimension.
3. The system according to claim 2, wherein the system is further configured to generate performance information on multi-dimensional groupings of the advertising data.
4. The system on claim 1, further comprising a user interface (“UI”) component configured to display high volume data analytics.
5. The system of claim 4, wherein the UI component is further configured to:
- receive historical advertising metrics;
- analyze and group the historical advertising metrics into an advertising demographic hierarchy configured for display in a selectable visual interface.
6. The system of claim 5, wherein the UI component is further configured to dynamically generate visual displays on the historical advertising metrics responsive to user selection of information dimensions associated with one or more advertisements in the selectable visual interface.
7. The system of claim 4, wherein the UI component is configured to display information dimensions associated with advertisements in a selectable pivot table display.
8. The system of claim 4, wherein the UI component is further configured to:
- receive current advertising metrics;
- analyze and group the current advertising metrics into an advertising demographic hierarchy configured for display in a selectable visual interface.
9. The system of claim 5, wherein the UI component is further configured to dynamically generate visual displays on the historical advertising metrics responsive to user selection of information dimensions associated with one or more advertisements.
10. The system of claim 4, wherein the UI component is further configured to dynamically generate visual displays on historical advertising metrics imported from outside providers in conjunction with current advertising metrics on advertisements managed by a destination system.
11. The system of claim 10, wherein the UI component is further configured to dynamically generate the visual displays of historic and current advertising metrics responsive to user selection of information dimensions associated with one or more advertisements.
12. The system of claim 4, wherein the UI component is further configured to display summary information for the advertising metrics in each level of an advertising demographic hierarchy.
13. The system of claim 12, wherein the UI component is further configure to generate a navigable user interface display including at least one selectable drawer associated with a hierarchical group of advertising metrics, wherein the at least one selectable drawer includes a display of a title of a respective hierarchical group; and wherein the at least one selectable drawer is associated with a respective summary view of the advertising metrics within the hierarchical group.
14. The system of claim 1, wherein the at least one processor is further configured to: access the advertising data via an advertising API associated with a social networking provider.
15. A computer implemented method for ingesting data structures in a first format to a destination format, the method comprising:
- identifying, by at least one processor, an existing account at a first service provider, the existing account associated with a first data structure format;
- capturing, by at least one processor, authentication information for accessing the first service providers;
- using, by at least one processor, the authentication information, accessing advertising data stored in the first data format and mapping the advertising data to a destination data format;
- generating, by at least one processor, performance information responsive to mapping historical advertising data in the destination data format.
16. The method of claim 15, further comprising an act of dynamically generating performance information responsive to user selection of data dimension.
17. The method of claim 16, wherein to the act of generating includes an act of generating performance information on multi-dimensional groupings of the advertising data.
18. The method of claim 15, further comprising an act of accessing the advertising data via an advertising API associated with a social networking provider.
19. The method of claim 15, displaying high volume data analytics via a user interface component.
20. The method of claim 19, further comprising acts of:
- receiving historical advertising metrics;
- analyzing and group the historical advertising metrics into an advertising demographic hierarchy configured for display in a selectable visual interface.
Type: Application
Filed: Jul 11, 2016
Publication Date: Jan 12, 2017
Inventors: Claude Denton (Lexington, MA), Per Anders Sandell (Boston, MA), Amit Deepak Adur (Chino Hills, CA), Brittney Katherine Exline (Brighton, MA), Derek J. Yimoyines (Winchester, MA), John Joseph Clyde (Seattle, WA)
Application Number: 15/206,581