Interactive user interface for dynamic data analysis exploration and query processing

Information

  • Patent Grant
  • 10157200
  • Patent Number
    10,157,200
  • Date Filed
    Thursday, April 7, 2016
    8 years ago
  • Date Issued
    Tuesday, December 18, 2018
    6 years ago
Abstract
The systems and methods described herein provide highly dynamic and interactive data analysis user interfaces which enable data analysts to quickly and efficiently explore large volume data sources. In particular, a data analysis system, such as described herein, may provide features to enable the data analyst to investigate large volumes of data over many different paths of analysis while maintaining detailed and retraceable steps taken by the data analyst over the course of an investigation, as captured via the data analyst's queries and user interaction with the user interfaces provided by the data analysis system. Data analysis paths may involve exploration of high volume data sets, such as Internet proxy data, which may include trillions of rows of data. The data analyst may pursue a data analysis path that involves, among other things, applying filters, joining to other tables in a database, viewing interactive data visualizations, and so on.
Description
BACKGROUND

The approaches described in this section are approaches that could be pursued, but not necessarily approaches that have been previously conceived or pursued. Therefore, unless otherwise indicated, it should not be assumed that any of the approaches described in this section qualify as prior art merely by virtue of their inclusion in this section.


Exploration, mining, and analysis of high-volume data sources and data warehouses can be a time and resource intensive process, both for the user and for the underlying computing systems which provide data analysis features. Large volumes of data contribute to high consumption of computer memory, and processing of such large volumes of data can require extremely powerful computer processors and processing time. Users such as data analysts often face a seemingly insurmountable task of attempting to locate discrete pieces of information from data sources which can include or primarily consist of innocuous or noisy data which provides little probative value. Often, many iterations to explore such data are required, with each iteration having an associated cost in time and resources.





BRIEF DESCRIPTION OF THE DRAWINGS


FIGS. 1A-1M illustrate an example data analysis workflow performed using several interactive data analysis user interfaces, as generated using one embodiment of the data analysis system of FIG. 6.



FIGS. 2A-2B illustrate example data analysis path tree view user interfaces, as generated using one embodiment of the data analysis system of FIG. 6.



FIG. 3 is a flowchart illustrating one embodiment of an example process for processing data set queries using an interactive data analysis user interface, as used in one embodiment of the data analysis system of FIG. 6.



FIG. 4 is a flowchart illustrating one embodiment of an example process for generating an interactive breadcrumb and/or an interactive tree view representing a data analysis path for display in a data analysis user interface, as used in one embodiment of the data analysis system of FIG. 6.



FIG. 5 is a flowchart illustrating one embodiment of an example process for navigating a data analysis path using an interactive breadcrumb and/or an interactive tree view representing the data analysis path in data analysis user interface, as used in one embodiment of the data analysis system of FIG. 6.



FIG. 6 is a block diagram of an implementation of an illustrative data analysis system.





DETAILED DESCRIPTION

Overview


Data analysts face a daunting challenge when tasked with exploring a large volume of data to identify discrete pieces of information and intelligence—a veritable needle-in-a-haystack problem. In some cases a data analyst may have a lead on something she wishes to investigate. For example, knowing that a particular bad actor was involved in an incident may be a starting point from which the data analyst can begin to investigate other individuals who may have been involved. However, in many cases the data analyst has little information or, at best, only some contextual information on which to base an investigation. For example, the data analyst might know that a website was hacked at a certain time but have little else to go on to identify the individuals involved. However, data analysts might need to explore multiple analysis paths, many of which lead to “dead ends” or results that do not answer the search premise, by sorting and filtering through a massive volume of (for example) Internet proxy traffic data, cyber security data, telephone data, and/or any other type of data. The data analyst's path through the data is often multi-directional, in that the analyst may approach a problem from the top-down, bottom-up, and/or in either direction over the course of a given data analysis path and investigation. For example, the data analyst may begin with a large set of data, submit one or more queries which may lead to smaller sets of data results or filtered data results, and then merge or join smaller sets of data results to formulate larger sets of data, exclude subsets of data, and so on in as many iterations as the data analysts desires or finds useful.


The systems and methods described herein provide highly dynamic and interactive data analysis user interfaces which enable the data analyst to quickly and efficiently explore large volume data sources. In particular, a data analysis system, such as described herein, may provide features to enable the data analyst to investigate large volumes of data over many different paths of analysis while maintaining detailed and retraceable steps taken by the data analyst over the course of an investigation, as captured via the data analyst's queries and user interaction with the user interfaces provided by the data analysis system. For example, one data analysis path may begin with a high volume data set, such as Internet proxy data, which may include trillions of rows of data corresponding to Internet communication events even over a short period of time. The data analyst may pursue a data analysis path that involves applying a filter, joining to another table in a database, viewing a histogram, manipulating a pivot table, and finally viewing a summary of the entries located which match the parameters of the data analysis path. The summary may not provide the data analyst with the results she was hoping to find and thus she may decide to investigate another data analysis path. However, rather than start over from scratch, she may wish to return to another point in the first data analysis path. For example, perhaps while viewing the histogram she noted other points to explore later.


In an embodiment, a main data analysis workflow user interface provided by the data analysis system provides the data analyst with a set of highly interactive data visualization tools with which the data analyst can explore sets of data. Data visualization tools provided by the data analysis system can include, for example, a data summary view; a time series view; a time grid view; a heat map view; a pivot table view; an ability to link to another table in a database; and options to add, remove, or keep only selected results from a data view.


Each of these data visualization tools may include rich UI controls which are configured to respond to user interaction and input in a manner that allows the non-technical user to quickly and intuitively create complex data set queries. For example, in a histogram view data visualization UI, when a user selects (e.g., by clicking on, touching, speaking, etc.) a column in the histogram, a query filter may be automatically determined and applied to a subsequent query to be processed by the data analysis system. Or, in another example, an interactive heat map overlaid on a geographic region may allow the user to click and/or touch-and-drag to select a region of interest, and in response a query filter may be automatically generated which specifies the region of interest as a matching parameter. Subsequent queries may be easily built and executed to automatically apply the filter specified by the user interaction with the various data visualizations, providing a highly responsive, intuitive, and immersive user experience.


In one embodiment, the data analysis system maintains a session history for the analyst's data analysis paths and may provide various user interface features to allow the analyst to quickly and easily return to any prior point in the data analysis path, including the histogram view in the hypothetical example above. When a new data analysis path is started the session history is updated to include a new branch path from the original path.


As the analyst builds a data set query using these data visualization tools, the corresponding query result is added to the main data analysis workflow UI (for example, appended to the bottom of the workflow), and the session history is updated. This analysis interaction process may proceed over as many data set queries as the analyst wishes to investigate, with each subsequent query result added to the main data analysis workflow UI and the session history being updated.


In one embodiment, the main data analysis workflow UI provides the ability for the data analyst to scroll up or down within the current data analysis path, for example to re-display various data set query results and associated data visualizations appearing earlier in the current data analysis path (which, for example, may no longer fit in a displayable area of a display screen). The data analyst user may then decide to investigate a new data analysis path based on an earlier query result/visualization.


To assist the data analyst user in navigating these multiple data analysis paths, data query sets, and results, the data analysis system can provide a variety of path navigation user interface tools. For example, in one embodiment, an interactive breadcrumb path UI control may be generated and displayed (e.g., at the top of the main data analysis workflow UI, as shown in the example user interfaces herein; or in any position). Each “crumb” in the breadcrumb path UI control may indicate a summary of a respective data query and/or filter submitted over the course of the current data analysis path that is displayed in the main data analysis workflow UI. Further, each crumb may be selectable by the data analyst. Selecting a crumb may automatically update the main data analysis workflow UI to re-display the associated data set query and data visualization of the associated results.


In another embodiment, an interactive tree view UI control may be generated and displayed (e.g., at the right side of the main data analysis workflow UI, as shown in the example user interfaces herein; or in any position). Each “node” in the tree view path UI control may indicate a summary of the respective data queries submitted over the course of the current data analysis path that is displayed in the main data analysis workflow UI. For example, when a user positions a cursor or pointer over a node in the tree view, a popover UI element may appear next to the node, where the popover UI element includes a summary of the data query. Further, each node may be selectable by the data analyst. Selecting a node may automatically update the main data analysis workflow UI to re-display the associated data set query and data visualization of the associated results. The data analyst may then, for example, jump to another point, save the associated data set, or begin a new branched data analysis path.


The tree view UI control may be displayed in a variety of ways. In one embodiment, a single-path tree view UI control may be displayed corresponding to the current data analysis path. For example, suppose the current data analysis path (and the main data analysis workflow UI) includes a filter with a histogram view; a join with a table view; and a filter with a time series view. Then, the single-path tree view UI control may include one path comprising three nodes: filter-join-filter. In some embodiments the different associated data visualization elements may be indicated by representative icons, such the data analyst can view at-a-glance that the current analysis path comprises filter-join-filter.


In another embodiment, an all-paths tree view UI control may be displayed to present the user with all analysis paths explored for the current session. For example, suppose the current data analysis path is as described above with two additional branch paths: a heat map view branched from the join; and a time grid view branched from the first filter. Then, the all-paths tree view UI control may include five nodes corresponding to the three paths: filter-join-filter (the current path); filter-histogram; and filter-time grid. In one embodiment, the single-path tree view UI control may be displayed concurrently with the main data analysis workflow UI and display the current data analysis path. A user-selectable option to view the all-paths tree view UI control may be presented, and upon selection the all-paths tree view UI control may displayed such as in a popover UI element. The all-paths tree view UI control may be configured to support full user interaction in a similar manner to the single-path UI control. Thus, the data analyst may switch to the all-paths tree view UI control, select a node from the all-paths tree, and in response the main data analysis workflow UI will re-display the associated data set query and data visualization of the associated results.


The breadcrumb path UI control and the tree view path UI control can thus each be used to jump from any first point in the data analysis path to any second point in the data analysis path, with the main data analysis workflow UI being updated to match the selected point. However, in certain embodiments, when the user jumps from point to point in this manner, the associated data query may not need to be executed again. Rather, a cached copy of the previously generated data visualization may be re-displayed, or a cached copy of the associated data query results may be accessed and used to generate or update the data visualization.


The data analysis system described herein provides a variety of additional features and benefits. In certain embodiments, the data analysis system and provided user interfaces may enable the data analyst user to save data query set results at any stage in the analysis path; and/or export data query set results, for example to another database or another format such as a presentation software format (e.g., PowerPoint), as further described below.


Saving a data query set may allow the data analyst to return to an analysis path in progress at a later time for further exploration. In some instances the data query set may be saved such that the full analysis path taken to reach the particular data query set is saved as well, which can enable the analyst to re-explore the full path at a later time. In some cases, the data query set may be saved in a “clean” state, such that the analysis path taken to reach the particular data query set is not saved. This may be of benefit, for example, if the analysis path was particularly long or convoluted and saving the path provides little value to the analyst. The system may provide an option for the analyst to choose whether a data set should be saved with or without the full analysis path.


Several types or varieties of data sets may be saved in accordance with this feature. One example data set is a materialized saved set, which is a particular set of records that matches the exact set of records that an analyst currently observes, and can be retrievable in the same precise form at a later date. A materialized saved set may have different versions that are refreshable or updatable at a later date, and as such information can also be stored describing, among other things, how a refresh may be performed, when the last refresh was conducted, and who performed the refresh. Another example data set is a dynamic saved set, which is a workflow definition that will produce a set applying some saved criteria. Another example data set is a parameterized saved sets, which is a workflow definition that will produce a set applying some saved criteria against with sets of the same shape (e.g., column definitions) as the original saved definition input sets. Many other types of saved sets may be possible as well.


Exporting a data query set may allow the data analyst to extract a data query set, for example, for importing into another data source separate from the original, high-volume data source. This feature may be of particular benefit if, for example, the original, high-volume data source comprises data which is very noisy or may otherwise be of little value in more focused or specialized databases. Using the example above with reference to Internet proxy traffic data, the vast majority of such data is normal, everyday traffic which is likely not to be of particular interest. Rather than import the full set of Internet proxy data into a more specialized database, the data analyst can use the data analysis system herein to explore and filter down the high-volume data. Once a filtered data query set is obtained which appears to be of interest or relevance to the specialized database, the data set can be exported.


Another benefit to the export feature is that it may reduce the costs involved in maintaining and searching a high-volume data source by keeping that data source separate. For example, the cost (both financially and physical resource-wise in terms of memory, response time, processing speed, efficiency, power consumption, etc.) of maintenance, duplication, backups, and other redundancy measures for specialized databases can grow exponentially if copious amounts of noisy data are imported. Thus, using the data analysis system and export features herein, the specialized databases can remain specialized, while the high-volume data sources may still be explored to identify and extract valuable data.


The data analysis systems and methods described herein may also include various features for query optimization on the backend or server-side. For example, a query backend module may be configured to analyze user selections and interactions with the data set query results and associated data visualizations and, based on those selections and interactions, determine what data the user is actually interested in, and translate the query into an efficient or optimized search query string. For example, the user might produce a workflow or analysis path which involves linking or joining a first large data set to a second large data set, and then filtering the resulting linked data set. An optimized search query string may then be generated which applies the filter operation prior to the link or join operation, such that the resources required to perform the join operation would be greatly reduced (i.e., since the link or join operation would be performed on smaller data sets resulting from the filter being applied first).


Another query optimization feature which may be provided by the data analysis system includes logic to evaluate a query, such as a JOIN operation, will be and, based on the expense, determine whether a temp table should be created in order to improve the performance of subsequent queries using the data query result set. For example, in some cases a temp table may “cost” less in terms of computer processing or memory requirements than re-executing the JOIN operation. Another query optimization feature related to the use of such temp tables which may be provided by the data analysis system includes connection pooling, whereby temp tables may be mapped to different connections or users to facilitate efficient re-use of temp tables for the respective user's analysis workflow. These and other features described herein are of particular value in the context of processing and querying high-volume data, where physical hardware costs and resources are constrained.


In some embodiments, the data analysis system may be configured to defer execution of a query until a particular analytic view is rendered. This can provide additional efficiency, for example, when users are simply trying to construct complex set-based queries, and enables non-technical users to create complex queries without actually understanding the underlying query language (like SQL). Users might find benefit from the data analysis system as a tool that enables construction of complex reporting queries, even without visual feedback (but with the benefit of optionally including such visual feedback on demand). In some instances, the data analysis system may provide users with the ability to define filters without visual feedback, and do so incrementally and intuitively as a logical “next step” in a workflow for filtering, triaging, linking, and so on.


Example User Interfaces



FIGS. 1A-1D and 2A-2B illustrate example user interfaces and UI components, as used in one or more embodiments of the data analysis system 100 of FIG. 6. The sample user interfaces may be displayed, for example, via a web browser (e.g., as a web page), a mobile application, or a standalone application. In some embodiments, the sample user interfaces shown in FIGS. 1A-1D and 2A-2B may also be displayed on any suitable computer device, such as a cell/smart phone, tablet, wearable computing device, portable/mobile computing device, desktop, laptop, or personal computer, and are not limited to the samples as described herein. The user interfaces include examples of only certain features that a data analysis system may provide. In other embodiments, additional features may be provided, and they may be provided using various different user interfaces and software code. Depending on the embodiment, the user interfaces and functionality described with reference to FIGS. 1A-1D and 2A-2B may be provided by software executing on the individual's computing device, by a data analysis system located remotely that is in communication with the computing device via one or more networks, and/or some combination of software executing on the computing device and the data analysis system. In other embodiments, analogous interfaces may be presented using audio or other forms of communication. In an embodiment, the interfaces shown in FIGS. 1A-1D and 2A-2B are configured to be interactive and respond to various user interactions. Such user interactions may include clicks with a mouse, typing with a keyboard, touches and/or gestures on a touch screen, voice commands, physical gestures made within a proximity of a user interface, and/or the like.



