The present invention relates to audio signal encoding, decoding, and processing, and, in particular, to adjusting a level of a signal to be frequency-to-time converted (or time-to-frequency converted) to the dynamic range of a corresponding frequency-to-time converter (or time-to-frequency converter). Some embodiments of the present invention relate to adjusting the level of the signal to be frequency-to-time converted (or time-to-frequency converted) to the dynamic range of a corresponding converter implemented in fixed-point or integer arithmetic. Further embodiments of the present invention relate to clipping prevention for spectral decoded audio signals using time domain level adjustment in combination with side information.
Audio signal processing becomes more and more important. Challenges arise as modern perceptual audio codecs are necessitated to deliver satisfactory audio quality at increasingly low bit rates.
In the current audio content production and delivery chains the digitally available master content (PCM stream (pulse code modulated stream)) is encoded e.g. by a professional AAC (Advanced Audio Coding) encoder at the content creation side. The resulting AAC bitstream is then made available for purchase e.g. through an online digital media store. It appeared in rare cases that some decoded PCM samples are “clipping” which means that two or more consecutive samples reached the maximum level that can be represented by the underlying bit resolution (e.g. 16 bit) of a uniformly quantized fixed-point representation (e.g. modulated according to PCM) for the output waveform. This may lead to audible artifacts (clicks or short distortion). Although typically an effort will be made at the encoder side to prevent the occurrence of clipping at the decoder side, clipping may nevertheless occur at the decoder side for various reasons, such as different decoder implementations, rounding errors, transmission errors, etc. Assuming an audio signal at the encoder's input that is below the threshold of clipping, the reasons for clipping in a modern perceptual audio encoder are manifold. First of all, the audio encoder applies quantization to the transmitted signal which is available in a frequency decomposition of the input waveform in order to reduce the transmission data rate. Quantization errors in the frequency domain result in small deviations of the signal amplitude and phase with respect to the original waveform. If amplitude or phase errors add up constructively, the resulting attitude in the time domain may temporarily be higher than the original waveform. Secondly, parametric coding methods (e.g. spectral band replication, SBR) parameterize the signal power in a rather course manner. Phase information is typically omitted. Consequently, the signal at the receiver side is only regenerated with correct power but without waveform preservation. Signals with an amplitude close to full scale are prone to clipping.
Modern audio coding systems offer the possibility to convey a loudness level parameter (g1) giving decoders the possibility to adjust loudness for playback with unified levels. In general, this might lead to clipping, if the audio signal is encoded at sufficiently high levels and transmitted normalization gains suggest increasing loudness levels. In addition, common practice in mastering audio content (especially music) boosts audio signals to the maximum possible values, yielding clipping of the audio signal when coarsely quantized by audio codecs.
To prevent clipping of audio signals, so called limiters are known as an appropriate tool to restrict audio levels. If an incoming audio signal exceeds a certain threshold, the limiter is activated and attenuates the audio signal in a way that the audio signal does not exceed a given level at the output. Unfortunately, prior to the limiter, sufficient headroom (in terms of dynamic range and/or bit resolution) is necessitated.
Usually, any loudness normalization is achieved in the frequency domain together with a so-called “dynamic range control” (DRC). This allows smooth blending of loudness normalization even if the normalization gain varies from frame to frame because of the filter-bank overlap.
Further, due to poor quantization or parametric description, any coded audio signal might go into clipping if the original audio was mastered at levels near the clipping threshold.
It is typically desirable to keep computational complexity, memory usage, and power consumption as small as possible in highly efficient digital signal processing devices based on a fixed-point arithmetic. For this reason, it is also desirable to keep the word length of audio samples as small as possible. To take any potential headroom for clipping due to loudness normalization into account, a filter bank, which typically is a part of an audio encoder or decoder, would have to be designed with a higher word length.
It would be desirable to allow signal limiting without losing data precision and/or without a need for using a higher word length for a decoder filter bank or an encoder filter bank. In the alternative or in addition it would be desirable if a relevant dynamic range of the signal to be frequency-to-time converted or vice versa could be determined continuously on a frame-by-frame basis for consecutive time sections or “frames” of the signal so that the level of the signal can be adjusted in a way that the current relevant dynamic range fits into the dynamic range provided by the converter (frequency-to-time domain converter or time-to-frequency-domain converter). It would also be desirable to make such a level shift for the purpose of frequency-to-time conversion or time-to-frequency conversion substantially “transparent” to other components of the decoder or encoder.
According to an embodiment, an audio signal decoder configured to provide a decoded audio signal representation on the basis of an encoded audio signal representation may have: a decoder preprocessing stage configured to obtain a plurality of frequency band signals from the encoded audio signal representation; a clipping estimator configured to analyze side information relative to a gain of the frequency band signals of the encoded audio signal representation as to whether the side information suggests a potential clipping in order to determine a current level shift factor for the encoded audio signal representation, wherein when the side information suggest the potential clipping, the current level shift factor causes information of the plurality of frequency band signals to be shifted towards a least significant bit so that headroom at at least one most significant bit is gained; a level shifter configured to shift levels of the frequency band signals according to the current level shift factor for obtaining level shifted frequency band signals; a frequency-to-time-domain converter configured to convert the level shifted frequency band signals into a time-domain representation; and a level shift compensator configured to act on the time-domain representation for at least partly compensating a level shift applied to the level shifted frequency band signals by the level shifter and for obtaining a substantially compensated time-domain representation.
According to another embodiment, an audio signal encoder configured to provide an encoded audio signal representation on the basis of a time-domain representation of an input audio signal may have: a clipping estimator configured to analyze the time-domain representation of the input audio signal as to whether potential clipping is suggested in order to determine a current level shift factor for the input signal representation, wherein when the potential clipping is suggested, the current level shift factor causes the time-domain representation of the input audio signal to shifted towards a least significant bit so that headroom at at least one most significant bit is gained; a level shifter configured to shift a level of the time-domain representation of the input audio signal according to the current level shift factor for obtaining a level shifted time-domain representation; a time-to-frequency domain converter configured to convert the level shifted time-domain representation into a plurality of frequency band signals; and a level shift compensator configured to act on the plurality of frequency band signals for at least partly compensating a level shift applied to the level shifted time-domain representation by the level shifter and for obtaining a plurality of substantially compensated frequency band signals.
According to still another embodiment, a method for decoding an encoded audio signal representation and for providing a corresponding decoded audio signal representation may have the steps of: preprocessing the encoded audio signal representation to obtain a plurality of frequency band signals; analyzing side information relative to a gain of the frequency band signals as to whether the side information suggest a potential clipping in order to determine a current level shift factor for the encoded audio signal representation, wherein when the side information suggests the potential clipping, the current level shift factor causes information of the plurality of frequency band signals to be shifted towards a least significant bit so that headroom at at least one most significant bit is gained; shifting levels of the frequency band signals according to the level shift factor for obtaining level shifted frequency band signals; performing a frequency-to-time-domain conversion of the frequency band signals to a time-domain representation; and acting on the time-domain representation for at least partly compensating a level shift applied to the level shifted frequency band signals and for obtaining a substantially compensated time-domain representation.
Another embodiment may have a computer program for instructing a computer to perform the above method.
An audio signal decoder for providing a decoded audio signal representation on the basis of an encoded audio signal representation is provided. The audio signal decoder comprises a decoder preprocessing stage configured to obtain a plurality of frequency band signals from the encoded audio signal presentation. The audio signal decoder further comprises a clipping estimator configured to analyze at least one of the encoded audio signal representation, the plurality of frequency signals, and side information relative to a gain of the frequency band signals of the encoded audio signal representation as to whether the encoded audio signal information, the plurality of frequency signals, and/or the side information suggest(s) a potential clipping in order to determine a current level shift factor for the encoded audio signal representation. When the side information suggest the potential clipping, the current level shift factor causes information of the plurality of frequency band signals to be shifted towards a least significant bit so that headroom at at least one most significant bit is gained. The audio signal decoder also comprises a level shifter configured to shift levels of the frequency band signals according to the level shift factor for obtaining level shifted frequency band signals. Furthermore, the audio signal decoder comprises a frequency-to-time-domain converter configured to convert the level shifter frequency band signals into a time-domain representation. The audio signal decoder further comprises a level shift compensator configured to act on the time-domain representation for at least partly compensating a level shift applied to the level shifter frequency band signals by the level shifter and for obtaining a substantially compensated time-domain representation.
Further embodiments of the present invention provide an audio signal encoder configured to provide an encoded audio signal representation on the basis of a time-domain representation of an input audio signal. The audio signal encoder comprises a clipping estimator configured to analyze the time-domain representation of the input audio signal as to whether potential clipping is suggested in order to determine a current level shift factor for the input signal presentation. When the potential clipping is suggested, the current level shift factor causes the time-domain representation of the input audio signal to shift towards a least significant bit so that headroom at at least one most significant bit is gained. The audio signal encoder further comprises a level shifter configured to shift a level of the time-domain representation of the input audio signal according to the level shift factor for obtaining a level shifted time-domain representation. Furthermore, the audio signal encoder comprises a time-to-frequency domain converter configured to convert the level shifted time-domain representation into a plurality of frequency band signals. The audio signal encoder also comprises a level shift compensator configured to act on the plurality of frequency band signals for at least partly compensating a level shift applied to the level shifter time domain presentation by the level shifter and for obtaining a plurality of substantially compensated frequency band signals.
Further embodiments of the present invention provide a method for decoding the encoded audio signal presentation to obtain a decoded audio signal representation. The method comprises preprocessing the encoded audio signal representation to obtain a plurality of frequency band signals. The method further comprises analyzing at least one of the encoded audio signal representation, the frequency band signals, and side information relative to a gain of the frequency band signals as to whether potential clipping is suggested in order to determine a current level shift factor for the encoded audio signal presentation. When the potential clipping is suggested, the current level shift factor causes the time-domain representation of the input audio signal to shift towards a least significant bit so that headroom at at least one most significant bit is gained. Furthermore, the method comprises shifting levels of the frequency band signals according to the level shift factor for obtaining level shifted frequency band signals. The method also comprises performing a frequency-to-time-domain conversion of the frequency band signals to a time-domain representation. The method further comprises acting on the time-domain representation for at least partly compensating a level shift applied to the level shifted frequency band signals and for obtaining a substantially compensated time-domain representation.
Furthermore, a computer program for implementing the above-described methods when being executed on a computer or signal processor is provided.
Further embodiments provide an audio signal decoder for providing a decoded audio signal representation on the basis of an encoded audio signal representation is provided. The audio signal decoder comprises a decoder preprocessing stage configured to obtain a plurality of frequency band signals from the encoded audio signal presentation. The audio signal decoder further comprises a clipping estimator configured to analyze at least one of the encoded audio signal representation, the plurality of frequency signals, and side information relative to a gain of the frequency band signals of the encoded audio signal representation in order to determine a current level shift factor for the encoded audio signal representation. The audio signal decoder also comprises a level shifter configured to shift levels of the frequency band signals according to the level shift factor for obtaining level shifted frequency band signals. Furthermore, the audio signal decoder comprises a frequency-to-time-domain converter configured to convert the level shifter frequency band signals into a time-domain representation. The audio signal decoder further comprises a level shift compensator configured to act on the time-domain representation for at least partly compensating a level shift applied to the level shifter frequency band signals by the level shifter and for obtaining a substantially compensated time-domain representation.
Further embodiments of the present invention provide an audio signal encoder configured to provide an encoded audio signal representation on the basis of a time-domain representation of an input audio signal. The audio signal encoder comprises a clipping estimator configured to analyze the time-domain representation of the input audio signal in order to determine a current level shift factor for the input signal presentation. The audio signal encoder further comprises a level shifter configured to shift a level of the time-domain representation of the input audio signal according to the level shift factor for obtaining a level shifted time-domain representation. Furthermore, the audio signal encoder comprises a time-to-frequency domain converter configured to convert the level shifted time-domain representation into a plurality of frequency band signals. The audio signal encoder also comprises a level shift compensator configured to act on the plurality of frequency band signals for at least partly compensating a level shift applied to the level shifter time domain presentation by the level shifter and for obtaining a plurality of substantially compensated frequency band signals.
Further embodiments of the present invention provide a method for decoding the encoded audio signal presentation to obtain a decoded audio signal representation. The method comprises preprocessing the encoded audio signal representation to obtain a plurality of frequency band signals. The method further comprises analyzing at least one of the encoded audio signal representation, the frequency band signals, and side information relative to a gain of the frequency band signals is suggested in order to determine a current level shift factor for the encoded audio signal presentation. Furthermore, the method comprises shifting levels of the frequency band signals according to the level shift factor for obtaining level shifted frequency band signals. The method also comprises performing a frequency-to-time-domain conversion of the frequency band signals to a time-domain representation. The method further comprises acting on the time-domain representation for at least partly compensating a level shift applied to the level shifted frequency band signals and for obtaining a substantially compensated time-domain representation.
At least some of the embodiments are based on the insight that it is possible, without losing relevant information, to shift the plurality of frequency band signals of a frequency domain representation by a certain level shift factor during time intervals, in which an overall loudness level of the audio signal is relatively high. Rather, the relevant information is shifted to bits that are likely to contain noise, anyway. In this manner, a frequency-to-time-domain converter having a limited word length can be used even though a dynamic range of the frequency band signals may be larger than supported by the limited word length of the frequency-to-time-domain converter. In other words, at least some embodiments of the present invention exploit the fact that the least significant bit(s) typically does/do not carry any relevant information while the audio signal is relatively loud, i.e., while the relevant information is more likely to be contained in the most significant bit(s). The level shift applied to the level shifted frequency band signals may also have the benefit of reducing a probability of clipping to occur within the time-domain representation, where said clipping may result from a constructive superposition of one or more frequency band signals of the plurality of frequency band signals.
These insights and findings also apply in an analogous manner to the audio signal encoder and the method for encoding an original audio signal to obtain an encoded audio signal presentation.
In the following, embodiments of the present invention are described in more detail with reference to the figures, in which:
Audio processing has advanced in many ways and it has been subject of many studies, how to efficiently encode and decode an audio data signal. Efficient encoding is, for example, provided by MPEG AAC (MPEG=Moving Pictures Expert Group; AAC=Advanced Audio Coding). Some aspects of MPEG AAC are explained in more detail below, as an introduction to audio encoding and decoding. The description of MPEG AAC is to be understood as an example only, as the described concepts may be applied to other audio encoding and decoding schemes, as well.
According to MPEG AAC, spectral values of an audio signal are encoded employing scalefactors, quantization and codebooks, in particular Huffman Codebooks.
Before Huffman encoding is conducted, the encoder groups the plurality of spectral coefficients to be encoded into different sections (the spectral coefficients have been obtained from upstream components, such as a filterbank, a psychoacoustical model, and a quantizer controlled by the psychoacoustical model regarding quantization thresholds and quantization resolutions). For each section of spectral coefficients, the encoder chooses a Huffman Codebook for Huffman-encoding. MPEG AAC provides eleven different Spectrum Huffman Codebooks for encoding spectral data from which the encoder selects the codebook being best suited for encoding the spectral coefficients of the section. The encoder provides a codebook identifier identifying the codebook used for Huffman-encoding of the spectral coefficients of the section to the decoder as side information.
On a decoder side, the decoder analyses the received side information to determine which one of the plurality of Spectrum Huffman Codebooks has been used for encoding the spectral values of a section. The decoder conducts Huffman Decoding based on the side information about the Huffman Codebook employed for encoding the spectral coefficients of the section which is to be decoded by the decoder.
After Huffman Decoding, a plurality of quantized spectral values is obtained at the decoder. The decoder may then conduct inverse quantization to invert a non-uniform quantization that may have been conducted by the encoder. By this, inverse-quantized spectral values are obtained at the decoder.
However, the inverse-quantized spectral values may still be unscaled. The derived unscaled spectral values have been grouped into scalefactor bands, each scalefactor band having a common scalefactor. The scalefactor for each scalefactor band is available to the decoder as side information, which has been provided by the encoder. Using this information, the decoder multiplies the unscaled spectral values of a scalefactor band by their scalefactor. By this, scaled spectral values are obtained.
Encoding and decoding of spectral values according to the state of the art is now explained with reference to
Moreover, the encoder in
After quantization, the quantized unscaled spectra of the audio signal are fed into a Huffman encoder 40 for being Huffman-encoded. Huffman coding is used for reduced redundancy of the quantized spectrum of the audio signal. The plurality of unscaled quantized spectral coefficients is grouped into sections. While in MPEG-AAC eleven possible codebooks are provided, all spectral coefficients of a section are encoded by the same Huffman codebook.
The encoder will choose one of the eleven possible Huffman codebooks that is particularly suited for encoding the spectral coefficients of the section. By this, the selection of the Huffman codebook of the encoder for a particular section depends on the spectral values of the particular section. The Huffman-encoded spectral coefficients may then be transmitted to the decoder along with side information comprising e.g., information about the Huffman codebook that has been used for encoding a section of spectral coefficients, a scalefactor that has been used for a particular scalefactor band etc.
Two or four spectral coefficients are encoded by a codeword of the Huffman codebook employed for Huffman-encoding the spectral coefficients of the section. The encoder transmits the codewords representing the encoded spectral coefficients to the decoder along with side information comprising the length of a section as well as information about the Huffman codebook used for encoding the spectral coefficients of the section.
In MPEG AAC, eleven Spectrum Huffman codebooks are provided for encoding spectral data of the audio signal. The different Spectrum Huffman codebook may be identified by their codebook index (a value between 1 and 11). The dimension of the Huffman codebook indicates how many spectral coefficients are encoded by a codeword of the considered Huffman codebook. In MPEG AAC, the dimension of a Huffman codebook is either 2 or 4 indicating that a codeword either encodes two or four spectral values of the audio signal.
However the different Huffman codebooks also differ regarding other properties. For example, the maximum absolute value of a spectral coefficient that can be encoded by the Huffman codebook varies from codebook to codebook and can, for example, be 1, 2, 4, 7, 12 or greater. Moreover, a considered Huffman codebook may be adapted to encode signed values or not.
Employing Huffman-encoding, the spectral coefficients are encoded by codewords of different lengths. MPEG AAC provides two different Huffman codebooks having a maximum absolute value of 1, two different Huffman codebooks having a maximum absolute value of 2, two different Huffman codebooks having a maximum absolute value of 4, two different Huffman codebooks having an maximum absolute value of 7 and two different Huffman codebooks having an maximum absolute value of 12, wherein each Huffman codebook represents a distinct probability distribution function. The Huffman encoder will always choose the Huffman codebook that fits best for encoding the spectral coefficients.
The audio signal decoder 100 comprises a decoder preprocessing stage 110 that is configured to obtain a plurality of frequency band signals from the encoded audio signal representation. For example, the decoder preprocessing stage 110 may comprise a bitstream unpacker in case the encoded audio signal representation and the side information are contained in a bitstream. Some audio encoding standards may use time-varying resolutions and also different resolutions for the plurality of frequency band signals, depending on the frequency range in which the encoded audio signal presentation currently carries relevant information (high resolution) or irrelevant information (low resolution or no data at all). This means that a frequency band in which the encoded audio signal representation currently has a large amount of relevant information is typically encoded using a relatively fine resolution (i.e., using a relatively high number of bits) during that time interval, in contrast to a frequency band signal that temporarily carries no or only very few information. It may even happen that for some of the frequency band signals the bitstream temporarily contains no data or bits, at all, because these frequency band signals do not contain any relevant information during the corresponding time interval. The bitstream provided to the decoder preprocessing stage 110 typically contains information (e.g., as part of the side information) indicating which frequency band signals of the plurality of frequency band signals contain data for the currently considered time interval or “frame”, and the corresponding bit resolution.
The audio signal decoder 100 further comprises a clipping estimator 120 configured to analyze the side information relative to a gain of the frequency band signals of the encoded audio signal representation in order to determine a current level shift factor for the encoded audio signal representation. Some perceptual audio encoding standards use individual scale factors for the different frequency band signals of the plurality of frequency band signals. The individual scale factors indicate for each frequency band signal the current amplitude range, relative to the other frequency band signals. For some embodiments of the present invention an analysis of these scale factors allows an approximate assessment of a maximal amplitude that may occur in a corresponding time-domain representation after the plurality of frequency band signals have been converted from a frequency domain to a time domain. This information may then be used in order to determine if, without any appropriate processing as proposed by the present invention, clipping would be likely to occur within the time-domain representation for the considered time interval or “frame”. The clipping estimator 120 is configured to determine a level shift factor that shifts all the frequency band signals of the plurality of frequency band signals by an identical amount with respect to the level (regarding a signal amplitude or a signal power, for example). The level shift factor may be determined for each time interval (frame) in an individual manner, i.e., the level shift factor is time-varying. Typically, the clipping estimator 120 will attempt to adjust the levels of the plurality of frequency band signals by the shift factor that is common to all the frequency band signals in a way that clipping within the time-domain representation is very unlikely to occur, but at the same time maintaining a reasonable dynamic range for the frequency band signals. As an example, consider a frame of the encoded audio signal representation in which a number of the scale factors are relatively high. The clipping estimator 120 may now consider the worst-case, that is, possible signal peaks within the plurality of frequency band signals overlap or add up in a constructive manner, resulting in a large amplitude within the time-domain representation. The level shift factor may now be determined as a number that causes this hypothetical peak within the time-domain representation to be within a desired dynamic range, possibly with the additional consideration of a margin. At least according to some embodiments the clipping estimator 120 does not need the encoded audio signal representation itself for assessing a probability of clipping within the time-domain representation for the considered time interval or frame. The reason is that at least some perceptual audio encoding standards choose the scale factors for the frequency band signals of the plurality of frequency band signals according to the largest amplitude that has to be coded within a certain frequency band signal and the considered time interval. In other words, the highest value that can be represented by the chosen bit resolution for the frequency band signal at hand is very likely to occur at least once during the considered time interval or frame, given the properties of the encoding scheme. Using this assumption, the clipping estimator 120 may focus on evaluating the side information relative to the gain(s) of the frequency band signals (e.g., said scale factor and possibly further parameters) in order to determine the current level shift factor for the encoded audio signal representation and the considered time interval (frame).
The audio signal decoder 100 further comprises a level shifter 130 configured to shift levels of the frequency band signals according to the level shift factor for obtaining level shifted frequency band signals.
The audio signal decoder 100 further comprises a frequency-to-time-domain converter 140 configured to convert the level shifted frequency band signals into a time-domain representation. The frequency-to-time-domain converter 140 may be an inverse filter bank, an inverse modified discrete cosine transformation (inverse MDCT), an inverse quadrature mirror filter (inverse QMF), to name a few. For some audio coding standards the frequency-to-time-domain converter 140 may be configured to support windowing of consecutive frames, wherein two frames overlap for, e.g., 50% of their duration.
The time-domain representation provided by the frequency-to-time-domain converter 140 is provided to a level shift compensator 150 that is configured to act on the time-domain representation for at least partly compensating a level shift applied to the level shifted frequency band signals by the level shifter 130, and for obtaining a substantially compensated time-domain representation. The level shift compensator 150 further receives the level shift factor from the clipping estimator 140 or a signal derived from the level shift factor. The level shifter 130 and the level shift compensator 150 provide a gain adjustment of the level shifted frequency band signals and a compensating gain adjustment of the time domain presentation, respectively, wherein said gain adjustment bypasses the frequency-to-time-domain converter 140. In this manner, the level shifted frequency band signals and the time-domain representation can be adjusted to a dynamic range provided by the frequency-to-time-domain converter 140 which may be limited due to a fixed word length and/or a fixed-point arithmetic implementation of the converter 140. In particular, the relevant dynamic range of the level shifted frequency band signals and the corresponding time-domain representation may be at relatively high amplitude values or signal power levels during relatively loud frames. In contrast, the relevant dynamic range of the level shifted frequency band signal and consequently also of the corresponding time-domain representation may be at relatively small amplitude values or signal power values during relatively soft frames. In the case of loud frames, the information contained in the lower bits of a binary presentation of the level shifted frequency band signals may typically be regarded as negligible compared to the information that is contained within the higher bits. Typically, the level shift factor is common to all frequency band signals which makes it possible to compensate the level shift applied to the level shifted frequency band signals even downstream of the frequency-to-time-domain converter 140. In contrast to the proposed level shift factor which is determined by the audio signal decoder 100 itself, the so-called global gain parameter is contained within the bitstream that was produced by a remote audio signal encoder and provided to the audio signal decoder 100 as an input. Furthermore, the global gain is applied to the plurality of frequency band signals between the decoder preprocessing stage 110 and the frequency-to-time-domain converter 140. Typically, the global gain is applied to the plurality of frequency band signals at substantially the same place within the signal processing chain as the scale factors for the different frequency band signals. This means that for a relatively loud frame the frequency band signals provided to the frequency-to-time-domain converter 140 are already relatively loud, and may therefore cause clipping in the corresponding time-domain representation, because the plurality of frequency band signals did not provide sufficient headroom in case the different frequency band signals add up in a constructive manner, thereby leading to a relatively high signal amplitude within the time-domain representation.
The proposed approach that is for example implemented by the audio signal decoder 100 schematically illustrated in
To overcome the problem of restricted word length of filter-banks, the loudness normalization as source of potential clipping may be moved to the time domain processing. This allows the filter-bank 140 to be implemented with original word length or reduced word length compared to an implementation where the loudness normalization is performed within the frequency domain processing. To perform a smooth blending of gain values, a transition shape adjustment may be performed as will be explained below in the context of
Further, audio samples within the bitstream are usually quantized at lower precision than the reconstructed audio signal. This allows for some headroom in the filter-bank 140. The decoder 100 derives some estimate from other bit-stream parameter p (such as the global gain factor) and, for the case clipping of the output signal is likely, applies a level shift (g2) to avoid the clipping in the filter-bank 140. This level shift is signaled to the time domain for proper compensation by the level shift compensator 150. If no clipping is estimated, the audio signal remains unchanged and therefore the method has no loss in precision.
The clipping estimator may be further configured to determine a clipping probability on the basis of the side information and/or to determine the current level shift factor on the basis of the clipping probability. Even though the clipping probability only indicates a trend, rather than a hard fact, it may provide useful information regarding the level shift factor that may be reasonably applied to the plurality of frequency band signals for a given frame of the encoded audio signal representation. The determination of the clipping probability may be relatively simple in terms of computational complexity or effort and compared to the frequency-to-time-domain conversion performed by the frequency-to-time-domain converter 140.
The side information may comprise at least one of a global gain factor for the plurality of frequency band signals and a plurality of scale factors. Each scale factor may correspond to one or more frequency band signals of the plurality of frequency band signals. The global gain factor and/or the plurality of scale factors already provide useful information regarding a loudness level of the current frame that is to be converted to the time domain by the converter 140.
According to at least some embodiments the decoder preprocessing stage 110 may be configured to obtain the plurality of frequency band signals in the form of a plurality of successive frames. The clipping estimator 120 may be configured to determine the current level shift factor for a current frame. In other words, the audio signal decoder 100 may be configured to dynamically determine varying level shift factors for different frames of the encoded audio signal representation, for example depending on a varying degree of loudness within the successive frames.
The decoded audio signal representation may be determined on the basis of the substantially compensated time-domain representation. For example, the audio signal decoder 100 may further comprise a time domain limiter downstream of the level shift compensator 150. According to some embodiments, the level shift compensator 150 may be a part of such a time domain limiter.
According to further embodiments, the side information relative to the gain of the frequency band signals may comprise a plurality of frequency band-related gain factors.
The decoder preprocessing stage 110 may comprise an inverse quantizer configured to re-quantize each frequency band signal using a frequency band-specific quantization indicator of a plurality of frequency band-specific quantization indicators. In particular, the different frequency band signals may have been quantized using different quantization resolutions (or bit resolutions) by an audio signal encoder that has created the encoded audio signal presentation and the corresponding side information. The different frequency band-specific quantization indicators may therefore provide an information about an amplitude resolution for the various frequency band signals, depending on a necessitated amplitude resolution for that particular frequency band signal determined earlier by the audio signal encoder. The plurality of frequency band-specific quantization indicators may be part of the side information provided to the decoder preprocessing stage 110 and may provide further information to be used by at the clipping estimator 120 for determining the level shift factor.
The clipping estimator 120 may be further configured to analyze the side information with respect to whether the side information suggests a potential clipping within the time-domain representation. Such a finding would then be interpreted as a least significant bit (LSB) containing no relevant information. In this case the level shift applied by the level shifter 130 may shift information towards the least significant bit so that by freeing a most significant bit (LSB) some headroom at the most significant bit is gained, which may be needed for the time domain resolution in case two or more of the frequency band signals add up in a constructive manner. This concept may also be extended to the n least significant bits and the n most significant bits.
The clipping estimator 120 may be configured to consider a quantization noise. For example, in AAC decoding, both the “global gain” and the “scale factor bands” are used to normalize the audio/subband. As a consequence, the relevant information by each (spectral) value is shifted to the MSB, while the LSB are neglected in quantization. After re-quantization in the decoder, the LSB typically contained(s) noise, only. If the “global gain” and the “scale factor band” (p) values suggest a potential clipping after the reconstruction filter-bank 140, it can be reasonably assumed that the LSB contained no information. With the proposed method, the decoder 100 shifts the information also into these bits to gain some headroom with the MSB. This causes substantially no loss of information.
The proposed apparatus (audio signal decoder or encoder) and methods allow clipping prevention for audio decoders/encoders without spending a high resolution filter-bank for the necessitated headroom. This is typically much less expensive in terms of memory requirements and computational complexity than performing/implementing a filter-bank with higher resolution.
The clipping estimator 120 shown in
The audio signal decoder 100 further comprises the level shifter 230 that is connected to an output of the inverse quantizer 210. The level shifter 230 further receives the side information or a part of the side information, as well as the level shift factor that is determined by the clipping estimator 120 in a dynamic manner, i.e., for each time interval or frame, the level shift factor may assume a different value. The level shift factor is consistently applied to the plurality of frequency band signals using a plurality of multipliers or scaling elements 231, 232, and 233. It may occur that some of the frequency band signals are relatively strong when leaving the inverse quantizer 210, possibly using their respective MSBs already. When these strong frequency band signals add up within the frequency-to-time-domain converter 140, an overflow may be observed within the time-domain representation output by the frequency-to-time-domain converter 140. The level shift factor determined by the clipping estimator 120 and applied by the scaling elements 231, 232, 233 makes it possible to selectively (i.e., taking into account the current side information) reduce the levels of the frequency band signals so that an overflow of the time-domain representation is less likely to occur. The level shifter 230 further comprises a second plurality of multipliers or scaling elements 236, 237, 238 configured to apply the frequency band-specific scale factors to the corresponding frequency bands. The side information may comprise M scale factors. The level shifter 230 provides the plurality of level shifted frequency band signals to the frequency-to-time-domain converter 140 which is configured to convert the level shifted frequency band signals into the time-domain representation.
The audio signal decoder 100 of
Optionally, the audio signal decoder 100 in
The bitstream parameters p are provided to the clipping estimator 320 which derives the scaling factor 1/g2 from the bitstream parameters p. The scaling factor 1/g2 is fed to the level shifter 330 which in the depicted embodiment also implements a dynamic range control (DRC). The level shifter 330 may further receive the bitstream parameters p or a portion thereof in order to apply the scale factors to the plurality of frequency band signals. The level shifter 330 outputs the plurality of level shifted frequency band signals X2(f) to the inverse filter bank 340 which provides the frequency-to-time-domain conversion. At an output of the inverse filter bank 340, the time-domain representation X3(t) is provided to be supplied to the level shift compensator 350. The level shift compensator 350 is a multiplier or scaling element, as in the embodiment depicted in
The applied gain shift g2 is fed forward to the limiter implementation 360 for compensation. The limiter 362 may be implemented at high precision.
If the clipping estimator 320 does not estimate any clipping, the audio samples remain substantially unchanged, i.e. as if no level shift and level shift compensation would have been performed.
The clipping estimator provides the reciprocal g2 of the level shift factor 1/g2 to a combiner 328 where it is combined with the global gain g1 to yield a combined gain g3.
The audio signal decoder 100 further comprises a transition shape adjustment 370 that is configured to provide smooth transitions when the combined gain g3 changes abruptly from a preceding frame to a current frame (or from the current frame to a subsequent frame). The transition shape adjuster 370 may be configured to crossfade the current level shift factor and a subsequent level shift factor to obtain a crossfaded level shift factor g4 for use by the level shift compensator 350. To allow for smooth transition of changing gain factors, a transition shape adjustment has to be performed. This tool creates a vector of gain factors g4(t) (one factor for each sample of the corresponding audio signal). To mimic the same behavior of the gain adjustment that the processing of the frequency domain signal would yield, the same transition windows W from the filter-bank 340 have to be used. One frame covers a plurality of samples. The combined gain factor g3 is typically constant for the duration of one frame. The transition window W is typically one frame long and provides different window values for each sample within the frame (e.g., the first half-period of a cosine). Details regarding one possible implementation of the transition shape adjustment are provided in
A rectangle 406 in
According to the embodiment schematically illustrated in
Window shapes may be guided by side information w from the filter-bank 340, if necessitated.
The window shape and the previous window shape may also be used by the frequency-to-time-domain converter 340 so that the same window shape and previous window shape are used for converting the level shifted frequency band signals into the time-domain representation and for windowing the current level shift factor and the previous level shift factor.
The current level shift factor may be valid for a current frame of the plurality of frequency band signals. The previous level shift factor may be valid for a previous frame of the plurality of frequency band signals. The current frame and the previous frame may overlap, for example by 50%.
The transition shape adjustment 370 may be configured to combine the previous level shift factor with a second portion of the previous window shape resulting in a previous frame factor sequence. The transition shape adjustment 370 may be further configured to combine the current level shift factor with a first portion of the current window shape resulting in a current frame factor sequence. A sequence of the crossfaded level shift factor may be determined on the basis of the previous frame factor sequence and the current frame factor sequence.
The proposed approach is not necessarily restricted to decoders, but also encoders might have a gain adjustment or limiter in combination with a filter-bank which might benefit from the proposed method.
By this, the derived level value is not calculated from the actual spectral values but instead, an average level value is used that depends only on the employed codebook. As has been explained before, the encoder is generally adapted to select the codebook from a plurality of codebooks that fit best to encode the respective spectral data of a section of the audio signal. As the codebooks differ, for example with respect to their maximum absolute value that can be encoded, the average value that is encoded by a Huffman codebook differs from codebook to codebook and, therefore, also the average level value of an encoded spectral coefficient encoded by a particular codebook differs from codebook to codebook.
Thus, according to an embodiment, an average level value for encoding a spectral coefficient of an audio signal employing a particular Huffman codebook can be determined for each Huffman codebook and can, for example, be stored in a memory, a database or on a remote computer. The level value deriver then simply has to look-up or request the level value associated with the identified codebook that has been employed for encoding the spectral data, to obtain the derived level value associated with the identified codebook.
However, it has to be taken into consideration that Huffman codebooks are often employed to encode unscaled spectral values, as it is the case for MPEG AAC. Then, however, scaling should be taken into account when a level estimate is conducted. Therefore, the estimation unit of
In an embodiment, where the derived level value is a derived energy value, the scaling unit is adapted to apply the derived scalefactor on the derived energy value to obtain a scaled level value by multiplying derived energy value by the square of the derived scalefactor.
In another embodiment, where the derived level value is a derived amplitude value, and the scaling unit is adapted to apply the derived scalefactor on the derived amplitude value to obtain a scaled level value by multiplying derived amplitude value by the derived scalefactor.
In a further embodiment, wherein the derived level value is a derived loudness value, and the scaling unit 1220 is adapted to apply the derived scalefactor on the derived loudness value to obtain a scaled level value by multiplying derived loudness value by the cube of the derived scalefactor. There exist alternative ways to calculate the loudness such as by an exponent 3/2. Generally, the scalefactors have to be transformed to the loudness domain, when the derived level value is a loudness value.
These embodiments take into account, that an energy value is determined based on the square of the spectral coefficients of an audio signal, that an amplitude value is determined based on the absolute values of the spectral coefficients of an audio signal, and that a loudness value is determined based on the spectral coefficients of an audio signal that have been transformed to the loudness domain.
The estimation unit is adapted to estimate a level estimate of the audio signal using the scaled level value. In the embodiment of
In contrast to the presented embodiments, a state-of-the-art approach for estimating e.g. the energy of one scalefactor band would be to do the Huffman decoding and inverse quantization for all spectral values and compute the energy by summing up the square of all inversely quantized spectral values.
In the proposed embodiments, however, this computationally complex process of the state-of-the-art is replaced by an estimate of the average level which only depends on the scalefactor and the codebook uses and not on the actual quantized values.
Embodiments of the present invention employ the fact that a Huffman codebook is designed to provide optimal coding following a dedicated statistic. This means the codebook has been designed according to the probability of the data, e.g., AAC-ELD (AAC-ELD=Advanced Audio Coding-Enhanced Low Delay): spectral lines. This process can be inverted to get the probability of the data according to the codebook. The probability of each data entry inside a codebook (index) is given by the length of the codeword. For example,
p(index)=2̂−length(codeword)
i.e.
p(index)=2−length(codeword)
wherein p(index) is the probability of a data entry (an index) inside a codebook.
Based on this, the expected level can be pre-computed and stored in the following way: each index represents a sequence of integer values (x), e.g., spectral lines, where the length of the sequence depends on the dimension of the codebook, e.g., 2 or 4 for AAC-ELD.
Determining a sequence of number values associated with a codeword of the codebook for each codeword of the codebook (step 1310). As has been explained before, a codebook encodes a sequence of number values, for example, 2 or 4 number values by a codeword of the codebook. The codebook comprises a plurality of codebooks to encode a plurality of sequences of number values. The sequence of number values, that is determined, is the sequence of number values that is encoded by the considered codeword of the codebook. The step 1310 is conducted for each codeword of the codebook. For example, if the codebook comprises 81 codewords, 81 sequences of number values are determined in step 1310.
In step 1320, an inverse-quantized sequence of number values is determined for each codeword of the codebook by applying an inverse quantizer to the number values of the sequence of number values of a codeword for each codeword of the codebook. As has been explained before, an encoder may generally employ quantization when encoding the spectral values of the audio signal, for example non-uniform quantization. As a consequence, this quantization has to be inverted on a decoder side.
Afterwards, in step 1330, a sequence of level values is determined for each codeword of the codebook.
If an energy value is to be generated as the codebook level value, then a sequence of energy values is determined for each codeword, and the square of each value of the inverse-quantized sequence of number values is calculated for each codeword of the codebook.
If, however, an amplitude value is to be generated as the codebook level value, then a sequence of amplitude values is determined for each codeword, and the absolute value of each value of the inverse-quantized sequence of number values is calculated for each codeword of the codebook.
If, though, a loudness value is to be generated as the codebook level value, then a sequence of loudness values is determined for each codeword, and the cube of each value of the inverse-quantized sequence of number values is calculated for each codeword of the codebook. There exist alternative ways to calculate the loudness such as by an exponent 3/2. Generally, the values of the inverse-quantized sequence of number values have to be transformed to the loudness domain, when a loudness value is to be generated as the codebook level value.
Subsequently, in step 1340, a level sum value for each codeword of the codebook is calculated by summing the values of the sequence of level values for each codeword of the codebook.
Then, in step 1350, a probability-weighted level sum value is determined for each codeword of the codebook by multiplying the level sum value of a codeword by a probability value associated with the codeword for each codeword of the codebook. By this, it is taken into account that some of the sequence of number values, e.g., sequences of spectral coefficients, will not appear as often as other sequences of spectral coefficients. The probability value associated with the codeword takes this into account. Such a probability value may be derived from the length of the codeword, as codewords that are more likely to appear are encoded by using codewords having a shorter length, while other codewords that are more unlikely to appear will be encoded by using codewords having a longer length, when Huffman-encoding is employed.
In step 1360, an averaged probability-weighted level sum value for each codeword of the codebook will be determined by dividing the probability-weighted level sum value of a codeword by a dimension value associated with the codebook for each codeword of the codebook. A dimension value indicates the number of spectral values that are encoded by a codeword of the codebook. By this, an averaged probability-weighted level sum value is determined that represents a level value (probability-weighted) for a spectral coefficient that is encoded by the codeword.
Then, in step 1370, the level value of the codebook is calculated by summing the averaged probability-weighted level sum values of all codewords.
It has to be noted, that such a generation of a level value does only have to be done once for a codebook. If the level value of a codebook is determined, this value can simply be looked-up and used, for example by an apparatus for level estimation according to the embodiments described above.
In the following, a method for generating an energy value associated with a codebook according to an embodiment is presented. In order to estimate the expected value of the energy of the data coded with the given codebook, the following steps have to be performed only once for each index of the codebook:
A) apply the inverse quantizer to the integer values of the sequence (e.g. AAC-ELD: x̂(4/3))
B) calculate energy by squaring each value of the sequence of A)
C) build the sum of the sequence of B)
D) multiply C) with the given probability of the index
E) divide by the dimension of the codebook to get the expected energy per spectral line.
Finally, all values calculated by E) have to be summed-up to get the expected energy of the complete codebook.
After the output of these steps is stored in a table, the estimated energy values can be simply looked-up based on the codebook index, i.e., depending on which codebook is used. The actual spectral values do not have to be Hoffman-decoded for this estimation.
To estimate the overall energy of the spectral data of a complete audio frame, the scalefactor has to be taken into account. The scalefactor can be extracted from the bit stream without a significant amount of complexity. The scalefactor may be modified before being applied on the expected energy, e.g. the square of the used scalefactor may be calculated. The expected energy is then multiplied with the square of the used scalefactor.
According to the above-described embodiments, the spectral level for each scalefactor band can be estimated without decoding the Huffman coded spectral values. The estimates of the level can be used to identify streams with a low level, e.g. with low power, which typically do not result in clipping. Therefore, the full decoding of such streams can be avoided.
According to an embodiment, an apparatus for level estimation further comprises a memory or a database having stored therein a plurality of codebook level memory values indicating a level value being associated with a codebook, wherein each one of the plurality of codebooks has a codebook level memory value associated with it stored in the memory or database. Furthermore, the level value deriver is configured for deriving the level value associated with the identified codebook by deriving a codebook level memory value associated with the identified codebook from the memory or from the database.
The level estimated according to the above-described embodiments can vary if a further processing step as prediction, such as prediction filtering, are applied in the codec, e.g., for AAC-ELD TNS (Temporal Noise Shaping) filtering. Here, the coefficients of the prediction are transmitted inside the bit stream, e.g., for TNS as PARCOR coefficients.
In an embodiment, the PARCOR coefficients for TNS are used as prediction filter coefficients. The prediction gain of the filtering process can be determined from those coefficients in a very efficient way. Regarding TNS, the prediction gain can be calculated according to the formula: gain=1/prod(1−parcor.̂2).
For example, if 3 PARCOR coefficients, e.g., parcor1, parcor2 and parcor3 have to be taken into consideration, the gain is calculated according to the formula:
For n PARCOR coefficients parcor1, parcor2, . . . parcorn, the following formula applies:
This means that the amplification of the audio signal through the filtering can be estimated without applying the filtering operation itself.
The audio signal encoder comprises a clipping estimator 1520 configured to analyze the time-domain representation of the input audio signal in order to determine a current level shift factor for the input signal representation. The audio signal encoder further comprises a level shifter 1530 configured to shift a level of the time-domain representation of the input audio signal according to the level shift factor for obtaining a level shifted time-domain representation. A time-to-frequency domain converter 1540 (e.g., a filter-bank, such as a bank of quadrature mirror filters, a modified discrete cosine transform, etc.) is configured to convert the level shifted time-domain representation into a plurality of frequency band signals. The audio signal encoder 1500 also comprises a level shift compensator 1550 configured to act on the plurality of frequency band signals for at least partly compensating a level shift applied to the level shifted time-domain representation by the level shifter 1530 and for obtaining a plurality of substantially compensated frequency band signals.
The audio signal encoder 1500 may further comprise a bit/noise allocation, quantizer, and coding component 1510 and a psychoacoustic model 1508. The psychoacoustic model 1508 determines time-frequency-variable masking thresholds on (and/or frequency-band-individual and frame-individual quantization resolutions, and scale factors) the basis of the PCM input audio signal, to be used by the bit/noise allocation, quantizer, and coding 1610. Details regarding one possible implementation of the psychoacoustic model and other aspects of perceptual audio encoding can be found, for example, in the International Standards ISO/IEC 11172-3 and ISO/IEC 13818-3. The bit/noise allocation, quantizer, and coding 1510 is configured to quantize the plurality of frequency band signals according to their frequency-band-individual and frame-individual quantization resolutions, and to provide these data to a bitstream formatter 1505 which outputs an encoded bitstream to be provided to one or more audio signal decoders. The bit/noise allocation, quantizer, and coding 1510 may be configured to determine side information in addition the plurality quantized frequency signals. This side information may also be provided to the bitstream formatter 1505 for inclusion in the bitstream.
In a step 1604 of the method for decoding, side information relative to a gain of the frequency band signals is analyzed in order to determine a current level shift factor for the encoded audio signal representation. The gain relative to the frequency band signals may be individual for each frequency band signal (e.g., the scale factors known in some perceptual audio coding schemes or similar parameters) or common to all frequency band signal (e.g., the global gain known in some perceptual audio encoding schemes). The analysis of the side information allows gathering information about a loudness of the encoded audio signal during the frame at hand. The loudness, in turn, may indicate a tendency of the decoded audio signal representation to go into clipping. The level shift factor is typically determined as a value that prevents such clipping while preserving a relevant dynamic range and/or relevant information content of (all) the frequency band signals.
The method for decoding further comprises a step 1606 of shifting levels of the frequency band signal according to the level shift factor. In case the frequency band signals are level shifted to a lower level, the level shift creates some additional headroom at the most significant bit(s) of a binary representation of the frequency band signals. This additional headroom may be needed when converting the plurality of frequency band signals from the frequency domain to the time domain to obtain a time domain representation, which is done in a subsequent step 1608. In particular, the additional headroom reduces the risk of the time domain representation to clip if some of the frequency band signals are close to an upper limit regarding their amplitude and/or power. As a consequence, the frequency-to-time-domain conversion may be performed using a relatively small word length.
The method for decoding also comprises a step 1609 of acting on the time domain representation for at least partly compensating a level shift applied to the level shifted frequency band signals. Subsequently, a substantially compensated time representation is obtained.
Accordingly, a method for decoding an encoded audio signal representation to a decoded audio signal representation comprises:
According to further aspects, analyzing the side information may comprise: determining a clipping probability on the basis of the side information and to determine the current level shift factor on the basis of the clipping probability.
According to further aspects, the side information may comprise at least one of a global gain factor for the plurality of frequency band signals and a plurality of scale factors, each scale factor corresponding to one frequency band signal of the plurality of frequency band signals.
According to further aspects, preprocessing the encoded audio signal representation may comprise obtaining the plurality of frequency band signals in the form of a plurality of successive frames, and analyzing the side information may comprise determining the current level shift factor for a current frame.
According to further aspects, the decoded audio signal representation may be determined on the basis of the substantially compensated time-domain representation.
According to further aspects, the method may further comprise: applying a time domain limiter characteristic subsequent to acting on the time-domain representation for at least partly compensating the level shift.
According to further aspects, the side information relative to the gain of the frequency band signals may comprise a plurality of frequency band-related gain factors.
According to further aspects, preprocessing the encoded audio signal may comprise re-quantizing each frequency band signal using a frequency band-specific quantization indicator of a plurality of frequency band-specific quantization indicators.
According to further aspects, the method may further comprise performing a transition shape adjustment, the transition shape adjustment comprising: crossfading the current level shift factor and a subsequent level shift factor to obtain a crossfaded level shift factor for use during the action of at least partly compensating the level shift.
According to further aspects, the transition shape adjustment may further comprise:
According to further aspects, the window shape and the previous window shape may also be used by the frequency-to-time-domain conversion so that the same window shape and previous window shape are used for converting the level shifted frequency band signals into the time-domain representation and for windowing the current level shift factor and the previous level shift factor.
According to further aspects, the current level shift factor may be valid for a current frame of the plurality of frequency band signals, wherein the previous level shift factor may be valid for a previous frame of the plurality of frequency band signals, and wherein the current frame and the previous frame may overlap. The transition shape adjustment may be configured
According to further aspects, analyzing the side information may be performed with respect to whether the side information suggests a potential clipping within the time-domain representation which means that a least significant bit contains no relevant information, and wherein in this case the level shift shifts information towards the least significant bit so that by freeing a most significant bit some headroom at the most significant bit is gained.
According to further aspects, a computer program for implementing the method for decoding or the method for encoding may be provided, when the computer program is being executed on a computer or signal processor.
Although some aspects have been described in the context of an apparatus, it is clear that these aspects also represent a description of the corresponding method, where a block or device corresponds to a method step or a feature of a method step. Analogously, aspects described in the context of a method step also represent a description of a corresponding block or item or feature of a corresponding apparatus.
The inventive decomposed signal can be stored on a digital storage medium or can be transmitted on a transmission medium such as a wireless transmission medium or a wired transmission medium such as the Internet.
Depending on certain implementation requirements, embodiments of the invention can be implemented in hardware or in software. The implementation can be performed using a digital storage medium, for example a floppy disk, a DVD, a CD, a ROM, a PROM, an EPROM, an EEPROM or a FLASH memory, having electronically readable control signals stored thereon, which cooperate (or are capable of cooperating) with a programmable computer system such that the respective method is performed.
Some embodiments according to the invention comprise a non-transitory data carrier having electronically readable control signals, which are capable of cooperating with a programmable computer system, such that one of the methods described herein is performed.
Generally, embodiments of the present invention can be implemented as a computer program product with a program code, the program code being operative for performing one of the methods when the computer program product runs on a computer. The program code may for example be stored on a machine readable carrier.
Other embodiments comprise the computer program for performing one of the methods described herein, stored on a machine readable carrier.
In other words, an embodiment of the inventive method is, therefore, a computer program having a program code for performing one of the methods described herein, when the computer program runs on a computer.
A further embodiment of the inventive methods is, therefore, a data carrier (or a digital storage medium, or a computer-readable medium) comprising, recorded thereon, the computer program for performing one of the methods described herein.
A further embodiment of the inventive method is, therefore, a data stream or a sequence of signals representing the computer program for performing one of the methods described herein. The data stream or the sequence of signals may for example be configured to be transferred via a data communication connection, for example via the Internet.
A further embodiment comprises a processing means, for example a computer, or a programmable logic device, configured to or adapted to perform one of the methods described herein.
A further embodiment comprises a computer having installed thereon the computer program for performing one of the methods described herein.
In some embodiments, a programmable logic device (for example a field programmable gate array) may be used to perform some or all of the functionalities of the methods described herein. In some embodiments, a field programmable gate array may cooperate with a microprocessor in order to perform one of the methods described herein. Generally, the methods may be performed by any hardware apparatus.
While this invention has been described in terms of several embodiments, there are alterations, permutations, and equivalents which will be apparent to others skilled in the art and which fall within the scope of this invention. It should also be noted that there are many alternative ways of implementing the methods and compositions of the present invention. It is therefore intended that the following appended claims be interpreted as including all such alterations, permutations, and equivalents as fall within the true spirit and scope of the present invention.
Number | Date | Country | Kind |
---|---|---|---|
EP13151910.0 | Jan 2013 | EP | regional |
This application is a continuation of co-pending International Application No. PCT/EP2014/050171, filed Jan. 7, 2014, which is incorporated herein by reference in its entirety, and additionally claims priority from European Application No. 13151910.0, filed Jan. 18, 2013, which is also incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/EP2014/050171 | Jan 2014 | US |
Child | 14795063 | US |