Some embodiments described herein relate to the generation and/or use of embedding of websites. Representation of websites in an embedding space can represent relationships between websites. Machine learning models can be trained to predict user actions based, at least in part, on the position of a network location in the embedding space.
Some embodiments described herein relate to unsupervised machine learning techniques that enable improvements in identifying target audiences and techniques for reducing the sparseness of data sets to enable otherwise unfeasible, unsupervised machine learning.
Typically, brands have employed market research firms to conduct surveys and/or focus groups to better understand their customers. Known forms of market research, however, can take months to complete and cost millions of dollars. Moreover, survey question selection can have a large impact on the results of a market research survey. A market research firm may be unable to formulate questions that would identify or characterize an audience the market research firm does not know the brand has. For example, if a brand is primarily focused on stay-at-home moms, a market research survey may be unable to identify that the brand also has a significant following among outdoorsmen and/or may be unable to develop insights into what outdoorsmen's interests in the brand might be. Similarly, focus group-based market research can also be biased (unintentionally or otherwise) because it may be difficult or impossible to identify a representative set of subjects that accurately portrays a company's overall and/or target customer set. Known forms of market research are also limited by relying on self-reported behavioral data, which relies on the subjects' honesty, memory, and introspective abilities.
New techniques for characterizing audiences and selecting targets for the delivery of targeted content have arisen in the internet age, and targeted content delivery has become a fundamental feature of the modern internet. Targeted content delivery can be roughly divided into two distinct modes, retargeting and prospecting. Retargeting involves providing targeted content to people who have previously taken a predefined action, while prospecting involves predicting which people are likely to be interested in targeted content. For example, during a retargeting campaign, individuals who have previously visited particular predefined webpages, purchased certain predefined items, and/or have social media connections with predefined profiles, may be selected to receive targeted content. Retargeting can include sending brand-related content to individuals who have previously interacted with the brand. Prospecting, by contrast, seeks to identify individuals who may be interested in the targeted content who have not been observed taking any particular predefined action. Prospecting generally involves the analysis of a relatively large amount of data associated with the user.
Modern prospecting is typically a “big data” operation, in which sophisticated algorithms process large amounts of information with the goal of quickly grouping or classifying individuals based on their predicted affinity to a content item. Known techniques, however, suffer from a number of drawbacks. For example, some known supervised learning techniques seek to predict how likely an individual is to perform a particular action (e.g., buy a product, click an advertisement, etc.). Before a supervised learning technique can be applied, a model must be trained using data that includes a measure of the action sought to be predicted. Selecting the action to be predicted, however, can be a significant challenge and/or data revealing the occurrence of the predicted action may be unavailable. For example, a brand selling sports equipment may be interested to know that it has a significant following among parents, and to identify those customers of its products that are parents to target them or to learn more about them. A supervised algorithm would not be able to identify this group of users from the full customer base unless (a) the brand already knew there was a group of parents in its customer base and (b) there were available examples of which users were parents. Without a very specific data source that labels this exact set of people, supervised learning techniques would be unable to identify that the brand has a significant following among parents, much less identify specific individuals as parents. Moreover, due to deficiencies of supervised learning techniques, the brand would generally be unable to identify suitable audiences if the suitable audience is not identified in the data revealing the occurrence of the predicted action. Similarly stated, even if the brand selling sports equipment were able to identify parents, many other subpopulations exist for which traditional market research data is not coded, particularly characteristics the brand has not previously identified as relevant.
Additionally, traditionally individual users have been classified using an identifier shared by the user's device, such as a cookie identifier, identifier for advertising, or other suitable indicator that can be received by websites and/or advertisers when that individual visits a particular website. Such identifiers have traditionally allowed content providers to track individuals across domains and characterize individuals based on a browsing history. Recently, however, there has been a renewed effort by browser developers to enable private browsing technologies that prevent content providers from identifying individuals. Instead, in some instances, browser developers may provide identifiers that identify a group of users and/or provide aggregated browsing information for the group of users. Accordingly, a need exists for systems and methods to select and deliver targeted content in an environment where some or all individuals are untrackable.
Some embodiments described herein relate to a computer-implemented method that includes accessing behavioral data, such as web visitation data, of multiple users. A sparse behavioral vector can be defined for each user based on the behavioral data. Each element of each sparse behavioral vector can represent a different potential detectable behavior such that each sparse behavioral vector encodes the behavioral data for that user. Multiple supervised learning models can be applied to each sparse behavioral vector to densify the vectors, defining multiple dense behavioral vectors. An unsupervised machine learning technique can be applied to the dense behavioral vectors to cluster, or define subpopulations, based on similarities between the dense behavioral vectors. Delivery of targeted content to a user can be facilitated based on a dense behavioral vector associated with that user being associated with one or more of the clusters or subpopulations.
Some embodiments described herein relate to a computer-implemented method that includes accessing sparse behavioral vectors. Each sparse behavioral vector can be associated with a user. Each element of each sparse behavioral vector represents a different detectable behavior. Multiple supervised machine learning models can be applied to each sparse behavioral vector. Each supervised learning model can be uniquely associated with a potential detectable behavior and configured to produce a score representing a probability that a user will perform that potential detectable behavior. The scores produced by the supervised machine learning can be used to define dense behavioral vectors; each element of each dense behavioral vector can correspond to a score produced by a different supervised machine learning model applied to the corresponding sparse behavioral vector. An unsupervised machine learning technique can be applied to the dense behavioral vectors to cluster, or define subpopulations, of dense behavioral vectors based on similarities between them. Delivery of targeted content to a user can be facilitated based on a dense behavioral vector associated with that user being associated with one or more of the clusters or subpopulations.
Some embodiments described herein relate to a computer-implemented method that includes receiving website visitation data. A machine learning technique can be applied to define associations between a plurality of websites represented in the website visitation data. An embedding of the plurality of websites in p-dimensional space can be defined based on the associations between the plurality of websites. A plurality of clusters of websites can be identified based on proximity of websites from the plurality of websites to each other in the p-dimensional space. A position of a user in the p-dimensional space can be identified based on website visitation data for the user. Delivery of targeted content to the user can be facilitated based on the user's position to relative to a cluster of websites. For example, targeted content can be selected based on the cluster nearest to the user in the p-dimensional space.
Some embodiments described herein relates to a computer-implemented method that includes accessing website visitation records for a first group of user devices. A p-dimensional embedding of websites can be generated based on the website visitation records for the first group of user devices. Conversion event data associated with website visitations records for a second group of user devices can be accessed. A position of each user device from the second group of user devices in the p-dimensional embedding can be determined based on the website visitation data for the second group user devices. Using the conversion event data and the website visitation records for the second group of user devices, a machine learning model can be trained to predict whether a user device is likely to take a conversion action, such as purchasing a good or service based on the position of that user device in the p-dimensional embedding. An indication that a user device is accessing a website can be received (the user device may not be from the first group of user devices or the second group of user devices). A position of that user device in the p-dimensional embedding can be determined based on, for example, that user device's full website visitation history (e.g., cookie data associated with that user device), a portion of that user device's visitation data, or based solely on the indication that that user device is accessing a particular website. Delivery of targeted content to that user device can be facilitated based on predicting whether that user device is likely to take a conversion action based on the position of that user device in the p-dimensional embedding.
In some embodiments, a method includes receiving multiple website traffic data records, the multiple website traffic data records is associated with multiple user devices. The method further includes generating a website traffic embedding based on the multiple website traffic data records. The method further includes defining training data including the website traffic embedding and website traffic data records for at least one of the multiple user devices and multiple conversion event data associated with at least one of the multiple user devices. The training data can be used to train a machine learning model. An indication of advertisement display opportunity can be provided to the machine learning model based on a user device that is not from the multiple user devices accessing a webpage. The machine learning model can predict whether that user device is likely to undertake a conversion action.
Some embodiments described herein relate to a computer-implemented method suitable for facilitating delivery of targeted content to user devices in situations in which historic tracking data (e.g., cookie data) is generally unavailable and/or unreliable. A p-dimensional embedding of websites can be generated based on a group of user devices for whom tracking data is available. The group of user devices can opt-in and/or be compensated to be tracked and, in some instances can be a relatively small group of user devices. Conversion event data can be received. Conversion event data may be data contains historical website visitation records and conversion records for user devices. In other instances, conversion event data may be data relating to targeted content delivery and associated conversion events. For example, targeted content can be provided to websites and the conversion rates on that targeted content can be monitored. In some instances a variety of targeted content can be provided to websites (e.g., each website can receive multiple items of differing targeted content and/or different websites can receive different items of targeted content). In this way, the effectiveness of different types of targeted content on each website and/or on different websites can be evaluated. The conversion event data can indicate that a group of users visited at least one website, where at least a subset of the group of users were exposed to an item of targeted content, and at least a sub-subset of the subset of the group of users performed a conversion action after being exposed to the item of targeted content. The conversion event data can provide conversion information on a per-user and/or an aggregated basis. Similarly stated, in some instances, the conversion event data can indicate that individual user(s) (1) visited a website, (2) were exposed to an item of targeted content, and (3) performed a conversion action. In other instances, the conversion event data can be aggregated across users and indicate, for example, that a set of X devices visited website Y, were exposed to targeted content, and Z % performed a conversion action without including individual visitation, exposures and/or conversion information. In yet other instances, conversion event data can be aggregated across websites indicating, for example, that a set of X devices visited one of a set of websites Y1, Y2, Y3, etc., where they were exposed to the item of targeted content, and that Z % of those X devices performed a conversion action. In yet other instances, conversion event data can be aggregated by other attributes, such as time of day or device location. A machine learning model can be trained using the conversion event data and the positions of websites appearing in the conversion event data within the p-dimensional embedding to predict a likelihood of conversion and/or a type of content to provide given a position in the p-dimensional embedding. When an indication that a user device (e.g., an untrackable user device) is accessing a website is received, a position of that website in the p-dimensional embedding can be determined and targeted content can be delivered to the user device based on predicting, using the machine learning model, a likelihood that the user device will perform a conversion action based on the position of the website in the p-dimensional embedding.
Some embodiments described herein relate to unsupervised learning techniques, and in some more specific embodiments, clustering, and/or agglomerative hierarchical clustering. Unlike supervised learning, such techniques do not require training data that includes a measure of a desired outcome. Some embodiments described herein apply unsupervised learning techniques to user web visitation data. Web visitation data is a sparse, high-dimensional data set. In this sparse, high-dimensional space, no natural way exists to define a meaningful distance between any two users. For example, two users with no website history in common will have a similarity of zero. Because the space is so sparse, many pairwise similarities are zero, which means clustering in this space is impractical or gives results with limited usefulness. Some embodiments described herein relate to specific novel computational techniques for reducing the dimensionality and sparseness of sparse data sets, such as web visitation data, which can allow computers to apply unsupervised modeling techniques to large, sparse data sets that have been densified.
Raeder, T. et al., Scalable Supervised Dimensionality Reduction Using Clustering, Proceedings of the 19th ACM SIGKDD International Conference on Knowledge Discovery and Data Mining (2013) (“Raeder”), the disclosure of which is hereby incorporated by reference in its entirety, describes a technique related to those described in the present application. Techniques described in Raeder involve reducing dimensionality by performing clustering on websites (or representations of websites) themselves, so that fewer dimensions can be used to represent the space of all websites. The technique described in Raeder, however, does not address the sparseness problem or reduce the dimensionality of users (or representations of users). Rather, Raeder collapses the existing non-zero dimensions that represent attributes of websites into fewer non-zero dimensions, but does not introduce new non-zero dimensions to describe each website. The resulting space generated by applying techniques described in Reader may have lower-dimensionality, but still very sparse, so that pairwise similarities between users, described by their history of website visitations, are zero for many users. Second, because Raeder's solution reduces dimensionality by representing many different websites with the same feature, information about the differences between those websites is lost, so that two users who have different histories among those websites have the same representation in the low-dimensionality space and thus have a pairwise distance of zero. To meaningfully group together users with different characteristics with useful options for the number and size of clusters, a need remains for a technique that captures a range of meaningful pairwise distances between users.
The user devices 160 are computing entities, such as personal computers, laptops, tablets, smartphones, or the like, each having a processor 162 and a memory 164. The processor 162 can be, for example, a general purpose processor, a Field Programmable Gate Array (FPGA), an Application Specific Integrated Circuit (ASIC), a Digital Signal Processor (DSP), and/or the like. The processor 162 can be configured to retrieve data from and/or write data to memory, e.g., the memory 164, which can be, for example, random access memory (RAM), memory buffers, hard drives, databases, erasable programmable read only memory (EPROMs), electrically erasable programmable read only memory (EEPROMs), read only memory (ROM), flash memory, hard disks, floppy disks, cloud storage, and/or so forth. Each user device 160 can be operable to access one or more of the webservers 130. For example, a user operating a user device 160 to browse the internet (e.g., the network 190) can access webpages stored on one or more of the webservers 130. The webservers 130 can be computing entities each having a processor 132 and a memory 134, which can be structurally and/or functionally similar to the processors 162 and/or 164, respectively, discussed above.
The targeted content provider 120 can be a computing entity operable to select, deliver, and/or facilitate the delivery of one or more items of targeted content. For example, the targeted content provider 120 can be associated with an advertiser or advertising network that provides targeted content that is displayed by a user device 160 when that user device 160 accesses a particular webserver 130. Similarly stated, targeted content selected, delivered, or facilitated by the targeted content provider 120 can include advertisements embedded within, displayed with, or otherwise associated with webpages displayed by a user device 160. The targeted content provider 120 includes a processor 122 and a memory 124, which can be structurally and/or functionally similar to the processor 162 and/or memory 164, respectively, discussed above.
The audience identification device 110 can be a computing entity configured to receive signals indicative of actions or behaviors of users associated with some or all of user devices 160. For example, the audience identification device 110 can receive web visitation data for user devices 160 and/or webservers 130 using cookie-based or any other suitable technique for network traffic attribution (e.g., any suitable technique for identifying that a user device was used to access a webserver including, for example monitoring Internet Protocol (IP) addresses of user devices 160, user agents of user devices 160 and/or browser fingerprints, time of day, location, etc.).
In some instances, some or all user devices 160, may be configured not to send signals indicative of behaviors of users associated with such user devices 160, and/or may be configured not to send identifiers of any kind (e.g., cookie identifier, IP address, etc.). Similarly stated, browsers or other hardware and/or software associated with some or all user device 160 may prevent data associated with cookies or other unique identifying information from being send to the audience identification device 110. In some such instances, a non-unique identifier—an identifier shared by a sufficiently large number of users (hundreds, thousands, tens of thousands, etc.)—can be sent to the audience identification device 110. The non-unique identifier can be associated with aggregate, summarized, and/or otherwise anonymized behavioral data for the group of users associated with that non-unique identifier. Additionally, in some instances, information indicative of user behavior (e.g. website visitation records) can be received directly from a subset of the user devices 160 and/or a separate group of users (e.g., a group of users who have opted in to having their activity tracked) or indirectly (e.g., from a privacy sensitive aggregator and/or anonymizing service).
In addition or alternatively, any other suitable signal, such as a signal representing behavioral data can be received by the audience identification device 110 and associated with a user of one or more of the user devices 160. For example, the audience identification device 110 can receive conversion event data. Conversion event data can include, for example, purchase information from purchase confirmation websites, purchase history associated with a user account, a credit reporting bureau, customer loyalty program, survey information, or any other suitable source. Conversion event data can also include information regarding whether a user took any suitable brand action, such as clicking on a predefined advertisement or like, visiting a predefined website, physically visiting a retail location, or any other suitable action. Conversion event data can include information not relating to any particular brand, such as visiting one of a set of predefined websites indicating interest in a product category, activity, or other interest. Conversion event data can identify users who undertook conversion actions or can be anonymized and/or aggregated. For example, targeted content can be served to a group of user devices, for example without knowing or receiving any information about the user devices other than that they visited a website hosting the targeted content, and conversion information for that group of users (e.g., an aggregate click-through rate) can be determined and/or received. The audience identification device 110 includes a processor 112 and a memory 114, which can be structurally and/or functionally similar to the processor 162 and/or the memory 164, respectively, discussed above.
As discussed in further detail herein, the audience identification device 110 can be operable to apply machine learning techniques to identify subsets of the user devices 160 or users associated with one or more user devices 160 (also referred to herein as subpopulations) based on the web visitation or other behavioral data. In some embodiments, subpopulations are identified based on a predicted affinity towards the targeted content, and not based on users within the subpopulation having taken one or more predefined actions. Similarly stated, the audience identification device 110 can be suitable to perform prospecting.
Machine learning techniques performed by the audience identification device 110 can be used to identify one or more subpopulations. The audience identification device 110 can be operable to send a signal to the targeted content provider 120 and/or other suitable party or device that includes a representation of the one or more subpopulations. The subpopulations can be studied to identify particular subpopulations that the targeted content provider 120 desires to reach or study. Unless specified otherwise, references to unsupervised machine learning and/or clustering refer specifically to hierarchical clustering. It should be understood, however, that techniques described in the context of clustering may be applicable to other suitable machine learning techniques, such as k-means clustering, and/or unsupervised co-clustering. Similarly stated, the audience identification device 110 can be operable to break an audience into subpopulations. In some instances, the audience identification device 110 can further be operable to predict which subpopulations are receptive to and/or likely to convert an item of targeted content via any suitable unsupervised machine learning technique. In addition or alternatively, the audience identification device 110 can be operable to prepare and/or transmit analytics and/or other suitable reports that can aid a marketer or other suitable entity to understand a brand's audience, including identifying and reporting on the one or more subpopulations.
In some embodiments, the memory 114 can store a vector for each user device 160 and/or for each user associated with one or more user devices 160. Such a vector can represent that user device's/user's behavior in a format discussed in further detail below. Using techniques described in further detail below, the processor 112 can be operable to perform machine learning techniques on a matrix comprising vectors of an audience (set of users) to identify subpopulations. Subpopulations can further be clustered to identify sub-subpopulations. In some embodiments the number subpopulations within each taxonomic rank and/or the number of taxonomic ranks can be user-selectable.
A vector for a user/user device 160 can include a large number of elements. Each element can represent a different webserver 130, a different uniform resource locator (URL), or any other suitable indicator of a potentially detectable behavior. If a user/user device 160 has visited a URL/webserver 130 or otherwise engaged in a behavior associated with a particular vector element, the element for that behavior and/or URL/webserver 130 in that user's vector can be set to 1. Conversely, if a user/user device 160 has not visited a URL/webserver 130 or otherwise engaged in a behavior associated with a particular element, the element for that behavior and/or URL/webserver 130 in that user's vector can be a 0. Alternatively, non-binary schemes are also possible. For example, each element can be a representation of that user's engagement with a URL/webserver 130 (e.g., representing number of times visited, time spent, links clicked, etc.). Similarly stated, each vector can be a representation of a user's/user device's 160 web browsing history. Given the size of the internet (e.g., the network 190) and/or universe of possible tracked behaviors, such a vector would be large and sparse, with, on average, less than 0.1%, less than 0.01%, or less than 0.001% of entries having a non-zero value. The processor 112 can be operable to identify subpopulations, sub-subpopulations and so forth by performing clustering on a set of vectors (a matrix) representing an audience (e.g., the set of users/user devices 160).
At 220, a sparse behavior vector for each member of the population can be defined based on the behavioral data received at 210. The sparse behavior vector can include an element for each potential detectable behavior. For example, each element of the sparse behavior vector can represent a different website/URL, product available for purchase, and/or the like. Given the number of websites/URLS, products available for purchase, and other identifiable behaviors, the sparse behavioral vector can be tens of thousands, hundreds of thousands, millions, tens of millions, hundreds of millions, billions, or tens of billions of elements long. The vast majority (99.9%, 99.99%, 99.999% or more) of the sparse behavioral vector for each audience member can be zeros or otherwise indicate that the member of the audience (e.g., a user device and/or user associated with a user device) represented by that sparse behavioral vector has not been observed performing a behavior associated with that element. A small number of elements (e.g., 0.1%, 0.01%, 0.001% or fewer) for each audience member can be ones or otherwise indicate that the member of the audience represented by that sparse behavioral vector performed a behavior associated with that element. Many unsupervised learning techniques require a measure of similarity or distance between pairwise combinations of records. When the behavioral vectors are extremely sparse, most pairs of users have no overlapping dimensions with non-zero values. This leads to a situation where, depending on the choice of distance metric, many pairwise distances are either not meaningful, or take the maximum distance value (e.g., a similarity of zero), so this sparse representation does not contain enough information to achieve meaningful results using these unsupervised learning techniques.
At 230, m supervised learning models can be applied to each sparse behavioral vector defined at 220. Five hundred is an example of a suitable m, and, for case of description, references herein to five hundred should be understood as referring to m. It should be understood, however, that m can be any other suitable integer greater than 1, such as 50, 100, 1000, or 5000. For example, a model for each of 500 websites or URLs represented by an element in the sparse behavioral vectors can be defined. Supervised models are used here because each of the 500 models can produce an output or score for each sparse behavioral vector. The score can represent, for example, a prediction of the likelihood of a user performing a potential detectable behavior (e.g., visiting a webpage, purchasing a good/service, etc.), an affinity of a user/user device associated with that sparse behavioral with the selected website or URL, a prediction or probability that a user/user device will make a purchase, and/or a prediction or probability that a user/user device will perform a conversion action. For example, the score can be an integer or floating point value in which higher values represent strong associations with the selected URL and/or products/services associated with the URL. For example, one of the 500 models can predict a likelihood that a user represented by a sparse behavioral vector will visit espn.com, while another of the 500 models predicts a likelihood of a user visiting bbc.co.uk, while another of the 500 models will predict the likelihood of a user visiting etsy.com. The 500 websites or URLs can be selected randomly or manually as representatives of categories of websites. Notably, the 500 websites or URLs may be selected independently of, be unrelated to, and/or be entirely different from the audience identified at 200. Similarly stated, the supervised learning models applied at 230 do not seek to identify, characterize, or segment the audience. For example, the audience identified at 200 might be users who have been observed visiting budwiser.com, while the 500 models may not include budwiser.com and/or may be selected independently of identifying the audience as visitors of budwiser.com, at 200. In this way, the 500 supervised learning models applied at 230 produce 500 partially, substantially, or completely independent measures of the sparse vector. Thus, in some instances, one or more of the 500 models may seek to predict an affinity of the audience for a website or other potential behavior that no audience members have been detected visiting/performing.
In some embodiments, the 500 models can be trained using a data set that is distinct from data representing the audience. In other embodiments at least portion of the data representing the audience can be used to train the 500 models, while another at least a portion of the data representing the audience can be used to validate the 500 models.
At 240, a dense behavioral vector can be defined based on the outputs of the 500 models. For example, a dense behavioral vector having a length of 500 can be defined for each sparse behavioral vector where each element of the dense behavioral vector is a score produced by one of the 500 models, placing each dense behavioral vector in an m-dimensional space. Optionally, at 245, a distance from each dense behavioral vector can be measured from each other dense behavioral vector using a suitable distance metric like cosine distance, correlation distance, or Euclidean distance, placing each dense behavioral vector in n-dimensional space, where n is the size of the audience (e.g., the number of dense behavioral vectors and users/user devices).
At 250, unsupervised machine learning techniques can be applied to the dense behavioral vectors, in m-dimensional space or optionally as they exist in the n-dimensional space, to define a number of subpopulations. As discussed above, the densification of sparse behavioral vectors into m-dimensional (or n-dimensional) space can facilitate unsupervised learning techniques that could not otherwise be applied to the sparse behavioral vectors. Such unsupervised learning techniques can provide insights not previously available via supervised techniques, such as the identification of unexpected subpopulations. Similarly stated, applying the techniques described herein allow a compute device to perform analyses that would previously been impossible.
In some embodiments, the number of subpopulations, k, the audience is clustered into can be a user-definable parameter. Similarly stated, an analyst associated with an audience identification device can specify the number of clusters (subpopulations) to be produced. Optionally, at 255, each subpopulation can be further clustered into lower ranked taxonomic orders using a similar unsupervised machine learning technique or any other suitable clustering technique. If the original unsupervised machine learning technique was a hierarchical method, a further clustering can be performed based on the original hierarchical results. The clustering process can be repeated any number of times to produce finer and finer-grained subpopulations. Each subpopulation and/or lower taxonomical ranks can be characterized by any suitable technique, including, for example, by characteristics based on web history, media usage, or other indications of subpopulation interests. Characterizing subpopulations can include, for example, the top website visited by that subpopulation, optionally normalized against generic internet traffic. Subpopulations and/or sub-subpopulations can be used to identify users for the delivery of targeted content.
At 280, a mapping between the subpopulations identified at 260 to the subpopulations defined at 270 can be defined. Because the clustering is unsupervised, there is no expectation that any particular subpopulation (e.g., subpopulation 1) identified at 260 is the same as a similar subpopulation identified at 270. Similarly, there is no pre-defined identification of which subpopulations are new or which subpopulations have disappeared. At 280, therefore, a mapping between subpopulations can be defined in one of several ways. For ease of description, the subpopulations identified at 260 will be referred to collectively as taxonomy A, and a subpopulations identified at 270 will be referred to collectively as taxonomy B.
According to one embodiment, a supervised multi-class classification (or model) can be trained on taxonomy A. This model predicts to which of the subpopulations in taxonomy A a user belongs. The model trained on taxonomy A can be applied to taxonomy B, such that each user in each subpopulation in taxonomy B has a label corresponding to a subpopulation in taxonomy A or a label that indicating no corresponding subpopulation in taxonomy A was identified. In this way, at 280, each subpopulation in taxonomy B can be mapped to a similar subpopulation in taxonomy A (or vice versa), or to introduce a new subpopulation(s) if there is no clear mapping to a subpopulation in taxonomy A. In some instances, a reverse mapping can identify users as belonging to corresponding subpopulations in taxonomy A and taxonomy B if a pre-defined level of agreement between a forward mapping and a reverse mapping is exceeded. Similarly stated, first taxonomy A can be mapped to taxonomy B, followed by reverse mapping taxonomy B to taxonomy A; a user can be identified as belonging to associated subpopulations in taxonomies A and B if the two mappings agree. This process can be extended for each user in taxonomy A and taxonomy B.
According to another embodiment, at 280, a sample of users from taxonomy A can be added to taxonomy B before performing the unsupervised learning on taxonomy B. In this way, each subpopulation in taxonomy B has a sample of users from taxonomy A that can be used to establish a mapping between taxonomies. If there are no members of a particular subpopulation in taxonomy A in a subpopulation in taxonomy B, or there is not sufficient agreement between subpopulations of users in taxonomy A and taxonomy B, then a new subpopulation can be defined in taxonomy B.
Meaningful distances between websites can be established by defining an embedding. An embedding is a relatively low-dimensional, learned continuous vector representation of a group of relatively high-dimensional vectors. Generating an embedding allows for the reduction of dimensionality while meaningfully representing the high-dimensional vectors in the embedding space.
A website embedding is a mapping from a website to a point in a p-dimensional vector space, where websites containing similar content are mapped to nearby points. At 410, website visitation data can be received from a number of users whose internet activity has been monitored (e.g., by cookie-based tracking or any other suitable technique). In some instances, website visitation from over 1,000,000, over 100,000,000, over 200,000,000 or over 500,000,000 users would be received. As discussed above, however, in other instances, cookie-based tracking may be unavailable for significant portions of users due to recent increases in private-browsing initiatives. Accordingly, in some instances the website visitation data received at 410 can be from a relatively small (hundreds to tens of thousands) number of users who have agreed to be tracked. Preferably the users whose internet activity has been monitored is a representative subset of the general internet browsing public. Weights and other suitable data processing techniques can be applied to behavioral data to compensate for demographic and/or behavioral deviations between the monitored users and the general internet browsing public. In some instances, the website visitation data for each user may include a list of all websites visited by that user and the order in which the websites were visited. In other instances, pairs of sequential website visitation events for a user can be stored for limited periods of time, optionally without any user identifiers, which can avoid the need to store full histories associated with specific users. At 420, a machine learning technique and/or neural network can be applied to the visitation data received at 410 and define associations between websites based on which sites are frequently viewed in sequence.
At 430, an embedding of the websites in p-dimensional space can be defined based on the associations between the websites, creating a p-dimensional map of the internet. 128 is an example of a suitable p, and, for ease of description, references herein to 128 should be understood as referring to p. It should be understood, however, that p can be any suitable integer greater than 1, such as 3, 4, 10, 50, 100, 200, or 500.
For example if multiple users are observed visiting www.netflix.com and www.hbo.com within a predetermined period of time and/or within a predetermined sequence (e.g., within 20 minutes, within an hour, without visiting any intervening websites, with fewer than five intervening websites, etc.), and similarly, multiple users (not necessarily the same users) are observed visiting www.tvtropes.com and www.hbo.com, then www.tvtropes.com and www.netflix.com can be mapped closer to each other in the 128-dimensional embedding. Moreover, two websites (target websites) viewed in the same context (where context is the sequence of websites visited before or after the target website) can be moved closer to each other based on the frequency of websites viewed in the same context as observed over the set of all users.
At 440, groups or clusters of websites can be identified. For example, websites located near each other in the 128-dimensional space (according to any suitable distance metric) can be identified as belonging to a cluster, using k-means or another suitable clustering technique. A cluster of websites may define an audience (users who have visited a minimum number of websites within the cluster). This audience may contain users that would be receptive to certain targeted content who would not otherwise have been identified, for it may not otherwise have been known that users who visit www.tvtropes.com are good candidates for advertisements about Netflix. Content and/or targeted advertising can be delivered to that audience.
Clusters of websites can be characterized and/or users can be associated with one or more clusters of websites, at 450. For example, a cluster of websites can be characterized by analyzing the website visitation data of users who visit websites within that cluster (e.g., users whose website visitation data indicates a minimum number of visits to websites in that cluster). Features of users who visit a particular cluster can be used to describe or classify that cluster. For example, if website visitation data of visitors to websites within a cluster characteristically overindexes a particular website (a particular website appears more frequently than it does in website visitation data of a random sample of users), that overindexing website can be used to characterize the cluster. Typically, the overindexing website will be within the cluster, but in some instances, a cluster can be characterized by an overindexing website that is not within the cluster or an overindexing cluster other than that cluster.
The website clusters may also be used to describe users or groups of users. For example, if one user has visited only www.tvtropes.com and another has visited only www.netflix.com, without clustering such websites together, it would not be obvious that those users share an actionable similar website visitation history. Grouping the websites into clusters provides a way to capture multiple actions under the same label and provides more descriptive power for understanding audiences and/or selecting audiences to receive targeted content.
In some embodiments, a position of users in the 128-dimensional space can be determined. For example, each website visited by a user can be (e.g., as ascertained by website visitation data associated by that user) can have a position in the 128-dimensional space. Each user's position can be an average, mean, median, max, or other suitable representative metric or summary of that user's web visitation history. In some instances, a user's positions in the 128-dimensional space (e.g., a vector having a length of 128) can be used as dense behavioral vectors and used to select and/or facilitate the delivery of suitable targeted content, cluster users, as described above at 245, 250, and/or 255, or otherwise analyze user behavior and/or make predictions about users' affinities. Similarly stated, determining a position of a user in the 128-dimensional space can be an alternative densification technique to the application of supervised models, as described above at 230 and/or 240. In other instances, a sparse behavioral vector can be densified based on the position of websites visited by an associated user in 128-dimensional without directly determining a position of that user in the 128-dimensional embedding. For example, a dense behavioral vector having a length of 256 can be defined by concatenating a mean position of websites visited by that user (a vector having a length of 128) and a max position of websites visited by that user (a vector having a length of 128).
The user's website visitation history within the 128-dimensional space can provide insights into the user's affinity for particular websites/website clusters even if that user has not been observed visiting those particular websites. For example, a user who has visited a website within a predetermined distance of a target website within the 128-dimensional map of the internet can be identified as an audience member or likely audience member of that target website, even if the user has not been observed visiting that target website. Content and/or advertisements for the user can be selected based on identifying the user as an audience member or likely audience member of a website.
The method described with reference to
This mapping of websites can be used to inform the unsupervised clustering described in
In addition or alternatively, the 128-dimensional space mapping websites can be used as a dense, lower dimensional space to describe users, in order to define a distance metric between users that can be used to perform the unsupervised user clustering described above (e.g., at 250 as discussed with reference to
At 920, the website visitation data for the first group of user devices can be used to generate a 128-dimensional embedding of websites in a manner similar to that described above with reference to
At 930, data, including website visitation data and/or conversion event data can be accessed and/or received. In some embodiments targeted content such as advertisements can be displayed on selected websites. Click-through or other measurements of conversion from targeted content on those websites can be used to indicate a conversion likelihood for that website and/or websites nearby in the 128-dimensional embedding (e.g., within a predetermined distance). For example, a variety of targeted content can be displayed on select websites, such that a measure of effectiveness of different types of targeted content can be made for each selected website and/or regions of the 128-dimensional embedding. Such a technique can allow for the effectiveness of multiple types of targeted content as a function of position in the 128-dimensional embedding to be measured. Such embodiments are particularly well suited to instances in which the conversion event data received at 930 includes little or no data tied to user identifiers, such as environments in which cookie data is unavailable and/or unreliable for a significant portion users represented in the conversion event data. The conversion event data receive at 930 can include information about the device, information identifying when a website (e.g., containing an item of targeted content) was accessed/displayed and/or historical website visitation events. The conversion event information can also include device location, time of day, operating system, device type, etc.
In other embodiments, conversion data event data may not be directly associated with targeted content. For example, accessing a website associated with a brand can constitute a conversion event. Referral or other analytic data can reveal how a user reached the website associated with the brand and/or what other websites have been accessed by that user. Websites that refer traffic to the website associated with the brand or otherwise appear in browsing history of users that access the website associated with the brand can have high conversion rates. Conversely websites that under index (e.g., relative to random internet traffic) in referral or browsing history data of users that access the website associated with the brand can have low conversion rates.
In addition or alternatively, historical website visitation data and/or conversion data (e.g., cookie or other user-tracking data) associated with a second group of user devices can be accessed and/or received at 930. The second group of user devices can be the same as, partially overlap with, or be mutually exclusive from the first group of user devices. The conversion event data can indicate that a subset of the second group of user devices engaged in a conversion action such as, for example, purchasing a good or service, clicking an advertisement, visiting a particular website (e.g., associated with a brand or topic) or other target outcome, visiting a physical retail location, etc.
Using the conversion event data and/or the website visitation records retrieved at 930, a machine learning model can be trained to select appropriate content and/or predict the likelihood of a conversion event for a particular item of targeted content, given coordinates in the 128-dimensional embedding, at 950. In embodiments in which targeted content is displayed on selected websites, the reaction to such targeted content (e.g., click-through rate). and the location of the selected websites in the 128-dimensional embedding can be used to train a machine learning model to identify websites likely to produce high conversion rates for a particular item of targeted content, predict a likelihood of a conversion event for an item of targeted content displayed on a particular website, and/or to optimize the website selected to display content and/or type of content served. (“Optimize” as used herein does not necessarily refer to identifying an objective optimal solution, but instead to the minimization of a loss function or other suitable technique to arrive at at least a local maximum or minimum representing, for example, conversion likelihood.) In instances in which website visitation data for a second group of user devices is available, the position in the 128-dimensional space of user devices in the second group of user devices and/or websites indicated in the user device's website visitation records can be used train the machine learning model to predict likelihood of a conversion event. Similarly stated, the coordinates in the 128-dimensional space of websites visited and/or user devices associated with conversion actions can tend to indicate that that portion of the embedding is associated with conversions, while the coordinates in the 128-dimensional space of websites visited and/or user devices that are not associated with conversion actions to particular types of targeted content can be negatively correlated with conversions. Thus, the trained model can be operable to identify suitable content and/or return a likelihood of a conversion event occurring, given a set of coordinates in the 128-dimensional space. In instances in which additional conversion event data, such as information identifying when a website (e.g., containing an item of targeted content) was accessed/displayed, historical website visitation events, device location, time of day, operating system, device type, etc., such information can also be used to train the machine learning model and such factors can be used by the machine learning model to predict conversion likelihood.
In some embodiments, the machine learning model can incorporate cost information and be trained, for example, to estimate an expected price per conversion event, given a set of coordinates in 128-dimensional space, and/or the selection of suitable content cost of delivering targeted content to a website. For example, the machine learning model can be trained using a dataset (that may not be associated with any specific users or user identifiers) that can be the output of a model that returns auction win rate as a function of bid price for each website, the data set can include direct historical data on the cost of delivering targeted content to each website, and/or the dataset can be of any other suitable form.
At 960, an indication that a user device is accessing a website is received. The user device may not be from the first group of user devices, the second group of user devices, and/or be a device for which historic website visitation is available. In some instances the user device can be “untrackable.” For example, the device may have deleted or disabled cookies, may present a generic or spoofed user agent, may access the website via a virtual private network, and/or otherwise have taken steps to obfuscate its web browsing history. Using known methods, significant challenges exist selecting targeted content for untrackable devices. Additionally, the website may not have appeared in the conversion event data. Thus, there may not be any direct data linking conversion event data to the website.
At 970, a position of the website accessed by the user device in the 128-dimensional space can be identified. The position of the website in the 128-dimensional space can be identified based on a small subset of the first group of user devices that was observed visiting the website and/or a relatively small amount of data, which may not include brand or purchase-related data.) This position can in turn be used as a privacy-sensitive proxy to select appropriate targeted content to be served with the website. Similarly stated, the position of the website can be provided to the trained model, which can identify appropriate targeted content to serve with the website and/or produce a value indicative of a likelihood of a conversion event occurring (e.g., the likelihood of a purchase of a good and/or service), at 980. Targeted content can be delivered to the user device based on the output of the trained model, for example, embedded in the webpage accessed by the user device.
The machine learning model trained at 950 can be privacy-sensitive, such that an advertisement display opportunity is not required to include privacy-sensitive contents as input to the machine learning model. For example, the advertisement display opportunity triggered by the user device's access to the webpage at 960 may not include or be associable with website traffic data records of the user devices. Additionally, the machine learning model trained at 950 may not require, as an input, any information associated with the textual or non-textual contents of the webpage.
While various embodiments have been described above, it should be understood that they have been presented by way of example only, and not limitation. Furthermore, although various embodiments have been described as having particular features and/or combinations of components, other embodiments are possible having a combination of any features and/or components from any of embodiments where appropriate as well as additional features and/or components.
For example, although
As another example, although
As yet another example, although some embodiments described generating a 128-dimensional embedding based on patterns of user interaction with websites, it should be understood that in other embodiments, a dataset of website keywords and topics may be available that may not be associated with any specific users or user devices. Such a database can include keywords, topics, or other numerical vector representations of keywords or topics, derived from the textual and/or graphical content of the webpage. A machine learning technique and/or neural network such as an autoencoder may be used to define an encoding layer, using data from the position of websites in the 128-dimensional embedding space and the keyword and/or topic data. The encoding layer is a reduced dimensional space capturing similarities between websites, similar to the 128-dimensional embedding space. Unlike the 128-dimensional embedding space, a website need not appear in the dataset from the first group of user devices in order to be identified in the encoding layer. The position of a website in the encoding layer may be determined based on its keyword and/or topic data, its position in the 128-dimensional embedding space, or both. Thus the encoding layer captures a vector representation of a website based on a combination of behavioral, textual, and/or graphical information about the websites, where not all modalities of need be present. In this way, websites can be represented in vector form even if not all modalities of data are present for that website, and if multiple modalities are present, a higher-fidelity or more precise representation of the website may be available. The machine learning model at 950 can then be trained using website positions in the encoding layer space.
In the case of the encoding layer described above, the position of a website in the encoding layer can be determined based on its keyword and/or topic data, its position in the 128-dimensional embedding space, or both. A position can also be determined for a set of keywords and/or topic data alone. A proximity or distance can be measured between any two positions in the encoding layer using any suitable distance metric, (e.g., cosine distance, Euclidean distance, etc.) The positions of the websites, keywords, and/or topics can then be used directly to select websites for targeted content delivery. In one embodiment, a website with a position in the space can be selected as a target, other websites in the encoding layer can be ranked based on their proximity to the target website in the encoding layer. The target website could be, for example, associated with a desired brand outcome (e.g., a webpage associated with the brand) or another website (e.g., a product review blog). In another embodiment, a set of keywords and/or topics can be used as a target, and websites in the encoding layer can be ranked based on their proximity to the target keywords and/or topics in the encoding layer. Additionally, the encoding space can be used to automatically generate appropriate names and/or descriptive keywords for clusters of websites. The position of each of a large corpus of words and phrases, for example from Wikipedia, can be identified in the encoding layer. Then, given a set of websites with location in the encoding layer, a ranked list of relevant keywords and/or topics can be generated based a suitable distance metric, for example distance from the centroid of the website positions. U.S. patent application Pub. Ser. No. 16/937,223 entitled “Machine Learning System and Method to Map Keywords and Records into an Embedding Space,” the entire disclosure of which is hereby incorporated by reference includes additional description of generating embeddings and ascertaining similarities between items represented in the embedding. U.S. patent application Pub. Ser. No. 16/937,223 further describes defining a descriptive title for an audience. It should be understood that the encoding layer described above could be used to define such a descriptive title, for example, in instances in which behavioral data for an audience and/or audience members is available and/or received. Such behavioral data can be used to identify a location in the encoding space for the audience and/or audience members. A descriptive title for the audience can then be defined based, for example, on the position(s) of keywords and/or topic(s) in the encoding space.
For example, in an embodiment, a method includes receiving and/or generating an embedding space (e.g., a word embedding) for a large dictionary of words. The method further include receiving a search query. The method further includes receiving a set of audience records and a set of device records associated with the set of audience records. A search query embedding can be generated such that the search query assumes a position in the embedding space. For each audience record from the set of audience records, an audience embedding can be generated such that a descriptive title of each audience record assumes a position in the embedding space. A set of keywords associated with browsing history of each audience record from the set of audience records can also be determined based, for example, on behavioral data associated with at least a subset of device records that are associated with that audience record. In some instances, the behavioral data can be aggregated for an audience record such that behavioral data associated with individual audience members is not available for analysis. A keyword embedding can be generated such that one or more keywords associated with each audience record assumes a position in the embedding space. A distance in the embedding space between the search query and audience embeddings and/or keyword embeddings can be determined. Each audience record can be scored and/or a ranked list of audience records can be generated, based on the relative distance of each audience record (e.g., audience embeddings and/or keyword embeddings associated with each audience record) from the search query in the embedding space.
The database(s) 1400 are databases, such external hard drives, database cloud services, external compute devices, virtual machine images on a stored device(s), and/or the like. Each database 1400 can include one or more memor(ies) 1410 and/or processor(s) 1420. The processor 1420 can be, for example, a hardware based integrated circuit (IC) or any other suitable processing device configured to run and/or execute a set of instructions or code. For example, the processor 1420 can be a general purpose processor, a central processing unit (CPU), an accelerated processing unit (APU), an application specific integrated circuit (ASIC), a field programmable gate array (FPGA), a programmable logic array (PLA), a complex programmable logic device (CPLD), a programmable logic controller (PLC) and/or the like. The processor 1420 is operatively coupled to the memory 1410 through a system bus (not shown; for example, address bus, data bus and/or control bus). The memory 1410 can be, for example, random access memory (RAM), memory buffers, hard drives, databases, erasable programmable read only memory (EPROMs), electrically erasable programmable read only memory (EEPROMs), read only memory (ROM), flash memory, hard disks, floppy disks, cloud storage, and/or so forth. The set of databases can communicate with the audience explorer device 1010 via a network 1500.
The set of content providers 1200 are compute devices, such as mainframe compute devices, servers, social media services, personal computers, laptops, smartphones, or so forth, each having a memory 1210 and a processor 1220. The processor 1220 can be, for example, a hardware based integrated circuit (IC) or any other suitable processing device configured to run and/or execute a set of instructions or code. For example, the processor 1220 can be a general purpose processor, a central processing unit (CPU), an accelerated processing unit (APU), an application specific integrated circuit (ASIC), a field programmable gate array (FPGA), a programmable logic array (PLA), a complex programmable logic device (CPLD), a programmable logic controller (PLC) and/or the like. The processor 1220 is operatively coupled to the memory 1210 through a system bus (not shown; for example, address bus, data bus and/or control bus). The memory 1210 can be, for example, random access memory (RAM), memory buffers, hard drives, databases, erasable programmable read only memory (EPROMs), electrically erasable programmable read only memory (EEPROMs), read only memory (ROM), flash memory, hard disks, floppy disks, cloud storage, and/or so forth. The set of content providers 1200 can communicate with the audience explorer device 1010 via a network 1500.
The set of audience devices 1300 are compute devices, such as personal computers, laptops, smartphones, or so forth, each having a memory 1310 and a processor 1330. The processor 1330 can be, for example, a hardware based integrated circuit (IC) or any other suitable processing device configured to run and/or execute a set of instructions or code. For example, the processor 1330 can be a general purpose processor, a central processing unit (CPU), an accelerated processing unit (APU), an application specific integrated circuit (ASIC), a field programmable gate array (FPGA), a programmable logic array (PLA), a complex programmable logic device (CPLD), a programmable logic controller (PLC) and/or the like. The processor 1330 is operatively coupled to the memory 1310 through a system bus (not shown; for example, address bus, data bus and/or control bus). The memory 1310 can be, for example, random access memory (RAM), memory buffers, hard drives, databases, erasable programmable read only memory (EPROMs), electrically erasable programmable read only memory (EEPROMs), read only memory (ROM), flash memory, hard disks, floppy disks, cloud storage, and/or so forth. The memory 1310 of each audience device can be configured to optionally include a device record 132 such as for example a browsing history, a cookie record, and/or the like. The set of audience devices 1200 can communicate with the audience explorer device 1010 via a network 1500.
The audience explorer device 1010, also referred to herein as “the audience explorer” or “the device,” can include a hardware-based computing device and/or a multimedia device. For example, in some instances, the audience explorer device 1010 can include a compute device, a server, a desktop compute device, a smartphone, a tablet, a wearable device, a laptop and/or the like. The audience explorer device 1010 includes a memory 1020, a communication interface 1030, and a processor 1040.
The memory 102 of the audience explorer device 1010 can be, for example, a random access memory (RAM), a memory buffer, a hard drive, a read-only memory (ROM), an erasable programmable read-only memory (EPROM), and/or the like. The memory 1020 can store, for example, one or more software modules and/or code that can include instructions to cause the processor 1040 to perform one or more processes, functions, and/or the like (e.g., the embedding space generator 1050, the keyword generator 1060, the embedding positioner 1070, the search query positioner 1080, the audience positioner 1090, and the distance estimator 1100). In some implementations, the memory 1020 can be a portable memory (e.g., a flash drive, a portable hard disk, and/or the like) that can be operatively coupled to the processor 1040. In other instances, the memory can be remotely operatively coupled with the audience explorer device 1010. For example, a remote database 1400 server can be operatively coupled to the audience explorer device 1010 via network 1500.
The memory 1020 can store the data including, but not limited to, the embedding space, the set of audiences, the audience search query, the data generated by operating the processor 1040 to run the audience explorer device 1010 (i.e., temporary variables and/or return addresses), and/or the like. The memory 1020 can also include data to generate the embedding space.
The communication interface 1030 can be a hardware device operatively coupled to the processor 1040 and memory 1020 and/or software stored in the memory 1020 and executable by the processor 1040. The communication interface 1030 can be, for example, a network interface card, a Wi-Fi™ module, a Bluetooth® module, an optical communication module, and/or any other suitable wired and/or wireless communication device. Furthermore, the communication interface 1030 can include a switch, a router, a hub and/or any other network device. The communication interface 1030 can be configured to connect the audience explorer device 1010 to a network 1500. In some instances, the communication interface 1030 can be configured to connect to a communication network such as, for example, the internet, an intranet, a local area network (LAN), a wide area network (WAN), a metropolitan area network (MAN), a worldwide interoperability for microwave access network (WiMAX®), an optical fiber (or fiber optic)-based network, a Bluetooth® network, a virtual network, and/or any combination thereof.
The processor 1040 can be, for example, a hardware based integrated circuit (IC) or any other suitable processing device configured to run and/or execute a set of instructions or code. For example, the processor 1040 can be a general purpose processor, a central processing unit (CPU), an accelerated processing unit (APU), an application specific integrated circuit (ASIC), a field programmable gate array (FPGA), a programmable logic array (PLA), a complex programmable logic device (CPLD), a programmable logic controller (PLC) and/or the like. The processor 1040 is operatively coupled to the memory 1020 through a system bus (for example, address bus, data bus and/or control bus).
The processor can include an embedding space generator 1050, a keyword generator 1060, an embedding positioner 1070, and a distance estimator 1100. Each of the embedding space generator 1050, the keyword generator 1060, the embedding positioner 1070, and the distance estimator 1100, can include software stored in the memory 1020 and/or executed by the processor 1040 (e.g., code to cause the processor 1040 to execute the embedding positioner 1090 and/or the distance estimator 1100 can be stored in the memory 1020). Each of the embedding space generator 1050, the keyword generator 1060, the embedding positioner 1070, and the distance estimator 1100 can include a hardware based device such as, for example, an ASIC, an FPGA, a CPLD, a PLA, a PLC, and/or the like. For example, the keyword generator 1060 can be implemented in a hardware based device that determined keywords associated with audience records. The memory 1020 can be configured to generate, receive and/or store data including an embedding space, a set of audience records, and an audience search query. The processor 1040 can be configured to generate a ranked list of at least a portion of the set of audience records based on the audience search query, the set of audiences, and the embedding space.
The embedding space generator 1050 can receive and/or generate an embedding space. The embedding space can be generated based on an English (or other) language corpus, such as fiction and/or non-fiction books, reference works, such as Wikipedia, and/or any other suitable database. U.S. Patent Application No. 62/737,620 and Ser. No. 16/586,502, the entire disclosure of each which is hereby incorporated by reference in its entirety, include a description of a technique to generating the embedding space. The embedding space generator 1050 can be configured to generate the embedding space using any generally available vector representation library, such as fastText, ELMo, BERT, Word2Vec, GloVe, and/or the like. The embedding space can be a word embedding in which words or phrases from the corpus are mapped to vectors of real number using a set of Natural Language Processing language modeling and feature learning techniques. The embedding space can be a representation of homogeneous data or heterogeneous data. Homogenous data refers to a collection of similar information, for example, a list of names of residents of a town. Heterogeneous data refers a collection of dissimilar information. Homogenous and/or heterogeneous data can be structured or unstructured data. Structured data has a pre-defined standardized format for providing information, for example, a list of homes, homeowners, addresses, market values, and/or the like stored in a database file and/or in a comma-separated value (CSV) file. Unstructured data can include information that have some organizational properties but are not stored in a standardized format, for example data found in an extendible markup language (XML) or javascript object notation (JSON) file. In some embodiments, the audience explorer device 1010 can receive the embedding space from a third party device. For example, the audience explorer device 1010 can receive the embedding space from a database 1400.
The keyword generator 1060 can associate browsing history or other suitable behavioral data with audience records. Each audience record from the set of audience records can be associated with one or more audience devices 1300. Typically an audience (represented by an audience record) will be associated with multiple audience devices 1300. Each audience device 1300 can be associated with a device record which can include, for example, browsing history information, a cookie record, and/or the like. In some instances, audience records and/or data associated with audience records can be received in an aggregated format. Similarly stated, in some embodiments, behavioral data for individual audience members/audience device(s) 1300 is obscured or otherwise not available for analysis and/or processing. The websites (e.g., a list of 10 websites, a list of 50 websites, a list of 100 websites, a list of 500 websites, a list of 1000 websites, and/or the like) most frequently visited by audience devices and/or an aggregate of audience devices in an audience can be identified. A set of keywords can be associated with each website indicated in the list of most frequently visited websites and/or in the browsing history of each audience device 1300. The set of keywords can, for example, be obtained (e.g., scraped) from the websites and can include text from the website, a website metadata, data associated with an embedded file on the website, and/or the like. In particular, the website metadata can describe and give information about the contents of the website and/or interaction of audience device(s) 1300 with the website. In other instances, the keyword generator 106 can be configured to find one or more keywords that are correlated to each audience record from the set of audience records. The correlation between an audience record with keyword(s) can be expressed using an index of correlation that represents a quantitative measure of an audience's affinity for the keyword. For example, the set of audience devices 1300 used by the audience have an index of correlation of 5 to the keyword “laser,” meaning that members of the audience, compared to a random device, is 5 times more likely to go to the set of websites associated with the keyword “laser.” In some instances, each keyword from the set of keywords can be associated with content of a website disproportionately visited as indicated by the device record (e.g., a browsing history, a cookie record, and/or the like) that are associated with an audience. In some instances, each keyword is obtained by identifying a word statistically overrepresented on a website disproportionately visited as indicated by the device records that are associated with the audience.
The embedding positioner 1070 can have a search query positioner 1080 and/or an audience positioner 1090, as described in further detail herein. The embedding positioner 1070 can receive the embedding space, the set of audience records, and/or the set of keywords and define a position of each audience based on a descriptive title (or descriptor) of the audience (an “audience embedding”) and/or keywords associated with the audience (a “keyword embedding) using fastText, ELMo, BERT, Word2Vec, GloVe, and/or the like. Similarly stated, the audience record assumes one or more positions (e.g., a set of coordinates representing the audience record) in the embedding space, such as a position associated with the descriptive title of the audience record and a position associated with keywords associated with the audience record. The embedding positioner 1070 can further receive the audience search query and define a position of (e.g., a set of coordinates representing the search query) in the embedding space. Determining a position of, for example, the audience search query in the embedding space allows for a quantitative measure of the meaning of the audience search query to be defined. Similarly, the position of the descriptive title of the audience and/or set of keywords in the embedding space represents a quantitative measure of the meaning of descriptive title and/or the keywords, respectively. A distance between the audience search query and the descriptive title and/or the keywords thus represents a measure of the similarity between the meaning and/or context of the respective terms (e.g., semantic similarity), rather than a simple text match.
The search query positioner 1080 can receive an audience search query using the communication interface 1030 from, for example, the set of content providers 1200, via the network 1500. The embedding positioner 1070 can be configured to generate an audience search query embedding from the search query. The search query positioner 1080 can be configured to define a position for the audience search query embedding in the embedding space.
The audience positioner 1090 can receive a set of audience records using the communication interface 1030 from, for example, the set of databases 1400, via the network 1500. The embedding positioner 1070 can generate an audience embedding from each audience record from the set of audience records. The audience positioner 1090 can generate an audience embedding and/or a keyword embedding for each audience record from the set of audience records. The audience positioner 1090 can define a position for the audience embedding and/or the keyword embedding in the embedding space.
The distance estimator 1100 can calculate an audience distance between the position of a descriptive title and/or summary metric of the audience record in the embedding space (the audience embedding) and the position of the search query embedding in the embedding space. The distance estimator 1100 can be configured further to calculate an audience keyword distance (e.g., a Euclidean distance, a Cosine distance, a word mover's distance (WDM), and/or the like) between the position of the audience keyword embedding in the embedding space and the position of the search query embedding in the embedding space. For example, in instances where multiple keywords are associated with one audience record, the distance estimation method can take an average of the distance between the search query embedding and the position of each keyword associated with that audience record in the embedding space, take a weighted average of a distance between the search query embedding and the position of each keyword associated with that audience record in the embedding space (e.g., such that more relevant keywords are weighted more heavily), taking a minimum, maximum, mode, mean, and so forth, of a set of distances for a set of keyword embedding associated with that audience record from the position of the audience embedding, and/or the like. The distance estimator 1100 can iterate or operate in parallel to calculate distances between the position of the search query embedding in the embedding space and each audience record in the embedding space (e.g., taking into account the audience embedding and/or keyword embedding(s) associated with that audience record). The distance estimator 1100 can further return a select list of audience records having the shortest overall distances from the search query embedding.
In use, the processor 1040 allows a user to search and/or explore the set of audience records based on actual behavioral data derived from the set of audience devices. Similarly stated, the processor 1040 can be configured to understand the contextual meaning of a search query by using a word embedding as a quantitative representation of the search query in the embedding space. This allows the processor 1040 to search the data based on similarity of the representative concepts captured in the device behaviors and the keywords in the embedding space, rather than just the words as strings of letters. In some embodiments, the behavioral data associated with the set of audience devices is aggregated behavioral data and/or summary behavioral data such that behavioral data for individual members associated with each audience record from the set of audience records is not analyzed.
In some embodiments, the audience explorer device 1010 receives, from a compute device, a search query and generates a search query embedding based on the search query. The audience explorer device 1010 determines a position for the search query embedding in the embedding space (e.g., generated by the embedding space generator 1050 or received from a third party). The audience explorer device 1010 receives a set of audience records and, for each audience record, generates one or more keyword embeddings based on the behavioral data (optionally aggregated) associated with the audience record for that audience. The audience explorer device 1010 then determines a position for each keyword embedding in the embedding space and calculates a similarity between the search query and each audience based on a distance between the search query embedding and the keyword embedding(s) associated with that audience. The audience explorer device can the send to the compute device, a ranked list of at least a subset of audiences from the set of audiences based on the similarity between the search query and the subset of audiences.
In some embodiments, the content providers 1200 can explore a set of audience records based on the actual behavioral data of the set of audience devices 1300 based on information received from the audience explorer device 1010. The audience explorer device 1010 can present information about the set of audiences and/or can allow an audiences to be selected by the content provider 1200 via a webpage, an application programming interface (API), and/or any other suitable user interfaces operatively coupled to the audience explorer device 1010. The content providers 1200 can be configured further to store the selected audience (e.g., an identifier for the audience and/or users within the audience) in the memory 1210. In some embodiments, the content provider 1200 can be configured further to analyze the set of audiences locally using the processor 1220 to generate a set of revised audiences. The content provider 1200 can be configured further to facilitate the delivery of content (e.g., information, advertisement, media items, etc.) to the selected audience and/or the revised audience via any suitable means. In some instances, the content provider 1200 can be operable to facilitate the placement of content through a real time bidding system implemented by the audience explorer device 1010 or a distinct third-party service. Similarly stated, the content provider 1200 can be operable to use audiences selected with the audience explorer device 1010 to facilitate the delivery of content through any suitable portal.
At 2010, an embedding space can be defined. The embedding space can be generated based on an English (or other) language corpus, such as fiction and/or non-fiction books, reference works, such as Wikipedia, and/or any other suitable database.
At 2020, a search query is received. The search query can include a set of words or other suitable parameters. The search query can be entered via a web browser interface, an app in a mobile phone, and/or the like.
At 2030, a set of audiences are received. Each audience from the set of audiences is associated with one or more audience devices. Each audience device can be associated with behavioral data, such as browsing history and/or one or more cookies. A set of keywords can be associated with each website indicated in the browsing history of each audience device. The keywords can, for example, be obtained (e.g., scraped) from the websites and can include text from the website, a website metadata, data associated with an embedded file on the website, and/or the like. In particular, website metadata can describe and give information about the contents of the website and/or the interaction of audience devices with the website.
In some instances, each audience from the set of audiences received at 2030 can include aggregated behavioral data such that behavioral data from individual audience members/devices is not received. For example, a third party with access to behavioral data can pre-define audiences (i.e., groups of users/devices) and indications of such pre-defined audiences, and an aggregated behavioral data and/or summary of behavioral data for the audience can be received at 2030.
At 2040, a position for the search query is can be defined in the embedding space. An audience search query embedding is defined for the search query by finding a set of query word embedding and calculating an average of the set of query word embedding, a weighted average of the set of query word embedding, and/or the like.
An audience embedding can be defined for the audience based on the descriptive title or other summary characteristic of the audience. A position for the audience embedding in the embedding space can be defined, at 2050.
At 2060, one or more keywords for each audience from the set of audiences is determined. One or more audience devices (e.g., from the set of audience devices 1300) can be associated with each audience from the set of audiences. Each audience device can be associated with a browsing history and/or one or more cookies. A set of keywords can be associated with each website indicated in the browsing history of each audience device. The key words can, for example, be obtained (e.g., scraped) from the websites and can include text from the website, a website metadata, data associated with an embedded file on the website, and/or the like. In particular, the website metadata can describe and give information about the contents of the website and/or the interaction of audience devices with the website. The set of keywords associated with each audience device can be associated with an audience that includes that audience device. In embodiments in which summary and/or aggregate behavioral data for audiences is received, the set of keywords associated with each audience can be similarly determined, but based on the aggregate data, for example, such that the behavioral data of no individual user/audience device is used to determine the keywords.
At 2070, the position(s) of the keywords associated with an audience in the embedding space is determined. Similarly stated, a keyword embedding for each keyword can be defined. Each keyword can be associated with one or more audiences using an index of correlation that represents a quantitative measure of that audience's affinity for the keyword. For example, an index of correlation of 4 to the keyword “fishing,” means that members of the audience, compared to a random device, are 4 times more likely to go to the set of websites with the keyword “fishing.”
At 2080, a distance between an audience in the embedding space and the position of a search query embedding in the embedding space is determined. The distance can be based on the distance of the position of the search query embedding in the embedding space from a) the position of the embedding of the descriptive title of the audience, and/or b) the position of the embedding of the behavior history of the audience (e.g., audience keyword distance). The distance between the audience in the embedding space and the search query embedding in the embedding space represents a difference in the meaning of the search query and the meaning of the content of webpages accessed by audience members. Thus, in contrast to known methods, the actual behavior of audience members is used to determine a similarity between a search query and an audience. Furthermore, rather than a simple text- or category-based approach to classifying audience behavior, the embedding space represents the meaning of the content of webpages accessed by audience members.
The method 2000 can include iterating, via a processor, to calculate a set of overall distances between the position of the search query in the embedding space and each audience from the set of audiences in the embedding space. The method 2000 can include scoring each audience (e.g., based on the distance of that audience from the search query in the embedding space) and/or returning, at 2080, a ranked list of audiences having the shortest overall distances from the search query embedding. The list, complete or in part can be presented to a graphical user interface (GUI) in form of a data stream, a table, and/or the like. Similarly stated, the list can presented to the device that entered and/or initiated the search query.
The “Soccer Players” audience 504 and the “Hikers” audience 506 can be assigned a score based on the distances between the descriptive title and/or keywords associated with the audiences and the search query in the embedding space. For example, if a sum, mean, median, product, minimum or any other suitable combination or metric summarizing or representing d1, d5, and/or do is lower than the combination or metric summarizing or representing d2, d3, and/or d4, the “Soccer Players” audience 504 can be scored or ranked higher than the “Hikers” audience 506, representing that soccer players have a stronger interest in or similarity to shoes than hikers and therefore that soccer players represent a better audience for targeted content related to shoes.
Although
As shown in
The method 4000 can include determining, at 4050, one or more keywords. Each keyword can be associated with an audience record. The keyword can be determined based on behavioral data associated with at least a subset of device records that are associated with that audience record. The behavioral data associated with the multiple device records can be aggregated behavioral data and/or summary behavioral data. Determining keywords based on the aggregated behavioral data and/or summary behavioral data can help in reducing/eliminating processing resources used to analyze behavioral data for individual members associated with each audience record from the multiple audience records and/or can preserve user privacy.
In some instances, each keyword can be associated with content of a website or websites disproportionately visited by the subset of device records that are associated with an audience record. In some instances, each keyword is obtained by identifying a word statistically overrepresented on a website(s) disproportionately visited as indicated by the subset of device records that are associated with an audience record that is from the multiple audience records and that is associated with that keyword.
The method 4000 can include determining, at 4060, a position for each keyword in the embedding space. In some instances, each of the position of the search query, the position of each audience record, and/or the position of each keyword can be represented by a vector and/or set of coordinates that define a location in the embedding space.
The method 4000 can include calculating, at 4070, a distance between the position of the search query in the embedding space and the position of each audience record from the multiple audience records in the embedding space. The method 4000 can include calculating, at 4080, a distance between the position of the search query in the embedding space and the position of each keyword from the multiple keywords in the embedding space. The method 4000 can further include ranking, at 4090, each audience record from the multiple audience records based on (1) a distance between the position of the search query in the embedding space and a position for that audience record in the embedding space and/or (2) a distance between the position of the search query in the embedding space and a position of one or more keywords associated with that audience record in the embedding space. The distance between the position of the search query in the embedding space and the position of each audience record and/or keyword in the embedding space can be calculated using at least one of a Euclidean distance, a Cosine distance, a word mover's distance (WMD), and/or the like.
In some embodiments, the method 4000 can optionally include generating a search query embedding, an audience embedding, and/or a keyword embedding from the search query, each audience record, and/or each keyword, respectively. The search query embedding, the audience embedding, or the keyword embedding can be generated using a vector representation library.
In some embodiments, the method 4000 can optionally include generating the embedding space based on an English (or other) language corpus, such as fiction and/or non-fiction books, reference works, such as Wikipedia, and/or any other suitable database. An embedding space generator (such as the embedding space generator 1050 as shown and described with respect to
Some embodiments described herein relate to methods. It should be understood that such methods may be computer-implemented methods (e.g., instructions stored in memory and executed on processors). Where methods described above indicate certain events occurring in certain order, the ordering of certain events may be modified. Additionally, certain of the events may be performed repeatedly, concurrently in a parallel process when possible, as well as performed sequentially as described above. Furthermore, certain embodiments may omit one or more described events.
Some embodiments described herein relate to computer-readable medium. A computer-readable medium (or processor-readable medium) is non-transitory in the sense that it does not include transitory propagating signals per se (e.g., a propagating electromagnetic wave carrying information on a transmission medium such as space or a cable). The media and computer code (also can be referred to as code) may be those designed and constructed for the specific purpose or purposes. Examples of non-transitory computer-readable media include, but are not limited to: magnetic storage media such as hard disks, floppy disks, and magnetic tape; optical storage media such as Compact Disc/Digital Video Discs (CD/DVDs), Compact Disc-Read Only Memories (CD-ROMs), and holographic devices; magneto-optical storage media such as optical disks; carrier wave signal processing modules; and hardware devices that are specially configured to store and execute program code, such as ASICs, PLDs, ROM and RAM devices. Other embodiments described herein relate to a computer program product, which can include, for example, the instructions and/or computer code discussed herein.
Examples of computer code include, but are not limited to, micro-code or micro-instructions, machine instructions, such as produced by a compiler, code used to produce a web service, and files containing higher-level instructions that are executed by a computer using an interpreter. For example, embodiments may be implemented using Java, C++, or other programming languages (e.g., object-oriented programming languages) and development tools. Additional examples of computer code include, but are not limited to, control signals, encrypted code, and compressed code.
This application is a continuation of U.S. patent application Ser. No. 17/569,412, filed Jan. 5, 2022, which is a continuation of now abandoned U.S. patent application Ser. No. 17/379,570, filed Jul. 19, 2021, which is a continuation of U.S. patent application Ser. No. 17/108,770, filed Dec. 1, 2020, now U.S. Pat. No. 11,068,935, which is a continuation-in-part of U.S. patent application Ser. No. 16/586,502, filed Sep. 27, 2019, which is a non-provisional of and claims priority to provisional U.S. Patent Application No. 62/737,620, filed Sep. 27, 2018, the disclosure of each of which is hereby incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
62737620 | Sep 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17569412 | Jan 2022 | US |
Child | 18779937 | US | |
Parent | 17379570 | Jul 2021 | US |
Child | 17569412 | US | |
Parent | 17108770 | Dec 2020 | US |
Child | 17379570 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16586502 | Sep 2019 | US |
Child | 17108770 | US |