Large amounts of multimedia data are transmitted over information networks in the form of a digital stream, analog video, or text captioning. Often, repetitions such as paid advertisements, theme music at the commencement of a TV broadcast, and common jingles and slogans occur in these streams. Detection of repetitions in a transmitted signal such as streaming audio or video is described, and includes extracting a plurality of samples from the information stream and accumulating the samples into segments comprising an interval of the transmitted signal. A vector indicative of the samples in each of the segments is generated, and each of the vectors in the segments is correlated to generate a covariance matrix, or signature, corresponding to the segment. Each of the covariance matrices are aggregated into a sequence of covariance matrices and compared to other covariance matrices to generate a distance matrix. The distance matrix includes a distance value, indicative of the similarity between the distance matrices, as a result of the comparing of each matrix. The distance matrix is then traversed to determine similar sequences of covariance matrices.
|
1. A method of matching sequences of signals from an information stream comprising:
extracting a stream of samples from a subject information stream, each of the extracted samples comprising a portion of the information stream;
computing, for each of the samples, a vector quantity indicative of the data in the sample;
correlating the vectors to generate a signature indicative of the stream of samples;
comparing the generated signatures to signatures generated from a match stream of samples using a distance metric to generate distance values;
generating, as a result of the comparing, a distance matrix containing entries of the distance values and indicative of signatures generated from similar samples;
traversing the distance matrix to determine if a similar distance value sequence is found;
querying, when a similar distance value sequence is found in the distance matrix, a library of previously found distance value sequences;
storing the distance value sequence in the library if a match is not found as a result of the querying;
updating, if a match is found as a result of the querying, a timestamp corresponding to the matching distance value sequence in the library;
traversing the distance value sequences in the library;
examining each of the timestamps of the distance value sequences; and
purging, when the timestamp is beyond a predetermined threshold, the distance value sequence corresponding to the timestamp.
9. A method of detecting repetitions in an information stream comprising:
providing an information stream of multimedia data corresponding to a transmitted signal;
extracting a plurality of samples from the information stream;
accumulating the samples into segments comprising a predetermined interval of the transmitted signal;
generating respective vectors indicative of the samples in each of the segments;
for each segment, correlating the vectors in the segments to generate a respective covariance matrix corresponding to the segment;
aggregating each of the covariance matrices corresponding to the segments into a sequence of covariance matrices;
comparing each of the covariance matrices in the sequence with each other covariance matrix in the sequence to generate a distance matrix;
traversing the distance matrix to determine if a similar distance value sequence is found;
querying, when a similar distance value sequence is found in the distance matrix, a library of previously found distance value sequences;
storing the distance value sequence in the library if a match is not found as a result of the querying;
updating, if a match is found as a result of the querying, a timestamp corresponding to the matching distance value sequence in the library;
traversing the distance value sequences in the library;
examining each of the timestamps of the distance value sequences; and
purging, when the timestamp is beyond a predetermined threshold, the distance value sequence corresponding to the timestamp.
28. A system for detecting repetitions in an information stream comprising:
means for extracting a stream of samples from a subject information stream, each of the extracted samples comprising a portion of the information stream;
means for computing, for each of the samples, a vector quantity indicative of the data in the sample;
means for correlating the vectors to generate a signature indicative of the stream of samples;
means for comparing the generated signatures to signatures generated from a match stream of samples using a distance metric to generate distance values;
means for generating, as a result of the comparing, a distance matrix containing entries of the distance values and indicative of signatures generated from similar samples;
means for traversing the distance matrix to determine if a similar distance value sequence is found;
means for querying, when a similar distance value sequence is found in the distance matrix, a library of previously found distance value sequences;
means for storing the distance value sequence in the library if a match is not found as a result of the querying;
means for updating, if a match is found as a result of the querying, a timestamp corresponding to the matching distance value sequence in the library;
means for traversing the distance value sequences in the library;
means for examining each of the timestamps of the distance value sequences; and
means for purging, when the timestamp is beyond a predetermined threshold, the distance value sequence corresponding to the timestamp.
20. A system for detecting repetitions in an information stream comprising:
a stream processor operable to extract a stream of samples from the subject information stream and further operable to arrange the samples into a plurality of segments, each of the samples comprising a portion of the information stream;
a segment processor operable to receive the segments and to compute, for each sample in the segments, a vector indicative of the data in the sample;
a correlator operable to correlate each of the vectors in at least one of the segments to generate a signature indicative of the segment;
a distance processor responsive to the correlator and operable to compare the signature to signatures generated from a match stream of samples using a distance metric to generate distance values, and further operable to generate, as a result of the comparing, a distance matrix containing entries of the distance values and indicative of signatures generated from similar samples in the match stream;
means for traversing the distance matrix to determine if a similar distance value sequence is found;
means for querying, when a similar distance value sequence is found in the distance matrix, a library of previously found distance value sequences;
means for storing the distance value sequence in the library if a match is not found as a result of the querying;
means for updating, if a match is found as a result of the querying, a timestamp corresponding to the matching distance value sequence in the library;
means for traversing the distance value sequences in the library;
means for examining each of the timestamps of the distance value sequences; and
means for purging, when the timestamp is beyond a predetermined threshold, the distance value sequence corresponding to the timestamp.
27. A computer program product encoded in a tangible computer readable medium having computer program code for matching sequences of signals from an information stream comprising: computer program code for extracting a stream of samples from a subject information stream, each of the extracted samples comprising a portion of the information stream; computer program code for computing, for each of the samples, a vector quantity indicative of the data in the sample; computer program code for correlating the vectors to generate a signature indicative of the stream of samples, computer program code for comparing the generated signatures to signatures generated from a match stream of samples using a distance metric to generate distance values, computer program code for generating, as a result of the comparing, a distance matrix containing entries of the distance values and indicative of signatures generated from similar samples, computer program code for traversing the distance matrix to determine if a similar distance value sequence is found; computer program code for querying, when a similar distance value sequence is found in the distance matrix, a library of previously found distance value sequences, computer program code for storing the distance value sequence in the library if a match is not found as a result of the querying; computer program code for updating, if a match is found as a result of the querying, a timestamp corresponding to the matching distance value sequence in the library; computer program code for traversing the distance value sequences in the library; computer program code for examining each of the timestamps of the distance value sequences; and computer program code for purging, when the timestamp is beyond a predetermined threshold, the distance value sequence corresponding to the timestamp.
2. The method of
3. The method of
5. The method of
7. The method of
8. The method of
10. The method of
11. The method of
12. The method of
13. The method of
14. The method of
determining, for each of the covariance matrices, a location in the multidimensional space; and
computing a distance value indicative of the distance between the covariance matrices in the multidimensional space.
15. The method of
16. The method of
17. The method of
18. The method of
19. The method of
21. The system of
23. The system of
25. The system of
26. The system of
|
Multimedia information streams such as streaming audio, video, and text are commonplace with the proliferation of information disseminated and available over information networks such as the Internet, telephone, cable TV, and wireless mediums. Massive amounts of multimedia data are transmitted over such networks, in the form of a digital stream, analog video, or text captioning, for example. Often, repetitions or near-repetitions of such data occur in these streams. Repetitions include transmissions such as paid advertisements, theme music at the commencement of a TV broadcast, and common jingles and slogans that may accompany transmissions from a common source.
Large amounts of multimedia data may be gathered by applications which store and process such data, such as SpeechBot™ and Mediaworqs™, for example. Repetitive transmissions can consume storage and computation resources redundantly if not detected. Also, processing of transmitted information, such as tracking paid advertisements to ensure frequency and duration, is typically performed by manually observing such multimedia transmissions. Detection and elimination or processing of repetitions can conserve resources, aid in tracking transmission patterns, and serve as building blocks for further processing. Accordingly, it would be beneficial to monitor and detect repetitions in a multimedia information stream to allow selective processing according to a specific application. One prior art technique for exact match audio detection is disclosed in Johnson, et al., “A Method for Direct Audio Search with Applications to Indexing and Retrieval,” IEEE International Conference on Audio, Speech and Signal Processing (ICASSP 2000), Jun. 5–9, 2000. Johnson, however, discloses a system which looks to a single vector derived from a portion of audio in relation to another single vector.
A method of detecting repetitions in an information stream of A/V (audio visual) data from a transmitted signal such as streaming audio or video includes extracting a plurality of samples from the information stream and accumulating the samples into segments comprising a predetermined interval of the transmitted signal. Vectors indicative of samples in respective segments are generated, and each of the vectors in the segments is correlated to generate a covariance matrix corresponding to the segment. The covariance matrices are aggregated into a sequence of covariance matrices and compared to each other covariance matrix in the sequence to generate a distance matrix. The distance matrix includes a distance value, indicative of the similarity between the covariance matrices, as a result of the comparing of each covariance matrix. The distance matrix is then traversed to determine similar sequences of covariance matrices, wherein determining similar sequences comprises searching for diagonals of similar distance values.
The distance matrix, therefore, contains a distance value for each pair of covariance matrices compared. A relatively low distance value between the two covariance matrices is indicative of a high degree of similarity. A sequence of relatively low distance values shows a repetition in the transmitted signal for an interval such as commercials, for example. Each segment represents a relatively small time interval so as to provide a high degree of granularity for the detection of repeated portions. Detection of repetitions, or duplicates, may include identification of near-duplicates which appear only slightly different due to sampling intervals or distortion. The higher granularity serves to ensure that the interval represented does not overlap with the start or the end of the duplicate segment by only partial overlap. Graphically, such repetitions are represented as a diagonal in the distance matrix since they represent a contiguous sequence of time intervals corresponding to the compared matrices.
Found repetitions are stored in a library database for comparison with other information streams. The stream of samples is compared to itself and to the previously found repetitions in the library. A repository of candidates of likely repetitions is therefore maintained in the database. Matches may be either a new match or an instantiation of a previously found match. If a found sequence is a repeat of a previously found match, a timestamp associated with the library entry is updated. The library database is periodically scanned and entries older than a predetermined threshold are purged. The library is therefore limited to a manageable size by purging stale entries and refreshing current ones.
In this manner, repetitions of transmitted data may be detected and handled efficiently by ignoring, capturing, or otherwise processing the repetitions to conserve computing resources and avoid delays and interruptions resulting from undesired repetitions in the transmitted stream.
The foregoing and other objects, features and advantages of the invention will be apparent from the following more particular description of preferred embodiments of the invention, as illustrated in the accompanying drawings in which like reference characters refer to the same parts throughout the different views. The drawings are not necessarily to scale, emphasis instead being placed upon illustrating the principles of the invention.
A description of preferred embodiments of the invention follows.
A multimedia stream including audio, video, and text may contain repetitions of material such as advertisements and slogans. Identification of repeated material, or portions thereof, can allow the duplications to be removed or otherwise processed to avoid expending unnecessary computing resources to process the repeated material. Further, detection of repetitions may include identification of near-duplicates which appear only slightly different due to sampling intervals or distortion, and which otherwise represent the same information stream.
The segments 36 are sent to a correlator 38, which computes a covariance matrix, or signature 40, by correlating the vectors in the segment 36. Each of the signatures 40, therefore, tends to be uniquely indicative of the corresponding portion of the transmitted signal for the segment 36 (transmission interval). The signatures 40 are received by a distance processor 42, which determines signatures that are similar by comparing them to other signatures. Similarity is determined by computing a distance between signatures in the multidimensional space corresponding to the vectors. A library database 46 stores sequences which have previously found to be repeated, and which are therefore deemed to be likely candidates for further repetition, described further below. In a particular embodiment, the vectors correspond to a 39 dimensional space commonly employed for audio signals. More dimensions would typically be employed with a video signal, for example.
The distance processor 42 determines a measure of similarity between signatures 40, and generates distance matrices 44, described further below. The distance matrices 44 contain entries of the distance between signatures 40, or covariance matrices, generated from the transmission stream 22. A self distance matrix 50 and a library distance matrix 48 are generated. The self distance matrix 50 stores the distance values between signatures from the transmission stream 22 compared to itself. The library distance matrix 48 stores distance values between signatures 40 from the transmission stream 22 and signatures from known repetitive sequences stored in the library DB 46. A traverser 54 receives the self distance matrix 50 and the library distance matrix 48, and identifies repetitions by searching for sequential entries of low distance values.
Once identified, new repetitions are stored in the library database 46 for use in successive distance matrices. A timestamp value ensures that stale entries are purged and frequently found sequences remain, so that the library 46 does not grow excessively large. The found duplicate sequences 56 are employed for successive processing applications, such as elimination of advertisements and tracking cycles of paid transmissions, for example. Also, new duplicates 52 are stored in the library 46 for use with successive transmission streams 22.
Continuing to refer to
Each covariance matrix 66a–66n can be represented as a vector in the multidimensional space, and may be compared to another vector to generate a distance value. As indicated above, the distance value is proportional to the similarity between the transmitted segments 62a–62n, i.e., the closer in distance, and hence the lower in distance values, the greater the similarity between segments 62.
Each element, or point (i,j), in the matrix, therefore, is compared to each other element to generate a distance value. The example shown employs four tiers of distance values 71, illustrated graphically, each corresponding to different distance threshold values. Varying numbers of tiers and thresholds may be employed. As indicated above, in the example shown, the main diagonal has a distance value threshold of zero and generally is observed only when a segment is compared to itself. The low distance value tier has a threshold which allows distances that are sufficiently close to be considered a match, such as less than 0.5 or less than 1.0, depending on the application. Since the elements/matrix points (i,j) each represent sequential segments 62, a matching sequence appears as a diagonal 78 of low distance values parallel to the main diagonal. Further, the diagonal 78 includes a sequence of a minimum number of segments corresponding to a minimum length of a repetition. In the example shown, the segments correspond to five seconds of transmission time, or transmission interval, therefore the diagonal 78 indicates a 15 second transmission. Other transmission intervals corresponding to an expected duplicate transmission time could be employed, such as 20 or 30 seconds, described further below.
The low distance value tier threshold and the minimum number of repeated segments for a match define the granularity of the system. As described above, the product of the segment size (transmission interval) and the minimum number of segments gives the minimum duration of a repeated segment found by the system. If the segment size is too large, the beginning of a repeated segment may not be detected until the following segment, and may be missed altogether if there is insufficient overlap. Similarly, if the minimum number of segments is too large, a shorter sequence of actual repetition may not be detected, possibly from only a portion of an advertisement having been sampled. Conversely, if the minimum number of segments or the segment size are too small, repetitions may be indicated from trivial commonalities. In each case, the low distance tier threshold affects the degree of similarity, and therefore the likelihood of a near miss or trivial match, and may be employed to tune the sensitivity of the system accordingly.
The sequence of covariance matrices 66 corresponding to the transmitted stream may be compared to sequences of covariance matrices stored in the database 46 (
In the example shown, segments 10–20 of the transmitted sequence 68 are compared to segments 70–80 of the library stream 92. This comparison is shown in region 94, in which a diagonal match 96 is found. The sequence of library segments shown by the i axis 92 may be of various sizes, depending on the number of previously found sequences and the available computing resources.
The library distance matrix is traversed to find diagonal sequences of low distance values, as depicted at step 115. A check is performed to see if a match is found in the library, as shown at step 116. If a match was found, then the matched sequence is marked in the transmitted stream 22, as disclosed at step 118, to avoid redundant searching in the self-match traversal. A time stamp in the library entry corresponding to the matched sequence is updated, as shown at step 120. As indicated above, the timestamp serves to keep the library entries from becoming stale. A predetermined timestamp threshold is employed to determine when entries are considered obsolete, such as one month. Other timestamp threshold values could be employed depending on the application. If there are more library sequences to compare, control reverts to step 115 to check the remaining sequences, as depicted at step 122.
Referring to
While this invention has been particularly shown and described with references to preferred embodiments thereof, it will be understood by those skilled in the art that various changes in form and details may be made therein without departing from the scope of the invention encompassed by the appended claims. Accordingly, the invention is not intended to be limited except by the following claims.
Patent | Priority | Assignee | Title |
10009635, | Oct 30 2008 | CITIBANK, N A | Methods and apparatus for generating signatures to identify media content using temporal signal characteristics |
10547877, | Oct 30 2008 | CITIBANK, N A | Methods and apparatus for identifying media content using temporal signal characteristics |
11025966, | Oct 30 2008 | CITIBANK, N A | Methods and apparatus for identifying media content using temporal signal characteristics |
11627346, | Oct 30 2008 | The Nielsen Company (US), LLC | Methods and apparatus for identifying media content using temporal signal characteristics |
7308468, | Dec 30 2003 | Intel Corporation | Pattern matching |
7437397, | Apr 10 2003 | AT&T Corp | Apparatus and method for correlating synchronous and asynchronous data streams |
7647604, | Nov 22 2004 | CITIBANK, N A | Methods and apparatus for media source identification and time shifted media consumption measurements |
7802236, | Sep 09 2003 | REGENT OF THE UNIVERSITY OF CALIFORNIA, THE | Method and apparatus for identifying similar regions of a program's execution |
8006258, | Nov 22 2004 | CITIBANK, N A | Methods and apparatus for media source identification and time shifted media consumption measurements |
8108887, | Oct 30 2008 | CITIBANK, N A | Methods and apparatus for identifying media content using temporal signal characteristics |
8255948, | Apr 23 2008 | GOOGLE LLC | Demographic classifiers from media content |
8495733, | Mar 25 2009 | TREND MICRO INCORPORATED | Content fingerprinting using context offset sequences |
8739207, | Apr 23 2008 | GOOGLE LLC | Demographic classifiers from media content |
8887191, | Oct 30 2008 | CITIBANK, N A | Methods and apparatus for identifying media using temporal signal characteristics |
8903847, | Mar 05 2010 | International Business Machines Corporation | Digital media voice tags in social networks |
8959165, | Mar 21 2011 | International Business Machines Corporation | Asynchronous messaging tags |
9313593, | Dec 30 2010 | Dolby Laboratories Licensing Corporation; DOLBY INTERNATIONAL AB | Ranking representative segments in media data |
9317561, | Dec 30 2010 | Dolby Laboratories Licensing Corporation; DOLBY INTERNATIONAL AB | Scene change detection around a set of seed points in media data |
9576197, | Oct 30 2008 | CITIBANK, N A | Methods and apparatus for identifying media content using temporal signal characteristics |
Patent | Priority | Assignee | Title |
3919479, | |||
4112496, | Dec 13 1974 | Sanders Associates, Inc. | Capacitor matrix correlator for use in the correlation of periodic signals |
4282403, | Aug 10 1978 | Nippon Electric Co., Ltd. | Pattern recognition with a warping function decided for each reference pattern by the use of feature vector components of a few channels |
4450531, | Sep 10 1982 | ENSCO, INC.; ENSCO INC | Broadcast signal recognition system and method |
4570232, | Dec 21 1981 | Nippon Telegraph & Telephone Corporation | Speech recognition apparatus |
4843562, | Jun 24 1987 | BROADCAST DATA SYSTEMS LIMITED PARTNERSHIP, 1515 BROADWAY, NEW YORK, NEW YORK 10036, A DE LIMITED PARTNERSHIP | Broadcast information classification system and method |
5210820, | May 02 1990 | NIELSEN ENTERTAINMENT, LLC, A DELAWARE LIMITED LIABILITY COMPANY; THE NIELSEN COMPANY US , LLC, A DELAWARE LIMITED LIABILITY COMPANY | Signal recognition system and method |
5313556, | Feb 22 1991 | Seaway Technologies, Inc. | Acoustic method and apparatus for identifying human sonic sources |
5512933, | Oct 15 1992 | Taylor Nelson AGB plc | Identifying a received programme stream |
5694474, | Sep 18 1995 | Vulcan Patents LLC | Adaptive filter for signal processing and method therefor |
5864807, | Feb 25 1997 | Google Technology Holdings LLC | Method and apparatus for training a speaker recognition system |
6192337, | Aug 14 1998 | Nuance Communications, Inc | Apparatus and methods for rejecting confusible words during training associated with a speech recognition system |
6513161, | Jan 22 1997 | NIELSEN COMPANY US , LLC, THE, A DELAWARE LIMITED LIABILITY COMPANY | Monitoring system for recording device |
6801895, | Dec 07 1998 | Nuance Communications, Inc | Method and apparatus for segmenting a multi-media program based upon audio events |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Nov 29 2001 | Hewlett-Packard Development Company, L.P. | (assignment on the face of the patent) | / | |||
Jan 08 2002 | MORENO, PEDRO J | COMPAQ INFORMATION TECHNOLOGIES GROUP, L P | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 012685 | /0058 | |
Oct 01 2002 | Compaq Information Technologies Group LP | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 014628 | /0103 |
Date | Maintenance Fee Events |
Dec 21 2009 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Nov 25 2013 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Jan 29 2018 | REM: Maintenance Fee Reminder Mailed. |
Jul 16 2018 | EXP: Patent Expired for Failure to Pay Maintenance Fees. |
Date | Maintenance Schedule |
Jun 20 2009 | 4 years fee payment window open |
Dec 20 2009 | 6 months grace period start (w surcharge) |
Jun 20 2010 | patent expiry (for year 4) |
Jun 20 2012 | 2 years to revive unintentionally abandoned end. (for year 4) |
Jun 20 2013 | 8 years fee payment window open |
Dec 20 2013 | 6 months grace period start (w surcharge) |
Jun 20 2014 | patent expiry (for year 8) |
Jun 20 2016 | 2 years to revive unintentionally abandoned end. (for year 8) |
Jun 20 2017 | 12 years fee payment window open |
Dec 20 2017 | 6 months grace period start (w surcharge) |
Jun 20 2018 | patent expiry (for year 12) |
Jun 20 2020 | 2 years to revive unintentionally abandoned end. (for year 12) |