This disclosure relates generally to measuring media exposure, and, more particularly, to methods and apparatus to measure exposure to streaming media.
Streaming enables media to be delivered to and presented by a wide variety of media presentation devices, such as desktop computers, laptop computers, tablet computers, personal digital assistants, smartphones, etc. A significant portion of media (e.g., content and/or advertisements) is presented via streaming to such devices.
Wherever possible, the same reference numbers will be used throughout the drawing(s) and accompanying written description to refer to the same or like parts.
The use of mobile devices (e.g., smartphones, tablets, MP3 players, etc.) to view media has increased in recent years. Initially, service providers created custom applications (e.g., apps) to display their media. As more types of mobile devices having different software requirements, versions, compatibilities, etc., entered the market, service providers began displaying streaming media in a browser of the mobile device. Consequently, many users view streaming media via the browser of their mobile device. Understanding how users interact with streaming media (e.g., such as by understanding what media is presented, how the media is presented, etc.) provides valuable information to service providers, advertisers, media providers (e.g., providers of content), manufacturers, and/or other entities.
Example methods, apparatus, systems, and articles of manufacture disclosed herein may be used to measure exposure to streaming media. Some such example methods, apparatus, and/or articles of manufacture measure such exposure based on media metadata, user demographics, and/or media device types. Some examples disclosed herein may be used to monitor streaming media transmissions received at client devices such as personal computers, tablets (e.g., an iPad®), portable devices, mobile phones, Internet appliances, and/or any other device capable of playing media. Some example implementations disclosed herein may additionally or alternatively be used to monitor playback of locally stored media in media devices. Example monitoring processes disclosed herein collect media metadata associated with media presented via media devices and associate the metadata with demographics information of users of the media devices. In this manner, detailed exposure metrics are generated based on collected media metadata and associated user demographics. As used herein, the term “metadata” is defined to be data that describes other data. In examples disclosed herein, metadata is used to describe and/or identify media. As such, metadata may be any data in any format that may be used for identifying media.
As used herein, the term “media” includes any type of content and/or advertisement (e.g., audio and/or visual (still or moving) content and/or advertisement) delivered via any type of distribution medium. Thus, media includes television programming, television advertisements, radio programming, radio advertisements, movies, web sites, streaming media, television commercials, radio commercials, Internet ads, etc. Example methods, apparatus, and articles of manufacture disclosed herein monitor media presentations at media devices. Such media devices may include, for example, Internet-enabled televisions, personal computers, Internet-enabled mobile handsets (e.g., a smartphone), video game consoles (e.g., Xbox®, PlayStation®), tablet computers (e.g., an iPad®), digital media players (e.g., a Roku® media player, a Slingbox®, etc.), etc.
Audio watermarking is a technique used to identify media such as television broadcasts, radio broadcasts, advertisements (television and/or radio), downloaded media, streaming media, prepackaged media, etc. Existing audio watermarking techniques identify media by including (e.g., embedding) one or more codes (e.g., one or more watermarks), such as media identifying information and/or an identifier that may be mapped to media identifying information, into a media signal (e.g., into an audio and/or video component of a media signal). In some examples, the audio or video component is selected to have a signal characteristic sufficient to hide the watermark. As used herein, the terms “code” or “watermark” are used interchangeably and are defined to mean any identification information (e.g., an identifier) that may be inserted in, transmitted with, or embedded in media (e.g., a program or advertisement) for the purpose of identifying the media or for another purpose such as tuning (e.g., a packet identifying header). To identify watermarked media, the watermark(s) are extracted and used to access a table of reference watermarks that are mapped to media identifying information.
Unlike media monitoring techniques based on codes and/or watermarks included with and/or embedded in the monitored media, fingerprint or signature-based media monitoring techniques generally use one or more inherent characteristics of the signal(s) representing the monitored media during a monitoring time interval to generate a substantially unique proxy for the media. Such a proxy is referred to as a signature or fingerprint, and can take any form (e.g., a series of digital values, a waveform, etc.) representative of any aspect(s) of the media signal(s)(e.g., the audio and/or video signals forming the media presentation being monitored). A good signature is one that is repeatable when processing the same media presentation, but that is unique relative to other (e.g., different) presentations of other (e.g., different) media. Accordingly, the terms “fingerprint” and “signature” are used interchangeably herein and are defined herein to mean a proxy for identifying media that is generated from one or more inherent characteristics of the media and/or the signal representing the media.
Signature-based media monitoring generally involves determining (e.g., generating and/or collecting) signature(s) representative of a media signal (e.g., an audio signal and/or a video signal) output by a monitored media device and comparing the monitored signature(s) to one or more references signatures corresponding to known (e.g., reference) media. Various comparison criteria, such as a cross-correlation value, a Hamming distance, etc., can be evaluated to determine whether a monitored signature matches a particular reference signature. When a match between the monitored signature and one of the reference signatures is found, the monitored media can be identified as corresponding to the particular reference media represented by the reference signature that matched the monitored signature. Because attributes, such as an identifier of the media, a presentation time, a broadcast channel, etc., are collected for the reference signature, these attributes may then be associated with the monitored media whose monitored signature matched the reference signature. Example systems for identifying media based on codes and/or signatures are long known and were disclosed in Thomas, U.S. Pat. No. 5,481,294, which is hereby incorporated by reference in its entirety.
As discussed above, media presented by a media device has sometimes been monitored by detecting the presence of audio watermarks. However, detection of audio watermarks can sometimes be difficult to implement. Monitoring audio watermarks using a media device is difficult because, for example, the media device may not have a microphone to detect audio watermarks, the media device may not enable programmatic access to an audio buffer, etc. Furthermore, after the audio is detected (e.g., by accessing an audio buffer, by accessing a microphone, etc.), processing the audio to detect the watermark consumes processor resources of the media device, thereby draining a battery of the media device and potentially affecting how a user uses and/or experiences the media device. Affecting how a user uses and/or experiences a media device is undesirable because it may impact the results of the monitoring effort (e.g., by monitoring changed behavior instead of behavior in the absence of monitoring). Moreover, taxing the resources of a media device may adversely affect its performance (e.g., cause slow response times, interfere with media display, and/or otherwise negatively affect the devices operation).
To enable monitoring, monitoring entities embed metadata in media to enable collection of the metadata and generation of media exposure reports. Some systems embed metadata in a closed captioning transport stream, a metadata channel of a transport stream, a separate timed text track, etc. Some such systems provide media devices with monitoring instructions to cause the media devices to return, store, and/or forward the metadata to a remote data collection site. Example systems for embedding metadata into media are described in U.S. patent application Ser. Nos. 13/341,646, 13/341,661, 13/443,596, 13/793,991, 13/445,961, 13/793,974, 13/472,170, 13/767,548, 13/793,959, and 13/778,108, which are incorporated by reference in their entirety.
Different media devices may be implemented with different browsers and/or media presentation functionality. Monitoring instructions to retrieve metadata may function differently on different media devices. Accordingly, some known media monitoring approaches are not cross-platform compatible. For example, while instructions for retrieving metadata from a metadata channel of a transport stream may function properly on a first system (e.g., an Apple iPad), they may not function properly on a second system (e.g., an Android Tablet). Maintaining different sets of instructions and/or ensuring the correct type of instructions are provided to the correct type of device is a very difficult technical problem. Example systems, methods, and apparatus disclosed herein overcome this problem by enabling a single set of monitoring instructions to be operated on multiple different devices and/or browsers. In examples disclosed herein, metadata is included with (e.g., embedded into) media by inserting the metadata formatted as a string into a file containing the media.
In some examples, the media identifying data (e.g., a code, a signature, a watermark, a fingerprint, etc.) having a first format is extracted at a service provider headend or the like from media decoded from a transport stream. In some such examples, the transport stream corresponds to a Moving Picture Experts Group (MPEG) 4 transport stream sent according to a hypertext transfer protocol (HTTP) live streaming (HLS) protocol. An example of media identifying data having the first format is an audio watermark that is embedded in an audio portion of the media. Additionally or alternatively, the media identifying data having the first format may be a video (e.g., image) watermark that is embedded in a video portion of the media. In some examples, the extracted media identifying data having the first format is transcoded into media identifying data having a second format. The media identifying data having the second format may correspond to, for example, metadata represented in a string format, such as an ID3 tag for insertion into a file containing the media.
Some example methods disclosed herein to monitor streaming media include inspecting a media file received at a consumer media device from a service provider. These example methods also include generating media presentation data for reporting to an audience measurement entity. As used herein, media presentation data includes metadata extracted from media (e.g., media identifying data) and/or other parameters related to the media presentation such as, for example, a playback position within the media, a duration of the media, a source of the media (e.g., a universal resource locator (URL) of a service provider, a name of a service provider, a channel, etc.), metadata of the media presenter (e.g., a display size of the media, a volume setting, etc.) a timestamp, a user identifier, and/or device identifier, etc.
In some examples, media presentation data is aggregated to determine ownership and/or usage statistics of media devices, relative rankings of usage and/or ownership of media devices, types of uses of media devices (e.g., whether a device is used for browsing the Internet, streaming media from the Internet, etc.), and/or other types of media device information. In some examples, media presentation data is aggregated to determine audience size(s) of different media, demographics associated with audience(s) of different media, etc. In some other examples, the aggregated device oriented information and the aggregated audience oriented information of the above examples are combined to identify audience sizes, demographics, etc. for media as presented on different type(s) of devices. In examples disclosed herein, media presentation data includes, but is not limited to, media identifying information (e.g., media-identifying metadata, codes, signatures, watermarks, and/or other information that may be used to identify presented media), application usage information (e.g., an identifier of an application, a time and/or duration of use of the application, a rating of the application, etc.), and/or user-identifying information (e.g., demographic information, a user identifier, a panelist identifier, a username, etc.). “Applications” are sometimes referred to as “apps”.
In some disclosed examples, streaming media is delivered to the media device using HTTP Live Streaming (HLS). However, any other past, present, and/or future method of streaming media to the media device may additionally or alternatively be used such as, for example, an HTTP Secure (HTTPS) protocol. HLS transport streams allow media to be transmitted to the media device in short duration segments (e.g., three second segments, five second segments, thirty second segments, etc.). In some disclosed examples, a media device uses a browser to display media received via HLS. To present the media, the example media device presents each sequential segment in sequence. Additionally or alternatively, in some disclosed examples the media device uses a media presenter (e.g., a browser plugin, an app, a framework, an application programming interface (API), etc.) to display media received via HLS.
The media provider 110 of the illustrated example of
The service provider 120 of the illustrated example of
In the illustrated example, the transcoder 122 employs any appropriate technique(s) to transcode and/or otherwise process the media received from the media provider 110 into a form suitable for streaming (e.g., a streaming format). For example, the transcoder 122 of the illustrated example transcodes the media in accordance with MPEG 4 audio/video compression for use via the HLS protocol. However, any other format may additionally or alternatively be used. In examples disclosed herein, the transcoder 122 transcodes the media into a binary format for transmission to the media device 160. To prepare the media for streaming, in some examples, the transcoder 122 segments the media into smaller portions implemented by MPEG4 files. For example, a thirty second piece of media may be broken into ten segments (MPEG4 files), each being three seconds in length.
The example media identifier 125 of
The example media identifier 125 of
In the illustrated example, the metadata inserter 135 inserts the metadata determined by the media identifier 125 into one or more of the media segments. In the illustrated example, the metadata inserter 135 converts the metadata to a binary format for insertion in each respective media segment. In the illustrated example, the metadata inserter 135 prepends a metadata start section to the metadata and appends a metadata stop section to the metadata. Example metadata start and stop sections are shown in the illustrated example of
In the illustrated example, the metadata inserter 135 inserts metadata corresponding to the media identifying data into the segmented media files (e.g., the MPEG4 files) that are to stream the media in accordance with the HLS or other appropriate streaming protocol. Accordingly, when the media segments are transmitted to the media device 160 for presentation, the metadata is included in a format that is readable by JavaScript instructions and, in some examples, does not require interaction with a media presenter for retrieval of metadata.
The media transmitter 140 employs any appropriate technique(s) to select and/or stream the media segments to a requesting device, such as the media device 160. For example, the media transmitter 140 of the illustrated example selects one or more media segments in response to a request for the one or more segments by the media device 160. The media transmitter 140 then streams the media to the media device 160 via the network 150 using HLS or any other streaming protocol. In some examples, when transmitting the media to the media device 160, the media transmitter 140 includes instructions for extracting the metadata from the media. The instructions may be located within a webpage transmitted to the media device 160. Moreover, the instructions may be transmitted in a separate instruction document transmitted in association with the webpage to the media device 160.
In some examples, the media identifier 125, the transcoder 122, and/or the metadata inserter 135 prepare media for streaming regardless of whether (e.g., prior to) a request is received from the client device 160. In such examples, the already-prepared media is stored in a data store of the service provider 120 (e.g., such as in a flash memory, magnetic media, optical media, etc.). In such examples, the media transmitter 140 prepares a transport stream for streaming the already-prepared media to the client device 160 when a request is received from the client device 160. In other examples, the media identifier 125, the transcoder 122, and/or the metadata inserter 135 prepare the media for streaming in response to a request received from the client device 160.
The example network 150 of the illustrated example is the Internet. Additionally or alternatively, any other network(s) communicatively linking the service provider 120 and the client device such as, for example, a private network, a local area network (LAN), a virtual private network (VPN), etc. may be used. The network 150 may comprise any number of public and/or private networks using any type(s) of networking protocol(s).
The media device 160 of the illustrated example of
In the illustrated example, the media monitor 165 interacts with the media presenter 162 to identify the metadata. The example media monitor 165 identifies media presentation data. As noted above, media presentation data includes metadata extracted from media (e.g., media identifying data) as well as other parameters related to the media presentation such as, for example, a playback position within the media, a duration of the media, a source of the media (e.g., a universal resource locator (URL) of a service provider, a name of a service provider, a channel, etc.), a timestamp, a user and/or device identifier, etc. In the illustrated example, the media monitor 165 reports media presentation data to the central facility 170. While a single media device 160 is illustrated in
The central facility 170 of the audience measurement entity of the illustrated example of
HLS is an adaptive format, in that, although multiple devices retrieve the same manifest 210, different media files and/or transport streams may be displayed depending on one or more factors. For example, devices having different bandwidth availabilities (e.g., a high speed Internet connection, a low speed Internet connection, etc.) and/or different display abilities (e.g., a small size screen such as a cellular phone, a medium size screen such as a tablet and/or a laptop computer, a large size screen such as a television, etc.) select an appropriate transport stream for their display and/or bandwidth abilities. In some examples, a cellular phone having a small screen and limited bandwidth uses a low-resolution transport stream. Alternatively, in some examples, a television having a large screen and a high speed Internet connection uses a high-resolution transport stream. As the abilities of the device change (e.g., the device moves from a high-speed Internet connection to a low speed Internet connection) the device may switch to a different transport stream.
In the illustrated example of
In the illustrated example of
In some examples, the metadata section 320 may include the metadata start section 315 and/or the metadata stop section 325. In the illustrated example, the metadata start section 315 and the metadata stop section 325 form a property list (.plist) around the metadata. However, any other format of the metadata start section 315 and/or the metadata stop section 325 may additionally or alternatively be used. The format of the metadata start section 315 and/or the metadata stop section 325 may depend on the type of media file being played and/or on the media presenter that is presenting the media file. For example, rather than implementing a metadata section, a comment section may be implemented.
The example position determiner 405 determines a current position of media presentation within media. As used herein, the current position represents a temporal offset (e.g., a time) from a start of the media (e.g., zero seconds, five seconds, ten seconds, etc.). In the illustrated example, the current position is measured in seconds. However, any other measure of time may additionally or alternatively be used, such as, for example, minutes, milliseconds, hours, etc. Moreover, any way of identifying a current position within a media presentation may additionally or alternatively be used, such as, for example, a video frame identifier of the media, etc. In particular, in the illustrated example, the example position determiner 405 identifies the current position by interacting with the media presenter 162. In the illustrated example, the position determiner 405 is implemented by a JavaScript instruction(s) to retrieve the current position from the media presenter 162. In the illustrated example, the JavaScript instruction(s) are transmitted to the media device 160 as part of a webpage that includes an instruction (e.g., a link, a Hypertext Markup Language (HTML) tag, etc.) instructing the media device to display the media. An example webpage including JavaScript instructions to implement the example position determiner 405 is shown in
The example duration determiner 407 of this example determines a duration of the media. In the illustrated example, the duration determiner 407 is implemented by a JavaScript instruction which, when executed, queries the media presenter 162 for the duration of the media. In the illustrated example, the JavaScript instruction(s) are transmitted to the media device 160 as part of a webpage that includes an instruction (e.g., a link, a Hypertext Markup Language (HTML) tag, etc.) instructing the media device to display the media. An example webpage including JavaScript instructions to implement the example duration determiner 407 is shown in
The example source determiner 410 of the illustrated example of
The example state determiner 415 of the illustrated example of
The example metadata processor 420 of the illustrated example of
The example media accesser 425 of the illustrated example of
The example media converter 430 of the illustrated example of
The example metadata locator 435 of the illustrated example inspects the text-formatted media converted by the media converter 430. In the illustrated example, the example metadata locator 435 inspects the text-formatted media for a start location of a metadata tag. In the illustrated example, the start location of the metadata tag represents a character within the text-formatted media where the metadata can be found. Referring to
The example metadata extractor 440 of the illustrated example of
The example timestamper 445 of the illustrated example of
The example transmitter 450 of the illustrated example of
In the illustrated example, the media presentation data is transmitted to the central facility using a Hypertext Transfer Protocol (HTTP) Post request. However, any other method of transmitting data and/or metadata may additionally or alternatively be used. Because, in the illustrated example, an HTTP request is used, the transmitter 450 may include cookie data that identifies a user and/or a device that is transmitting the media presentation data (assuming the transmission is to an Internet domain that has set such a cookie). As such, the central facility 170 can identify the user and/or the device as associated with the media presentation. In some examples, the users are panelists and the cookie data that includes the user and/or device identifier is set by the central facility 170 to enable instances of monitored media presentation data to be associated with the panelist. However, in some other examples, the users are not panelists and the demographic information is determined via other approaches, such as those described in Mazumdar, U.S. Pat. No. 8,370,489, which is hereby incorporated by reference in its entirety.
While in the illustrated example an HTTP Post request is used to convey the media presentation data to the central facility 170, any other approach to transmitting data may additionally or alternatively be used such as, for example, a file transfer protocol (FTP), an HTTP Get request, Asynchronous JavaScript and extensible markup language (XML) (AJAX), etc. In some examples, the media presentation data is not transmitted to the central facility 170. Additionally or alternatively, the media presentation data may be transmitted to a display object of the client device 160 for display to a user. In the illustrated example, the media presentation data is transmitted in near real-time (e.g., streamed) to the central facility 170. As used herein, near real-time transmission is defined to be transmission of data (e.g., the media presentation data) within a short time duration (e.g., one minute) of the identification, generation, and/or detection of the data. However, in some examples, the media presentation data may be stored (e.g., cached, buffered, etc.) for a period of time before being transmitted to the central facility 170.
In the illustrated example of
When the “LoadTs” function (block 511) is called, the example position determiner 405 identifies a current time and/or position within the media (block 515). In the illustrated example, the instruction of block 515 implements the example position determiner 405 and causes a request for the current position within the media to be transmitted to the media presenter 162 that is displaying the video element of block 505. The media presenter 162 responds by determining a time associated with a frame of the media that is currently presented and providing the time to the example position determiner 405.
The example duration determiner 407 identifies a duration of the media (block 520). In the illustrated example, the instruction of block 520 implements the example position determiner 407 and causes a request for the duration of the media to be transmitted to the media presenter 162 that is displaying the video element of block 505. The media presenter 162 responds by determining a time associated with a final frame of the media, and providing the time to the example duration determiner 407.
The example source determiner 410 identifies a source of the media (block 525). In the illustrated example, the instruction of block 525 implements the example source determiner 410 and causes a request for a source universal resource locator (URL) of the media to be transmitted to the media presenter 162 that is displaying the video element of block 505. In the illustrated example, the media presenter responds to the request by performing a lookup of the source URL of the media it is presenting and providing the source URL to the example source determiner 410. However, in some examples, the source determiner 410 may directly inspect the video element of block 505 to identify the source of the media.
The example state determiner 415 identifies a state of the media presenter 162 (block 530). In the illustrated example, the instruction of block 530 implements the example state determiner 415 and causes a request for a current state of the media (e.g., playing, not playing, fast-forwarding, etc.) to be transmitted to the media presenter 162 that is displaying the video element of block 505. In the illustrated example, the example media presenter 162 responds to the request by determining the current state (e.g., mode of operation) of the media presenter 162 and providing the state to the example state determiner 415. However, any other approach to identifying a state of a media presentation may additionally or alternatively be used such as, for example, using image processing techniques to identify whether a play button or a pause button is displayed as part of the video element of block 505. Example systems for identifying a state of a media presentation are disclosed in co-pending U.S. patent application Ser. Nos. 12/100,264 and 12/240,756, which are hereby incorporated by reference in their entirety.
The example media accesser 425 accesses the media by transmitting a request to the media presenter 162 for access to a media buffer. When access is provided, the example media accesser 425 is permitted to read memory locations of the media device 160 allocated to the media presenter 162. In some other examples, the media presenter 162 reads the memory locations on behalf of the media accesser 425 and responds to a request for access to the media with the data contained in the media buffer. The example media accesser 425 instructs the media converter 430, the metadata locator 435, and/or the metadata extractor to determine the metadata (block 535). In the illustrated example, a dataview is used to access the media from the media presenter 162. A dataview is a JavaScript view that provides a low-level interface for reading data from and writing data to a buffer. However, any other approach to accessing the media may additionally or alternatively be used. In the illustrated example, the dataview represents a binary version of the media. The example media converter 430 converts the binary version of the media to a text format (block 540). For example, if the media has a length of two hundred thousand bits, the example media converter 430 may convert the media to a text format using an American Standard Code for Information Interchange (ASCII) eight bit character encoding scheme to result in a string having twenty five thousand characters. However, in some examples, the example media converter 430 converts a part of the media because, for example, it is assumed that the metadata section is within a particular section of the media. For example, the example media converter 430 may convert the first one hundred and sixty thousand bits (e.g., out of two hundred thousand bits) of the binary version of the media to the text format, resulting in a string having twenty thousand characters of eight bits in length. However, any other conversion technique, character encoding schema, and/or text format may additionally or alternatively be used.
The example metadata locator 435 searches through the media to identify the start location of the metadata. (block 545). In the illustrated example, the instructions of block 545 cause the example metadata locator 435 to search for the characters “META” as an indication of the start of the metadata. The example metadata extractor 440 extracts the metadata from the converted media using the identified start location. (block 550). In the illustrated example, the instructions of block 550 cause the metadata extractor to seeks to the identified start location of the metadata within the media, and extract the next forty characters. However, any other approach to extracting metadata may additionally or alternatively be used. For example, pattern recognition (e.g., a regular expression) may be used to extract the metadata. Moreover, while in the illustrated example, the metadata has a fixed length of forty characters, any other length of metadata may additionally or alternatively be used. Furthermore, the metadata may not be a fixed length and may, instead be a variable length. Moreover, the start identifier “META” may be replaced with any other descriptor.
The example timestamper 445 determines a current time indicative of a date and/or time that the media presentation data was gathered. (block 555). The example transmitter 450 then transmits the media presentation data (e.g., the current time, the duration, the source location, the media presentation state, the metadata, the timestamp, etc.) to the central facility. (block 560). In the illustrated example, the example instructions of block 560 cause the transmitter 450 to transmit the media presentation data using an HTTP request. The example transmitter 450 includes a user and/or device identifier in a header of the HTTP request to identify a user of the media device 160 and/or the media device 160 itself. In some examples, the example transmitter 450 embeds the user and/or device identifier in the media presentation data. In the illustrated example, the example media presentation data is transmitted in a JavaScript Object Notation (JSON) format. The JSON format is a data structure format that is used for data interchanging and results in organized data that is easy to parse when transmitted to the central facility 170. However, any other format may additionally or alternatively be used.
While an example manner of implementing the example service provider 120 is illustrated in
A flowchart representative of example machine readable instructions for implementing the example service provider of
As mentioned above, the example processes of
The media identifier 125 of the illustrated example then identifies the media (block 630). In the illustrated example, the example media identifier 125 operates on the transcoded media. However, in some examples, the example media identifier 125 operates on the media prior to transcoding. The media identifier 125 of the illustrated example identifies the media by extracting media identifying data (e.g., signatures, watermarks, etc.) from the media. Based on the extracted media identifying data, the media identifier 125 generates metadata (block 640). In the illustrated example, the metadata is generated using an ID3 formatted string. However, any other metadata format may additionally or alternatively be used. Further, in the illustrated example, the metadata is generated based on the extracted media identifying data. However, in some examples, the metadata may be generated by querying an external source using some or all of the extracted media identifying data.
The metadata inserter 135 of the service provider 120 embeds the metadata into the media (block 650). In the illustrated example, the metadata is converted into a binary format and inserted into the binary formatted media. In some examples, the metadata inserter 135 embeds a metadata start section as a prefix to the metadata and a metadata stop section as a suffix to the metadata.
The media is then transmitted by the media transmitter 140 of the service provider 120 (block 660). In the illustrated example, the media is transmitted using HTTP live streaming (HLS). However, any other format and/or protocol for transmitting (e.g., broadcasting, unicasting, multicasting, etc.) media may additionally or alternatively be used.
If media presentation data is to be gathered (block 710) the example position determiner 405 determines a current position within the media (block 720). The example position determiner 405 determines the current position within the media by interacting with the media presenter 162. In the illustrated example, the position determiner 405 executes a JavaScript instruction to retrieve the current position from the media presenter 162. However, any other way of identifying a current position of media presentation within media may additionally or alternatively be used.
The example duration determiner 407 determines a duration of the media. (block 725) In the illustrated example, the duration determiner 407 determines the duration by querying the media presenter 162 for the duration of the media. However, any other approach to identifying a duration of media may additionally or alternatively be used such as, for example, processing a screenshot of the media presenter to identify a duration text (e.g., 5:06, representing media that is five minutes and six seconds in duration).
The example source determiner 410 interacts with the example media presenter 162 to identify a source of the media. (block 730). In the illustrated example, the source of the media is identified by a universal resource locator (URL). However, any other source descriptor may additionally or alternatively be employed (e.g., a name of the service provider 120, a name of the media provider 110, etc.) The example source determiner 410 retrieves the URL through the media presenter 162. In some examples, rather than interacting with the media presenter 162 (e.g., a QuickTime plugin of a browser), the example source determiner 410 is implemented using JavaScript instructions (e.g., the example JavaScript instructions of the example webpage of
The example state determiner 415 interacts with the example media presenter 162 to identify a state of the media presentation. (block 740). In the illustrated example, the example state determiner 415 queries the media presenter 162 for the state of the media presentation. However, any other approach may additionally or alternatively be used such as, for example, processing an image of the media presenter to, for example, detect a presence of a play icon, a presence of a pause icon, etc.
The example metadata processor 420 accesses metadata inserted in the media. (block 750). An example procedure for accessing the inserted metadata is described below in connection with
The example timestamper 445 generates a timestamp indicative of a date and/or time that the media presentation data was gathered. (block 760). In the illustrated example, the timestamper 445 determines the date and/or time using a clock of the media device 160. However, in some examples, the timestamper 445 determines the data and/or time by requesting the date and/or time from an external time source, such as a National Institute of Standards and Technology (NIST) Internet Time Service (ITS) server. However, any other approach to determining a timestamp may additionally or alternatively be used.
The example transmitter 450 transmits the gathered media presentation data (e.g., the position information, the duration information, the source information, the state information, the inserted metadata, and a timestamp) to the central facility 170. (block 770) In the illustrated example, the media presentation data is transmitted to the central facility 170 using an HTTP Post request. However, any other method of transmitting data and/or metadata may additionally or alternatively be used. Because, in the illustrated example, an HTTP request is used, the transmitter 450 includes cookie data that identifies a user and/or a device that is transmitting the media presentation data. In some examples, the users are panelists and the user and/or device identifier conveyed by the cookie data is known and/or set by the central facility 170. The user and/or device identifier enables the central facility 170 to identify demographic information associated with the user and/or device. However, in some other examples, the users are not panelists and the demographic information is determined via other approaches, such as those described in Mazumdar, U.S. Pat. No. 8,370,489, which is hereby incorporated by reference in its entirety. As such, the central facility 170 can identify the user and/or the device as associated with the media presentation. While in the illustrated example an HTTP Post request is used, any other approach to transmitting data may additionally or alternatively be used.
If the media is not accessible (block 810), the example media accesser 425 determines whether metadata is already known for the media. (block 815). In some examples, metadata may be stored in a cache accessible to the media monitor 165 prior to transmitting the metadata to the central facility 170. The cache may be inspected to determine whether metadata from a previous metadata extraction is available. Metadata may already be known for the media if, for example, the media was previously viewed using a different media presenter, the media presenter recently provided the media to the media accesser 425 but has since malfunctioned, etc. If metadata is already known for the media, the media accesser 425 determines whether the metadata should be re-gathered. (block 825). In some examples, the known metadata may not be current. That is, the known metadata may have been associated with media that was presented more than a threshold period of time ago (e.g., more than ten minutes ago, more than one day ago, etc.). If the metadata is current, the known metadata for the media source is returned as the media for the media source. (block 830).
If the metadata is (1) not known (block 815), or (2) known, but not current (block 825), the metadata is re-gathered. To this end, the example media accesser 425 of the illustrated example accesses the media from the source identified by the source determiner 410 (block 820). In such an implementation, the media may be transmitted to the media device 160 more than once. While such re-transmission does use additional bandwidth, because the media is transmitted using small HLS segments (e.g., three second segments), the effect of such re-transmission is negligible. Moreover, by determining whether the metadata is already known for the media source (block 815) and/or determining whether the metadata is current (block 825), the example media accesser 425 reduces the amount of bandwidth required by selectively requiring re-transmission only when necessary.
Once the media is accessed (e.g., via the media presenter 162 (block 810), via the source identified by the source determiner 410 (block 820), etc.), the example media converter 430 converts the media accessed by the media accesser 425 into a string representation. As described above, the media accesser 425 accesses the media in a binary format. However, the metadata embedded in the media is embedded in a text (e.g., string) format. In the illustrated example, the example media converter 430 converts the media from a binary format to a text format. In the illustrated example, the media converter 430 converts the binary data into a text format using an American Standard Code for Information Exchange (ASCII) format. However, any other format may additionally or alternatively be used.
The example metadata locator 435 inspects the text formatted media converted by the media converter 430. (block 840). In the illustrated example, the example metadata locator 435 inspects the text formatted media for a start location of a metadata tag. In the illustrated example, the start location of the metadata tag represents a character within the text formatted media where the metadata can be found. Referring to the example of
The example metadata extractor 440 extracts the metadata from the converted media based on the identified location of the metadata identified by the metadata locator 435. (block 845) In the illustrated example, the metadata is a fixed length (e.g., forty characters). As such, the example metadata extractor 440 extracts a string from the metadata starting from the start location and matching the predefined fixed length of the metadata. However, in some examples, the metadata is a variable length. In some examples, the example metadata extractor 440 determines a length of the metadata and extracts the metadata based on the identified length. The example metadata extractor 440 returns the extracted metadata to the metadata processor 420 for reporting via the transmitter 450 as part of the media presentation data. (block 850).
The processor platform 120 of the illustrated example includes a processor 912. The processor 912 of the illustrated example is hardware. For example, the processor 912 can be implemented by one or more integrated circuits, logic circuits, microprocessors, or controllers from any desired family or manufacturer.
The processor 912 of the illustrated example includes a local memory 913 (e.g., a cache), and executes instructions to implement the example transcoder 122, the example media identifier 125, and the example metadata inserter 135. The processor 912 of the illustrated example is in communication with a main memory including a volatile memory 914 and a non-volatile memory 916 via a bus 918. The volatile memory 914 may be implemented by Synchronous Dynamic Random Access Memory (SDRAM), Dynamic Random Access Memory (DRAM), RAMBUS Dynamic Random Access Memory (RDRAM) and/or any other type of random access memory device. The non-volatile memory 916 may be implemented by flash memory and/or any other desired type of memory device. Access to the main memory 914, 916 is controlled by a memory controller.
The processor platform 120 of the illustrated example also includes an interface circuit 920. The interface circuit 920 may be implemented by any type of interface standard, such as an Ethernet interface, a universal serial bus (USB), and/or a PCI express interface.
In the illustrated example, one or more input devices 922 are connected to the interface circuit 920. The input device(s) 922 permit(s) a user to enter data and commands into the processor 912. The input device(s) can be implemented by, for example, an audio sensor, a microphone, a camera (still or video), a keyboard, a button, a mouse, a touchscreen, a track-pad, a trackball, and/or a voice recognition system.
One or more output devices 924 are also connected to the interface circuit 920 of the illustrated example. The output devices 924 can be implemented, for example, by display devices (e.g., a light emitting diode (LED), an organic light emitting diode (OLED), a liquid crystal display, a cathode ray tube display (CRT), a touchscreen, a tactile output device, a printer and/or speakers). The interface circuit 920 of the illustrated example, thus, typically includes a graphics driver card, a graphics driver chip or a graphics driver processor.
The interface circuit 920 of the illustrated example also includes a communication device such as a transmitter, a receiver, a transceiver, a modem and/or network interface card to facilitate exchange of data with external machines (e.g., computing devices of any kind) via a network 926 (e.g., an Ethernet connection, a digital subscriber line (DSL), a telephone line, coaxial cable, a cellular telephone system, etc.). The interface circuit 920 implements the example media transmitter 140.
The processor platform 120 of the illustrated example also includes one or more mass storage devices 928 for storing software and/or data. Examples of such mass storage devices 928 include floppy disk drives, hard drive disks, compact disk drives, Blu-ray disk drives, RAID systems, and digital versatile disk (DVD) drives.
The coded instructions 932 of
The processor platform 160 of the illustrated example includes a processor 1012. The processor 1012 of the illustrated example is hardware. For example, the processor 1012 can be implemented by one or more integrated circuits, logic circuits, microprocessors, or controllers from any desired family or manufacturer.
The processor 1012 of the illustrated example includes a local memory 1013 (e.g., a cache), and executes instructions to implement the example position determiner 405, the example duration determiner 407, the example source determiner 410, the example state determiner 415, the example metadata processor 420, the example media accesser 425, the example media converter 430, the example metadata locator 435, the example metadata extractor 440, and the example timestamper 445. The processor 1012 of the illustrated example is in communication with a main memory including a volatile memory 1014 and a non-volatile memory 1016 via a bus 1018. The volatile memory 1014 may be implemented by Synchronous Dynamic Random Access Memory (SDRAM), Dynamic Random Access Memory (DRAM), RAMBUS Dynamic Random Access Memory (RDRAM) and/or any other type of random access memory device. The non-volatile memory 1016 may be implemented by flash memory and/or any other desired type of memory device. Access to the main memory 1014, 1016 is controlled by a memory controller.
The processor platform 160 of the illustrated example also includes an interface circuit 1020. The interface circuit 1020 may be implemented by any type of interface standard, such as an Ethernet interface, a universal serial bus (USB), and/or a PCI express interface.
In the illustrated example, one or more input devices 1022 are connected to the interface circuit 1020. The input device(s) 1022 permit(s) a user to enter data and commands into the processor 912. The input device(s) can be implemented by, for example, an audio sensor, a microphone, a camera (still or video), a keyboard, a button, a mouse, a touchscreen, a track-pad, a trackball, and/or a voice recognition system.
One or more output devices 1024 are also connected to the interface circuit 1020 of the illustrated example. The output devices 1024 can be implemented, for example, by display devices (e.g., a light emitting diode (LED), an organic light emitting diode (OLED), a liquid crystal display, a cathode ray tube display (CRT), a touchscreen, a tactile output device, a printer and/or speakers). The interface circuit 1020 of the illustrated example, thus, typically includes a graphics driver card, a graphics driver chip or a graphics driver processor.
The interface circuit 1020 of the illustrated example also includes a communication device such as a transmitter, a receiver, a transceiver, a modem and/or network interface card to facilitate exchange of data with external machines (e.g., computing devices of any kind) via a network 1026 (e.g., an Ethernet connection, a digital subscriber line (DSL), a telephone line, coaxial cable, a cellular telephone system, etc.). The interface circuit 920 implements the example transmitter 450.
The processor platform 160 of the illustrated example also includes one or more mass storage devices 1028 for storing software and/or data. Examples of such mass storage devices 1028 include floppy disk drives, hard drive disks, compact disk drives, Blu-ray disk drives, RAID systems, and digital versatile disk (DVD) drives.
The coded instructions 1032 of
From the foregoing, it will be appreciated that methods, apparatus and articles of manufacture have been disclosed which enable measurement of exposure to streaming media. Example approaches disclosed herein enable collection of media presentation data upon loading of the media. These example approaches are beneficial over prior known systems because they enable detection of media that is not yet presented, as compared to detecting media once it is presented (e.g., after presentation begins). This is useful because, for example, it enables monitoring of media that was available for presentation to a user, but the user did not begin presentation.
Moreover, example methods, apparatus, and articles of manufacture disclosed herein reduce processing requirements as compared with known systems for accessing metadata associated with media. Some known systems for accessing media identifying information at a consumer's media device require the consumer's media device to process the media to extract a code, signature, watermark, etc. from the media itself. Such extraction is a processor intensive task which consumes time, battery power, etc., and when performed by a media device with limited processing resources potentially causes the consumer's device to perform poorly. Accessing the metadata by converting the media from a binary to a string format reduces the processing requirements of the consumer media device, thereby reducing the amount of time, battery power, etc. consumed by the monitoring efforts of the media device. Such reduced processing requirements enhance battery life because less processing power is required to operate the media device to monitor media.
Some other known systems require the media device to access metadata supplied with media by, for example, inspecting a timed text track, inspecting a metadata channel of the media, inspecting an encryption key of the media, etc. However, access to such metadata is not implemented consistently across various platforms (e.g., different operating systems, different browsers, etc.). For some platforms, access to such information (e.g., via a metadata channel, via a timed text track, etc.) is prohibited. The example methods, apparatus, and articles of manufacture disclosed herein present a cross-platform approach, as JavaScript instructions are reliably executed by a large variety of different media devices. Implementing monitoring instructions as JavaScript instructions results in a wider range of users who may be monitored, including users who are not panelists. Monitoring users who are not panelists further results in less missed instances where media monitoring would occur.
Moreover, the example methods, apparatus, and articles of manufacture disclosed herein, while attempting to interface with an Application Programming Interface (API) of a media presenter (e.g., a QuickTime plugin of a browser), is not reliant on such access. As disclosed above, when the media monitor detects that access to the media is not granted (e.g., the QuickTime plugin does not grant access to the media), the example media monitor may re-download the media for metadata analysis. Moreover, in some examples, the media monitor determines whether the metadata for the media to be re-downloaded is already known. In such an example, bandwidth requirements of the media device are reduced because the media monitor does not re-download media unless the metadata associated with the media is unknown. Such an approach is not reliant on the media presenter (e.g., QuickTime, Flash, etc.), and ensures that media presentations are reliably monitored. Because less instances where media monitoring would occur are missed (i.e., more instances are monitored), less projection and/or extrapolation is required to prepare reports about the media. These reduced projections and/or extrapolations result in reduced processing and/or memory requirements of the central facility that crates the reports.
Although certain example methods, apparatus and articles of manufacture have been disclosed herein, the scope of coverage of this patent is not limited thereto. On the contrary, this patent covers all methods, apparatus and articles of manufacture fairly falling within the scope of the claims of this patent.