Method and apparatus for identifying an unknown work

Information

  • Patent Grant
  • 8082150
  • Patent Number
    8,082,150
  • Date Filed
    Tuesday, March 24, 2009
    15 years ago
  • Date Issued
    Tuesday, December 20, 2011
    13 years ago
Abstract
A system for determining an identity of a received work. The system receives audio data for an unknown work. The audio data is divided into segments. The system generates a signature of the unknown work from each of the segments. Reduced dimension signatures are then generated at least a portion of the signatures. The reduced dimension signatures are then compared to reduced dimensions signatures of known works that are stored in a database. A list of candidates of known works is generated from the comparison. The signatures of the unknown works are then compared to the signatures of the known works in the list of candidates. The unknown work is then identified as the known work having signatures matching within a threshold.
Description
BACKGROUND OF THE INVENTION
Field of the Invention

The present invention relates to data communications. In particular, the present invention relates to a novel method and apparatus for identifying an unknown work.


THE PRIOR ART
Background

Digital audio technology has greatly changed the landscape of music and entertainment. Rapid increases in computing power coupled with decreases in cost have made it possible for individuals to generate finished products having a quality once available only in a major studio. One consequence of modern technology is that legacy media storage standards, such as reel-to-reel tapes, are being rapidly replaced by digital storage media, such as the Digital Versatile Disk (DVD), and Digital Audio Tape (DAT). Additionally, with higher capacity hard drives standard on most personal computers, home users may now store digital files such as audio or video tracks on their home computers.


Furthermore, the Internet has generated much excitement, particularly among those who see the Internet as an opportunity to develop new avenues for artistic expression and communication. The Internet has become a virtual gallery, where artists may post their works on a Web page. Once posted, the works may be viewed by anyone having access to the Internet.


One application of the Internet that has received considerable attention is the ability to transmit recorded music over the Internet. Once music has been digitally encoded, the audio may be both downloaded by users for play, or broadcast (“streamed”) over the Internet. When audio is streamed, it may be listened to by Internet users in a manner much like traditional radio stations.


Given the widespread use of digital media, digital audio files, or digital video files containing audio information, may need to be identified. The need for identification of digital files may arise in a variety of situations. For example, an artist may wish to verify royalty payments or generate their own Arbitron®-like ratings by identifying how often their works are being streamed or downloaded. Additionally, users may wish to identify a particular work. The prior art has made efforts to create methods for identifying digital audio works.


However, systems of the prior art suffer from certain disadvantages. One area of difficulty arises when a large number of reference signatures must be compared to an unknown audio recording.


The simplest method for comparing an incoming audio signature (which could be from a file on the Internet, a recording of a radio or Internet radio broadcast, a recording from a cell phone, etc) to a database of reference signatures for the purpose of identification is to simply compare the incoming signature to every element of the database. However, since it may not be known where the reference signatures might have occurred inside the incoming signature, this comparison must be done at many time locations within the incoming signature. Each individual signature-to-signature comparison at each point in time may also be done in a “brute-force” manner using techniques known in the art; essentially computing the full Euclidean distance between the entire signatures' feature vectors. A match can then be declared when one of these comparisons yields a score or distance that is above or below some threshold, respectively.


However, when an audio signature or fingerprint contains a large number of features such a brute-force search becomes too expensive computationally for real-world databases which typically have several hundred thousand to several million signatures.


Many researchers have worked on methods for multi-dimensional indexing, although the greatest effort has gone into geographical (2-dimensional) or spatial (3-dimensional) data. Typically, all of these methods order the elements of the database based on their proximity to each other.


For example, the elements of the database can be clustered into hyper-spheres or hyper-rectangles, or the space can be organized into a tree form by using partitioning planes. However, when the number of dimensions is large (on the order of 15 or more), it can be shown mathematically that more-or-less uniformly distributed points in the space all become approximately equidistant from each other. Thus, it becomes impossible to cluster the data in a meaningful way, and comparisons can become both lengthy and inaccurate.


Hence, there exists a need to provide a means for data comparison which overcomes the disadvantages of the prior art.


BRIEF DESCRIPTION OF THE INVENTION

A method and apparatus for identifying an unknown work is disclosed. In one aspect a method may includes the acts of providing a reference database having a reduced dimensionality containing signatures of sampled works; receiving a sampled work; producing a signature from the work; and reducing the dimensionality of the signature.





BRIEF DESCRIPTION OF THE DRAWING FIGURES


FIG. 1A is a flowchart of a method according to the present invention.



FIG. 1B is a flowchart of another method according to the present invention.



FIG. 2 is a diagram of a system suitable for use with the present invention.



FIG. 3 is a diagram of segmenting according to the present invention.



FIG. 4 is a detailed diagram of segmenting according to the present invention showing hop size.



FIG. 5 is a graphical flowchart showing the creating of a segment feature vector according to the present invention.



FIG. 6 is a diagram of a signature according to the present invention.



FIG. 7A is a flowchart of a method for preparing a reference database according to the present invention.



FIG. 7B is a flowchart of method for identifying an unknown work according to the present invention.





DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

Persons of ordinary skill in the art will realize that the following description of the present invention is illustrative only and not in any way limiting. Other embodiments of the invention will readily suggest themselves to such skilled persons having the benefit of this disclosure.


It is contemplated that the present invention may be embodied in various computer and machine-readable data structures. Furthermore, it is contemplated that data structures embodying the present invention will be transmitted across computer and machine-readable media, and through communications systems by use of standard protocols such as those used to enable the Internet and other computer networking standards.