FIG. 1A illustrates an example data analysis user interface 1000A, as generated using one embodiment of the data analysis system 100 of FIG. 6. The data analysis UI 1000 may comprise, for example, a main data analysis workflow user interface for a user, such as a data analyst, to dynamically build data sets and queries and to view query set results. The query set results may be generated by the data analysis system 100 in response to user queries, and presented via highly interactive user interface UI display elements and controls. The data analysis UI 1000 may include a tree view UI control 102A, breadcrumb UI control 104A, and a data visualization UI element 106, which in FIG. 1 comprises a summary data view presenting a summary of data set results. Also shown is an action menu 108 which provides a list of data analysis tools and options available for the user, including: summary view; histogram; time series; time grid; heat map; pivot table; a set viewer; a table view; a pivot table; and options to save a set and to export a set. Additional actions and options not shown can also be included. In response to selection of these various data analysis tools the data analysis UI 1000 may be updated to add a new UI display panel presenting the selected analysis tool at the bottom of the workflow area. The user may then use the selected analysis tool to build and run a subsequent query to obtain a next data query result set.


Each time a selected data analysis tool is used by the user to build a query, the data analysis system 100 may update the associated session history for the user to track the user's analysis path. In some embodiments, the session history may be updated as the user builds the query, but before the query is executed, in order to capture the user's work in progress. In some embodiments, the session history may be updated when the query is executed and query results are obtained. As the session history is updated, the tree view UI control 102A and the breadcrumb UI control 104A may also be updated to reflect the updated analysis path. This is described in more detail with reference to FIGS. 1B-1D as the example workflow progresses; as well as with respect to the process 400 of FIG. 4 herein. For example, the breadcrumb UI control 104A may be appended with a description of the query parameters and/or type of operation performed (e.g., as may be indicated by an icon). Similarly, the tree view UI control 102A may be updated to include an additional node on the current branch or path, corresponding to the additional analysis step (including either a query-in-progress or a query result set generated and added to the main workflow).


As the analysis path grows or the user begins to backtrack and create new branches, the tree view may become too large to persistently display in the main data analysis workflow user interface. Thus, in some embodiments, the tree view UI control 102A-D may comprise a single series of nodes representing the current analysis path in the session. The tree view UI control 102A-D may include an expand option which the user can select to view the full or expanded tree view. The full or expanded tree view may be presented as a popover UI control overlaid on the main data analysis workflow user interface or in a separate window or user interface. More detailed examples of the expanded tree view are illustrated and described with respect to FIGS. 2A and 2B herein.


With continued reference to FIG. 1A, the hand cursor over the histogram icon in the actions menu 108 indicates that the user is selecting a histogram data visualization, which is illustrated and described next in FIG. 1B.



FIG. 1B illustrates an example data analysis user interface 1000B, which may be a continuation of the workflow shown in user interface 1000A. Once the user has selected the histogram option, a histogram menu 110 may be displayed by which the user can select one or more query parameters specifying the desired output result and format. Other data visualization elements described herein may have similar or other menu options for the user to specify query parameters for the respective data visualization.


When the user is satisfied with the selection, e.g., of count_distinct, hometown, country, and quantity parameters in the example of FIG. 1B, the “compute” button may be selected. In response the data analysis system 100 receives the request and query parameters and processes a query against the current query result set. The output results may be used to generate the histogram data visualization and displayed in the main data analysis workflow user interface, as FIG. 1B shows. Also shown in user interface 1000B, the view UI control 102B may be updated to add an additional node indicating the histogram has been added to the current analysis path. In some embodiments, the visualization, e.g., the histogram, is updated in real time as the various parameters are each individually selected.


The histogram data visualization may be interactive and provide functionality for the analyst to quickly and intuitively begin developing another query. For example, in response to the user selecting one or more bars in the histogram, a query filter display 114B may appear and dynamically update to include each of the one or more bars selected by the user. When the user wishes to continue the analysis beyond the histogram, another action may be selected from the action menu 108B. If any query filter criteria are still selected from the user interaction with the histogram, these may be gathered and applied to the next query processed by the data analysis system for the current workflow.



FIG. 1C illustrates an example data analysis user interface 1000C, which may be a continuation of the workflow shown in user interface 1000B. In this continued example of the workflow which started in FIG. 1A, the data analyst has progressed a couple of steps further in the analysis path. The view UI control 102C has been updated to indicate that subsequent to the histogram discussed above, a time series query was processed by the system and the associated time series data visualization (shown partially visible in the user interface 1000C) was generated and displayed. At any point in the analysis the user may use the fully interactive view UI control 102C to navigate to an earlier step in the analysis path; in response, the main data flow user interface may scroll up or otherwise cause re-presentation of the data visualization corresponding to the selected node.


The user interface 1000C also demonstrates the breadcrumb UI control 104C being updated to reflect the user's earlier selection from the histogram to filter on the country “USA.” As with the tree view UI control 102C, the user may select any crumb in the breadcrumb UI control 104C to navigate to the corresponding step in the analysis path.


The time series data visualization, like the histogram, may provide several interactive features. For example, in response to the user selecting a segment of the time series, the query filter display 114C may dynamically update to specify a query filter corresponding to the user selection (here, a date range). As user interface 1000C further illustrates, a summary view has been selected again by the data analyst so that she can assess at a glance whether the query filters applied so far in the analysis path have yielded any interesting query results.



FIG. 1D illustrates an example data analysis user interface 1000D, which may be a continuation of the workflow shown in user interface 1000C. In this continued example of the workflow which started in FIG. 1A, the analyst has selected a heat map data visualization element 116. The view UI control 102D has been updated to indicate that subsequent to the histogram and time series discussed above, a summary view, a pivot table, and finally the heat map currently displayed were processed by the data analysis system. As before, at any point in the analysis the user may use the fully interactive view UI control 102D to navigate to an earlier step in the analysis path.


The user interface 1000D also demonstrates the breadcrumb UI control 104C being updated to reflect the user's earlier selection from the histogram to filter on the country “USA,” as well as several additional interim filters and operations which have been applied during the current analysis path. As with the breadcrumb UI control 104C, the user may select any crumb in the breadcrumb UI control 104D to navigate to the corresponding step in the analysis path.


The heat map data visualization, like the histogram and the time series, may provide several interactive features. For example, in response to the user drawing a circle or otherwise circumscribing an area on the map, the query filter display 114C may dynamically update to specify a query filter corresponding to the user selection (here, a geographic range and a center point).


In the example shown, the user has selected a region roughly corresponding to the New England area, with New York as the center focus. For instance, the query results data may indicate a high degree of activity, such as Internet traffic, satisfying the query parameters in the New York area. The data analyst/user may quickly make this determination from studying the heat map, and then uses the map selector to zoom in on the region of interest. In response the data analysis user interface may interpret the user's map selection as a desire to build a new query and immediately add a query filter, shown below the map in this example, to filter the results to the selected region. The user can then select one of the actions 108D and execute the query filter to view a subsequent data set, where the filter is applied to the query results from the heat map.



FIGS. 1E-1M illustrate additional user interface features that may be implemented in some embodiments in order to selection actions, visualizations, and/or data sets upon which new visualizations should be generated. In this example, a text input control 123 receives text entry from the user in a natural language format; although in other embodiments the text entry may be in a coded, shorthand, or abbreviated format. The text entered by user may then be parsed by the system in order to predict another visualization of interest to the user and/or further filter parameters of interest to the user, such as that might be applied to another visualization.


For example, in the example of FIG. 1E, the user has begun typing a query such as “show me count by day.” However, before finishing the text, each of the visualizations shown below the input control 123 are grayed out (e.g., not selectable) as the system is processing the text data to determine which visualization is associated with the provided text. In some embodiments, the system provides suggestions of visualizations/or filtering associated with those visualizations before an entire search string is entered. For example, the system may predict characters that are going to be typed by the user. Returning to the example in the figures, when the text has been entered, as in FIG. 1F (or prior to completion of the full text query in some implementations), the dropdown list of visualizations is updated to provide one or more predicted or suggested data visualization elements relevant to the provided text entry. In the example of FIG. 1F, The prediction or suggestion may be based on a real-time analysis of the user input and scanning for certain keywords which may indicate or otherwise suggest that the user is interested in a particular set of data which may be well suited for one or more data visualization types. For example, the word “count” in the user input may signal to the system that the user is probably interested in viewing a time series, and thus this particular data visualization option or thumbnail in the dropdown list may be highlighted so that the user can see that the “time series” data visualization is recommended and/or available for the particular user input or query. As another example, the user input may be “histogram rate code” which may in turn signal the system that the user is probably interested in viewing a histogram; then the histogram option or thumbnail may be highlighted for the user to more easily select.


The user can then select any of the available visualizations (e.g., time series in example of FIG. 1) for display in the user interface, such as is shown in FIG. 1G. FIG. 1G also includes an input control 123B that provides the same or similar functionality to the input control 123; that is, free-form text may be entered in order for the system to predict which visualization the user is interested in viewing next and/or additional parameters for filtering the data set in the recommended visualizations. However, the visualization prediction provided in response to text provided into input control 123B may further be influenced by the time series that was previously displayed in response to the previous selection made with reference to FIG. 1G, for example. Thus, as with other examples discussed herein, filtering of the data set and subsequent visualizations based on such filtering may build upon one another in a sequential fashion to provide various granularities, types, and sets of information to the user in various available visualizations.


In the example of FIG. 1H, the user has started typing a new free-form search query, but the system has not yet identified a most appropriate visualization and/or parameters for the visualization. Moving to FIG. 1I, the user has completed entering “histogram rate code”, such that a histogram visualization is unlocked for selection, and the system has automatically determined that the “rate code” should be the main input parameter of the histogram. Thus, when the Histogram visualization is selected, a new visualization, such as in FIG. 1J, including a histogram showing rate counts, is added to the user interface.



FIGS. 1K-1M illustrate yet another example of parsing of free-form text in order to provide a particular visualization and primary attribute for display in the visualization. In this example, the user has indicated that a distribution visualization is desired, such that the system automatically begins precalculating (in some embodiments) a distribution visualization based on a “trip distance” parameter of the data set, resulting in display of the distribution visualization of FIG. 1M in response to the user's selection of the Distribution visualization (in FIG. 1L).


In some instances, the dropdown list (or other user interface display element listing one or more options for user selection) may display or include a hint for the user to indicate one or more keywords or data types which, if included in the text input, would enable or highlight the particular data visualization element. For example, the list may indicate that, for a pivot table, the system is “looking for” the keyword “across.” Then, if the user inputs the term “across” in the text input control, the system may infer that the user is interested in viewing a pivot table and correspondingly enable or recommend the pivot table data visualization. Other examples may include: Grid is looking for the keyword “an aggregate”; Histogram is looking for the keyword “hist”; Distribution is looking for the a data type of “a column,” and Time Series is looking for the keyword “time.”


Additional keywords may be used or suggested, and more than one keyword may be “looked for” by a particular data visualization to signal the system to generate, enable, or otherwise recommend the particular data visualization to the user. In addition, the data visualization highlighted or recommended by the system may change in real-time as the user provides more input. For example, the system may initially recommend one data visualization such as a Time Series in response to identifying the keyword “time” in the user input; but then update to recommended a different data visualization such as Pivot Table in response to identifying other keywords or structure to the user input that may indicate the user is more likely interested in something other than the initially recommended Time Series data visualization.



FIGS. 2A-2B illustrates example data analysis path tree view user interfaces, as generated using one embodiment of the data analysis system 100 of FIG. 6. The tree view 202A of FIG. 2A or the tree view 202B of FIG. 2B may be displayed in response to a user selection from the main data workflow user interface. Nodes in each tree view 202A, 202B may be represented by icons indicating the types of query operations or data visualization performed or accessed at the particular node. For example, the tree view 202A includes a summary node, a histogram node, a time series node, a pivot table node, and a summary node on each of two branches from the pivot table node. The tree view 202A may correspond, for example, to some of the analysis path and tree view 102C described in FIG. 1C.


In FIG. 2B, the tree view 202B corresponds to the same analysis path represented in tree view 202A but includes several additional nodes, indicating that the analysis path has grown. For example, the tree view 202B includes the same nodes as tree view 202A, with additional nodes for each of the two branches—namely a table view node and a histogram node.


As further illustrated in FIG. 2B, popover UI elements 204B may be displayed to show query detail (e.g., the associated query parameters and/or type of operation performed). The popover UI elements 204B may be displayed to the right (or left, etc.) of the tree, such as when the user positions a pointer or cursor over a node in the tree view 202A. In some embodiments, only some nodes of tree view 202B display the associated query detail, perhaps indicating certain key nodes in the analysis path. For example, a node's query detail might be selected for display based on a user flag or marker indicating the query result was one of interest for later data exploration; or, the query detail might be selected for display based on a determination made by the data analysis system, such as a based on a number of results returned, or other factors.


In certain embodiments, the tree views 202A, 202B may be interactive such that the user may select a node in order to return to that point in the analysis path. Selection of the node may cause the main data analysis workflow user interface to re-display the associated data query set result and/or visualization control, which the user can view and optionally from which the user can launch a new analysis path.


Although the tree views 202A and 202B shown in FIG. 2A-2B illustrate two branched analysis paths for the current session, in certain embodiments other tree views may be generated to show any number of paths. For example, in one embodiment, a single-path tree view UI control may be presented to show only the current analysis path, for example in a side panel on the main data analysis workflow user interface. An expanded or all-paths tree view UI control may then be displayed in response to user selection of an option presented in one of the data system user interfaces to view the expanded or all-paths tree. In other instances, depending on the depth and complexity of the analysis path, the tree view UI may be generated to display only a local portion of the analysis path, or include a zoom in/zoom out feature to allow the user to navigate the tree view and different analysis path.


In various embodiments, the tree view represents a computation graph (for example, Directed Acyclic Graph) of input sets. Some operations take as input more than just the parent set, and thus form the nodes of a compute graph. Other compute graphs can be used as input at these junctions, and with the added feature of constructing saved sets, these compute graphs can be quite complicated. Thus, one benefit provided by the tree views discussed herein is to allow non-technical users to construct large compute graphs with semantically labeled sets. The data analysis system may be configured to perform some caching on the back-end to optimize the compute profile of particular graphs. This caching can be performed across multiple users, such that if multiple users request the same graph, the result of that compute graph may be cached for speedier or more efficient execution. Elements of the total computation may be optimized by replacing a particular node in the graph with its materialized saved set result (for example, in cases in which the materialization data set remains valid).


Examples of Processes Performed by Data Analysis Systems



FIGS. 3, 4, and 5 are flowcharts illustrating various embodiments of data analysis system processes. In some implementations, the processes are performed by embodiments of the data analysis system 100 described with reference to FIG. 6 and/or by one of its components, such as the network service module 124, the caching module 126, the export service 128, the import service 132, and/or the query backend 134 shown in FIG. 6. For ease of explanation, the following describes the services as performed by the data analysis system 100. The example scenarios are intended to illustrate, but not to limit, various aspects of the data analysis system 100. In one embodiment, the processes can be dynamic, with some procedures omitted and others added.



FIG. 3 is a flowchart illustrating one embodiment of a process 300 for processing data set queries using an interactive data analysis user interface, as used in one embodiment of the data analysis system 100 of FIG. 6. Depending on the embodiment, the method of FIG. 3 may include fewer or additional blocks and/or the blocks may be performed in an order that is different than illustrated.


At block 305, the data analysis system 100 processes a data set query on a data set. The data set may be an unfiltered data set, such as a set of proxy data logs that the user wishes to analysis or may be a filter portion of a data set, such as a subset of the proxy data that was previously processed.


At block 310, the data analysis system 100 generates and provides output results for the data set query, which may include an associated data visualization UI element such as those described herein. The output results and data visualization UI element may be displayed, for example, via one of the example user interfaces 1000A-D discussed above.


At block 315, the data analysis system 100 receives user interaction data for user interaction with the data visualization UI element. For example, the user may interact with the data visualization UI element by selecting one or more bars, lines, or other portions indicating a selection of some subset of the data represented by the data visualization. The selections may then be interpreted as query filters for a subsequent query result set. Several examples of these types of interactions are described with reference to FIGS. 1A-1D.


At block 320, the data analysis system 100 initializes generation of the subsequent query based on the user interaction data. For example, a query filter display may be presented and dynamically updated to include each of the user's selections. Once the user's selections have been received and the user elects to calculate or submit the query, the process 300 may return to block 305 and repeat again. In this way, the user can drill down (and/or up) in various manners to view different subsets of the data in various ways.



FIG. 4 is a flowchart illustrating one embodiment of a process 400 for generating an interactive breadcrumb and/or an interactive tree view representing a data analysis path for display in a data analysis user interface, as used in one embodiment of the data analysis system 100 of FIG. 6. Depending on the embodiment, the method of FIG. 4 may include fewer or additional blocks and the blocks may be performed in an order that is different than illustrated.


