[go: up one dir, main page]

HK40059301A - Tracking pixels and cookies for television event viewing - Google Patents

Tracking pixels and cookies for television event viewing Download PDF

Info

Publication number
HK40059301A
HK40059301A HK42022050505.1A HK42022050505A HK40059301A HK 40059301 A HK40059301 A HK 40059301A HK 42022050505 A HK42022050505 A HK 42022050505A HK 40059301 A HK40059301 A HK 40059301A
Authority
HK
Hong Kong
Prior art keywords
context
dependent application
fingerprint
television
server
Prior art date
Application number
HK42022050505.1A
Other languages
Chinese (zh)
Other versions
HK40059301B (en
Inventor
泽埃夫·诺伊迈尔
小迈克尔·柯莱特
里奥·W·豪迪
Original Assignee
构造数据有限责任公司
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 构造数据有限责任公司 filed Critical 构造数据有限责任公司
Publication of HK40059301A publication Critical patent/HK40059301A/en
Publication of HK40059301B publication Critical patent/HK40059301B/en

Links

Description

Tracking pixels and COOKIE for television event viewing
The application is a divisional application of an invention patent application with the application date of 2014, 12 and 23, international application numbers of PCT/US2014/072255 and national application number of 201480070447.4, and the invention name of 'tracking pixels and COOKIE for watching television events'.
Related patent application
This application claims priority and benefit from U.S. provisional application No. 61/920,086 filed on 23/12/2013.
Background
The traditional Television (TV) viewing experience and the way video media is obtained over the internet has been confluent for some time and now becomes interdependent. Both forms of media delivery have experienced a monthly subscription fee and a pay-per-view revenue model for many years as a business model, but the advertising support model for both remains the dominant economic engine.
Financial support from advertisers is typically based on the number of viewers exposed to an advertisement, which advertisers charge per thousand "impressions" or times an advertisement is viewed, commonly referred to as "cost of thousand" or "CPM". Generally, a higher CPM rate is charged for advertisements that may provide additional detailed information about these individual impressions, such as the time of day the advertisement was viewed or the market area in which the viewing occurred. Correlating these impressions with demographic information about those viewing the advertisement is even more valuable, particularly when the demographic information is that the advertiser believes to provide better prospects for positive actions about the product or service being promoted.
For content accessed by a personal computer or any other type of internet-connected device, the viewer's internet browsing activity can be easily detected and captured through a variety of techniques. The most common technique is to use a "cookie," also known as an HTTP cookie, a web page cookie, or a browser cookie. This is a small data file sent from the website being browsed to the user's browser. Each time the website is reloaded, the browser then sends a cookie back to the server so that the server can be aware of the user's previous activity on the server. This approach allows the "shopping cart" to hold earlier, incomplete purchases and pre-authenticate the user so that they do not need to re-enter some identity verification.
Cookies are also used to build a history of previous browsing. This information is advantageously used to allow presentation of commercial offers that are more likely to be of interest to the user than any layout. For example, browsing in Philadelphia searches an engine such as Google for many websites that a user, such as "Hotels in Seattle," would find subsequently browsing would show advertisements for Seattle travel, entertainment, local attractions, and other customized service offers. This is a result of some data about the search activity being stored locally on the user's computer in the form of a data cookie.
Another common technique takes advantage of the fact that most commercial web pages are not completely self-contained. For a variety of technical and business reasons, many of the elements seen on a displayed web page are instead combined by using content "in the flight" downloaded from many different servers that are typically geographically dispersed. Thus, when initially downloaded, the screen locations where certain pictures, animations or advertisements can be displayed are typically effectively blank, but contain program instructions, most commonly in the HTML or JavaScript language, that make a request or "call" to the server where the desired content is located.
These requests typically include the IP address of the requesting computer, the time the content was requested, the type of web browser that issued the request, the nature of the display on which the content is displayed, and other details. In addition to acting on the request and serving the requested content, the server may store all of this information and associate it with a unique tracking token (sometimes in the form of a browser cookie), which is relevant to the content request.
This same technique can be used to gain insight into the behavior and habits of those browsing websites, which can then be used to personalize the type of advertisements served to the user, even in cases where the web page does not require additional content to complete the user's browsing experience. This can be done by: the web page is programmed with invisible (not shown) graphic files called "tracking pixels" to request the graphic files from a particular server. These are (usually) very small image files (GIF, JPEG, PNG, etc.) whose internet addresses are put into web pages and other HTML files. When a particular web page containing these tracking pixels is loaded, the web browser then sends a request, typically over the internet, to a server at the address of the embedded web graphic. The server at that address sends the requested graphics file (e.g., tracking pixels) and records the event of the request for the particular graphics. These tracking pixel files are sometimes referred to by other names such as web bugs, transparent pixels, tracking bugs, pixel tags, web beacons, or clean figure files. Regardless of how the token images are called, their functions are substantially the same.
In many commercial applications, an advertiser or its agent or other third party service may decide to track an impression with tracking pixels (as described above, an impression includes a person viewing a piece of information). Each time an advertisement is displayed, code in the displayed web page addresses, either locally or via the internet, a server containing the tracking pixels. The server responding to the request then records information that may include the user's IP address, host name, device type, screen size, operating system, web browser, and date the image was viewed.
In traditional TV viewing, commercial ratings data is typically collected and analyzed offline by media search companies, such as the Nielsen Company, through the use of specialized equipment, sometimes referred to as "home units," that the search Company places on connection with the television sets of a limited number of selected homes. These devices record when the television is tuned to a particular channel, however, there is currently an unmet need for reliable techniques to detect whether a viewer actually views a particular video segment (either broadcast content or an advertisement). At the same time, there is still no truly reliable process to confirm whether and when broadcast content that has been recorded and stored on a DVR or the like is viewed at some later time.
In addition, with existing monitoring services such as Nielsen, there is a material delay between the time a program is aired and the availability of reliable, widely sampled information about which programs are watched in which markets and which demographics are available to content providers or advertisers. How effective such predictions are when extrapolating predictions for the entire united states from this small sample of potential viewers (estimated about 1 in every ten thousand households) is a significant controversial problem.
Thus, the ability to accurately determine in near real time what television programs or advertisements each U.S. television viewer is watching at any time has been an unmet market need. This has been a challenge because it may be desirable to be able to identify not only what channel has been tuned to, but specifically what content is being viewed, since the media that the viewer is actually consuming may include not only scheduled programs, but also locally or locally inserted advertisements, time-staggered content, or other entertainment products.
Some attempts have been made to map content heard on a home television to a database of "audio fingerprints" using audio matching techniques. This is the process of attempting to match audio fingerprints to some specific content. It has been found that there are limitations to the speed and reliability of this technology that has been on the market to date. Screen images are more computationally difficult than using audio for video matching of known content, but are theoretically more accurate and useful. Matching a video segment being viewed with a database of samples (including samples taken just a few seconds ago from an online television event) has presented a number of technical challenges, but has been effectively adopted and taught, inter alia, in U.S. patent No. 8,595,781.
Disclosure of Invention
The subject matter disclosed in detail below relates to a real-time content identification and tracking system that allows monitoring of television program consumption for individual television sets or other viewing devices. The metrics collected may include data about viewing specific broadcast media, commercial messages, interactive on-screen information or other programs, and locally cached time-staggered programs. Information regarding the media consumption of these particular televisions or other viewing devices may be returned to the business clients of the system through a trusted third party intermediary service, and in some embodiments, the encoded tokens may be used to manage the display of certain events and allow for robust auditing of each interested party's contract fulfillment.
More specifically, the systems and methods disclosed herein allow for identifying a video segment being viewed or identifying interactive messages displayed on a video screen of any connected television viewing device, such as a smart television, a television with a cable set-top box, or a television with an internet-based set-top box. Furthermore, this video segment identification system accurately identifies whether a video segment is being aired, prerecorded, or commercial message, while incorporating this capability into an all-in-one system, allowing a variety of new products and services to be offered to commercial clients in a number of ways similar to the tracking functions provided over the internet using so-called COOKIE and media consumption tracking pixels. Various embodiments of the systems and methods are described in detail below from a commercial utility perspective.
The ability to monitor viewing events of internet-connected television at multiple locations can be used in conjunction with the display of contextually targeted content. The contextually oriented content is typically embedded in a contextually oriented display application module (hereinafter "contextually oriented display application"). One or more context-oriented display applications are then previously sent from the central server device to (and loaded onto) each participating television system before displaying the video segment of interest associated with the application modules. Sometimes, when a contextually targeted display application is executed, the contextually targeted display application summons other servers across the internet to obtain additional (or current) information to update, or add to, the content already embedded within the application module. All content of the contextually-oriented display application, whether sent in advance or retrieved at execution time, appears within the frame of the contextually-oriented display application window that pops up on the television screen for the user to view and sometimes interact with. It should be understood, however, that sometimes the role of a context-oriented display application is not to display what, but merely to call the embedded URL address (or send the embedded encoded token) to trigger the auditing apparatus to register (i.e., record) the viewing event.
One aspect of the following detailed disclosed subject matter is a computer system executed method for automatically recording a viewing event on a screen of a television system, comprising the operations of: (a) storing in a database a respective reference data set for each of a plurality of reference video segments; (b) loading a plurality of context-oriented display applications in a memory of the television system, each context-oriented display application having a respective tracking pixel URL address embedded therein; (c) receiving at a server a video fingerprint from the television system, the video fingerprint being derived from a television signal of a respective portion of a video segment displayed on the screen; (d) searching the database to identify a reference dataset that best matches the video fingerprint; (e) in response to the identification of the matching reference data set in operation (d), identifying a contextually-oriented display application that is related to the matching reference data set; (f) in response to the identification of the associated contextually-oriented display application in operation (e), transmitting a signal to the television system identifying the associated contextually-oriented display application; (g) sending a request for a tracking pixel from the television system to a server using a tracking pixel URL address embedded in the associated context-oriented display application; (h) transmitting a tracking pixel from the server to the television system in response to receiving the request for a tracking pixel; and (i) recording in a memory of the server the receipt of the request for tracking pixels. The request for tracking pixels may include information identifying the television system, information indicating a geographic location of the television system, information identifying contextually targeted content, and a time at which the server received the request for tracking pixels.
Another aspect of the subject matter disclosed below is a system for automatically recording a viewing event on a screen of a television system, the system comprising a television system having a screen, first and second servers, and a database, which communicate via a network. The database stores a respective reference data set for each of a plurality of reference video segments. The television system is programmed to obtain video fingerprints from the television signal of the corresponding portion of the video segment displayed on the screen. The first server is programmed to: loading a plurality of context-oriented display applications in a memory of the television system, each context-oriented display application having a respective tracking pixel URL address embedded therein; receiving the video fingerprint from the television system; searching the database to identify a reference dataset that best matches the video fingerprint; identifying a contextually-oriented display application associated with the matched reference dataset; and transmitting a signal to the television system identifying the associated contextually-oriented display application. The television system is further programmed to send a request for a tracking pixel to a tracking pixel URL address embedded in the associated contextually-oriented display application, the tracking pixel URL address located at the second server. The second server is programmed to receive a request for the tracking pixel from the television system, send the tracking pixel to the television system, and record in memory receipt of the request for the tracking pixel.
A further aspect is a computer system implemented method for automatically recording a viewing event on a screen of a television system, comprising the operations of: (a) storing in a database a respective reference data set for each of a plurality of reference video segments; (b) loading a plurality of contextually-oriented display applications in a memory of the television system, each contextually-oriented display application having a respective coded token embedded therein; (c) receiving at a server a video fingerprint from the television system, the video fingerprint being derived from a television signal of a respective portion of a video segment displayed on the screen; (d) searching the database to identify a reference dataset that best matches the video fingerprint; (e) in response to the identification of the matching reference data set in operation (d), identifying a contextually-oriented display application that is related to the matching reference data set; (f) in response to the identification of the associated contextually-oriented display application in operation (e), transmitting a signal to the television system identifying the associated contextually-oriented display application; (g) sending from the television system to an audit server an encoded token embedded in the associated contextually-oriented display application; (h) decoding the encoded token at the audit server; and (i) recording in a memory of the audit server receipt of the encoded token.
Yet another aspect is a system for automatically recording a viewing event on a screen of a television system, the system comprising a television system having a screen, first and second servers, and a database, in communication via a network. The database stores a respective reference data set for each of a plurality of reference video segments. The television system is programmed to obtain video fingerprints from the television signal of the corresponding portion of the video segment displayed on the screen. The first server is programmed to: loading a plurality of contextually-oriented display applications in a memory of the television system, each contextually-oriented display application having a respective coded token embedded therein; receiving a video fingerprint from the television system, the video fingerprint being derived from a television signal of a corresponding portion of a video segment displayed on the screen; searching the database to identify a reference dataset that best matches the video fingerprint; identifying a contextually-oriented display application associated with the matched reference dataset; and transmitting a signal to the television system identifying the associated contextually-oriented display application. The television system is further programmed to send to the second server an encoded token embedded in the associated contextually-oriented display application. The second server is programmed to receive and decode the encoded token from the television system and record in memory receipt of the encoded token.
Additional aspects of a system and method for automatically recording viewing events for internet-connected televisions are disclosed below.
Drawings
Fig. 1a illustrates an embodiment that allows a particular video segment to be identified by sampling a video frame buffer of a television, building fingerprints, and then comparing these fingerprints to a pre-cached database of fingerprints for known programs. If a match is found, the system determines if there is a system event that is predetermined to be related to the arrival of the program and executes the event on the client device while reporting activity to the central system.
FIG. 1b illustrates one embodiment of a system and method for allowing a business client of the system to monitor specific television program consumption (including viewing interactive information displayed locally by a television client) in real-time using a method similar to how an Internet web site uses tracking pixels to monitor and record web page viewing for a specific user.
Fig. 2 illustrates one embodiment of a system and method for allowing a service provider to identify specific television program consumption in real-time and then return that information to the business clients of the system without client involvement.
Figure 3 illustrates a preferred embodiment of the system and method for allowing real-time identification of specific television program consumption and returning this information in the form of a cookie to the commercial client of the system through the trusted third party intermediary service for confirmation of delivery and a secondary confirmation back to the system to verify the third party's report.
FIG. 4 illustrates an additional embodiment of a system and method for allowing the real-time identification of specific television program consumption and the return of this information to the system's commercial clients through a trusted third party intermediary service. This embodiment incorporates additional steps to provide control and service verification by the client using encoded tokens that manage event display according to additional criteria. This is combined with a robust audit of the performance of each party involved by using encoded tokens and duplicate acknowledgments that can be cross-checked to allow clients to verify service delivery.
FIG. 5 is a flow diagram that summarizes the initial configuration processing sequence utilized by some embodiments, such as the example depicted in FIG. 3. This embodiment uses the video tracking URL to call the client server in a manner similar to how a traditional HTML web page gets graphical elements and other files from a server accessed over the internet.
FIG. 6 is a flow diagram that summarizes a second processing sequence utilized by some embodiments, such as the system depicted in FIG. 3. This embodiment allows relatively more robust tracking and validation services to be provided to customers than certain other embodiments.
FIG. 7 is a flow diagram that summarizes the initial configuration processing sequence utilized by some embodiments, such as the system depicted in FIG. 4. This embodiment receives a coded token sent by a customer to provide additional data integrity and auditing capabilities.
FIG. 8 is a flow diagram summarizing a second processing sequence utilized by other embodiments, such as the system depicted in FIG. 4. This processing sequence allows for the delivery of more efficient customer support features, including even more robust security features.
Reference will now be made to the drawings wherein like elements in different drawings bear the same reference numerals.
Detailed Description
The means of using the tracking pixels is conventional for personal computers and web browsers. When a web browser addresses a web site, the web server sends a program in the form of hypertext markup language (HTML) to the web browser, which itself contains many sub-program modules, such as Java, Adobe Flash, and JavaScript, among others. Also, these elements are typically from different servers.
All information (text, graphics, video) is combined by the HTML program into a single display page within the computer browser. Within the display page are a plurality of windows, some with graphics and some with video. Additionally, on the web page are advertisements from multiple sponsors. These advertisements themselves consist of HTML code. The HTML code also contains Java, Flash, JavaScript and other program elements. This code is provided to the website operator by an advertising agency on behalf of the advertiser.
Hundreds to thousands of lines of computer code correctly instruct the computer's web browser as to what text, graphics, and video to display, including what font to use, what text color, background color, text, and picture to display or the exact location where the video window is positioned. Among the program elements provided by the advertising agency are graphic elements in JPEG or PNG format, like those from a digital camera, called "tracking pixels". It may be 1 x 1 pixel size and set to 100% transparent so that it will not show up in the displayed content. However, when the browser of the computer executes HTML code from a web site, when the program retrieves an advertisement, the browser calls the advertiser's servers across the Internet (one for graphics, one for video (if present), and one for event tracking (auditing)) to retrieve multiple elements to form an advertisement window partition for the web page. HTML reads a program element called GET that instructs the program to call a URL to obtain, among other things, something needed to render and display a web page. When this instruction is executed (i.e., the graphical element at the URL address is retrieved), the instruction calls an advertiser server (hereinafter "advertisement server") at the URL address. The ad server then sends the element (in this example, the tracking pixel) back to the client system's web browser. The display of the tracking pixels is irrelevant, however, the action of the ad server responding to a GET call from the client system's web browser causes an event to be recorded that tells the advertiser that the ad was displayed on a web page such as Weehawken (New Jersey). The ad server also records the time and date of the request.
This means of auditing advertisements allows for higher confidence in the system than a website operator that reports only the number of times a web page is displayed to the advertiser. However, the website operator also wants to know how many times the advertisement is displayed, so the website operator can track his advertisement bill. Because of the complexity of web servers and web browsers, a server may send one or more HTML web pages, but not all web pages retrieved are displayed, so in the case of the above example, neither the website operator nor the advertiser can know how often to display advertisements simply by counting the servers of the website operator that issued the HTML code when requested by the web browser in some homes.
According to the system disclosed below, the aforementioned tracking pixel method extends to smart televisions that include a small computer or processor programmed to execute a web browsing application. Such a computer system within the television system can take over the television screen and display exactly the same content as one would see on a personal computer. However, the use of such computer systems is often directed towards pre-programmed applications that provide a "secret garden" that closely resembles a smartphone. Such a preloaded program (application) may be an application for watching a movie or an application for acquiring latest news via the internet. The obtained user experience is almost the same as the smartphone or iPad experience. In reality, these applications are essentially just pre-packaged web scripts, usually written in HTML. When this application runs, it invokes a software program call to the web server to send all the information needed to display the web page. Of course, in contrast to ipads held in one's hands, the information received by the smart tv from the website operator is in a format suitable for a larger display 10 feet from the viewer. This programming approach may not be suitable for live television by itself, as the internet language of such HTML is intended as a static approach to linking information from multiple computers (not to be confused with the ability of a web page to display video within a window on the web page).
The novelty of video tracking pixels disclosed herein stems from this underlying technology using tracking pixels, but by extending their application into video by employing video matching, the action whereby a video segment is identified by means of video matching can be used to trigger a program to run in a computer system of a smart tv or set-top box. When the program is running, part of its program code addresses a remote computer server to request that the server send the graphics elements back to the program running in the smart tv or set-top box. The system of video tracking pixels uses existing internet programming languages and existing internet server means for prior art web page tracking pixels.
The use of tracking pixels in the context of a television provides a third party with a means for verifying that a video segment of interest to the third party has been displayed on the television. Also, this video segment of interest can be an advertisement for a company product or an advertisement for a competitor product. For example, competitor a, ford automotive, may want to know how many times competitor B, toyota automotive, has had their advertisement viewed in a particular market. Competitor a may obtain this information by: the video tracking pixel service is contracted to place an application in each smart tv in a market area of interest, such as the new york city metropolitan area, that is triggered each time an advertisement for competitor B is displayed on the respective tv. In other uses, if the application triggered in the home displays context-oriented information (information that appears as a pop-up on the television screen), then this event is audited in the same way as the previous example of simply detecting the display of a video segment of interest. That is, the video tracking pixels provide an independent means for context-oriented customers of information services to verify delivery of services to multiple televisions and subsequent display of the services.
Current means of auditing the display of television programs or advertisements is inaccurate because, for example, a buyer of a television advertising spot only knows how many times the buyer's advertisement was aired, but does not know how many televisions are on and tuned to the channel on which the advertisement is being played. Several companies have designed various means to statistically measure home television viewing events, but this is a very inaccurate technique and cannot accurately measure actual viewing. For example, during an advertisement slot, a viewer may switch channels to view another channel and miss an advertisement. The actual viewing of the commercial (or any video segment of interest) can be measured by the video tracking pixel method disclosed in detail below. If the advertisement relates to context-targeted information, the display of such additional information may be similarly verified.
A method for matching viewed video with reference video stored in a database will now be described with reference to fig. 1a and 1b, which fig. 1a and 1b depict at a high level the components of a system that allows a particular video segment to be identified by sampling the video frame buffer of a television. The systems shown in fig. 1a and 1b represent useful examples to provide background for additional embodiments of the systems and methods disclosed below with reference to fig. 2-4.
As can be seen from fig. 1a, a matching server 101 (of a matching server system) receives reference video feeds 102 or other video information, such as feature films or archival videos, for a plurality of television channels and builds a reference database 103 of their digital fingerprints stored in computer memory. The fingerprint is composed of samples of at least a subset of the received video frames. These samples may be, but are not limited to, one or more video sub-regions of a video frame that are further processed by averaging or other techniques known to those skilled in the art.
The matching server 101 preferably comprises a plurality of centrally located matching servers, only one of which is depicted in fig. 1 a. Each matching server may then include multiple processors programmed to perform different functions, such as video segment identification and management based on context orientation. Each matching server may then communicate with a corresponding plurality of remotely located television systems, only one of which is depicted in fig. 1 a. The system partially depicted in fig. 1a (as well as the systems partially depicted in fig. 1b and fig. 2-4) will be described with reference to a single television system communicating with a single matching server, although it will be understood that in practice, multiple television systems will communicate with multiple matching servers.
Referring to fig. 1a, a remotely located television system 108 is capable of communicating with the matching server 101 via communication channels 106, 107 and 115 (e.g., the internet). The television system 108 may be a smart television or television monitor with an external set-top controller. The television client 109 receives a video program from a television video frame buffer (not shown in FIG. 1 a). Television client 109 is a software application running in a computer or processor of television system 108. The television system samples the data from the television video frame buffer and generates an unknown (i.e., not yet identified) video fingerprint that is sent to the matching server 101 via the communication channel 107 to be matched with the data in the reference database 103.
More specifically, the video fingerprint obtained from the processing of the television system 108 is transferred via the communication channel 107 to the video segment identification processor 105, which is part of the matching server 101. The television client 109 generates fingerprints of unknown videos using algorithms similar to those used by the matching server 101 to store reference videos in the reference database 103. The video segment recognition processor 105 proceeds to search the reference database 103 in an attempt to find a match to the incoming video fingerprint using a search means according to methods known in the art, such as the method taught by Neumeier et al in U.S. Pat. No. 8,595,781, the disclosure of which is 8,595,781, which is incorporated herein in its entirety by reference. When the video segment identification processor 105 finds that a known fingerprint in the reference database 103 matches an unknown fingerprint of a video segment received from the television system 108, the video segment identification processor 105 sends a message to the manager 104 directed according to the background to identify the video segment displayed by the television system 108. (As used herein, the term "manager" refers to a processor or computer programmed with application software that performs data management or data processing functions). The manager 104, based on the context orientation, determines what, if any, events are associated with the detection of the newly identified video fingerprint from the television client 109. Once an appropriate response is determined, context-dependent manager 104 sends the encoded trigger to application manager 110 of television system 108 over communication channel 106. (application manager 110 is software running on the same processor in television system 108 on which the television client software is running.) application manager 110 starts and triggers or otherwise signals the particular application determined to be relevant to the event.
More specifically, the application manager 110 sends a trigger signal to the display application 112 oriented according to the background via the communication channel 111. The television system 108 may be loaded with a plurality of display applications oriented according to the background. (the display application 112 targeted according to the background is software running on the same processor in the television system 108 on which the television client software is running.) in one example, the display application 112 targeted according to the background may be invoked to display a related graphical image overlaid on a video screen of the television system 108 with information related to, for example, a television advertisement currently being displayed. The graphics overlay is from an embedded graphic (previously downloaded from the context oriented manager 104) stored within the context oriented display application. Or the image may come from an external website when the display application oriented according to the background causes the overlap. Similar to a web browser, a display application that is oriented according to the context may contain a URL that points to an external website for requesting graphics and/or video.
After the overlaid display, the context oriented display application 112 sends an event complete message over the communication channel 115 to the context oriented manager 104 that recorded the action occurrence. The last step is useful when the advertiser or another third party wishes to receive confirmation that the display of additional information targeted by context on the television system 108 overlaps or even only that a video segment () such as an advertisement or a public service advertisement has been displayed. In these cases, the context-oriented manager 104 may provide a log file to the third party, such as the time and location of the occurrence.
FIG. 1b illustrates how one embodiment of the system operates if configured in a similar manner as how many Internet web sites monitor content consumption. The television client 109 receives video programming from a television video frame buffer of the television system 108. As previously described, television client 109 is a software application running in a computer or processor of television system 108, which is a smart television or television monitor with an external set-top controller. The video stream is processed according to methods known in the art, such as the method taught by Neumeier et al in U.S. Pat. No. 8,595,781.
The monitored television client 109 sends the matching server 101 a video fingerprint being viewed consisting of multiple samples per second of the unknown program being displayed on the television 109. These video fingerprints, which contain "cues" about the video segment being viewed, are sent via the communication channel 107 to the video segment identification processor 105 which attempts to match the "cues" with data in the reference database 103 to identify the program being viewed and the particular segment of the video segment in the sample sent, and then passes a token to this information and its associated metadata to the context-oriented manager 104. If and when this segment of interest is identified, the context-oriented manager 104 then determines what (if any) action is to be performed. The measurements are sent via the communication channel 106 to an application manager 110 of the television system 108, which routes this information (e.g., in the form of software scripts) via a communication channel 111 to a display application 112 that is oriented according to the context. The context-oriented display application 112 then sends a request to display a piece of content to a URI-based address embedded in a software script provided by the application manager 110 via a communication channel 113 (e.g., the internet). This request addresses a client server 116 somewhere on the internet. The location of the client server 116 is not a matter of the process disclosed herein (i.e., the client server 116 may be located anywhere). The client server 116 returns a data item, perhaps a small graphic (i.e., a trace pixel) with transparent pixels (e.g.,. png file), via the communication channel 114. Upon receiving this data item, the display application 112, oriented according to the background, combines the remainder of the display elements (if any) and renders the image on the screen of the television system 108 much like a web page consists of addressable elements that are combined by a web browser for display on the screen of a personal computer. The context-oriented display application 112 sends a request for a particular graphical element over the communication channel 113 to provide information to the commercial client server 116 that the television system 108 has viewed the video segment of interest and that the context-dependent graphical overlay has been rendered. For example, when client server 116 sends a tracking pixel via communication channel 114 in response to receiving a GET call over communication channel 113, client server 116 may record the event. (As previously described, the trace pixel is not displayed on the television system. the primary purpose of sending the trace pixel in response to a GET call is to complete the request so that the GET call is not repeated.)
Another task of the context-oriented display application 112 may be to transmit a confirmation (i.e., event log) message back to the matching server 101 via the communication channel 115, which is logged, perhaps for billing purposes or network reliability monitoring. A disadvantage of this embodiment is that it requires the business client to act as an active participant in the process, undertaking the client server 116 maintaining its own database of graphics elements (also known to the skilled person as tracking pixels) while recording details of video segment matches found based on the received requests for graphics.
Optionally, a particular context-oriented display application 112 may be triggered to send a request to track pixels and other information including a television system identifier, location, etc., without requesting that any content be displayed on the television screen in a graphical overlay. Since the request to track pixels is triggered by the matching server 102 identifying the relevant video segment being viewed, the client server 116 can log the event (i.e., display the identified video segment on the identified television system) upon receiving the request to track pixels. This approach may allow the client server to determine the number of television systems that are viewing a particular video segment within the area of interest, even when no background-oriented material is provided.
Fig. 2 depicts how another embodiment of the system, if configured to offload the administrative burden of a business client maintaining a database of graphical elements ("tracking pixels") and corresponding access logging means on the client server 216, may operate. The television client 209 receives the video program from a television video frame buffer (not shown in fig. 2). The television system 208 samples data from the television video frame buffer and generates an unknown (i.e., not yet identified) video fingerprint. The television client 209 generates fingerprints of unknown videos using algorithms similar to those used by the matching server 201 to store reference videos in the reference database 203. The video fingerprint contains "clues" about what is being viewed, which includes multiple samples per second of an unknown program being displayed on the screen of the television system 208. These threads are sent to matching server 201 via communication channel 207 to match with data in reference database 203. More specifically, the cues obtained from the processing in the television system 208 are communicated to the video segment identification processor 205 via the communication channel 207. The video segment recognition processor 205 continuously searches the reference database 203 in an attempt to find a match with the incoming video fingerprint. When the video segment identification processor 205 finds a match between a known fingerprint in the reference database 203 and an unknown fingerprint of a video segment received from the television system 208, the video segment identification processor 205 sends a message to the manager 204 directed according to the background to identify the video segment displayed by the television system 208. The context oriented manager 204 determines what, if any, events are relevant to the detection of the newly identified video fingerprint from the television client 209. Once an appropriate response is determined, the context-dependent manager 204 sends the encoded trigger to the application manager 210 of the television system 208 over the communication channel 206. The application manager 210 launches and triggers or otherwise signals the particular contextually-oriented display application 212, which particular contextually-oriented display application 212 has been determined to be associated with the trigger and event. More specifically, the application manager 210 sends a trigger signal to a particular contextually-oriented display application 212 via a communication channel 211. In one example, the display application 112, which is oriented according to the background, may be invoked to display a related graphical image overlaid on a video screen of the television system 208, along with information related to, for example, a television advertisement currently being displayed. The context oriented display application 212 sends an event complete message over the communication channel 215 to the context oriented manager 204, which context oriented manager 204 records the occurrence of actions for internal tracking and billing purposes. The context oriented manager 204 also sends a confirmation report to the client server 216 via a communication channel 217 (e.g., the internet) to confirm the detection of the video segment displayed on the television system 208. While reasonably efficient, this embodiment does not support the need for the business client to ensure sufficient accuracy of the received video identification information.
Figure 3 illustrates how a particularly advantageous embodiment of the system operates when configured to interpose a display confirmation audit server 318 as part of this process. This allows commercial client servers 316 to obtain independent verification of the number of views or "clicks" of their advertisement or some other particular video segment. Although confirmation audit server 318 is shown in FIG. 3 as being separate from client server 316, the two servers may be combined into one server. In the case where the display confirms that the audit server is independent, the server 318 may be operated by a trusted third party.
Referring again to FIG. 3, the video program is received by the television client 309 from a television video frame buffer (not shown in FIG. 3). The television system 308 samples data from the television video frame buffer and generates an unknown (i.e., not yet identified) video fingerprint. Television client 309 generates fingerprints of unknown videos using algorithms similar to those used by matching server 301 to store reference videos in reference database 303. The video fingerprint contains "clues" about what is being viewed, which includes multiple samples per second of an unknown program being displayed on the screen of the television system 308. These threads are sent to matching server 301 via communication channel 307 to match with data in reference database 303. More specifically, the cues obtained from the processing in the television system 308 are communicated to the video segment identification processor 305 via the communication channel 307. The video segment identification processor 305 continuously searches the reference database 303 in an attempt to find a match with the incoming video fingerprint. When the video segment identification processor 305 finds that the known fingerprint in the reference database 303 matches an unknown fingerprint of a video segment received from the television system 308, the video segment identification processor 305 sends a message to the manager 304 directed according to the background to identify the video segment displayed by the television system 308. The context-oriented manager 304 determines what, if any, events are relevant to the detection of the newly identified video fingerprint from the television client 309. Once an appropriate response is determined, context-dependent manager 304 transmits the encoded trigger to application manager 310 of television system 308 via communication channel 306. The application manager 310 launches and triggers or otherwise signals a particular contextually-oriented display application 312 that the contextually-oriented display application 312 has been determined to be relevant to the event. More specifically, the application manager 310 sends the trigger signal to the display application 312 oriented according to the background via the communication channel 311. In one example, the contextually targeted display application 312 may be invoked to display a related graphical image overlaid on a video screen of the television system 308 and concurrently display information related to, for example, a television advertisement that is currently being displayed. Display application 312, oriented according to the background, is programmed to notify confirmation audit server 318 via communication channel 315 a: some television systems 308 that have been properly identified by associated metadata via device, time, location, or other information have viewed a video segment of interest (typically identified by its timestamp and associated metadata provided by the matching server 301). This notification may include a request by the client server 316 (maintained by a commercial client for the video segment viewing detection service) to send a tracking pixel, which is sent via the communication channel 315 b. Confirmation audit server 318 then communicates an event report containing an audit of observation detected event indicators and related metadata to client server 316 via communication channel 319.
Optionally, the context oriented display application 312 also sends a confirmation of the event to the context oriented manager 304 via communication channel 317b, thereby providing a single source for both billing and verification data, for example. Optionally, confirmation audit server 318 also provides a message to context-directed manager 304 via communication channel 317a indicating that client server 316 has been notified. This means may be used to maintain an internal display confirmation audit trail of confirmation audit server 318.
Fig. 4 depicts yet another embodiment of a system with certain additional advantages. As shown in fig. 4, a video client 409, such as a television or other video display device, of a television system 408 receives video programming. As in other embodiments, television client 409 receives video programs from a television video frame buffer (not shown in fig. 4). The television system 408 samples data from the television video frame buffer and generates an unknown (i.e., not yet identified) video fingerprint. Television client 409 generates fingerprints of unknown videos using algorithms similar to those used by matching server 401 to store reference videos in reference database 403. The video fingerprint contains "clues" about what is being viewed, which includes multiple samples per second of an unknown program being displayed on the screen of the television system 408. These threads are sent to the matching server 401 via the communication channel 407 to match with the data in the reference database 403. More specifically, the cues obtained from the processing in the television system 408 are transferred to the video segment identification processor 405 via the communication channel 407. The video segment identification processor 405 continues to search the reference database 403 in an attempt to find a match with the incoming video fingerprint. When the video segment identification processor 405 finds that the known fingerprint in the reference database 403 matches the unknown fingerprint of the video segment received from the television system 408, the video segment identification processor 405 sends a message to the manager 404 directed according to the background to identify the video segment displayed by the television system 408. Manager from background targeting 404 determines what, if any, events are associated with the detection of the newly identified video fingerprint from television client 409. Once an appropriate response is determined, the context-dependent manager 404 sends the encoded trigger to the application manager 410 of the television system 408 over the communication channel 406. The application manager 410 starts and triggers or otherwise signals the particular application that has been determined to be related to the event.
More specifically, the video segment identification processor 405 attempts to match the received cues to reference data in the database 403 to identify a particular segment of the video segment in the program and transmitted sample, and then passes a token pointing to that information and its associated metadata to the context-oriented manager 404. If and when this segment of interest is identified, the context-oriented manager 404 then determines what (if any) action is to be performed. When an action is to occur on television system 408, this determination is sent to application manager 410 via communication channel 406 along with a token and/or encryption seed (public key value) received from client server 416 via communication channel 421. The client server 416 may then use the token and/or the encrypted seed to uniquely identify any event, action, or metric associated with the token for verification or other purposes. The application manager 410 then routes the information via the communication channel 411 to the context-oriented display application 412, which then displays the relevant graphical image overlaid on the video screen of the television system 408. The contextually oriented display application 412 is programmed to notify the confirmation audit server 418 via communication channel 415 a: certain television systems 408 that have been properly identified by means of device, time, location or other information by means of associated metadata have viewed a video segment of interest (typically identified by its timestamp and associated metadata provided by the matching server 401). This notification may include a request for the client server 416 to send a tracking pixel, which is sent via the communication channel 415 b. Confirmation audit server 418 then communicates an audited event report containing an observation detection event indicator and associated metadata to client server 416 via communication channel 419.
Optionally, the contextually oriented display application 412 also sends a confirmation of the event to the contextually oriented manager 404 via a communication channel 417 b. Optionally, the validation audit server 418 also provides a message to the context-oriented manager 404 via communication channel 417a indicating that the client server 416 has been notified. Optionally, the context-oriented manager 404 sends the audited event report to the client server 416 via the communication channel 420.
It will be appreciated by those skilled in the art that the token as described above may be advantageously applied to the task of identifying the confirmation that third party verification service 418 receives from television system 408. For example, client server 416 may provide a unique token for each of the first 120 Demographic Market Areas (DMAs) in the united states. It is the responsibility of the matching server 401 to assign the respective token to the television system present in the respective DMA before the token is expected to be used. When the system disclosed herein detects a video segment, such as a television advertisement, and instructs the television system 408 to send a message to the third party verification service 418, a token identifying the DMA area is transmitted as part of the message. This helps the client server 416 classify the collected data. In addition to the examples of regional identification disclosed herein, tokens may be established for classification tasks. In addition, a combination of multiple parameters may be assigned to a token, or multiple tokens may be assigned to a television system for any combination of beneficial metrics.
If the client provides the encryption seed as a token, or in addition to a token, such as a public key value of a public key/private key encryption pair, the computing device of television system 408 algorithmically processes the encryption seed to generate a unique encryption code that, when transmitted to third party verification service 418, is further transmitted back to client server 416 for active identification of the particular television system and any video segments viewed on those particular television systems.
FIG. 5 shows a flow diagram summarizing a key establishment process utilized by certain embodiments, such as the system depicted in FIG. 3. In this flowchart, the process begins with a first step 501 involving matching server 301 receiving a video tracking pixel Uniform Resource Locator (URL) from client server 316 from display confirmation audit device 318 via communication channel 317 a. This URL is then embedded in a contextually-oriented display application 312 associated with the business customer (i.e., client server 316) in step 102. This context-oriented display application is then transmitted to a selected television client, such as a smart television or set-top box, of the corresponding television system 308 in the region, metropolitan, or local viewing area of interest to the commercial customer in step 503. In a next step 504, an event execution list is built via the context-oriented manager 304. The final step 505 in this process is to send an event list to the application manager 310 (in the targeted television system 308) that associates event trigger codes from the context oriented manager 304 with the particular context oriented display application 312 stored in the storage of the television system 308. Receipt of an event-triggered code from the context oriented manager 304 will cause the application manager 310 to launch a particular context oriented display application 312 associated with that code xxx.
FIG. 6 shows a flowchart summarizing a second processing sequence utilized by certain embodiments, an example of which is the system depicted in FIG. 3. When the process begins at step 601, television system 308 receives one or more contextually-oriented display applications 312 from matching server 301. In step 602, the application manager 310 receives an event trigger list from the context oriented manager 304 that matches the context oriented display application with a trigger code sent via the context oriented manager 304. In step 603, the television client 309 sends the video information from the television display to the video segment identification processor 305, which is a subsystem of the matching server 301. In step 604, the video segment identification processor 305 monitors videos from multiple television systems and reports matches of unknown video segments from these television systems to known video segments stored in a database associated with the matching server 301. The results of this identification of known video segments (i.e., matches) are sent to the context oriented manager 304. In step 605, the context targeting based manager 304 matches the identified video segment with the event list associated with the identified video segment. In step 606, when a particular video segment matches an associated event, this causes the context oriented manager 304 to send a trigger to the application manager 310, which is part of the television system 308. In step 607, when application manager 310 receives a trigger from context-oriented manager 304, application manager 310 launches context-oriented display application 312 that has been associated with the received trigger.
Fig. 6 assumes that the display confirms that audit server 318 is incorporated into client server 316. In this configuration, upon execution, the display application 312, oriented according to the context, addresses (step 608) the URL embedded in this application via the communication channel 315a to obtain the specified video tracking pixels from the client server 316. Step 609 involves client server 316 sending a request for a tracking pixel via communication channel 315b and recording the tracking pixel to confirm that the associated contextually-oriented display application 312 has been running on television system 308. The contextually targeted display application 312 also sends an event confirmation in the form of a token to the matching server 301 to confirm execution of the contractually agreed service, ending the process at step 610.
FIG. 7 shows a flow diagram summarizing a key establishment process sequence utilized by the system depicted in FIG. 4 in some embodiments. In this flowchart, the process begins with a first step 701 involving the matching server 401 receiving a video tracking pixel URL from the client server 316 via the communication channel 421. In step 702, the URL with the associated data token is embedded in a contextually-oriented display application associated with the business customer (client server 416) for service. The display application 412, oriented according to the background, is then sent to the selected television system 408 in the regional or local viewing area of interest in step 703. In a next step 704, an event execution list is created via the context-oriented manager 404. The final step 705 in this process is to send the application manager 410 an event list that associates the trigger codes received from the context oriented manager 404 with the context oriented display application that will be executed (launched) when the trigger codes are received by the application manager 410.
FIG. 8 shows a flowchart summarizing a modified processing sequence utilized by certain embodiments, an example of which is the system depicted in FIG. 4. When the process begins at step 801, the application manager 410 receives one or more context-oriented display applications from the context-oriented manager 404 of the matching server 401. In step 802, application manager 410 receives a list of threads from context-oriented manager 404 that match context-oriented display applications to trigger codes. In step 803, television client 409 sends video information from the television display to video segment identification processor 405 in matching server 401. In step 804, the video segment identification processor 405 monitors video from a plurality of television systems and reports identified video segments from these television systems to the context-oriented manager 404. In step 805, the context targeting based manager 404 matches the identified video segment with the event list associated with the identified video segment. In step 806, when a particular video segment matches an associated event, this causes the context oriented manager 404 to send a trigger to the application manager 410 in the television system 408. In step 807, when application manager 410 receives a trigger from context-oriented manager 404, application manager 410 launches context-oriented display application 412, and application manager 410 determines that context-oriented display application 412 is associated with the trigger.
Fig. 8 assumes that display confirmation audit server 318 is incorporated into client server 316. In such a configuration, upon execution, the context-oriented display application 412 launched in step 808 invokes a URL embedded in this application and sends a data token, which may also be embedded in the application or, alternatively, stored in advance in a known location in the memory of the television system 408. Step 809 involves client server 416 recording a request to track pixels to confirm that the associated contextually-oriented display application 412 has been running on television system 408. The contextually targeted display application 412 also sends an event confirmation in the form of a token to the matching server 401 to confirm execution of the contractually agreed service, ending the process at step 810.
While the system and method has been described with reference to multiple embodiments, it will be understood by those skilled in the art that various changes may be made and equivalents may be substituted for elements thereof without departing from the scope of the teachings herein. In addition, many modifications may be made to adapt the concepts and practices disclosed herein to a particular situation. Therefore, it is intended that the subject matter covered by the claims be limited not by the disclosed embodiments.
As used in the claims, the term "computer system" should be broadly construed to include a system having at least one computer or processor, and the system may have multiple computers or processors communicating over a network or bus. The terms "computer" and "processor" as used in the preceding sentence both refer to a device that includes a processor (e.g., a central processing unit) and some form of memory (i.e., a computer-readable medium) for storing programs that are readable by the processor.
The method claims set forth below should not be construed as requiring that the steps set forth therein be performed in alphabetical order (alphabetical order in the claims merely being used to reference the steps set forth in advance) or in the order in which they are set forth. Nor should they be construed as excluding any portion of performing two or more steps in parallel or in alternation.

Claims (20)

1. A system, comprising:
one or more processors; and
a non-transitory computer-readable medium comprising instructions that, when executed by the one or more processors, cause the one or more processors to:
storing a plurality of context-dependent applications, wherein a context-dependent application is associated with a video segment, wherein the context-dependent application is associated with an address, and wherein the address identifies an additional server for recording a viewing event corresponding to a media system;
generating a fingerprint, wherein the fingerprint is associated with a frame being displayed by the media system;
sending the fingerprint, wherein when the fingerprint is received at a matching server, the matching server determines a reference data set similar to the fingerprint, and wherein the matching server generates a signal identifying a particular context-dependent application corresponding to the reference data set;
receiving the signal identifying the particular context-dependent application corresponding to the reference data set;
using the signal to identify the particular context-dependent application;
determining a particular address associated with the particular context-dependent application, wherein the particular address identifies a particular additional server for recording a viewing event corresponding to the media system; and
in response to determining that the reference data set is similar to the fingerprint, automatically sending a message using the particular address associated with the particular context-dependent application, wherein receiving the message at the particular additional server causes the particular additional server to record a viewing event corresponding to the particular context-dependent application.
2. The system of claim 1, wherein the message includes information identifying the media system.
3. The system of claim 1, wherein the message includes information indicating a geographic location of the media system.
4. The system of claim 1, wherein the fingerprint is generated from one or more pixels of the frame.
5. The system of claim 1, wherein the determining and the sending are performed by the particular context-dependent application.
6. The system of claim 1, wherein the instructions further cause the one or more processors to:
in response to receiving the signal, performing the particular context-dependent application.
7. The system of claim 1, wherein the message comprises a token related to the particular context-dependent application.
8. The system of claim 1, wherein the message comprises a request for a tracking pixel.
9. The system of claim 1, wherein the instructions further cause the one or more processors to:
receiving a tracking pixel in response to the message being sent, wherein the tracking pixel is not displayed by the media system.
10. The system of claim 1, wherein the particular address is a uniform resource locator embedded in the particular context-dependent application.
11. A non-transitory computer-readable storage medium that is a non-transitory computer-readable storage medium of a media system, the non-transitory computer-readable storage medium comprising instructions that, when executed by the one or more processors, cause the one or more processors to:
storing a plurality of context-dependent applications, wherein a context-dependent application is associated with a video segment, wherein the context-dependent application is associated with an address, and wherein the address identifies an additional server for recording a viewing event corresponding to the media system;
generating a fingerprint, wherein the fingerprint is associated with a frame being displayed by the media system;
sending the fingerprint, wherein when the fingerprint is received at a matching server, the matching server determines a reference data set similar to the fingerprint, and wherein the matching server generates a signal identifying a particular context-dependent application corresponding to the reference data set;
receiving the signal identifying the particular context-dependent application corresponding to the reference data set;
using the signal to identify the particular context-dependent application;
determining a particular address associated with the particular context-dependent application, wherein the particular address identifies a particular additional server for recording a viewing event corresponding to the media system; and
in response to determining that the reference data set is similar to the fingerprint, automatically sending a message using the particular address associated with the particular context-dependent application, wherein receiving the message at the particular additional server causes the particular additional server to record a viewing event corresponding to the particular context-dependent application.
12. The non-transitory computer-readable storage medium of claim 11, wherein the message includes information identifying the media system.
13. The non-transitory computer-readable storage medium of claim 11, wherein the message includes information indicating a geographic location of the media system.
14. The non-transitory computer-readable storage medium of claim 11, wherein the fingerprint is generated from one or more pixels of the frame.
15. The non-transitory computer readable storage medium of claim 11, wherein the determining and the sending are implemented by the particular context-dependent application.
16. The non-transitory computer-readable storage medium of claim 11, wherein the instructions further cause the one or more processors to:
in response to receiving the signal, performing the particular context-dependent application.
17. The non-transitory computer readable storage medium of claim 11, wherein the message comprises a token related to the particular context-dependent application.
18. The non-transitory computer readable storage medium of claim 11, wherein the message comprises a request for a tracking pixel.
19. The non-transitory computer-readable storage medium of claim 11, wherein the instructions further cause the one or more processors to:
receiving a tracking pixel in response to the message being sent, wherein the tracking pixel is not displayed by the media system.
20. The non-transitory computer-readable storage medium of claim 11, wherein the particular address is a uniform resource locator embedded in the particular context-dependent application.
HK42022050505.1A 2013-12-23 2022-03-23 Tracking pixels and cookies for television event viewing HK40059301B (en)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US61/920,086 2013-12-23

Publications (2)

Publication Number Publication Date
HK40059301A true HK40059301A (en) 2022-05-06
HK40059301B HK40059301B (en) 2024-09-13

Family

ID=

Similar Documents

Publication Publication Date Title
US11039178B2 (en) Monitoring individual viewing of television events using tracking pixels and cookies
CN106062801B (en) Tracking pixels and COOKIE for television event viewing
US9838753B2 (en) Monitoring individual viewing of television events using tracking pixels and cookies
US11854049B2 (en) Methods and apparatus to measure media using media object characteristics
US9785980B2 (en) Content syndication in web-based media via ad tagging
US20160127755A1 (en) Distributing Media Content Via Media Channels Based on Associated Content Being Provided Over Other Media Channels
EP3528501B1 (en) Methods and apparatus to measure media using media object characteristics
US9277255B1 (en) Metering of internet protocol video streams
HK40059301A (en) Tracking pixels and cookies for television event viewing
HK1231225A1 (en) Tracking pixels and cookies for television event viewing
US9639817B2 (en) Remote metering for panelist web usage
HK1231225B (en) Tracking pixels and cookies for television event viewing