The invention further relates to machine-readable media on which are stored embodiments of the present invention. It is contemplated that any media suitable for storing instructions related to the present invention is within the scope of the present invention. By way of example, such media may take the form of magnetic, optical, or semiconductor media.


The present invention may be described through the use of flowcharts. Often, a single instance of an embodiment of the present invention will be shown. As is appreciated by those of ordinary skill in the art, however, the protocols, processes, and procedures described herein may be repeated continuously or as often as necessary to satisfy the needs described herein. Accordingly, the representation of the present invention through the use of flowcharts should not be used to limit the scope of the present invention.


The present invention may also be described through the use of web pages in which embodiments of the present invention may be viewed and manipulated. It is contemplated that such web pages may be programmed with web page creation programs using languages standard in the art such as HTML or XML. It is also contemplated that the web pages described herein may be viewed and manipulated with web browsers running on operating systems standard in the art, such as the Microsoft Windows® and Macintosh® versions of Internet Explorer® and Netscape®. Furthermore, it is contemplated that the functions performed by the various web pages described herein may be implemented through the use of standard programming languages such a Java® or similar languages.


The present invention will first be described in general overview. Then, each element will be described in further detail below.


Referring now to FIG. 1A, a flowchart is shown which provides a general overview of the present invention as related to the preparation of a database of reference signatures. Two overall acts are performed to prepare a reference database in accordance with the present invention: in act 100, the present invention reduces the dimensionality of reference signatures; and the reference database is indexed in act 102.


Referring now to FIG. 1B, a flowchart is shown which provides a general overview of the present invention as related to the identification of an unknown signature in accordance with the present invention. In act 104, a sampled work is received. In act 106, the present invention reduces the dimensionality of the received work. In act 108, the present invention determines initial candidates. In act 110, the present invention searches for the best candidate.


Prior to presenting a detailed overview of each act of FIGS. 1A and 11B, some background will first be presented.


Structural Embodiment of the Present Invention

Referring now to FIG. 2, a diagram of a system suitable for use with the present invention is shown. FIG. 2 includes a client system 200. It is contemplated that client system 200 may comprise a personal computer 202 including hardware and software standard in the art to run an operating system such as Microsoft Windows®, MAC OS® Palm OS, UNIX, or other operating systems standard in the art. Client system 200 may further include a database 204 for storing and retrieving embodiments of the present invention. It is contemplated that database 204 may comprise hardware and software standard in the art and may be operatively coupled to PC 202. Database 204 may also be used to store and retrieve the works and segments utilized by the present invention.


Client system 200 may further include an audio/video (A/V) input device 208. A/V device 208 is operatively coupled to PC 202 and is configured to provide works to the present invention which may be stored in traditional audio or video formats. It is contemplated that A/V device 208 may comprise hardware and software standard in the art configured to receive and sample audio works (including video containing audio information), and provide the sampled works to the present invention as digital audio files. Typically, the A/V input device 208 would supply raw audio samples in a format such as 16-bit stereo PCM format. A/V input device 208 provides an example of means for receiving a sampled work.


It is contemplated that sampled works may be obtained over the Internet, also. Typically, streaming media over the Internet is provided by a provider, such as provider 218 of FIG. 2. Provider 218 includes a streaming application server 220, configured to retrieve works from database 222 and stream the works in a formats standard in the art, such as Real®, Windows Media®, or QuickTime®. The server then provides the streamed works to a web server 224, which then provides the streamed work to the Internet 214 through a gateway 216. Internet 214 may be any packet-based network standard in the art, such as IP, Frame Relay, or ATM.


To reach the provider 218, the present invention may utilize a cable or DSL head end 212 standard in the art operatively, which is coupled to a cable modem or DSL modem 210 which is in turn coupled to the system's network 206. The network 206 may be any network standard in the art, such as a LAN provided by a PC 202 configured to run software standard in the art.


It is contemplated that the sampled work received by system 200 may contain audio information from a variety of sources known in the art, including, without limitation, radio, the audio portion of a television broadcast, Internet radio, the audio portion of an Internet video program or channel, streaming audio from a network audio server, audio delivered to personal digital assistants over cellular or wireless communication systems, or cable and satellite broadcasts.


Additionally, it is contemplated that the present invention may be configured to receive and compare segments coming from a variety of sources either stored or in real-time. For example, it is contemplated that the present invention may compare a real-time streaming work coming from streaming server 218 or A/V device 208 with a reference segment stored in database 204.


Segmenting Background


It is contemplated that a wide variety of sampled works may be utilized in the present invention. However, the inventors have found the present invention especially useful with segmented works. An overview of a segmented work will now be provided.



FIG. 3 shows a diagram showing the segmenting of a work according to the present invention. FIG. 3 includes audio information 300 displayed along a time axis 302. FIG. 3 further includes a plurality of segments 304, 306, and 308 taken of audio information 300 over some segment size T.


In an exemplary non-limiting embodiment of the present invention, instantaneous values of a variety of acoustic features are computed at a low level, preferably about 100 times a second. In particular, 10 MFCCs (cepstral coefficients) are computed. It is contemplated that any number of MFCCs may be computed. Preferably, 5-20 MFCCs are computed, however, as many as 30 MFCCs may be computed, depending on the need for accuracy versus speed.


