Described herein is a system and method of ad targeting that automatically matches advertisements to media based on the demographic signatures of each. The method and system include calculating a match score between historical buyer demographics and media demographics. media which is similar to the demographic of the product buyers is targeted for advertising.
|
49. A computing device comprising:
a memory; and
a processing device coupled to the memory, the processing device to:
automatically extract one or more product keywords for a product from one or more sources by a processing device;
generate a product profile for the product by the processing device, the product profile comprising the extracted one or more product keywords for the product;
automatically generate a plurality of media asset profiles for a plurality of television media assets, each media asset profile for a television media asset comprising one or more media asset keywords for the television media asset;
for each television media asset, calculate a match score between the one or more media asset keywords for the television media asset and the one or more product keywords for the product;
calculate fitness scores between the product profile for the product and the plurality of media asset profiles for the plurality of television media assets based at least in part on the match scores; and
select a particular television media asset for placing an advertisement for the product based upon the fitness scores.
1. A method comprising:
automatically extracting, by a processing device, one or more product keywords for a product from a resource at a uniform resource locator (URL) associated with the product;
generating a product profile for the product by the processing device, the product profile comprising the extracted one or more product keywords for the product;
automatically generating, by the processing device, a plurality of media asset profiles for a plurality of television media assets, each media asset profile for a television media asset comprising one or more media asset keywords for the television media asset;
for each television media asset, calculating a match score between the one or more media asset keywords for the television media asset and the one or more product keywords for the product;
calculating fitness scores between the product profile for the product and the plurality of media asset profiles for the plurality of television media assets based at least in part on the match scores; and
selecting a particular television media asset for placing an advertisement for the product based upon the fitness scores.
33. A computer readable storage medium having instructions that, when executed by a processing device, cause the processing device to perform operations comprising:
automatically extracting, by the processing device, one or more product keywords for a product from one or more sources;
generating a product profile for the product by the processing device, the product profile comprising the extracted one or more product keywords for the product;
automatically generating, by the processing device, a plurality of media asset profiles for a plurality of television media assets, each media asset profile for a television media asset comprising one or more media asset keywords for the television media asset;
for each television media asset, calculating a match score between the one or more media asset keywords for the television media asset and the one or more product keywords for the product;
calculating fitness scores between the product profile for the product and the plurality of media asset profiles for the plurality of television media assets based at least in part on the match scores; and
selecting a particular television media asset for placing an advertisement for the product based upon the fitness scores.
17. A computer-implemented method of matching an advertisement for a product to a television media asset comprising:
automatically extracting, by a processing device, one or more media asset keywords for a plurality of television media assets, wherein the media asset keywords for a television media asset are extracted from at least one of closed captioning text associated with the television media asset, a program schedule description associated with the television media asset, or speech-to-text conversion for program content of the television media asset;
generating a plurality of media asset profiles for a plurality of television media assets, each media asset profile for a television media asset comprising the one or more media asset keywords for the television media asset;
generating, by the processing device, a product profile for a product, the product profile comprising one or more product keywords for the product;
for each television media asset, calculating a match score between the one or more media asset keywords for the television media asset and the one or more product keywords for the product;
calculating fitness scores between the product profile for the product and the plurality of media asset profiles for the plurality of television media assets based at least in part on the match scores; and
selecting a particular television media asset for placing the advertisement for the product based upon the fitness scores.
40. A computer readable storage medium having instructions that, when executed by the processing device, cause the processing device to perform operations comprising:
automatically extracting, by a processing device, one or more media asset keywords for a plurality of television media assets, wherein the media asset keywords for a television media asset are extracted from at least one of closed captioning text associated with the television media asset, a program schedule description associated with the television media asset, or speech-to-text conversion for program content of the television media asset;
generating a plurality of media asset profiles for a plurality of television media assets, each media asset profile for a television media asset comprising the one or more media asset keywords for the television media asset;
generating, by the processing device, a product profile for a product, the product profile comprising one or more product keywords for the product;
for each television media asset, calculating a match score between the one or more media asset keywords for the television media asset and the one or more product keywords for the product;
calculating fitness scores between the product profile for the product and the plurality of media asset profiles for the plurality of television media assets based at least in part on the match scores; and
selecting a particular television media asset for placing the advertisement for the product based upon the fitness scores.
2. The method of
showing the fitness scores as part of a media asset schedule; showing the fitness scores and upper and lower confidence bounds of the fitness scores as part of a media asset schedule; showing the fitness scores superimposed on the media asset schedule; and showing forecast fitness scores and actual fitness scores on the media fitness schedule.
3. The method of
4. The method of
5. The method of
6. The method of
automatically selecting previous customers of the product using a plurality of customer records from previous product orders for the product;
concatenating a plurality of enriched customer records for the previous customers based on adding customer demographic information to the plurality of customer records, wherein the customer demographic information comprises a plurality of variables; and
creating, by the processing device, the product demographic profile for the product from the plurality of enriched customer records, the product demographic profile comprising automatically scored target demographics for the product based at least in part on a combination of the customer demographic information from the plurality of enriched customer records.
7. The method of
8. The method of
assigning a unique identification code to each of a plurality of media asset fitness models;
testing media asset fitness models of the plurality of media asset fitness models against other media asset fitness models; and
tracking results of the testing using the unique identification codes.
9. The method of
10. The method of
automatically extracting the one or more media asset keywords for the plurality of television media assets, wherein the media asset keywords for a television media asset are extracted from at least one of closed captioning text associated with the television media asset, a program schedule description associated with the television media asset, or speech-to-text conversion for program content of the television media asset.
11. The method of
12. The method of
13. The method of
14. The method of
15. The method of
16. The method of
18. The method of
19. The method of
20. The method of
21. The method of
22. The method of
23. The method of
24. The method of
25. The method of
26. The method of
27. The method of
28. The method of
29. The method of
30. The method of
automatically extracting one or more product keywords for the product from one or more sources.
31. The method of
automatically selecting previous customers of the product using a plurality of customer records from previous product orders for the product;
concatenating a plurality of enriched customer records for the previous customers based on adding customer demographic information to the plurality of customer records, wherein the customer demographic information comprises a plurality of variables; and
creating the product demographic profile for the product from the plurality of enriched customer records, the product demographic profile comprising automatically scored target demographics for the product based at least in part on a combination of the customer demographic information from the plurality of enriched customer records.
32. The method of
34. The computer readable storage medium of
35. The computer readable storage medium of
36. The computer readable storage medium of
automatically selecting previous customers of the product using a plurality of customer records from previous product orders for the product;
concatenating a plurality of enriched customer records for the previous customers based on adding customer demographic information to the plurality of customer records, wherein the customer demographic information comprises a plurality of variables; and
creating, by the processing device, the product demographic profile for the product from the plurality of enriched customer records, the product demographic profile comprising automatically scored target demographics for the product based at least in part on a combination of the customer demographic information from the plurality of enriched customer records.
37. The computer readable storage medium of
38. The computer readable storage medium of
39. The computer readable storage medium of
automatically extracting the one or more media asset keywords for the plurality of television media assets, wherein the media asset keywords for a television media asset are extracted from at least one of closed captioning text associated with the television media asset, a program schedule description associated with the television media asset, or speech-to-text conversion for program content of the television media asset.
41. The computer readable storage medium of
42. The computer readable storage medium of
43. The computer readable storage medium of
44. The computer readable storage medium of
45. The computer readable storage medium of
46. The computer readable storage medium of
47. The computer readable storage medium of
automatically extracting one or more product keywords for the product from one or more sources.
48. The computer readable storage medium of
automatically selecting previous customers of the product using a plurality of customer records from previous product orders for the product;
concatenating a plurality of enriched customer records for the previous customers based on adding customer demographic information to the plurality of customer records, wherein the customer demographic information comprises a plurality of variables; and
creating the product demographic profile for the product from the plurality of enriched customer records, the product demographic profile comprising automatically scored target demographics for the product based at least in part on a combination of the customer demographic information from the plurality of enriched customer records.
50. The computing device of
51. The computing device of
52. The computing device of
53. The computing device of
automatically selecting previous customers of the product using a plurality of customer records from previous product orders for the product;
concatenating a plurality of enriched customer records for the previous customers based on adding customer demographic information to the plurality of customer records, wherein the customer demographic information comprises a plurality of variables; and
creating, by the processing device, the product demographic profile for the product from the plurality of enriched customer records, the product demographic profile comprising automatically scored target demographics for the product based at least in part on a combination of the customer demographic information from the plurality of enriched customer records.
54. The computing device of
automatically extract the one or more media asset keywords for the plurality of television media assets, wherein the media asset keywords for a television media asset is extracted from at least one of closed captioning text associated with the television media asset, a program schedule description associated with the television media asset, or speech-to-text conversion for program content of the television media asset.
|
This application claims the benefit of U.S. Provisional Application No. 61/372,974, entitled “METHOD AND SYSTEM FOR AUTOMATICALLY TARGETING ADS TO TELEVISION MEDIA USING DEMOGRAPHIC SIMILARITY”, filed Aug. 12, 2010, and U.S. Provisional Application No. 61/378,299, entitled “SYSTEM AND METHOD FOR ATTRIBUTING MULTI-CHANNEL CONVERSION EVENTS AND SUBSEQUENT ACTIVITY TO MULTI-CHANNEL MEDIA SOURCES”, filed Aug. 30, 2010, both of which are hereby incorporated by reference in their entirety.
Brief definitions of several terms used herein follow, which may be helpful to certain readers. Such definitions, although brief, will help those skilled in the relevant art to more fully appreciate aspects of the invention based on the detailed description provided herein. Such definitions are further defined by the description of the invention as a whole and not simply by such definitions.
Asset | A specific impression, airing, or advertising event. For |
instance | example, a media asset may be CNN-Monday through Friday. |
An Asset instance of this asset may be CNN-Tuesday-8:05pm- | |
AC360. | |
Media | Advertising media that can be published for purposes of |
asset | advertising. Examples include television airing, radio spot, |
newspaper spot, internet publisher page. For example, a | |
television media asset may comprise some combination of | |
station-geography-program-day-hours such as WXGN- | |
Florida-SixO'ClockNews-Monday-6pm, or may be a more | |
general set such as FOX-Monday through Friday. | |
Asset | Same as media asset |
Media | Same as media asset |
Station | Same as media asset |
Station- | Same as media asset |
Program | |
Station- | Same as media asset |
Program- | |
Day-Hour | |
Product | Something that is being sold by an advertiser. The product |
and advertisement are used interchangeably - each product is | |
assumed to have one or more advertisements that can be | |
aired on television media. The contents of the advertisement | |
are considered part of the product for the present system in | |
order to simplify the description. | |
Adver- | Same as Product |
tisement | |
A variety of methods have been used in the past for television advertising targeting.
Television Ad Targeting Using Intuition
The first method which is widely used today uses human intuition and insight to identify which television programs to purchase. This method can be effective, however, doesn't scale. There are over 2 million possible television advertising placements during a year even with conservative estimates of airing frequencies, and many more when local broadcast schedules are considered (there are 5,000 local stations), and so picking the right times, geographies, and programs to run is difficult.
Television Ad Targeting Using the Nielsen Television Panel
A second method for targeting television advertisements is to use Nielsen age-gender ratings. Nielsen's viewer panel was developed in the 1960s and consists of 5,000 to 25,000 households spread around the United States. The viewing panels themselves range from fully electronic recording systems to paper-based diaries.
Nielsen panelists track their viewing habits, and then Nielsen aggregates the data and shows the age-gender demographics for each program. A media buyer can then decide whether to purchase advertisement for this programming if it seems to be like the audience that would want to purchase the product.
Television Ad Targeting Using Historical Ad-Media Performance
Another form of television ad targeting uses historical data from previous advertisement airings on media, and their performance, in order to predict whether buying another airing with the same program-station-day-hour might be effective. This technique is most commonly used for “Television long-form buying”, also known as “Infomercials”. In order to determine if “DIY Saturday midnight-1 am” will perform well, the ad company looks for how the ad performed in this same time-slot and station a week prior (for example). The best example of this method that we know of besides our own work in this area is from Tellis et. al. (2005) which presents an automated system of this kind. The system includes lag-terms for ad placements, and responses collected over the past several hours. Tellis, G., Chandy, R., MacInnis, D., Thaivanich, P. (2005), “Modeling the Microeffects of Television Advertising: Which Ad Works, When, Where, for How Long, and Why?”, Marketing Science, Marketing Science 24(3), pp. 351-366, INFORMS.
Television Ad Targeting Using One-to-One Techniques
Television Ad Targeting should theoretically be able to be performed by analyzing an individual television viewer's activity to determine what products they're interested in, and delivering an advertisement to that specific person.
At the moment this technology is not available for television except in some very limited—generally research-related—cases. Most of the work in this area comprises experiments, tests in the New York area where some one-to-one capabilities have been installed via the cable system in that area, and academic studies. There are technological problems around both tracking viewer activity, as well as delivering an ad to them without delivering it to lots of other customers. The overwhelming majority of televisions as of 2011 have no capability for individualized tracking or ad delivery.
One-to-one television ad targeting was first discussed as early as the 1970s. Personalized television programming has since been proposed by Smyth and Cotter (2000) and Spangler et. al. (2003). Smyth, B. and Cotter, P. (2000), “A Personalized Television Listings Service”, Communications of the ACM, Vol. 43, No. 8, August 2000, pp. 107-111; Spangler, W., Gal-Or, M., May, J. (2003), “Using data mining to profile TV viewers”, Communications of the ACM archive, Volume 46, Issue 12 (December 2003), pp. 66-72. One-to-one targeting in a TV context has been described conceptually by (Arora, N., Hess, J., Joshi, Y., Neslin, S., Thomas, J. (2008), “Putting one-to-one marketing to work: Personalization, customization, and choice”, Marketing Letters, Vol. 19, pp. 305-321). Chorianopoulos, Lekakos, Spinellis (2003) and Lekakos and Giaglis (2004) ran experiments which tested the effectiveness of personalized advertising on television. Chorianopoulos, K. and G. Lekakos and D. Spinellis (2003). “The Virtual Channel Model for Personalized Television”, Proceedings of the 1st EuroITV conference: From Viewers to Actors pp. 59-67. They recruited experimental subjects and had them fill out surveys to classify them into segments. They next used a training set of users who had explicitly indicated their interest in some advertisements to predict interest in the new ads.
Aspects of the inventive system, as described herein, recognize that the media is represented by the demographics of people who are watching. Using this insight, the system can create a “fingerprint” for the kinds of customer that buys a product of interest. The system can then perform a vector match against media looking for the closest match. After the system finds a close match, it recommends buying that media. Although the technology for one-to-one television advertisement targeting is not currently available, aspects of the current invention are designed to work with one-to-one targeting capabilities and can utilize one-to-one tracking and delivery when that becomes available. The present invention would simply add in the individualized information to its segment information in order to improve the ad match quality.
The method used by a media buyer using Nielsen aggregated data to determine which program to purchase is not based on any formal method (such as vector match), nor is it based on analysis of the product buyer population. Furthermore, while the Nielsen panel is a useful data source and use of this data is described in this application, the Nielsen viewer panel is inherently limited by its very small size, minimal ability to cover different geographic areas, and this has remained a consistent problem with using Nielsen data for deciding whether to purchase ads for a particular programming. A variety of enhancements are discussed for making the techniques described below compatible with multiple other demographic sources (including census, Set top box data, and linked buyer data) so as to create a highly complete and rich profile based on millions of viewers, over 400 variables, not just 2 or 20 as are available through the Nielsen panel, and buyers rather than viewers.
Various examples of the invention will now be described. The following description provides specific details for a thorough understanding and enabling description of these examples. One skilled in the relevant art will understand, however, that the invention may be practiced without many of these details. Likewise, one skilled in the relevant art will also understand that the invention may include many other obvious features not described in detail herein. Additionally, some well-known structures or functions may not be shown or described in detail below, so as to avoid unnecessarily obscuring the relevant description.
The terminology used below is to be interpreted in its broadest reasonable manner, even though it is being used in conjunction with a detailed description of certain specific examples of the invention. Indeed, certain terms may even be emphasized below; however, any terminology intended to be interpreted in any restricted manner will be overtly and specifically defined as such in this Detailed Description section.
System Architecture
Prior to being able to do response modeling and detailed targeting for television media, a large amount of system infrastructure should be in place.
Aspects of the invention can be embodied in a special purpose computer or data processor that is specifically programmed, configured, or constructed to perform one or more of the computer-executable instructions explained in detail herein. While aspects of the invention, such as certain functions, are described as being performed exclusively on a single device, the invention can also be practiced in distributed environments where functions or modules are shared among disparate processing devices, which are linked through a communications network, such as a Local Area Network (LAN), Wide Area Network (WAN), or the Internet. In a distributed computing environment, program modules may be located in both local and remote memory storage devices.
Aspects of the invention may be stored or distributed on tangible computer-readable media, including magnetically or optically readable computer discs, hard-wired or preprogrammed chips (e.g., EEPROM semiconductor chips), nanotechnology memory, biological memory, or other data storage media. Alternatively, computer implemented instructions, data structures, screen displays, and other data under aspects of the invention may be distributed over the Internet or over other networks (including wireless networks), on a propagated signal on a propagation medium (e.g., an electromagnetic wave(s), a sound wave, etc.) over a period of time, or they may be provided on any analog or digital network (packet switched, circuit switched, or other scheme).
Step 1: Setup Data Feeds with Media Agency
A first step is to ensure all the data about what media is being purchased, running, and trafficked to stations is collected to ensure that there is an accurate representation of the television media. This includes setting up data feeds for:
a. Media Plan Data (
b. Media Verification Data (
c. Trafficking/Distribution Data (
Step 2: Setup Data Feed with Call Center
A second step is to ensure there is accurate data about the callers that called into specific phone numbers from the call center and it is important to get the call center onboarded with a data feed (
Step 3: Setup Data Ecommerce Vendor Datafeeds
A third step is to setup recurring data feeds with the vendor or internal system of the advertiser that records orders that come in from the advertiser's website (
Step 4: Step Data Order Processing/Fulfillment Data Feed
A fourth step is to setup recurring data feeds with the order vendor or internal system that physically handles the logistics of billing and/or fulfillment. This is important for subsequent purchases such as subscriptions and for returns/bad debt, etc to accurately account for revenue. This may also come from a series of retail Point of Sale system (
Step 5: Setup Audience Data Enrichment Data Feed with Data Bureau
A fifth step is to ensure that every caller, web-converter, and ultimate purchaser has their data attributes appended to their record in terms of demographics, psychographics, behavior, etc (
Step 6: Setup Data Feed with Guide Service
A sixth step is to ensure that the forward looking guide service data is ingested into the system. This is the programming of what is going to run on television for the weeks ahead (
Step 7: Setup Data Feed for Panel Data Enrichment
Either through the purchasers of products on television, set top box viewer records, or existing panels it is necessary to get a feed of viewer/responder data that has the same demographic, psychographic, behavioral data appended to that is being appended to the advertiser's purchaser data in Step 5 (
Step 8: Ingest All Data Into Staging System
In step 8, all of the underlying data is put into production and all of the data feeds setup from Steps 1-7 are loaded into an intermediate format for cleansing, adding identifiers, etc. Personally Identifiable Information (PII) is also split and routed to a separate pipeline for secure storage. (
Step 9: Run Business Logic/Models for Matching Responses and Orders to Media
In step 9, all of the data from the data feeds has been ingested into the system at the most granular form. Here the phone responses are matched up to the media that generated it. The e-commerce orders are matched using statistical models to the media that likely generated them. (
Step 10: Load Data into Final Databases
In step 10, the data is aggregated and final validation of the results is automatically completed. After this, the data is loaded into the databases for use with any of the upstream media systems. These include the ability to support media planning through purchase suggestions, revenue predictions, pricing suggestions, performance results, etc (
Step 11: Use Data in Presentation Layer
In step 11, all of the data becomes accessible to the operators of various roles in the media lifecycle. This includes graphical tools for media planning (where the targeting in this application primarily fits), optimization, billing, trafficking, reporting, etc (
System Inputs and Outputs
The user provides the following information:
A1 Inputs
B2. Optional Outputs
The steps of the ad-program targeting algorithm are given below. These steps are shown in a flow chart in
The first step is to identify which kinds of customers would like to buy the product. In many cases, an advertiser already has a significant number of customers who have bought the product previously. These customers are known because they have had to provide their credit card number, name, address, and phone number as part of the order process.
The system can take this database of customers, and enrich the customer records with demographics. For example, using the zip-code of the customer it is possible to infer their household value using US Census data. Using name it is often possible to infer gender and ethnicity (e.g. “Christine”→Female, “Bob”→Male). A variety of third party services for customer demographics exist, and can be used for this purpose, for example, Acxiom, which maintains an extensive database, and enriches to over 400 variables including income, age, gender, interests, and so on.
After enriching the customer records, the system can now create an average profile for customers who have bought this product.
Customer demographics can be defined as ri,Dj,k where Dj is the jth demographic variable for customer response i and product k. The product profile pj,k will be defined as the average of the many customer demographics where that demographic is not a missing value, and the customer in question purchased product P(i,k).
After creating the product profile, the system can report on the most distinctive attributes of the product profile. Assume that there are a large number of customers with demographic enrichment, from a variety of products k. The system can calculate a grand mean or population centroid as follows:
Each product profile element can be expressed as a z-score compared to the population mean and standard deviation:
The operation above ensures that each profile value is re-scaled so that its difference from the mean is scaled to units of standard deviations. Therefore, all of the dimensions are now transformed into the same z-score scale. Higher zscores means more unusually high variable compared to the population. While a z-score is used in the calculations here, any standardized or normalized statistical score can be calculated for each variable and used in a similar manner.
Table I shows a product profile for a handyman tool product that indicates that customers enjoy woodworking and auto-repair. They buy unusual amounts of “big and tall male apparel”, smoke at a higher rate than the population, and engage in outdoor activities and even like fishing.
Table II shows a product profile for a cat product. The highest z-score is “cat owner”. The buyers are also older, are interested in environmental issues, and give to charities.
One other embodiment is to display the product profile information in a manner called “key insights”. The Key insights section (the left hand column in
Such insights into the buyer population could be used to optimize the advertising program. For example, because the cat buyers are interested in environmental issues, the advertising creative could be modified to mention that the cat product is bio-degradable. Since the buyers like to give to charities, the advertiser might offer to donate 5% of proceeds to a charity such as an animal shelter.
A. Product Clusters and Segments for Ad Targeting (Optional)
The above steps create a single product centroid. It is also possible to create multiple clusters for use in ad targeting. One embodiment is to do this using unsupervised clustering such as K-Means algorithm.
Another embodiment is to utilize segments that have been pre-defined by the client, and then create a profile for each of those pre-defined segments. Examples of segments can include, but are not limited to, recently acquired customers, such as within the last three months, the top 10% of customers based upon dollar amount purchased, and the bottom 10% of customers based upon dollar amount purchased.
TABLE I | ||
DEMOGRAPHIC PRODUCT PROFILE FOR | ||
PROJECT 10023 (HANDYMAN PRODUCT). | ||
Variable | z-score | |
Woodworking | 0.588898 | |
AutoWork | 0.491806 | |
Automotive, AutoPartsandAccessories-SC | 0.48754 | |
SportsandLeisure-SC | 0.470066 | |
HomeImprovement-Do-It-Yourselfers | 0.447953 | |
Gardening | 0.438412 | |
Camping/Hiking | 0.43656 | |
Gardening-C | 0.429214 | |
HomeImprovement | 0.421209 | |
HomeandGarden | 0.417073 | |
SportsGrouping | 0.407583 | |
HomeImprovementGrouping | 0.39556 | |
AgeinTwo-YearIncrements-InputIndividualID | 0.392807 | |
DIYLiving | 0.392767 | |
Computers | 0.387011 | |
PCOwnerID | 0.386974 | |
OutdoorsGrouping | 0.385564 | |
TruckOwner | 0.369703 | |
CreditCardHolder-UnknownType | 0.369275 | |
BankCardHolder | 0.36921 | |
HomeFurnishings/Decorating | 0.365209 | |
Apparel-Men's-C | 0.362816 | |
Income-EstimatedHouseholdID | 0.360737 | |
Crafts | 0.357646 | |
Income-EstimatedHousehold-NarrowRangesID | 0.349372 | |
AgeinTwo-YearIncrements-1stIndividualID | 0.342792 | |
Fishing | 0.342675 | |
TABLE II | ||
DEMOGRAPHIC PRODUCT PROFILE FOR | ||
PROJECT 10019 (CAT PRODUCT). | ||
Variable | z-score | |
CatOwner | 0.72978 | |
OtherPetOwner | 0.507782 | |
AgeinTwo-YearIncrements-InputIndividualID | 0.497612 | |
AgeinTwo-YearIncrements-1stIndividualID | 0.470661 | |
Pets-SC | 0.460489 | |
Community/Charities | 0.382429 | |
CollectiblesandAntiquesGrouping | 0.382163 | |
Value-PricedGeneralMerchandise-SC | 0.380277 | |
Collectibles-General | 0.378843 | |
Gardening | 0.362677 | |
EnvironmentalIssues | 0.356035 | |
Gardening-C | 0.339698 | |
HomeImprovementGrouping | 0.339207 | |
HomeLiving | 0.334977 | |
SportsGrouping | 0.328068 | |
Cooking/FoodGrouping | 0.325231 | |
Movie/MusicGrouping | 0.32243 | |
HomeFurnishings/Decorating | 0.322362 | |
An alternative method for defining the product profile is to ask a user to “manually define” the profile that they would want to target. For example, they could specify that they would like to target:
In one embodiment, the user specifies these variables by defining the percentage above or below the “reference population” for this demographic. In the above example, the user specified interest in identifying media for people who are 50% higher than the population in terms of interest in diabetes.
Based on the above “manually defined” profile, these lift scores can now be translated back into product z-scores by setting: z=((diff+1)*mean)/stdev. The remainder of the matches to media then performs the same as described in the following sections.
Step 2: Create Media Profile
The next step is to create a demographic profile of television media assets. If the television media has customer viewership information it may already have demographics associated with it. In this case the “linkage” between the person and the media is a definite viewing event by that person.
In another embodiment, television media that is linked to buyers by way of a unique phone number or other device to tie the media to the person can be used. Linking keys can be any of a (a) telephone number, (b) URL, (c) offer, (d) cookie, or some other identifier in the advertisement that is uniquely associated with an advertisement on the media. When the customer uses the key to buy the product, that customer can be tied back to the unique broadcast where they saw the embedded linking key.
The system can create an average profile for customers that have been linked to each media. For every media Si Si,Dj is defined as the jth demographic of the media Si. Each media Si is equal to the sum of its constituent asset instances and the customers who were linked to those spots. Thus each media demographic profile is an average of the customer demographic vector who purchased from asset instances linked to the media. In one embodiment, the media demographic profile can be used to predict the demographic viewership of media assets.
An example of this kind of media demographic profile is shown in Table III. “Do It Yourself” (“DIY”) station watchers have interest in Woodworking, Hunting, Gardening, Sport and Leisure, tend to be male (Big and Tall Male apparel). They also own dogs and smoke at a higher rate than the rest of the population. Please note the significant similarity between DIY profile and that of the handyman tool product. This will be uses in the next step.
Table IV shows a television station profile for “Animal Planet”. The television audience for this station tends to be older, female, owns pets, and so on. There are a variety of traits also in common with the cat product.
TABLE III | ||
DEMOGRAPHIC PRODUCT BUYER PROFILE | ||
FOR DO IT YOURSELF CHANNEL | ||
Variable | z-score | |
Gender-InputIndividualID | −3.45 | |
Reading-FinancialNewsletterSubscribers | 3.21 | |
Apparel-Men's-BigandTall-C | 2.38 | |
Donation/Contribution-C | 1.97 | |
DogOwner | 1.62 | |
SeniorAdultinHouseholdID | 1.61 | |
Woodworking | 1.57 | |
Collectibles-Antiques | 1.54 | |
Hunting/Shooting | 1.52 | |
Gardening-C | 1.49 | |
Golf | 1.38 | |
SportsandLeisure-SC | 1.32 | |
OutdoorsGrouping | 1.29 | |
Arts | 1.19 | |
Smoking/Tobacco | 1.18 | |
TABLE IV | ||
DEMOGRAPHIC PRODUCT PROFILE | ||
FOR ANIMAL PLANET TV CHANNEL | ||
Variable | z-score | |
Gender-InputIndividualID | −3.08 | |
Pets-SC | 2.55 | |
CatOwner | 2.35 | |
Veteran | 2.30 | |
Donation/Contribution-C | 2.25 | |
Gardening-C | 2.23 | |
Collectibles-Antiques | 2.22 | |
OtherPetOwner | 2.15 | |
Woodworking | 2.14 | |
Apparel-Children's-C | 2.13 | |
History/Military | 2.09 | |
Apparel-Women's-C | 1.89 | |
PCOperatingSystemID | 1.83 | |
EnvironmentalIssues | 1.81 | |
In one embodiment, the media demographic profile can be reported as an index showing the proportion of demographics on each media asset. For example, the average income level of viewers of a particular television station is 50 percent above the average income level in the United States, and this can be indicated using an index.
In another embodiment, the media demographic profile can be reported as the population equivalent numbers of viewers on each media asset. For example, the number of viewers of a particular television station that is male and between the ages of 30 and 32 can be given as a percentage of the general population.
A. Calculate Media Profile Using Viewer Panel
An alternative method for calculating the media profile is to use a viewing panel demographics, and to summarize the profile based on the viewing panel. In one embodiment the viewing panel may make available their demographics, and may make available the media that they are watching throughout the day. As a result, it is now possible to summarize the media profile as the average of demographics of the panel viewers (an example is the Nielsen panel which maintains 5,000-25,000 customers and some demographics).
In another embodiment, the media profile is calculated using information obtained from unique set-top boxes that have been assigned television viewers to record the television viewing history of the viewers and using demographic information provided by the viewers (an example is Set top box data provided by a company such as Tivo and which has demographics appended via a company such as Acxiom).
As will be appreciated by those skilled in the art, there may be other techniques to monitor viewers' television viewing history and obtain demographic information from those viewers. A media profile can be calculated using these other techniques.
Step 4: Calculate Product-Television Station Similarity (Using Linked Buyer Records)
The disparity δ between the product and television station program can be calculated as below.
δ(pi,Dj,SiDj)=|pi,Dj−SiDj|
A. Basic Normalization for Calculation of Similarity
In measuring the disparity between spot and customer response demographics, it is necessary to appropriately scale the variables to maximize the effectiveness of the match. Demographic variables range from ordinal values in the tens (e.g. age ranges from 18 . . . 80) to “has children” which is a two-value binary variable, 0,1. If the variables aren't scaled then in an L1-distance calculation, the age variable would tend to exert up around 50× more “weight” on the distance match than gender. Yet gender may be just as valuable as age. Because of this, the system standardizes each disparity to z-scores. The transformation is
Z is the standardized discrepancy for demographic j. wj is a weight on demographic j which can be computed numerically by regression, or entered by a user to place more or less weight on the match between different demographics. D is the overall average weighted discrepancy between the demographics of product and media.
Each demographic is compared against the distribution of its disparities to determine whether it is high or low compared to the norm for disparity.
As a result, the system provides a similarity score, with the lower value indicating better similarity between the product and station demographics.
Table V shows the top list of stations that match the handyman product. ESPN, HGTV, DIY, HISTORY channel, Hallmark, which are all very similar stations.
TABLE V | ||
Closest Television Stations For Project | ||
10023 (HandyMan Tool Product) | ||
Project key | Station natural key | Similarity |
10023 | KL4 | −0.305 |
10023 | ESPNU | −0.302 |
10023 | HGTV | −0.300 |
10023 | DIY | −0.297 |
10023 | DG8 | −0.296 |
10023 | DISH_Network | −0.294 |
10023 | HALL | −0.293 |
10023 | HIST | −0.292 |
10023 | ESPN2_Local | −0.291 |
10023 | CRT5 | −0.288 |
B. Alternative Methods for Normalizing the Media Profile
In order to help reduce bias, the invention allows for the definition of different panels of persons as “reference populations” to create z-score parameters. For example, if customers were acquired through the web, then the appropriate means and standard deviations for these customers would be based on a large population of web users (typically web users are younger, higher income, etc). The product vector is then summarized using z-scores relative to the mean and standard deviation of the reference population. Similarly, customers acquired through television phone response should be compared to a large set of television phone responders; in general, these responders tend to be older. By comparing the customers to the appropriate reference population, the influence of the acquisition vehicle can be reduced.
The invention allows multiple “reference populations” to be maintained, and used for comparison—one particular embodiment includes an ecommerce panel (customers who are active on the web), DRTV panel (persons who have telephoned in response to a television ad), and 1% of US population panel (persons who are sampled to approximately 1% of US population).
Mapping Between Different Demographic Sources
In the above discussion, both customers who are linked to media, as well as product buying customers, are each enriched with the same set of demographics (eg. both might have Acxiom data enrichment). However, in some instances, product customer demographics and media asset demographics will originate from different sources. For example, customer records associated with linked buyers can be enriched with data obtained from a third party that provides consumer demographics, e.g. Acxiom, while media asset viewer demographics can be obtained from a viewing data provider, e.g., Tivo. With different demographics sources, a transform or demographic conversion can be used to convert the customer demographics into comparable media asset demographics, or vice versa.
In one embodiment this is implemented by creating (a) an aggregation layer which maps multiple source demographics and numerically transforms and then aggregates them based on parameters that that are set (eg. transform could just be a sum), and (b) a mapping table which maps the newly created aggregated variable from source 1 demographic to source 2 demographic (so that the appropriate “income>$120K” in source 1 maps to an appropriate “income>$120K” variable in source 2).
For example, in source 1 there may be the categories “age 18”, “age 19”, “age 20”, and these are aggregated to “age 18-20” using the mapping layer, and then mapped to an equivalent “age 18-20” variable that exists in the second demographic source. Using this method, profile vectors can be created using the aggregated/transformed demographic representation, and mapped one-to-one to media vectors in a second source that have also been transformed in this way.
Tables showing example mapping of variables from one demographic to another are shown in Table VI and Table VII. Table VI shows examples of demographic mapping from some Acxiom variables to some US Census variables (over 20 variables can be matched). The mapping between Acxiom variables to US Census variables is used to match product vector with 400 elements enriched by Acxiom data to US Census data.
Table VII shows an example mapping of some Acxiom variables to some Nielsen variables (about 10 variables match). The mapping between Acxiom variables to Nielsen variables is used to match Acxiom-enriched product demographic vector against Nielsen Media assets that have a limited number of variables available.
Using this mapping technique, match scores between products and Geographic areas including Direct Marketing Association areas, Television Cable Zones, Zip codes, States, and “Advertising Patches” (a unit that Lowes stores use) and other Geographic areas) can be calculated, allowing upcoming television airings in local areas to be targeted in part based on customer characteristics in their geographic area.
Also using this technique, match scores between the product and the Nielsen panel can be created, allowing the TV media that the Nielsen panelists watched to be appropriately scored, as another source of information about the media. The same technique can also be used for Set Top Box data such as that provided by Tivo—in this case, income, ethnicity, age, gender, and other variables can be mapped in the same way, allowing match scores to be created against Tivo-provided Media. These match scores can subsequently be combined to create an overall score for value of targeting some media asset in question.
TABLE VI | |||
Examples of Demographic Mapping Between Some | |||
Acxiom Variables and Some US Census Variables | |||
Acxiom Demographics | |||
Aggregator | Census | Acxiom Demographics Name | Value |
Age20to21 | TotalPopFemale20 | AgeinTwo-YearIncrements- | Age 20-21 |
InputIndividualDetail | |||
Age20to21 | TotalPopFemale21 | AgeinTwo-YearIncrements- | Age 20-21 |
InputIndividualDetail | |||
Age20to21 | TotalPopMale20 | AgeinTwo-YearIncrements- | Age 20-21 |
InputIndividualDetail | |||
Age20to21 | TotalPopMale21 | AgeinTwo-YearIncrements- | Age 20-21 |
InputIndividualDetail | |||
Age22to24 | TotalPopFemale22to24 | AgeinTwo-YearIncrements- | Age 22-23 |
InputIndividualDetail | |||
Age22to24 | TotalPopMale22to24 | AgeinTwo-YearIncrements- | Age 22-23 |
InputIndividualDetail | |||
Age22to24 | TotalPopFemale22to24 | AgeinTwo-YearIncrements- | Age 24-25 |
InputIndividualDetail | |||
Age22to24 | TotalPopMale22to24 | AgeinTwo-YearIncrements- | Age 24-25 |
InputIndividualDetail | |||
TABLE VII | |||
Example Demographic Mapping Between Some Acxiom | |||
Variables and Some Nielsen Variables | |||
EnrichedNielsen | EnrichedDemographics | NielsenDemographics | Demographics |
MappingID | Variable | Variable | Variable |
1 | africanamerican | Black18-65 | African American |
2 | male | MaleAdult | Adult Male |
3 | female | FemaleAdult | Adult Female |
4 | workingwoman | WorkingWomanAdult | Working Woman |
5 | child6to8 | C6-8 | Child 6-8 |
6 | child9to11 | C9-11 | Child 9-11 |
In the discussion above, the product vector was matched to the media asset vector. More details about the media asset will now be described. Media may be purchased in several forms—for example, a specific Television program such as “AC360”, a Rotator such as “CNN M-F 6 p-9 pm” or a broad station such as “CNN”, and Geographic-specific versions of the same such as “CNN Seattle”.
Using the upcoming media schedule, each of these “purchasable media grains” are applied to the schedule, and all feasible “purchasable media” are extracted and scored. These “purchasable media” are the media assets that are referred to throughout this disclosure.
Getting a Combined Media Asset Score from Multiple Media Asset Patterns
There's one further step that is required in order to produce a practical estimate of similarity. Each media asset itself is comprised of several different “features” which carries information about the ultimate performance of the particular media instance that is under consideration. For example, let's say that on the upcoming schedule, there is the program “AC360” on CNN next Monday at 7 pm, for a television viewer located in Seattle. Predicting the performance of this instance should be possible using information about the performance of: the station “CNN”; eg. higher income people tend to watch; the program “AC360”; television on “Mondays at 7 pm on any station”; eg. fewer old people percentage-wize watch during this time; television on “CNN on Mondays at 7 pm”; television on “CNN Monday 7 pm in Seattle”; the geographic area of “Seattle”; younger demographic exists in this area; the Rotation “CNN M-F 6 p-9 p”; the rotation “CNN 6 p-9 p”; and so on. Each of these features may convey information about the asset, as a “media asset pattern”. Examples of media asset patterns include distributor (station), program, genre, distributor-rotation, day of week-hour of day, day of week, hour of day, media market, state, state per capita, Direct Marketing Association customers per capita, Cable zone, and Cable zone customers per capita.
For each media asset, a similarity match is computed between the M media asset patterns that comprise the media asset, and the product. There are M similarity scores. The invention combines this evidence to create an overall score for the fitness of the upcoming airing. An example embodiment is as follows:
d(p,s)=sum i(w(i)*d(p,mediaassetpattern(s,i))) where i e[1 . . . M]
An example of combining media asset patterns is provided below for the case of trying to estimate the similarity of a rotator to the product. As discussed, a rotator comprises a wide variety of programming, times, and days, and as a result, the final estimate for similarity needs to blend all of these constituent components. For example, consider CNN “M-F 6 p-9 p”. Three programs each night might be covered by this rotator. The vector match is calculated based on all of the persons in that period and their demographics. Next, the similarity of “Program 1”, “Program 2”, “Program 3”, “CNN”, “CNN M-F”, and other media asset patterns, are each combined with weights to provide a final estimate of the similarity of this exact rotation instance which covers the above programming and patterns.
Tables VIII-XIV below show examples of different media asset patterns and correlation or similarity scores for an example product (handyman product):
TABLE VIII | |||
Program-level: Fox Nascar and similar programming | |||
shows a high correlation with the product | |||
purchasers of the handyman product. | |||
lookup key | Program | corr | |
P-1 | FOX NASCAR SPRINT PRE | 0.8358 | |
P-2 | NASCAR SERIES AT DOVER | 0.8357 | |
P-3 | FOX NASCAR SPRINT PRE SAT | 0.8241 | |
P-4 | FOX NASCAR SPRINT SAT PRE | 0.8103 | |
P-5 | FOX SPRINT CUP WNNRS CIRC | 0.8036 | |
P-6 | FOX NASCAR SPRNT SAT WNNR | 0.7996 | |
P-7 | FOX NASCAR SPRNT WNNR SAT | 0.7905 | |
P-8 | MASH M-F 2 | 0.7901 | |
P-9 | FOX SPRINT CUP PACE LAP | 0.7791 | |
P-10 | FOX NASCAR SPRINT CUP PST | 0.7787 | |
TABLE IX | |||
Genre level: Documentary and news programs score well | |||
lookup | Genre | Corr | |
Q-1 | DOCUMENTARY, GENERAL | 0.496117 | |
Q-2 | DOCUMENTARY, NEWS | 0.489461 | |
Q-3 | NEWS | 0.461017 | |
Q-4 | OFFICIAL POLICE | 0.443524 | |
TABLE X | |||
Station level: Media asset patterns TWC, Fox | |||
News, and History international score well | |||
lookup | Station | corr | |
S-1 | TWC | 0.683457 | |
S-2 | HI | 0.677207 | |
S-3 | FOXNC | 0.613114 | |
S-4 | CNBC | 0.603963 | |
S-5 | HLMC | 0.584917 | |
S-6 | HIST | 0.563381 | |
S-7 | DIY | 0.563147 | |
S-8 | IMG MEDIA | 0.54394 | |
S-9 | BBCA | 0.523207 | |
S-10 | NGC | 0.511578 | |
TABLE XI | |||||
Day of week: These persons are most heavily represented | |||||
in television media during Sunday. | |||||
Y | lookup | rownum | weekday | DOW | corr |
1 | Y-1 | 8575 | 1 | Sunday | 0.298701477 |
2 | Y-2 | 8576 | 3 | Tuesday | 0.270696067 |
3 | Y-3 | 8577 | 2 | Monday | 0.264775938 |
4 | Y-4 | 8578 | 6 | Friday | 0.257218758 |
5 | Y-5 | 8579 | 4 | Wednesday | 0.256585593 |
6 | Y-6 | 8580 | 5 | Thursday | 0.2562688 |
7 | Y-7 | 8581 | 7 | Saturday | 0.201279356 |
TABLE XII | ||||
Day-Hour: 6pm is a good time of day to target for these customers. | ||||
lookup | hour | corr | day-hour | |
a-1 | 1-18.0 | 0.45940398 | Sunday-18.0 | |
a-2 | 3-18.0 | 0.4507812 | Tuesday-18.0 | |
a-3 | 7-18.0 | 0.44892917 | Saturday-18.0 | |
a-4 | 5-18.0 | 0.43370198 | Thursday-18.0 | |
a-5 | 1-21.0 | 0.43338671 | Sunday-21.0 | |
a-6 | 2-18.0 | 0.43201616 | Monday-18.0 | |
a-7 | 6-21.0 | 0.42660428 | Friday-21.0 | |
a-8 | 7-21.0 | 0.42047077 | Saturday-21.0 | |
a-9 | 4-18.0 | 0.41009863 | Wednesday-18.0 | |
a-10 | 6-18.0 | 0.40573727 | Friday-18.0 | |
TABLE XIII | |||
Rotator: History international has rotators | |||
that match these customers well. | |||
lookup | hour | corr | |
zzz-1 | HI-Sa-Su + 9a-8p | 0.769536 | |
zzz-2 | HI-M-Su + 8p-12a | 0.760089 | |
zzz-3 | TWC-M-Su + 6a-9a | 0.746814 | |
zzz-4 | FOXNC-M-Su + 6a-9a | 0.728315 | |
zzz-5 | HI-M-F + 6p-8p | 0.714299 | |
zzz-6 | HI-M-F + 3p-6p | 0.708095 | |
zzz-7 | TWC-M-F + 3p-6p | 0.702081 | |
zzz-8 | TWC-Sa-Su + 9a-8p | 0.685666 | |
zzz-9 | TWC-M-F + 6p-8p | 0.683632 | |
zzz-10 | HI-M-F + 9a-3p | 0.667747 | |
TABLE XIV | |||
Direct Marketing Association Area (Geographic area): | |||
These persons are well-represented in rural areas. | |||
lookup | DMA | corr | |
zzzzzz-2 | BUTTE, MT | 0.348392 | |
zzzzzz-3 | NORTH PLATTE, NE | 0.325346 | |
zzzzzz-4 | MISSOULA, MT | 0.316646 | |
zzzzzz-5 | TWIN FALLS, ID | 0.316364 | |
zzzzzz-6 | Lincoln | 0.316109 | |
zzzzzz-7 | CHEYENNE, WY | 0.314863 | |
zzzzzz-8 | SPOKANE, WA | 0.313262 | |
zzzzzz-9 | BURLINGTON, VT-PQ | 0.309855 | |
zzzzzz-10 | HONOLULU, HI | 0.290508 | |
Similar to the preceding discussion, a demographic similarity based on viewer panel can be defined by dv(p,s) where dv is the demographic similarity, p is the product and s is the media.
Step 6: Calculate Contextual Product-Television Station Match
An additional aspect of the current invention is that it is able to utilize keywords to improve the match between the product and media asset. This is done by defining a set of words related to the advertising product, and also defining words related to the media. The match between these two sets of words is then calculated, and this forms an additional source of evidence regarding the quality of the media for targeting the product.
This is done using the following steps:
When the product has previously been run on television media (eg. “CNN-AC360-Tues-8 pm”) and the performance of that media is available, this information can be incorporated into the prediction for the fitness of the television media to the product. Historical product-television media performance is calculated as a function of the revenue and cost of the media from previous airings.
Historical product-television media performance data is extremely predictive, since if an ad performed well on a specific program and day-time such as “AC360” it will likely perform well on the same program day-time again. However, it is generally the case that historical data is very minimal, since only a tiny fraction of TV media can be directly sampled in this way. In addition, the method for being able to track revenue due to the program is often limited and may include phone numbers or vanity URLs attached to the advertisement, and so not all of the revenue associated with the ad may be tracked. As a result, while this is a useful technique, it is only part of the process for assessing the quality for an upcoming airing.
One specific embodiment that creates a Historical product-media performance estimate is as follows: Tables of historical data for StationPerformance(StationID,Cost,Revenue,Impressions,RevenuePerImpression,RevenuePerCost), Station DayPerformance(StationID,Day,Cost,Revenue,Impressions,RevenuePerImpression, RevenuePerCost), StationDayHourPerformance(StationID,Day,Hour, Cost,Revenue,Impressions,RevenuePerImpression,RevenuePerCost), and ProgramPerformance(ProgramID,Cost,Revenue,Impressions,RevenuePerImpression,Rev enueperCost)
are created, where each time a particular media asset is used for advertising, the results are recorded into the tables above. This is summarized to create average revenue per impression for each program, station, station-day, etc. For any new upcoming airing, a prediction of performance based on the historical performance of the ad in this same spot can be created as:
HistoricalRevenuePerImpressionPrediction=a1*historicalStationRevenuePerImpression+a2*StationProgramRevenuePerImpression+a3*StationDayRevenuePerImpression+a4*StationDayHourRevenuePerImpression+a5
The total impressions for any upcoming spot are estimated separately by using Nielsen rated data or Set top box data using the same summary table method (eg. StationDayHourImpressions, StationImpressions, etc), and then the performance for any upcoming spot is estimated as:
HistoricalRevenuePrediction=b1*ImpressionPrediction*HistoricalrevenuePerImpressionPrediction
TABLE VIII | |||||
TF-IDF SCORES FOR KEYWORDS ON | |||||
THE FUSE TELEVISION STATION | |||||
call- | Term | Word | Total | ||
letters | Word | frequency | occurrences | occurrences | tfidf |
FUSE | Superstars | 41 | 4 | 321505 | 3295426 |
FUSE | Missy | 23 | 5 | 321505 | 1478923 |
FUSE | Gaga | 23 | 5 | 321505 | 1478923 |
FUSE | Cent | 23 | 6 | 321505 | 1232436 |
FUSE | Jay-Z | 23 | 8 | 321505 | 924326.9 |
FUSE | Elliott | 23 | 11 | 321505 | 672237.7 |
FUSE | Shakur | 4 | 3 | 321505 | 428673.4 |
FUSE | Tupac | 4 | 3 | 321505 | 428673.4 |
Step 8: Estimate Cost and CPM
An important part of the fitness of a particular media asset is its cost and cost per thousand impressions (CPM). Ideally these will be low. The Cost and CPM estimates for upcoming media can be generated in several ways:
1. Quoted costs and CPM as provided by media publishers: For example television stations can list the cost and CPM rate for their different programs, rotations, and days of the week. These quoted costs may be (a) available electronically in which case they are collected, (b) available after inquiring with the publisher.
2. Estimated costs and CPM: Quoted costs and CPMs may not always be freely available for all media assets, and it may be too costly to contact all publishers. As a result an estimate may be used to “fill in” costs and CPM for as many media assets as possible to identify which ones to potentially narrow in on and purchase. In order to create these estimates, a variety of data providers maintain historical data on costs and CPMs for different media placements. In addition, the advertiser may also have purchased media before, and these costs and CPMs are also available. These can be used to forecast the future costs and CPMs. A method that can be used for forecasting cost and CPM is similar to that described in Step 7, which is to define the following summary tables:
StationPerformance(StationID,Cost,Revenue,Impressions,RevenuePerImpression,RevenuePerCost),
StationDayPerformance(StationID,Day,Cost,Revenue,Impressions,RevenuePerImpression,RevenuePerCost),
StationDayHourPerformance(StationID,Day,Hour,Cost,Revenue,Impressions,RevenuePerImpression,RevenuePerCost), and
ProgramPerformance(ProgramID,Cost,Revenue,Impressions,RevenuePerImpression,RevenueperCost).
Each time a particular media asset is used for advertising, the results are recorded into these tables. Historical data is also collected from data providers who monitor CPM and Costs of media. This is summarized to create average cost per impression and cost for each program, station, station-day, etc. For any new upcoming airing, a prediction of performance can be created based on the historical performance of the ad in this same spot as:
HistoricalCostPerImpressionPrediction(s)=c1*historicalStationCostPerImpression(s)+c2*StationProgramCostPerImpression(s)+c3*StationDayCostPerImpression(s)+c4*StationDayHourCostPerImpression(s)+c5
CPM(s)=1000*HistoricalCostPerImpressionPrediction(s)
Cost(s)=HistoricalCostPerImpressionPrediction(s)*historicalImpressionPrediction(s)
Step 9: Purchase Television Media Using Similarity
In order to purchase media, a media buyer would purchase media with a high fitness score, where fitness is defined below:
Fitness(p,s)=f(d(p,s),Cost(s),CPM(s),historicalImpressionPrediction(s),historicalRevenuePrediction(p,s),ContextualMatch(p,s),dv(p,s)),
where p is the product, s is the media asset, d(p,s) is the demographic similarity between the product and media, Cost(s) is the cost of the media, CPM(s) is the cost per thousand impressions of the media, historicalRevenuePRediction(p,s) is the predicted revenue of the product were it to be advertised in the media s, ContextualMatch(p,s) is the word vector match between the product and media, and dv(p,s) is the demographic similarity of a viewer panel.
A. Purchase Using Target Impressions and Target CPM
A specific embodiment of the current invention is using a metric defined as “target CPM” (tCPM) in order to produce an effective targeted media buy. This is a fitness function as defined above, but with some specific selections around the function form. This is defined as follows:
The quantity dv(p,s)*HistoricalImpressionPrediction(s) provides a measure of wthe percentage of the sqrt(variance) in the product vector accounted for by this media asset (ignoring negative correlations). The tool can now sort the media in order of tCPM since this corresponds to media with the best value per dollar.
B. Purchase Using Percent of Budget
Another specific embodiment of the current invention in terms of purchasing media, is to define a “percent of budget” that should be ideally allocated to a set of media assets. This is a fitness function as defined above, but with some specific selections around the function form. This is defined as follows:
Fitness(p,s)=tCPM(p,s)/SumS(tCPM(p,S))
C. Purchase Using Cluster Multi-Targeting:
One other specific embodiment to purchase media is what called “cluster multi-targeting”. If the overall product profile (the average) were targeted, the result may be a targeted profile that either has very few customers behind it, or which favors one cluster over the others. For example, male, high-income programming might be favored, but there are actually clusters including females which won't be addressed.
In one embodiment to purchase media, all of the clusters can be targeted simultaneously by aggregating the underlying segments together to form an overall tratio and timp based on the quality of the match for each segment. This can be done as follows.
Fitness(p,s)=cost(s)/timp(p,s)′,
where
Timp(p,s)′=Sum over c (timp(p,s)*membership % (c))
Imp(p,s)′=Sum over c (imp(p,s)*membership % (c))
Tratio(p,s)′=timp(p,s)/imp(p,s).
In another embodiment, the system first sorts by cluster, tcpm and assigns a rank-within-cluster, so that the results for cluster 1 have rank 1 . . . . R, and the results for cluster 2 also have ranks 1 . . . R. The system then sorts again by rank alone, so that the top results for cluster 1, 2, and 3 are grouped together, and then the second best for 1, 2, 3, and so on. The result is that the system simultaneously targets all clusters.
D. Purchase Using Revenue Estimate
Another specific embodiment is to purchase media based on its estimated revenue prediction. This is a fitness function as defined above, but where the fitness function parameters were estimated to minimize the squared error between predicted revenue and actual revenue produced by the media.
min(Fitness(p,s)−Revenue(p,s))^2
E. Purchase Using ROI Optimization
Another specific embodiment is for the system to select media to purchase based on the following constraints:
max Revenue subject to PredictedRevenue/Cost>minROI and PredictedCost<=Budget
The algorithm for solving the above optimization problem is as follows:
Repeat steps 2 through 6 below until PredictedRevenue/PredictedCost>ROAS or PredictedCost>Budget
Another embodiment is to provide a list of recommended media. The user may then accept/reject or edit the list of recommended media. Secondly, if the user has given the system the authority to do so, the system may proceed and purchase the media on its own.
Reasons for Recommending Media Assets
Rather than just present a set of media assets to potentially purchase with fitness score alone, the system can also provide the reason certain media assets are being suggested. When prompted by the user, the system will do the following: list the N components of the covariance matrix between p and s which have the highest magnitude, ie. show the set of demographic attributes
{i}:largest N from |p(i)*s(i)|
Intuitively these components exerted the greatest influence in driving the match score, and so are the “reasons” why the media was selected. Table XV shows an example of the program feature that provides reasons for explaining why certain programming was recommended. The product in this case was the handyman tool product. The product was only matched on a small number of variables, but it shows the reason why each program was selected—for example, the top match “FOX NASCAR SPRINT PRE” was recommended because this has a strong positive match with the product on the demographic “perHH-P55-64” or persons aged 55-64. For a 400-variable match, this feature would be even more useful. Using this feature, users can uncover why a certain media asset was recommended, obtain more confidence in why the media is being recommended, and they can decide if they agree with the recommendation or would like to change it.
TABLE XV | ||||
REASONS CERTAIN MEDIA ASSETS ARE | ||||
RECOMMENDED FOR ADVERTISING | ||||
lookup | ||||
key | Program | Corr | why | cov |
P-1 | FOX NASCAR SPRINT PRE | 0.8358 | perHH-P55-64 | 0.3385818 |
P-2 | NASCAR SERIES AT DOVER | 0.8357 | perHH-P55-64 | 0.5546946 |
P-3 | FOX NASCAR SPRINT PRE SAT | 0.8241 | perHH-P55-64 | 0.4557614 |
P-4 | FOX NASCAR SPRINT SAT PRE | 0.8103 | perHH-P55-64 | 0.4509219 |
P-5 | FOX SPRINT CUP WNNRS CIRC | 0.8036 | perHH-MaleAdult | 0.3706025 |
P-6 | FOX NASCAR SPRNT SAT WNNR | 0.7996 | perHH-P55-64 | 0.3920339 |
P-7 | FOX NASCAR SPRNT WNNR SAT | 0.7905 | perHH-P55-64 | 0.4054008 |
P-8 | MASH M-F 2 | 0.7901 | perHH-P55-64 | 0.5861894 |
P-9 | FOX SPRINT CUP PACE LAP | 0.7791 | perHH-MaleAdult | 0.4735653 |
P-10 | FOX NASCAR SPRINT CUP PST | 0.7787 | perHH-P55-64 | 0.1984156 |
Table XVI below shows the final set of television airings that the system is recommending buying. This is based on scanning the upcoming television guide (as described in the data feed setup), and assigning a fitness score to each upcoming airing, and then presenting the programs in order of fitness:
TABLE XVI | |||||||||||
EXAMPLES OF TELEVISION AIRINGS RECOMMENDED BY THE SYSTEM FOR PURCHASE | |||||||||||
Rota- | Day | Day of | Hour of | ||||||||
Fitness | Sta- | Station | Start | tion | of | Week | Hour of | Day | |||
Score | Program | tion | Score | Date | End Date | Rotation | Score | Week | Score | Day | Score |
0.6419 | Ritmo | Aug. 14, 2011 | Aug. 14, 2011 | Sa + Su + | Sun | 0.5575 | 3-6 PM | (0.4558) | |||
Deportivo | 4:30 PM | 5:00 PM | 9a + 8p | ||||||||
0.6419 | Ritmo | Aug. 21, 2011 | Aug. 21, 2011 | Sa + Su + | Sun | 0.5575 | 3-6 PM | (0.4558) | |||
Deportivo | 4:30 PM | 5:00 PM | 9a + 8p | ||||||||
0.6262 | Descontrol | Aug. 13, 2011 | Aug. 13, 2011 | Sa + Su + | Sat | 0.3124 | 3-6 PM | (0.4558) | |||
5:00 PM | 6:00 PM | 9a + 8p | |||||||||
0.6262 | Descontrol | Aug. 20, 2011 | Aug. 20, 2011 | Sa + Su + | Sat | 0.3124 | 3-6 PM | (0.4558) | |||
5:00 PM | 6:00 PM | 9a + 8p | |||||||||
0.6239 | Entourage | Aug. 16, 2011 | Aug. 16, 2011 | M + Su + | Tue | (0.2831) | 3-6 AM | 0.4971 | |||
4:30 AM | 5:00 AM | 12a + 6a | |||||||||
0.6239 | Entourage | Aug. 13, 2011 | Aug. 13, 2011 | M + Su + | Sat | 0.3124 | 3-6 AM | 0.4971 | |||
4:30 AM | 5:00 AM | 12a + 6a | |||||||||
0.6239 | Entourage | Aug. 12, 2011 | Aug. 12, 2011 | M + Su + | Fri | (0.6910) | 3-6 AM | 0.4971 | |||
4:30 AM | 5:00 AM | 12a + 6a | |||||||||
0.6239 | Entourage | Aug. 17, 2011 | Aug. 17, 2011 | M + Su + | Wed | (0.4429) | 3-6 AM | 0.4971 | |||
4:30 AM | 5:00 AM | 12a + 6a | |||||||||
0.6239 | Entourage | Aug. 19, 2011 | Aug. 19, 2011 | M + Su + | Fri | (0.6910) | 3-6 AM | 0.4971 | |||
4:30 AM | 5:00 AM | 12a + 6a | |||||||||
0.6239 | Entourage | Aug. 25, 2011 | Aug. 25, 2011 | M + Su + | Thu | (0.4277) | 3-6 AM | 0.4971 | |||
4:30 AM | 5:00 AM | 12a + 6a | |||||||||
Example of Media Buying using Product-Spot Similarity
A company looking for maximum performance could achieve even better results however. It could restrict its media campaign to only the most similar television stations to the product. If this strategy is pursued, in one scenario, similarities <−0.20 can be used. In this case a 7.3× performance gain might be achieved in terms of orders per spot. At this significantly higher performance, 36% of the media budget can be spent on this higher performing inventory. This is still a very high amount of spend, given that the television assets are so much higher performing.
An example of media buying would be to
1. Determine the desired Media Efficiency Ratio (revenue/cost ratio)
2. Look up Table XVII for the desired MER, and read-off the similarity threshold.
3. Buy all media assets that have this similarity or better.
TABLE XVII | ||||||
SIMILARITY THRESHOLD VS ADVERTISING PERFORMANCE | ||||||
Cost | | ||||||
p-value | similarity < | |||||
mean(orders) | | mean(orders) | | orders | n | | Ratio of | d (prop | |
d | similarity < d | similarity > d | (Wilcoxon) | similarity < d | means | of total) |
−0.2646 | 2.475 | 0.2581 | 0.0986 | 2 | 9.59 | 0.24 |
−0.2469 | 1.8167 | 0.2488 | 0.0534 | 3 | 7.30 | 0.37 |
−0.1764 | 1.6958 | 0.2054 | 0.0105 | 4 | 8.26 | 0.44 |
−0.1651 | 1.3567 | 0.2139 | 0.0678 | 5 | 6.34 | 0.45 |
−0.1313 | 1.1722 | 0.2124 | 0.0785 | 6 | 5.52 | 0.53 |
−0.1267 | 1.0966 | 0.1928 | 0.0246 | 7 | 5.69 | 0.53 |
−0.1035 | 1.022 | 0.1782 | 0.0114 | 8 | 5.74 | 0.53 |
−0.0988 | 0.9202 | 0.1818 | 0.0189 | 9 | 5.06 | 0.59 |
−0.0682 | 0.8281 | 0.1914 | 0.0601 | 10 | 4.33 | 0.60 |
−0.0153 | 0.7529 | 0.202 | 0.1484 | 11 | 3.73 | 0.65 |
0.0069 | 0.7214 | 0.1918 | 0.1079 | 12 | 3.76 | 0.67 |
0.0097 | 0.6902 | 0.1841 | 0.0839 | 13 | 3.75 | 0.69 |
0.0099 | 0.6409 | 0.1964 | 0.1817 | 14 | 3.26 | 0.75 |
0.0192 | 0.6297 | 0.1766 | 0.108 | 15 | 3.57 | 0.76 |
0.0208 | 0.6008 | 0.1773 | 0.1063 | 16 | 3.39 | 0.79 |
0.0219 | 0.5654 | 0.1921 | 0.2149 | 17 | 2.94 | 0.82 |
0.0238 | 0.542 | 0.1966 | 0.2254 | 18 | 2.76 | 0.82 |
0.0265 | 0.5134 | 0.2162 | 0.4049 | 19 | 2.37 | 0.84 |
0.0298 | 0.4878 | 0.2403 | 0.6599 | 20 | 2.03 | 0.84 |
0.034 | 0.4645 | 0.2703 | 0.9798 | 21 | 1.72 | 0.84 |
0.0389 | 0.4434 | 0.3089 | 0.7113 | 22 | 1.44 | 0.84 |
0.0432 | 0.4467 | 0.274 | 0.9555 | 23 | 1.63 | 0.87 |
0.0639 | 0.4409 | 0.2672 | 0.8574 | 24 | 1.65 | 0.87 |
0.065 | 0.4233 | 0.334 | 0.7678 | 25 | 1.27 | 0.90 |
0.0756 | 0.407 | 0.4454 | 0.3342 | 26 | 0.91 | 0.90 |
0.0833 | 0.3919 | 0.6681 | 0.0549 | 27 | 0.59 | 0.95 |
Because there are so many different variables that can be used to build a fitness model, a model management infrastructure can be useful. The management infrastructure assigns a unique model identification code to each fitness model. The estimates for a particular fitness model can be tested against other models to determine which model performs better.
Fitness predictions can be recorded in a schema as FitnessPredictionProduction (ProjectKey, MediaInstanceID, Date, Time, MediaAssetID, Score) tuples. This representation is used to avoid moving code during a new fitness model release.
A second area—a modeling schema—is maintained where predictions are generated, and simultaneously flight multiple fitness models. The code in this area may not meet the same standard as for the production system. The code is available to analysts and can be modified in order to develop new models.
In this schema results are written as FitnessPrediction (ProjectKey, MediaInstanceID, Date, Time, MediaAssetID, ModelID, Score). Another table, FitnessModel (modelid, Description) keeps track of the fitness model that has been enabled for each project.
The production system performs two steps. First, it runs a default fitness model in production which populates a set of Fitness predictions. This code is designed to be reliable and is changed on a slower time-scale. Next, it then joins to the underlying FitnessPrediction table to retrieve model results. If model results are available in the proper format it will retrieve these results and use them in production. Every day FitnessPrediction is archived in a FitnessPredictionHistory table to ensure that model results can be tracked over time.
In the modeling schema area, it is possible to run multiple models in parallel, record their predictions, preview different models prior to release, and so on.
As a result of this architecture, releasing a new fitness model can be achieved without moving any code into the production system—keeping it safe and appropriately isolated while still allowing rapid iteration on models through a controlled interface. Eventually the new models should be migrated to become the new default model in production, however operationally new models can be deployed and used in production for extended periods of time, and then productized when needed. This increases reliability and model release speed and simultaneously supports prototyping and model development which occurs in parallel with the production model.
Examples of Results Provided by an Automated Program Finder
An automated program finder, details of which are shown in block 110 shown of
The result also includes a sortable list of suggested programs. The list is sortable in order of targeting ratio (tratio) which is the most relevant programming or the programming with the closest vector match. The list is also sortable in order of target cost per thousand impressions (tCPM) which is the media with the best target impressions per dollar spent. Media buyers typically buy based upon tCPM. The list can also be sorted by revenue estimate (not shown).
Unless the context clearly requires otherwise, throughout the description and the claims, the words “comprise,” “comprising,” and the like are to be construed in an inclusive sense, as opposed to an exclusive or exhaustive sense; that is to say, in the sense of “including, but not limited to.” As used herein, the terms “connected,” “coupled,” or any variant thereof means any connection or coupling, either direct or indirect, between two or more elements; the coupling or connection between the elements can be physical, logical, or a combination thereof. Additionally, the words “herein,” “above,” “below,” and words of similar import, when used in this application, refer to this application as a whole and not to any particular portions of this application. Where the context permits, words in the above Detailed Description using the singular or plural number may also include the plural or singular number respectively. The word “or,” in reference to a list of two or more items, covers all of the following interpretations of the word: any of the items in the list, all of the items in the list, and any combination of the items in the list.
The above Detailed Description of examples of the invention is not intended to be exhaustive or to limit the invention to the precise form disclosed above. While specific examples for the invention are described above for illustrative purposes, various equivalent modifications are possible within the scope of the invention, as those skilled in the relevant art will recognize. For example, while processes or blocks are presented in a given order, alternative implementations may perform routines having steps, or employ systems having blocks, in a different order, and some processes or blocks may be deleted, moved, added, subdivided, combined, and/or modified to provide alternative or subcombinations. Each of these processes or blocks may be implemented in a variety of different ways. Also, while processes or blocks are at times shown as being performed in series, these processes or blocks may instead be performed or implemented in parallel, or may be performed at different times. Further any specific numbers noted herein are only examples: alternative implementations may employ differing values or ranges.
The teachings of the invention provided herein can be applied to other systems, not necessarily the system described above. The elements and acts of the various examples described above can be combined to provide further implementations of the invention. Some alternative implementations of the invention may include not only additional elements to those implementations noted above, but also may include fewer elements.
Any patents and applications and other references noted above, including any that may be listed in accompanying filing papers, are incorporated herein by reference. Aspects of the invention can be modified, if necessary, to employ the systems, functions, and concepts of the various references described above to provide yet further implementations of the invention.
These and other changes can be made to the invention in light of the above Detailed Description. While the above description describes certain examples of the invention, and describes the best mode contemplated, no matter how detailed the above appears in text, the invention can be practiced in many ways. Details of the system may vary considerably in its specific implementation, while still being encompassed by the invention disclosed herein. As noted above, particular terminology used when describing certain features or aspects of the invention should not be taken to imply that the terminology is being redefined herein to be restricted to any specific characteristics, features, or aspects of the invention with which that terminology is associated. In general, the terms used in the following claims should not be construed to limit the invention to the specific examples disclosed in the specification, unless the above Detailed Description section explicitly defines such terms. Accordingly, the actual scope of the invention encompasses not only the disclosed examples, but also all equivalent ways of practicing or implementing the invention.
Burdick, Brian, Kitts, Brendan, Au, Dyng, Roberts, Tyson
Patent | Priority | Assignee | Title |
11979623, | Dec 02 2020 | DISCOVERY COMMUNICATIONS, LLC | Systems and methods for predicting television viewership patterns for advanced consumer segments |
Patent | Priority | Assignee | Title |
6286005, | Mar 11 1998 | NIELSEN COMPANY US , LLC , THE | Method and apparatus for analyzing data and advertising optimization |
8046797, | Jan 09 2001 | THOMSON LICENSING, S A S | System, method, and software application for targeted advertising via behavioral model clustering, and preference programming based on behavioral model clusters |
8046798, | Jan 11 2001 | Prime Research Alliance E, Inc. | Profiling and identification of television viewers |
8352980, | Feb 15 2007 | SBC KNOWLEDGE VENTURES, L P | System and method for single sign on targeted advertising |
20030101451, | |||
20080201731, | |||
20080235008, | |||
20090030780, | |||
20090144801, | |||
20100231239, | |||
20110040616, | |||
20110231243, | |||
20110246267, | |||
20110295680, | |||
20110307326, | |||
20120046996, | |||
20120185899, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Aug 12 2011 | Lucid Commerce, Inc. | (assignment on the face of the patent) | ||||
Oct 02 2011 | KITTS, BRENDAN | LUCID COMMERCE, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 027089 | 0147 | |
Oct 06 2011 | AU, DYNG | LUCID COMMERCE, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 027089 | 0147 | |
Oct 06 2011 | BURDICK, BRIAN | LUCID COMMERCE, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 027089 | 0147 | |
Oct 10 2011 | ROBERTS, TYSON | LUCID COMMERCE, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 027089 | 0147 | |
Jun 30 2014 | LUCID COMMERCE, INC | JPMORGAN CHASE BANK, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST | 033360 | 0157 | |
Jun 30 2014 | CONVERTRO, INC | JPMORGAN CHASE BANK, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST | 033360 | 0157 | |
Apr 30 2015 | LUCID COMMERCE, INC | LUCID COMMERCE LLC | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 036723 | 0112 | |
Jun 23 2015 | JPMORGAN CHASE BANK, N A | LUCID COMMERCE, INC | RELEASE OF SECURITY INTEREST IN PATENT RIGHTS -RELEASE OF 033360 0157 | 036041 | 0969 | |
Jun 23 2015 | JPMORGAN CHASE BANK, N A | CONVERTRO, INC | RELEASE OF SECURITY INTEREST IN PATENT RIGHTS -RELEASE OF 033360 0157 | 036041 | 0969 | |
Sep 22 2015 | LUCID COMMERCE LLC | ADAP TV, INC | MERGER SEE DOCUMENT FOR DETAILS | 036693 | 0966 |
Date | Maintenance Fee Events |
Aug 07 2014 | ASPN: Payor Number Assigned. |
Aug 07 2014 | STOL: Pat Hldr no Longer Claims Small Ent Stat |
Jan 22 2018 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Jan 05 2022 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Date | Maintenance Schedule |
Jul 22 2017 | 4 years fee payment window open |
Jan 22 2018 | 6 months grace period start (w surcharge) |
Jul 22 2018 | patent expiry (for year 4) |
Jul 22 2020 | 2 years to revive unintentionally abandoned end. (for year 4) |
Jul 22 2021 | 8 years fee payment window open |
Jan 22 2022 | 6 months grace period start (w surcharge) |
Jul 22 2022 | patent expiry (for year 8) |
Jul 22 2024 | 2 years to revive unintentionally abandoned end. (for year 8) |
Jul 22 2025 | 12 years fee payment window open |
Jan 22 2026 | 6 months grace period start (w surcharge) |
Jul 22 2026 | patent expiry (for year 12) |
Jul 22 2028 | 2 years to revive unintentionally abandoned end. (for year 12) |