SYSTEM FOR HIGH VOLUME DATA ANALYTIC INTEGRATION AND CHANNEL-INDEPENDENT ADVERTISEMENT GENERATION
A system and user interface capable of effectively manipulating high volumes of data is provided. The system and/or user interface is specially-configured to aggregate large data volumes and translate the large data volumes into summary information associated with navigable categorizations (e.g., categorizations linked to selectable visualizations in the user interface) that enable dynamic selection and visualization of portions of the large data volumes. In one particular example, the system and/or user interface is adapted to generate selectable panels having a plurality of build or editing tools displayed coextensive with portions of the large volumes of data. Such panels may be particularly useful for generating a placement (e.g., an advertisement) while reviewing or managing large amounts of information, such as ad placement and performance information for hundreds or thousands or advertisements.
Latest Nanigans, Inc. Patents:
- System for high volume data analytic integration and channel-independent advertisement generation
- Graphical user interface for high volume data analytics
- MANAGEMENT SYSTEM FOR HIGH VOLUME DATA ANALYTICS AND DATA INGESTION
- SYSTEM FOR HIGH VOLUME DATA ANALYTIC INTEGRATION AND CHANNEL-INDEPENDENT ADVERTISEMENT GENERATION
- SYSTEM FOR HIGH VOLUME DATA ANALYTIC INTEGRATION AND CHANNEL-INDEPENDENT ADVERTISEMENT GENERATION
This application 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, each of which applications are incorporated herein by reference in their entirety.
BACKGROUNDConventional systems provide some features to manage large numbers of placements (e.g., advertisements) and further provide for management of those placements over a number of delivery channels. Some drawbacks to existing systems include the inability to effectively manage and access high data volumes associated with large numbers of active placements. Further difficulties are presented when the active placements cross delivery channels (e.g., social media networks, blogs, live feeds, service sites, etc.). Often, the end user suffers from these difficulties and can be overwhelmed by the volume of information and the inability to drill into relevant information while preserving context.
SUMMARYAccording to various aspects of the present invention, a system and user interface capable of effectively manipulating high volumes of data is provided. The system and/or user interface is specially-configured to aggregate large data volumes and translate the large data volumes into summary information including navigable categorizations (e.g., categorizations linked to selectable visualizations in the user interface) that enable dynamic selection and visualization of portions of the large data volumes. In one example, the system and/or user interface is adapted to generate selectable panels having a plurality of build or editing tools displayed coextensive with portions of the large volumes of data. Such panels may be particularly useful for generating a placement (e.g., an advertisement) while reviewing or managing large amounts of information, such as ad placement and performance information for hundreds or thousands or advertisements.
According to one embodiment, the plurality of build and/or editing tools are configured in the user interface to be accessible co-extensive with visualizations of the large data volumes (including, for example, performance information and grouping information for thousands of placements). In some implementations a build panel interface provides access to the build and/or editing tools that is displayed in conjunction with the large data volumes shown a main display. The user interface generates the build panel to include continuous state monitoring and updating. In one example, the continuous state monitoring and updating includes, persistence of any selection with in the large data volumes. For example, selection of an placement in a main portion of the display is configured to capture associated information for the placement, and populate the associated information as selections in the build panel for creating new placements.
According to one embodiment, the user interface is configured to constantly monitor selections in the main body of the display, so information from any number of placements can be captured and persisted through a series of build tools shown in the build panel. In further embodiments, additional selections in the main body of the display trigger updates in information throughout a series of build tools shown in the build panel. In another embodiment, each of the build tools can be displayed as its own element or sub-display in the build panel. The system can be configured to enable user navigation through the elements or sub-displays as a sequence to build new placements. Further, the system enables selection of the elements or sub-displays out of order, and enables re-visiting of any element or sub-display, all without leaving the context provided via the main body of the display. Providing real time access to users to constantly updating information on any number of placements while enabling construction of new placements significantly improves the execution efficiency of the underlying system. Rather than forcing the user to navigate through numbers of different displays to simply access relevant information, the novel user interface not only enables access but reduces computer operations necessary to capture the same information and to utilize that information in build environments. In some embodiments, the user interface manages constantly updating information obtained on large volumes of placements, and enables transitions to and between management displays and management functions while preserving contextual information relevant to the management displays and management functions. In some embodiments, the transitions between views and/or the introduction of management function displays are configured to automatically resize currently visualized metrics and selectively obscure other metrics to transition management functional visualizations into the current display.
It is appreciated that in conventional systems for developing placements (e.g., advertisements), there is often a lag and disconnect between the system for analyzing success or failure advertisements (e.g., those placed on the Internet and in on-line applications (e.g., FACEBOOK)), and using such information for creating new advertisements. Such conventional analysis processes are generally manual ones involving a great amount of time and effort as there is often no link between the systems that permit users to view the performance of existing advertisements and the systems used to create new advertisements.
According to various aspects, a system and associated user interfaces are provided that permit a user to more easily analyze the performance of existing placements (e.g., advertisements) and use such information to improve the chances of success for new placements. According to further aspects, a system is provided that permits high data volume visualization (e.g., 50K, 60K, 70K, 80K, 90K, 100K, 110K+ rows of individual ad placement instances and data in a table), such as advertising data. In at least one embodiment, the system includes at least one processor operatively connected to a memory, the at least one processor when executing, is configured to manage display of high data volumes in a user interface, generate a user interface (“UI”) configured to dynamically generate a visual display of high data volumes, the data including advertising data corresponding to at least a first advertisement, responsive to selection within the visual display of the advertising data of a build function, capturing constituent elements of one or more placements (e.g., advertisements that are shown), wherein the constituent elements of the one or more placements include at least a creative parameter, an audience parameter, and a context parameter, and maintain the visual display of the high data volumes, including persisting display of the advertising data and automatically generating a build panel including one or more selectable build tools corresponding to generation of at least a second advertisement.
In one embodiment, the UI component is adapted to automatically generate and visualize the build panel responsive to activation of a build indicator included in the visual display of the high data volumes, wherein a main body of the visual display of high data volumes resizes responsive to visualization of the build panel. According to an embodiment, the UI component is further adapted to automatically generate an editing panel including one or more selectable edit tools corresponding to the at least first advertisement, and automatically generate and visualize the build panel responsive to activation of a build indicator included in the editing panel, wherein a main body of the visual display of high data volumes resizes responsive to visualization of the build panel. In a further embodiment, the UI component is further adapted to terminate visualization of the build panel and automatically resize the main body of the visual display. The resizing operations and selective obscuring of data can be specifically tailored to the management functions being accessed. In one example, the user interface is configured to analyze a current view state (including, for example, data fields being visualized) to determine what data visualizations to resize and what data visualizations to obscure with an introduction of a management display panel. Tailored resizing and/or obscuring of information enables the system to present contextual data to the used relevant to the management functions and reduces the need for the user to transition through multiple display screens to obtain necessary information.
According to one embodiment, the UI component is adapted to display the advertising data corresponding to the at least first advertisement in a selectable pivot table display. In an embodiment, the advertising data includes advertising data metrics, and the UI component is further adapted to analyze and group the advertising data 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) adapted for display in the visual display of the high data volumes. In a further embodiment, the UI component is further adapted to dynamically generate information dimension visual displays on historical advertising metrics responsive to user selection of information dimensions associated with the at least first advertisement.
In one embodiment, the one or more selectable build tools are adapted to define advertisement parameters of the at least a second advertisement including a creative parameter, an audience parameter, and a context parameter, wherein the creative parameter corresponds to content, the audience parameter corresponds to a targeted audience, and the context parameter corresponds to a method of targeting the targeted audience. In a further embodiment, the creative parameter, audience parameter, and context parameter include generic field data translated in a destination language format. In one embodiment, at least one of the creative parameter, audience parameter, and context parameter of the at least second advertisement includes a constituent element of the at least first advertisement. According to one embodiment, the second advertisement further includes a third advertisement, and wherein the one or more selectable build tools are adapted to define advertisement parameters simultaneously for the second advertisement and the third advertisement. In one embodiment, the at least one processor is further adapted to execute a series of build validation rules corresponding to at least one of the creative parameter, the audience parameter, and the context parameter, of the at least second advertisement and wherein the UI component is further adapted to dynamically generate a validation display, the validation display including a result of the execution of the build validation rules. In one embodiment the build panel including one or more selectable build tools corresponding to generation of the at least second advertisement further includes a plurality of selectable tabs, each tab of the plurality corresponding to one of the creative parameter, the audience parameter, and the context parameter of the at least second advertisement, the activation of which causes the UI component to transition the build panel to a display corresponding to the selected tab. In a further embodiment, the plurality of selectable tabs is arranged in a vertical orientation along a perimeter of the build panel.
According to another aspect, a system is provided that permits generating and displaying a graphic user interface for high volume data. In one embodiment the system includes at least one processor operatively connected to a memory, the at least one processor when executing, adapted to generate performance information corresponding to advertisement data for a plurality of advertisements, and a user interface (“UI”) component adapted to receive the performance information corresponding to the plurality of advertisements, analyze and group the performance information into an advertising demographic hierarchy adapted for display in a selectable visual interface, responsive to selection within the visual display of the advertising, capturing constituent elements of one or more placements (e.g., advertisements), wherein the constituent elements of the one or more placements include at least a creative parameter, an audience parameter, and a context parameter, and generate and visualize a build panel in the selectable visual interface coextensive with the advertising demographic hierarchy, the build panel providing a plurality of selectable build tools corresponding to generation of a new advertisement.
In one embodiment, the UI component is adapted to automatically generate the build panel responsive to activation of at least a build indicator included in the selectable visual interface, wherein a main body of the selectable visual interface resizes responsive to visualization of the build panel. According to another embodiment, wherein the UI component is further adapted to generate an editing panel for display in the selectable visual interface coextensive with the advertising demographic hierarchy, the editing panel providing a plurality of selectable edit tools corresponding to management of the performance information, and automatically generate and visualize the build panel responsive to activation of at least a build indicator included in the editing panel, wherein a main body of the selectable visual interface resizes responsive to visualization of the build panel. In a further embodiment, the UI component is further adapted to terminate visualization of the build panel and automatically resize the main body of the visual display.
According to one embodiment, the UI component is further adapted to dynamically generate visual displays on the performance information responsive to user selection of information dimensions associated with at least one advertisement of the plurality of advertisements. In an embodiment, the plurality selectable build tools are adapted to define advertisement parameters of the new advertisement including a creative parameter, an audience parameter, and a context parameter, wherein the creative parameter corresponds to content, the audience parameter corresponds to a targeted audience, and the context parameter corresponds to a method of targeting the targeted audience.
According to various aspects, a system is provided that permits generating and displaying a graphical user interface for high volume data, the system including at least one processor operatively connected to a memory, the at least one processor when executing, adapted to analyze and group advertising data into an advertising demographic hierarchy, determine summary information for the advertising data in each level of the advertising demographic hierarchy, and generate a navigable user interface display including a visual display of the advertising demographic hierarchy, and a build panel including one or more selectable build tools corresponding to generation of at least a first new advertisement.
In one embodiment, the advertising data includes advertising metrics (e.g., site, budget pool, strategy group, ad set, placement, among other options). According to a further embodiment, the build panel is viewable coextensive with the visual display of the advertising demographic hierarchy along a perimeter of the visual display of the advertising demographic hierarchy.
One aspect is directed to system for high volume data visualization. In one embodiment the system includes at least one processor operatively connected to a memory, the at least one processor adapted to execute a plurality of system layers, wherein the system layers include a data analytics layer adapted to organize and render recursive advertisement data hierarchies such that the recursive hierarchies define sub-sets of hierarchical advertisement data, the recursive advertisement data hierarchies being displayed in a visual display, an advertisement build layer adapted to receive definition a plurality of build parameters of a new advertisement, the plurality of build parameters including a creative parameter, an audience parameter, and a context parameter, the build parameters defined according to activation of build tools provided in a build panel displayed in the visual display coextensive with the recursive advertisement data hierarchies, and a campaign configuration layer adapted to define a rules-based campaign configuration.
In one embodiment, the system layers include a data management layer interconnected with the data analytics layer, the data management layer being adapted to manage advertisement data metrics corresponding to the recursive advertisement data hierarchies. According to one embodiment, the system layers include a cross-channel generics layer interconnected with the advertisement build layer and the data analytics layer, the cross-channel generics layer adapted to import advertisement data from data analytics layer to define at least one of the creative parameter, audience parameter, and context parameter for the new advertisement.
According to one embodiment, the system layers include an advertisement representation layer interconnected with at least the cross-channel generics layer, the advertisement representation layer adapted to assemble the new advertisement based on the defined advertisement parameters, wherein each advertisement parameter includes generic field data. In one embodiment, the system layers include a channel translation layer, the channel translation layer adapted to translate the generic field data to a format of a channel destination. According to one embodiment, the system layers include a predictive, analytics, and optimization layer interposed between the advertisement representation layer and the campaign configuration layer, the predictive, analytics, and optimization layer adapted to provide one or more advertisement parameter suggestions.
According to one aspect a user interface for high volume data visualization, analysis, and management are provided. The user interface comprises at least one processor operatively connected to a memory, the at least one processor when executing, configured to manage display of high data volumes in a user interface, a user interface (“UI”) component, executed by the at least one processor, configured to dynamically generate a visual display of high data volumes, the data including placement data corresponding to at least a first placement for electronic delivery through at least one electronic media channel, responsive to selection within the visual display of data associated with a plurality of placements of a build function, capture constituent elements of one or more placements selected in the user interface, wherein the constituent elements of the one or more placements include at least a creative parameter, an audience parameter, and a context parameter, and maintain in a first portion of the visual display, the display of the high data volumes and the placement data, wherein the UI component is further configured to automatically persist and resize at least a portion of the high data volume including the placement data in the first portion of the visual display, and generate a build panel display including one or more selectable build tools corresponding to generation of at least a second placement in a second portion of the visual display.
According to one embodiment, the UI component is configured to automatically generate and visualize the build panel in the second portion of the visual display responsive to activation of a build indicator included in the visual display of the high data volumes, wherein a main body of the visual display of high data volumes resizes responsive to visualization of the build panel to become the first portion of the visual display. According to one embodiment, the UI component is further configured to automatically generate an editing panel including one or more selectable edit tools, wherein the edit tools capture and provide prefilled data fields corresponding to the at least a first placement or data structure visually selected in the main body of the display, and automatically generate and visualize the build panel responsive to activation of a build indicator associated with the editing panel, wherein a main body of the visual display of high data volumes resizes responsive to visualization of the build panel. According to one embodiment, the UI component is further configured to, render the editing panel as an element of the build panel, and enable navigation between the build panel elements and the editing panel responsive to selection of respective tabs displayed in the build panel.
According to one embodiment, the UI component is configured to display the advertising data corresponding to the at least first advertisement in a selectable pivot table display. According to one embodiment, the placement data includes advertising data metrics, and the UI component is further configured to analyze and group the placement data metrics into an advertising demographic hierarchy adapted for display in the visual display of the high data volumes. According to one embodiment, the UI component is further configured to dynamically generate information dimension visual displays on historical advertising metrics responsive to user selection of information dimensions associated with the at least first advertisement. According to one embodiment, the one or more selectable build tools are configured to define advertisement parameters of the at least second advertisement including a creative parameter, an audience parameter, and a context parameter, wherein the creative parameter corresponds to content, the audience parameter corresponds to a targeted audience, and the context parameter corresponds to a method of targeting the targeted audience.
According to one embodiment, the creative parameter, audience parameter, and context parameter include generic field data translated in a destination language format. According to one embodiment, at least one of the creative parameter, audience parameter, and context parameter of the at least second advertisement includes a constituent element of the at least first advertisement. According to one embodiment, the second advertisement further includes a third advertisement, and wherein the one or more selectable build tools are configured to define advertisement parameters simultaneously for the second advertisement and the third advertisement. According to one embodiment, the at least one processor is further configured to execute a series of build validation rules corresponding to at least one of the creative parameter, the audience parameter, and the context parameter, of the at least second advertisement and wherein the UI component is further configured to dynamically generate a validation display, wherein the validation display including a result of the execution of the build validation rules.
According to one embodiment, the user interface component is further configured to generate the build panel including one or more selectable build tools corresponding to generation of the at least second advertisement, wherein the display of the build panel includes a plurality of selectable tabs, each tab of the plurality corresponding to one of the creative parameter, the audience parameter, and the context parameter of the at least second advertisement, the activation of which causes the UI component to transition the build panel to a display corresponding to the selected tab, and wherein the plurality of selectable tabs are displayed in the user interface responsive to accessing associated build functions in the build panel.
According to one embodiment, the plurality of selectable tabs is arranged in a vertical orientation along a perimeter of the build panel. According to one embodiment, the user interface of claim 1, wherein the user interface component is further configured to render a first sub-set of hierarchical advertisement data, and render selections of additional sub-sets of hierarchical advertisement data responsive to scrolling through a prior sub-set of advertisement data. According to one embodiment, the user interface component is further configured to access a data analytics layer, wherein the analytics layer is configured to generate recursive advertisement data hierarchies such that the recursive hierarchies define sub-sets of hierarchical advertisement data, the recursive advertisement data hierarchies.
According to one embodiment, the data analytics layer is further configured to recursively partition advertisement data until a respective partition of the advertisement data can be loaded via the user interface component in less than one second. According to one embodiment, the user interface component is configured to monitor rendering time on user devices. According to one embodiment, the user interface component is configured to access or derive a rendering time responsive to analyzing historic data (e.g., generate average rendering time per row of data, generate average rendering time per row of data filtered by device class or type (e.g., mobile device, laptop, etc.) or type of network, among other options). According to one embodiment, the data analytics layer is further configured to determine partition size based on evaluation of at least historic data of rendering time.
According to one aspect a system for generating and displaying a graphical user interface for high volume data is provided. The system comprises at least one processor operatively connected to a memory, the at least one processor when executing, adapted to, analyze and group advertising data into an advertising demographic hierarchy, determine summary information for the advertising data in each level of the advertising demographic hierarchy, and a navigable user interface display including, a visual display of the advertising demographic hierarchy, and a build panel visualization including one or more selectable build tools corresponding to generation of at least a first new advertisement, wherein the system is configured to trigger visualization of the build panel responsive to selection with the navigable user interface, and responsive to selection display a transition whereby the build panel is introduced into the navigable user interface from a boarder position, and the prior visualized display is automatically resized to incorporate the visualization of the build panel.
According to one aspect a system for high volume data visualization, analysis, and management, are provided. The system comprises at least one processor operatively connected to a memory, the at least one processor when executing, configured to manage display of high data volumes in a user interface, a user interface (“UI”) component, executed by the at least one processor, configured to, dynamically generate a visual display of high data volumes, the data including placement data corresponding to at least a first placement for electronic delivery through at least one electronic media channel, responsive to selection within the visual display of data associated with a plurality of placements of a build function, capture constituent elements of one or more placements selected in the user interface, wherein the constituent elements of the one or more placements include at least a creative parameter, an audience parameter, and a context parameter, and maintain in a first portion of the visual display, the display of the high data volumes and the placement data, wherein the UI component is further configured to, automatically persist and resize at least a portion of the high data volume including the placement data in the first portion of the visual display, and generate a build panel display including one or more selectable build tools corresponding to generation of at least a second placement in a second portion of the visual display.
According to one embodiment, the UI component is configured to automatically generate and visualize the build panel in the second portion of the visual display responsive to activation of a build indicator included in the visual display of the high data volumes, wherein a main body of the visual display of high data volumes resizes responsive to visualization of the build panel to become the first portion of the visual display. According to one embodiment, the UI component is further configured to automatically generate an editing panel including one or more selectable edit tools, wherein the edit tools capture and provide prefilled data fields corresponding to the at least a first placement or data structure visually selected in the main body of the display, and automatically generate and visualize the build panel responsive to activation of a build indicator associated with the editing panel, wherein a main body of the visual display of high data volumes resizes responsive to visualization of the build panel.
According to one embodiment, the UI component is further configured to render the editing panel as an element of the build panel, and enable navigation between the build panel elements and the editing panel responsive to selection of respective tabs displayed in the build panel. According to one embodiment, the UI component is configured to display the advertising data corresponding to the at least first advertisement in a selectable pivot table display. According to one embodiment, the placement data includes advertising data metrics, and the UI component is further configured to analyze and group the placement data metrics into an advertising demographic hierarchy adapted for display in the visual display of the high data volumes. According to one embodiment, the UI component is further configured to dynamically generate information dimension visual displays on historical advertising metrics responsive to user selection of information dimensions associated with the at least first advertisement.
According to one embodiment, the one or more selectable build tools are configured to define advertisement parameters of the at least second advertisement including a creative parameter, an audience parameter, and a context parameter, wherein the creative parameter corresponds to content, the audience parameter corresponds to a targeted audience, and the context parameter corresponds to a method of targeting the targeted audience. According to one embodiment, the creative parameter, audience parameter, and context parameter include generic field data translated in a destination language format. According to one embodiment, at least one of the creative parameter, audience parameter, and context parameter of the at least second advertisement includes a constituent element of the at least first advertisement. According to one embodiment, the at least second advertisement further includes a third advertisement, and wherein the one or more selectable build tools are configured to define advertisement parameters simultaneously for the second advertisement and the third advertisement. According to one embodiment, the at least one processor is further configured to execute a series of build validation rules corresponding to at least one of the creative parameter, the audience parameter, and the context parameter, of the at least second advertisement and wherein the UI component is further configured to dynamically generate a validation display, wherein the validation display including a result of the execution of the build validation rules.
According to one embodiment, the user interface component is further configured to generate the build panel including one or more selectable build tools corresponding to generation of the at least second advertisement, wherein the display of the build panel includes a plurality of selectable tabs, each tab of the plurality corresponding to one of the creative parameter, the audience parameter, and the context parameter of the at least second advertisement, the activation of which causes the UI component to transition the build panel to a display corresponding to the selected tab, and wherein the plurality of selectable tabs are displayed in the user interface responsive to accessing associated build functions in the build panel. According to one embodiment, the plurality of selectable tabs is arranged in a vertical orientation along a perimeter of the build panel.
According to one aspect a computer implemented method for high volume data visualization, analysis, and management are provided. The method comprises dynamically generating, by at least one processor, a visual display of high data volumes, the data including placement data corresponding to at least a first placement for electronic delivery through at least one electronic media channel, capturing, by the at least one processor, constituent elements of one or more placements selected in the user interface, responsive to selection within the visual display of data associated with a plurality of placements of a build function, wherein the constituent elements of the one or more placements include at least a creative parameter, an audience parameter, and a context parameter, and maintaining, by the at least one processor, in a first portion of the visual display, the display of the high data volumes and the placement data, wherein the act of maintaining includes acts of automatically persisting and resizing at least a portion of the high data volume including the placement data in the first portion of the visual display, and generating a build panel display including one or more selectable build tools corresponding to generation of at least a second placement in a second portion of the visual display.
According to one embodiment, the method automatically generating and visualizing the build panel in the second portion of the visual display responsive to activation of a build indicator included in the visual display of the high data volumes, includes an act of resizing a main body of the visual display of high data volumes responsive to visualization of the build panel, and wherein the resized main body becomes the first portion of the visual display. According to one embodiment, the method further comprises automatically generating an editing panel including one or more selectable edit tools, wherein the edit tools capture and provide prefilled data fields corresponding to the at least a first placement or data structure visually selected in the main body of the display, automatically generating and visualizing the build panel responsive to activation of a build indicator associated with the editing panel, and resizing a main body of the visual display of high data volumes responsive to visualization of the build panel.
According to one embodiment, the method, further comprises rendering the editing panel as an element of the build panel, and enabling navigation between the build panel elements and the editing panel responsive to selection of respective tabs displayed in the build panel. According to one embodiment, the method further comprising displaying the advertising data corresponding to the at least first advertisement in a selectable pivot table display. According to one embodiment, the placement data includes advertising data metrics, and the method further comprise analyzing and grouping the placement data metrics into an advertising demographic hierarchy adapted for display in the visual display of the high data volumes. According to one embodiment, the method further comprises dynamically generating information dimension visual displays on historical advertising metrics responsive to user selection of information dimensions associated with the at least first advertisement.
According to one embodiment, the method defining advertisement parameters of the at least second advertisement including a creative parameter, an audience parameter, and a context parameter, wherein the creative parameter corresponds to content, the audience parameter corresponds to a targeted audience, and the context parameter corresponds to a method of targeting the targeted audience with the one or more selectable build tools in the user interface. According to one embodiment, the method further comprises an act of translating the creative parameter, audience parameter, and context parameter into a destination language format. According to one embodiment, at least one of the creative parameter, audience parameter, and context parameter of the at least second advertisement includes a constituent element of the at least first advertisement. According to one embodiment, the at least second advertisement further includes a third advertisement, and the method further comprises defining advertisement parameters simultaneously for the second advertisement and the third advertisement with the one or more selectable build tools.
According to one aspect system for generating and displaying a graphical user interface for high volume data, the system are provided. The system comprises at least one processor operatively connected to a memory, the at least one processor when executing, adapted to analyze and group advertising data into an advertising demographic hierarchy, determine summary information for the advertising data in each level of the advertising demographic hierarchy, and a navigable user interface display including a visual display of the advertising demographic hierarchy, and a build panel visualization including one or more selectable build tools corresponding to generation of at least a first new advertisement wherein the system is configured to trigger visualization of the build panel responsive to selection with the navigable user interface, and responsive to selection display a transition whereby the build panel is introduced into the navigable user interface from a boarder position, and the prior visualized display is automatically resized to incorporate the visualization of the build panel.
According to one aspect a system for high volume data visualization is provided. The system comprises at least one processor operatively connected to a memory, the at least one processor adapted to execute a plurality of system layers, wherein the system layers include a data analytics layer adapted to organize and render recursive advertisement data hierarchies such that the recursive hierarchies define sub-sets of hierarchical advertisement data, the recursive advertisement data hierarchies being displayed in a visual display, an advertisement build layer adapted to receive definition a plurality of build parameters of a new advertisement, the plurality of build parameters including a creative parameter, an audience parameter, and a context parameter, the build parameters defined according to activation of build tools provided in a build panel displayed in the visual display coextensive with the recursive advertisement data hierarchies, and a campaign configuration layer adapted to define a rules-based campaign configuration.
According to one embodiment, the system layers include a data management layer interconnected with the data analytics layer, the data management layer being adapted to manage advertisement data metrics corresponding to the recursive advertisement data hierarchies. According to one embodiment, the system layers include a cross-channel generics layer interconnected with the advertisement build layer and the data analytics layer, the cross-channel generics layer adapted to import advertisement data from data analytics layer to define at least one of the creative parameter, audience parameter, and context parameter for the new advertisement. According to one embodiment, the system layers include an advertisement representation layer interconnected with at least the cross-channel generics layer, the advertisement representation layer adapted to assemble the new advertisement based on the defined advertisement parameters, wherein each advertisement parameter includes generic field data.
According to one embodiment, the system layers include a channel translation layer, the channel translation layer adapted to translate the generic field data to a format of a channel destination. According to one embodiment, the system layers include a predictive, analytics, and optimization layer interposed between the advertisement representation layer and the campaign configuration layer, the predictive, analytics, and optimization layer adapted to provide one or more advertisement parameter suggestions.
According to one aspect system for generating and displaying a graphical user interface for high volume data is provided. The system comprises at least one processor operatively connected to a memory, the at least one processor when executing, adapted to analyze and group advertising data into an advertising demographic hierarchy, determine summary information for the advertising data in each level of the advertising demographic hierarchy, and generate a navigable user interface display including a visual display of the advertising demographic hierarchy, and a build panel including one or more selectable build tools corresponding to generation of at least a first new advertisement.
According to one embodiment, the advertising data includes advertising metrics (e.g., site, budget pool, strategy group, ad set, placement, among other options). According to one embodiment, the build panel is viewable coextensive with the visual display of the advertising demographic hierarchy along a perimeter of the visual display of the advertising demographic hierarchy.
Still other aspects, embodiments, and advantages of these exemplary 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:
Various aspects and embodiments are directed to a system and or user interface for engaging with high volumes of data, and in particular high volumes of advertising data (also referred to herein as advertising information). In practice, there may be millions or more of advertisements that can be analyzed in real time and used for generating new advertisements. Aspects and embodiments may include a user interface adapted to dynamically generate a navigable visual display of high volumes of data and generate a build panel including one or more selectable build tools corresponding to generation of advertisements. The user interface is specially-adapted to persist display of the high volumes of data while coextensively displaying the build panel such that the data may be managed and/or reviewed simultaneous with definition of parameters of the advertisements to be generated. Accordingly, various aspects and embodiments discussed herein improve the user experience of a conventional advertising management system by increasing organization and access to more relevant detailed metrics and analytics, while also fundamentally improving the functioning of the advertising management system itself (i.e., speed and efficiency).
Further embodiments augment the executional efficiency of the system itself via build panel displays that are introduced into contextually relevant information displays. For example, automated transitions in the user interface reformat and/or resize displayed data to incorporate build panel functions, integrating information access previously maintained separately. These dynamic integrations enable access to constantly updated information, while streamlining build functions for user selection. In another example, the dynamic integration reduces the number of screens and/or system transitions that need to be visualized by the system, and thereby reduces the processing and memory required to perform the same operations with access to the same information over conventional approaches.
In further embodiments, selections made in the user interface main body can be incompatible with selections in the build panel. For example, the build panel enables construction of multiple placements across a variety of delivery channels simultaneously. A selection in the main body of a channel specific placement can yield options incompatible with the variety of delivery channels already selected. In some embodiments, the system is configured to validate any context selections made in the main body of the display. For example, validation can reference criteria for selected placements parameters (e.g., an audience value) and criteria associated with selected delivery channels to ensure compatibility. Where incompatibility is detected the system can be configured to transition automatically to a build tool display containing the incompatible information (if not already there) and highlight the identified issue. In further examples, the system can identify the issue, generate a solution (e.g., finding a similar compatible audience selection for the channel), and allow the user to undo the identified solution in the user interface, if desired.
Example Display SystemUser interface 100 includes an example of a summary view tailored for understanding and summarizing metrics associated with advertisement data associated within individual advertisements. A main body 102 of the display includes a listing of advertisement data for individual advertisements 104A-C . . . , each advertisement 104A organized by one or more advertisement parameters 106A-E, such as a creative parameter 106C, an audience parameter 106A, and a context parameter 106B. While other advertisement parameters may be used, in one embodiment, the creative parameter corresponds to content of an advertisement (e.g., 104A-C . . . ), the audience parameter corresponds to a targeted audience, and a context parameter corresponds to a method of targeting the audience. Each advertisement parameter includes a segment of the advertisement data which defines the particular advertisement or information on the particular advertisement. In various embodiments, receiving, segmenting, and providing advertisement data as one or more advertisement parameters enables a user to more easily review and comprehend analytics and metrics associated with an advertisement. For instance, the user interface 100 may generate and display in the main body 102 analytics corresponding to the particular audience parameter of an advertisement (e.g., 104A-C . . . ) permitting a user to determine whether that advertisement is performing well for a given audience, or whether the targeted audience needs to be edited.
In one embodiment, and as shown in
Similarly, each advertisement parameter 106 may include groupings of advertisement attributes which can be expanded in the user interface 100 via selection. Within each parameter, multiple attributes may be selected to define that particular parameter. For instance, an audience parameter may include attributes corresponding to an audience location, gender, age, spoken language, TV show, followers, similar followers, interests, keywords, among others. Activation of an advertisement parameter or one or more view tools within a view panel, such as the view panel discussed with reference below to
Turning briefly to
In various embodiments the user interface 200 further simplifies access to advertisement data and metrics. For instance, the user interface 200 is responsive to user actions of repositioning the display via a separator 206, as described above with reference to the user interface 100 of
Returning to
In various embodiments, the build panel 302 may be positioned along a perimeter of the user interface 300, such that a user may effectively review and/or manage advertisement data or metrics within the main body 304 while generating a new advertisement within the build panel 302. It is appreciated that often users will be interested in advertisements that are performing well, and accordingly, want to define the advertisement parameters of a new advertisement based on the advertisement parameters of those advertisements performing successfully (e.g., high conversion rates, high impressions, high views, etc.). Various aspects and embodiments address this desire by providing a build panel including or more selectable build tools adapted to define advertisement parameters for a new advertisement including advertisement parameters maintained from an advertisement included in the main display. Such aspects and embodiments are discussed in further detail below with reference to
In various embodiments, the user interface 300 is adapted to resize and/or reconfigure the main display 304, in addition to advertisement data or metrics within the main display 304, responsive to visualization of the build panel 302. While in some embodiments, the build panel 302 may be delivered “on top of” the main display 304, in various other embodiments, the user interface 300 performs one or more functions to reorganize advertisement data or metrics within the main display 304, such that view of the contents of the main display 304 is not obstructed. For instance, the user interface 300 may be adapted to visually compress in a horizontal direction the dimensions of the main display 304 and the contents therein. For instance, one or more functions may cause the user interface 300 to decrease a dimension of each column within the main display 304 by an incremental amount, where the incremental amounts when totaled substantially equal a horizontal dimension of the build panel 302. In various other embodiments, the user interface 300 may reconfigure the main display 304 to deliver advertisement data or metrics corresponding to data or metrics that would not be overlapped by the build panel 302. For instance, when a user interface of one embodiment transitions from a view similar to that shown in
Similarly, in some embodiments the user interface 300 is adapted to resize and/or reconfigure the main display 304, in addition to advertisement data or metrics within the main display 304, responsive to termination of the build panel 302. Such an event may occur when the user interface 300 generates a new advertisement, and transitions to a summary view, such as that shown in
As discussed above, and in further detail below, in various embodiments the build panel 302 may include a plurality of selectable tabs presented along an edge of the user interface 300, allowing the user to easily navigate among a plurality of active build panels. In such an embodiment, each active build panel may correspond to various additional advertisement parameters of a new advertisement, since advertisements may be constructed from numerous advertisement parameters (e.g., a creative parameter, an audience parameter, and a context parameter), which each may be constructed from further attributes (e.g., image, gender, etc.). Accordingly, in various embodiments, the user interface 300 may be adapted to visualize a second active build panel responsive to termination of a first build panel (e.g., build panel 302). The build panel 302 shown in
Turning to
In various embodiments, each build tool 504, such as the audience parameter tool, context parameter tool, and creative parameter tool, may be adapted to define the respective advertisement parameter responsive to selection of a new advertisement parameter, or selection of an advertisement parameter from a pre-existing advertisement, such as an advertisement listed in a main display 506 of the user interface 500. For instance, the user interface 500 may provide within the build panel 502 a “new” option 508 in addition to the drop down menu, or other input mechanism, of a build tool 504. Activation of the new option 508 transitions the user interface 500 to a display of a more detailed menu permitting the user to specify the attributes of the advertisement parameter corresponding to the selected build tool. In various embodiments, activation of an advertisement parameter within the drop down menu of a build tool 504 imports from the main display 506 the advertisement parameters or attributes corresponding to the advertisement parameter or attributes of an advertisement (or group) identified within the main display 506. For instance, the user interface 500 permits the user to identify advertisement parameters in the main display 506, populates a drop down menu of a build tool 504 with those identified advertisement parameters, and permits the user to define the new advertisement based on a selection of those attributes in the drop down menu. For instance,
In various embodiments, each build tool 504A-D (e.g., audience parameter build tool, context parameter build tool, and creative parameter build tool) may include a drop down menu (e.g., expansion box) including a listing of audience parameters or attributes. In contrast to defining a new advertisement parameter, each drop down menu provides a listing of pre-determined advertisement parameters corresponding to the particular build tool. For instance, the list of advertisement parameters may include the advertisement parameters of the advertisements listed in the main display 506.
In further embodiments, each build tool may enable a user to define more than one advertisement parameter at a time, or identify those advertisement parameters that will appear in the drop down menu of the build tool 504A-D. Such an embodiment is shown in the view of the user 500 interface in
In various embodiments, the build tools 504A-D are adapted to define more than one advertisement parameter or attribute. For example, the build tools 504A-D may permit a user to select two audience parameters, three context parameters, and five creative parameters. Such a situation would result in the generation of multiple new advertisements, the multiple advertisements covering each permutation of the combination of selected advertisement parameters. Accordingly, various aspects and embodiments further provide an efficient interface for generating multiple advertisements simultaneously.
In various embodiments, the build panel 504A-D includes a plurality of selectable tabs 704A-B, each tab corresponding to a particular advertisement parameter and including a plurality of build tools (e.g., build tools 504A-D) adapted to define that parameter. According to some embodiments, the selectable tabs (e.g., 704A-B) are displayed along a vertical edge of the build panel bar in the user interface. In some examples, this configuration minimizes the display footprint of the selectable tabs while preserving the user's ability to navigate within any of the parameters of the build panel. In further embodiments, the user is able to navigate within any parameter of the build panel without leaving the context shown in the main body and without leaving the build panel itself. In further examples, each navigation to a build panel parameter can trigger capture of any context information that has not already been captures. For example, context information associated with any selections in the main display 506 is captured an made available, for example, as a drop down selection in the build panel responsive to navigation into the build panel parameter.
Referring to
In some embodiments, the dynamic vertical navigation bar 812 is specially configured to minimize a display area occupied by the navigation bar 812. In various embodiments, displayable screen space is a scarce commodity, and minimizing the associated screen area for a display while making the associated functions available and useable improves the efficiency of the underlying computer system. For example, preserving context of the main display provides greater data availability and enables selection of the same, while navigating the adjacent build panel that dynamically populates displayed data fields based on the contextual selections in the main body 506. As discussed above, the user interface can automatically translate data selected in the main body 506 to channel agnostic data object that can be used in the build panel. In some examples, specific data may not have a translated data object, but the user interface can identify similar implementations for a given channel or data fields and automatically suggest the similar implementation or similar data field (e.g., by identifying similar named data fields across channels having similar data attributes (e.g., searching for similar field names, field attributes, etc.)).
Responsive to selection of a tab 704A-C, the user interface 500 is adapted to transition a display of the build panel 502 to an arrangement of build tools corresponding to the advertisement parameters or functions associated with the tab selected. For example, the view of
As discussed herein, in various embodiments, each build tool of a build panel of various embodiments, such as the audience parameter tool, context parameter tool, and creative parameter tool, may be adapted to define a respective advertisement parameter responsive to selection of a new advertisement parameter. For instance, activation of a new option (e.g. 804A-E) transitions the user interface 500 of
For purposes of explanation, the window 902 shown in the view of
In various embodiments, the user interface 500 is configured to dynamically generate a compatibility analysis of the new advertisement with one or more destination channels based on the specified advertisement parameters and attributes. It is appreciated that various destination channels may have limiting restrictions and capabilities. Accordingly, while the user is interacting with the one or more build tools of the window 902, the user interface 500 may be dynamically generating and displaying one or more indicators 910A-D providing the compatibility of the new advertisement with a particular destination platform. For instance, the view of
In various embodiments, a user interface component, or a component of a system including the user interface 500 (e.g., a translation component), dynamically executes one or more translation rules based on the particular selected parameters and attributes. Translation rules may include 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 and mappings to data structures used on the destination system. Accordingly, the translation component enables detection of compatibility of a specified attribute or parameter with a given destination channel. In particular, the translation component may include channel-specific modules which define channel restrictions and capabilities. Restrictions may reflect the structure of a particular channel, and may be dynamically created or queried from a destination channel via one or more APIs. Each channel-specific module communicates the particular capabilities via a cross-channel generics API within the system of one embodiment, which provides a common structured interface for such functionality. System structure, translation rules, and channel restrictions are further described below with reference to
Referring to
Turning now to
Referring to
Referring now to
As discussed above, the new advertisements may be grouped or displayed according to one or more demographic hierarchies. However, occasionally insufficient attributes will have been selected to properly define an advertisement parameter. Additionally, one or more advertisement parameters may have not been defined within the build panel 502. Generating an advertisement, or group of advertisements, based on such parameters (or the absence thereof) would lead to undesirable results such as incorrect advertisements, incorrect destination channel, misleading advertisements, or other advertisements that were not intended by the user. Accordingly, in various embodiments the user interface 500 is adapted to validate the selected advertisement parameters prior to generating the new advertisement or advertisement groups based on one or more executed validation rules. Validation rules may consist of pre-defined tests configured to verify the proper parameters have been defined to generate an advertisement. In various other embodiments, validation rules consist of pre-defined tests configured to detect duplicate advertisements.
In various embodiments, the validation rules are configured to validate the definitions defined by each build tool within the build panel. Responsive to executing the validation rules, one or more failures may result, and responsively, the user interface may generate an error message 1004 detailing such failure. In such an instance, the user interface 500 may be adapted to generate and display the error message 1004 in the build panel 502. In various other embodiments, execution of the validation rules may cause the user interface 500 to transition to a validation report delivered in one or more ad build validation windows.
In one particular implementation, the user interface 500 is adapted to dynamically generate a validation report window and display the validation window superimposed over the main display area and the build panel, as shown in the view of
As shown, and in various embodiments, an advertisement may fail an “ad is a duplicate” validation rule, where one or more processors in communication with the user interface 500 are configured to dynamically compare the advertisement parameters specified in the build panel 502 with the advertisement parameters of pre-existing advertisements. A direct match between advertisement parameters of a pre-existing ad and the specified new advertisement may result in the type of error shown. The validation report 1102 may provide one or more links, the activation of which causes the user interface 500 to transition to a visual display of the advertisement parameters, advertisement data, and/or advertisement metrics of the pre-existing duplicate advertisement. In further embodiments, selection of one or more buttons 1106 within the validation report 1102 causes the user interface 500 to proceed with generation of the new advertisement, cease generation of the new advertisement, or cease duplication of the advertisement, but persist tags specified for the new advertisement for the existing duplicate advertisements.
Turning now to
In the editing panel 1202, selection of each edit tool 1206 triggers the respective action for the specific editing tool. For instance, editing tools 1206 may correspond to activation, deletion, redeployment, changing a strategy group, or managing tags. Any editing tool 1206 selected within the editing panel 1202 can be executed on a particular advertisement within the main display 1204. For example, any editing tool 1206 shown in the editing panel 1202 can be executed on a user selected advertisement within the main display 1204. In various embodiments, editing tools 1206 may be executed on a group of selected advertisements as shown in the view of
In various embodiments, the user interface 1200 is adapted to automatically generate a build panel responsive to activation of a build indicator included in the editing panel. For instance, selection of the “clone” editing tool 1302 within the editing panel 1304 of
Returning to
In various embodiments, the system 1900 receives advertising data including advertising metrics from any number of advertising platforms or publishers of advertisements (i.e., channels). In one embodiment, the system 1900 is configured to automatically capture and aggregate advertisement data and metrics from the known FACEBOOK platform. In other embodiments the system 1900 is configured to automatically capture advertisement data from other systems (e.g., GOOGLE, YAHOO, etc.). The received data is processed and stored according to, for example, advertising type, advertising grouping, advertising targets, by one or more system components and, for example, at the data management layer. Various embodiments may include an ingestion subsystem, such as the ingestion subsystem 1802 described above in
The received data is processed through the channel translation layer 1914 to translate the data to a destination format language. In various embodiments, the translation layer 1914 includes a translation component 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 on the destination system. The translation component can then capture and fill destination formatted data structures containing all of the previous advertising information. In further embodiments, the translation component enables the destination system to use the historical advertising information as if it were originally created on the destination system. In particular, the channel translation layer 1914 may include channel-specific modules which define channel restrictions and capabilities. Restrictions may reflect the structure of a particular channel, and may be dynamically created or queried from a destination channel via one or more APIs. Each channel-specific module communicates the particular capabilities via a cross-channel generics API (e.g., cross-channel generics layer 1910) within the system of one embodiment, which provides a common structured interface for such functionality.
At the data management layer 1908, the received data and metrics are stored according to, for example, advertising type, advertising groupings, advertising targets. In one example, an analytic and grouping component of the performance subsystem 1804 of
According to one embodiment, the system 1900 presents a plurality of user interface layers that are presented to users of the system. The user interface layers are configured to organize and display advertisement data and metrics in a variety of summary views, a variety of detailed views, and organize and display any management functions and/or views, and one or more action panels such as a build panel, a view panel, or an editing panel. Various panels may be organized and displayed coextensively with each other and/or the display of the summary views, detailed views, and management functions or views, such that a user may individually interact with each panel. Such side by side views not only optimize inefficiencies in previous known unified user interface views, such improvements improve the underlying advertising management systems by increasing the speed at which data is available and the organization of information.
Further, because the volumes of data may be 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). As discussed above, information may be aggregated and for use in pivot tables that can be presented to users within a user interface, for instance by a performance subsystem, such as the performance subsystem 1804 of
In some embodiments, additional system components, user interface elements, and user interface displays can be also be provided to facilitate interaction with and to expedite display of any data associated with system managed media objects.
According to one embodiment, the system presents a unified UI layer 2310 that is presented to users of the system. The UI layer 2310 is configured to organize and display the variety of summary views 2312 (e.g., views 2500, 2700, 3500 of
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 2408). The web queue tier 2408 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 2410 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 2412, 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 2414 to determine the best attribution. Based on the data returned form MMP APIs, the system identifies a best attribution and stores the attribution information.
According to some embodiments, the UI layer 2310 is configured to generate and present tailored views to end user, where the views include navigable visualizations of advertising data.
For example, according to one embodiment, the UI layer can generated a user interface 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.
In further embodiments, the system can be configured to combine this information with data drawn from advertising publisher APIs (e.g., 2424) and RTB data streams (e.g., 2432), as well as various advertiser data sources (e.g., conveying conversion events at 2434), such as customer relation management (“CRM”) systems (e.g., 2428) and product and inventory feeds (e.g., 2426).
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; 100 thousand RTB events/second; 400 million user records; 100 million feed elements; 10 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., 2460) with a corresponding server-side API (e.g., 2458) that interfaces with the query engine (e.g., 2456). The javascript app issues data requests to the API (e.g., 2458) 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 that 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 such 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.
An example interface template for a inline summary view is shown in
In one example, the inline user interface display can include an ad preview portion for the inline display 2552. Proximately displayed at 2554 is a hierarchy display for accessing information on the ad placement being previewed, where the advertisement information is stored according to hierarchical layers. The hierarchy display 2554 can be configured to enable navigation between visualizations on the inline display showing respective layers and associated detail. In one example, responsive to selection in the hierarchy at 2554 an inline detail portion of the display 2556 provides additional information on the ad placement relevant to the selection made in 2554. In another example, the default display shown in 2556 is shown based on the first level of the hierarchy selected in 2554.
The display template can also include further selection menus to facilitate navigation within, for example, the inline display. In one embodiment, display section 2554 includes vertically arranged display of hierarchy objects, and each hierarchy object is associated with a display in section 2556. In another embodiment, a horizontally displayed inline menu section 2557 can enable further navigation through placement information (e.g., via hierarchy object selection at 2558), definitional selections associated with a given placement (e.g., via selection at 2560), targeting information (e.g., via selection at 2562), and may optionally include additional information menus (e.g., at 2564) to access information not categorized in the preceding options. Further examples of the user interfaces are shown and described in
Shown in
Summary view 2500 includes an example of a view tailored for understanding and summarizing metrics associated with individual advertisements. 101 In one embodiment, view 400 is configured to be introduced into a data-centric pivot table that allows dynamic navigation into more specific information. In one example, view 400 is generates a row in the data-centric pivot table and sized to span the width of available columns in the data-centric pivot table. At 2501, a preview of a specific ad is shown to provide a visual indicator and/or reference for a specific advertisement. A second portion of the display 2500 includes a plurality of drawers (e.g., 2502-110). According to one embodiment, each of the plurality of drawers is a navigable data and visual structure, that is executable via selection in the user interface.
The plurality of drawers are arranged in the visual display 2500 based on a hierarchy of groupings. In the example, the hierarchy includes a site grouping—value “AllModern”; Budget Pool grouping with value—“Gateway”; strategy group grouping with value “Gate Desk Feed CPC” (Cost Per Click); ad set grouping with an unique identifier for the ad set; and placement grouping with an unique identifier for the placement. Each drawer having more than one member in its associated grouping is configured to display membership information, for example, the number of members of the grouping. In one embodiment, the summary view 2500 includes a longitudinal menu 2518 for selecting a display format of the summary 2500. In one example, the display format includes a first default view showing an object hierarchy. The currently selected display format can be highlighted in the longitudinal menu 2518, for example, at 2520. Object 2522 is also configured to transition the user interface to summary 2500 via selection on 2522.
In further embodiments, each drawer includes an active state and a passive state. In a passive state grouping information, specific value, and membership number information can be displayed. Once selected, for example, by hovering with a user interface pointer or clicking with a user interface pointer—each drawer triggers display of an associated visualization, for example, the active state of the placement drawer triggers a display at 2512.
In some embodiments, the drawer is associated with a plurality of information view. Each view operates as a dynamic selection of data from the database that presents summary and/or aggregate information or in some alternative views and management information that can be used to add, modify, delete, and/or update advertising placements. At 2512 is shown some additional detailed information relating to the placement being visualized. In some examples, an initial view can include placement number, current bid, date created, a current bid type, ad group name, stop loss credit (for reactivating ads that would otherwise fail stop loss criteria), and an associated Facebook or other advertising source identifier. In some embodiments, selections made within summary view 2500 are reflected in real time on the data-centric pivot table, that summary view 2500 is integrated into. According to one aspect, the immediate connection between changes made in the summary view and the data-centric pivot table ensure accuracy in entered information (e.g., facilitates user understanding of context for each selection) and reduce errors in data entry as users reviews and/or manipulates thousands of advertisements. The views associated with a respective drawer in the active state can also include a graphical representation of the principal information for that view. In the initial view 2512, the principle information being conveyed to the user is bid amount for the advertising placement. At 2514, the initial view displays recent bids, bid time, and bid amount in a graphical form, so that the user is immediately provided a reference and recent historical window to understand how the current bid amount relates to the placement. Each active drawer view (e.g., initial view 2512) can include links to underlying information being displayed/summarized in the view (e.g., at 2516 a user can navigate to the underlying information being conveyed by the view). According to some embodiments, each active drawer can be associated with a plurality of views and can include additional summarizations of additional views.
According to one embodiment,
Various embodiments describe the summary views implemented as inline displays. According to some embodiments, the same functions can be implemented as overlay displays. According to one example, the overlay displays are positioned in the user interface to enable visualization of contextual information associated with a placement being reviewed in the overlay display.
Shown at 2604 is a view for conveying budgeting information across the gateway grouping. Included with the summary data 2606 is a graphical representation of the total budgetary information with reference to the portion of the total budgetary information made up by the strategy group at 2608. Responsive to accessing detailed information and/or selecting “Placement” in the vertical menu 2610, the system is configured to display action control s at 2612. The action controls are configured to start and stop advertisement bidding and/or execution in real time. For example, selection of 2602 triggers the action control to transition between active and paused states depending on a beginning state of the action control. In the illustrated example, 2602 is in a paused state, thus, selection at 2602 triggers a transition to an active state. In response to the transition to an active stated the system is configured to communication with a hosting system for the respective placement and activate any bidding instructions for executing the respective advertisement. In one example, the placement can be hosted on the known FACEBOOK platform, and the transition to active state is configured to cause the system to communicate with the FACEBOOK platform via an API executed on the system, that triggers bidding as defined on the system (e.g., in the placement details) and monitors spend and tracks performance of the placement. Transitions to a paused state perform similar operations in reverse (e.g., triggering an API to communicate with a hosting platform to suspend bidding activity). As any changes are made in the summary view, so to does the data-centric pivot table update any corresponding record in real time.
According another aspect, the high data volume analytic user interface is further configured to manage creation and/or modification of advertising placements or ads. The user interface includes selections for navigating to “creative details” associated with an advertisement. Similar to the view 2500, view 2700 includes a preview of an advertisement 2702, and a set of user interface drawers 2704-2718. Each drawer is selectable in the user interface and configured to present an associated view or associated information in an adjacent portion of the user interface (e.g., at 2720). The highlighted portions of the user interface examples shown in
As shown in
According to one embodiment, similar to changes made in view 2500, changes in view 2700 are reflected in the data-centric pivot table in real time. Additionally, as new data is captured by the system (e.g., via one or more APIs connected to respective hosting systems) entries in the data-centric pivot table update and provide real time contextual information, while a user is navigating summary views and/or summary information shown inline. In further embodiments, the system can delay updating of information to avoid confusion. For example, the system can operate on cached data and/or cached date results, and new data received by the system will not be updated until a cache invalidation event occurs. Cache invalidation can be executed based on detecting a period of time has elapsed, or identifying a threshold number of changes have occurred, among other options.
Additional views summarize the targeting information for a viewing user differently (e.g., 3600,
According to other embodiments, the user interface can include additional detailed displays of advertising metrics and/or data associated with managing an advertising network or campaign.
Shown
Other actions may be selected, including a menu option to access detailed logging activity. In one examples, a menu titles can specify “AI Logs,” which transitions the system to detailed logging information tracked by the system showing the automatic placement of ads according to artificial intelligence functions. More generally, various embodiments of the system are configured to tailor machine learning algorithms based on prior user's data. In one example, selections made in the user interface are tracked by the system constrained by a current state of the system that is associated with each selection. Machine learning matching and/or fitting can be used to predict what information subsequent users will find useful by matching similar or same states to various subsequent user contexts. The system can be configured to include matching information fields based on such learning algorithms. In some examples, user interface views can be tailored to highlight such fields, and/or tailored to include or exclude information fields based on matching.
Further, other actions may be performed, such as applying additional filters to the display (e.g., via the “Add Filters” action), isolating or eliminating certain ad placements from the display (e.g., via the “Only show this Placement ID” action or the “Exclude this Placement ID” action), or displaying detailed placement performance relating to the selected ad placement (e.g., via the “Placement Performance” action).
The summary displays aggregate the information being viewed in the detailed view organized based on the management function (e.g.,
According to one embodiment, a visual indication of a separator bar 4510 is shown. The user interface can be configured to be responsive to user actions associated with repositioning the separator 4510, so that a first portion of the display 4512 and a second portion of the display 4514 can be dynamically manipulated. For example, in response to the translation of the separator 4510 (e.g., moving the separator 4510 left or right in the display), additional advertisement data or metrics can be hidden or displayed in either of the first portion 4512 or the second portion of the display 4514.
In some embodiments, translation of the separator 4510 can trigger the user interface to automatically resize information displayed in the first and/or second portion of the view in the display, and in some examples, enable the user interface to continue to visualize the current advertising parameters 4516-4520, while introducing additional relevant information in the first portion of the display by manipulating the separator 4510. In some embodiments, detailed information fields are ordered automatically by the system and responsive to manipulations of the separator 4510, the detailed information is introduced into the display based on the system based ordering (e.g., spend 4516, impressions 4518, clicks 4520, etc.). In some alternatives, the system and/or user interface retains information on any modifications to a view that and end user selects, including for example, user specified ordering of column and/or selection/exclusion of columns to be displayed. In one example, the modifications to the view (e.g., data ordering, selected data elements, removed data elements, separator position, etc.) can be retained as a temporary view. The temporary view can be preserved across multiple logins, etc. but can also be subject to any latter modifications. In further embodiments, any changes a user wishes to maintain can be saved as user named views and made accessible through the user interface.
According to one embodiment, the operation/translation of separator bar 4510 is configured to operate only on the first portion and second portion of the user interface. In one example, the separator 4510 does not affect the display of an integrated summary view regardless of resizing the first portion and/or second portion of the display.
In other examples, summary information views can be combined with other graphical summarization information. For example,
In some examples, the system and/or user interface facilitates the consumption of large volumes of data associated with advertisement placement and execution. For example, the user interface provides a placement summary (e.g.,
Another option provided in some embodiments includes visualizations of the performance of an individual placement over time. In one example, selection in the user interface triggers the system to display a table and chart of how that ad placement performed over time. The display can dynamically refresh during viewing as additional advertising metrics are received by the system. In one example, the placement summary also provides additional information such as, AI Logs that allow a user to see more detail about optimization logic applied to a placement. In addition, the user can also view ad placement on advertising platforms (e.g., Facebook) to see comments, likes, and shares.
According to another aspect, generation of logical groupings of advertising types provides selectable options in the user interface that facilitate advertising management. Each grouping is responsive to mouse over operations to display information for matching. The Ad Type grouping remain the same across any view, and are selectable within the UI to display how each ad will be presented on Facebook.
In various examples, extremely long urls are handled by the system by creating shorter visualizations of the long urls.
Interfaces to such a system may include functions such as those discussed above in relation to
-
- Content metadata (i.e., creative parameter)
- Audience based metadata (i.e., audience parameter)
- Placement based data (i.e., context parameter).
Placement metadata may be stored in memory and, according to one embodiment, the data 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 metadata 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.
The query engine acts upon the data in memory using data agnostic actions (i.e. group, sort, where, having). 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)
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 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 data analytics and workflow architecture is capable of executing a more complex query in under 2 seconds.
In
Accordingly, the cross-channel generics layer 1910 is interconnected with the advertisement build layer 1904. The cross-channel generics layer 1910 is adapted receive user selected advertisement parameters and advertisement parameter attributes and deliver the received parameters and attributes to the advertisement representation layer 1912. For instance, in one embodiment, data is passed between the advertisement build layer 1904 and the cross-channel generics layer 1910 based on a JSON-RPC, wherein parameters are passed as an array or object. Accordingly, in one or more embodiments, one or more components at the cross-channel generics layer 1910 are adapted to capture advertisement data from the data analytics layer for at least one of the creative parameter, audience parameter, and context parameter for the new advertisement. Varying destination channels will have different organizations of advertisement attributes into parameters, and may have different representations of the attributes themselves. For example, a FACEBOOK channel may not provide a context parameter, and although the FACEBOOK and a TWITTER channel may both provide for language targeting, they may use different representations for the language attribute. The cross-channel generics layer 1910 provides translation of advertising parameters and a unified representation of attributes to support data transfer between the advertisement build layer 1904 and the channel-specific advertisement representation layer 1912 and the channel translation layer 1914. Accordingly, the cross-channel generics layer 1910 provides a common API and grammar rules for interfacing across destination channels, as well as defining a single set of representations for attributes that are common in meaning across channels (like country, gender, age, language, keyword targeting) but have channel-specific encoding.
The advertisement representation layer 1912 is interconnected with at least the cross-channel generics layer 1910 and data analytics layer 1902. In various embodiments, the advertisement representation layer 1912 is adapted to assemble the new advertisement based on the defined advertisement parameters and advertisement parameter attributes. In particular, each advertisement parameter or attribute may include a generic data object. For instance, one or more build subsystem, such as the build subsystem of
In
In various embodiments, the system 1900 includes a predictive, analytics, and optimization layer 1916 interposed between the advertisement representation layer 1912 and the campaign configuration layer 1906. The predictive, analytics, and optimization layer 1916 may be adapted to provide one or more advertisement parameter suggestions. In various embodiments the destination format is configured to enable predictive optimizations on the execution and management of individual advertisements, groups of advertisements, and entire advertising campaigns. In some embodiments, after receiving 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.
As described above, various embodiments include systems for high volume data visualization, and in particular, systems including a user interface component adapted to dynamically generate a visual display of high data volumes, the data including advertising data corresponding to at least a one advertisement. In at least one embodiment, advertising data includes advertising data metrics, and the user interface component is further adapted to analyze and group the advertising data 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) adapted for display in the visual display of the high data volumes. The user interface component may be further adapted to dynamically generate information dimension visual displays on historical advertising metrics responsive to user selection of information dimensions associated with the at least first advertisement.
In at least one embodiment, advertisement data or metrics are provided in one or more recursive row groupings. For example, if a “row group” of advertisement data is visible in the user interface and spans more than 10 rows, instead of filling memory or the user interface with all the advertisement data, the system subdivides the main row group into subsidiary “row groups” again. At each stage of data loading and/or visualization of each large group of data can be divided into a first hierarchical level, a first sub-level, a second sub-level, and further sub-levels until a manageable number of rows is achieved. In some embodiments, by applying this algorithm recursively, the system reduces need for large amounts of DOM elements down to an efficient level of DOM elements utilized in a display that allows users to access exceedingly large number of rows.
In further embodiments, searching for row groups that should be loaded into memory or shown the user interface is executed by the system as a tree search that generates and returns results efficiently. In one example, the system reduces the problems associated with loading and displaying a million rows into a logarithmic solution. In terms of a logarithmic solution, increasing the data size handled by the recursive row group solution by 10 fold adds only 10 new DOM elements to the execution. Thus, the problem is resolved up and until the point that backend delivery sets a processing ceiling, and also where the maximum height of a page that a browser can render is limited to approximately 32 million pixels.
In some embodiments, the underlying functions of row rendering and height approximation can be implemented with a variety of solutions. For example, there are many approaches for rendering that can include traditional table elements, sized “divs,” or more complex solutions like “display:box.” The various approaches can be integrated with recursive row grouping to build, load, and display massive lists of arbitrary elements.
In some embodiments, one or more filters provided by the user interface can include hierarchy aware filters. In one example, the filters listed are determined by the system based on a position in the hierarchical display of the data in the main body of the user interface 7202. In further embodiments, the filer bar 7204 includes a search tool for accessing a filter, sub-filter, or custom filter executable against the current data set. Selected filters are shown are the bottom of bar 7204 at 7210. The selected filters can be edited (e.g., via selection of 7212 or removed 7214. In other embodiments, filtering can be applied at any level of the data hierarchy.
As discussed above, 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 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.
Example Display ProcessAs described above with reference to
According to other embodiments, automated transitions in the user interface reformat and/or resize displayed data to incorporate build panel functions, integrating information access previously maintained separately. The dynamic integration and automatic display operations reduces the number of screens and/or system transitions that need to be visualized by the system, and thereby reduces the processing and memory required to perform the same operations with access to the same information over conventional approaches.
In various embodiments, the process 2100 includes the act of generating a visual display of high volumes of advertising data or metrics (act 2102). As described above with reference to
In act 2104, the process 2100 may include the act of receiving an input. For instance, in various embodiments receiving an input includes receiving user selection of the build indicator. As shown in the view of
In act 2106, responsive to the receipt of input (e.g., user selection of the build indicator), the process 2100 may include the act of generating and visualizing a build panel. In various embodiments, the build panel is displayed coextensively with advertisement data or metrics, such as advertisement data or metrics included in the main display of the user interface. In various embodiments, generating and visualizing the build panel includes positioning the build panel along a perimeter of the user interface, such that a user may effectively review and/or manage advertisement data or metrics within the main body while generating a new advertisement within the build panel. As described above with reference to the view of a user interface shown in
In act 2108, the process 2100 may include receiving selection of a build tool corresponding to generation of a new advertisement. In various embodiments, the build panel provides one or more build tools adapted to define advertisement parameters of a new advertisement to be generated. Each build tool may include one or more selectable objects or options the selection of which specifies the advertisement parameter, or in further embodiments, an attribute of an advertisement parameter. In various embodiments, the process 2100 may include defining a particular advertisement parameter (audience parameter, context parameter, or creative parameter) responsive to receipt of a parameter selection. In various embodiments, receiving a parameter selection includes receiving a selection from a user. Further processes for receiving selection of an advertisement parameter or attribute are described below with reference to
In act 2110, the process 2100 may include generating an advertisement based on at least the defined advertisement parameters. In various embodiments, act 2110 may include generating an advertisement based on a user defined creative parameter, context parameter, and audience parameter. Such advertisements parameters may be created according to user specified attributes, or captured from one or more advertisements within the main display of the user interface. Accordingly, various aspects and embodiments improve the user experience of a conventional data management system by increasing organization and access to more relevant detailed metrics and analytics, while also fundamentally improving the functioning of the data management system itself (i.e., speed and efficiency). That is, various embodiments permit a user to view and interact with advertisement data and metrics while concurrently generating a new advertisement.
Turning now to
In various embodiments, process 2200 includes the act of visualizing at least one build tool within a build panel of a user interface. As described herein, build tools are adapted to define advertisement parameters for a new advertisement. In various embodiments, visualizing at least one build tools includes visualizing a build tool for a creative parameter, a context parameter, an audience parameter, or attributes thereof. Build tools of various embodiments may include drop down menus, text based searches, series of buttons, series of check boxes, or any other tools capable of selecting an advertisement parameter. Similarly, the each build tool may include a drop down menu of attributes, a text based search, a series of buttons, a series of check boxes, or any other tool that is capable of selecting an advertisements parameter attribute.
At decision block 2204, the process 2200 includes determining whether a build tool has been selected. If a build tool has been selected, the process 2200 proceeds to decision block 2206. If a build tool has not been selected, the process 2200 returns to act 2202. At decision block 2206, the process 2200 includes determining whether a previously created advertisement, or group of advertisements, has been identified. In various embodiments, this may include determining whether the user has identified an advertisement within the main display of the user interface. If the system determines an advertisement or group of advertisements has been identified within the main display of the user interface, the user interface captures the constituent elements of the selected advertisement(s) (act 2208). In various embodiments, act 2208 may include importing from the main display one or more advertisement parameters or advertisement parameter attributes of the identified advertisements. For instance, the imported advertisement parameters may be displayed as selectable options within a drop down menu of a build tool.
At decision block 2210, the process 2200 includes determining if one or more of the parameters or attributes of a build tool have been selected. In various embodiments, selection of an advertisement parameter or advertisement parameter attribute may include selection within a drop down menu, for example. If a parameter or attribute has been selected, the process 2200 proceeds to act 2212 where the selected parameter is defined for the new advertisement. The process 2200 then returns to act 2202 and the user interface awaits selection of an advertisement parameter for another build tool.
If at decision block 2206 an advertisement has not been identified, or if at decision block 2210 no parameter or attribute has been selected, the process 2200 includes determining if a new option has been selected (decision block 2214). As discussed above with reference to at least
At decision block 2218, the process 2200 include determining if one or more attributes within the advertisement parameter attribute window have been selected. If attributes have been selected, the process proceeds to 2212 where the advertisement parameter of the new advertisement is defined based on the selected attributes within the advertisement parameter attribute window. In various embodiments this may include transitioning the visual display to terminate the advertisement parameter attribute window and return to a visual display of the build panel coextensive with advertisement data. However, if attributes have not been selected, the process returns to act 2216 where the user interface displays the advertisement parameter window.
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 5400 shown in
Referring to
As illustrated in
The memory 5412 stores programs (e.g., sequences of instructions coded to be executable by the processor 5410) and data during operation of the computer system 5402. Thus, the memory 5412 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 5412 may include any device for storing data, such as a disk drive or other nonvolatile storage device. Various examples may organize the memory 5412 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 5402 are coupled by an interconnection element such as the interconnection element 5414. The interconnection element 5414 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 5414 enables communications, including instructions and data, to be exchanged between system components of the computer system 5402.
The computer system 5402 also includes one or more interface devices 5416 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 5402 to exchange information and to communicate with external entities, such as users and other systems.
The data storage element 5418 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 5410. The data storage element 5418 also may include information that is recorded, on or in, the medium, and that is processed by the processor 5410 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 5410 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 5410 or some other controller causes data to be read from the nonvolatile recording medium into another memory, such as the memory 5412, that allows for faster access to the information by the processor 5410 than does the storage medium included in the data storage element 5418. The memory may be located in the data storage element 5418 or in the memory 5412, however, the processor 5410 manipulates the data within the memory, and then copies the data to the storage medium associated with the data storage element 5418 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 5402 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 5402 as shown in
The computer system 5402 may be a computer system including an operating system that manages at least a portion of the hardware elements included in the computer system 5402. In some examples, a processor or controller, such as the processor 5410, 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 5410 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. Use of at least one of and a list of elements (e.g., A, B, C) is intended to cover one selection from A, B, C (e.g., A), two selections from A, B, C (e.g., A and B), three selections (e.g., A, B, C), and multiples of each selection.
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 user interface for high volume data visualization, analysis, and management, the user interface comprising:
- at least one processor operatively connected to a memory, the at least one processor when executing, configured to manage display of high data volumes in a user interface;
- a user interface (“UI”) component, executed by the at least one processor, configured to: dynamically generate a visual display of high data volumes, the data including placement data corresponding to at least a first placement for electronic delivery through at least one electronic media channel; responsive to selection within the visual display of data associated with a plurality of placements of a build function, capture constituent elements of one or more placements selected in the user interface, wherein the constituent elements of the one or more placements include at least a creative parameter, an audience parameter, and a context parameter; and maintain in a first portion of the visual display, the display of the high data volumes and the placement data, wherein the UI component is further configured to: automatically persist and resize at least a portion of the high data volume including the placement data in the first portion of the visual display; and generate a build panel display including one or more selectable build tools corresponding to generation of at least a second placement in a second portion of the visual display.
2. The user interface of claim 1, wherein the UI component is configured to:
- automatically generate and visualize the build panel in the second portion of the visual display responsive to activation of a build indicator included in the visual display of the high data volumes, wherein a main body of the visual display of high data volumes resizes responsive to visualization of the build panel to become the first portion of the visual display.
3. The user interface of claim 1, wherein the UI component is further configured to:
- automatically generate an editing panel including one or more selectable edit tools, wherein the edit tools capture and provide prefilled data fields corresponding to the at least a first placement or data structure visually selected in the main body of the display; and
- automatically generate and visualize the build panel responsive to activation of a build indicator associated with the editing panel, wherein a main body of the visual display of high data volumes resizes responsive to visualization of the build panel.
4. The user interface of claim 3, wherein the UI component is further configured to:
- render the editing panel as an element of the build panel; and
- enable navigation between the build panel elements and the editing panel responsive to selection of respective tabs displayed in the build panel.
5. The user interface of claim 1, wherein the UI component is configured to display the advertising data corresponding to the at least first advertisement in a selectable pivot table display.
6. The user interface of claim 1, wherein the placement data includes advertising data metrics, and the UI component is further configured to analyze and group the placement data metrics into an advertising demographic hierarchy adapted for display in the visual display of the high data volumes.
7. The user interface of claim 6, wherein the UI component is further configured to dynamically generate information dimension visual displays on historical advertising metrics responsive to user selection of information dimensions associated with the at least first advertisement.
8. The user interface of claim 1, wherein the one or more selectable build tools are configured to define advertisement parameters of the at least second advertisement including a creative parameter, an audience parameter, and a context parameter, wherein the creative parameter corresponds to content, the audience parameter corresponds to a targeted audience, and the context parameter corresponds to a method of targeting the targeted audience.
9. The user interface of claim 8, wherein the creative parameter, audience parameter, and context parameter include generic field data translated in a destination language format.
10. The user interface of claim 9, wherein at least one of the creative parameter, audience parameter, and context parameter of the at least second advertisement includes a constituent element of the at least first advertisement.
11. The user interface of claim 8, wherein the second advertisement further includes a third advertisement, and wherein the one or more selectable build tools are configured to define advertisement parameters simultaneously for the second advertisement and the third advertisement.
12. The user interface of claim 8, wherein the at least one processor is further configured to execute a series of build validation rules corresponding to at least one of the creative parameter, the audience parameter, and the context parameter, of the at least second advertisement and wherein the UI component is further configured to dynamically generate a validation display, wherein the validation display including a result of the execution of the build validation rules.
13. The user interface of claim 8, wherein the user interface component is further configured to generate the build panel including one or more selectable build tools corresponding to generation of the at least second advertisement, wherein the display of the build panel includes a plurality of selectable tabs, each tab of the plurality corresponding to one of the creative parameter, the audience parameter, and the context parameter of the at least second advertisement, the activation of which causes the UI component to transition the build panel to a display corresponding to the selected tab, and wherein the plurality of selectable tabs are displayed in the user interface responsive to accessing associated build functions in the build panel.
14. The user interface of claim 13, wherein the plurality of selectable tabs is arranged in a vertical orientation along a perimeter of the build panel.
15. The user interface of claim 1, wherein the user interface component is further configured to render a first sub-set of hierarchical advertisement data, and render selections of additional sub-sets of hierarchical advertisement data responsive to scrolling through a prior sub-set of advertisement data.
16. The user interface of claim 15, wherein the user interface component is further configured to access a data analytics layer, wherein the analytics layer is configured to generate recursive advertisement data hierarchies such that the recursive hierarchies define sub-sets of hierarchical advertisement data, the recursive advertisement data hierarchies.
17. The user interface of claim 16, wherein the data analytics layer is further configured to recursively partition advertisement data until a respective partition of the advertisement data can be loaded via the user interface component in less than one second.
18. The user interface of claim 17, wherein the user interface component is configured to monitor rendering time on user devices.
19. The user interface of claim 18, wherein the user interface component is configured to access or derive a rendering time responsive to analyzing historic data (e.g., generate average rendering time per row of data, generate average rendering time per row of data filtered by device class or type (e.g., mobile device, laptop, etc.) or type of network, among other options).
20. The user interface of claim 19, wherein the data analytics layer is further configured to determine partition size based on evaluation of at least historic data of rendering time.
21. A system for generating and displaying a graphical user interface for high volume data, the system comprising:
- at least one processor operatively connected to a memory, the at least one processor when executing, adapted to: analyze and group advertising data into an advertising demographic hierarchy;
- determine summary information for the advertising data in each level of the advertising demographic hierarchy; and
- generate a navigable user interface display including: a visual display of the advertising demographic hierarchy; and a build panel visualization including one or more selectable build tools corresponding to generation of at least a first new advertisement
- wherein the system is configured to trigger visualization of the build panel responsive to selection with the navigable user interface, and responsive to selection display a transition whereby the build panel is introduced into the navigable user interface from a boarder position, and the prior visualized display is automatically resized to incorporate the visualization of the build panel.
Type: Application
Filed: May 27, 2016
Publication Date: Dec 15, 2016
Applicant: Nanigans, Inc. (Boston, MA)
Inventors: Claude Denton (Lexington, MA), Ric Calvillo (Chestnut Hill, MA), Joshua Allen Breckman (Arlington, MA), Per Anders Sandell (Boston, MA), Derek J. Yimoyines (Winchester, MA), Amit Deepak Adur (Chino Hills, CA), Christopher Connors (Cambridge, MA), Jonathan Palmer (Belmont, MA)
Application Number: 15/166,852