Segment-level features are disclosed U.S. Pat. No. 5,918,223 to Blum, et al., which is assigned to the assignee of the current disclosure and incorporated by reference as though fully set forth herein. In an exemplary non-limiting embodiment of the present invention, the segment-level acoustical features comprise statistical measures as disclosed in the '223 patent of low-level features calculated over the length of each segment. The data structure may store other bookkeeping information as well (segment size, hop size, item ID, UPC, etc). As can be seen by inspection of FIG. 3, the segments 304, 306, and 308 may overlap in time. This amount of overlap may be represented by measuring the time between the center point of adjacent segments. This amount of time is referred to herein as the hop size of the segments, and is so designated in FIG. 3. By way of example, if the segment length T of a given segment is one second, and adjacent segments overlap by 50%, the hop size would be 0.5 second.


The hop size may be set during the development of the software. Additionally, the hop sizes of the reference database and the real-time signatures may be predetermined to facilitate compatibility. For example, the reference signatures in the reference database may be precomputed with a fixed hop and segment size, and thus the client applications should conform to this segment size and have a hop size which integrally divides the reference signature hop size. It is contemplated that one may experiment with a variety of segment sizes in order to balance the tradeoff of accuracy with speed of computation for a given application.


The inventors have found that by carefully choosing the hop size of the segments, the accuracy of the identification process may be significantly increased. Additionally, the inventors have found that the accuracy of the identification process may be increased if the hop size of reference segments and the hop size of segments obtained in real-time are each chosen independently. The importance of the hop size of segments may be illustrated by examining the process for segmenting pre-recorded works and real-time works separately.


Reference Signatures


Prior to attempting to identify a given work, a reference database of signatures must be created. When building a reference database, a segment length having a period of less than three seconds is preferred. In an exemplary non-limiting embodiment of the present invention, the segment lengths have a period ranging from 0.5 seconds to 3 seconds. For a reference database, the inventors have found that a hop size of approximately 50% to 100% of the segment size is preferred.


It is contemplated that the reference signatures may be stored on a database such as database 204 as described above. Database 204 and the discussion herein provide an example of means for providing a plurality of reference signatures each having a segment size and a hop size.


Unknown Signatures


The choice of the hop size is important for the signatures of the audio to be identified, hereafter referred to as “unknown audio.”



FIG. 4 shows a detailed diagram of the segmentation of unknown audio according to the present invention. FIG. 4 includes unknown audio information 400 displayed along a time axis 402. FIG. 4 further includes segments 404 and 406 taken of audio information 400 over some segment length T. In an exemplary non-limiting embodiment of the present invention, the segment length of unknown audio segments is chosen to range from 0.5 to 3 seconds.


As can be seen by inspection of FIG. 4, the hop size of unknown audio segments is chosen to be smaller than that of reference segments. In an exemplary non-limiting embodiment of the present invention, the hop size of unknown audio segments is less than 50% of the segment size. In yet another exemplary non-limiting embodiment of the present invention, the unknown audio hop size may be 0.1 seconds.


The inventors have found such a small hop size advantageous for the following reasons. The ultimate purpose of generating unknown audio segments is to analyze and compare them with the reference segments in the database to look for matches. The inventors have found at least two major reasons why an unknown audio recording would not match its counterpart in the database. One is that the broadcast channel does not produce a perfect copy of the original. For example, the work may be edited or processed or the announcer may talk over part of the work. The other reason is that larger segment boundaries may not line up in time with the original segment boundaries of the target recordings.


The inventors have found that by choosing a smaller hop size, some of the segments will ultimately have time boundaries that line up with the original segments, notwithstanding the problems listed above. The segments that line up with a “clean” segment of the work may then be used to make an accurate comparison while those that do not so line up may be ignored. The inventors have found that a hop size of 0.1 seconds seems to be the maximum that would solve this time shifting problem.


As mentioned above, once a work has been segmented, the individual segments are then analyzed to produce a segment feature vector. FIG. 5 is a diagram showing an overview of how the segment feature vectors may be created using the methods described in U.S. Pat. No. 5,918,223 to Blum, et al. It is contemplated that a variety of analysis methods may be useful in the present invention, and many different features may be used to make up the feature vector. The inventors have found that the pitch, brightness, bandwidth, and loudness features of the '223 patent to be useful in the present invention. Additionally, spectral features may be used analyzed, such as the energy in various spectral bands. The inventors have found that the cepstral features (MFCCs) are very robust (more invariant) given the distortions typically introduced during broadcast, such as EQ, multi-band compression/limiting, and audio data compression techniques such as MP3 encoding/decoding, etc.


In act 500, the audio segment is sampled to produce a segment. In act 502, the sampled segment is then analyzed using Fourier Transform techniques to transform the signal into the frequency domain. In act 504, mel frequency filters are applied to the transformed signal to extract the significant audible characteristics of the spectrum. In act 506, a Discrete Cosine Transform is applied which converts the signal into mel frequency cepstral coefficients (MFCCs). Finally, in act 508, the MFCCs are then averaged over a predetermined period. In an exemplary non-limiting embodiment of the present invention, this period is approximately one second. Additionally, other characteristics may be computed at this time, such as brightness or loudness. A segment feature vector is then produced which contains a list containing at least the 10 MFCCs corresponding average.


The disclosure of FIGS. 3, 4, and 5 provide examples of means for creating a signature of a sampled work having a segment size and a hop size.



