Monitoring and Activity Reporting of Enhanced Media Content
A monitoring and analysis system is disclosed that gathers and analyzes information about distributed enhanced content delivery to end user or other equipment. The system may establish communications connections along the content delivery system, filter content received from different locations of the system, and compare the received content with an expected content characteristic. Also, a radio frequency signal from the distribution network may be converted into an Internet Protocol (IP) format by a converter so that the transformed signal may be similarly analyzed as other signals from the system. A report may be consequently generated that is indicative of the received enhanced content and any detected discrepancies with respect to expected enhancement events. Identification of the enhanced content may be based on the program association table and the program map table in order to determine the packet ID of the application signals.
This application is a continuation of and claims priority to U.S. Pat. Application No. 16/984,963, filed Aug. 4, 2020, which is a continuation of U.S. Pat. Application No. 13/114,729 filed on May 24, 2011 (now U.S. Pat. No. 10,771,827), each of which is hereby incorporated by reference in its entirety.
TECHNICAL FIELDThe disclosure relates generally to gathering and analyzing information about distributed enhanced content delivery.
BACKGROUNDContent and data providers around the world are deploying more interactive applications by, for example, creating enhancements to a video stream. Enhanced television (ETV) applications may rely on embedding various types of data in the video stream, including programs, images, and triggers. ETV may support a growing variety of program applications, such as interactive advertising, game shows, news, sports events, voting applications, impulse upgrade promotions, and E-commerce applications.
As a new revenue opportunity, content and data providers are aggressively deploying new ETV applications on a variety of different content, in which a number of applications focus on enhanced advertisements. Advertising enhancements may be distributed in-band, for example, and the content provider typically has no easy way to determine whether an advertisement or an enhancement was actually delivered correctly and completely. However, in order to maintain statistics or collect revenue, the provider or operator must be able to verify that an enhanced advertisement or related data was correctly distributed to and/or displayed on end-user equipment. Traditional approaches for verification may be inefficient, non-scalable, and expensive to the provider or operator.
BRIEF SUMMARYOne embodiment of the disclosure is a data collection and analysis system that gathers and analyzes information about distributed content delivery to a receiver, where content such as enhanced content may include enhanced television (ETV) content. The data collection and analysis system may gather information at different points of the distribution system, e.g., Internet Protocol (IP) or another service provider network. If the data signal has been transformed, the transformed signal may be converted into an IP format by a converter so that the transformed signal may be similarly analyzed as the other signals.
Another embodiment of the disclosure may comprise a monitoring and analysis system for establishing communication connections along a content delivery network. The system may filter content received from different locations of the network. The received content may be compared with an expected content characteristic (e.g., scheduled delivery time) so that an indicator can be generated based on the comparison. The monitoring and analysis system may filter the content by identifying enhanced content any passing the identified content. Identification of the enhanced content may be based on the program association table and the program map table in order to determine the packet identifications (PIDs) of the application signals. The monitoring and analysis system may then generate a report that is indicative of the received enhancement content with the corresponding distribution location and any detected discrepancies with respect to expected enhancement events.
Another embodiment of the disclosure may include a monitoring and analysis system that establishes IP connections along different locations of a content distribution system. RF signals from the distribution system may be converted to an IP format and processed in a similar fashion as the other signals.
Aspects of the embodiments may be provided in a computer-readable medium having computer-executable instructions to perform one or more of the process steps described herein.
These and other aspects of the embodiments are discussed in greater detail throughout this disclosure, including the accompanying drawings.
The present disclosure is illustrated by way of example and not limited in the accompanying figures in which like reference numerals indicate similar elements and in which:
In the following description of the various embodiments, reference is made to the accompanying drawings, which form a part hereof, and in which is shown by way of illustration various embodiments in which the embodiments may be practiced. It is to be understood that other embodiments may be utilized and structural and functional modifications may be made without departing from the scope and spirit of the present the embodiments.
In an aspect of the disclosure, system 100 supports the creation and/or storage of enhanced applications of media source 101 through production entity 103, content source entity 102, and application server 109. Moreover, the media distribution provider may create and deploy enhancements through distribution facilities, including Internet Protocol (IP) network 104 and a provider’s central office or facility (e.g., a head-end) 105.
Application production teams may generate the interactive enhancements (e.g., applications) through entity 103 in conjunction with the sources that produce the video. Applications may be built around templates for triggers and data that are inserted by a production team. Triggers often refer to a message that provides a synchronization mechanism to an enhancement and may be embedded in the associated video program, or delivered via another means such as out-of-band (OOB). Triggers may also be used for the delivery of unsolicited data with an enhancement and may include application signals and stream events. A stream event typically refers to a type of trigger that conveys application defined messages to an enhancement. For pre-recorded shows, the application signaling and triggers may be mastered, for example, during the video post-production process before the show is broadcast or otherwise transmitted. An application signal may comprise a message that provides information to a receiver or another device necessary to acquire, launch, and terminate an ETV application. Throughout the production process, the production team may use a media timeline based on SMPTE time codes that are used for synchronization of a video stream. For live shows, the application signal may be prepared in advance, but the actual data to feed the application may be inserted dynamically.
Typically, enhancements are not bound to a program until after the data (e.g., video) has been digitized for final transmission. Video feeds from the major networks, for example, are often converted back to analog by a local network affiliate and then re-digitized for use by the local content transmission company, losing many enhancements along the way. Content channels may remain in the digital domain, and consequently enhancements may be inserted at the digital encoding stage. Applications and triggers may be inserted into the video stream by the broadcaster, though content source or another entity 102, using synchronization triggers and play lists that are appropriate for the type of equipment used in the transmission environment. Content providers may rely on sending those enhancements across a broadband connection to content transmission companies and affiliates who do not preserve the full digital signal from beginning to end. Some enhancements may be sent to a provider ahead of time for automatic insertion on a given schedule or a predetermined plan. Other enhancements may be transmitted in real time and synchronized to live events, either by production teams directly or via the broadcasters or the content transmission operators.
Some content providers or transmission system operators may generate their own programming and enhancements (e.g., applications) through media source 107 and enhancement source 108. The provider or operator may be responsible for obtaining the enhancement from the production entity 103 and inserting the application, signaling and triggers into the video streams, adding to or replacing video segments received over a communications media such as an IP network or satellite system. At this point, operators may be working in either the analog or digital domain, because the video may be in either state before final transmission to the user.
System 100 may include an application server 109, which may comprise a polling or score server to dynamically process user actions such as votes or quiz answers and, for example, send responses back to particular client receivers. Messages sent from the application server may require routing or insertion by the operator back into either an in-band or out-of-band data stream to a client, where the insertion is within the data stream or separate from the data stream, respectively.
Data collection and analysis system 110 gathers and analyzes information about enhanced content delivery that is distributed by system 100 to the receiver 106. System 110 typically gathers information at different points of the distribution system, e.g., at IP network 104 and at central office 105. If the media signal has been transformed (e.g., into a QAM format), the transformed signal may be converted into an IP format by converter 111. The transformed signal may be then forwarded to system 110 through IP network 104.
While application signals may be transported upstream from end-user equipment 202 (which may correspond to receiver 106) to support interactive applications, some embodiments may gather only application signals to end-user equipment 202 to verify that scheduled application signals are delivered to end-user equipment 202 at scheduled times. For example, as a revenue opportunity, operators may be deploying new enhanced television applications on a variety of different channels, for example, the Home Shopping Network (HSN). A number of such applications often focus on enhanced advertisements. The advertising enhancements may be distributed in-band or out-of-band, and the operator or content provider may have no easy way to tell whether an enhancement was actually delivered correctly and completely through the operator’s system, or run on the end user’s equipment. In order to bill for the enhanced advertisement, the operator often must verify that enhanced advertisement was correctly delivered intact to and displayed by end-user equipment 202 (e.g., set-top box, display device, smart phone, etc.).
Acquisition system 203 may monitor data streams from a converged regional area network (CRAN), at the IP level over connections 251-253 or by using converter device 207, such as a QAM-IP converter, in the RF domain over IP connection 254. In some embodiments, an IP multicast group address may be used by sources along distribution system 201 and the receiver at acquisition system 203 to send and receive content. Sources may use the group address as the IP destination address in data packets to inform the multicast group whether they are interested in receiving packets sent to that group. System 203 may gather information at different points along distribution system 201 to capture enhancement events by extracting and decoding relevant enhanced signaling, and the corresponding captured data may be stored in event database 204. It may be beneficial to gather information at different points to detect any changes or acknowledgements at different points along the network or distribution system.
Analysis system 205 then can process the captured data from events database 204 to verify integrity and, for example, to create report 206. Report 206 may assume any usable or desired format including Extensible Markup Language (XML) or HyperText Markup Language (HTML) and may represent a timeline of the enhancement events. Analysis system 205 can then compare the actual enhancement events against the expected enhancement events (for example, when the enhancement information is scheduled to be displayed at an end-user’s display device) and report any detected discrepancies. However, with some embodiments, a real time analysis and alerting system (not explicitly shown) may be located between systems 203 and 204.
Acquisition system 203 may monitor the enhancement or application in a signal or stream throughout its propagation through distribution network 201, as discussed below with reference to
Advertisement content 353 may be added on a zone-basis (e.g., a city or region) that is specific to the zone by ad splicer 303. Advertisement content 353 may or may not include enhancement content components. In some aspects of the disclosure, edge QAM unit 304 converts signals over the IP transport to signals over a RF transport (e.g., quadrature amplitude modulation) in order to deliver content 354 to end user equipment 202. Referring to
While
Decoder 403 may read packets with a PID value corresponding to ETV Integrated Signaling Stream (EISS), for example, to identify enhancement events that are detected along distribution system 201. Decoder 403 may extract and decode the ETV signaling and data activity, and verify integrity of the delivery of enhancements. Each identified enhancement event may be characterized by a start time, a stop time, and event details, e.g., application ID and organization ID as signaled in the EISS. Decoder 403 may then read packets with a resource data PID in order to load files from the data carousel (where data may be transmitted repeatedly in a standard format) and to identify corresponding enhancement sub-events based on a start time, a stop time, and enhancement sub-event details. (As will be further discussed, a sub-event is a change of the signaling of the enhancement while the enhancement stays active.) Also, location identification may be added to the event information based on the source of the decoded event information as provided to events database 204 (as shown in
An enhancement event may be a period of time during which an EISS message appears with a certain application identification (e.g., orgid/appid) with a minimal interval of x seconds. A single enhancement event may have one or more EISSs associated with it and one or more data carousels. An EISS and a data carousel may be repeated many times in normal scenarios.
An enhancement event is typically the actual enhancement, and an enhancement sub-event is a change of the signaling of the enhancement while the enhancement stays active. For example, the Home Shopping Network (HSN) may generate the same enhancement event, but different product offerings may be identified by different files on the carousel. The different carousel configurations may correspond to different enhancement sub-events.
The following are examples monitoring and/or tracking of knowing about enhancement events as may be supported by some of the embodiments. For example, an enhancement event may occur over a period of time in which an EISS message is detected with a specific application identification. A single enhancement event may be associated with one or more EISSs and one or more data carousels. An EISS and a data carousel may be repeated many times. As previously discussed in reference to
A Ford ad enhancement (application ID 121432) runs from 11:30:00AM to 11:30:30AM on BET in adzone ID 3012. A software entity (e.g., an agent) in the ETV Activity Reporting System typically knows what agent_id it is, and what transport_id it is on from its startup parameters and a database query on startup.
The agent may perform:
- Entering a new event row into the database when the EISS AUTOSTART is seen with a null end_time
- Entering a new eiss row into the database when the EISS AUTOSTART is seen with a null end_time
- Entering a new data_carousel row into the database when the DownloadInfoIndication (DII) on the data carousel is seen and
- Reading the files from the carousel,
- Performing md5 checksum
- Checking if md5sum already exists in DB
- Loading file into DB if it didn’t already exist
- Creating a carousel_to_file entry that links the file(s) to the carousel
- Updating the end_time in the previously mentioned eiss row when the EISS DESTROY is seen
- Entering a new row in the eiss table into the database with the DESTROY info
- Updating the end_time in the eiss row and in the event row when the EISS DESTROY is not seen for x seconds
Another example of an enhancement event is associated with a Home Shopping Network application. An agent typically knows what agent_id it is, and what transport_id it is on from its startup parameters and a database query on startup. The agent may perform:
- Entering a new event row into the database when the EISS AUTOSTART is seen with a null end_time
- Entering a new eiss row into the database when the EISS AUTOSTART is seen with a null end_time
- (1) Entering a new data_carousel row into the database when the first DII on the data_carousel is seen and
- Reading the files from the carousel,
- Performing md5 checksum
- Checking if md5sum already exists in DB
- Loading file into DB if it didn’t already exist
- Creating a carousel_to_file entry that links the file(s) to the carousel
- Updating the end_time in the previously mentioned data_carousel row when a new version of the DII is seen
- goto (1)
With this example, the event may never end, but there may be many different carousel, carousel_to_file, and file_data entries for this single event. However, the event may be artificially terminated at an off hour and may be later restarted.
Example 3: Enhancement EventThis example may be for a CNN application. An agent typically knows what agent_id it is, and what transport_id it is on from its startup parameters and a database query on startup. The agent may perform:
- (1) Entering a new event row into the database when the EISS AUTOSTART is seen with a null end_time
- Entering a new eiss row into the database when the EISS AUTOSTART is seen with a null end_time
- (2) Entering a new data_carousel row into the database when the first DII on the data carousel is seen and
- Reading the files from the carousel,
- Performing md5 checksum
- Checking if md5sum already exists in DB
- Loading file into DB if it didn’t already exist
- Creating a carousel_to_file entry that links the file(s) to the carousel
- Updating the end_time in the previously mentioned data_carousel row when a new version of the DII is seen
- goto (2), or goto (1) when a EISS DESTROY or PRESENT is seen
With this example, the CNN application may be seen as events that are tucked in between the commercials.
The above XML file may be compared and displayed by analysis system 205, for example using for instance the timeline widget from the Simile project (http://www.simile-widgets.org/timeline/) as shown in
Event data from database 204 may be exported to a requesting system (not explicitly shown) or may be accessed by analysis system 205 (which may be implemented as a web server) through connection 552 in order to compare the captured enhancement information with expected enhancement events. For example, system 204 may export events data as XML file 554.
Analysis system 205 may further track the captured enhancement events along distribution system 201 in order to detect possible changes or problems with any entities of distribution system 201. For example, a possible problem may be detected when an enhancement event is captured for multiplexer 301 but not for aggregation multiplexer 302, or if a program shows the ETV signature in the PMT in one location in the network but not in another. Analysis system 205 subsequently may generate report 206 that is indicative of the captured enhanced data and discrepancies between the identified enhancement events and the scheduled (expected) enhancement events through connection 553. For example, analysis system 205 may utilize Ajax (asynchronous JavaScript and XML). With Ajax, web applications may be able to retrieve data from the server asynchronously in the background without interfering with the display and behavior of the existing page.
Report 206 may be displayed on a web browser in HTML that displays a timeline of events based on the enhancement information.
Analysis system 205 compares the filtered enhancement data with the expected data at step 703. The expected data may be obtained from the scheduled transmission of enhancements (e.g., an enhanced advertisement). Analysis system 205 then determines any discrepancies between the captured enhancement information and the expected information at step 704 and generates report 206 at step 705.
The computing system apparatus 900 may include a computing device 901 wherein the processes discussed herein may be implemented. Computing device 901 may have a processor for controlling overall operation of the computing device 901 and its associated components, including memory 903 (that may include RAM and/or ROM) and a communication interface 902 such as an IP protocol communication interface.
Computing device 901 typically includes a variety of computer readable media. Computer readable media may include volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data. For example, computing device 901 may store and access enhancement data to/from data storage 204. Computer storage media include, but is not limited to, random access memory (RAM), read only memory (ROM), electronically erasable programmable read only memory (EEPROM), flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to store the desired information and that can be accessed by computing device 901.
Computing device may create report 206, as previously discussed, through a display device (not explicitly shown), communication interface to another system (not explicitly shown), through a printing device (not explicitly shown), and the like.
Embodiments may be operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well known computing systems, environments, and/or configurations that may be suitable for use with the embodiments include, but are not limited to, personal computers, server computers, handheld or laptop devices, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
Aspects of the embodiments have been described in terms of illustrative embodiments thereof. Numerous other embodiments, modifications and variations within the scope and spirit of the appended claims will occur to persons of ordinary skill in the art from a review of this disclosure. For example, one of ordinary skill in the art will appreciate that the steps illustrated in the illustrative figures may be performed in other than the recited order, and that one or more steps illustrated may be optional in accordance with aspects of the embodiments.
Although some devices and/or components may be shown separately, the devices and/or components may be combined in different ways. Conversely, while some devices and/or components may be shown in combination, the device/components may be separated in different ways.
Claims
1. A method comprising:
- receiving, by a computing device, first information indicating an advertisement delivered via a first communication format was displayed by a first user device;
- receiving, by the computing device, second information indicating the advertisement delivered via a second communication format was displayed by a second user device; and
- storing a delivery report that is associated with the advertisement and that indicates delivery of the advertisement to the first user device and to the second user device.
2. The method of claim 1, wherein the first communication format is a first communication protocol and the second communication format is a second communication protocol.
3. The method of claim 1, wherein the second information is based on information converted from the second communication format to the first communication format.
4. The method of claim 1, wherein the first communication format is an internet protocol (IP) format and the second communication format is a quadrature amplitude modulation format.
5. The method of claim 1, wherein the first information indicates the advertisement was delivered via an IP format and was displayed by a mobile device, and wherein the second information indicates the advertisement was delivered via a radio frequency signal format and was displayed by a display device associated with a set top box.
6. The method of claim 1, wherein the delivery report comprises a verification that the advertisement was delivered to the first user device and to the second user device.
7. The method of claim 1, wherein the delivery report indicates a discrepancy between an expected delivery time of the advertisement and an actual delivery time of the advertisement to one or more of the first user device or the second user device.
8. The method of claim 1, wherein the delivery report indicates whether an application signal associated with the advertisement was delivered to the first user device or to the second user device.
9. The method of claim 1, wherein the advertisement comprises one or more of:
- an application;
- interactive content; or
- enhanced content.
10. The method of claim 1, further comprising generating, based on a comparison of the first information and the second information with one or more expected characteristics of the delivery of the advertisement to the first user device and to the second user device, the delivery report.
11. An apparatus comprising:
- one or more processors; and
- memory storing instructions that, when executed by the one or more processors, configure the apparatus to: receive first information indicating an advertisement delivered via a first communication format was displayed by a first user device; receive second information indicating the advertisement delivered via a second communication format was displayed by a second user device; and store a delivery report that is associated with the advertisement and that indicates delivery of the advertisement to the first user device and to the second user device.
12. The apparatus of claim 11, wherein the first communication format is a first communication protocol and the second communication format is a second communication protocol.
13. The apparatus of claim 11, wherein the first communication format is an internet protocol (IP) format and the second communication format is a quadrature amplitude modulation format.
14. The apparatus of claim 11, wherein the first information indicates the advertisement was delivered via an IP format and was displayed by a mobile device, and wherein the second information indicates the advertisement was delivered via a radio frequency signal format and was displayed by a display device associated with a set top box.
15. The apparatus of claim 11, wherein the delivery report comprises a verification that the advertisement was delivered to the first user device and to the second user device.
16. A non-transitory computer-readable medium storing instructions that, when executed, cause:
- receiving, by a computing device, first information indicating an advertisement delivered via a first communication format was displayed by a first user device;
- receiving, by the computing device, second information indicating the advertisement delivered via a second communication format was displayed by a second user device; and
- storing a delivery report that is associated with the advertisement and that indicates delivery of the advertisement to the first user device and to the second user device.
17. The non-transitory computer-readable medium of claim 16, wherein the first communication format is a first communication protocol and the second communication format is a second communication protocol.
18. The non-transitory computer-readable medium of claim 16, wherein the first communication format is an internet protocol (IP) format and the second communication format is a quadrature amplitude modulation format.
19. The non-transitory computer-readable medium of claim 16, wherein the first information indicates the advertisement was delivered via an IP format and was displayed by a mobile device, and wherein the second information indicates the advertisement was delivered via a radio frequency signal format and was displayed by a display device associated with a set top box.
20. The non-transitory computer-readable medium of claim 16, wherein the delivery report comprises a verification that the advertisement was delivered to the first user device and to the second user device.
Type: Application
Filed: Jul 25, 2023
Publication Date: Nov 16, 2023
Inventors: Jan Van Doorn (Castle Rock, CO), Brian Field (Evergreen, CO), Daniel Groustra (Littleton, CO), Mark Torluemke (Centennial, CO), James Hamilton Hall, JR. (Centennial, CO)
Application Number: 18/358,663