The present invention relates generally to delivering supplemental content stored on a database to a user (e.g., supplemental entertainment content relating to an audio recording), and more particularly to recognizing an audio recording fingerprint retrieving the supplemental content stored on the database.
Recordings can be identified by physically encoding the recording or the media storing one or more recordings, or by analyzing the recording itself. Physical encoding techniques include encoding a recording with a “watermark” or encoding the media storing one or more audio recordings with a TOC (Table of Contents). The watermark or TOC may be extracted during playback and transmitted to a remote database which then matches it to supplemental content to be retrieved. Supplemental content may be, for example, metadata, which is generally understood to mean data that describes other data. In the context of the present invention, metadata may be data that describes the contents of a digital audio compact disc recording. Such metadata may include, for example, artist information (name, birth date, discography, etc.), album information (title, review, track listing, sound samples, etc.), and relational information (e.g., similar artists and albums), and other types of supplemental information such as advertisements and related images.
With respect to recording analysis, various methods have been proposed. Generally, conventional techniques analyze a recording (or portions of recordings) to extract its “fingerprint,” that is a number derived from a digital audio signal that serves as a unique identifier of that signal. U.S. Pat. No. 6,453,252 purports to provide a system that generates an audio fingerprint based on the energy content in frequency subbands. U.S. Pat. No. 7,110,338 purports to provide a system that utilizes invariant features to generate fingerprints.
Storage space for storing libraries of fingerprints is required for any system utilizing fingerprint technology to provide metadata. Naturally, larger fingerprints require more storage capacity. Larger fingerprints also require more time to create, more time to recognize, and use up more processing power to generate and analyze than do smaller fingerprints.
What is needed is a fingerprinting technology which creates smaller fingerprints, uses less storage space and processing power, is easily scalable and requires relatively little hardware to operate. There also is a need for technology that will enable the management of hundreds or thousands of audio files contained on consumer electronics devices at home, in the car, in portable devices, and the like, which is compact and able to recognize a vast library of music.
It is an object of the present invention to provide a fingerprinting technology which creates smaller fingerprints, uses less storage space and processing power, is easily scalable and requires relatively little hardware to operate.
It is also an object of the present invention to provide a fingerprint library that will enable the management of hundreds or thousands of audio files contained on consumer electronics devices at home, in the car, in portable devices, and the like, which is compact and able to recognize a vast library of music.
In accordance with one embodiment of the present invention an apparatus for recognizing an audio fingerprint of an unknown audio recording is provided. The apparatus includes a database operable to store audio recording identifiers corresponding to known audio recordings, where the audio recording identifiers are organized by variation information about the audio recordings. A processor can search a database and identify at least one of the audio recording identifiers corresponding to the audio fingerprint, where the audio fingerprint includes variation information of the unknown audio recording.
In accordance with another embodiment of the present invention a method for recognizing an audio fingerprint of an unknown audio recording is provided. The method includes organizing audio recording identifiers corresponding to known audio recordings by variation information about the audio recordings, and identifying at least one of the audio recording identifiers corresponding to the audio fingerprint, where the audio fingerprint includes variation information of the unknown audio recording.
In accordance with yet another embodiment of the present invention computer-readable medium containing code recognizing an audio fingerprint of an unknown audio recording is provided. The computer-readable medium includes code for organizing audio recording identifiers corresponding to known audio recordings by variation information about the audio recordings, and identifying at least one of the audio recording identifiers corresponding to the audio fingerprint, where the audio fingerprint includes variation information of the unknown audio recording.
As used herein, the term “computer” (also referred to as “processor”) may refer to a single computer or to a system of interacting computers. Generally speaking, a computer is a combination of a hardware system, a software operating system and perhaps one or more software application programs. Examples of computers include, without limitation, IBM-type personal computers (PCs) having an operating system such as DOS, Microsoft Windows, OS/2 or Linux; Apple computers having an operating system such as MAC-OS; hardware having a JAVA-OS operating system; graphical work stations, such as Sun Microsystems and Silicon Graphics Workstations having a UNIX operating system; and other devices such as for example media players (e.g., iPods, PalmPilots, Pocket PCs, and mobile telephones).
For the present invention, a software application could be written in substantially any suitable programming language, which could easily be selected by one of ordinary skill in the art. The programming language chosen should be compatible with the computer by which the software application is executed, and in particular with the operating system of that computer. Examples of suitable programming languages include, but are not limited to, Object Pascal, C, C++, CGI, Java and Java Scripts. Furthermore, the functions of the present invention, when described as a series of steps for a method, could be implemented as a series of software instructions for being operated by a data processor, such that the present invention could be implemented as software, firmware or hardware, or a combination thereof.
The present invention uses audio fingerprints to identify audio files encoded in a variety of formats (e.g., WMA, MP3, WAV, and RM) and which have been recorded on different types of physical media (e.g., DVDs, CDs, LPs, cassette tapes, memory, and hard drives). Once fingerprinted, a retrieval engine may be utilized to match supplemental content to the fingerprints. A computer accessing the recording displays the supplemental content.
The present invention can be implemented in both server-based and client or device-embedded environments. Before the fingerprint algorithm is implemented, the frequency families that exhibit the highest degree of resistance to the compression and/or decompression algorithms (“CODECs”) and transformations (such frequency families are also referred to as “stable frequencies”) are determined. This determination is made by analyzing a representative set of audio recording files (e.g., several hundred audio files from different genres and styles of music) encoded in common CODECs (e.g., WMA, MP3,WAV, and RM) and different bit rates or processed with other common audio editing software.
The most stable frequency families are determined by analyzing each frequency and its harmonics across the representative set of audio files. First, the range between different renderings for each frequency is measured. The smaller the range, the more stable the frequency. For example, a source file (e.g., one song), is encoded in various formats (e.g., MP3 at 32 kbs, 64 kbs, 128 kbs, etc., WMA at 32 kbs, 64 kbs, 128 kbs, etc.). Ideally, the difference between each rendering would be identical. However, this is not typically the case since compression distorts audio recordings.
Only certain frequencies will be less sensitive to the different renderings. For example, it may be the case that 7 kHz is 20 dB different between a version of MP3 and a version of WMA, and another frequency, e.g., 8 kHz, is just 10 dB different. In this example, 8 kHz is the more stable frequency. The measurement used to determine the difference can be any common measure of variation such as standard or maximum deviations. Variation in the context of the present invention is a measure of the change in data, a variable, or a function.
As CODECs are changed and updated, this step might need to be performed again. Typically stable frequencies are determined on a server.
The stable frequencies are extracted from the representative set of audio recording files and collected into a table. The table is then stored onto a client device which compares the stable frequencies to the audio recording being fingerprinted. Frequency families are harmonically related frequencies that are inclusive of all the harmonics of any of its member frequencies and as such can be derived from any member frequency taken as a base frequency. Thus, it is not required to store in the table all of the harmonically related stable frequencies or the core frequency of a family of frequencies.
The client maps the elements of the table to the unknown recording in real time. Thus, as a recording is accessed, it is compared to the table for a match. It is not required to read the entire media (e.g., an entire CD) or the entire audio recording to generate a fingerprint. A fingerprint can be generated on the client based only on a portion of the unknown audio recording.
The present invention will now be described in more detail with reference to
The evaluation of frequency families described below is performed completely in integer math without using frequency domain transformation methods (e.g., Fast Fourier Transform or FFT).
Once the fingerprint creation has been completed, all of the fingerprints are analyzed and encoded into the data structure by a fingerprint encoder 130. The data structure includes a set of fingerprints organized into groups related by some criteria (also referred to as “feature groups,” “summary factors,” or simply “features”) which are designed to optimize fingerprint access.
If the optimistic approach fails, then a “pessimistic” approach attempts to match the received fingerprint to those stored in the server database one at a time using heuristic and conventional search techniques.
Once the fingerprint is matched the audio recording's corresponding unique ID is used to correlate metadata stored on a database. A preferred embodiment of this matching approach is described below with reference to
Only a portion of the audio stream is used to generate the fingerprint. In the embodiment described herein only 155 frames are analyzed, where each frame has 8192 bytes of data. This embodiment performs the fingerprinting algorithm of the present invention on encoded or compressed audio data which has been converted into a stereo PCM audio stream.
PCM is typically the format into which most consumer electronics products internally uncompress audio data. The present invention can be performed on any type of audio data file or stream, and therefore is not limited to operations on PCM formatted audio streams. Accordingly, any reference to specific memory sizes, number of frames, sampling rates, time, and the like are merely for illustration.
Silence is very common at the beginning of audio tracks and can potentially lower the quality of the audio recognition. Therefore the present invention skips silence at the beginning of the audio stream 300, as illustrated in step 300a. Silence need not be absolute silence. For example, low amplitude audio can be skipped until the average amplitude level is greater than a percentage (e.g., 1-2%) of the maximum possible and/or present volume for a predetermined time (e.g., 2-3 second period). Another way to skip silence at the beginning of the audio stream is simply to do just that, skip the beginning of the audio stream for a predetermined amount of time (e.g., 10-12 seconds).
Next, each frame of the audio data is read into a memory and processed, as shown in step 400. In the embodiment described herein, each frame size represents roughly 0.18 seconds of standard stereo PCM audio. If other standards are used, the frame size can be adjusted accordingly. Step 400, which is described in more detail with reference to
At step 426, data points are stored sequentially into integer arrays corresponding to the predefined number of frequency families. More particularly, each array has a length of a full cycle of one of the predefined frequencies (i.e., stable frequencies) which, as explained above, also corresponds to a family of frequencies. Since a full wavelength can be equated to a given number of points, each array will have a different size. In other words, an array of x points corresponds to a full wave having x points, and an array of y points corresponds to a full wave having y points. The incoming stream of points are accumulated into the arrays by placing the first incoming data point into the first location of each array, the second incoming data point is placed into the second location in each array, and so on. When the end of an array is reached, the next point is added to the first location in that array. Thus, the contents of the arrays are synchronized from the first point, but will eventually differ since each array has a different length (i.e., represents a different wavelength).
After a full frame is processed, at step 430 each one of the accumulated arrays is curve fitted (i.e., compared) to the “model” array of the perfect sine curve for the same stable frequency. To compensate for any potential phase differential, the array being compared is cyclically shifted N times, where N represents the number of points in the array, and then summed with the model array to find the best fit which represents the level of “resonance” between the audio and the model frequency. This allows the strength of the family of frequencies harmonically related to a given frequency to be estimated.
Referring again to
Sometimes there are spikes in the audio data (e.g., pops and clicks), which are artifacts. Trimming a percentage (e.g., 5%-10%) of the highest values to the maximum level can improve the overall performance of algorithm by allowing the most variation (i.e., the most significant range) of the audio content. This is accomplished in Step 320 by normalizing the 155×8 matrix to fit into a predetermined range of values (e.g., 0 . . . 255).
The audio data may be slightly shifted in time due to the way it is read and/or digitized. That is, the recording may start playback a little earlier or later due to the shift of the audio recording. For example, each time a vinyl LP is played the needle transducer may be placed by the user in a different location from one playback to the next. Thus, the audio recording may not start at the same location, which in effect shifts the LP's start time. Similarly, CD players may also shift the audio content differently due to difference in track-gap playback algorithms. Before the fingerprint is created, another summary matrix is created including a subset of the original 155×8 matrix, shown at step 325. This step smoothes the frequency patterns and allows fingerprints to be slightly time-shifted, which improves recognition of time altered audio. The frequency patterns are smoothed by summing the initial 155×8 matrix. To account for potential time shifts in the audio, a subset of the resulting summation is used, leaving room for time shifts. The subset is referred to as a summary matrix.
In the embodiment described herein, the resulting summary matrix has 34 points, each representing the sum of 3 points from the initial matrix. Thus, the summary matrix includes 34×3=102 points allowing for 53 points of movement to account for time shifts caused by different playback devices and/or physical media on which audio content is stored (e.g., +/−2.5 seconds). In practice, the shifting operations need not be point by point and may be multiples thereof. Thus, only a small number of data points from the initial 155×8 matrix are used to create each time-shifted fingerprint, which can improve the speed it takes to analyze time-shifted audio data.
Step 510 determines, for each point in the 34×8 matrix, which frequencies are predominant (e.g., frequency with highest amplitude) or with very little presence. First, two 8 member arrays are created, where each member of an array is a 4 byte integer. For the first 32 points of each row of the 34×8 summary matrix, a bit in one of the newly created arrays (SGN) is set to “on” (i.e., a bit is set to one) if a value in the row of the summary matrix exceeds the average of the entire matrix plus a fraction of its standard deviation. For each of the first 32 points in the 34×8 summary matrix that is below the average of the entire matrix minus a fraction of its standard deviation a corresponding bit in the second newly created array (SGN_) is set to “on.” The result of this procedure is the two 8 member arrays indicating the distributional values of the original integer matrix, thereby reducing the amount of information necessary to indicate which frequencies are predominant or not present, which in turn helps make processing more efficient.
In step 520, the 8 frequency families are summed together resulting in one 32 point array. From this array, the average and deviation can be calculated and a determination made as to which points exceed the average plus its deviation. For each point in the 32 point array that exceeds the average plus a fraction of the standard deviation, a corresponding bit in another 4-byte integer (SGN1) is set “on.”
Some types of music have very little, if any, variation within a particular span within the audio stream (e.g., within 34 points of audio data). In step 530, a measurement of the quality or “quality measurement factor” (QL) for the fingerprint is defined as the sum of the total variation of the 3 highest variation frequency families. Stated differently, the sum of all differences for each one of the eight combined frequency families results in 8 values representing a total change within a given frequency family. The 3 highest values of the 8 values are those with the most overall change. When added together, the 3 highest values become the QL factor. The QL factor is thus a measurement of the overall variation of the audio as it relates to the model frequency families. If there is not enough variation, the fingerprint may not be distinctive enough to generate a unique fingerprint, and therefore, may not be sufficient for the audio recognition. The QL factor is thus used to determine if another set of 155 frames from the audio stream should be read and another fingerprint created.
In step 540, a 1 byte integer (SGN2) is created. This value is a bitmap where 5 of its bits correspond to the 5 frequency families with the highest level of variation. The bits corresponding to the frequency families with the highest variation are set on. The variation determination for step 540 and step 530 are the same. For example, the variation can be defined as the sum of differences between values across all of the (time) points. The total of the differences is the variation.
Finally, in step 550, a 1 byte integer value (SGN3) is created to store the translation of the total running time of the audio file (if known) to the 0 . . . 255 integer. This translation can take into account the actual running time distribution of the audio content. For example, popular songs typically average in time from 2.5 to 4 minutes. Therefore the majority of the 0 . . . 255 range should be allocated to these times. The distribution could be quite different for classical music or for spoken word.
One audio file can potentially have multiple fingerprints associated with it. This might be necessary if the initial QL value is low. The fingerprint creation program continues to read the audio stream and create additional fingerprints until the QL value reaches an acceptable level.
Once the fingerprints have been created for all the available audio files they can be put into the fingerprint library which includes a data structure optimized for the recognition process. As a first step the fingerprints are clustered into 255 clusters based on the SGN and SGN_ values (i.e., the two integer arrays discussed above with respect to step 510 in
All fingerprints are written into the library as binary data in an order based on SGN2. As discussed above, SGN and SGN_ represent the most predominant and least present frequencies, respectively. Out of 8 frequency families there are five frequency bands that exhibit the highest level of variation, which are denoted by the bits set in SGN2. Instead of storing 8 integers from each of the SGN and SGN_ arrays, only 5 each are written based of the bits set in SGN2 (i.e., those corresponding to the highest variation frequency families). Advantageously, this saves storage space since the 3 frequency families with the lowest variation are much less likely to contribute to the recognition.
The variation data that remain have the most information. The record in the database is as follows: 1 byte for SGN2, 1 Byte for cluster number, 4 bytes for SGN1, 20 bytes for 5 SGN numbers, 20 bytes for 5 SGN_ numbers, 3 bytes for the audio ID, and 1 byte for SGN3. The size of each fingerprint is thus 50 bytes.
In step 620, the recognition engine attempts to recognize the audio in a series of data scans starting with the most direct and therefore the most immediate match cases. The “instant” method assumes that SGN1 matches precisely and SGN2 matches with only a minor difference (e.g., a one bit variation). If the “instant” method does not yield a match, then a “quick” method is invoked in step 630 which allows a difference (e.g., up to a 2 bit variation) on SGN2 and no direct matches on SGN1.
If still no match is found, in step 640 a “standard” scan is used, which may or may not match SGN2, but uses SGN2, SGN1 and potential fingerprint cluster numbers as a quick heuristic to reject a large number of records as a potential match. If still no match is found in step 650 a “full” scan of the database is evoked as the last resort.
Each method keeps a running list of the best matches and the corresponding match levels. If the purpose of recognition is to return a single ID, the process can be interrupted at any point once an acceptable level of match is reached, thus allowing for very fast and efficient recognition. If on the other hand, all possible matches need to be returned, the “standard” and “full” scan should be used.
The exchange of information between a client and a recognition server 750 include returning a web page with metadata based on a fingerprint. The exchange can be automatic, triggered for example when an audio recording is uploaded onto a computer (or a CD placed into a CD player), a fingerprint is automatically generated using a fingerprint creation module (not shown), which analyzes the unknown audio recording in the same manner as described above. After the fingerprint creation engine generates a fingerprint 710, the client PC 700 transmits the fingerprint onto the network 760 to a recognition server 750, which for example may be a Web server. Alternatively, the fingerprint creation and recognition process can be triggered manually, for instance by a user selecting a menu option on a computer which instructs the creation and recognition process to begin.
The network can be any type of connection between any two or more computers, which permits the transmission of data. An example of a network, although it is by no means the only example, is the Internet.
A query on the fingerprint takes place on a recognition server 750 by calculating one or more derivatives of the fingerprint and matching each derivative to one or more fingerprints stored in a fingerprint library data structure. Upon recognition of the fingerprint, the recognition server 750 transmits audio identification and metadata via the network 760 to the client PC 700. Internet protocols may be used to return data to the application which runs the client, which for example may be implemented in a web browser, such as Internet Explorer, Mozilla or Netscape Navigator, or on a proprietary media viewer.
Alternatively, the invention may be implemented without client-server architecture and/or without a network. Instead, all software and data necessary for the practice of the present invention may be stored on a storage device associated with the computer (also referred to as a device-embedded system). In a most preferred embodiment the computer is an embedded media player. For example, the device may use a CD/DVD drive, hard drive, or memory to playback audio recordings. Since the present invention uses simple arithmetic operations to perform audio analysis and fingerprint creation, the device's computing capabilities can be quite modest and the bulk of the device's storage space can be utilized more effectively for storing more audio recordings and corresponding metadata.
As illustrated in
More particularly, after the fingerprint creation engine 810 generates a fingerprint 840, the device 800 internally communicates the fingerprint 840 to an internal recognition engine 830 which includes a library for storing metadata and audio recording identifiers (IDs). The recognition engine 830 recognizes a match, and communicates an audio ID and metadata corresponding to the audio recording. Other variations exist as well.
While the present invention has been described with respect to what is presently considered to be the preferred embodiments, it is to be understood that the invention is not limited to the disclosed embodiments. To the contrary, the invention is intended to cover various modifications and equivalent arrangements included within the spirit and scope of the appended claims. The scope of the following claims is to be accorded the broadest interpretation so as to encompass all such modifications and equivalent structures and functions.
This application is a continuation of U.S. application Ser. No. 10/905,362, filed Dec. 30, 2004, now U.S. Pat. No. ______, the disclosure of which is incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
Parent | 10905362 | Dec 2004 | US |
Child | 12488518 | US |