FIG. 6 is a diagram showing a complete signature 600 according to the present invention. Signature 600 includes a plurality of segment feature vectors 1 through n generated as shown and described above. Signature 600 may also include an identification portion containing a unique ID. It is contemplated that the identification portion may contain a unique identifier provided by the RIAA (Recording Industry Association of America) or some other audio authority or cataloging agency. The identification portion may also contain information such as the UPC (Universal Product Code) of the various products that contain the audio corresponding to this signature. Additionally, it is contemplated that the signature 600 may also contain information pertaining to the characteristics of the file itself, such as the hop size, segment size, number of segments, etc., which may be useful for storing and indexing.


Signature 600 may then be stored in a database and used for comparisons.


The following computer code in the C programming language provides an example of a database structure in memory according to the present invention:

















typedef struct



{










float hopSize;
/* hop size */



float segmentSize;
/* segment size */



MFSignature* signatures;
/* array of signatures */









} MFDatabase;










The following provides an example of the structure of a segment according to the present invention:














typedef struct


{










char* id;
/* unique ID for this audio clip */



long numSegments;
/* number of segments */



float* features;
/* feature array */



long size;
/* size of per-segment feature vector */









float hopSize;



float segmentSize;







} MFSignature;









The discussion of FIG. 6 provides an example of means for storing segments and signatures according to the present invention.


A more detailed description of the operation of the present invention will now be provided.


Referring now to FIG. 7A, a flowchart showing one aspect of a method according to the present invention is presented.


Reference Database Preparation


Prior to the identification of an unknown sample, a database of reference signatures is prepared in accordance with the present invention.


In an exemplary non-limiting embodiment of the present invention, a reference signature may comprise an audio signature derived from a segmentation of the original audio work as described above. In a presently preferred embodiment, reference signatures have 20 non-overlapping segments, where each segment is one second in duration, with one-second spacing from center to center, as described above. Each of these segments is represented by 10 Mel filtered cepstral coefficients (MFCCs), resulting in a feature vector of 200 dimensions. Since indexing a vector space of this dimensionality is not practical, the number of dimensions used for the initial search for possible candidates is reduced according to the present invention.


Reducing the Dimensionality



FIG. 7A is a flowchart of dimension reduction according to the present invention. The number of dimensions used for the initial search for possible candidates is reduced, resulting in what the inventors refer to as a subspace. By having the present invention search a subspace at the outset, the efficiency of the search may be greatly increased.


Referring now to FIG. 7A, the present invention accomplishes two tasks to develop this subspace: (1) the present invention uses less than the total number of segments in the reference signatures in act 701; and (2) the present invention performs a principal components analysis to reduce the dimensionality in act 703.


Using Less Segments to Perform an Initial Search


The inventors empirically have found that using data from two consecutive segments (i.e., a two-second portion of the signature) to search for approximately 500 candidates is a good tradeoff between computation complexity and accuracy. The number of candidates can be altered for different applications where either speed or accuracy is more or less important.


For example, the present invention may be configured to extract a predetermined percentage of candidates. In an exemplary non-limiting embodiment of the present invention, a list of candidates may comprise 2% of the size of the reference signature database when using 2 segments for the initial search. In another exemplary non-limiting embodiment of the present invention, a list of candidates may be those reference signatures whose distances based on the initial 2 segment search are below a certain threshold.


As will be appreciated by those of ordinary skill in the art, the dimension reduction of the present invention may be used to perform initial search using fewer segments for data other than MFCC-based feature vectors. It is contemplated that any feature-based vector set may be used in the present invention.


Furthermore, the segments used in the initial search do not have to be the same size as the segments used for the final search. Since it may be better to use as few dimensions as possible in the initial search for candidates, a smaller segment size is advantageous here. The full segment size can then be used in the final search. In an exemplary non-limiting embodiment of the current invention, the initial search may use the higher-order MFCCs (since these are the most robust)—this is a simple way to reduce the dimensionality.


In the next section, we will discuss another, more sophisticated, method for reducing the segment size for the initial candidate search.


Perform Alternate Encoding


The second step is to use an alternate encoding of the MFCC data which has the same information but with fewer features.


To accomplish this, the present invention first performs an eigenanalysis of N candidates to determine the principal components of the MFCCs for our typical audio data. In an exemplary non-limiting embodiment of the present invention, the present invention examines 25,000 audio signatures of 20 segments each—each taken from a different recording, which gives provides 500,000 sets of MFCCs. The inventors have found that this is enough to be a good statistical sample of the feature vectors.


As is appreciated by those of ordinary skill in the art, the number examined in the present invention may be adjusted to provide a good statistical sample of different kinds of music. For example, 100 or a 1000 segments may be satisfactory.


Next, a Karhunen-Loève transformation is derived. Each set of 10 MFCCs becomes a column of a matrix A. We then compute ATA and find the 10 eigenvalues and eigenvectors of this matrix. Sorting the eigenvectors by eigenvalue (largest eigenvalue first) results in a list of orthogonal basis vectors that are the principal components of the segment data. For a database of typical music recordings, 95% of the information in the MFCCs is contained in the first 7 components of this new basis.


As is known by those having ordinary skill in the art, the Karhunen-Loève transformation is represented by the matrix that has the all 10 of the above eigenvectors as its rows. This transformation is applied to all the segments of all the reference signatures in the database as well as to all the segments of any signatures that are to be identified. This allows approximate distances to be computed by using the first few components of the transformed segment MFCC vectors for a small tradeoff in accuracy. Most importantly, it reduces the initial search dimension to 14 (7 components times 2 segments), which can be indexed with reasonable efficiency.