At block 405, the data analysis system 100 receives a request to execute a data set query on a current session or result set. The request may be received, for example, via one of the user interfaces 1000A-D described previously, for example over the course of an analysis workflow.


At block 410, the data analysis system 100 executes the data set query, for example by using the caching module 1226 and/or accessing the local data source 170 to run the query. Some or all of the query execution may be performed by, for example, the query backend 134, which may apply some of all of the query optimization techniques described herein.


At block 415, the data analysis system 100 accesses the output results and generates a UI element (e.g., a data visualization control) associated with the execution of the data set query. For example, the type of UI element generated may be based on a user selection from the actions menu 108 illustrated and described with reference to FIG. 1A.


At block 420, the data analysis system 100 maintains or updates a session history of the data set queries executed for the current session. The session history includes the query details associated with each respective data set query, such as query parameters and/or a type of operation performed. The query details may be used, for example, in order to provide a visual reminder to the user about the data set query, as well as to enable re-execution of the query in some instances.


At block 425, the data analysis system 100 generates or updates an interactive breadcrumb UI control (such as the breadcrumb 104A-D to display the summary of the query detail information for data set queries performed for the current analysis path.


At block 430, the data analysis system 100 generates or updates an interactive tree view UI control (such as the tree view 102A-D or 202A-B), which may be configured to optionally display the summary of the query detail information for data set queries performed for the current analysis path (e.g., the query detail information may be displayed in response to a user interaction such as positioning a cursor, gesturing with a finger or hand near the screen, etc.).


Once the interactive breadcrumb and/or tree view UI controls have been updated, the user interfaces 1000, 2000 may be updated or refreshed to display the current view, and the user may continue to build and execute data set queries.



FIG. 5 is a flowchart illustrating one embodiment of a process 500 for navigating a data analysis path using an interactive breadcrumb and/or an interactive tree view representing the data analysis path in data analysis user interface, as used in one embodiment of the data analysis system 100 of FIG. 6. Depending on the embodiment, the method of FIG. 5 may include fewer or additional blocks and the blocks may be performed in an order that is different than illustrated.


At block 505, data analysis system 100 provides for display in a data analysis workflow user interface, an interactive breadcrumb and/or tree view UI element each of which may display summary information about data set queries performed for the current session, analysis path, or result set.


At block 510, data analysis system 100 receivers a user selection of a session history node, such as a crumb in the breadcrumb or a node in the tree view.


At block 515, data analysis system 100 updates the main workflow user interface to display the data set query and results corresponding to the selected session history node.


At block 520, data analysis system 100 updates the interactive breadcrumb to display the data set queries or detail associated with the selected session history node.


At block 525, data analysis system 100 updates the interactive tree view to provide an indication that the current position in the analysis path has changed, and to optionally display a new branch for the current session.


At block 530, data analysis system 100 provides or updates the main workflow user interface as generated at block 515, the interactive breadcrumb as updated at block 520, and the interactive tree view at block 525.


Example System Implementation and Architecture



FIG. 6 is a block diagram of one embodiment of a data analysis system 100 in communication with a network 160 and various systems, such as client computing systems(s) 168, external data source(s) 172. The data analysis system 100 may be used to implement systems and methods described herein, including, but not limited to the process 300 of FIG. 3, the process 400 of FIG. 4 and the process 500 of FIG. 5.


Data Analysis System


In the embodiment of FIG. 6, the data analysis system 100 includes a network service module 124, a caching module 126, an export service 128, an import service 130, a query backend 134, and a local data source 170.


The security/single sign-on manager 122 provides capabilities to ensure that users are properly authenticated with the data analysis system 100, as well as other security measures and protocols which may be used by the data analysis system 100.


The network service module 124 provides capabilities related to generation, presentation, and in some cases display of the user interfaces, UI components, and related features, such as those illustrated and described with reference to FIGS. 1A-1D and 2A-2D herein.


The caching module 126 provides capabilities related to, among other things, caching of query results generated for analysis workflow sessions. The caching module 126 may also be configured to manage connection pooling for the data analysis system 100, such that users of the system are mapped to temp tables created for their respective analysis workflows. Among other benefits this may help improve response times for the users as they may utilize the same connection and same temp tables many times over a single session.


The export service 128 processes requests to export data from the data analysis system 100 to, for example, the external data sources(s) 172, working in association with the caching module 126 to access data and provide it to the network service module 124 for export.


The import service 132 may periodically poll or be notified by the external data source(s) 172 when new data may be available for import. When new data is available for import, the import service 132 may update the local data store 170 and provide an indication to the caching module 126 that new data is available. In response the caching module 126 may purge or invalidate outdated data.


The query backend 134 provides capabilities related to query optimization including analyzing query filters received from the network service module 124.


Each of these components may be stored in a mass storage device as executable software codes that are executed by a central processing units (“CPU”). These and other modules in the data analysis system 100 may include, by way of example, components, such as software components, object-oriented software components, class components and task components, processes, functions, attributes, procedures, subroutines, segments of program code, drivers, firmware, microcode, circuitry, data, databases, data structures, tables, arrays, and variables. In the embodiment shown in FIG. 6, the data analysis system 100 is configured to execute the modules recited above to perform the various methods and/or processes herein (such as the processes described with respect to FIGS. 3, 4, and 5 herein).


The data analysis system 100 and/or its subcomponents may include, for example, a server, workstation, or other computing device. In one embodiment, the exemplary data analysis system 100 includes CPUs, which may each include a conventional or proprietary microprocessor. The data analysis system 100 further includes one or more memories, such as random access memory (“RAM”) for temporary storage of information, one or more read only memories (“ROM”) for permanent storage of information, and one or more mass storage devices, such as a hard drive, diskette, solid state drive, or optical media storage device. Typically, the modules of the data analysis system 100 are connected to the computer using a standard based bus system. In different embodiments, the standard based bus system could be implemented in Peripheral Component Interconnect (“PCI”), Microchannel, Small Computer System Interface (“SCSI”), Industrial Standard Architecture (“ISA”), and Extended ISA (“EISA”) architectures, for example. In addition, the functionality provided for in the components and modules of data analysis system 100 may be combined into fewer components and modules or further separated into additional components and modules.


The data analysis system 100 and/or its subcomponents are generally controlled and coordinated by operating system software, such as Windows XP, Windows Vista, Windows 7, Windows 8, Windows Server, UNIX, Linux, SunOS, Solaris, iOS, Blackberry OS, or other compatible operating systems. In Macintosh systems, the operating system may be any available operating system, such as MAC OS X. In other embodiments, the data analysis system 100 may be controlled by a proprietary operating system. Conventional operating systems control and schedule computer processes for execution, perform memory management, provide file system, networking, I/O services, and provide a user interface, such as a graphical user interface (“GUI”), among other things.


Network


In the embodiment of FIG. 6, the data analysis system 100 is electronically coupled to a network 160, which comprises one or more of a LAN, WAN, and/or the Internet, for example, via a wired, wireless, or combination of wired and wireless, communication link. The network 160 communicates with various computing devices and/or other electronic devices via wired or wireless communication links.


According to FIG. 6, in some embodiments information may be provided to or accessed by the data analysis system 100 over the network 160 from one or more external data source(s) 172. The local data store 170 and/or external data source(s) 172 may include one or more internal and/or external data sources. In some embodiments, one or more of the databases or data sources may be implemented using a relational database, such as Sybase, Oracle, CodeBase, MySQL, and Microsoft® SQL Server as well as other types of databases such as, for example, a flat file database, an entity-relationship database, and object-oriented database, and/or a record-based database


Other Embodiments

Each of the processes, methods, and algorithms described in the preceding sections may be embodied in, and fully or partially automated by, code modules executed by one or more computer systems or computer processors comprising computer hardware. The code modules may be stored on any type of non-transitory computer-readable medium or computer storage device, such as hard drives, solid state memory, optical disc, and/or the like. The systems and modules may also be transmitted as generated data signals (for example, as part of a carrier wave or other analog or digital propagated signal) on a variety of computer-readable transmission mediums, including wireless-based and wired/cable-based mediums, and may take a variety of forms (for example, as part of a single or multiplexed analog signal, or as multiple discrete digital packets or frames). The processes and algorithms may be implemented partially or wholly in application-specific circuitry. The results of the disclosed processes and process steps may be stored, persistently or otherwise, in any type of non-transitory computer storage such as, for example, volatile or non-volatile storage.


In general, the word “module,” as used herein, refers to logic embodied in hardware or firmware, or to a collection of software instructions, possibly having entry and exit points, written in a programming language, such as, for example, Java, Lua, C or C++. A software module may be compiled and linked into an executable program, installed in a dynamic link library, or may be written in an interpreted programming language such as, for example, BASIC, Perl, or Python. It will be appreciated that software modules may be callable from other modules or from themselves, and/or may be invoked in response to detected events or interrupts. Software modules configured for execution on computing devices may be provided on a computer readable medium, such as a compact disc, digital video disc, flash drive, or any other tangible medium. Such software code may be stored, partially or fully, on a memory device of the executing computing device, such as the programming notebook system 100, for execution by the computing device. Software instructions may be embedded in firmware, such as an EPROM. It will be further appreciated that hardware modules may be comprised of connected logic units, such as gates and flip-flops, and/or may be comprised of programmable units, such as programmable gate arrays or processors. The modules described herein are preferably implemented as software modules, but may be represented in hardware or firmware. Generally, the modules described herein refer to logical modules that may be combined with other modules or divided into sub-modules despite their physical organization or storage.


The various features and processes described above may be used independently of one another, or may be combined in various ways. All possible combinations and subcombinations are intended to fall within the scope of this disclosure. In addition, certain method or process blocks may be omitted in some implementations. The methods and processes described herein are also not limited to any particular sequence, and the blocks or states relating thereto can be performed in other sequences that are appropriate. For example, described blocks or states may be performed in an order other than that specifically disclosed, or multiple blocks or states may be combined in a single block or state. The example blocks or states may be performed in serial, in parallel, or in some other manner. Blocks or states may be added to or removed from the disclosed example embodiments. The example systems and components described herein may be configured differently than described. For example, elements may be added to, removed from, or rearranged compared to the disclosed example embodiments.


Conditional language used herein, such as, among others, “can,” “could,” “might,” “may,” “for example,” and the like, unless specifically stated otherwise, or otherwise understood within the context as used, is generally intended to convey that certain embodiments include, while other embodiments do not include, certain features, elements and/or steps. Thus, such conditional language is not generally intended to imply that features, elements and/or steps are in any way required for one or more embodiments or that one or more embodiments necessarily include logic for deciding, with or without author input or prompting, whether these features, elements and/or steps are included or are to be performed in any particular embodiment. The terms “comprising,” “including,” “having,” and the like are synonymous and are used inclusively, in an open-ended fashion, and do not exclude additional elements, features, acts, operations, and so forth. Also, the term “or” is used in its inclusive sense (and not in its exclusive sense) so that when used, for example, to connect a list of elements, the term “or” means one, some, or all of the elements in the list. Conjunctive language such as the phrase “at least one of X, Y and Z,” unless specifically stated otherwise, is otherwise understood with the context as used in general to convey that an item, term, etc. may be either X, Y, or Z. Thus, such conjunctive language is not generally intended to imply that certain embodiments require at least one of X, at least one of Y, and at least one of Z to each be present.


While certain example embodiments have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of the disclosure. Thus, nothing in the foregoing description is intended to imply that any particular element, feature, characteristic, step, module, or block is necessary or indispensable. Indeed, the novel methods and systems described herein may be embodied in a variety of other forms; furthermore, various omissions, substitutions, and changes in the form of the methods and systems described herein may be made without departing from the spirit of the inventions disclosed herein. The accompanying claims and their equivalents are intended to cover such forms or modifications as would fall within the scope and spirit of certain of the inventions disclosed herein.


Any process descriptions, elements, or blocks in the flow diagrams described herein and/or depicted in the attached figures should be understood as potentially representing modules, segments, or portions of code which include one or more executable instructions for implementing specific logical functions or steps in the process. Alternate implementations are included within the scope of the embodiments described herein in which elements or functions may be deleted, executed out of order from that shown or discussed, including substantially concurrently or in reverse order, depending on the functionality involved, as would be understood by those skilled in the art.


All of the methods and processes described above may be embodied in, and partially or fully automated via, software code modules executed by one or more general purpose computers. For example, the methods described herein may be performed by the programming notebook system 100 and/or any other suitable computing device. The methods may be executed on the computing devices in response to execution of software instructions or other executable code read from a tangible computer readable medium. A tangible computer readable medium is a data storage device that can store data that is readable by a computer system. Examples of computer readable mediums include read-only memory, random-access memory, other volatile or non-volatile memory devices, CD-ROMs, magnetic tape, flash drives, and optical data storage devices.


It should be emphasized that many variations and modifications may be made to the above-described embodiments, the elements of which are to be understood as being among other acceptable examples. All such modifications and variations are intended to be included herein within the scope of this disclosure. The foregoing description details certain embodiments of the invention. It will be appreciated, however, that no matter how detailed the foregoing appears in text, the invention can be practiced in many ways. As is also stated above, it should be noted that the use of particular terminology when describing certain features or aspects of the invention should not be taken to imply that the terminology is being re-defined herein to be restricted to including any specific characteristics of the features or aspects of the invention with which that terminology is associated.

Claims
  • 1. A computer system comprising: one or more computer processors configured to execute software code; anda non-transitory storage medium storing software code that, when executed by the one or more computer processors causes the one or more computer processors to: generate a first data visualization representing a first set of data items;receive a selection of an element of the first data visualization representing a subset of the first set of data items;generate, based on the selection, a second data visualization representing the subset of the first set of data items; andgenerate an analysis path visualization including a visual representation of the first data visualization and a visual representation of the second data visualization, wherein the analysis path visualization is rendered as a hierarchical plurality of nodes wherein at least one or more nodes of the hierarchical plurality of nodes indicates query information selected by a user.
  • 2. The computer system of claim 1, wherein the software code, in response to execution by the one or more computer processors, further causes the one or more computer processors to: generate a user interface including first data visualization, the second data visualization, and the analysis path visualization; andcause display of the user interface in an electronic display.
  • 3. The computer system of claim 1, wherein generating the second data visualization comprises: generating, based on the subset of the first set of data items, a query to apply to the first set of data.
  • 4. The computer system of claim 3, wherein the query comprises one or more filters to apply to the first set of data, wherein the one or more filters are based on the selection.
  • 5. The computer system of claim 1, wherein the first or second data visualization comprises at least one of: a time series view, a time grid view, a pivot table view, or a data summary view.
  • 6. The computer system of claim 1, wherein the software code, in response to execution by the one or more computer processors, further causes the one or more computer processors to: receive a selection of an element of the second data visualization representing a subset of the first set of data items;generate, based at least in part on the selection of the element of the second data visualization, a third data visualization; andupdate the analysis path visualization to include a visual representation of the third data visualization.
  • 7. The computer system of claim 6, wherein generating the third data visualization comprises: generating, based at least in part on the selection of the element of the second data visualization, a query to apply to one or more sets of data including the first set of data.
  • 8. The computer system of claim 7, wherein the query comprises a join operation to be performed with respect to a second set of data distinct from the first set of data.
  • 9. The computer system of claim 1, wherein the selection comprises an indication of a range of values.
  • 10. The computer system of claim 1, wherein the visual representations of the first and second data visualizations are selectable, and wherein the software code, in response to execution by the one or more computer processors, further causes the one or more computer processors to: in response to selection of the visual representation of the first data visualization, cause display of the first data visualization in a user interface; andin response to selection of the visual representation of the second data visualization, cause display of the second data visualization in the user interface.
  • 11. A computer-implemented method comprising: by one or more computer processors executing software code: generating a first data visualization representing a first set of data items;receiving a selection of an element of the first data visualization representing a subset of the first set of data items;generating, based on the selection, a second data visualization representing the subset of the first set of data items; andgenerating an analysis path visualization including a visual representation of the first data visualization and a visual representation of the second data visualization, wherein the analysis path visualization is rendered as a hierarchical plurality of nodes wherein at least one or more nodes of the hierarchical plurality of nodes indicates query information selected by a user.
  • 12. The computer-implemented method of claim 11 further comprising: by the one or more computer processors executing software code: generating a user interface including first data visualization, the second data visualization, and the analysis path visualization; andcausing display of the user interface in an electronic display.
  • 13. The computer-implemented method of claim 11, wherein generating the second data visualization comprises: by the one or more computer processors executing software code: generating, based on the subset of the first set of data items, a query to apply to the first set of data, wherein the query comprises one or more filters to apply to the first set of data, wherein the one or more filters are based on the selection.
  • 14. The computer-implemented method of claim 11 further comprising: by the one or more computer processors executing software code: receiving a selection of an element of the second data visualization representing a subset of the first set of data items;generating, based at least in part on the selection of the element of the second data visualization, a third data visualization; andupdating the analysis path visualization to include a visual representation of the third data visualization.
  • 15. The computer-implemented method of claim 14, wherein generating the third data visualization comprises: by the one or more computer processors executing software code: generating, based at least in part on the selection of the element of the second data visualization, a query to apply to one or more sets of data including the first set of data.
  • 16. The computer-implemented method of claim 15, wherein the query comprises a join operation to be performed with respect to a second set of data distinct from the first set of data.
  • 17. The computer-implemented of claim 11, wherein the selection comprises an indication of a range of values.
  • 18. The computer-implemented method of claim 11, wherein the visual representations of the first and second data visualizations are selectable, and wherein the computer-implemented method further comprises: by the one or more computer processors executing software code: in response to selection of the visual representation of the first data visualization, causing display of the first data visualization in a user interface; andin response to selection of the visual representation of the second data visualization, causing display of the second data visualization in the user interface.
  • 19. The computer-implemented method of claim 11, wherein the analysis path visualization includes a visual representation of multiple paths associated with a plurality of data visualizations including the first data visualization and the second data visualization.
  • 20. A non-transitory computer readable storage medium having computer-executable instructions stored thereon, the computer-executable instructions executable by a computing system having one or more hardware processors, wherein the computer-executable instructions are executable to perform operations comprising: generating a first data visualization representing a first set of data items;receiving a selection of an element of the first data visualization representing a subset of the first set of data items;generating, based on the selection, a second data visualization representing the subset of the first set of data items; andgenerating an analysis path visualization including a visual representation of the first data visualization and a visual representation of the second data visualization, wherein the analysis path visualization is rendered as a hierarchical plurality of nodes wherein at least one or more nodes of the hierarchical plurality of nodes indicates query information selected by a user.
CROSS-REFERENCE TO RELATED APPLICATIONS

This application is a continuation of U.S. patent application Ser. No. 14/858,647, filed on Sep. 18, 2015, which claims priority from provisional U.S. Pat. App. No. 62/097,327, filed on Dec. 29, 2014. Each of the above-referenced applications is hereby incorporated by reference in its entirety.

US Referenced Citations (686)
Number Name Date Kind
5109399 Thompson Apr 1992 A
5329108 Lamoure Jul 1994 A
5515488 Hoppe May 1996 A
5632009 Rao et al. May 1997 A
5670987 Doi et al. Sep 1997 A
5781704 Rossmo Jul 1998 A
5798769 Chiu et al. Aug 1998 A
5845300 Comer Dec 1998 A
5870559 Leshem Feb 1999 A
6057757 Arrowsmith et al. May 2000 A
6088032 Mackinlay Jul 2000 A
6091956 Hollenberg Jul 2000 A
6144962 Weinberg Nov 2000 A
6161098 Wallman Dec 2000 A
6219053 Tachibana et al. Apr 2001 B1
6232971 Haynes May 2001 B1
6247019 Davies Jun 2001 B1
6279018 Kudrolli et al. Aug 2001 B1
6341310 Leshem et al. Jan 2002 B1
6366933 Ball et al. Apr 2002 B1
6369835 Lin Apr 2002 B1
6430305 Decker Aug 2002 B1
6456997 Shukla Sep 2002 B1
6549944 Weinberg et al. Apr 2003 B1
6560620 Ching May 2003 B1
6581068 Bensoussan et al. Jun 2003 B1
6594672 Lampson et al. Jul 2003 B1
6631496 Li et al. Oct 2003 B1
6642945 Sharpe Nov 2003 B1
6674434 Chojnacki et al. Jan 2004 B1
6714936 Nevin, III Mar 2004 B1
6775675 Nwabueze et al. Aug 2004 B1
6820135 Dingman Nov 2004 B1
6828920 Owen et al. Dec 2004 B2
6839745 Dingari et al. Jan 2005 B1
6877137 Rivette et al. Apr 2005 B1
6900807 Liongosari May 2005 B1
6976210 Silva et al. Dec 2005 B1
6978419 Kantrowitz Dec 2005 B1
6980984 Huffman et al. Dec 2005 B1
6985950 Hanson et al. Jan 2006 B1
7020847 Holzheuer Mar 2006 B1
7036085 Barros Apr 2006 B2
7043702 Chi et al. May 2006 B2
7055110 Kupka et al. May 2006 B2
7139800 Bellotti et al. Nov 2006 B2
7158878 Rasmussen et al. Jan 2007 B2
7162475 Ackerman Jan 2007 B2
7168039 Bertram Jan 2007 B2
7171427 Witkowski Jan 2007 B2
7269786 Malloy et al. Sep 2007 B1
7278105 Kitts Oct 2007 B1
7290698 Poslinski et al. Nov 2007 B2
7333998 Heckerman et al. Feb 2008 B2
7370047 Gorman May 2008 B2
7379811 Rasmussen et al. May 2008 B2
7379903 Caballero et al. May 2008 B2
7426654 Adams et al. Sep 2008 B2
7454466 Bellotti et al. Nov 2008 B2
7461077 Greenwood Dec 2008 B1
7467375 Tondreau et al. Dec 2008 B2
7487139 Fraleigh et al. Feb 2009 B2
7502786 Liu et al. Mar 2009 B2
7525422 Bishop et al. Apr 2009 B2
7529727 Arning et al. May 2009 B2
7529734 Dirisala May 2009 B2
7558677 Jones Jun 2009 B2
7574409 Patinkin Aug 2009 B2
7574428 Leiserowitz et al. Aug 2009 B2
7579965 Bucholz Aug 2009 B2
7596285 Brown et al. Sep 2009 B2
7614006 Molander Nov 2009 B2
7617185 Werner Nov 2009 B2
7617232 Gabbert et al. Nov 2009 B2
7620628 Kapur et al. Nov 2009 B2
7624122 Gaurav Nov 2009 B2
7627812 Chamberlain et al. Dec 2009 B2
7634717 Chamberlain et al. Dec 2009 B2
7703021 Flam Apr 2010 B1
7706817 Bamrah et al. Apr 2010 B2
7712049 Williams et al. May 2010 B2
7716077 Mikurak May 2010 B1
7725530 Sah et al. May 2010 B2
7725547 Albertson et al. May 2010 B2
7730082 Sah et al. Jun 2010 B2
7730109 Rohrs et al. Jun 2010 B2
7756843 Palmer Jul 2010 B1
7770100 Chamberlain et al. Aug 2010 B2
7805457 Viola et al. Sep 2010 B1
7809703 Balabhadrapatruni et al. Oct 2010 B2
7818291 Ferguson et al. Oct 2010 B2
7818658 Chen Oct 2010 B2
7870493 Pall et al. Jan 2011 B2
7894984 Rasmussen et al. Feb 2011 B2
7899611 Downs et al. Mar 2011 B2
7899796 Borthwick et al. Mar 2011 B1
7917376 Bellin et al. Mar 2011 B2
7920963 Jouline et al. Apr 2011 B2
7933862 Chamberlain et al. Apr 2011 B2
7941321 Greenstein et al. May 2011 B2
7962281 Rasmussen et al. Jun 2011 B2
7962495 Jain et al. Jun 2011 B2
7962848 Bertram Jun 2011 B2
7970240 Chao et al. Jun 2011 B1
7971150 Raskutti et al. Jun 2011 B2
7984374 Caro et al. Jun 2011 B2
8001465 Kudrolli et al. Aug 2011 B2
8001482 Bhattiprolu et al. Aug 2011 B2
8010545 Stefik et al. Aug 2011 B2
8015487 Roy et al. Sep 2011 B2
8019749 Leban Sep 2011 B2
8024778 Cash et al. Sep 2011 B2
8036632 Cona et al. Oct 2011 B1
8036971 Aymeloglu et al. Oct 2011 B2
8037046 Udezue Oct 2011 B2
8042110 Kawahara et al. Oct 2011 B1
8046283 Burns Oct 2011 B2
8054756 Chand et al. Nov 2011 B2
8103543 Zwicky Jan 2012 B1
8134457 Velipasalar et al. Mar 2012 B2
8145703 Frishert et al. Mar 2012 B2
8185819 Sah et al. May 2012 B2
8214361 Sandler et al. Jul 2012 B1
8214490 Vos et al. Jul 2012 B1
8214764 Gemmell et al. Jul 2012 B2
8225201 Michael Jul 2012 B2
8229902 Vishniac et al. Jul 2012 B2
8229947 Fujinaga Jul 2012 B2
8230333 Decherd et al. Jul 2012 B2
8249885 Berkowitz Aug 2012 B2
8271461 Pike et al. Sep 2012 B2
8280880 Aymeloglu et al. Oct 2012 B1
8290838 Thakur et al. Oct 2012 B1
8290926 Ozzie et al. Oct 2012 B2
8290942 Jones et al. Oct 2012 B2
8301464 Cave et al. Oct 2012 B1
8301904 Gryaznov Oct 2012 B1
8302855 Ma et al. Nov 2012 B2
8312367 Foster Nov 2012 B2
8312546 Alme Nov 2012 B2
8352881 Champion et al. Jan 2013 B2
8368695 Howell et al. Feb 2013 B2
8386377 Xiong et al. Feb 2013 B1
8397171 Klassen et al. Mar 2013 B2
8412707 Mianji Apr 2013 B1
8447722 Ahuja et al. May 2013 B1
8452790 Mianji May 2013 B1
8463036 Ramesh et al. Jun 2013 B1
8473454 Evanitsky et al. Jun 2013 B2
8484115 Aymeloglu et al. Jul 2013 B2
8489331 Kopf et al. Jul 2013 B2
8489641 Seefeld Jul 2013 B1
8494984 Hwang et al. Jul 2013 B2
8510743 Hackborn et al. Aug 2013 B2
8514082 Cova et al. Aug 2013 B2
8515207 Chau Aug 2013 B2
8554579 Tribble et al. Oct 2013 B2
8554653 Falkenborg et al. Oct 2013 B2
8554709 Goodson et al. Oct 2013 B2
8560413 Quarterman Oct 2013 B1
8577911 Stepinski et al. Nov 2013 B1
8589273 Creeden et al. Nov 2013 B2
8595234 Siripurapu et al. Nov 2013 B2
8620641 Farnsworth et al. Dec 2013 B2
8646080 Williamson et al. Feb 2014 B2
8639757 Adams et al. Mar 2014 B1
8676857 Adams et al. Mar 2014 B1
8688573 Rukonic et al. Apr 2014 B1
8689108 Duffield et al. Apr 2014 B1
8713467 Goldenberg et al. Apr 2014 B1
8726379 Stiansen et al. May 2014 B1
8739278 Varghese May 2014 B2
8742934 Sarpy et al. Jun 2014 B1
8744890 Bernier Jun 2014 B1
8745516 Mason et al. Jun 2014 B2
8781169 Jackson et al. Jul 2014 B2
8787939 Papakipos et al. Jul 2014 B2
8788407 Singh et al. Jul 2014 B1
8799799 Cervelli Aug 2014 B1
8806355 Twiss Aug 2014 B2
8812960 Sun et al. Aug 2014 B1
8830322 Nerayoff et al. Sep 2014 B2
8832594 Thompson et al. Sep 2014 B1
8868537 Colgrove et al. Oct 2014 B1
8917274 Ma et al. Dec 2014 B2
8924388 Elliot et al. Dec 2014 B2
8924389 Elliot et al. Dec 2014 B2
8924872 Bogomolov et al. Dec 2014 B1
8937619 Sharma et al. Jan 2015 B2
8938686 Erenrich et al. Jan 2015 B1
8949164 Mohler Feb 2015 B1
9009171 Grossman et al. Apr 2015 B1
9009827 Albertson et al. Apr 2015 B1
9021260 Falk et al. Apr 2015 B1
9021384 Beard et al. Apr 2015 B1
9043696 Meiklejohn et al. May 2015 B1
9043894 Dennison et al. May 2015 B1
9069842 Melby Jun 2015 B2
9100428 Visbal Aug 2015 B1
9111281 Stibel Aug 2015 B2
9116975 Shankar et al. Aug 2015 B2
9129219 Robertson et al. Sep 2015 B1
9256664 Chakerian et al. Feb 2016 B2
9280618 Bruce Mar 2016 B1
9286373 Elliot et al. Mar 2016 B2
9335911 Elliot May 2016 B1
9483745 Ackermann Nov 2016 B2
20020033848 Sciammarella et al. Mar 2002 A1
20020065708 Senay et al. May 2002 A1
20020091707 Keller Jul 2002 A1
20020095360 Joao Jul 2002 A1
20020095658 Shulman Jul 2002 A1
20020103705 Brady Aug 2002 A1
20020116120 Ruiz et al. Aug 2002 A1
20020147805 Leshem et al. Oct 2002 A1
20020174201 Ramer et al. Nov 2002 A1
20020194119 Wright et al. Dec 2002 A1
20030028560 Kudrolli et al. Feb 2003 A1
20030036848 Sheha et al. Feb 2003 A1
20030039948 Donahue Feb 2003 A1
20030126102 Borthwick Jul 2003 A1
20030140106 Raguseo Jul 2003 A1
20030144868 MacIntyre et al. Jul 2003 A1
20030163352 Surpin et al. Aug 2003 A1
20030200217 Ackerman Oct 2003 A1
20030225755 Iwayama et al. Dec 2003 A1
20030229848 Arend et al. Dec 2003 A1
20040032432 Baynger Feb 2004 A1
20040034570 Davis Feb 2004 A1
20040064256 Barinek et al. Apr 2004 A1
20040085318 Hassler et al. May 2004 A1
20040095349 Bito et al. May 2004 A1
20040111410 Burgoon et al. Jun 2004 A1
20040111480 Yue Jun 2004 A1
20040126840 Cheng et al. Jul 2004 A1
20040143602 Ruiz et al. Jul 2004 A1
20040143796 Lerner et al. Jul 2004 A1
20040153418 Hanweck Aug 2004 A1
20040163039 McPherson et al. Aug 2004 A1
20040193600 Kaasten et al. Sep 2004 A1
20040221223 Yu et al. Nov 2004 A1
20040236688 Bozeman Nov 2004 A1
20040260702 Cragun et al. Dec 2004 A1
20040267746 Marcjan et al. Dec 2004 A1
20050010472 Quatse et al. Jan 2005 A1
20050027705 Sadri et al. Feb 2005 A1
20050028094 Allyn Feb 2005 A1
20050039119 Parks et al. Feb 2005 A1
20050065811 Chu et al. Mar 2005 A1
20050080769 Gemmell Apr 2005 A1
20050080770 Lueder Apr 2005 A1
20050086207 Heuer et al. Apr 2005 A1
20050125715 Franco et al. Jun 2005 A1
20050154628 Eckart et al. Jul 2005 A1
20050154769 Eckart et al. Jul 2005 A1
20050162523 Darrell et al. Jul 2005 A1
20050166144 Gross Jul 2005 A1
20050180330 Shapiro Aug 2005 A1
20050182793 Keenan et al. Aug 2005 A1
20050183005 Denoue et al. Aug 2005 A1
20050210409 Jou Sep 2005 A1
20050246327 Yeung et al. Nov 2005 A1
20050251786 Citron et al. Nov 2005 A1
20060026120 Carolan et al. Feb 2006 A1
20060026170 Kreitler Feb 2006 A1
20060059139 Robinson Mar 2006 A1
20060074881 Vembu et al. Apr 2006 A1
20060080283 Shipman Apr 2006 A1
20060080619 Carlson et al. Apr 2006 A1
20060093222 Saffer et al. May 2006 A1
20060129746 Porter Jun 2006 A1
20060139375 Rasmussen et al. Jun 2006 A1
20060142949 Helt Jun 2006 A1
20060143034 Rothermel Jun 2006 A1
20060143075 Carr et al. Jun 2006 A1
20060143079 Basak et al. Jun 2006 A1
20060149596 Surpin et al. Jul 2006 A1
20060203337 White Sep 2006 A1
20060218637 Thomas et al. Sep 2006 A1
20060241974 Chao et al. Oct 2006 A1
20060242040 Rader Oct 2006 A1
20060242630 Koike et al. Oct 2006 A1
20060271277 Hu et al. Nov 2006 A1
20060279630 Aggarwal et al. Dec 2006 A1
20070000999 Kubo et al. Jan 2007 A1
20070011150 Frank Jan 2007 A1
20070011304 Error Jan 2007 A1
20070016363 Huang et al. Jan 2007 A1
20070038646 Thota Feb 2007 A1
20070038962 Fuchs et al. Feb 2007 A1
20070057966 Ohno et al. Mar 2007 A1
20070078832 Ott et al. Apr 2007 A1
20070083541 Fraleigh et al. Apr 2007 A1
20070088596 Berkelhamer et al. Apr 2007 A1
20070094389 Nussey et al. Apr 2007 A1
20070112737 Carlson May 2007 A1
20070150369 Zivin Jun 2007 A1
20070150801 Chidlovskii et al. Jun 2007 A1
20070156673 Maga Jul 2007 A1
20070162454 D'Albora et al. Jul 2007 A1
20070174760 Chamberlain et al. Jul 2007 A1
20070185867 Maga Aug 2007 A1
20070192122 Routson et al. Aug 2007 A1
20070192265 Chopin et al. Aug 2007 A1
20070198571 Ferguson et al. Aug 2007 A1
20070208497 Downs et al. Sep 2007 A1
20070208498 Barker et al. Sep 2007 A1
20070208736 Tanigawa et al. Sep 2007 A1
20070233709 Abnous Oct 2007 A1
20070240062 Christena et al. Oct 2007 A1
20070266336 Nojima et al. Nov 2007 A1
20070284433 Domenica et al. Dec 2007 A1
20070294643 Kyle Dec 2007 A1
20080040275 Paulsen et al. Feb 2008 A1
20080040684 Crump Feb 2008 A1
20080051989 Welsh Feb 2008 A1
20080052142 Bailey et al. Feb 2008 A1
20080065655 Chakravarthy Mar 2008 A1
20080065665 Pomroy et al. Mar 2008 A1
20080069081 Chand et al. Mar 2008 A1
20080077597 Butler Mar 2008 A1
20080077642 Carbone Mar 2008 A1
20080082486 Lermant et al. Apr 2008 A1
20080103996 Forman et al. May 2008 A1
20080104019 Nath May 2008 A1
20080126951 Sood et al. May 2008 A1
20080148398 Mezack et al. Jun 2008 A1
20080155440 Trevor et al. Jun 2008 A1
20080162616 Gross et al. Jul 2008 A1
20080195417 Surpin et al. Aug 2008 A1
20080195608 Clover Aug 2008 A1
20080208735 Balet et al. Aug 2008 A1
20080222295 Robinson et al. Sep 2008 A1
20080243711 Aymeloglu et al. Oct 2008 A1
20080249983 Meisels et al. Oct 2008 A1
20080255973 El Wade et al. Oct 2008 A1
20080263468 Cappione et al. Oct 2008 A1
20080267107 Rosenberg Oct 2008 A1
20080270328 Lafferty et al. Oct 2008 A1
20080276167 Michael Nov 2008 A1
20080278311 Grange et al. Nov 2008 A1
20080288306 MacIntyre et al. Nov 2008 A1
20080288475 Kim et al. Nov 2008 A1
20080294663 Heinley Nov 2008 A1
20080301559 Martinsen et al. Dec 2008 A1
20080301643 Appleton et al. Dec 2008 A1
20080313132 Hao et al. Dec 2008 A1
20080313281 Scheidl et al. Dec 2008 A1
20090002492 Velipasalar et al. Jan 2009 A1
20090027418 Maru et al. Jan 2009 A1
20090030915 Winter et al. Jan 2009 A1
20090037912 Stoitsev et al. Feb 2009 A1
20090043762 Shiverick Feb 2009 A1
20090055251 Shah et al. Feb 2009 A1
20090076845 Bellin et al. Mar 2009 A1
20090088964 Schaaf et al. Apr 2009 A1
20090094166 Aymeloglu et al. Apr 2009 A1
20090094270 Alirez et al. Apr 2009 A1
20090106178 Chu Apr 2009 A1
20090112745 Stefanescu Apr 2009 A1
20090119309 Gibson et al. May 2009 A1
20090125359 Knapic May 2009 A1
20090125369 Kloostra et al. May 2009 A1
20090125459 Norton et al. May 2009 A1
20090132921 Hwangbo May 2009 A1
20090132953 Reed, Jr. May 2009 A1
20090143052 Bates et al. Jun 2009 A1
20090144262 White et al. Jun 2009 A1
20090144274 Fraleigh et al. Jun 2009 A1
20090157732 Hao et al. Jun 2009 A1
20090164934 Bhattiprolu et al. Jun 2009 A1
20090171939 Athsani et al. Jul 2009 A1
20090172511 Decherd et al. Jul 2009 A1
20090172821 Daira et al. Jul 2009 A1
20090177962 Gusmorino et al. Jul 2009 A1
20090179892 Tsuda et al. Jul 2009 A1
20090187464 Bai et al. Jul 2009 A1
20090187546 Whyte et al. Jul 2009 A1
20090187548 Ji et al. Jul 2009 A1
20090222400 Kupershmidt et al. Sep 2009 A1
20090222759 Drieschner Sep 2009 A1
20090222760 Halverson et al. Sep 2009 A1
20090234720 George et al. Sep 2009 A1
20090249244 Robinson et al. Oct 2009 A1
20090254572 Redlich Oct 2009 A1
20090254842 Leacock Oct 2009 A1
20090254970 Agarwal et al. Oct 2009 A1
20090259636 Labrou et al. Oct 2009 A1
20090271343 Vaiciulis et al. Oct 2009 A1
20090281839 Lynn et al. Nov 2009 A1
20090287470 Farnsworth et al. Nov 2009 A1
20090292626 Oxford Nov 2009 A1
20090307049 Elliott et al. Dec 2009 A1
20090313463 Pang et al. Dec 2009 A1
20090319418 Herz Dec 2009 A1
20090319515 Minton et al. Dec 2009 A1
20090319891 MacKinlay Dec 2009 A1
20100004857 Pereira et al. Jan 2010 A1
20100011282 Dollard et al. Jan 2010 A1
20100030722 Goodson Feb 2010 A1
20100031141 Summers et al. Feb 2010 A1
20100042922 Bradateanu et al. Feb 2010 A1
20100057622 Faith et al. Mar 2010 A1
20100057716 Stefik et al. Mar 2010 A1
20100070523 Delgo et al. Mar 2010 A1
20100070842 Aymeloglu et al. Mar 2010 A1
20100070845 Facemire et al. Mar 2010 A1
20100070897 Aymeloglu et al. Mar 2010 A1
20100076979 Wang Mar 2010 A1
20100098318 Anderson Apr 2010 A1
20100100963 Mahaffey Apr 2010 A1
20100103124 Kruzeniski et al. Apr 2010 A1
20100106752 Eckardt et al. Apr 2010 A1
20100114887 Conway et al. May 2010 A1
20100114916 Cooke May 2010 A1
20100122152 Chamberlain et al. May 2010 A1
20100131457 Heimendinger May 2010 A1
20100131502 Fordham May 2010 A1
20100161735 Sharma Jun 2010 A1
20100162176 Dunton Jun 2010 A1
20100191563 Schlaifer et al. Jul 2010 A1
20100198684 Eraker et al. Aug 2010 A1
20100199225 Coleman et al. Aug 2010 A1
20100211535 Rosenberger Aug 2010 A1
20100228812 Uomini Sep 2010 A1
20100235915 Memon et al. Sep 2010 A1
20100250412 Wagner Sep 2010 A1
20100262688 Hussain et al. Oct 2010 A1
20100280857 Liu et al. Nov 2010 A1
20100293174 Bennett Nov 2010 A1
20100306713 Geisner et al. Dec 2010 A1
20100312837 Bodapati et al. Dec 2010 A1
20100313119 Baldwin et al. Dec 2010 A1
20100318924 Frankel et al. Dec 2010 A1
20100321399 Ellren et al. Dec 2010 A1
20100325526 Ellis et al. Dec 2010 A1
20100325581 Finkelstein et al. Dec 2010 A1
20100330801 Rouh Dec 2010 A1
20110004498 Readshaw Jan 2011 A1
20110029526 Knight et al. Feb 2011 A1
20110040776 Najm et al. Feb 2011 A1
20110047159 Baid et al. Feb 2011 A1
20110060753 Shaked et al. Mar 2011 A1
20110061013 Bilicki et al. Mar 2011 A1
20110066933 Ludwig Mar 2011 A1
20110074811 Hanson et al. Mar 2011 A1
20110078055 Faribault et al. Mar 2011 A1
20110078173 Seligmann et al. Mar 2011 A1
20110093327 Fordyce, III et al. Apr 2011 A1
20110099133 Chang et al. Apr 2011 A1
20110117878 Barash et al. May 2011 A1
20110119100 Ruhl et al. May 2011 A1
20110137766 Rasmussen et al. Jun 2011 A1
20110153384 Horne et al. Jun 2011 A1
20110161096 Buehler et al. Jun 2011 A1
20110167105 Ramakrishnan et al. Jul 2011 A1
20110167710 Ramakrishnan et al. Jul 2011 A1
20110170799 Carrino et al. Jul 2011 A1
20110173032 Payne et al. Jul 2011 A1
20110173093 Psota et al. Jul 2011 A1
20110185316 Reid et al. Jul 2011 A1
20110208565 Ross et al. Aug 2011 A1
20110208724 Jones Aug 2011 A1
20110213655 Henkin Sep 2011 A1
20110218934 Elser Sep 2011 A1
20110218955 Tang Sep 2011 A1
20110219450 McDougal et al. Sep 2011 A1
20110225198 Edwards et al. Sep 2011 A1
20110238495 Kang Sep 2011 A1
20110238553 Raj et al. Sep 2011 A1
20110251951 Kolkowitz Oct 2011 A1
20110258158 Resende et al. Oct 2011 A1
20110270604 Qi et al. Nov 2011 A1
20110270705 Parker Nov 2011 A1
20110270834 Sokolan et al. Nov 2011 A1
20110289397 Eastmond et al. Nov 2011 A1
20110289407 Naik et al. Nov 2011 A1
20110289420 Morioka et al. Nov 2011 A1
20110291851 Whisenant Dec 2011 A1
20110295649 Fine Dec 2011 A1
20110310005 Chen et al. Dec 2011 A1
20110314007 Dassa et al. Dec 2011 A1
20110314024 Chang et al. Dec 2011 A1
20120004904 Shin et al. Jan 2012 A1
20120011238 Rathod Jan 2012 A1
20120011245 Gillette et al. Jan 2012 A1
20120019559 Siler et al. Jan 2012 A1
20120022945 Falkenborg et al. Jan 2012 A1
20120036013 Neuhaus et al. Feb 2012 A1
20120036434 Oberstein Feb 2012 A1
20120050293 Carlhian et al. Mar 2012 A1
20120054284 Rakshit Mar 2012 A1
20120059853 Jagota Mar 2012 A1
20120066166 Curbera et al. Mar 2012 A1
20120066296 Appleton et al. Mar 2012 A1
20120072825 Sherkin et al. Mar 2012 A1
20120079363 Folting et al. Mar 2012 A1
20120084117 Tavares et al. Apr 2012 A1
20120084118 Bai et al. Apr 2012 A1
20120084287 Lakshminarayan et al. Apr 2012 A1
20120089606 Eshwar et al. Apr 2012 A1
20120106801 Jackson May 2012 A1
20120117082 Koperda et al. May 2012 A1
20120131512 Takeuchi et al. May 2012 A1
20120137235 Ts et al. May 2012 A1
20120144335 Abeln Jun 2012 A1
20120158527 Cannelongo et al. Jun 2012 A1
20120159307 Chung et al. Jun 2012 A1
20120159362 Brown et al. Jun 2012 A1
20120159399 Bastide et al. Jun 2012 A1
20120170847 Tsukidate Jul 2012 A1
20120173381 Smith Jul 2012 A1
20120173985 Peppel Jul 2012 A1
20120180002 Campbell et al. Jul 2012 A1
20120196557 Reich et al. Aug 2012 A1
20120196558 Reich et al. Aug 2012 A1
20120197651 Robinson et al. Aug 2012 A1
20120203708 Psota et al. Aug 2012 A1
20120208636 Feige Aug 2012 A1
20120215784 King et al. Aug 2012 A1
20120221511 Gibson et al. Aug 2012 A1
20120221553 Wittmer et al. Aug 2012 A1
20120221580 Barney Aug 2012 A1
20120226523 Weiss Sep 2012 A1
20120245976 Kumar et al. Sep 2012 A1
20120246148 Dror Sep 2012 A1
20120254129 Wheeler et al. Oct 2012 A1
20120266245 McDougal et al. Oct 2012 A1
20120284345 Costenaro et al. Nov 2012 A1
20120290879 Shibuya et al. Nov 2012 A1
20120296907 Long et al. Nov 2012 A1
20120304244 Xie et al. Nov 2012 A1
20120311684 Paulsen et al. Dec 2012 A1
20120323829 Stokes et al. Dec 2012 A1
20120323888 Osann, Jr. Dec 2012 A1
20120323889 Marum Dec 2012 A1
20120330801 McDougal et al. Dec 2012 A1
20120330973 Ghuneim et al. Dec 2012 A1
20130006426 Healey et al. Jan 2013 A1
20130006725 Simanek et al. Jan 2013 A1
20130006916 McBride et al. Jan 2013 A1
20130016106 Yip et al. Jan 2013 A1
20130018796 Kolhatkar et al. Jan 2013 A1
20130024268 Manickavelu Jan 2013 A1
20130046635 Grigg et al. Feb 2013 A1
20130046842 Muntz et al. Feb 2013 A1
20130054306 Bhalla Feb 2013 A1
20130055145 Antony et al. Feb 2013 A1
20130057551 Ebert et al. Mar 2013 A1
20130060786 Serrano et al. Mar 2013 A1
20130061169 Pearcy et al. Mar 2013 A1
20130073377 Heath Mar 2013 A1
20130073454 Busch Mar 2013 A1
20130078943 Biage et al. Mar 2013 A1
20130086482 Parsons Apr 2013 A1
20130096988 Grossman et al. Apr 2013 A1
20130097482 Marantz et al. Apr 2013 A1
20130110746 Ahn May 2013 A1
20130110822 Ikeda et al. May 2013 A1
20130110877 Bonham et al. May 2013 A1
20130111320 Campbell et al. May 2013 A1
20130117651 Waldman et al. May 2013 A1
20130101159 Rosen Jun 2013 A1
20130150004 Rosen Jun 2013 A1
20130151148 Parundekar et al. Jun 2013 A1
20130151388 Falkenborg et al. Jun 2013 A1
20130151453 Bhanot et al. Jun 2013 A1
20130157234 Gulli et al. Jun 2013 A1
20130166348 Scotto Jun 2013 A1
20130166480 Popescu et al. Jun 2013 A1
20130166550 Buchmann et al. Jun 2013 A1
20130176321 Mitchell et al. Jul 2013 A1
20130179420 Park et al. Jul 2013 A1
20130185245 Anderson Jul 2013 A1
20130185307 El-Yaniv et al. Jul 2013 A1
20130218879 Park et al. Aug 2013 A1
20130224696 Wolfe et al. Aug 2013 A1
20130225212 Khan Aug 2013 A1
20130226318 Procyk Aug 2013 A1
20130226953 Markovich et al. Aug 2013 A1
20130232045 Tai Sep 2013 A1
20130238616 Rose et al. Sep 2013 A1
20130246170 Gross et al. Sep 2013 A1
20130246537 Gaddala Sep 2013 A1
20130246597 Iizawa et al. Sep 2013 A1
20130251233 Yang et al. Sep 2013 A1
20130208565 Castellanos et al. Oct 2013 A1
20130262527 Hunter et al. Oct 2013 A1
20130262528 Foit Oct 2013 A1
20130263019 Castellanos et al. Oct 2013 A1
20130267207 Hao et al. Oct 2013 A1
20130268520 Fisher Oct 2013 A1
20130279757 Kephart Oct 2013 A1
20130282696 John et al. Oct 2013 A1
20130288719 Alonzo Oct 2013 A1
20130290011 Lynn et al. Oct 2013 A1
20130290825 Arndt et al. Oct 2013 A1
20130297619 Chandarsekaran et al. Nov 2013 A1
20130304770 Boero et al. Nov 2013 A1
20130311375 Priebatsch Nov 2013 A1
20130318604 Coates et al. Nov 2013 A1
20140012796 Petersen et al. Jan 2014 A1
20140019936 Cohanoff Jan 2014 A1
20140032506 Hoey et al. Jan 2014 A1
20140033010 Richardt et al. Jan 2014 A1
20140040371 Gurevich et al. Feb 2014 A1
20140047319 Eberlein Feb 2014 A1
20140047357 Alfaro et al. Feb 2014 A1
20140053091 Hou Feb 2014 A1
20140058914 Song et al. Feb 2014 A1
20140059038 McPherson et al. Feb 2014 A1
20140067611 Adachi et al. Mar 2014 A1
20140068487 Steiger et al. Mar 2014 A1
20140074855 Zhao et al. Mar 2014 A1
20140081685 Thacker et al. Mar 2014 A1
20140095273 Tang et al. Apr 2014 A1
20140095509 Patton Apr 2014 A1
20140108068 Williams Apr 2014 A1
20140108380 Gotz et al. Apr 2014 A1
20140108985 Scott et al. Apr 2014 A1
20140123279 Bishop et al. May 2014 A1
20140129261 Bothwell et al. May 2014 A1
20140136285 Carvalho May 2014 A1
20140143009 Brice et al. May 2014 A1
20140149436 Bahrami et al. May 2014 A1
20140156527 Grigg et al. Jun 2014 A1
20140157172 Peery et al. Jun 2014 A1
20140164502 Khodorenko et al. Jun 2014 A1
20140189536 Lange et al. Jul 2014 A1
20140189870 Singla et al. Jul 2014 A1
20140195515 Baker et al. Jul 2014 A1
20140195887 Ellis et al. Jul 2014 A1
20140214579 Shen et al. Jul 2014 A1
20140214810 Takeda Jul 2014 A1
20140222521 Chait Aug 2014 A1
20140222793 Sadkin et al. Aug 2014 A1
20140229554 Grunin et al. Aug 2014 A1
20140244388 Manouchehri et al. Aug 2014 A1
20140250377 Bisca Sep 2014 A1
20140258246 Lo Faro et al. Sep 2014 A1
20140267294 Ma Sep 2014 A1
20140267295 Sharma Sep 2014 A1
20140279824 Tamayo Sep 2014 A1
20140280056 Kelly Sep 2014 A1
20140282160 Zarpas Sep 2014 A1
20140310266 Greenfield Oct 2014 A1
20140316911 Gross Oct 2014 A1
20140333651 Cervelli et al. Nov 2014 A1
20140337772 Cervelli et al. Nov 2014 A1
20140344230 Krause et al. Nov 2014 A1
20140351070 Christner et al. Nov 2014 A1
20140358829 Hurwitz Dec 2014 A1
20140366132 Stiansen et al. Dec 2014 A1
20140372956 Bisca Dec 2014 A1
20150019394 Unser et al. Jan 2015 A1
20150046870 Goldenberg Feb 2015 A1
20150073929 Psota et al. Mar 2015 A1
20150073954 Braff Mar 2015 A1
20150089424 Duffield Mar 2015 A1
20150095773 Gonsalves et al. Apr 2015 A1
20150100897 Sun et al. Apr 2015 A1
20150100907 Erenrich et al. Apr 2015 A1
20150106170 Bonica Apr 2015 A1
20150106379 Elliot et al. Apr 2015 A1
20150134599 Banerjee May 2015 A1
20150134666 Gattiker et al. May 2015 A1
20150135256 Hoy et al. May 2015 A1
20150169709 Kara et al. Jun 2015 A1
20150169726 Kara et al. Jun 2015 A1
20150170077 Kara et al. Jun 2015 A1
20150178825 Huerta Jun 2015 A1
20150178877 Bogomolov et al. Jun 2015 A1
20150186821 Wang et al. Jul 2015 A1
20150187036 Wang et al. Jul 2015 A1
20150188872 White Jul 2015 A1
20150227295 Meiklejohn et al. Aug 2015 A1
20150242401 Liu Aug 2015 A1
20150309719 Ma et al. Oct 2015 A1
20150317342 Grossman et al. Nov 2015 A1
20150324868 Kaftan et al. Nov 2015 A1
20150338233 Cervelli Nov 2015 A1
20150379413 Robertson et al. Dec 2015 A1
20160004764 Chakerian et al. Jan 2016 A1
20160034463 Brewer Feb 2016 A1
20160180557 Yousaf et al. Jun 2016 A1
20170116259 Elliot et al. Apr 2017 A1
Foreign Referenced Citations (54)
Number Date Country
102546446 Jul 2012 CN
103167093 Jun 2013 CN
102054015 May 2014 CN
102014103482 Sep 2014 DE
102014204827 Sep 2014 DE
102014204830 Sep 2014 DE
102014204834 Sep 2014 DE
102014215621 Feb 2015 DE
1672527 Jun 2006 EP
2487610 Aug 2012 EP
2551799 Jan 2013 EP
2560134 Feb 2013 EP
2778977 Sep 2014 EP
2835745 Feb 2015 EP
2835770 Feb 2015 EP
2838039 Feb 2015 EP
2846241 Mar 2015 EP
2851852 Mar 2015 EP
2858014 Apr 2015 EP
2858018 Apr 2015 EP
2863326 Apr 2015 EP
2863346 Apr 2015 EP
2869211 May 2015 EP
2881868 Jun 2015 EP
2884439 Jun 2015 EP
2884440 Jun 2015 EP
2889814 Jul 2015 EP
2891992 Jul 2015 EP
2892197 Jul 2015 EP
2911078 Aug 2015 EP
2911100 Aug 2015 EP
2940603 Nov 2015 EP
2940609 Nov 2015 EP
2963595 Jan 2016 EP
2996053 Mar 2016 EP
3035214 Jun 2016 EP
3038002 Jun 2016 EP
3040885 Jul 2016 EP
2516155 Jan 2015 GB
2518745 Apr 2015 GB
2012778 Nov 2014 NL
2013306 Feb 2015 NL
624557 Dec 2014 NZ
WO 00009529 Feb 2000 WO
WO 02065353 Aug 2002 WO
WO 2005104736 Nov 2005 WO
WO 2005116851 Dec 2005 WO
WO 2008064207 May 2008 WO
WO 2009061501 May 2009 WO
WO 2010000014 Jan 2010 WO
WO 2010030913 Mar 2010 WO
WO 2012061162 May 2012 WO
WO 2013010157 Jan 2013 WO
WO 2013102892 Jul 2013 WO
Non-Patent Literature Citations (356)
Entry
Brooks et al., “Hoptrees: Branching History Navigation for Hierarchies,” Sep. 2, 2013, Network and Parallel Computing, pp. 316-333.
IBM Predictive Analytics, https://www.ibm.com/analytics/us/en/technology/predictive-analytics/, as printed Feb. 15, 2017 in 12 pages.
IBM SPSS Modeler, https://www.ibm.com/us-en/marketplace/spss-modeler, as printed Feb. 15, 2017 in 5 pages.
IBM Analytics, “IBM SPSS software and Watson Analytics: A powerful combo for the cognitive age,” available at https://www.youtube.com/watch?v=AvYctzFf8gc, as published on Apr. 14, 2016.
Armand Ruiz, “Watson Analytics, SPSS Modeler and Esri ArcGIS,” available at https://www.youtube.com/watch?v=fk49hw4OrN4, as published on Jul. 28, 2015.
IBM Knowledge Center, “Merge Node,” https://www.ibm.com/support/knowledgecenter/en/SS3RA7_15.0.0/com.ibm.spss.modeler.help/merge_overview.htm[ibm.com], as printed Feb. 14, 2017 in 1 page.
IBM Knowledge Center, “New features in IBM SPSS Modeler Professional,” https://www.ibm.com/support/knowledgecenter/en/SS3RA7_15.0.0/com.ibm.spss.modeler.help/whatsnew_features_pro.htm[ibm.com], as printed Feb. 14, 2017 in 2 pages.
IBM Knowledge Center, “Overview—What's new in IBM Watson Explorer Content Analytics Version 10.0,” https://www.ibm.com/support/knowledgecenter/en/SS8NLW_10.0.0/com.ibm.discovery.es.nav.doc/iiysawhatsnew.htm, as printed Mar. 6, 2017 in 4 pages.
Yates, Rob, “Introducing the IBM Watson Natural Language Classifier,” IBM developerWorks/Developer Centers, posted Jul. 10, 2015 in 4 pages, https://developer.ibm.com/watson/blog/2015/07/10/the-ibm-watson-natural-language-classifier/.
Goyal, Manish, “Announcing our largest release of Watson Developer Cloud services,” IBM developerWorks/Developer Centers, posted Sep. 24, 2015 in 6 pages, https://developer.ibm.com/watson/blog/2015/09/24/announcing-our-largest-release-of-watson-developer-cloud-services/.
IBM Analytics Communities, “Is IBM SPSS statistics now integrated to WatsonAnalytics?” https://community.watsonanalytics.com/discussions/questions/1464/is-ibm-spss-statistics-now-integrated-to-watsonana.html, as printed Mar. 7, 2017 in 2 pages.
IBM Support, “Software lifecycle—Watson Explorer 10.0.0,” https://www-01.ibm.com/software/support/lifecycleapp/PLCDetail.wss?q45=T283072T66911H98, as printed Mar. 7, 2017 in 1 page.
IBM Analytics Communities, “Creating a map visualization for UK coordinates,” https://community.watsonanalytics.com/discussions/questions/3753/creating-a-map-visualisation-for-uk-coordinates.html, as printed Mar. 9, 2017 in 1 page.
Esri News, “IBM and Esri Team Up to Offer Cognitive Analyrics and IoT in the IBM Cloud,” http://www.esri.com/esri-news/releases/16-4qtr/ibm-and-esri-team-up-to-offer-cognitive-analytics-and-iot-in-the-ibm-cloud, as published on Oct. 26, 2016, in 2 pages.
Notice of Allowance for U.S. Appl. No. 15/398,113 dated Jun. 30, 2017.
Official Communication for Europaean Patent Application No. 15202919.5, dated Jun. 12, 2017.
Official Communication for U.S. Appl. No. 15/398,113 dated Feb. 17, 2017.
Gill et al “Computerised Linking of Medical Records: Methodological Guidelines,” Journal of Epidemiology and Community Health, 1993, vol. 47, pp. 316-319.
Wikipedia, “Mobile Web,” Jan. 23, 2015, retrieved from the internet on Mar. 15, 2016 https://en.wikipedia.org/w/index.php?title=Mobile_Web&oldid=643800164.
Winkler, William E., “Bureau of the Census Statistical Research Division Record Linkage Software and Methods for Merging Administrative Lists,” Statistical Research Report Series No. RR2001/03, Jul. 23, 2001, https://www.census.gov/srd/papers/pdf/rr2001-03.pdf, retrieved on Mar. 9, 2016.
Notice of Allowance for U.S. Appl. No. 14/483,527 dated Apr. 29, 2016.
Official Communication for European Patent Application No. 14200298.9 dated May 13, 2015.
Official Communication for European Patent Application No. 15200073.3 dated Mar. 30, 2016.
Official Communication for European Patent Application No. 15201924.6 dated Apr. 25, 2016.
Official Communication for European Patent Application No. 16152984.7 dated Mar. 24, 2016.
Official Communication for U.S. Appl. No. 14/141,252 dated Apr. 14, 2016.
Official Communication for U.S. Appl. No. 14/225,160 dated Jun. 16, 2016.
Official Communication for U.S. Appl. No. 14/225,160 dated Apr. 22, 2016.
Official Communication for U.S. Appl. No. 14/929,584 dated May 25, 2016.
“A First Look: Predicting Market Demand for Food Retail using a Huff Analysis,” TRF Policy Solutions, Jul. 2012, pp. 30.
“A Quick Guide to UniProtKB Swiss-Prot & TrEMBL,” Sep. 2011, pp. 2.
“A Word About Banks and the Laundering of Drug Money,” Aug. 18, 2012, http://www.golemxiv.co.uk/2012/08/a-word-about-banks-and-the-laundering-of-drug-money/.
About 80 Minutes, “Palantir in a Number of Parts—Part 6—Graph,” Mar. 21, 2013, pp. 1-6.
Acklen, Laura, “Absolute Beginner's Guide to Microsoft Word 2003,” Dec. 24, 2003, pp. 15-18, 34-41, 308-316.
Alur et al., “Chapter 2: IBM InfoSphere DataStage Stages,” IBM InfoSphere DataStage Data Flow and Job Design, Jul. 1, 2008, pp. 35-137.
Amnet, “5 Great Tools for Visualizing Your Twitter Followers,” posted Aug. 4, 2010, http://www.amnetblog.com/component/content/article/115-5-grate-tools-for-visualizing-your-twitter-followers.html.
Ananiev et al., “The New Modality API,” http://web.archive.org/web/20061211011958/http://java.sun.com/developer/technicalArticles/J2SE/Desktop/javase6/modality/, Jan. 21, 2006, pp. 8.
Bluttman et al., “Excel Formulas and Functions for Dummies,” 2005, Wiley Publishing, Inc., pp. 280, 284-286.
Boyce, Jim, “Microsoft Outlook 2010 Inside Out,” Aug. 1, 2010, retrieved from the internet https://capdtron.files.wordpress.com/2013/01/outlook-2010-inside_out.pdf.
Bugzilla@Mozilla, “Bug 18726—[feature] Long-click means of invoking contextual menus not supported,” http://bugzilla.mozilla.org/show_bug.cgi?id=18726 printed Jun. 13, 2013 in 11 pages.
Canese et al., “Chapter 2: PubMed: The Bibliographic Database,” The NCBI Handbook, Oct. 2002, pp. 1-10.
Celik, Tantek, “CSS Basic User Interface Module Level 3 (CSS3 UI),” Section 8 Resizing and Overflow, Jan. 17, 2012, retrieved from internet http://www.w3.org/TR/2012/WD-css3-ui-20120117/#resizing-amp-overflow retrieved on May 18, 2015.
Chen et al., “Bringing Order to the Web: Automatically Categorizing Search Results,” CHI 2000, Proceedings of the SIGCHI conference on Human Factors in Computing Systems, Apr. 1-6, 2000, The Hague, The Netherlands, pp. 145-152.
Chung, Chin-Wan, “Dataplex: An Access to Heterogeneous Distributed Databases,” Communications of the ACM, Association for Computing Machinery, Inc., vol. 33, No. 1, Jan. 1, 1990, pp. 70-80.
Conner, Nancy, “Google Apps: The Missing Manual,” May 1, 2008, pp. 15.
Definition “Identify” downloaded Jan. 22, 2015, 1 page.
Definition “Overlay” downloaded Jan. 22, 2015, 1 page.
Delcher et al., “Identifying Bacterial Genes and Endosymbiont DNA with Glimmer,” BioInformatics, vol. 23, No. 6, 2007, pp. 673-679.
Dramowicz, Ela, “Retail Trade Area Analysis Using the Huff Model,” Directions Magazine, Jul. 2, 2005 in 10 pages, http://www.directionsmag.com/articles/retail-trade-area-analysis-using-the-huff-model/123411.
Gesher, Ari, “Palantir Screenshots in the Wild: Swing Sightings,” The Palantir Blog, Sep. 11, 2007, pp. 1-12.
GIS-NET 3 Public—Department of Regional Planning. Planning & Zoning Information for Unincorporated LA County. Retrieved Oct. 2, 2013 from http://gls.planning.lacounty.gov/GIS-NET3_Public/Viewer.html.
Goswami, Gautam, “Quite Writly Said!,” One Brick at a Time, Aug. 21, 2005, pp. 7.
Griffith, Daniel A., “A Generalized Huff Model,” Geographical Analysis, Apr. 1982, vol. 14, No. 2, pp. 135-144.
Hansen et al. “Analyzing Social Media Networks with NodeXL: Insights from a Connected World”, Chapter 4, pp. 53-67 and Chapter 10, pp. 143-164, published Sep. 2010.
Hardesty, “Privacy Challenges: Analysis: It's Surprisingly Easy to Identify Individuals from Credit-Card Metadata,” MIT News on Campus and Around the World, MIT News Office, Jan. 29, 2015, 3 pages.
Hibbert et al., “Prediction of Shopping Behavior Using a Huff Model Within a GIS Framework,” Healthy Eating in Context, Mar. 18, 2011, pp. 16.
Hogue et al., “Thresher: Automating the Unwrapping of Semantic Content from the World Wide Web,” 14th International Conference on World Wide Web, WWW 2005: Chiba, Japan, May 10-14, 2005, pp. 86-95.
Huang et al., “Systematic and Integrative Analysis of Large Gene Lists Using DAVID Bioinformatics Resources,” Nature Protocols, 4.1, 2009, 44-57.
Huff et al., “Calibrating the Huff Model Using ArcGIS Business Analyst,” ESRI, Sep. 2008, pp. 33.
Huff, David L., “Parameter Estimation in the Huff Model,” ESRI, ArcUser, Oct.-Dec. 2003, pp. 34-36.
Kahan et al., “Annotea: an open RDF infrastructure for shared WEB annotations”, Computer Networks 39, pp. 589-608, 2002.
Keylines.com, “An Introduction to KeyLines and Network Visualization,” Mar. 2014, http://keylines.com/wp-content/uploads/2014/03/KeyLines-White-Paper.pdf downloaded May 12, 2014 in 8 pages.
Keylines.com, “KeyLines Datasheet,” Mar. 2014, http://keylines.com/wp-content/uploads/2014/03/KeyLines-datasheet.pdf downloaded May 12, 2014 in 2 pages.
Keylines.com, “Visualizing Threats: Improved Cyber Security Through Network Visualization,” Apr. 2014, http://keylines.com/wp-content/uploads/2014/04/Visualizing-Threats1.pdf downloaded May 12, 2014 in 10 pages.
Kitts, Paul, “Chapter 14: Genome Assembly and Annotation Process,” The NCBI Handbook, Oct. 2002, pp. 1-21.
Li et al., “Interactive Multimodal Visual Search on Mobile Device,” IEEE Transactions on Multimedia, vol. 15, No. 3, Apr. 1, 2013, pp. 594-607.
Liu, Tianshun, “Combining GIS and the Huff Model to Analyze Suitable Locations for a New Asian Supermarket in the Minneapolis and St. Paul, Minnesota USA,” Papers in Resource Analysis, 2012, vol. 14, pp. 8.
Madden, Tom, “Chapter 16: The BLAST Sequence Analysis Tool,” The NCBI Handbook, Oct. 2002, pp. 1-15.
Manno et al., “Introducing Collaboration in Single-user Applications through the Centralized Control Architecture,” 2010, pp. 10.
Manske, “File Saving Dialogs,” http://www.mozilla.org/editor/ui_specs/FileSaveDialogs.html, Jan. 20, 1999, pp. 7.
Map of San Jose, CA. Retrieved Oct. 2, 2013 from http://maps.yahoo.com.
Map of San Jose, CA. Retrieved Oct. 2, 2013 from http://maps.bing.com.
Map of San Jose, CA. Retrieved Oct. 2, 2013 from http://maps.google.com.
Microsoft—Developer Network, “Getting Started with VBA in Word 2010,” Apr. 2010, http://msdn.microsoft.com/en-us/library/ff604039%28v=office.14%29.aspx as printed Apr. 4, 2014 in 17 pages.
Microsoft Office—Visio, “About connecting shapes,” http://office.microsoft.com/en-us/visio-help/about-connecting-shapes-HP085050369.aspx printed Aug. 4, 2011 in 6 pages.
Microsoft Office—Visio, “Add and glue connectors with the Connector tool,” http://office.microsoft.com/en-us/visio-help/add-and-glue-connectors-with-the-connector-tool-HA010048532.aspx?CTT=1 printed Aug. 4, 2011 in 1 page.
Mizrachi, Ilene, “Chapter 1: GenBank: The Nuckeotide Sequence Database,” The NCBI Handbook, Oct. 2002, pp. 1-14.
“Money Laundering Risks and E-Gaming: A European Overview and Assessment,” 2009, http://www.cf.ac.uk/socsi/resources/Levi_Final_Money_Laundering_Risks_egaming.pdf.
Nierman, “Evaluating Structural Similarity in XML Documents,” 2002, 6 pages.
Nolan et al., “MCARTA: A Malicious Code Automated Run-Time Analysis Framework,” Homeland Security, 2012 IEEE Conference on Technologies for, Nov. 13, 2012, pp. 13-17.
Olanoff, Drew, “Deep Dive with the New Google Maps for Desktop with Google Earth Integration, It's More than Just a Utility,” May 15, 2013, pp. 1-6, retrieved from the internet: http://web.archive.org/web/20130515230641/http://techcrunch.com/2013/05/15/deep-dive-with-the-new-google-maps-for-desktop-with-google-earth-integration-its-more-than-just-a-utility/.
Palantir Technologies, “Palantir Labs—Timeline,” Oct. 1, 2010, retrieved from the internet https://www.youtube.com/watch?v=JCgDW5bru9M.
Palmas et al., “An Edge-Bunding Layout for Interactive Parallel Coordinates” 2014 IEEE Pacific Visualization Symposium, pp. 57-64.
Perdisci et al., “Behavioral Clustering of HTTP-Based Malware and Signature Generation Using Malicious Network Traces,” USENIX, Mar. 18, 2010, pp. 1-14.
“Potential Money Laundering Warning Signs,” snapshot taken 2003, https://web.archive.org/web/20030816090055/http:/linsolinc.com/ANTI-MONEY%20LAUNDERING%20TRAINING%20GUIDES.pdf.
Quest, “Toad for Oracle 11.6—Guide to Using Toad,” Sep. 24, 2012, pp. 1-162.
“Refresh CSS Ellipsis When Resizing Container—Stack Overflow,” Jul. 31, 2013, retrieved from internet http://stackoverflow.com/questions/17964681/refresh-css-ellipsis-when-resizing-container, retrieved on May 18, 2015.
Rouse, Margaret, “OLAP Cube,” http://searchdatamanagement.techtarget.com/definition/OLAP-cube, Apr. 28, 2012, pp. 16.
Shi et al., “A Scalable Implementation of Malware Detection Based on Network Connection Behaviors,” 2013 International Conference on Cyber-Enabled Distributed Computing and Knowledge Discovery, IEEE, Oct. 10, 2013, pp. 59-66.
Sigrist, et al., “PROSITE, a Protein Domain Database for Functional Characterization and Annotation,” Nucleic Acids Research, 2010, vol. 38, pp. D161-D166.
Sirotkin et al., “Chapter 13: The Processing of Biological Sequence Data at NCBI,” The NCBI Handbook, Oct. 2002, pp. 1-11.
Symantec Corporation, “E-Security Begins with Sound Security Policies,” Announcement Symantec, Jun. 14, 2001.
“The FASTA Program Package,” fasta-36.3.4, Mar. 25, 2011, pp. 29.
Thompson, Mick, “Getting Started with GEO,” Getting Started with GEO, Jul. 26, 2011.
Umagandhi et al., “Search Query Recommendations Using Hybrid User Profile with Query Logs,” International Journal of Computer Applications, vol. 80, No. 10, Oct. 1, 2013, pp. 7-18.
“Using Whois Based Geolocation and Google Maps API for Support Cybercrime Investigations,” http://wseas.us/e-library/conferences/2013/Dubrovnik/TELECIRC/TELECIRC-32.pdf.
Wikipedia, “Federated Database System,” Sep. 7, 2013, retrieved from the internet on Jan. 27, 2015 http://en.wikipedia.org/w/index.php?title=Federated_database_system&oldid=571954221.
Wright et al., “Palantir Technologies VAST 2010 Challenge Text Records—Investigations into Arms Dealing,” Oct. 29, 2010, pp. 1-10.
Yang et al., “HTML Page Analysis Based on Visual Cues,” 2001, pp. 859-864.
Notice of Acceptance for Australian Patent Application No. 2014250678 dated Oct. 7, 2015.
Notice of Allowance for U.S. Appl. No. 12/556,318 dated Nov. 2, 2015.
Notice of Allowance for U.S. Appl. No. 14/102,394 dated Aug. 25, 2014.
Notice of Allowance for U.S. Appl. No. 14/108,187 dated Aug. 29, 2014.
Notice of Allowance for U.S. Appl. No. 14/135,289 dated Oct. 14, 2014.
Notice of Allowance for U.S. Appl. No. 14/148,568 dated Aug. 26, 2015.
Notice of Allowance for U.S. Appl. No. 14/192,767 dated Dec. 16, 2014.
Notice of Allowance for U.S. Appl. No. 14/225,084 dated May 4, 2015.
Notice of Allowance for U.S. Appl. No. 14/268,964 dated Dec. 3, 2014.
Notice of Allowance for U.S. Appl. No. 14/294,098 dated Dec. 29, 2014.
Notice of Allowance for U.S. Appl. No. 14/326,738 dated Nov. 18, 2015.
Notice of Allowance for U.S. Appl. No. 14/473,552 dated Jul. 24, 2015.
Notice of Allowance for U.S. Appl. No. 14/473,860 dated Jan. 5, 2015.
Notice of Allowance for U.S. Appl. No. 14/486,991 dated May 1, 2015.
Notice of Allowance for U.S. Appl. No. 14/504,103 dated May 18, 2015.
Notice of Allowance for U.S. Appl. No. 14/616,080 dated Apr. 2, 2015.
Official Communication for Australian Patent Application No. 2014201511 dated Feb. 27, 2015.
Official Communication for Australian Patent Application No. 2014202442 dated Mar. 19, 2015.
Official Communication for Australian Patent Application No. 2014210604 dated Jun. 5, 2015.
Official Communication for Australian Patent Application No. 2014210614 dated Jun. 5, 2015.
Official Communication for Australian Patent Application No. 2014213553 dated May 7, 2015.
Official Communication for Australian Patent Application No. 2014250678 dated Jun. 17, 2015.
Official Communication for European Patent Application No. 14158861.6 dated Jun. 16, 2014.
Official Communication for European Patent Application No. 14159464.8 dated Jul. 31, 2014.
Official Communication for European Patent Application No. 14180142.3 dated Feb. 6, 2015.
Official Communication for European Patent Application No. 14180281.9 dated Jan. 26, 2015.
Official Communication for European Patent Application No. 14180321.3 dated Apr. 17, 2015.
Official Communication for European Patent Application No. 14180432.8 dated Jun. 23, 2015.
Official Communication for European Patent Application No. 14186225.0 dated Feb. 13, 2015.
Official Communication for European Patent Application No. 14187739.9 dated Jul. 6, 2015.
Official Communication for European Patent Application No. 14187996.5 dated Feb. 12, 2015.
Official Communication for European Patent Application No. 14189344.6 dated Feb. 20, 2015.
Official Communication for European Patent Application No. 14189347.9 dated Mar. 4, 2015.
Official Communication for European Patent Application No. 14189802.3 dated May 11, 2015.
Official Communication for European Patent Application No. 14191540.5 dated May 27, 2015.
Official Communication for European Patent Application No. 14197879.1 dated Apr. 28, 2015.
Official Communication for European Patent Application No. 14197895.7 dated Apr. 28, 2015.
Official Communication for European Patent Application No. 14197938.5 dated Apr. 28, 2015.
Official Communication for European Patent Application No. 14199182.8 dated Mar. 13, 2015.
Official Communication for European Patent Application No. 15155845.9 dated Oct. 6, 2015.
Official Communication for European Patent Application No. 15155846.7 dated Jul. 8, 2015.
Official Communication for European Patent Application No. 15165244.3 dated Aug. 27, 2015.
Official Communication for European Patent Application No. 15175106.2 dated Nov. 5, 2015.
Official Communication for European Patent Application No. 15175151.8 dated Nov. 25, 2015.
Official Communication for European Patent Application No. 15183721.8 dated Nov. 23, 2015.
Official Communication for Great Britain Patent Application No. 1404457.2 dated Aug. 14, 2014.
Official Communication for Great Britain Patent Application No. 1404574.4 dated Dec. 18, 2014.
Official Communication for Great Britain Patent Application No. 1408025.3 dated Nov. 6, 2014.
Official Communication for Great Britain Patent Application No. 1411984.6 dated Dec. 22, 2014.
Official Communication for Great Britain Patent Application No. 1413935.6 dated Jan. 27, 2015.
Official Communication for Netherlands Patent Application No. 2012437 dated Sep. 18, 2015.
Official Communication for Netherlands Patent Application No. 2013306 dated Apr. 24, 2015.
Official Communication for New Zealand Patent Application No. 622513 dated Apr. 3, 2014.
Official Communication for New Zealand Patent Application No. 622517 dated Apr. 3, 2014.
Official Communication for New Zealand Patent Application No. 624557 dated May 14, 2014.
Official Communication for New Zealand Patent Application No. 627962 dated Aug. 5, 2014.
Official Communication for New Zealand Patent Application No. 628161 dated Aug. 25, 2014.
Official Communication for New Zealand Patent Application No. 628263 dated Aug. 12, 2014.
Official Communication for New Zealand Patent Application No. 628495 dated Aug. 19, 2014.
Official Communication for New Zealand Patent Application No. 628585 dated Aug. 26, 2014.
Official Communication for New Zealand Patent Application No. 628840 dated Aug. 28, 2014.
Official Communication for U.S. Appl. No. 12/556,318 dated Jul. 2, 2015.
Official Communication for U.S. Appl. No. 13/247,987 dated Apr. 2, 2015.
Official Communication for U.S. Appl. No. 13/247,987 dated Sep. 22, 2015.
Official Communication for U.S. Appl. No. 13/831,791 dated Mar. 4, 2015.
Official Communication for U.S. Appl. No. 13/831,791 dated Aug. 6, 2015.
Official Communication for U.S. Appl. No. 13/835,688 dated Jun. 17, 2015.
Official Communication for U.S. Appl. No. 13/839,026 dated Aug. 4, 2015.
Official Communication for U.S. Appl. No. 14/134,558 dated Oct. 7, 2015.
Official Communication for U.S. Appl. No. 14/148,568 dated Oct. 22, 2014.
Official Communication for U.S. Appl. No. 14/148,568 dated Mar. 26, 2015.
Official Communication for U.S. Appl. No. 14/196,814 dated May 5, 2015.
Official Communication for U.S. Appl. No. 14/225,006 dated Sep. 10, 2014.
Official Communication for U.S. Appl. No. 14/225,006 dated Sep. 2, 2015.
Official Communication for U.S. Appl. No. 14/225,006 dated Feb. 27, 2015.
Official Communication for U.S. Appl. No. 14/225,084 dated Sep. 11, 2015.
Official Communication for U.S. Appl. No. 14/225,084 dated Sep. 2, 2014.
Official Communication for U.S. Appl. No. 14/225,084 dated Feb. 20, 2015.
Official Communication for U.S. Appl. No. 14/225,160 dated Feb. 11, 2015.
Official Communication for U.S. Appl. No. 14/225,160 dated Aug. 12, 2015.
Official Communication for U.S. Appl. No. 14/225,160 dated May 20, 2015.
Official Communication for U.S. Appl. No. 14/225,160 dated Oct. 22, 2014.
Official Communication for U.S. Appl. No. 14/225,160 dated Jul. 29, 2014.
Official Communication for U.S. Appl. No. 14/268,964 dated Sep. 3, 2014.
Official Communication for U.S. Appl. No. 14/289,596 dated Jul. 18, 2014.
Official Communication for U.S. Appl. No. 14/289,596 dated Jan. 26, 2015.
Official Communication for U.S. Appl. No. 14/289,596 dated Apr. 30, 2015.
Official Communication for U.S. Appl. No. 14/289,599 dated Jul. 22, 2014.
Official Communication for U.S. Appl. No. 14/289,599 dated May 29, 2015.
Official Communication for U.S. Appl. No. 14/289,599 dated Sep. 4, 2015.
Official Communication for U.S. Appl. No. 14/294,098 dated Aug. 15, 2014.
Official Communication for U.S. Appl. No. 14/294,098 dated Nov. 6, 2014.
Official Communication for U.S. Appl. No. 14/306,138 dated Sep. 14, 2015.
Official Communication for U.S. Appl. No. 14/306,138 dated Feb. 18, 2015.
Official Communication for U.S. Appl. No. 14/306,138 dated Sep. 23, 2014.
Official Communication for U.S. Appl. No. 14/306,138 dated Dec. 24, 2015.
Official Communication for U.S. Appl. No. 14/306,138 dated May 26, 2015.
Official Communication for U.S. Appl. No. 14/306,138 dated Dec. 3, 2015.
Official Communication for U.S. Appl. No. 14/306,147 dated Feb. 19, 2015.
Official Communication for U.S. Appl. No. 14/306,147 dated Aug. 7, 2015.
Official Communication for U.S. Appl. No. 14/306,147 dated Sep. 9, 2014.
Official Communication for U.S. Appl. No. 14/306,154 dated Mar. 11, 2015.
Official Communication for U.S. Appl. No. 14/306,154 dated May 15, 2015.
Official Communication for U.S. Appl. No. 14/306,154 dated Nov. 16, 2015.
Official Communication for U.S. Appl. No. 14/306,154 dated Jul. 6, 2015.
Official Communication for U.S. Appl. No. 14/306,154 dated Sep. 9, 2014.
Official Communication for U.S. Appl. No. 14/319,765 dated Sep. 10, 2015.
Official Communication for U.S. Appl. No. 14/319,765 dated Jun. 16, 2015.
Official Communication for U.S. Appl. No. 14/319,765 dated Nov. 25, 2014.
Official Communication for U.S. Appl. No. 14/319,765 dated Feb. 4, 2015.
Official Communication for U.S. Appl. No. 14/323,935 dated Jun. 22, 2015.
Official Communication for U.S. Appl. No. 14/323,935 dated Nov. 28, 2014.
Official Communication for U.S. Appl. No. 14/323,935 dated Mar. 31, 2015.
Official Communication for U.S. Appl. No. 14/326,738 dated Dec. 2, 2014.
Official Communication for U.S. Appl. No. 14/326,738 dated Jul. 31, 2015.
Official Communication for U.S. Appl. No. 14/326,738 dated Mar. 31, 2015.
Official Communication for U.S. Appl. No. 14/473,552 dated Feb. 24, 2015.
Official Communication for U.S. Appl. No. 14/486,991 dated Mar. 10, 2015.
Official Communication for U.S. Appl. No. 14/490,612 dated Aug. 18, 2015.
Official Communication for U.S. Appl. No. 14/504,103 dated Mar. 31, 2015.
Official Communication for U.S. Appl. No. 14/504,103 dated Feb. 5, 2015.
Official Communication for U.S. Appl. No. 14/579,752 dated Aug. 19, 2015.
Official Communication for U.S. Appl. No. 14/579,752 dated May 26, 2015.
Official Communication for U.S. Appl. No. 14/631,633 dated Sep. 10, 2015.
Official Communication for U.S. Appl. No. 14/639,606 dated Oct. 16, 2015.
Official Communication for U.S. Appl. No. 14/639,606 dated May 18, 2015.
Official Communication for U.S. Appl. No. 14/639,606 dated Jul. 24, 2015.
Official Communication for U.S. Appl. No. 14/726,353 dated Sep. 10, 2015.
Official Communication for U.S. Appl. No. 14/813,749 dated Sep. 28, 2015.
Restriction Requirement for U.S. Appl. No. 13/839,026 dated Apr. 2, 2015.
Appacts, “Smart Thinking for Super Apps,” http://www.appacts.com Printed Jul. 18, 2013 in 4 pages.
Apsalar, “Data Powered Mobile Advertising,” “Free Mobile App Analytics” and various analytics related screen shots http://apsalar.com Printed Jul. 18, 2013 in 8 pages.
Capptain—Pilot Your Apps, http://www.capptain.com Printed Jul. 18, 2013 in 6 pages.
Chaudhuri et al., “An Overview of Business Intelligence Technology,” Communications of the ACM, Aug. 2011, vol. 54, No. 8.
Cohn et al., “Semi-supervised Clustering with User Feedback,” Constrained Clustering: Advances in Algorithms, Theory, and Applications 4.1, 2003, pp. 17-32.
Countly Mobile Analytics, http://count.ly/ Printed Jul. 18, 2013 in 9 pages.
DISTIMO—App Analytics, http://www distimo.com/app-analytics Printed Jul. 18, 2013 in 5 pages.
Flurry Analytics, http://www.flurry.com/ Printed Jul. 18, 2013 in 14 pages.
Glaab et al., “EnrichNet: Network-Based Gene Set Enrichment Analysis,” Bioinformatics 28.18 (2012): pp. i451-i457.
Google Analytics Official Website—Web Analytics & Reporting, http://www.google.com/analytics.index.html Printed Jul. 18, 2013 in 22 pages.
Gorr et al., “Crime Hot Spot Forecasting: Modeling and Comparative Evaluation,” Grant 98-IJ-CX-K005, May 6, 2002, 37 pages.
Gu et al., “Record Linkage: Current Practice and Future Directions,” Jan. 15, 2004, pp. 32.
Hua et al., “A Multi-attribute Data Structure with Parallel Bloom Filters for Network Services” HiPC 2006, LNCS 4297, pp. 277-288, 2006.
“HunchLab: Heat Map and Kernel Density Calculation for Crime Analysis,” Azavea Journal, printed from www.azavea.com/blogs/newsletter/v4l4/kernel-density-capabilities-added-to-hunchlab/ on Sep. 9, 2014, 2 pages.
Hur et al., “SciMiner: web-based literature mining tool for target identification and functional enrichment analysis,” Bioinformatics 25.6 (2009): pp. 838-840.
IBM, Determining Business Object Structure, IBM, 2004, pp. 9.
Kontagent Mobile Analytics, http://www.kontagent.com/ Printed Jul. 18, 2013 in 9 pages.
Localytics—Mobile App Marketing & Analytics, http://www.localytics.com/ Printed Jul. 18, 2013 in 12 pages.
Mixpanel—Mobile Analytics, https://mixpanel.com/ Printed Jul. 18, 2013 in 13 pages.
Open Web Analytics (OWA), http://www.openwebanalytics.com/ Printed Jul. 19, 2013 in 5 pages.
Piwik—Free Web Analytics Software. http://piwik.org/ Printed Jul. 19, 2013 in18 pages.
“SAP Business Objects Explorer Online Help”, SAP Business Objects, Mar. 19, 2012, pp. 68.
StatCounter—Free Invisible Web Tracker, Hit Counter and Web Stats, http://statcounter.com/ Printed Jul. 19, 2013 in 17 pages.
TestFlight—Beta Testing on the Fly, http://testflightapp.com/ Printed Jul. 18, 2013 in 3 pages.
trak.io, http://trak.io/ printed Jul. 18, 2013 in 3 pages.
UserMetrix, http://usermetrix.com/android-analytics printed Jul. 18, 2013 in 3 pages.
Valentini et al., “Ensembles of Learning Machines,” M. Marinaro and R. Tagliaferri (Eds.): WIRN VIETRI 2002, LNCS 2486, pp. 3-20.
Vose et al., “Help File for ModelRisk Version 5,” 2007, Vose Software, pp. 349-353. [Uploaded in 2 Parts].
Wang et al., “Research on a Clustering Data De-Duplication Mechanism Based on Bloom Filter,” IEEE 2010, 5 pages.
Wikipedia, “Multimap,” Jan. 1, 2013, https://en.wikipedia.org/w/index.php?title=Multimap&oldid=530800748.
Zheng et al., “GOEAST: a web-based software toolkit for Gene Ontology enrichment analysis,” Nucleic acids research 36.suppl 2 (2008): pp. W385-W363.
Notice of Allowance for U.S. Appl. No. 13/247,987 dated Mar. 17, 2016.
Notice of Allowance for U.S. Appl. No. 14/192,767 dated Apr. 20, 2015.
Notice of Allowance for U.S. Appl. No. 14/319,161 dated May 4, 2015.
Notice of Allowance for U.S. Appl. No. 14/323,935 dated Oct. 1, 2015.
Notice of Allowance for U.S. Appl. No. 14/451,221 dated Aug. 4, 2015.
Notice of Allowance for U.S. Appl. No. 14/473,860 dated Feb. 27, 2015.
Notice of Allowance for U.S. Appl. No. 14/479,863 dated Mar. 31, 2015.
Notice of Allowance for U.S. Appl. No. 14/552,336 dated Nov. 3, 2015.
Notice of Allowance for U.S. Appl. No. 14/579,752 dated Apr. 4, 2016.
Notice of Allowance for U.S. Appl. No. 14/676,621 dated Feb. 10, 2016.
Notice of Allowance for U.S. Appl. No. 14/746,671 dated Jan. 21, 2016.
Notice of Allowance for U.S. Appl. No. 14/858,647 dated Mar. 4, 2016.
Official Communication for European Patent Application No. 14180321.3 dated May 9, 2016.
Official Communication for European Patent Application No. 14187996.5 dated Feb. 19, 2016.
Official Communication for European Patent Application No. 14189344.6 dated Feb. 29, 2016.
Official Communication for European Patent Application No. 14200246.8 dated May 29, 2015.
Official Communication for European Patent Application No. 15181419.1 dated Sep. 29, 2015.
Official Communication for European Patent Application No. 15184764.7 dated Dec. 14, 2015.
Official Communication for European Patent Application No. 15202919.5 dated May 9, 2016.
Official Communication for Great Britain Patent Application No. 1404486.1 dated May 21, 2015.
Official Communication for Great Britain Patent Application No. 1404486.1 dated Aug. 27, 2014.
Official Communication for Great Britain Patent Application No. 1404489.5 dated May 21, 2015.
Official Communication for Great Britain Patent Application No. 1404489.5 dated Aug. 27, 2014.
Official Communication for Great Britain Patent Application No. 1404499.4 dated Jun. 11, 2015.
Official Communication for Great Britain Patent Application No. 1404499.4 dated Aug. 20, 2014.
Official Communication for Great Britain Patent Application No. 1404499.4 dated Sep. 29, 2014.
Official Communication for Netherlands Patent Application 2012438 dated Sep. 21, 2015.
Official Communication for Netherlands Patents Application No. 2012417 dated Sep. 18, 2015.
Official Communication for Netherlands Patents Application No. 2012421 dated Sep. 18, 2015.
Official Communication for New Zealand Patent Application No. 622473 dated Jun. 19, 2014.
Official Communication for New Zealand Patent Application No. 622473 dated Mar. 27, 2014.
Official Communication for U.S. Appl. No. 13/827,491 dated Dec. 1, 2014.
Official Communication for U.S. Appl. No. 13/827,491 dated Jun. 22, 2015.
Official Communication for U.S. Appl. No. 13/827,491 dated Mar. 30, 2016.
Official Communication for U.S. Appl. No. 13/827,491 dated Oct. 9, 2015.
Official Communication for U.S. Appl. No. 13/831,791 dated Feb. 11, 2016.
Official Communication for U.S. Appl. No. 13/835,688 dated Sep. 30, 2015.
Official Communication for U.S. Appl. No. 14/102,394 dated Mar. 27, 2014.
Official Communication for U.S. Appl. No. 14/108,187 dated Apr. 17, 2014.
Official Communication for U.S. Appl. No. 14/108,187 dated Mar. 20, 2014.
Official Communication for U.S. Appl. No. 14/135,289 dated Apr. 16, 2014.
Official Communication for U.S. Appl. No. 14/135,289 dated Jul. 7, 2014.
Official Communication for U.S. Appl. No. 14/141,252 dated Oct. 8, 2015.
Official Communication for U.S. Appl. No. 14/148,568 dated Mar. 27, 2014.
Official Communication for U.S. Appl. No. 14/192,767 dated Sep. 24, 2014.
Official Communication for U.S. Appl. No. 14/192,767 dated May 6, 2014.
Official Communication for U.S. Appl. No. 14/196,814 dated Aug. 13, 2014.
Official Communication for U.S. Appl. No. 14/196,814 dated Oct. 7, 2015.
Official Communication for U.S. Appl. No. 14/225,006 dated Dec. 21, 2015.
Official Communication for U.S. Appl. No. 14/225,084 dated Feb. 26, 2016.
Official Communication for U.S. Appl. No. 14/225,084 dated Jan. 4, 2016.
Official Communication for U.S. Appl. No. 14/225,160 dated Jan. 25, 2016.
Official Communication for U.S. Appl. No. 14/268,964 dated Jul. 11, 2014.
Official Communication for U.S. Appl. No. 14/289,596 dated Aug. 5, 2015.
Official Communication for U.S. Appl. No. 14/306,138 dated Mar. 17, 2016.
Official Communication for U.S. Appl. No. 14/306,147 dated Dec. 24, 2015.
Official Communication for U.S. Appl. No. 14/306,154 dated Feb. 1, 2016.
Official Communication for U.S. Appl. No. 14/306,154 dated Mar. 17, 2016.
Official Communication for U.S. Appl. No. 14/319,161 dated Jan. 23, 2015.
Official Communication for U.S. Appl. No. 14/319,765 dated Feb. 1, 2016.
Official Communication for U.S. Appl. No. 14/451,221 dated Oct. 21, 2014.
Official Communication for U.S. Appl. No. 14/451,221 dated Apr. 6, 2015.
Official Communication for U.S. Appl. No. 14/463,615 dated Sep. 10, 2015.
Official Communication for U.S. Appl. No. 14/463,615 dated Nov. 13, 2014.
Official Communication for U.S. Appl. No. 14/463,615 dated May 21, 2015.
Official Communication for U.S. Appl. No. 14/463,615 dated Jan. 28, 2015.
Official Communication for U.S. Appl. No. 14/463,615 dated Dec. 9, 2015.
Official Communication for U.S. Appl. No. 14/473,860 dated Nov. 4, 2014.
Official Communication for U.S. Appl. No. 14/479,863 dated Dec. 26, 2014.
Official Communication for U.S. Appl. No. 14/483,527 dated Jun. 22, 2015.
Official Communication for U.S. Appl. No. 14/483,527 dated Jan. 28, 2015.
Official Communication for U.S. Appl. No. 14/483,527 dated Oct. 28, 2015.
Official Communication for U.S. Appl. No. 14/490,612 dated Jan. 27, 2015.
Official Communication for U.S. Appl. No. 14/490,612 dated Mar. 31, 2015.
Official Communication for U.S. Appl. No. 14/552,336 dated Jul. 20, 2015.
Official Communication for U.S. Appl. No. 14/562,524 dated Nov. 10, 2015.
Official Communication for U.S. Appl. No. 14/562,524 dated Sep. 14, 2015.
Official Communication for U.S. Appl. No. 14/562,524 dated Feb. 18, 2016.
Official Communication for U.S. Appl. No. 14/571,098 dated Nov. 10, 2015.
Official Communication for U.S. Appl. No. 14/571,098 dated Mar. 11, 2015.
Official Communication for U.S. Appl. No. 14/571,098 dated Feb. 23, 2016.
Official Communication for U.S. Appl. No. 14/571,098 dated Aug. 24, 2015.
Official Communication for U.S. Appl. No. 14/571,098 dated Aug. 5, 2015.
Official Communication for U.S. Appl. No. 14/579,752 dated Dec. 9, 2015.
Official Communication for U.S. Appl. No. 14/631,633 dated Feb. 3, 2016.
Official Communication for U.S. Appl. No. 14/639,606 dated Apr. 5, 2016.
Official Communication for U.S. Appl. No. 14/676,621 dated Oct. 29, 2015.
Official Communication for U.S. Appl. No. 14/676,621 dated Jul. 30, 2015.
Official Communication for U.S. Appl. No. 14/726,353 dated Mar. 1, 2016.
Official Communication for U.S. Appl. No. 14/746,671 dated Nov. 12, 2015.
Official Communication for U.S. Appl. No. 14/746,671 dated Sep. 28, 2015.
Official Communication for U.S. Appl. No. 14/800,447 dated Dec. 10, 2015.
Official Communication for U.S. Appl. No. 14/800,447 dated Mar. 3, 2016.
Official Communication for U.S. Appl. No. 14/813,749 dated Apr. 8, 2016.
Official Communication for U.S. Appl. No. 14/842,734 dated Nov. 19, 2015.
Official Communication for U.S. Appl. No. 14/929,584 dated Feb. 4, 2016.
Related Publications (1)
Number Date Country
20170102863 A1 Apr 2017 US
Provisional Applications (1)
Number Date Country
62097327 Dec 2014 US
Continuations (1)
Number Date Country
Parent 14858647 Sep 2015 US
Child 15092964 US