The present invention is related to the field of digital file summarization, and more particularly to the field of automatic digital file summarization.
Digital format is becoming an increasingly popular form for storing all types of information. For example, music, audio, video, and multimedia may be stored in digital formats.
With the advent of the Internet and the multitude of peer-to-peer services, such as Napster, individuals routinely assemble large collections of digital files on their personal digital devices. For example, a recent poll on the collection of MPEG-Layer 3 (“MP3”) files stored on individuals digital devices illustrated that a quarter of the respondents' collections contain at least nine gigabytes of digital audio.
As a result of the massive growth in the size of these personal collections, research and development tools supporting file management has become increasingly active. For example, providing summaries of digital music has become a key area in this field. Given summaries of MP3 files, users can navigate and sample music databases more efficiently, whether browsing music at e-commerce websites or within personal collections. Furthermore, distribution of music summaries in place of complete files bypasses many security concerns of content providers.
Currently techniques for generating music summaries frequently produce summaries that do not adequately represent the piece of music being summarized. For example, one technique for summarizing a piece of music divides the piece into fixed length time segments and analyzes each segment, groups the segments into clusters and then selects a segment from one of the clusters as the summary. However, this technique frequently segments the piece at undesirable locations and selects a segment of the piece that does not adequately represent the piece of music.
Therefore, it is desirable to Produce a system and method that automatically summarizes a digital file on one or more computers, such as a music file, and generates a summary that adequately represents that digital file.
Roughly described, the invention comprises a method and system for producing a summary of a digital file on one or more computers. In an embodiment, the method includes segmenting the digital file into a plurality of segments, clustering said segments into a plurality of clusters and selecting one or more clusters from said plurality of clusters wherein said selected cluster(s) includes segments representative of said digital file, according to selected criteria for determining representative segments. One or more segments is then selected from each cluster and combined as a summary of said digital file.
The invention will be described with respect to the particular embodiments thereof. Other objects, features, and advantages of the invention will become apparent with reference to the specification and drawings in which:
Upon initiation, a digital file is segmented 101 by detection of locally novel points. After segmentation the segments are clustered 103 by statistical analysis of their spectral characteristics. Finally, a summary is constructed 105 using the segmentation and cluster analysis. The summarization may also utilize application-specific information or user-specific preferences in generating the summary.
Audio Segmentation
Segments of a file may be generated using several different segmentation techniques. For example,
“Self-similarity” is a non-parametric technique for assessing the global structure of time-ordered multimedia streams. In an embodiment, self-similarity is determined at two hierarchical levels. In the segmentation step, an incomplete time-indexed similarity matrix is computed and processed to detect locally novel audio time samples. Given the segmentation boundaries, a complete segment-indexed similarity matrix of substantially lower dimension is calculated. For this, a statistical similarity measure is introduced by which the similarity of variable length media segments may be quantitatively assessed. The use of statistical, segment-level analysis improves the robustness of the clustering while drastically reducing the computational requirements compared to existing techniques.
In an embodiment, the self-similarity analysis of digital data is accomplished by comparing each media segment to all other media segments using a similarity measure. For example, for N samples of a digital audio file, each sample may be represented by the B-dimensional feature vectors {vi: i=1, . . . , N} ⊂B for a generic similarity measure, d:
B ×
B →
. The resulting similarity data may be embedded in a matrix S 301, as illustrated in
Matrix 301 is generated by comparing each media element 311, 313 of digital file 303. The similarity value 315 is represented in matrix 301 as degree of color. Referring to FIG 3B, matrix 302 illustrates a simailarity matrix computed for the song “Wild Honey” by U2 analyzed according to an embodiment of the invention. As shown in
It will be understood that alternative parameterization may also be employed for segmenting a digital file. For example, the Mel Frequency Cepstral Coefficients (“MFCC”), or subspace representations computed using singular value decomposition (“SVD”) of the data may be used. Other techniques, such as Probabilistic Latent Semantic Analysis (“PLSA”) as described in “Unsupervised Learning by Probabilistic Latent Semantic Analysis,” M
Segmentation 101 may also be accomplished by comparing the spectral information using cosine distance measures. Given vectors Vi and Vj representing the spectrograms for sample times i and j, respectively,
For example, consider a digital audio stream comprised of N samples. This information is embedded in a similarity matrix, S, with elements given by (1). To detect novel points in the file, a Gaussian-tapered checkerboard kernel is correlated along the main diagonal of the similarity matrix. A complete discussion on detecting novelty score can be found in co-pending U.S. application Ser. No. 09/569,230, filed May 11, 2000, entitled METHOD FOR AUTOMATIC ANALYSIS OF AUDIO INCLUDING MUSIC AND SPEECH, which is incorporated herein by reference.
For segmentation, the similarity matrix is calculated around the main diagonal with the width of the checkerboard kernel. Using a simple change of variables an N×K matrix Ŝ is computed such that
By considering only the matrix elements within the bandwidth of K=256 centered around the main diagonal, the computational requirements are reduced by over 96% for a three-minute audio file sampled at 20 Hertz. However, it is understood that K may be set to any other desired value. If a symmetric similarity measure is used, the remaining computation can be reduced still further.
Regardless of the type of segmentation utilized, the output may be represented as a set of segments, {pi, . . . , pp}. Each segment is determined by a start time and an end time. In an embodiment, segments may be of varying length and are not predefined, thereby allowing the system to more accurately generate a segment representative of the song.
Statistical Segment Clustering
In logic box 103 the segments are clustered to determine dominant clusters and their representatives for summarization. For clustering, a second similarity matrix, denoted SS, is computed which quantifies similarity at the segment level. To assess segment similarity, the time-indexed set of spectrogram vectors {vi: i=1 . . . N} ⊂B is computed. For the matrix the B×1 empirical mean vector and B×B empirical covariance matrix for the spectrogram data in each segment is computed. The segments are clustered using a similarity measure. Similarity measure may be determined using different techniques. For example, a similarity measure may be determined based on a cosine distance between the segments' empirical mean. In another embodiment, similarity measure may be determined based on the Kullback-Leibler (“KL”) distance between Gaussian densities characterized by the segment's empirical mean and co-variance. For example, let G(μ, Σ) denote the B-dimensional Gaussian density determined by the mean vector μ and covariance matrix Σ. The KL distance between the B-dimensional densities G(μi, Σj) is
where Tr denotes the matrix trace. For a B×B matrix A,
The KL distance is not symmetric, but a symmetric variation may be constructed as
Each segment pi is identified with the empirical mean μi and covariance Σi of its spectrogram data. Segment similarity is assessed by
where dseg( . , . ) ∈(0,1] and is symmetric.
To cluster the segments, the inter-segment similarity measure of (6) is computed for each pairing of segments. The data may be embedded in a segment-indexed similarity matrix, Ss, analogous to the time-indexed similarity matrices of
Ss(i, j)=dseg(pi, pj) i, j=1, . . . , P.
Ss is two orders of magnitude smaller in dimension than its time-indexed counterpart. SVD of Ss=UΛVt is computed where U and V are orthogonal matrices and Λ is a diagonal matrix whose diagonal elements are the singular values of Ss: Λii=λi. The singular vectors in the columns of U are used to form unit-sum vectors for
ûi=λi(ui∘vi) (7),
where ∘ denotes the element-wise vector product for x, y∈IRB,x∘y=z∈IRB,z(i)y(i),i=1, . . . , B. ui and vi denote the ith column of U and V, respectively; for symmetric similarity matrices, U=V. As output of the SVD the columns are ordered by descending singular value, i.e. u1, is the left singular vector corresponding to λ1, the largest singular value. The cluster to which each segment belongs is determined according to method 600 described with respect to
In logic box 601, the process begins by calculating a P×P segment-indexed similarity matrix Ss using (6). Control is then transferred to logic box 603 where the SVD of Ss and the set of vectors {ûi: i=1, . . . , P} per (7) ordered by decreasing singular values is computed. Each vector ûi is scaled to have maximum value one. In logic box 605 each vector ûi is processed until each segment is associated with a cluster. To perform the processing the method begins by setting i←1. Each segment whose corresponding index in the vector ûi exceeds a predetermined value is joined as a member of cluster i. For example the predetermined value may be 0.05. Next i is set to i←i+1 and the process is repeated while i≦P and there are unclustered segments remaining.
In other embodiments, segments may be clustered using other techniques, such as Probabilistic Latent Semantic Analysis (“PLSA”) as described in “Unsupervised Learning by Probabilistic Latent Semantic Analysis,” M
The results for the method 600 for the song “Wild Honey” by U2 are shown in
For the song “Wild Honey” by U2, the time index similarity matrix generated using a segmentation algorithm is initially 4,540×4,540. Matrix 501 illustrates the corresponding 11×11 segment index similarity matrix for the time index similarity matrix for the song “Wild Honey.” The segment index matrix 501 represents the corresponding 11 segments. Each segment is represented in a horizontal row 1-11 and a corresponding vertical column 1-11. Segments that are similar are represented with a grayish color at their intersecting points. For example, segment index 3 and segment index 6 are similar and have a darkened intersecting point 505. Segment index 3 is also similar to segment index 10 and is illustrated by a darkish gray intersecting point 507. Likewise, segment index 2 is similar to segment index 5 as illustrated by intersecting point 509, and segment index 2 is also similar to segment index 8, as illustrated by intersection 511.
Image 503 illustrates the segment-indexed cluster indicators produced according to the process of
Summary Construction
In an embodiment, segments may be selected for summary construction by computing the column sum of Ss as a measure of the similarity of each segment to the remaining segments. For example, each segment index may be computed by:
In an embodiment, each column represents a segment of the song of variable length.
In an alternative embodiment, segments may be selected based on its maximal off-diagonal similarity. This may be determined by calculating an index score for each segment:
In another embodiment a two step approach is used. First, the dominant clusters are selected. Selection may be accomplished by selecting the clusters with maximal off-diagonal elements, combining segments from the same cluster to use a cluster-indexed analogue to (9). The corresponding clusters generally represent repeated segments of the audio file, such as a verse or chorus segment in a song. For each dominant cluster, the segment with the maximal value in the corresponding cluster indicator ûi of (7) is added to the summary. For dominant cluster i, this segment will have index ji* such that
An advantage to this approach is its flexibility in integrating structural information with other criteria. For example, representative segments for each significant (repeated) segment cluster could be included in the summary. Additionally, a subset of the segments that satisfies a temporal constraint could also be selected. Moreover, knowledge of the ordering of the segments and clusters, application-specific constraints, or user preferences may be included in the summarization process.
Below is an example of an embodiment of the present invention used to summarize the song “Wild Honey” by U2. The below description is intended for explanation purposes only and not intended to be limiting in any way. It is readily apparent that embodiments of the present invention may be used to generate summaries of a multitude of digital files and not just audio files.
In generating a summarization, the song is first segmented. As discussed above, many different forms of segmentation may be used. For example, the song may be manually segmented or automatically segmented.
Column 703 illustrates the results from automatic segmentation of Wild Honey. Upon automatic segmentation the song is automatically segmented into eleven segments 7031, 7032, 7033, 7034, 7035, 7036, 7037, 7038, 7039, 70310, 70311. As can be seen, each segment varies in length with respect to other segments. Upon segmentation each segment is analyzed and clustered. Using the techniques described above, it is determined that segments 7032, 7035, 7038 are similar and are assigned to Cluster 1; segments 7034, 7037, 70311 are similar and assigned to Cluster 2; segments 7033, 7036, 70310 are similar and assigned to Cluster 3. Segments 7031 and 7039 are unique and assigned their own respective Clusters 5 and 4. As can be seen by comparison with the manual segmentation and identification, the segments have been properly clustered.
In the results, the clusters and manual labels agree with the sole exception of the first segment. In that segment, a distinctive guitar riff is shared between the segments of cluster 5 and cluster 2. In the first segment however, the riff is heard without the other instruments, causing it to be clustered as a unique segment.
A summary of the song may be created based on a user's needs. In this example, the user desires a small summary and so only one segment is included in the song summary. Alternatively, a representative segment from each cluster, or any combination of clusters, could be included in the summary. It will be understood that any combination of representative segments may be used in generating a summary.
Although headings have been used in this description, they are to serve as a guide to the reader only and should not be construed to limit the invention.
It should be understood that the particular embodiments described above are only illustrative of the principles of the present invention, and various modifications could be made by those skilled in the art without departing from the scope and spirit of the invention. Thus, the scope of the present invention is limited only by the claims that follow.
Number | Name | Date | Kind |
---|---|---|---|
5227892 | Lince | Jul 1993 | A |
5598507 | Kimber et al. | Jan 1997 | A |
5630125 | Zellweger | May 1997 | A |
5655058 | Balasubramanian et al. | Aug 1997 | A |
5659662 | Wilcox et al. | Aug 1997 | A |
5671294 | Rogers et al. | Sep 1997 | A |
5828994 | Covell et al. | Oct 1998 | A |
5918223 | Blum et al. | Jun 1999 | A |
6058211 | Bormans et al. | May 2000 | A |
6542869 | Foote et al. | Apr 2003 | B1 |
20020051077 | Liou et al. | May 2002 | A1 |
20020054074 | Sugano et al. | May 2002 | A1 |
Number | Date | Country | |
---|---|---|---|
20040073554 A1 | Apr 2004 | US |