As will be appreciated by those of ordinary skill in the art, dimension reduction according to the present invention may be utilized to examine subspaces for feature sets other than MFCCs. The dimension reduction of the present invention may be applied to any set of features since such sets comprise vectors of floating point numbers. For example, given a feature vector comprising spectral coefficients and loudness, one could still apply the KL-process of the present invention to yield a smaller and more easily searched feature vector.


Furthermore, the transform of the present invention may be applied to each segment separately. For example, prior art identification methods may use a single 30-second segment of sound over which they compute an average feature vector. Of course, the accuracy of such methods are much lower, but the process of the present invention may work for such features as well. Moreover, such prior art methods may be used as an initial search.


The dimension reduction aspect of the present invention provides significant efficiency gains over prior art methods. For example, in a “brute force” method, the signature of the incoming sampled work is tested against every reference signature in the database. This is time-consuming because the comparison of any two signatures is a 200-dimensional comparison and because there are a lot of reference signatures in the database. Either alone are not unsatisfactory, but both together takes a long time. The present invention solves the first problem by searching only a subspace, i.e., using less than all 200 dimensions in the comparison.


In addition to the raw speedup given by searching a subspace, the reduced dimensionality also allows one to practically index the database of reference signatures. As mentioned above, it is impractical to index a 200-dimensional database, but 14 is practical.


The present disclosure thus provides for several manners in which the dimensionality may be reduced:

    • (1) searching for the top N candidates over a subspace;
    • (2) searching for the top N candidates using less than the total number of segments from the reference signature;
    • (3) searching for the top N candidates by projecting the reference signatures and signature of the work to be identified onto a subspace; and
    • (4) searching for the top N candidates by projecting the reference signatures and signature of the work to be identified onto a subspace, where the subspace is determined by a Karhunen-Loève transformation.


The preparation of the reference database may occur at any time. For example, the results of the preparation may occur each time the server is started up. Additionally, the results could be saved and reused from then on, or the results may be prepared once and used over again. It may need to be recomputed whenever a new reference signature is added to the database.


Computing the Index


The present invention may also compute an index of the reference signatures. As is appreciated by those having ordinary skill in the art, many indexing strategies are available for use in the present invention. Examples include the k-d tree, the SS-tree, the R-tree, the SR-tree, and so on. Any look-up method known in the art may be used in the present disclosure. Common to all indexing strategies is that the multidimensional space is broken into a hierarchy of regions which are then structured into a tree. As one progress down the tree during the search process, the regions become smaller and have fewer elements. All of these trees have tradeoffs that affect the performance under different conditions, e.g., whether the entire tree fits into memory, whether the data is highly clustered, and so on.


In an exemplary non-limiting embodiment of the present invention, a binary k-d tree indexing method is utilized. This is a technique well-known in the art, but a brief overview is given here. At the top level, the method looks to see which dimension has the greatest extent, and generates a hyperplane perpendicular to this dimension that splits the data into two regions at its median. This yields two subspaces on either side of the plane. This process is continued by recursion on the data in each of these subspaces until each of the subspaces has a single element.


After the reference database has been prepared, the present invention may be used to identify an unknown work. Such a process will now be shown and described.


Identification of an Unknown Work


Referring now to FIG. 7B, a flowchart of a method for identifying an unknown work is shown. In act 700, the present invention receives a sampled work. In act 702, the present invention determines a set of initial candidates. Finally, in act 704, the present invention determines the best candidate. Each act will now be described in more detail.


Receiving a Sampled Work


Beginning with act 700, a sampled work is provided to the present invention. It is contemplated that the work will be provided to the present invention as a digital audio stream. It should be understood that if the audio is in analog form, it may be digitized in any manner standard in the art.


Indexed Lookup.


In act 702, the present invention determines the initial candidates. In a preferred embodiment, the present invention uses the index created above to perform an indexed candidate search.


An index created in accordance with the present invention may used to do the N nearest neighbor search required to find the initial candidates.


Candidate Search.


Once a set of N nearest neighbors is determined, the closest candidate may then be determined in act 704. In an exemplary non-limiting embodiment of the present invention, a brute-force search method may be used to determine which candidate is the closest to the target signature. In another preferred embodiment, the present invention may compare the distance of this best candidate to a predetermined threshold to determine whether there is a match.


There are a number of techniques that may be applied to the candidate search stage which make it much faster. In one aspect, these techniques may be used in a straightforward brute-force search that did not make use of any of the steps previously described above. That is, one could do a brute-force search directly on the reference signature database without going through the index search of step 702, for example. Since there is some overhead in doing step 702, direct brute-force search may be faster for some applications, especially those that need only a small reference database, e.g., generating a playlist for a radio station that plays music from a small set of possibilities.


Speedups of Brute-Force Search.


Any reference signature that is close to the real-time signature has to be reasonably close to it for every segment in the signature. Therefore, in one aspect, several intermediate thresholds are tested as the distance is computed and the computation is exited if any of these thresholds are exceeded. In a further aspect, each single segment-to-segment distance is computed as the sum of the squared differences of the MFCCs for the two corresponding segments. Given the current computation of the MFCCs, average segment-to-segment distances for matches are about approximately 2.0. In an exemplary non-limiting embodiment of the invention, we exit the computation and set the distance to infinity if any single segment-to-segment distance is greater than 20. In further aspects, the computation is exited if any two segment-to-segment distances are greater than 15, or if any four segment-to-segment distances are greater than 10. It should be clear to anyone skilled in the art that other thresholds for other combinations of intermediate distances could easily be implemented and set using empirical tests.


