This disclosure relates generally to media monitoring and, more particularly, to signature retrieval and matching for media monitoring.
A media monitoring system typically includes one or more device meters to monitor the media presented by one or more media devices located at one or more monitored sites. Such a device meter can use watermarks decoded from the presented media and/or signatures (also referred to as media fingerprints or just fingerprints) generated from the presented media, or both, to monitor (e.g., identify and/or track) the media being presented by a media device. For example, identification codes, such as watermarks, ancillary codes, etc., may be transmitted within media signals. Identification codes are data that are transmitted with media (e.g., inserted into the audio, video, or metadata stream of media) to uniquely identify broadcasters and/or the media (e.g., content or advertisements), and/or are associated with the media for another purpose, such as tuning (e.g., packet identifier headers (“PIDs”) used for digital broadcasting). Codes are typically extracted using a decoding operation.
In contrast, signatures are a representation of some characteristic of the media signal (e.g., a characteristic of the frequency spectrum of the signal). Signatures can be thought of as fingerprints. They are typically not dependent upon insertion of identification codes in the media but, instead, preferably reflect an inherent characteristic of the media and/or the signal transporting the media. Systems to utilize codes and/or signatures for audience measurement are long known. See, for example, Thomas, U.S. Pat. No. 5,481,294, which is hereby incorporated by reference in its entirety.
When signatures are used for media monitoring, signatures of the monitored media (referred to herein as site signatures) are generated by the device meter and compared to reference signatures representative of reference media known to the media monitoring system. When a match is found, the media corresponding to the site signature being processed can be identified as corresponding to the reference media represented by the matching reference signature(s). In many media monitoring systems, the device meters provide their generated site signatures to a data processing facility or other centralized processing site for comparison with the reference signatures that are representative of the reference media available for presentation at the respective monitored sites. Such comparison may involve comparing large numbers of site signatures with large numbers of reference signatures, especially when the number of monitored sites is large and/or the amount of possible reference media available for consumption is large.
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, elements, etc.
Methods, apparatus, systems and articles of manufacture (e.g., physical storage media, structures, etc.) to perform signature retrieval and matching for media monitoring are disclosed herein. Some example signature retrieval and matching methods disclosed herein include querying a first table using a first site signature obtained from a monitored site. For example, the first table can include hash keys corresponding to respective reference signatures, and can further include respective qualifier data descriptive of respective ones of the reference signatures (and/or descriptive of reference media represented by the respective ones of the reference signatures). Such example methods can also include querying a second table using first qualifier data obtained from querying the first table using the first site signature. For example, the first qualifier data can be descriptive of a first reference signature (and/or first reference media represented by the first reference signature) corresponding to a first hash key determined to match the first site signature. Such example methods can further include comparing a first block of site signatures with a portion of a plurality of blocks of reference signatures obtained from querying the second table using the first qualifier data.
In some such examples, the first qualifier data includes a first timestamp associated with a first block of reference signatures including the first reference signature. In some such examples, the first qualifier data also includes first media identification data identifying first reference media represented by the first reference signature.
In some such examples, the plurality of blocks of reference signatures obtained from querying the second table using the first qualifier data include: (1) the first block of reference signatures representative of the first reference media and associated with the first timestamp, (2) a second block of reference signatures representative of the first reference media and associated with a second timestamp preceding the first timestamp, and (3) a third block of reference signatures representative of the first reference media and associated with a third timestamp following the first timestamp. In some such examples, the first qualifier data further includes a first offset specifying a position of the first reference signature in the first block of reference signatures, and the first block of site signatures includes neighboring site signatures of the first site signature. Some such example methods further include aligning the first block of site signatures with a portion of the first, second and third blocks of reference signatures based on the offset. Such example methods can also include comparing the first block of site signatures with the portion of the first, second and third blocks of reference signatures.
Additionally or alternatively, in some such examples, the first reference signature is representative of first reference media, and the plurality of blocks of reference signatures is a first plurality of blocks of reference signatures representative of the first reference media. Some such example methods further include querying the second table using second qualifier data obtained from querying the first table using the first site signature. For example, the second qualifier data can be descriptive of a second reference signature corresponding to a second hash key determined to match the first site signature, and the second reference signature can be representative of second reference media. Such example methods can also include comparing the first block of site signatures with a portion of a second plurality of blocks of reference signatures obtained from querying the second table using the second qualifier data. For example, the second plurality of blocks of reference signatures can be representative of the second reference media.
Additionally or alternatively, some such example methods can also include obtaining the first hash key, the first qualifier data and first value data associated with the first hash key in response to querying the first table using a first site signature. Some such example methods can also include using the first value data to prequalify the first hash key as a candidate for subsequent signature processing associated with the first site signature. For example, some such example methods can further include obtaining a second hash key, second qualifier data and second value data associated with the second hash key in response to querying the first table using a first site signature. In such examples, the second hash key can have been determined to match the first site signature, and the second qualifier data can be descriptive of a second reference signature corresponding to the second hash key. Such example methods can also include querying the second table using the second qualifier data in response to a successful prequalification of the second hash key based on the second value data, but not querying the second table using the second qualifier data in response to an unsuccessful prequalification of the second hash key based on the second value data.
Furthermore, in some such examples, the first reference signature is representative of first reference media, the first value data includes a second hash key and a third hash key both representative of the first reference media, and the second hash key precedes the first hash key in time, whereas the third hash key follows the first hash key in time. In some such examples, using the first value data to prequalify the first hash key includes determining prequalification of the first hash key is successful in response to determining that the second hash key matches a second site signature preceding the first site signature in time and that the third hash key matches a third site signature following the first site signature in time. In some such examples, using the first value data to prequalify the first hash key also includes determining prequalification of the first hash key is unsuccessful in response to determining that at least one of the second hash key fails to match the second site signature or the third hash key fails to match the third site signature.
These and other example methods, apparatus, systems and articles of manufacture (e.g., physical storage media, structures, etc.) to perform signature retrieval and matching for media monitoring are disclosed in greater detail below.
As mentioned above, in media monitoring systems employing media signatures, the device meters monitoring media presented by media devices at monitored sites typically provide their generated site signatures to a data processing facility or other centralized processing site for comparison with the reference signatures that are representative of the possible reference media available for presentation at the respective monitored sites. In prior media monitoring systems, the central data processing facility may store the reference signatures in random access memory (RAM) for comparison with the site signatures obtained from the monitored sites. However, as the amount of possible reference media available for presentation increases, the number of possible reference signatures to be compared also increases. In prior media monitoring systems, the increasing number of references signatures requires more and more RAM to store the reference signatures for comparison, to the point at which the amount of RAM may become cost prohibitive and/or unwieldy to manage.
In contrast, media monitoring systems employing signature retrieval and matching as disclosed herein can perform signature matching more efficiently than prior systems. Some example media monitoring systems employing signature retrieval and matching as disclosed herein utilize a database employing a double index hashing strategy in which a first table—a hash table—is stored in RAM and queried using site signatures obtained from monitored sites to retrieve candidate reference signatures for further examination. The first hash table can be relatively lightweight and have a smaller RAM footprint than that of prior media monitoring systems. The double index hashing strategy of such examples also utilizes a second table—a block table—storing blocks of reference signatures that can be retrieved for matching using the candidate reference signatures retrieved from the hash table. The block table need not be stored in RAM (although it could be), and may or may not be stored remotely from the hash table. The (relatively few) blocks of signatures retrieved from the block table can be temporarily stored in RAM for signature matching. In some examples, signature matching processing is offloaded to servers or other computing devices implementing the block table, thereby supporting parallel and/or distributed data processing.
Turning to the figures, a block diagram of an example system 100 capable of performing signature retrieval and matching for media monitoring as disclosed herein is illustrated in
In the example system 100 of
In the system 100 of the illustrated example, the crediting facility 115 performs signature retrieval and matching for media monitoring as disclosed herein. Unlike media monitoring techniques based on codes and/or watermarks included with and/or embedded in the monitored media, signature-based media monitoring techniques generally use one or more inherent characteristics of the monitored media during a signature sampling interval to generate a substantially unique proxy for the media. Such a proxy is referred to as a signature or media fingerprint, and can take the form of a series of bits, data values, a waveform, etc., representative of the media signal(s) (e.g., an audio signal and/or a video signal) forming the media presentation being monitored. A good signature is usually one that is repeatable when processing the same media presentation, but that is unique relative to other (different) presentations of other (different) media. Thus, as used herein, a signature is a representation of some characteristic of the media signal (e.g., a characteristic of the frequency spectrum of the signal) which can be used to identify the signal, and can be thought of as a fingerprint. Signatures are typically not dependent upon insertion of identification codes in the media, but instead preferably reflect an inherent characteristic of the media and/or the signal transporting the media. Systems to utilize codes and/or signatures for audience measurement are long known. See, for example, Thomas, U.S. Pat. No. 5,481,294, which is hereby incorporated by reference in its entirety.
In the example system 100 of
The crediting facility 115 of the illustrated example employs signature retrieval and matching as disclosed herein to facilitate efficient retrieval of reference signatures for comparison with the site signatures obtained from the monitored sites 120. As disclosed in further detail below, the example crediting facility 115 utilizes a database employing a double index hashing strategy involving a first table, referred to herein as a hash table, and a second table, referred to herein as a block table. The hash table is arranged such that each entry corresponds to a reference signature and is indexed using a hash key, which may correspond to a hash of the reference signature or the data value of the reference signature itself. The hash table entry for a particular reference signature also includes qualifier data descriptive of the reference signature and, in at least some examples, value data that may be used to prequalify the reference signature as a good candidate for further signature matching processing, as described in further detail below. The block table is arranged such that each entry corresponds to a particular value, or combination of values, of the qualifier data and, thus, is indexed using qualifier data retrieved in response to querying the hash table. The block table entry for a particular value, or combination of values, of the qualifier data also includes blocks of reference signatures corresponding to that qualifier data, which can be retrieved for comparison with a block of site signature(s) reported by the device meter at a monitored site 120. Operation of the crediting facility 115 to use the hash table and block table for signature retrieval and matching is described in further detail below in connection with the example implementation of the crediting facility 115 illustrated in
The example system 100 of
A block diagram of an example implementation of one of the monitored sites 120 of
The example monitored site 120 of
For example, in the example monitored site 120 of
In some examples, the monitored site 120 also includes an example people meter 215 to capture audience identification information describing an audience being exposed to the media presented by the media device 205. In some examples, the people meter 215 can prompt audience member(s) in the vicinity of the media device 205 to identify which one or more of a possible group of audience members are present in the audience. Additionally or alternatively, in some examples, the people meter 215 can automatically identify one or more individual included in an audience in the vicinity of the media device 205. In such examples, the device meter 210 may combine the metering data identifying (e.g., directly or indirectly) the media being presented by the media device 205 with the audience identification data determined by the people meter 215 to form audience measurement data characterizing media exposure (e.g., with demographic information) at the monitored site 120.
The device meter 210 of the illustrated example stores the metering data (or audience measurement data), including the generated site signatures, for reporting to the crediting facility 115 via the reporting medium 125. The generated site signatures in the metering data are also timestamped to allow the site signatures to be associated with the particular time when the site signatures were generated. The timestamps also indicate the time at which the monitored media represented by the site signatures was presented at the monitored site 120. The device meter 210 can report the metering data/audience measurement data (including the site signatures and timestamps) as it is collected (e.g., streamed), at specified/predetermined time intervals, when a certain amount of data has been collected, when an available memory space is filled or reaches a threshold capacity (e.g., 90% or some other percentage being full), and/or via any other periodic, aperiodic and/or event-driven schedule.
Example site signatures that can be generated and reported by the example device meter 210 of
In the illustrated example of
A block diagram of an example implementation of the MMS 130 of
The example MMS 130 of
The signatures generated by the signature generator(s) 310 are reference signatures that can be used (e.g., by the crediting facility 115) to identify corresponding media being distributed by the media distributor(s) 105. For example, for each media distribution received and processed by the MMS 130, the reference signatures output from the signature generator(s) are associated with media identification data (e.g., such as a source identifier, a stream identifier, etc., as described in further detail) identifying the particular media represented by the reference signatures. Such media identification data can be known to the MMS 130 based on, for example, the known association of the media receiver(s) 305 to the respective media distributor(s) 105.
The example MMS 130 of
Example reference signatures that can be generated and reported by the example MMS 130 of
In the illustrated example of
Returning to
A block diagram of an example implementation of the crediting facility 115 of
Turning to
As mentioned above, the crediting facility 115 of the illustrated example employs a double index hashing strategy for signature retrieval and matching, which involves a first table, referred to herein as a hash table, and a second table, referred to herein as a block table. Accordingly, the example crediting facility 115 of
Turning to
In the illustrated example, the entry of the hash table 710 corresponding to a particular reference signature represented by the hash key 712 also includes example qualifier data 720 descriptive of the reference signature. For example, the qualifier data 720 can include metadata, such as an example timestamp 722, an example source identifier 724, an example stream identifier 726 and an example offset 728. In the illustrated example of
In some examples, the entry of the hash table 710 corresponding to a particular reference signature represented by the hash key 712 further includes example value data 730 that may be used to prequalify the reference signature corresponding to the hash table entry as a good candidate for further signature matching processing. In the illustrated example of
The example block table 715 illustrated in
The entry of the block table 715 corresponding to a particular reference signature block represented by the key 750 also includes example value data 760, which includes the current reference signature block 762 corresponding to this entry of the block table 715, as well as the previous reference signature block 764 and the next reference signature block 766. In the illustrated example of
In some examples, the entry of the block table 715 corresponding to a particular reference signature block represented by the key 750 further includes example qualifier data 770. In the illustrated example of
In some examples, the hash table 710 and/or the block table 715 are implemented by one or more databases. For example, the hash table 710 and the block table 715 may be implemented by the crediting facility 115 using an Apache HBase™ database solution, a Structured Query Language (SQL) database solution, etc.
Returning to
In some examples, the example hash table storage 620 is implemented by RAM to enable relatively fast access and processing of the hash table 710. For example, the hash table storage 620 can be implemented by the volatile memory 1214 and/or the local memory 1213 of the example processor platform 1200 of
The example block table populator 615 receives the reference signature blocks 505 and associated timestamps 510 and media identifiers 515 from the MMS 130 via the MMS interface 605. The block table populator 615 of the illustrated example then populates the block table 715, which is stored in an example block table storage 625, using the received reference signature blocks 505 and associated timestamps 510 and media identifiers 515. For example, for a particular received reference signature block 505, the block table populator 615 populates the key 750 of an entry in the block table 715 corresponding to the received reference signature block 505 as follows. The block table populator 615 populates the timestamp 752 of the key 750 for this block table entry with the value of the timestamp 510 associated with the reference signature block 505, and populates the source identifier 754 and the stream identifier 756 of the key 750 for this block table entry based on the media identifier 515 associated with the reference signature block 505. The block table populator 615 further populates the current reference signature block 762 of the value data 760 for this block table entry with the reference signatures included in the received reference signature block 505. Additionally, the block table populator 615 populates the previous reference signature block 764 and the next reference signature block 766 with the appropriate previous and next reference signature blocks relative to the current reference signature block 762. In some examples, the block table populator 615 also populates the qualifier data 770 for this block table entry with the appropriate version data 772.
The example block table storage 625 may be implemented by any appropriate memory, storage device, etc., such as one or more of the volatile memory 1214, the local memory 1213, the mass storage device 1228 of the example processor platform 1200 of
The example crediting facility 115 of
The example crediting facility 115 of
Because multiple hash keys 712 (e.g., reference signatures) may match a particular site signature (e.g., the site signature 405A), the example crediting facility 115 of
In the illustrated example, the candidate qualifier 640 performs prequalification of a particular candidate hash key 712 using the value data 730 associated with the candidate hash key 712. For example, the candidate qualifier 640 of the illustrated example can obtain the previous hash key 732 and the next hash key 734 included in the value data 730 for the particular candidate hash key 712. As noted above, the previous hash key 732 corresponds to the hash key (e.g., reference signature) preceding the hash key 712 in time, and the next hash key 734 corresponds to the hash key (e.g., reference signature) following the hash key 712 in time. In such examples, the candidate qualifier 640 compares the previous hash key 732 with the neighboring site signature preceding, in time, the site signature used to query the hash table 710, and compares the next hash key 734 with the neighboring site signature following, in time, the site signature used to query the hash table 710. For example, if the site signature 405B is used to query the hash table 710, then the candidate qualifier 640 compares the site signature 405A with the previous hash key 732 and compares the site signature 405C with the next hash key 734 for the candidate hash key 712 undergoing prequalification. If both comparisons are successful (e.g., the previous hash key 732 matches the previous site signature and the next hash key 734 matches the following site signature), then the candidate qualifier 640 indicates that prequalification for the particular candidate hash key 712 is successful and this key is retained for use in querying the block table 715 (or, in other words, the qualifier data 720 associated with the particular candidate hash key 712 is used to query the block table 715 in response to a successful prequalification of the particular candidate hash key 712 based on its associated value data 730, which includes the previous hash key 732 and the next hash key 734). Otherwise (e.g., if either comparison is unsuccessful), then the candidate qualifier 640 indicates that prequalification for the particular candidate hash key 712 is unsuccessful and this key is not retained for use in querying the block table 715 (or, in other words, the qualifier data 720 associated with the particular candidate hash key 712 is not used to query the block table 715 in response to an unsuccessful prequalification of the particular candidate hash key 712 based on its associated value data 730, which includes the previous hash key 732 and the next hash key 734). In some examples, the candidate qualifier 640 performs the preceding prequalification process for each candidate hash key 712 returned in response to a query of the hash table 710.
The example crediting facility 115 of
In the illustrated example of
The signature matcher 650 uses any appropriate metric to compare the site signature block with the overlapping portion of the current, previous and/or next reference signature block(s) 762-766. For example, if the site signatures and reference signatures are all digital values represented by sequences of bits, the signature matcher 650 can use a POP count to count the number of bits that are different between the site signature block and the overlapping portion of the current, previous and/or next reference signature block(s) 762-766. If the number of different bits satisfies/meets (e.g., is less than, or is less than or equal to) a threshold, the signature matcher 650 determines that the site signature block matches the overlapping portion of the current, previous and/or next reference signature block(s) 762-766. Conversely, if the number of different bits fails to satisfy/meet (e.g., is greater than, or is greater than or equal to) the threshold, the signature matcher 650 determines that the site signature block fails to match the overlapping portion of the current, previous and/or next reference signature block(s) 762-766.
An example matching operation capable of being performed by the example signature matcher 650 of
The offset 728 included in the qualifier data 720 for this candidate hash key 712 specifies the location of the reference signature 812 (which corresponds to this candidate hash key 712) in the current reference signature block 862. Accordingly, the signature matcher 650 is able to align the site signature 805 (which was used to query the hash table 710) with the reference signature 812 (which corresponds to this matching candidate hash key 712) using the offset as shown in the example of
While example manners of implementing the example crediting facility 115 and, more generally, the example system 100 are illustrated in
Flowcharts representative of example machine readable instructions for implementing the example system 100, the example crediting facility 115, the example media distributor(s) 105, the example monitored site(s) 120, the example MMS 130, the example media device 205, the example device meter 210, the example people meter 215, the example media receiver(s) 305, the example signature generator(s) 310, the example time determiner(s) 315, the example data reporter 320, the example MMS interface 605, the example hash table populator 610, the example block table populator 615, the example hash table storage 620, the example block table storage 625, the example site interface 630, the example hash table query processor 635, the example candidate qualifier 640, the example block table query processor 645 and/or the example signature matcher 650 are shown in
As mentioned above, the example processes of
A first example program 900 that may be executed to implement the example crediting facility 115 of
In some examples, at block 920, the crediting facility 115 performs hash table compaction to purge out-of-date reference data from the hash table 710. Similarly, in some examples, at block 925 the crediting facility 115 performs block table compaction to purge out-of-date reference data from the block table 715. For example, in an HBase implementation, the data included in entries of the hash table 710 and/or the block table 715 can be tagged with time-to-live values specifying a duration (e.g., such as a number of days, weeks, etc.) during which the data should be retained in the respective hash table 710 and/or block table 715. Upon expiration of the time-to-live values, the crediting facility 115 purges the expired hash table data at block 920, and purges the expired block table data at block 925.
A second example program 1000 that may be executed to implement the example crediting facility 115 of
At block 1020, the crediting facility 1020 configures the example block table query processor 645 and the example signature matcher 650 to process each prequalified candidate hash key 712 retained at block 1015. For example, at block 1025, the block table query processor 645 queries the block table 715, as described above, using the qualifier data 720 for a given prequalified candidate hash key 712 (e.g., corresponding to a respective reference signature) to retrieve the current, previous and next reference signature blocks 762-766 corresponding to the given prequalified candidate hash key 712. At block 1030, the signature matcher 650 performs signature matching, as described above, to compare a portion of the current, previous and next reference signature blocks 762-766 corresponding to the given prequalified candidate hash key 712 with a site signature block containing the particular site signature used to obtain the prequalified candidate hash key 712. At block 1035, the signature matcher 650 associates the site signatures in the site signature block with the reference media represented by the current, previous and next reference signature blocks 762-766 corresponding to the given prequalified candidate hash key 712 if the matching performed at block 1030 was successful. At block 1040, the crediting facility 115 causes processing to continue until all prequalified candidate hash keys 712 have been processed. At block 1045, the signature matcher 150 provides the successful signature matching results to further media monitoring process(es) (e.g., to credit the media monitored at the monitored site 120 as corresponding to the reference media represented by the reference signatures determined to match the site signatures at block 1035).
An example program 1015P that may be executed to implement the example candidate qualifier 640 of the example crediting facility 115 of
At block 1120, the candidate qualifier 640 determines if both comparisons performed at block 1115 were successful (e.g., if the previous hash key 732 matched the previous site signature and the next hash key 734 matched the subsequent site signature). If both comparisons were successful (block 1120), at block 1125 the candidate qualifier 640 indicates that the given candidate hash key 712 is prequalified for use in further signature matching processing for the current site signature. However, if either comparisons was unsuccessful (block 1120), at block 1125 the candidate qualifier 640 causes the given candidate hash key 712 to be excluded from use in further signature matching processing for the current site signature. At block 1135, the candidate qualifier 640 continues performing prequalification processing until all candidate hash keys 712 have been processed. At block 1140, the candidate qualifier 640 returns information identifying the resulting prequalified candidate hash keys 712 (e.g., which correspond to respective reference signatures).
The processor platform 1200 of the illustrated example includes a processor 1212. The processor 1212 of the illustrated example is hardware. For example, the processor 1212 can be implemented by one or more integrated circuits, logic circuits, microprocessors or controllers from any desired family or manufacturer.
The processor 1212 of the illustrated example includes a local memory 1213 (e.g., a cache). The processor 1212 of the illustrated example is in communication with a main memory including a volatile memory 1214 and a non-volatile memory 1216 via a link 1218. The link 1218 may be implemented by a bus, one or more point-to-point connections, etc., or a combination thereof. The volatile memory 1214 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 1216 may be implemented by flash memory and/or any other desired type of memory device. Access to the main memory 1214, 1216 is controlled by a memory controller.
The processor platform 1200 of the illustrated example also includes an interface circuit 1220. The interface circuit 1220 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 1222 are connected to the interface circuit 1220. The input device(s) 1222 permit(s) a user to enter data and commands into the processor 1212. 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, a trackbar (such as an isopoint), a voice recognition system and/or any other human-machine interface. Also, many systems, such as the processor platform 1200, can allow the user to control the computer system and provide data to the computer using physical gestures, such as, but not limited to, hand or body movements, facial expressions, and face recognition.
One or more output devices 1224 are also connected to the interface circuit 1220 of the illustrated example. The output devices 1224 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 light emitting diode (LED), a printer and/or speakers). The interface circuit 1220 of the illustrated example, thus, typically includes a graphics driver card, a graphics driver chip or a graphics driver processor.
The interface circuit 1220 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 1226 (e.g., an Ethernet connection, a digital subscriber line (DSL), a telephone line, coaxial cable, a cellular telephone system, etc.).
The processor platform 1200 of the illustrated example also includes one or more mass storage devices 1228 for storing software and/or data. Examples of such mass storage devices 1228 include floppy disk drives, hard drive disks, compact disk drives, Blu-ray disk drives, RAID (redundant array of independent disks) systems, and digital versatile disk (DVD) drives.
Coded instructions 1232 corresponding to the instructions of
Example methods, apparatus, systems and articles of manufacture to perform signature retrieval and matching for media monitoring have been disclosed herein. Further example techniques to identify media using hash keys, which can be employed in conjunction with the examples provided herein, are disclosed in U.S. Provisional Application Ser. No. 61/976,238, entitled “METHODS and APPARATUS TO IDENTIFY MEDIA USING HASH KEYS” and filed on Apr. 7, 2014, which is hereby incorporated by reference in its entirety.
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.
This patent arises from a continuation of U.S. patent application Ser. No. 17/099,483, now U.S. Pat. No. 11,533,535, filed on Nov. 16, 2020, which is a continuation of U.S. patent application Ser. No. 16/188,165, now U.S. Pat. No. 10,841,650, filed on Nov. 12, 2018, which is a continuation of U.S. patent application Ser. No. 15/607,006, now U.S. Pat. No. 10,129,591, filed on May 26, 2017, which is a continuation of U.S. patent application Ser. No. 14/469,245, now U.S. Pat. No. 9,668,020, filed Aug. 26, 2014, which claims the benefit of U.S. Provisional Application No. 61/976,168, filed on Apr. 7, 2014. U.S. patent application Ser. No. 17/099,483, U.S. patent application Ser. No. 16/188,165, U.S. patent application Ser. No. 15/607,006, U.S. patent application Ser. No. 14/469,245, and U.S. Provisional Application No. 61/976,168 are hereby incorporated by reference in their entireties. Priority to U.S. Provisional Application No. 61/976,168, U.S. patent application Ser. No. 14/469,245, U.S. patent application Ser. No. 15/607,006, U.S. patent application Ser. No. 16/188,165 and U.S. patent application Ser. No. 17/099,483 is hereby claimed.
Number | Name | Date | Kind |
---|---|---|---|
4677466 | Lert, Jr. et al. | Jun 1987 | A |
5371499 | Graybill et al. | Dec 1994 | A |
5481294 | Thomas et al. | Jan 1996 | A |
5686902 | Reis et al. | Nov 1997 | A |
6005503 | Burrows | Dec 1999 | A |
6453252 | Laroche | Sep 2002 | B1 |
6593976 | Lord | Jul 2003 | B1 |
6785714 | Thompson et al. | Aug 2004 | B1 |
6990453 | Wang et al. | Jan 2006 | B2 |
7328153 | Wells et al. | Feb 2008 | B2 |
7363500 | Funk | Apr 2008 | B2 |
7460684 | Srinivasan | Dec 2008 | B2 |
7668851 | Triplett | Feb 2010 | B2 |
7793318 | Deng | Sep 2010 | B2 |
7831531 | Baluja et al. | Nov 2010 | B1 |
7921296 | Haitsma et al. | Apr 2011 | B2 |
8180712 | Nelson et al. | May 2012 | B2 |
8184953 | Covell et al. | May 2012 | B1 |
8381241 | Ramaswamy et al. | Feb 2013 | B2 |
8510608 | Futa et al. | Aug 2013 | B2 |
9313359 | Stojancic et al. | Apr 2016 | B1 |
9438940 | Nelson | Sep 2016 | B2 |
9548830 | Kariyappa et al. | Jan 2017 | B2 |
9668020 | Nelson et al. | May 2017 | B2 |
10129591 | Nelson et al. | Nov 2018 | B2 |
10200546 | Nelson et al. | Feb 2019 | B2 |
10841650 | Nelson et al. | Nov 2020 | B2 |
11108915 | Nelson et al. | Aug 2021 | B2 |
11252460 | Nelson et al. | Feb 2022 | B2 |
11290508 | Walters et al. | Mar 2022 | B1 |
11348126 | Sullivan et al. | May 2022 | B2 |
11533535 | Nelson et al. | Dec 2022 | B2 |
11665288 | Nelson et al. | May 2023 | B2 |
11765412 | Nelson et al. | Sep 2023 | B2 |
20010027479 | Delaney et al. | Oct 2001 | A1 |
20020017841 | Nishimoto | Feb 2002 | A1 |
20020178410 | Haitsma et al. | Nov 2002 | A1 |
20030120647 | Aiken et al. | Jun 2003 | A1 |
20040059933 | Levy | Mar 2004 | A1 |
20050154899 | Marvel et al. | Jul 2005 | A1 |
20050177738 | Van Der Veen et al. | Aug 2005 | A1 |
20050232411 | Srinivasan et al. | Oct 2005 | A1 |
20060094460 | Tiedemann et al. | May 2006 | A1 |
20060153296 | Deng | Jul 2006 | A1 |
20060184961 | Lee et al. | Aug 2006 | A1 |
20060195861 | Lee | Aug 2006 | A1 |
20060195886 | Ashley | Aug 2006 | A1 |
20070143778 | Covell et al. | Jun 2007 | A1 |
20070271300 | Ramaswamy | Nov 2007 | A1 |
20070274537 | Srinivasan | Nov 2007 | A1 |
20070300249 | Smith et al. | Dec 2007 | A1 |
20080033942 | Kao et al. | Feb 2008 | A1 |
20080091288 | Srinivasan | Apr 2008 | A1 |
20080126420 | Wright et al. | May 2008 | A1 |
20080263579 | Mears et al. | Oct 2008 | A1 |
20080276265 | Topchy et al. | Nov 2008 | A1 |
20090049465 | Deng | Feb 2009 | A1 |
20090154916 | Huang et al. | Jun 2009 | A1 |
20090193052 | Fitzgerald et al. | Jul 2009 | A1 |
20090305680 | Swift et al. | Dec 2009 | A1 |
20100095320 | Lee | Apr 2010 | A1 |
20100115542 | Lee | May 2010 | A1 |
20100293332 | Krishnaprasad et al. | Nov 2010 | A1 |
20100318515 | Ramanathan et al. | Dec 2010 | A1 |
20110173185 | Vogel | Jul 2011 | A1 |
20110264663 | Verkasalo | Oct 2011 | A1 |
20120215789 | Ramanathan et al. | Aug 2012 | A1 |
20120259587 | Sannino et al. | Oct 2012 | A1 |
20120291058 | Lee et al. | Nov 2012 | A1 |
20120297198 | Danezis et al. | Nov 2012 | A1 |
20130013324 | Topchy et al. | Jan 2013 | A1 |
20130142331 | Schultz | Jun 2013 | A1 |
20130145099 | Liu et al. | Jun 2013 | A1 |
20130160042 | Stokes et al. | Jun 2013 | A1 |
20130215219 | Hefeeda et al. | Aug 2013 | A1 |
20130282964 | Sengupta et al. | Oct 2013 | A1 |
20130283053 | Hwang et al. | Oct 2013 | A1 |
20140088742 | Srinivasan et al. | Mar 2014 | A1 |
20140136814 | Stark | May 2014 | A1 |
20140189279 | Seo et al. | Jul 2014 | A1 |
20150078386 | Jackson et al. | Mar 2015 | A1 |
20150288513 | Nelson | Oct 2015 | A1 |
20150289013 | Nelson et al. | Oct 2015 | A1 |
20160034452 | Ramanathan et al. | Feb 2016 | A1 |
20160191530 | Jain et al. | Jun 2016 | A1 |
20160342667 | Chen et al. | Nov 2016 | A1 |
20170093854 | Nelson et al. | Mar 2017 | A1 |
20170134395 | Enns et al. | May 2017 | A1 |
20170244999 | Chen | Aug 2017 | A1 |
20170264952 | Nelson et al. | Sep 2017 | A1 |
20190037257 | Nelson et al. | Jan 2019 | A1 |
20210306687 | Nelson et al. | Sep 2021 | A1 |
20220270127 | Kurzynski et al. | Aug 2022 | A1 |
20230283842 | Borawski et al. | Sep 2023 | A1 |
20230300412 | Spoentgen et al. | Sep 2023 | A1 |
20240031642 | Wright et al. | Jan 2024 | A1 |
20240040173 | Jain et al. | Feb 2024 | A1 |
Number | Date | Country |
---|---|---|
2013324105 | May 2016 | AU |
1461565 | Dec 2003 | CN |
1858799 | Nov 2006 | CN |
101164069 | Apr 2008 | CN |
101477527 | Jul 2009 | CN |
102497581 | Jun 2012 | CN |
102567395 | Jul 2012 | CN |
103312770 | Sep 2013 | CN |
103460711 | Dec 2013 | CN |
2626212 | Aug 2013 | EP |
2629212 | Aug 2013 | EP |
4257084 | Apr 2009 | JP |
2007120518 | Oct 2007 | WO |
2011087756 | Jul 2011 | WO |
2015156843 | Oct 2015 | WO |
Entry |
---|
IP Australia, “Notice of Acceptance for Patent Application,” issued in connection with Australian Patent Application No. 2014389997, dated Aug. 7, 2017, 3 pages. |
International Searching Authority, “Written Opinion,” issued in connection with International Patent Application No. PCT/US2014/068173, dated Feb. 26, 2015, 5 pages. |
International Bureau, “International Preliminary Report on Patentability,” issued in connection with International Patent Application No. PCT/US2014/068173, dated Oct. 12, 2016, 7 pages. |
P Australia, “Examination report No. 1,” issued in connection with Australian Patent Application No. 2014389997, dated Mar. 24, 2017, 3 pages. |
United States Patent and Trademark Office, “Non-Final Office Action,” issued in connection with U.S. Appl. No. 14/469,245, dated Sep. 21, 2015, 9 pages. |
United States Patent and Trademark Office, “Final Office Action,” issued in connection with U.S. Appl. No. 14/469,245, dated Mar. 16, 2016, 9 pages. |
United States Patent and Trademark Office, “Advisory Action,” issued in connection with U.S. Appl. No. 14/469,245, dated May 25, 2016, 4 pages. |
United States Patent and Trademark Office, “Notice of Panel Decision from Pre-Appeal Brief Review,” issued in connection with U.S. Appl. No. 14/469,245, dated Jul. 28, 2016, 2 pages. |
United States Patent and Trademark Office, “Notice of Allowance and Fees,” issued in connection with U.S. Appl. No. 14/469,245, dated Jan. 20, 2017, 8 pages. |
Canadian Intellectual Property Office, “Examination Report,” issued in connection Canadian Patent Application No. 2,940,524, dated May 1, 2017, 4 pages. |
European Patent Office, “Search Report,” issued in connection with European Patent Application No. 14888969.4, dated Jul. 7, 2017, 8 pages. |
European Patent Office, “Communication pursuant to Rules 70(2) and 70a(2) EPC,” issued in connection with European Patent Application No. 14888969.4, dated Jul. 28, 2017, 1 page. |
European Patent Office, “Communication Pursuant to Article 94(3) EPC,” issued in connection with European Patent Application No. 14888969.4, dated Apr. 13, 2018, 4 pages. |
United States Patent and Trademark Office, “Non-Final Office Action,” issued in connection with U.S. Appl. No. 15/607,006, dated Jan. 24, 2018, 9 pages. |
United States Patent and Trademark Office, “Notice of Allowance,” issued in connection with U.S. Appl. No. 15/607,006, dated Jul. 20, 2018, 7 pages. |
Canadian Intellectual Property Office, “Notice of Allowance,” issued in connection with Canadian Application No. 2,940,524, dated Jun. 6, 2018, 1 page. |
The Mexican Institute of Industrial Property, “Office Action,” issued in connection with Mexican Patent Application No. MX/a/2016/010617, dated Sep. 4, 2018, 5 pages. |
The Mexican Institute of Industrial Property, “Office Action,” issued in connection with Mexican Patent Application No. MX/a/2016/010617, dated May 4, 2018, 5 pages. |
China National Intellectual Property Administration, “Notification of the First Office Action,” issued in connection with Chinese Patent Application No. 201480077611.4, dated Nov. 28, 2018, 12 pages. |
European Patent Office, “Intention to grant,” issued in connection with European Patent Application No. 14888969.4, dated Apr. 17, 2019, 59 pages. |
European Patent Office, “Search Report,” issued in connection with European Patent Application No. 19195329.8, dated Sep. 24, 2019, 11 pages. |
China National Intellectual Property Administration, “Notification to Grant the Patent Right for Invention,” issued in connection with Chinese Patent Application No. 201480077611.4, dated Aug. 23, 2019, 2 pages. |
Intellectual Property Office of Great Britain, “Examination Report,” dated Jan. 31, 2020 in connection with British Patent Application No. GB1617286.8, 4 pages. |
United States Patent and Trademark Office, “Non-Final Office,” issued in connection with U.S. Appl. No. 16/188,165, dated Sep. 27, 2019, 8 pages. |
United States Patent and Trademark Office, “Notice of Allowance,” issued in connection with U.S. Appl. No. 16/188,165, dated Jul. 8, 2020, 7 pages. |
European Patent Office, Communication pursuant to Article 94(3) EPC, mailed in connection with European Patent Application No. 19 195 329.8, dated Sep. 9, 2020, 8 pages. |
Mexican Institute of Intellectual Property, “Notice of Allowance,” issued in connection with Mexican Patent Application MX/a/2019/006383, dated May 28, 2021, 6 pages. |
European Patent Office, “Intention to Grant,” issued in connection with European Patent Application No. 19195329.8, dated Apr. 1, 2021, 5 pages. |
China National Intellectual Property Administration, “First Office Action,” issued in connection with Chinese Patent Application No. 201911082452.8, dated Jun. 2, 2021, 22 pages. |
China National Intellectual Property Administration, “Notification to Grant the Patent,” issued in connection with Chinese Patent Application No. 201911082452.8, dated Nov. 2, 2021, 2 pages. |
European Patent Office, “Communication pursuant to Article 94(3) EPC,” issued in connection with European Patent Application No. 19195329.8, dated Sep. 9, 2020, 8 pages. |
United States Patent and Trademark Office, “Notice of Allowance and Fee(s) Due,” dated Aug. 12, 2022, in connection with U.S. Appl. No. 17/099,483, 7 pages. |
United States Patent and Trademark Office, “Non-Final Office Action,” dated Feb. 16, 2022, in connection with U.S. Appl. No. 17/099,483, 6 pages. |
Extended European Search Report received in European Application No. 14889168.2, mailed on Sep. 20, 2017, 7 pages. |
Fink et al., “Social-and Interactive Television-Applications Based on Real-Time Ambient-Audio Identification,” 2006 [retrieved from http://www.mangolassi.org/covell/pubs/eurolTV-2006.pdf, accessed on Apr. 4, 2014] (10 pages). |
Haitsma et al., “Robust Audio Hashing for Content Identification,” 2001 [retrieved from http://citeseerx.ist.psu.edu/ viewdoc/download?doi=10.1.1.16.2893&rep=rep1&type=pdf, accessed on Apr. 4, 2014] (8 pages). |
Internation Search Report and Written Opinion received in PCT Application No. PCT/US2014/067939, mailed on Feb. 16, 2015, 7 pages. |
International Searching Authority, “International Search Report,” mailed in connection with International Patent Application No. PCT/US2014/068173, on Feb. 26, 2015, 3 pages. |
Ke et al., “Computer Vision for Music Identification,” Intel, 2004 (8 pages). |
Hagmuller et al., “Audio Fingerprint,” Institute for Signal Processing and Speech Communication, Digitale Audiotechnik 2, VO, Jun. 4, 2009 (11 pages). |
Moravec et al., “A Comparison of Extended Fingerprint Hashing and Locality Sensitive Hashing for Audio Fingerprints,” ICMR, Apr. 17-20, 2011 (8 pages). |
Patent Cooperation Treaty: International Search Report, mailed in connection with corresponding International Patent Application No. PCT/US2021/024435, on Jul. 6, 2021, 3 pages. |
Patent Cooperation Treaty: Written Opinion, mailed in connection with corresponding International Patent Application No. PCT/US2021/024435, on Jul. 6, 2021, 3 pages. |
United States Patent and Trademark Office, “Non-Final Office Action,” issued in connection with U.S. Appl. No. 15/214,087, mailed Nov. 4, 2016, 5 pages. |
United States Patent and Trademark Office, “Non-Final Office Action,” issued in connection with U.S. Appl. No. 17/461,810, mailed on Aug. 11, 2022, 13 pages. |
United States Patent and Trademark Office, “Non-Final Office Action,” issued in connection with U.S. Appl. No. 17/670,222, mailed on Sep. 28, 2022, 12 pages. |
United States Patent and Trademark Office, Final Office Action, issued in connection with U.S. Appl. No. 17/670,222, mailed on Feb. 14, 2023, 14 pages. |
United States Patent and Trademark Office, Final Office action, issued in connection with U.S. Appl. No. 14/866,755, mailed on Mar. 7, 2018, 16 pages. |
United States Patent and Trademark Office, Non- Final Office action, issued in connection with U.S. Appl. No. 14/866,755, mailed on Aug. 10, 2017, 13 pages. |
United States Patent and Trademark Office, Non-Final Office Action, issued in connection with U.S. Appl. No. 16/227,524 on Aug. 20, 2020, 17 pages. |
United States Patent and Trademark Office: Non-Final Rejection, mailed in connection with corresponding U.S. Appl. No. 16/832,681, on Mar. 9, 2021, 12 pages. |
United States Patent and Trademark Office, “Non-Final Office Action,” issued in connection with U.S. Appl. No. 14/473,670, mailed Oct. 15, 2015, 5 pages. |
United States Patent and Trademark Office, “Non-Final Office Action,” issued in connection with U.S. Appl. No. 18/365,037, mailed on Mar. 5, 2024, 19 pages. |
Number | Date | Country | |
---|---|---|---|
20230122391 A1 | Apr 2023 | US |
Number | Date | Country | |
---|---|---|---|
61976168 | Apr 2014 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17099483 | Nov 2020 | US |
Child | 18068247 | US | |
Parent | 16188165 | Nov 2018 | US |
Child | 17099483 | US | |
Parent | 15607006 | May 2017 | US |
Child | 16188165 | US | |
Parent | 14469245 | Aug 2014 | US |
Child | 15607006 | US |