This application is a National Phase application of International Application No. PCT/AT2009/000401 filed Oct. 15, 2009 which claims priority to European Patent Application No. EP 08450164.2 filed Oct. 22, 2008.
The present invention relates to a method for recognizing similarly recurring patterns of notes in a piece of music, which contains note sequences distributed on parallel channels.
The recognition of recurring note patterns in pieces of music, e.g. loops, riffs, phrases, motifs, themes, verses, refrains, transitions, movements etc., has become an extensive field of research in recent years with specific and promising technical applications. Some examples of application to be mentioned are the automated analysis of musical structures in pieces of music in computer-aided recording studio, audio workstation and music production environments, which must be based on a reliable music recognition for archiving and sorting purposes as well as the resynthesis of existing note patterns into new compositions. A further specific technical application is the analysis and indexing of large music data banks, e.g. of music archives or online music shops, according to identifiable note patterns for the new field of music information retrieval (MIR), for example, to be able to process “fuzzy” user queries in an automated manner, code word “query by humming”
A wide variety of methods have already been proposed in the past for pattern recognition in single-channel pieces of music that also adopt concepts from other fields of pattern recognition such as “string matching” techniques from the field of DNA sequence analysis, e.g. as in Kilian Jürgen, Hoos Holger H.: “MusicBLAST—Gapped Sequence Alignment for MIR”, International Conference on Music Information Retrieval (ISMIR), 2004. String matching methods are frequently based on the use of dynamic programming algorithms for the alignment and the similarity comparison of note sequences, cf. e.g. Hu Ning, Dannenberg Roger B., Lewis Ann L.: “A Probabilistic Model of Melodic Similarity”, Proceedings of the ICMS, 2002.
In Hsu Jia-Lien, Liu Chih-Chin, Chen Arbee L. P.: “Discovering Nontrivial Repeating Patterns in Musical Data”, IEEE Transactions on Multimedia, vol. 3, no. 3, 2001, the use of a correlation matrix, which allows nontrivial, i.e. not excluding one another, identically recurring patterns in a channel to be detected, is proposed specially for the recognition of identically recurring note patterns for the purposes of music analysis and MIR.
All methods known hitherto have the characteristic that they respectively analyse each channel of a multi-channel piece of music separately. The inventors of the present method have recognized that there is a significant disadvantage in the known methods, because structure information contained specifically in the musical parallelism of the channels, i.e. their rhythmic, melodic and polyphonic context, are completely ignored thereby, and this results in the unsatisfactory rate and quality of recognition of the known methods.
Therefore, there is continuous demand for an improved method of pattern recognition for multi-channel pieces of music. The aim set by the invention is to provide such a method.
This aim is achieved with a method of the aforementioned type that is distinguished by the following steps: a) repeatedly segmenting each channel by varying segment length and segment beginning and, for each type of segmentation, determining segments that are similar to one another and storing these in lists of candidate patterns with their respective instances, i.e. one list respectively for each type of segmentation and channel; b) calculating an intrinsic similarity value for each list, which is based on the similarities of the instances of each candidate pattern of a list with one another; c) calculating coincidence values for each list for each channel with respect to the lists for all other channels, which is respectively based on the overlaps of instances of a candidate pattern of one list with instances of a candidate pattern of the other list when these overlap at least twice; and d) combining the intrinsic similarity and coincidence values for each list to form a total value for each list and using the pattern candidates in the lists with the highest total value in each channel as recognized note patterns in the channel.
The method of the invention thus takes into consideration for the first time and in a significant manner the parallel structure information of a multi-channel piece of music, which can be concealed in the temporal coincidences of potential patterns (candidate patterns) in different channels, and combines these with an assessment of the soundness of discovered candidate patterns on the basis of the intrinsic similarities of their instances, their so-called “fitness”. In consequence, a substantially more reliable, more meaningful and more relevant pattern recognition result is obtained than with all the methods known hitherto.
It should be mentioned at this point that the term “channel” used here for a multi-channel piece of music is to be understood in its most general form, i.e. in the sense of a single voice (monophonic) of a multi-voice (polyphonic) movement, in the sense of a (possibly also polyphonic) instrument voice such as a bass, trumpet, string, percussion, piano part etc., as well as in the sense of a technical channel such as a midi-channel, which can contain both monophonic and polyphonic voices, parts or combinations thereof, e.g. a drum pattern, a chord sequence, a string movement etc.
A particularly advantageous embodiment of the invention is distinguished in that in step a) the following step is additionally conducted:
a1) detecting the patterns identically recurring in a channel, selecting therefrom the patterns best covering the channel and storing these in a further list of candidate patterns with their respective instances for each channel.
The degree of recognition can be still further increased as a result. Channel-related pattern recognition is thus based on two equivalent principles, an identity recognition and a similarity recognition, and different methods can be used for these variants. Incorporating the recognition results of both variants into one and the same list set of candidate patterns results in an implicit combination of the two methods in the subsequent list evaluation by means of the intrinsic similarity and coincidence values, since the results of the two methods are in competition with one another there. The method of the invention is thus self-adaptive for different types of input signals, which respond differently to different types of recognition processes.
In step a1) the detection of identically recurring patterns is preferably conducted by means of the correlation matrix method, as is known per se from Hsu Jia-Lien et al. (as above). It is particularly preferred if in step a1) the selection of the best covering patterns is achieved by iterative selection of the respective most frequent and/or longest pattern from the detected patterns.
According to a further preferred feature of the invention, in step a) the segment length is varied in multiples of the rhythmic unit of the piece of music, which limits the variation possibilities to a suitable degree and saves computing time. It is particularly favourable if the segment length is varied from double the average note duration of the piece of music to half the length of the piece of music.
According to a further advantageous embodiment of the invention, in step a) the determination of segments that are similar to one another is achieved by aligning the notes of two segments with one another, determining a degree of consistency of both segments and recognizing similarity when the degree of consistency exceeds a preset threshold value. These measures can be implemented speedily with a feasible computing effort.
In particular, the alignment of the notes is achieved in this case by means of the dynamic programming method as is known per se from Kilian Jürgen et al. (as above) or Hu Ning et al. (as above with further evidence).
According to a preferred embodiment of the method, the calculation of the intrinsic similarity value in step b) occurs in that for each candidate pattern for the list a similarity matrix of its instances is drawn up, the values of which are combined to form the intrinsic similarity value for the list, preferably with weighting by the channel coverage of the candidate patterns for the list. It has been found that this embodiment leads to a quick and stable implementation.
To further improve the recognition result, at the end of step b) those lists for a channel whose intrinsic similarity value does not reach a preset threshold value can optionally be deleted. This preset threshold value is preferably adaptive, in particular a percentage of the highest intrinsic similarity value of all lists for the channel, particularly preferred at least 70%. In a particularly suitable embodiment in practice the threshold value amounts to about 85%.
A particularly advantageous variant of the method of the invention lies in that in step c) for a specific candidate pattern of a list only the overlaps with those instances of the other list, with which the longest overlaps in time are present, are taken into consideration. It has been found in practical tests that this leads to a satisfactory recognition rate and simplifies the method in this step.
According to a further preferred variant of the invention it is provided that when combining step e) for each list for each channel only those coincidence values to the lists of the other channels that represent the respectively highest value there are taken into consideration, and this improves the recognition rate still further.
For the same reason it is preferably provided that when combining step e) the coincidence values taken into consideration for a list are respectively added up, and it is particularly preferred if the added coincidence values are multiplied by the intrinsic similarity value for the list to form the said total value.
The invention is explained in more detail below on the basis of preferred exemplary embodiments with reference to the accompanying drawings:
In the interests of simplicity, only the note pitches and the times of incidence of the individual notes in the note sequences qp are taken into consideration in the present examples, but not further note parameters such as e.g. note duration, loudness, striking speed, envelope, tone, key context, etc. However, it is understood that all comparisons of individual notes or note patterns described below can also extend equally to such parameters, if desired, i.e. multistage or multi-dimensional identity or similarity comparisons between multiple parameters can also be conducted accordingly in these comparisons.
Moreover, in the interests of simplicity also only monophonic note sequences are considered in each channel in the present examples. However, it is understood that the method proposed here is equally suited to polyphonic note sequences in the channels, for which extended identity or similarity comparisons, e.g. chord comparisons and key context comparisons etc., can be employed accordingly.
As is thus evident for the person skilled in the art, the method proposed here can be easily scaled to multiple note parameter comparisons and polyphonic note sequences.
The represented sequence of steps a1)-a)-b)-c)-d) is only essential insofar as some steps assume the result of others. Otherwise, the sequence is arbitrary. For example, the sequence of steps a1) and a) could be interchanged, or the sequence of steps b) and c), and so on.
In a simplified embodiment of the method step a1) can optionally be omitted with the range of application of the method limited accordingly, as explained above.
Steps a1) to d) will now be explained in detail.
a1) Pattern Detection by Means of Correlation Matrix
To detect the identically recurring note patterns (identical “loops”) in a channel chp a correlation matrix is firstly drawn up for each channel chp in accordance with Hsu Jia-Lien et al. (as above) in step a1).
Through statistical evaluation of the entries in the correlation matrix
From the preliminary list of
The “best” pattern in step (i) is respectively the most frequent and/or longest pattern mI, mII etc. in the preliminary list
Therefore, the result obtained from step a1) for each channel chp is a first list L1 of candidate patterns m1a, m1b (in general m1x), which cover the channel chp or its note sequence qp without overlap and as far as possible, i.e. as gap-free as possible, see
a) Pattern Detection by Means of Segment Similarity Comparison
A second approach is followed in step a). Each channel chp is segmented repeatedly and respectively in different ways, i.e. by varying segment length and beginning.
The shown types of segmentation I and II are based on a segmentation into segments with a length of two beats, wherein in segmentation II the segment beginning has been displaced by one beat.
The types of segmentation III—V are based on a segment length of three beats and a successive displacement of the segment beginning by one beat in each case.
It is understood that this concept can be extended accordingly to any desired segmentation lengths, beginnings and also to any desired fine quantisation units (beats) of the note sequences.
In this case, the segment length of double the average note duration of the piece of music is preferably varied to half the length of the entire piece of music at maximum, since the maximum length of a note pattern can be half the length of the piece of music at most. If desired, the process could also be stopped earlier to shorten it, i.e. segment length could be varied only to a given number of pulses, for example.
For each possible type of segmentation I, II, III etc. the similarity of the segments S1, S2, etc. with one another is now determined, i.e. preferably using the dynamic programming method known in the art.
To explain this method, reference is now made only briefly to
Using the dynamic programming alignment method of
The similarity of segments Ss and St is then evaluated by means of an accordingly selected point evaluation chart between 0% (dissimilar) and 100% (identical), e.g. on the basis of the number of identical notes, the number of gaps, the pitch interval of deviating notes etc. Two segments Ss, St are then recognized as “similar” when their similarity value determined in such a manner lies above a preset threshold value, preferably above 50%.
In this way, all segments Ss are now compared with all other segments St of a type of segmentation I, II etc. of a channel chp. For segmentation type II of channel chp, for example, this leads to recognition of a similarity between the segments S1, S3 and S6, as shown in
All segments that are similar to one another or also only transitively similar are now compiled again as instances ii of a candidate pattern, which results from the note sequence of one (e.g. the first) of these segments. The candidate patterns found for a segmentation type of a channel in this way are stored in the form of a further list L2 of candidate patterns m2a, m2b etc. with their respective instances i1, i2 etc., see
All lists L2, L3 etc. for all possible segmentation types I, II etc. of a channel chp together with the previously discussed first list L1 from step a1) provide a set of lists Ln for each channel chp, see
The lists Ln are now evaluated in the following steps b), c) and d).
b) Calculation of the Intrinsic Similarity Values
In step b) an intrinsic similarity value En is firstly calculated for each list L1, on the basis of similarity matrices for all candidate patterns mna, mnb etc. (in general mnx) for list Ln.
An intrinsic similarity value Enx for the candidate pattern mnx is now determined from all values of the similarity matrix
Alternatively, an evaluation chart can also be used that statistically evaluates or assesses the values in the cells of the similarity matrix, preferably in the following form:
The intrinsic similarity value Enx of the candidate pattern mnx is also called “loop fitness” of the candidate pattern mnx.
The intrinsic similarity value En of list Ln then results as a sum of the intrinsic similarity values Enx of all candidate patters mnx of list Ln multiplied by the channel coverage P, which all instances of all candidate patterns mnx of list Ln reach, i.e.
Channel coverage Pn of a list Ln of a channel chp is understood to mean either the temporal coverage of the channel as sum of the time durations tnxi of all instances i of all candidate patterns mnx of the channel, in relation to the total duration Tp of the channel chp; or the note-related coverage of the channel as sum of the numbers of notes nnxi in all instances i of all candidate patters mnx of the channel, in relation to the total number Np of notes of the channel chp; or preferably both the temporal and the note-related coverage in weighted form, e.g. equally weighted, i.e.
In an optional step, after determination of the intrinsic similarity values En of the lists Ln, e.g. directly after step b), for a specific channel chp all those lists Ln of the channel chp having intrinsic similarity values En that do not reach a preset threshold value can be deleted. The threshold value can preferably be predetermined adaptively or dynamically, e.g. as a percentage of the highest intrinsic similarity value En of all lists Ln of the channel chp, e.g. at least 70% or particularly preferred about 85% of the highest intrinsic similarity value En of all lists Ln of the channel chp.
c) Calculation of the Coincidence Values
In step c) coincidence values are calculated for each list Ln, i.e. between each list Ln of every channel chp and each list Ln of every other channel chp, as outlined in
According to
In this case only those overlaps u of instances ii of a candidate pattern m1x of list L1 with instances ii of the candidate pattern m2x of list L2 that occur at least twice are considered, and only those overlaps u that generate the longest—candidate pattern-related—overlap times ti. In the example of
All further overlaps of the candidate pattern m1b with instances of other candidate patterns, e.g. instances i1 and i4 of m2b, remain unconsidered, since these overlaps are shorter than the aforementioned. The repeated overlap of instance i2 of m1b with instance i3 of m2a is not counted, but respectively only one double overlap per instance of the first list L1, i.e. the longest in time.
Repeated overlaps v of instances i1 and i2 of the candidate pattern m1a with instances i1 and i2 of the candidate pattern m2b likewise remain unconsidered, since the overlaps u of instances i3 and i4 of m1a with instances i1 and of m2a were taken into consideration.
The coincidence value Kpn-p′n′ can optionally be increased for instances coinciding exactly in its beginning or end—in the shown example of
Coming back to the general method of reference in
d) Combination of the Intrinsic Similarity and Coincidence Values
The intrinsic similarity values Epn and coincidence values Kpn-p′n′ determined for each list Lpn are combined to form a total value Gpn of list Lpn, e.g. by addition, multiplication or other mathematical operations.
The following combination is applied: as illustrated in
These channel-maximum coincidence values are added to a total coincidence value Kpn for the list Lpn, i.e.:
The total coincidence value Kpn of the list Lpn is then multiplied by the intrinsic similarity value Epn of the list Lpn to give a total value Gpn for the list Lpn:
Gpn=Epn*Kpn
Then the respective list Lp that has the highest total value Gp is sought in each channel chp
In the example shown in
The candidate patterns mpx of list Lp thus constitute the respectively best known similarly recurring note patterns of the channel—i.e. with consideration of its structure relations to all other channels—as shown in
The invention is not restricted to the represented embodiments, but covers all variants and modifications that fall within the framework of the attached claims.
Number | Date | Country | Kind |
---|---|---|---|
08450164 | Oct 2008 | EP | regional |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/AT2009/000401 | 10/15/2009 | WO | 00 | 7/8/2011 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2010/045665 | 4/29/2010 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5869782 | Shishido et al. | Feb 1999 | A |
6225546 | Kraft et al. | May 2001 | B1 |
6570080 | Hasegawa et al. | May 2003 | B1 |
6747201 | Birmingham et al. | Jun 2004 | B2 |
7295985 | Kawashima et al. | Nov 2007 | B2 |
20030089216 | Birmingham et al. | May 2003 | A1 |
20030182133 | Kawashima et al. | Sep 2003 | A1 |
Number | Date | Country |
---|---|---|
102004047068 | Apr 2006 | DE |
2354095 | Mar 2001 | GB |
Number | Date | Country | |
---|---|---|---|
20110259179 A1 | Oct 2011 | US |