Since any match will also be close to a match at a small time-offset, we may initially compute the distances at multiples of the hop size. If any of these distances are below a certain threshold, we compute the distances for hops near it. In an exemplary non-limiting embodiment of the invention, we compute distances for every third hop. If the distance is below 8.0, we compute the distances for the neighboring hops. It should be clear to anyone skilled in the art that other thresholds for other hop-skippings could easily be implemented and set using simple empirical tests.


While embodiments and applications of this invention have been shown and described, it would be apparent to those skilled in the art that many more modifications than mentioned above are possible without departing from the inventive concepts herein. For example, the teachings of the present disclosure may be used to identify a variety of sampled works, including, but not limited to, images, video and general time-based media. The invention, therefore, is not to be restricted except in the spirit of the appended claims.

Claims
  • 1. A method, implemented by a computing system programmed to perform the following, comprising: providing, by the computing system, a reference database containing a plurality of reference works, wherein each reference work corresponds to a reference signature comprising a plurality of reference segments;receiving, by the computing system, an unknown work, wherein the unknown work comprises a plurality of unknown segments;calculating, by the computing system, at least one distance from one of the plurality of unknown segments to one of the plurality of reference segments;if the at least one calculated distance does not meet a predefined threshold, repeating, by the computing system, a calculation for a distance from each subsequent segment of the plurality of unknown segments to each subsequent segment of the plurality of reference segments until the predefined threshold is met; andidentifying, by the computing system, the unknown work as one of the plurality of reference works based on the calculated distances.
  • 2. The method of claim 1, wherein the predetermined threshold includes one calculated distance greater than 20.
  • 3. The method of claim 1, wherein the predetermined threshold includes two calculated distances greater than 15.
  • 4. The method of claim 1, wherein the predetermined threshold includes four calculated distances greater than 10.
  • 5. The method of claim 1, wherein calculating the at least one distance from one of the plurality of unknown segments to one of the plurality of reference segments comprises: calculating a mel frequency cepstral coefficients (MFCC) for the one of the plurality of unknown segments;calculating a MFCC for the one of the plurality of reference segments; andcalculating a sum of squared differences of the MFCCs for the unknown segment and the
  • 6. A non-transitory computer readable storage medium, comprising executable instructions which when executed on a processing system cause the processing system to perform a method comprising: providing a reference database containing a plurality of reference works, wherein each reference work corresponds to a reference signature comprising a plurality of reference segments, the segments defining a hop size;receiving an unknown work having an unknown signature;calculating a distance from the unknown signature to one of the plurality of reference signatures at a point in time in said reference signature;if the calculated distance is greater than a predefined threshold, repeating a calculation for a distance from the unknown signature to the reference signature at least one offset point in time in the reference signature until the calculated distance is less than the predefined threshold;calculating a distance from the unknown signature to the reference signature at one or more points in time neighboring the point in time where the distance calculated is less than the predefined threshold; andidentifying the unknown signature as one of the plurality of reference works based on the distances calculated at the one or more neighboring points in time.
  • 7. The non-transitory computer readable storage medium of claim 6, wherein the offset point in time is a point in time one or more multiples of the hop size from the last point in time where the distance was calculated.
  • 8. The non-transitory computer readable storage medium of claim 6, wherein the offset point in time is a point in time three hop sizes from the last point in time where the distance was calculated.
  • 9. The non-transitory computer readable storage medium of claim 6, wherein the one or more neighboring points in time is one or more point in time one hop size from the point in time in the reference signature where the distance calculated is less than the predefined threshold.
  • 10. The non-transitory computer readable storage medium of claim 6, wherein the predefined threshold is 8.0.
  • 11. A computer-implemented apparatus comprising: a memory to store a reference database containing a plurality of reference works, wherein each reference work corresponds to a reference signature comprising a plurality of reference segments;a processor coupled to the memory to receive an unknown work, wherein the unknown work comprises a plurality of unknown segments;to calculate at least one distance from one of the plurality of unknown segments to one of the plurality of reference segments;if the at least one calculated distance does not meet a predefined threshold, to repeat a calculation for a distance from each subsequent segment of the plurality of unknown segments to each subsequent segment of the plurality of reference segments until the predefined threshold is met; andto identify the unknown work as one of the plurality of reference works based on the calculated distances.
  • 12. The system of claim 11, wherein the predetermined threshold includes one calculated distance greater than 20.
  • 13. The system of claim 11, wherein the predetermined threshold includes two calculated distances greater than 15.
  • 14. The system of claim 11, wherein the predetermined threshold includes four calculated distances greater than 10.
  • 15. The system of claim 11, wherein the processor is to calculate the at least one distance from one of the plurality of unknown segments to one of the plurality of reference segments by: calculating a mel frequency cepstral coefficients (MFCC) for the one of the plurality of unknown segments;calculating a MFCC for the one of the plurality of reference segments; andcalculating a sum of squared differences of the MFCCs for the unknown segment and the reference segment.
PRIORITY CLAIM

