The present invention relates to an information processing apparatus, method, and program and, in particular, to an information processing apparatus, method, and program for analyzing a waveform of a tune involving a modulation.
Various methods have already been proposed for analyzing a structure of a tune. Specifically, by analyzing a waveform of a tune as illustrated in the upper part of
Hereinafter, a part of a tune that is positioned in the middle of the time and involves a change in motif and which, in particular, is the roost alluring part of the tune will be referred to as a “chorus”, In addition, a unit for making a meter will be hereinafter referred to as a “beat”. That is, heats can be counted as they each have a constant temporal duration, and positions of the beats in a measure produce variations in accent (i.e., downbeats and upbeats), and different combinations thereof result in different, meters.
There is also a method in which features are extracted from input audio data; the degree of similarity between the features is calculated to list repetitive sections; the listed repetitive sections are integrated; the detection of repetitive sections involving a modulation is performed; the repetitive sections involving a modulation are integrated; and a section that is appropriate as a chourusesection is selected from the integrated repetitive sections (see, for example, Patent Document 1).
In the case where a waveform of a tune that involves a modulation is analysed, handling the modulation involves an increased amount of operation, and therefore, unfortunately, a time required for analysing the waveform of the tune increases.
In the method as disclosed in Japanese Patent Laid-open No. 2004-233965, for example, the section that is appropriate as the chourusesection is selected by performing the detection of the repetitive sections involving the modulation. In this method, however, it sometimes takes a long time to select an appropriate chourusesection.
The present invention has been designed in view of the above circumstances, and enables analysis of the waveform of the tune involving the modulation to be achieved with a reduced amount of operation.
One aspect of the present invention is an information processing apparatus including: first extraction means for extracting a first feature from first sections of a waveform of a tune involving a modulation, each of the first sections corresponding to each beat, the first feature being related to the beat; removal means for removing a phase component from a frequency component of each first feature extracted; and generation means for, based on the first features whose phase components have been removed, generating autocorrelation information representing correlation between one first section and another first section.
The information processing apparatus may further include: separation means for, based on the autocorrelation information, separating the beats into a plurality of second sections each containing a succession of beats with high correlation; second extraction means for extracting a second feature from each of the second sections obtained by the separation, the second feature representing a musical feature of the tune; and identification means for, based on the second feature, identifying a tune structure component of the tune in the second sections as separated.
The removal means may remove the phase component from the frequency component of each first feature by a discrete Fourier transform.
The identification means may identify, as the tune structure component, a section corresponding to a chorus of the tune.
The first feature may be energy of each tone in a predetermined number of octaves in the first section.
The second feature may be volume, information concerning a sound source, or a gain of a certain frequency band in the second section.
The second feature may foe a length of the second section, the number of times the second section appears, or the number of times the second section is repeated consecutively.
Based on the first features whose phase components have been removed, the generation means may calculate; at intervals of a predetermined number of beats, the correlation with another first section to generate the autocorrelation information.
The removal means may shuffle the first features before removing the phase component from the frequency component of each first feature.
The removal means may shift the energy of each tone before removing the phase component from the frequency component of each first feature.
One aspect of the present invention is an information processing method including: an extraction step of extracting a feature from sections of a waveform of a tune involving a modulation, each of the sections corresponding to each beat, the feature being related to the beat; a removal step of removing a phase component from a frequency component of each feature extracted; and a generation step of, based on the features whose phase components have been removed, generating autocorrelation information representing correlation between one section and another section.
One aspect of the present invention is a program for causing a computer to perform: an extraction step of extracting a feature from sections of a waveform of a tune involving a modulation, each of the sections corresponding to each beat, the feature being related to the beat; a removal step of removing a phase component from a frequency component of each feature extracted; and a generation step of, based on the features whose phase components have been removed, generating autocorrelation information representing correlation between one section and another section.
In one aspect of the present invention, a first feature is extracted from first sections of a waveform of a tune involving a modulation, each of the first sections corresponding to each beat, the first feature being related to the beat; a phase component is removed from a frequency component of each first feature extracted; and based on the first features whose phase components have been removed, autocorrelation information representing correlation between one first, section and another first section is generated.
As described above, according to one aspect of the present invention, the waveform of a tune involving a modulation can be analyzed with a reduced operation amount.
1 personal computer, 11 CPU, 12 ROM, 13 RAM, 16 input section, 17 output section, 16 recording section, 19 communication section, 20 drive, 21 removable medium, 31 tune structure analysis unit, 41 beat feature extraction section, 42 beat feature removal section, 43 autocorrelation map generation section, 44 segmentation section, 45 music feature extraction section, 46 chorus identification section, 101 beat detection unit, 111 attack information extraction section, 112 basic beat period detection section, 113 tempo determination section, 114 tune feature extraction section, 115 tempo correction section, 116 beat feature extraction section, 117 meter determination section, 118 measure top determination section
Hereinafter, embodiments of the present invention will be described with reference to the accompanying drawings.
The personal computer 1 is a device for performing a predetermined process to record data of a tune and analyze a waveform of the tune that is reproduced from the data of the tune. The personal computer 1 is an example of an information processing apparatus of the present invention.
In the personal computer 1 in the example of
The CPU 11, the ROM 12, and the RAM 13 are connected to one another via a bus 14. To the bus 14, an input/output interface 15 is also connected.
To the input/output interface 15 are connected an input section 16 formed by a keyboard, a mouse, etc.; an output section 17 formed by a loudspeaker, a display such as an LCD (Liquid Crystal Display), etc.; the recording section 13 formed by a hard disk, etc.; and a communication section 19 that controls a communication process in relation to another device via a network such as the Internet.
A drive 20 is also connected to the input/output interface 15 as necessary. A removable medium 21, such as a magnetic disk, an optical disk, a magneto-optical disk, or a semiconductor memory, is mounted on the drive 20 as appropriate, and a computer program is read therefrom and installed into the recording section 18 as necessary.
Note that the hardware configuration of the personal computer 1 is not limited to the example of
A tune structure analysis unit 31 performs a predetermined process to analyze the waveform of the tune (which involves a modulation).
The tune structure analysis unit 31 includes a beat feature extraction section 41, an autocorrelation map generation section 42, a segmentation section 43, a music feature extraction section 44, and a chorus identification section 45.
The beat feature extraction section 41 performs a beat feature extraction process to extract beat features, which are features to be extracted on a beat-by-beat basis. The beat feature extraction section 41 supplies the extracted beat features to the beat feature removal section 42. The details of the beat feature extraction process will be described later.
The beat, feature removal section 42 removes a phase component from each of the beat features supplied from the beat feature extraction section 41. The beat feature removal section 42 supplies, to the autocorrelation map generation section 43, the beat features amounts from which the phase components have been removed.
Based on the beat features from which the phase components have been removed, which have been supplied from the beat feature removal section 42, the autocorrelation map generation section 43 performs an autocorrelation map generation process to generate an autocorrelation map. The autocorrelation map generation section 43 supplies the generated autocorrelation map to the segmentation section 44. The details of the autocorrelation map generation process will be described later.
Based on the autocorrelation map supplied from the autocorrelation map generation section 43, the segmentation section 44 performs separation (segmentation) so that the tune is separated into sections each corresponding to one of identical phrases that are repeated a plurality of times by the waveform of the tune.
The music feature extraction section 45 extracts a music feature, which is a musical feature, from each of the separated sections (i.e., partial waveforms of the tune corresponding to the respective separated sections) each corresponding to one of the identical (similar) phrases. The music feature extraction section 45 supplies the extracted music features to the chorus identification section 46.
The music feature extraction section 45 also extracts another feature than the music feature from each of the separated sections (i.e., the partial waveforms of the tune corresponding to the respective separated sections) each corresponding to one of the identical (similar) phrases. The music feature extraction section 45 supplies the other features extracted to the chorus identification section 46.
Based on the music features and the other features supplied from the music feature extraction section 45, the chorus identification section 46 identifies a section corresponding to a chorus of the tune from among the separated sections (i.e., the partial waveforms of the tune corresponding to the respective separated sections) each corresponding to one of the identical (similar) phrases.
Mote that, in the present embodiment, since the personal computer 1 has the above-described hardware configuration of
As described above, analysis of the structure of the tune based on the waveform of the tune makes it possible to identify the chourusesection of the tune. Therefore, next, with reference to a flowchart of
At step S1, the tune structure analysis unit 31 detects the beats from the waveform of the tune. For example, at step S1, the tune structure analysis unit 31 detects a tempo, a meter, positions of measures, etc., from the waveform of the tune that is reproduced from an audio signal obtained by audio compression according to an MP3 (MPEG Audio Layer-3) system, an AAC (Advanced Audio Coding) system, or the like.
The beats detected from the waveform of the tune illustrated in the upper portion of
That is, for example, as illustrated in
Returning to the flowchart of
In the waveform of the tune as illustrated in
Here, the details of the beat feature extraction process performed by the beat feature extraction section 41 at step S2 will now be described below with reference to a flowchart of
At step S11, based on the tune waveform separated into the parts each corresponding to each beat, the beat feature extraction section 41 calculates, with respect to each beat, an energy of each tone in the range of seven octaves, for example.
As illustrated, in
That is, based on the tune waveform separated into the parts each corresponding to each beat, the beat feature extraction section 41 calculates the respective energies of O1 to B7, for example.
As to a method, for calculating the energies of the tones (O1 to B7) in the range of seven octaves, the energy of each tone is calculated by, for example, analyzing the tune waveform separated into the parts each corresponding to each beat in terms of pitch and time. Next, with reference to
In an example as illustrated in
The figure includes areas in black and areas in white. The areas in black represent more intense energy, while the areas in white in the figure represent less intense energy. Note that, in the example of
Six horizontal dotted lines in the figure are drawn to facilitate explanation, and each of seven sections separated by these dotted lines represents one octave. That is, the seven octaves O1 to O7 are represented by the seven separated sections.
For example, referring to the example as illustrated in
In the case where the energies over the seven-octave range are calculated on a beat-by-beat basis, as illustrated in
Returning to the flowchart of
As to a method for weighting the energy of each of the tones (C1 to B7), the beat feature extraction section 41 calculates weights by a Gaussian distribution or the like, for example, and, by normalizing the calculated weights, identifies a weight for each of the tones (C1 to B7) and assigns the weight to the tone.
Specifically, the weights W (N) by the Gaussian distribution are calculated using formula (1).
W(N)=Exp(−(N−Gm)×(N−Gm)/(2×Gv×Gv)) (1)
In formula (1), Gm denotes a tone with the highest weight, and Gv denotes a width of the weights, and predetermined values are set for them. In addition, N denotes the number of tones; therefore, the number of weights W (N) calculated by the Gaussian distribution is the same as the number of tones (in the case of
Assigning the weights to the tones (C1 to B7) in the above-described manner contributes to removing irrelevant tones, such as tones in high frequency bands and tones in low frequency bands, for example.
Returning to the flowchart of
For example, at step S13, as illustrated in
That is, by performing the processes of step S11 to step S13, the beat feature extraction section 41 calculates the beat feature of each of the separated sections of the tune waveform, each corresponding to each beat.
Note that the beat feature extracted by the beat-feature extraction section 41 is not limited to the above-described example. For example, the 84 (12×7) energies as they are may be used without carrying out the adding process in the process of step S13. In short, any feature is applicable as the beat feature as long as it is extracted with respect to each of the separated sections each corresponding to each beat.
Returning to the flowchart of
For example, at step S3, the beat feature removal section 42 identifies, from among the tune waveform separated into the parts each corresponding to each beat, sections for which correlation calculation is to be performed. The beat feature removal section 42 subjects the extracted beat features of the identified sections to a discrete Fourier transform (DFT) to remove the phase components from the extracted beat features.
In an example as illustrated in
Suppose, for example, that, in connection with a waveform of a certain tune, the correlation between a section including position X (i.e., the beat feature of this section) and a section including position (i.e., the beat feature of this section) (i.e., the correlation between two different sections) is to be calculated. In this case, the correlation between the beat features of four sections (i.e., four beats) that extend backward in time from the section including position X and which are hatched by rising oblique lines in the figure and the beat features of four sections (i.e., four beats) that extend backward in time from the section including position Y and which are hatched by falling oblique lines in the figure is calculated.
In this case, for example, the beat feature removal section 42 subjects both of the beat features of the four sections hatched by the rising inclined lines in the figure and the beat features of the four sections hatched by the falling oblique lines in the figure, for which the correlation calculation is to be performed, to the discrete Fourier transform, thereby removing the phase components from those beat features.
That is, for example, as illustrated in
Similarly, for example, the beat feature removal section 42 subjects the beat features of the four sections (i.e., four beats) hatched by the falling inclined lines in
At this time, referring to
Note that the number of sections selected when calculating the correlation between the beat features is not limited to four (four beats) as in the above-described example, but may be one, eight, or ten, for example. Also note that it is not essential that the selected sections extend backward in time from the reference position (e.g., X or Y in
Also note that in the above-described example, the beat feature removal section 42 uses the discrete Fourier transform to remove the phase components from the bear, features. However, the present invention is not limited to this example. Any method is applicable as long as it is able to remove the phase components from the beat features.
Returning to the flowchart of
Here, with reference to the flowchart of
At step S21, the autocorrelation map generation section 43 calculates the correlation between the beat features of the four sections (i.e., the sections hatched by the rising oblique lines in
In other words, in order to handle the tune involving the modulation, the autocorrelation map generation section 43 uses only a norm component of the discrete Fourier transformed beat features of several beats to calculate the correlation.
Specifically, the correlation between the beat features is calculated using formula (2), for example.
In formula (2), for example, X denotes the beat features of the four sections (four beats) including position X in
At step S22, based on the calculated correlation between each beat, the autocorrelation map generation section 43 generates the autocorrelation map.
In the exemplary autocorrelation map as illustrated in
Areas in black in the figure indicate that the correlation between the corresponding beats of the tune identified by the horizontal and vertical axes is high, whereas areas in white in the figure indicate that the correlation between the corresponding beats of the tune identified by the horizontal and vertical axes is low. A diagonal that extends from the top left corner to the bottom right corner of the autocorrelation map represented by a square in the figure corresponds to positions where the beat of the tune identified by the horizontal axis is identical to the beat identified by the vertical axis. Therefore, the diagonal is naturally represented by a black line (diagonal) in the figure, indicating a high correlation.
That is, based on the correlations between the beat features calculated by formula (2), for example, the exemplary autocorrelation map of
Returning to the flowchart of
Specifically, referring to an example of
An expression of
In
Returning to the flowchart of
Here, the music features extracted by the music feature extraction section 45 are musical features, such as information concerning volume or a sound source, a gain of a certain frequency band, a frequency balance, a diversity of tones, a proportion of rhythm instruments such as drums and a bass, or whether a vocal exists.
The separated sections as illustrated in
Returning to the flowchart of
Here, the other feature extracted by the music feature extraction section 45 is a feature, such as a length of a particular separated section, the number of times a particular section appears in one tune, or the number of times a particular section is repeated.
In an example as illustrated in
Other than the examples described above with reference to
Extracting more of the music features and the other features allows the chorus identification section 46 to identify the structure of the tune with a more improved precision, for example. Details thereof will be described later.
Note that the music feature extraction section 45 may extract only either one of the music features and the other features from each of the separated sections (i.e., the partial waveforms of the tune corresponding to the respective separated sections) each corresponding to one of the identical (similar) phrases, and supply the extracted music features or other features to the chorus identification section 46.
Returning to the flowchart of
For example, referring to
Specifically, for example, the chorus identification section 46 performs learning for chorus identification using the music features (X1), the other features (X2), and data concerning a correct chorus (e.g., user-set data that indicates which part of the tune is the chorus of the tune) to generate a specific function (e.g., a function for computing the “chorus likeliness”). The chorus identification section 46 subjects the music features (X1) and the other features (X2) supplied from the music feature extraction section 45 to computation according to the generated specific function to calculate the “chorus likeliness” (y(%)) of each section, thereby identifying the section corresponding to the chorus of the tune.
Note that a method in which the “chorus likeliness” (y(%)) is calculated by the chorus identification section 46 is not limited to the above-described method. Any method is applicable as long as a probability of being the chorus can be calculated.
In an example as illustrated in
Then, the chorus identification section 46 identifies the section that has the highest average of the calculated “chorus likeliness” as the section corresponding to the chorus of the tune, for example. Because the “chorus likeliness” of sections B is 60%, 70%, 80%, and so on, as illustrated in
In the above-described manner, the tune structure analysis unit 32 is able to recognize the structure of the tune involving the modulation based on the waveform of the tune with a reduced operation amount.
For example, based on waveforms of tunes obtained from: an enormous number of pieces of tune data recorded on the recording section 18 formed by the hard disk or the like of the personal computer 1, sections corresponding to chouruses of the tunes can be identified from the tune structures of the tunes with a reduced operation amount. This makes it possible to play, when selecting a tune, only a chorus of the tune, instead of playing the tune from the beginning. As a result, a user is able to listen to the chouruses (i.e., the most alluring parts) of the tunes to search for a desired tune, for example.
Moreover, because the section corresponding to the chorus of the tune can be identified based on the tune structure of the tune with a reduced operation amount, it, becomes possible to record data of a larger number of tunes on a recording medium of small capacity by recording only the cut-out chourusesections of the tunes, for example.
Sole that the above example has been described with reference to an exemplary case where “Chorus” as a tune structure component is identified based on the waveform of the tune. However, the present invention is not limited to this example. For example, “Introduction”, “Interlude”, “Verse A”, “Verse B”, or the like may be identified instead of “Chorus”.
Note that the process of generating the autocorrelation map by the autocorrelation map generation section 43 is not limited to the above-described process (the autocorrelation map generation process of
Next, with reference to a flowchart of
At step S31, the autocorrelation map generation section 43 calculates the correlations between the beats at intervals of N beats on one side. For example, at step S31, at intervals of N beats on the vertical axis in
Specifically, the calculation of the correlations between the beat features at intervals of K beats on the vertical axis in
At step S32, the autocorrelation map generation section 43 generates the autocorrelation map based on the calculated correlations between the beats.
In the exemplary autocorrelation map as illustrated in
In the exemplary autocorrelation map of
That is, in the exemplary autocorrelation map of
Note that, as described above, in the case where the length that can generally be considered as the length of “Chorus” is that of twenty or more beats, for example, the user previously sets N=20 (beats) in the autocorrelation map of
Returning to the flowchart of
The axes of the exemplary autocorrelation map as illustrated in
The exemplary autocorrelation map as illustrated in
Specifically, for example, referring to the exemplary autocorrelation map of
Returning to the flowchart of
Specifically, for example, referring to the exemplary autocorrelation map of
That is, as illustrated in
As described above, the autocorrelation map (i.e., the autocorrelation map of
In the above-described process of step S3, the beat feature removal section 42 may shuffle the beat features supplied from the beat feature extraction section 41 and thereafter remove the phase components from the shuffled beat features.
In an example as illustrated in
Assuming that the four rectangles are referred to as a “first beat”, a “second beat”, a “third beat”, and a “fourth beat” lined from left to right in the figure, the beat feature removal section 42 shuffles the second and third beats and thereafter subjects the shuffled beat features to the discrete Fourier transform or the like to remove the phase components from the extracted beat features, for example.
The shuffle of the beat features as described above contributes to improving the precision of the autocorrelation map (i.e., the process of identifying the tune structure component, such as the chorus).
Note that the above description has been made with reference to an exemplary case where the second and third rectangles in
Further, in order to improve the precision of the autocorrelation map (i.e., the process of identifying the tune structure component, such as the chorus), for example, it may be so arranged that, after the phase components of the beat features are removed by the discrete Fourier transform or the like and the correlations between the beats are calculated, the correlation calculation is performed again while shifting the beat features for one side of the autocorrelation map (e.g., the horizontal or vertical axis in
In an example as illustrated in
For example, first, the beat feature removal section 42 subjects the beat feature represented by the first rectangle to the discrete Fourier transform or the like to remove the phase component from the beat feature. The autocorrelation map generation section 43 calculates the correlations between the beat features based on the first rectangle whose phase component has been removed.
Next, the chords of the twelve types of tones in the first rectangle are shifted downward by one, so that the beat feature becomes such that the chords are arranged, as represented, by the second rectangle, from bottom to top in the following order: C#, D, D#, E, F, F#, G, G#, A, A#, B, and C.
At this time, for example, the beat feature removal section 42 subjects the beat feature represented by the second rectangle to the discrete Fourier transform or the like to remove the phase component from the beat feature. The autocorrelation map generation section 43 calculates the correlations between the beat features based on the second rectangle whose phase component has been removed.
Similarly, each of the chords of the twelve types of tones in the beat feature is shifted downward by one sequentially, and, for example, the beat feature removal section 42 subjects the beat features represented by the third to eleventh rectangles (not shown) to the discrete Fourier transform or the like to remove the phase components from the beat features, and the autocorrelation map generation section 43 calculates the correlations between the beat features based on the third to eleventh rectangles whose phase components have been removed.
Finally, the chords of the twelve types of tones in the eleventh rectangle are shifted downward by one, so that the beat feature becomes such that the chords are arranged, as represented by the twelfth rectangle (i.e., the rightmost rectangle in the figure), from bottom, to top in the following order: B, C, C#, D, D#, E, F, F#, G, G#, A, and A#.
At this time, for example, the beat feature removal section 42 subjects the beat feature represented by the twelfth rectangle to the discrete Fourier transform or the like to remove the phase component from the beat feature. The autocorrelation map generation section 43 calculates the correlations between the beat features based on the twelfth rectangle whose phase component has been removed.
Calculating the correlations while shifting the beat feature components eleven times in the above-described manner enables the autocorrelation map generation section 43 to generate a more precise autocorrelation map.
Note that the above description using
In the present embodiment, in the case where the segmentation process (i.e., the process of step S5 in
In
The beat detection unit 101 detects the beat data from the tune waveform. For example, the beat detection unit 101 detects the beat data, such as the tempo, the meter, or the tops of the measures, from the tune waveform reproduced from the audio signal obtained by the audio compression according to the MP3 system, the AAC system, or the like.
Next, referring to
A width of an interspace between two adjacent vertical lines represents, for example, the duration of the quarter note, and corresponds to the tempo. The positions indicated by the vertical lines corresponding to the numbers “1:1”, “2:1”, “3:1”, and so on indicate the tops of the measures.
In other words, the beat detection unit 101 detects, as the beat data, the top of each beat or the top of each measure indicated by the vertical lines in the figure or the tempo (i.e., the width of the interspace between two adjacent vertical lines in the figure) from the tune waveform resultant from the audio signal as illustrated in
The attack information extraction section 111 extracts time-series attack information from the audio signal representing the tune waveform. Here, the time-series attack information is data representing a change in volume over time, which allows humans to perceive beats. As illustrated in
For example, the attack information extraction section 111 extracts, from the audio signal, the attack information that represents a level of sound at each point in time, the sound being based on the audio signal.
Alternatively, for example, as illustrated in
Alternatively, for example, the attack information extraction section 111 divides the sound based on the audio signal into a plurality of octave components, and detects timing at which each of the twelve tones in each octave that have the respective pitches according to the twelve-tone equal temperament begins to sound. For example, in the case where a difference in the energy of each tone over time is larger than a predetermined threshold, the attack information extraction section 111 regards that moment as a time point at which that tone begins to sound.
Then, regarding a time point at which each tone begins to sound as “1” and the other time points as “0”, the attack information extraction section 111 adds up such values with respect to each of the twelve tones in each octave, and regards the result of the addition as the attack information.
In
Further, for example, the attack information extraction section 111 divides the sound based on the audio signal into a plurality of octave components, and determines a change in energy of each of the twelve tones in each octave that have the respective pitches according to the twelve-tone equal temperament. The change in energy of each tone is calculated, for example, in terms of a difference in energy of the tone over time. The attack information extraction section 111 adds up the changes in energy of the twelve tones in each of the octaves with respect to each point in time, and regards the result of the addition as the attack information.
Returning to
The basic beat period detection section 112 detects the duration of the most basic sound in the tune with respect to which the chords are to be detected. The most basic sound in the tune is, for example, a sound represented by a quarter note, an eighth note, or a sixteenth note.
Hereinafter, the duration of the most basic sound in the tune will be referred to as a “basic beat period”.
The basic beat period detection section 112 determines the basic beat period by performing basic pitch detection while regarding the attack information, which is time-series information, as an ordinary waveform.
For example, as illustrated in
Specifically, while sliding the position of a window that is sufficiently short in period as compared to the temporal length of the attack information little by little in relation to the attack information, the basic beat period detection section 112 subjects a part of the attack information within the window to the Fourier transform, and arranges results of the Fourier transform in chronological order, whereby the time-series data representing the intensity of the energy in each frequency over time is obtained.
As a result of the short-time Fourier transform, a frequency with intense energy as compared to the energy of the other frequencies is detected as a period that is a candidate for the basic beat period. In the lower part of
The basic beat period detection section 112 regards the most predominant one of the periods detected as a result of the short-time Fourier transform of the attack information as the basic beat period.
Specifically, while comparing basic beat likeliness, which is a previously prepared weight, with the result of the short-time Fourier transform of the attack information, the basic beat period detection section 112 determines, from among the periods detected as a result of the short-time Fourier transform of the attack information, one of the periods with high basic beat likeliness to be the basic beat period.
More specifically, using the basic beat likeliness that is a previously prepared weight extending in frequency direction, the basic beat period detection section 112 weights the energy of each of the frequencies obtained as a result of the short-time Fourier transform of the attack information, and determines the period with the highest, of values obtained as a result of the weighting to be the basic beat period.
Use of the basic beat likeliness that is the weight extending in frequency direction prevents periods of extremely low frequencies or periods of extremely high frequencies, i.e., periods that can never become the basic beat period, from being determined to be the basic beat period.
Returning to
By applying a predetermined signal processing to the audio signal, the tune feature extraction section 114 extracts a predetermined number of features (hereinafter referred to as “tune features”) from the tune. For example, the tune feature extraction section 114 divides the audio signal into a plurality of octave components, then obtains signals of the twelve tones in each octave that, have the respective pitches according to the twelve-tone equal temperament, and then applies a predetermined signal processing to the signals of the twelve tones in each octave to extract the tune feature.
For example, the tune feature extraction section 114 obtains, as the time feature, the number of peaks in unit time of the signals of the twelve tones in each octave.
Further, for example, the tune feature extraction section 114 obtains, as the tune feature, energy dispersal in pitch direction of the signals of the twelve tones in each octave.
Still further, for example, the tune feature extraction section 114 obtains, as the tune feature, balance between low-range, medium-range, and high-range energies from the signals of the twelve tones in each octave.
Still further, for example, the tune feature extraction section 114 obtains, as the tune feature, the degree of correlation between signals of left and right, channels of a stereo audio signal from the signals of the twelve tones in each octave.
The tune feature extraction section 114 supplies the thus extracted, tune feature to the tempo determination section 113.
The tempo determination section 113, which is previously constructed by learning using the tune feature and the tempo, estimates the tempo based, on the tune feature supplied from the tune feature extraction section 114. Hereinafter, the tempo estimated will be referred to as an estimated tempo.
Based on the estimated tempo and the basic beat period supplied from the basic beat period detection section 112, the tempo determination section 113 determines the basic beat period multiplied by Xth power of 2 (e.g., ⅓, ¼, ½, 1, 2, 4, 8, etc.) to be the tempo. With the estimated tempo obtained by regression analysis of the feature of the tune, a value obtained by multiplying the basic beat period by 2 or ½ and which falls within a range between the estimated tempo×21/2 and the estimated tempo÷21/2 is determined to be the tempo, for example.
For example, as illustrated in
In the case where the basic beat period (i.e., the basic beat periods represented by white circles in an lower part of
The tempo determination section 113 determines the basic beat period, (i.e., the basic beat periods represented by black circles in
Note that in the case where the basic beat period falls within the range between the estimated tempo×21/2 and the estimated tempo÷21/2, the tempo determination section 113 determines the basic beat period as it is to be the tempo.
Returning to
Based on the attack information supplied from the attack information extraction section 111, the tempo correction section 115 makes minute correction to the tempo determined in the tempo determination section 113.
First, the tempo correction section 115 corrects a phase of the beats.
Specifically, as illustrated in
For example, the tempo correction section 115 adds up a first attack information sample of each of the first to last, beat ranges throughout the entire tune, with each of the beat ranges being determined based on the interval of the tempo, and then the tempo correction section 115 regards a result of the addition as a sum total of a first section in the beat range. Next, the tempo correction section 115 adds up a second attack information sample of each of the first to last beat, ranges throughout the entire tune, with each, of the beat ranges being determined based on the interval of the tempo, and then the tempo correction section 115 regards a result of the addition as a sum total of a second section of the beat range.
Similarly, the tempo correction section 115 adds up a third to last attack information sample of each of the first to last beat ranges throughout the entire tune in regular sequence, with each of the beat ranges being determined based on the interval of the tempo, and then the tempo correction section 115 regards results of the addition as sum totals of third to last sections in the beat range, respectively.
Then, shifting the phase of the tempo intervals sideways with respect to the attack information, the tempo correction section 115 similarly adds up the attack information components, each from each beat range, throughout the entire tune.
The tempo correction section 115 corrects the phase of the tempo intervals with respect to the attack information to a phase for which the sum total has the largest value of all sum totals obtained by shifting the phase of the tempo intervals sideways with respect to the attack information. That is, the tempo correction section 115 corrects the positions of the beats so as to correspond to the positions of the tempo intervals with respect to the attack information for which the largest sum total has been obtained.
In addition, the tempo correction section 115 corrects the tempo.
Specifically, as illustrated in
In this case also, the tempo correction section 115 acids up the first to last attack information samples of each of the first to last beat ranges throughout the entire tune in sequential order, with each of the beat ranges being determined based on the interval of the tempo, and then the tempo correction section 115 regards results of the addition as sum totals of the first to last sections in the beat range, respectively.
The tempo correction section 115 shortens or extends the tempo intervals by the predetermined length, and adds up the attack information components at intervals of the shortened or extended tempo throughout the entire tune to obtain the sum totals of the first to last sections in the beat range.
The tempo correction section 115 corrects the tempo intervals so as to have a length of one of the original, shortened, and extended tempo intervals for which the largest sum total has been obtained.
The tempo correction section 115 repeats the above-described correction of the beat phase and the above-described correction of the tempo as necessary to determine the final tempo. For example, the tempo correction section 115 repeats the correction of the beat phase and the correction of the tempo a predetermined number of times, e.g., twice for both, to determine the final tempo.
Returning to
Based on the tempo data supplied from the tempo correction section 115, the beat feature extraction section 116 extracts the tune feature, such as the music feature or the chord, from each segment (i.e., each beat).
For example, from the tune waveform as illustrated in
Note that the tune feature extracted by the beat feature extraction section 116 is, as with the above-described tune feature extracted by the tune feature extraction section 114, extracted by applying a predetermined signal processing to a signal obtained as a result of the twelve-tone analysis, for example.
Returning to
Based on the attack information supplied from the attack, information extraction section 111, the meter determination section 117 determines the meter, such as 4/4 meter, 3/4 meter, 6/8 raster, for example.
Here, as to a method for determining the meter, a harmonic structure of the attack information subjected to the short-time Fourier transform can be used to determine the meter, for example. For example, referring to
That is, as illustrated in an example of
Further, similarly, for example, in the 3/4 meter illustrated in the middle of the figure, the relationships between the quarter note, one measure, and two measures are as follows: the frequency of one measure is one-third the frequency of the quarter note as indicated by circles in the figure; and the frequency of two measures is half the frequency of one measure as indicated by crosses in the figure.
Still further, similarly, in the 6/8 meter illustrated on the right-hand side of the figure, the relationships between the eighth note, the quarter note, a dotted quarter note, and one measure are as follows: the frequency of the quarter note is half the frequency of the eighth note as indicated by circles in the figure; and as indicated by crosses in the figure, the frequency of the dotted quarter note is two-thirds the frequency of the quarter note, and the frequency of one measure is one-third the frequency of the quarter note.
That is, the meter determination section 117 determines the meter based on a pattern of energy interval at the frequency at which the peak has appeared, i.e., the harmonic structure of the attack information subjected to the short-time Fourier transform.
Referring to
Then, the meter determination section 117 compares a feature that is a power component obtained by subjecting an energy for each log-frequency indicated in the energy versus log-frequency graph to a fast Fourier transform (FFT) with a previously prepared meter pattern to determine the meter.
Returning to
The measure top determination section 118 receives the tempo data from the tempo correction section 115, the tune feature for each beat from the beat feature extraction section 116, and the meter from the meter determination section 117. Based on the tempo data, the feature for each beat, and the meter, the measure top determination section 118 determines the tops of the measures.
Here, regarding a method for determining the tops of the measures, the tops of the measures have, for example, the following characteristics as compared to the other parts of the measures: the chord is more likely to change; a musically stable chord (e.g., a so-called three chord) appears with a high probability; the pitch is distinct and stable; and there is an accent in terms of volume.
Using these characteristics of the tops of the measures, the measure top determination section 118 estimates a measure top likeliness of each beat. Note that the measure top determination section 118 is, for example, previously constructed by learning using the chord and the feature of each beat, or the like, and estimates the measure top likeliness based on the tempo data, the tune feature for each beat, and the meter.
Next, as illustrated in an example of
Then, as illustrated in the example of
As described above, the beat detection unit 101 detects the beat data, such as the tempo, the meter, and the tops of the measures, from the tune waveform (i.e., the audio signal), and outputs the beat data. That is, since the beat detection unit 101 is able to obtain the beat data by the above-described method in the process of detecting the beats (i.e., the process of step S1 in
Here, operation amounts (i.e., the number of multiplications and additions) when the analysis of the waveform of a tune involving a modulation is performed by a related art technique and the technique of the present invention will now be compared with each other. In order to equalize conditions when comparing them, the operation amounts thereof are compared assuming, for example, that the length of the tune is five minutes, that the tempo is 120, and that the number of beats used for the correlation calculation is eight beats.
First, in the case where the analysis of the waveform of the tune involving the modulation is performed by the related art technique, an operation amount a1 when calculating the average and norm for calculating the correlations is as follows:
Operation amount a1=(the number of beats)×(8 beats)×(12 tones)×(2(the average and the norm))=5×120×8×12×2=115,200(the number of operations)
Further, an operation amount a2 when calculating the correlations is as follows:
Operation amount a2=(the number of beats)×(the number of beats/2+1)×(8 beats)×(12 tones)×(12 shifts)−5×120×299×8×12×12=206,668,800(the number of operations)
Accordingly, an operation amount A in the case of the related art technique is as follows:
Operation amount A=operation amount a1+operation amount a2=115,200+206,668,800=206,784,000(the number of operations)
Next, in the case where the analysis of the waveform of the tune involving the modulation is perform by the technique of the present invention, an operation amount b1 when removing the phase component by the discrete Fourier transform and calculating the average and norm for calculating the correlations is as follows:
Operation amount b1=(the number of beats)×((8 beats)×(12 tones))2(the calculation of the discrete Fourier transform)+(the number of beats)×(the features after the discrete Fourier transform)×(2(the average and the norm))=5×120×(8×12)2+5×120×47×2=5,529,600+56,400=5,586,000 (the number of operations)
Further, an operation amount b2 when calculating the correlations is as follows:
Operation amount b2=(the number of beats)×(the number of beats/2+1)×(the features after the discrete Fourier transform)=5×120×299×47=8,431,300(the number of operations)
Accordingly, an operation amount E in the case of the technique of the present invention is as follows:
Operation amount B=operation amount b1+operation amount b2=5,586,000+8,431,800=14,017,800(the number of operations)
As described above, the operation amount A in the case of the related art technique and the operation amount B in the case of the technique of the present invention are 206,784,000 (the number of operations) and 14,017,800 (the number of operations), respectively. That is, the operation amount B in the case of the technique of the present invention is an operation amount (i.e., the number of multiplications and additions) less than 1/14 of the operation amount A in the case of the related art technique. In practice, use of a fast algorithm for the discrete Fourier transform enables the calculation to be achieved with the number of multiplications and additions N2 or less, and therefore, the number of computations is further reduced to achieve more quick generation of the autocorrelation map. As a result, the processes for identifying the tune structure or the chorus can be performed more quickly, for example.
As described above, the present invention makes it possible to analyse the waveform of the tune involving the modulation with a reduced operation amount.
Further, the present invention makes it possible to identify, based on the waveform of the tune involving the modulation, the structure of the tune with a reduced operation amount.
The above-described series of processes can be implemented by either hardware or software. In the case where the series of processes are implemented by software, a program that forms the software and is stored in a storage medium is installed into a dedicated computer or a general-purpose personal computer that, when various programs are installed thereon, becomes capable of performing various functions, for example.
This storage medium may be the removable medium 21 in
Further, the program for executing the above-described series of processes may be installed into the computer via a wired or wireless communication medium, such as a local area network, the Internet, or digital satellite broadcasting, through an interface such as a router or a modem as necessary.
Note that the steps implemented by the program stored in the storage medium and described in the present specification may naturally be performed chronologically in order of description but do not have to be performed chronologically. Some steps may be performed in parallel or independently.
Also note that embodiments of the present invention are not limited to the above-described embodiments. It should be understood that various modifications can be devised without departing from the scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2005-323153 | Nov 2005 | JP | national |
2006-278351 | Oct 2006 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP2006/322273 | 11/8/2006 | WO | 00 | 7/5/2007 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2007/055238 | 5/18/2007 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5698807 | Massie et al. | Dec 1997 | A |
5986199 | Peevers | Nov 1999 | A |
6787689 | Chen | Sep 2004 | B1 |
6951977 | Streitenberger et al. | Oct 2005 | B1 |
7026536 | Lu et al. | Apr 2006 | B2 |
7035742 | Klefenz et al. | Apr 2006 | B2 |
7132595 | Lu et al. | Nov 2006 | B2 |
7183479 | Lu et al. | Feb 2007 | B2 |
20040068401 | Herre et al. | Apr 2004 | A1 |
20040094019 | Herre et al. | May 2004 | A1 |
20040255758 | Klefenz et al. | Dec 2004 | A1 |
20050211072 | Lu et al. | Sep 2005 | A1 |
20050211077 | Kobayashi | Sep 2005 | A1 |
20050217463 | Kobayashi | Oct 2005 | A1 |
20050241465 | Goto | Nov 2005 | A1 |
20060048634 | Lu et al. | Mar 2006 | A1 |
20060064299 | Uhle et al. | Mar 2006 | A1 |
20060075884 | Streitenberger et al. | Apr 2006 | A1 |
20070022867 | Yamashita | Feb 2007 | A1 |
20080078280 | Okazaki et al. | Apr 2008 | A1 |
20090056526 | Yamashita et al. | Mar 2009 | A1 |
Number | Date | Country |
---|---|---|
2004-233965 | Aug 2004 | JP |
2005-274708 | Oct 2005 | JP |
2005-275068 | Oct 2005 | JP |
WO 2005122136 | Dec 2005 | WO |
WO 2006034743 | Apr 2006 | WO |
Number | Date | Country | |
---|---|---|---|
20090287323 A1 | Nov 2009 | US |