Example embodiments described herein generally relates to audio signal processing and more specifically estimating a tempo metric from an audio bit-stream.
Portable handheld devices (PDAs), such as smart phones, feature phones, portable media players and the like, typically include audio and/or video rendering capabilities to provide access to a variety of entertainment content as well as support social media applications. Such PDAs employ low complexity algorithms due to their limited computational power as well as energy consumption constraints. A variety of tools may be employed by low complexity algorithms such as Music Information Retrieval (MRI) applications which cluster or classify media files. An important musical feature for various MIR applications includes genre and mood classification, music summarization, audio thumbnailing, automatic playlist generation and music recommendation systems using music similarity such as musical tempo. Accordingly, there is a need for a procedure for extracting tempo information from an audio signal from an encoded bit-stream of an audio signal,
In view of the above, the example embodiments disclosed herein provides a method for estimating a tempo metric related to an audio signal based on an encoded bit-stream representing the audio signal, wherein the bit-stream includes a plurality of audio blocks. The method includes, receiving the bit-stream, detecting transitions in block sizes of the audio blocks in the bit-stream, determining at least one periodicity related to a re-occurrence of the detected transitions and determining an estimated tempo metric based on the determined periodicity.
In another example embodiment there is an apparatus for estimating a tempo metric related to an audio signal based on an encoded bit-stream representing the audio signal, wherein the bit-stream includes a plurality of audio blocks. The apparatus includes an input unit for receiving the bit-stream and a computing unit for detecting transitions in block sizes of the audio blocks in the bit-stream, determining at least one periodicity related to a re-occurrence of the detected transitions, and determining an estimated tempo metric based on the determined periodicity.
In yet another example embodiment there is an apparatus for estimating a tempo metric related to an audio signal based on an encoded bit-stream representing the audio signal, the bit-stream encoded in a format including mantissas and exponents to represent transform coefficients. The apparatus includes an input unit for receiving the bit-stream and a computing unit for repeatedly determining a cost of encoding the exponents based on information included in metadata of the bit-stream, detecting a change of the cost, determining at least one periodicity related to a re-occurrence of the detected change of cost, and, determining an estimated tempo metric based on the determined periodicity.
In still yet another example embodiment there is a non-transitory computer-readable storage medium which stores executable computer program instructions for executing a method for estimating a tempo metric related to an audio signal based on an encoded bit-stream representing the audio signal, wherein the bit-stream includes a plurality of audio blocks. The method includes receiving the bit-stream, detecting transitions in block sizes of the audio blocks in the bit-stream, determining at least one periodicity related to a re-occurrence of the detected transitions and determining an estimated tempo metric based on the determined periodicity.
These and other example embodiments and aspects are detailed below with particularity.
The foregoing and other aspects of the example embodiments of this invention are further explained in the following Detailed Description, when read in conjunction with the attached Drawing Figures.
Principles of the present disclosure will now be described with reference to various example embodiments illustrated in the drawings. It should be appreciated that depiction of these embodiments is only to enable those skilled in the art to better understand and further implement the present disclosure, not intended for limiting the scope of the present disclosure in any manner.
As already mentioned, an important musical feature for various music information retrieval (MIR) applications includes a musical tempo. It is common to characterize a music tempo by a notated tempo on a sheet music or a musical score in BPM (Beats Per Minute), this value often does not correspond to the perceptual tempo. For instance, if a group of listeners (including skilled musicians) is asked to annotate the tempo of music excerpts, they typically give different answers, for example they typically tap at different metrical levels. For some excerpts of music the perceived tempo is less ambiguous and all the listeners typically tap at the same metrical level, but for other excerpts of music the tempo can be ambiguous and different listeners identify different tempos. In other words, perceptual experiments have shown that the perceived tempo may differ from the notated tempo. A piece of music can feel faster or slower than its notated tempo in that the dominant perceived pulse can be a metrical level higher or lower than the notated tempo. In view of the fact that MIR applications should preferably take into account the tempo most likely to be perceived by a user, an automatic tempo extractor should predict the most perceptually salient tempo of an audio signal.
Example embodiments described herein provide for methods, techniques or algorithms for estimating a tempo metric related to an audio signal based on an encoded bit-stream representing the audio signal, wherein the bit-stream includes a plurality of audio blocks. The method includes, receiving the bit-stream, detecting transitions in block sizes of the audio blocks in the bit-stream, determining at least one periodicity related to a re-occurrence of the detected transitions and determining an estimated tempo metric based on the determined periodicity. Such a method has many advantages, for example it exhibits low computational complexity, for example in that it relies on detecting changes in audio block sizes on the audio bit-stream.
A fundamental concept in tempo estimation algorithm is the notion of onsets. Onsets are the locations in time where significant rhythmic events such as pitched notes or transient percussion events take place. Tempo estimators in accordance with example embodiments disclosed here use a continuous representation of onsets in which a “soft” onset strength value is provided at a regular time locations. The resulting signal is frequently called the onset strength signal. It will be appreciated that employing “onsets” in an audio file, (e.g., drum beats), may determine the tempo that a listener perceives when listening to the audio file. Furthermore, example embodiments disclosed herein may rely upon such onsets appearing in the bit-stream domain as a change in audio block size. In an embodiment the detected transitions are transitions from long audio blocks to short audio blocks. The block size relates to an amount of bits required for representing a block of transform coefficient.
In an embodiment, the bit-stream is encoded in a format including mantissa and exponent to represent a transform coefficient, wherein the exponent relates to the number of leading zeros in a binary representation of the transform coefficient. Such a coding scheme as described here in accordance with example embodiment may be applicable to many different codecs (e.g., Dolby Digital (AC-3)).
In another aspect of a further embodiment, a cost of encoding the exponent is determined. This cost may relate to a bit-requirement at an encoder to encode a current exponent. It should be appreciate that a change of the cost may relate to a transition in the block sizes.
Accordingly, it will be appreciated that example embodiments disclosed herein constitutes a simple and efficient way of determining the changes in audio block size as an indirect identification of tempo information, such as the “onsets”.
The cost of encoding the exponent in accordance with example embodiments herein may for example, be determined depending on an exponent strategy per audio block, as employed at an encoder end. An exponent strategy may be used to optimize bit allocation when encoding a signal. Therefore, the encoding cost calculation can be made more accurate when taking into consideration the exponent strategy as used by an encoder when generating the bit-stream.
In one aspect of the example embodiments, the exponent strategy may for example, depend on signal conditions of the audio signal. In another example embodiment, the exponent strategy may for example, include any of frequency exponent sharing, time exponent sharing and recurring transmission/encoding of exponents.
It will be appreciated by those skilled in the art that the above described strategies will contribute to optimize the before-mentioned bit allocation when encoding the audio signal, for example, by sharing one exponent among at least two mantissas, or encoding the exponents in a first audio block and reusing the exponents as exponents encoded for subsequent audio blocks, or distributing the exponents among a first audio block and one or more subsequent audio blocks.
As previously mentioned—it will be appreciated that a first increase of the cost of encoding that the exponent is likely to represent a first onset included in the audio signal. Accordingly, with a second increase of the cost of encoding; the exponent is thus likely to represent a second onset included in the audio signal.
In one example embodiment, the at least one periodicity is determined from the first and second onsets.
Example embodiments described herein may for example be employed in an audio file (e.g. music file), where the detection of first and second onsets is likely to represent a repetitive pattern from which a tempo metric may be derived.
In an another example embodiment, at least one further increase of the cost is determined, where the further increase of cost represents a further onset, and wherein at least one further periodicity is determined from at least two of the first, second and further onsets.
It will be appreciated by those skilled in the art that the estimated tempo metric will be the more accurate when more onsets are considered to derive the tempo metric. For example, a musical beat might include some “faster” and some “slower” onsets, such as drum beats. Only considering the slower drum beats could reveal a tempo metric being too low (e.g., half, quarter), and considering only the faster drum beats could result in an estimated tempo being too high (e.g. double, triple, quadruple and the like). Accordingly, a refined periodicity may be determined for example, from any of the first and further periodicities. The estimated (and more refined) tempo metric may then be based on the refined periodicity.
In yet another example embodiment, the encoded bit-stream may also include a number of encoded channels which include a number of individual channels and at least one coupling channel, and the cost of encoding the exponents for the number of channels is determined by calculating a sum of cost of encoding spectral envelopes of the individual channels and the at least one coupling channel.
In yet another example embodiment there is disclosed a method for estimating a tempo metric related to an audio signal based on an encoded bit-stream representing the audio signal, the bit-stream encoded in a format including mantissas and exponents to represent transform coefficients. Such a method may include receiving the bit-stream, repeatedly determining a cost of encoding the exponents based on information included in metadata of the bit-stream, detecting a change of the cost, determining at least one periodicity related to a re-occurrence of the detected change of cost and determining an estimated tempo metric based on the determined periodicity.
It will be appreciated that that when we have a change of the cost it will reflect the tempo a listener perceives when listening, because onsets included in the audio file are likely to have caused the change in cost at the encoder end.
In yet another embodiment, the information included in the metadata is related to an exponent strategy previously employed by an encoder end to allocate bits to the encoding of the exponents.
In another example embodiment, depending on the exponent strategy employed, a different amount of bits are allocated to exponents during encoding. In such an example embodiment, the cost of encoding the exponents may be determined based on the exponent strategy per audio block.
In one aspect, the exponent strategy may also depend on, for example, the signal conditions of the audio signal. In another aspect, the exponent strategy may for example, include any of frequency exponent sharing, time exponent sharing and recurring transmission and/or encoding of exponents.
It will be appreciated by those skilled in the art that the above described strategies may contribute to optimize the before-mentioned bit allocation when encoding the audio signal, for example, by sharing one exponent among at least two mantissas, or encoding the exponents in a first audio block and reusing the exponents as exponents encoded for subsequent audio blocks, or distributing the exponents among a first audio block and one or more subsequent audio blocks.
As previously mentioned it will be appreciated that a first increase of the cost of encoding the exponent is likely to represent a first onset included in the audio signal. Accordingly, with a second increase of the cost of encoding, the exponent may likely represent a second onset included in the audio signal.
In one example embodiment, the at least one periodicity is determined from the first and second onsets.
In yet another embodiment, at least one further increase of the cost is determined, said further increase of cost representing a further onset, and wherein at least one further periodicity is determined from at least two of said first, second and further onsets.
Therefore, a refined periodicity can thus be determined e.g. from any of the first and further periodicities. The estimated (and more refined) tempo metric can then be based on said refined periodicity.
In another embodiment, the encoded bit-stream may also include a number of encoded channels which include a number of individual channels and at least one coupling channel. The cost of encoding the exponents for the number of channels is determined by calculating a sum of cost of encoding spectral envelopes of the individual channels and the at least one coupling channel.
As shown in
As shown in
The size of the audio blocks 11, 13 reveals a downmix representation of coded audio in the bit-stream domain. It will be appreciated to those skilled in the art that audio blocks containing signals with a high bit demand may be weighted more heavily than others in the distribution of the available bits (e.g., bit pool) for one frame.
Coded bit streams 9 may, for example, include quantized frequency coefficients (e.g. MDCT coefficients).
The coefficients may, for example, be delivered in floating-point format, whereby each can include an exponent and a mantissa. See also
When the onsets 3, 5, 7 occur, a change in cost (i.e. change in bit allocation) can be observed when encoding the exponents of the bit-stream. The encoding of the exponents depends on a specific exponent strategy for the current audio block. When the onsets 3, 5, 7 occur, a change in exponent strategy for the subsequent block can be employed.
A distance determined between at least two of the onsets 3, 5, 7 is representative for a periodicity 17, 18 (e.g. repeatedly recurring drum beats) related to a tempo metric of the audio file content (specifically music). The periodicity can e.g. be a time between two onsets 3, 5, 7. Such time can be derived from further properties of the encoded bit-stream, e.g. the sample rate used when encoding.
A tempo estimation can then be derived based on said at least one of periodicities 17, 18.
E.g., if two onsets are spaced apart by 0.25 seconds, we assume a recurrence after another 0.25 seconds—thus arriving at a periodicity of 0.25 seconds.
This e.g. corresponds to a frequency of 4 Hz—indicating a tempo of 4 beats per second.
A further refinement in determining the tempo estimation can be based on considering at least two (or more) of the periodicities 17, 18, e.g. by combining and weighting them—and/or by omitting one or more of them in the estimation calculation. Such refinement steps are suitable to correct the tempo estimate for half-time, double-time or other “octave” errors.
An audio file e.g. includes music which reveals onsets 3, 5, 7—such as characteristic drum beats—spaced apart at a time distance.
The inventor has detected that the occurrence of the onsets 3, 5, 7 typically leads to a change in cost 19, 21, 23, 25—as a consequence of a change in encoding strategy.
Based on information included in metadata of the bit-stream, a cost of encoding the exponents can be determined.
When the onsets 3, 5, 7 occur, a change in cost (i.e. change in bit allocation) can be observed when encoding the exponents of the bit-stream.
A distance determined between at least two of the onsets 3, 5, 7 is representative for a periodicity 17, 18 (e.g. repeatedly recurring drum beats) related to a tempo metric of the audio file content (specifically music). The periodicity can e.g. be a time between two onsets. Such time can be derived from further properties of the encoded bit-stream, e.g. the sample rate used when encoding.
A periodicity 17, 18 is determined that relates to the re-occurrence of the detected change of cost.
A tempo estimation can then be derived based on said at least one of periodicities 17, 18.
E.g., if two onsets are spaced apart by 0.25 seconds, we assume a recurrence after another 0.25 seconds—thus arriving at a periodicity of 0.25 seconds.
This e.g. corresponds to a frequency of 4 Hz—which is 4 beats per second.
A further refinement in determining the tempo estimation can be based on considering at least two (or more) of the periodicities 17, 18, e.g. by combining and weighting them and/or by omitting one or more of them in the estimation calculation. Such refinement steps are suitable to correct the tempo estimate for half-time, double-time or other “octave” errors.
A first increase of the cost 19, 21, 23, 25 of encoding the exponent can represent a first onset included in the audio signal and a second increase of the cost 19, 21, 23, 25 of encoding the exponent can represent a second onset included in the audio signal. At least one periodicity 17, 18 is determined from the first and second onsets. One further increase of said cost can then be determined, where said further increase of cost represents a further onset 3, 5, 7. At least one further periodicity can be determined from at least two of said first, second and further onsets.
The exponent relates to the number of leading zeros in a binary representation of the transform coefficient. For background information see the following reference by Davidson, G. A “Digital Audio Coding: Dolby AC-3” Digital Signal Processing Handbook, Ed Vijaj K Madisetti and Douglas B. Williams, Boca Raton CRC Press LLC, 1999.
Sharing exponents in either the time or frequency domain, or both, can reduce the total cost of exponent encoding for one or more frames. Employing exponent sharing therefore allows for more bits for mantissa quantization. If exponents would routinely be encoded without employing such (or other) sharing strategies, fewer bits would be available for mantissa quantization. Furthermore, the block positions at which exponents are re-encoded can significantly determine the effectiveness of mantissa assignments among the various audio blocks. Generally, an exponent sharing strategy is suitable for optimizing the bit allocation between the mantissas and exponents for encoding, by providing as many bits for quantizing/encoding the mantissas as possible—to improve the overall coding accuracy.
In the frequency domain: an exponent can be shared among at least two mantissas.
In the time domain, any two or more consecutive audio blocks from one frame can share a common set of exponents. “Re-using” the same exponent by at least two mantissas will usually lower the cost of the exponent encoding. Hence, e.g. depending on signal conditions describing if the signal is more of a stationary or not stationary signal, the encoder can decide if and when to use frequency or time exponent sharing, and when to re-encode exponents. This decision making process is often referred to as exponent strategy.
For stationary signals the signal spectrum remains substantially invariant from block-to-block.
Dolby Digital (abbreviated as AC-3), e.g., employs exponent strategies related to 6 audio blocks. When we have e.g. stationary signals, the encoder encodes exponents once in audio block zero (AB0), and then re-uses them for audio blocks AB1-AB5. The resulting bit allocation would generally be identical for all six blocks, which is appropriate for stationary signals.
For non-stationary signals, the signal spectrum can change significantly from block-to-block. The encoder can e.g. encode exponents once in AB0 and re-encode new exponents in one or more other blocks as well, thus increasing cost of encoding the exponents. Re-encoding of new exponents produces a time curve of coded spectral envelopes that better matches dynamics of the original signal.
In e.g. AC-3, the encoder encodes exponents in AB0. The current frame may e.g. be re-using exponents from the last block of the previous frame. The block(s) at which bit assignment updates occur, is governed by several parameters, but primarily by the exponent strategy—as reflected in the respective metadata field. Bit allocation updates are triggered if the state of any one or more strategy flags is D15, D25, or D45.
A flag indicating exponent strategy D15 can e.g. indicate that one exponent is “shared” by only one mantissa. D25 means e.g. that one exponent is shared by two mantissas. D45 e.g. means that one exponent is shared by 4 mantissas.
An unshared exponent requires e.g. 5 bits.
Updates of bit allocations indicate onsets of the signal. If a new strategy flag is detected, a new bit allocation is about to be employed and it can indicate the occurrence of an onset in the signal if it is also related to an increase in cost of encoding the exponents.
In a multi-channel scenario, the bit-stream can include a number of encoded channels comprising a number of individual channels and at least one coupling channel.
Here, the frequency coefficients of a coupling channel can be encoded instead of encoding individual channel spectra of the individual channels—while adding side information to enable later decoding.
The cost of encoding the exponents in said multichannel scenario can then be calculated as a sum of cost of encoding the spectral envelopes of the individual channels and the at least one coupling channel.
Apparatus 30 of
The functionality of the apparatus 30 incorporates functionality as depicted in and described for
Apparatus 35 of
The functionality of the apparatus 35 incorporates functionality as depicted in and described for
The entities shown in
The storage device 508 is a non-transitory computer-readable storage medium such as a hard drive, compact disk read-only memory (CD-ROM), DVD, or a solid-state memory device. The memory 506 holds instructions and data used by the processor 502. The pointing device 514 is a mouse, track ball, or other type of pointing device, and is used in combination with the keyboard 510 to input data into the computer system 500. The graphics adapter 512 displays images and other information on the display 518. The network adapter 516 couples the computer system 500 to one or more computer networks.
The computer 500 is adapted to execute computer program modules for providing functionality described herein. As used herein, the term “module” refers to computer program logic used to provide the specified functionality. Thus, a module can be implemented in hardware, firmware, and/or software. In one embodiment, program modules are stored on the storage device 508, loaded into the memory 506, and executed by the processor 502.
The types of computers 500 used by the entities of
Example embodiments disclosed herein may for example, provide estimating tempo information directly from a bit-stream encoding audio information, (e.g., music).
Tempo information may as described in this disclosure be derived from at least one periodicity derived from a detection of at least two onsets included in the audio information.
Such onsets maybe detected by way of detecting long to short block transitions (in the bit-stream) or/and via a detection of a changing bit allocation (change of cost) regarding encoding/transmitting the exponents of transform coefficients encoded in the bit-stream.
This application claims the benefit of priority to U.S. Provisional Patent Application No. 61/941,283 filed 18 Feb. 2014, which is hereby incorporated by reference in its entirety.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/EP2015/053371 | 2/18/2015 | WO | 00 |
Number | Date | Country | |
---|---|---|---|
61941283 | Feb 2014 | US |