This application is a continuation of U.S. patent application Ser. No. 11/239,543, filed Sep. 28, 2005 now U.S. Pat. No. 7,529,659, which is a continuation of U.S. patent application Ser. No. 10/192,783, filed Jul. 9, 2002 now U.S. Pat. No. 6,968,337, which claims the benefit of U.S. Provisional Patent application Ser. No. 60/304,647, filed Jul. 10, 2001, which are hereby incorporated by reference.

US Referenced Citations (177)
Number Name Date Kind
3919479 Moon et al. Nov 1975 A
4230990 Lert, Jr. et al. Oct 1980 A
4449249 Price May 1984 A
4450531 Kenyon May 1984 A
4454594 Hefron et al. Jun 1984 A
4677455 Okajima Jun 1987 A
4677466 Lert, Jr. et al. Jun 1987 A
4739398 Thomas et al. Apr 1988 A
4843562 Kenyon et al. Jun 1989 A
4918730 Schulze Apr 1990 A
5210820 Kenyon May 1993 A
5247688 Ishigami Sep 1993 A
5283819 Glick Feb 1994 A
5327521 Savic et al. Jul 1994 A
5437050 Lamb et al. Jul 1995 A
5442645 Ugon Aug 1995 A
5504518 Ellis Apr 1996 A
5581658 O'Hagan et al. Dec 1996 A
5588119 Vincent Dec 1996 A
5612729 Ellis et al. Mar 1997 A
5612974 Astrachan Mar 1997 A
5613004 Cooperman et al. Mar 1997 A
5638443 Stefik Jun 1997 A
5692213 Goldberg et al. Nov 1997 A
5701452 Siefert Dec 1997 A
5710916 Barbara et al. Jan 1998 A
5724605 Wissner Mar 1998 A
5732193 Aberson Mar 1998 A
5850388 Anderson Dec 1998 A
5881182 Fiete et al. Mar 1999 A
5918223 Blum et al. Jun 1999 A
5924071 Morgan et al. Jul 1999 A
5930369 Cox et al. Jul 1999 A
5943422 Van Wie et al. Aug 1999 A
5949885 Leighton Sep 1999 A
5959659 Dokic Sep 1999 A
5983176 Hoffert et al. Nov 1999 A
6006183 Lai et al. Dec 1999 A
6006256 Zdepski et al. Dec 1999 A
6011758 Dockes Jan 2000 A
6026439 Chowdhury Feb 2000 A
6044402 Jacobson Mar 2000 A
6067369 Kamei May 2000 A
6088455 Logan et al. Jul 2000 A
6092040 Voran Jul 2000 A
6096961 Bruti Aug 2000 A
6118450 Proehl et al. Sep 2000 A
6192340 Abecassis Feb 2001 B1
6195693 Berry Feb 2001 B1
6229922 Sasakawa et al. May 2001 B1
6243615 Neway Jun 2001 B1
6243725 Hempleman et al. Jun 2001 B1
6253193 Ginter Jun 2001 B1
6253337 Maloney et al. Jun 2001 B1
6279010 Anderson Aug 2001 B1
6279124 Brouwer et al. Aug 2001 B1
6285596 Miura et al. Sep 2001 B1
6330593 Roberts et al. Dec 2001 B1
6345256 Milsted et al. Feb 2002 B1
6374260 Hoffert et al. Apr 2002 B1
6385596 Wiser May 2002 B1
6418421 Hurtado et al. Jul 2002 B1
6422061 Sunshine Jul 2002 B1
6438556 Malik et al. Aug 2002 B1
6449226 Kumagai Sep 2002 B1
6452874 Otsuka et al. Sep 2002 B1
6453252 Laroche Sep 2002 B1
6460050 Pace et al. Oct 2002 B1
6463508 Wolf et al. Oct 2002 B1
6477704 Cremia Nov 2002 B1
6487641 Cusson et al. Nov 2002 B1
6490279 Chen et al. Dec 2002 B1
6496802 van Zoest et al. Dec 2002 B1
6526411 Ward Feb 2003 B1
6542869 Foote Apr 2003 B1
6550001 Corwin et al. Apr 2003 B1
6550011 Sims, III Apr 2003 B1
6552254 Hasegawa et al. Apr 2003 B2
6591245 Klug Jul 2003 B1
6609093 Gopinath et al. Aug 2003 B1
6609105 van Zoest et al. Aug 2003 B2
6628737 Timus Sep 2003 B1
6636965 Beyda Oct 2003 B1
6654757 Stern Nov 2003 B1
6732180 Hale May 2004 B1
6771316 Iggulden Aug 2004 B1
6771885 Agnihotri et al. Aug 2004 B1
6834308 Ikezoye Dec 2004 B1
6947909 Hoke, Jr. Sep 2005 B1
6968337 Wold Nov 2005 B2
7043536 Philyaw May 2006 B1
7047241 Erickson et al. May 2006 B1
7058223 Cox et al. Jun 2006 B2
7181398 Thong et al. Feb 2007 B2
7266645 Garg et al. Sep 2007 B2
7269556 Kiss et al. Sep 2007 B2
7281272 Rubin et al. Oct 2007 B1
7289643 Brunk et al. Oct 2007 B2
7349552 Levy et al. Mar 2008 B2
7363278 Schmelzer et al. Apr 2008 B2
7443797 Cheung et al. Oct 2008 B2
7500007 Ikezoye et al. Mar 2009 B2
7529659 Wold May 2009 B2
7562012 Wold Jul 2009 B1
7565327 Schmelzer Jul 2009 B2
7593576 Meyer et al. Sep 2009 B2
20010013061 DeMartin Aug 2001 A1
20010027493 Wallace Oct 2001 A1
20010027522 Saito Oct 2001 A1
20010034219 Hewitt et al. Oct 2001 A1
20010037304 Paiz Nov 2001 A1
20010056430 Yankowski Dec 2001 A1
20020049760 Scott Apr 2002 A1
20020064149 Elliott et al. May 2002 A1
20020082999 Lee Jun 2002 A1
20020087885 Peled et al. Jul 2002 A1
20020120577 Hans et al. Aug 2002 A1
20020123990 Abe et al. Sep 2002 A1
20020129140 Peled et al. Sep 2002 A1
20020133494 Goedken Sep 2002 A1
20020141384 Liu et al. Oct 2002 A1
20020152261 Arkin et al. Oct 2002 A1
20020152262 Arkin et al. Oct 2002 A1
20020156737 Kahn Oct 2002 A1
20020158737 Yokoyama Oct 2002 A1
20020186887 Rhoads Dec 2002 A1
20020198789 Waldman Dec 2002 A1
20030014530 Bodin Jan 2003 A1
20030018709 Schrempp et al. Jan 2003 A1
20030023852 Wold Jan 2003 A1
20030033321 Schrempp et al. Feb 2003 A1
20030037010 Schmelzer et al. Feb 2003 A1
20030051100 Patel Mar 2003 A1
20030061352 Bohrer Mar 2003 A1
20030061490 Abajian Mar 2003 A1
20030095660 Lee et al. May 2003 A1
20030135623 Schrempp et al. Jul 2003 A1
20030191719 Ginter et al. Oct 2003 A1
20030195852 Campbell et al. Oct 2003 A1
20040008864 Watson et al. Jan 2004 A1
20040010495 Kramer et al. Jan 2004 A1
20040053654 Kokumai et al. Mar 2004 A1
20040073513 Stefik et al. Apr 2004 A1
20040089142 Georges et al. May 2004 A1
20040133797 Arnold Jul 2004 A1
20040148191 Hoke, Jr. Jul 2004 A1
20040163106 Schrempp et al. Aug 2004 A1
20040167858 Erickson Aug 2004 A1
20040201784 Dagtas et al. Oct 2004 A9
20050021783 Ishii Jan 2005 A1
20050039000 Erickson Feb 2005 A1
20050044189 Ikezoye et al. Feb 2005 A1
20050097059 Shuster May 2005 A1
20050154678 Schmelzer Jul 2005 A1
20050154680 Schmelzer Jul 2005 A1
20050154681 Schmelzer Jul 2005 A1
20050216433 Bland et al. Sep 2005 A1
20050267945 Cohen et al. Dec 2005 A1
20050289065 Weare Dec 2005 A1
20060034177 Schrempp Feb 2006 A1
20060062426 Levy et al. Mar 2006 A1
20070074147 Wold Mar 2007 A1
20070078769 Way et al. Apr 2007 A1
20070186229 Conklin et al. Aug 2007 A1
20070226365 Hildreth et al. Sep 2007 A1
20080008173 Kanevsky et al. Jan 2008 A1
20080019371 Anschutz et al. Jan 2008 A1
20080133415 Ginter et al. Jun 2008 A1
20080141379 Schmelzer Jun 2008 A1
20080154730 Schmelzer Jun 2008 A1
20080155116 Schmelzer Jun 2008 A1
20090030651 Wold Jan 2009 A1
20090043870 Ikezoye et al. Feb 2009 A1
20090077673 Schmelzer Mar 2009 A1
20090089586 Brunk et al. Apr 2009 A1
20090240361 Wold et al. Sep 2009 A1
20090328236 Schmelzer Dec 2009 A1
Foreign Referenced Citations (32)
Number Date Country
0349106 Jan 1990 EP
0402210 Jun 1990 EP
0517405 May 1992 EP
0689316 Dec 1995 EP
0731446 Sep 1996 EP
0859503 Aug 1998 EP
0459046 Apr 1999 EP
1354276 Dec 2007 EP
1485815 Oct 2009 EP
WO 9636163 Nov 1996 WO
WO 9820672 May 1998 WO
WO 0005650 Feb 2000 WO
WO 0039954 Jul 2000 WO
WO 0063800 Oct 2000 WO
WO 0123981 Apr 2001 WO
WO 0147179 Jun 2001 WO
WO 0152540 Jul 2001 WO
WO 0162004 Aug 2001 WO
WO 0203203 Jan 2002 WO
WO 0215035 Feb 2002 WO
WO 0237316 May 2002 WO
WO 02082271 Oct 2002 WO
WO 03007235 Jan 2003 WO
WO 03009149 Jan 2003 WO
WO 03036496 May 2003 WO
WO 03067459 Aug 2003 WO
WO 03091990 Nov 2003 WO
WO 2004044820 May 2004 WO
WO 2004070558 Aug 2004 WO
WO 2006015168 Feb 2006 WO
WO 2006015168 Feb 2006 WO
WO 2009017710 Feb 2009 WO
Related Publications (1)
Number Date Country
20090192640 A1 Jul 2009 US
Provisional Applications (1)
Number Date Country
60304647 Jul 2001 US
Continuations (2)
Number Date Country
Parent 11239543 Sep 2005 US
Child 12410445 US
Parent 10192783 Jul 2002 US
Child 11239543 US