The invention pertains to audio signal processing. Some embodiments pertain to encoding and decoding of audio bitstreams (e.g., bitstreams having an MPEG-4 AAC format) including metadata for controlling enhanced spectral band replication (eSBR). Other embodiments pertain to decoding of such bitstreams by legacy decoders which are not configured to perform eSBR processing and which ignore such metadata, or to decoding of an audio bitstream which does not include such metadata including by generating eSBR control data in response to the bitstream.
A typical audio bitstream includes both audio data (e.g., encoded audio data) indicative of one or more channels of audio content, and metadata indicative of at least one characteristic of the audio data or audio content. One well known format for generating an encoded audio bitstream is the MPEG-4 Advanced Audio Coding (AAC) format, described in the MPEG standard ISO/IEC 14496-3:2009. In the MPEG-4 standard, AAC denotes “advanced audio coding” and HE-AAC denotes “high-efficiency advanced audio coding.”
The MPEG-4 AAC standard defines several audio profiles, which determine which objects and coding tools are present in a complaint encoder or decoder. Three of these audio profiles are (1) the AAC profile, (2) the HE-AAC profile, and (3) the HE-AAC v2 profile. The AAC profile includes the AAC low complexity (or “AAC-LC”) object type. The AAC-LC object is the counterpart to the MPEG-2 AAC low complexity profile, with some adjustments, and includes neither the spectral band replication (“SBR”) object type nor the parametric stereo (“PS”) object type. The HE-AAC profile is a superset of the AAC profile and additionally includes the SBR object type. The HE-AAC v2 profile is a superset of the HE-AAC profile and additionally includes the PS object type.
The SBR object type contains the spectral band replication tool, which is an important coding tool that significantly improves the compression efficiency of perceptual audio codecs. SBR reconstructs the high frequency components of an audio signal on the receiver side (e.g., in the decoder). Thus, the encoder needs to only encode and transmit low frequency components, allowing for a much higher audio quality at low data rates. SBR is based on replication of the sequences of harmonics, previously truncated in order to reduce data rate, from the available bandwidth limited signal and control data obtained from the encoder. The ratio between tonal and noise-like components is maintained by adaptive inverse filtering as well as the optional addition of noise and sinusoidals. In the MPEG-4 AAC standard, the SBR tool performs spectral patching, in which a number of adjoining Quadrature Mirror Filter (QMF) subbands are copied from a transmitted lowband portion of an audio signal to a highband portion of the audio signal, which is generated in the decoder.
Spectral patching may not be ideal for certain audio types, such as musical content with relatively low cross over frequencies. Therefore, techniques for improving spectral band replication are needed.
A first class of embodiments relates to audio processing units that include a memory, bitstream payload deformatter, and decoding subsystem. The memory is configured to store at least one block of an encoded audio bitstream (e.g., an MPEG-4 AAC bitstream). The bitstream payload deformatter is configured to demultiplex the encoded audio block. The decoding subsystem is configured to decode audio content of the encoded audio block. The encoded audio block includes a fill element with an identifier indicating the start of the fill element, and fill data after the identifier. The fill data includes at least one flag identifying whether enhanced spectral band replication (eSBR) processing is to be performed on audio content of the encoded audio block.
A second class of embodiments relates to methods for decoding an encoded audio bitstream. The method includes receiving at least one block of an encoded audio bitstream, demultiplexing at least some portions of the at least one block of the encoded audio bitstream, and decoding at least some portions of the at least one block of the encoded audio bitstream. The at least one block of the encoded audio bitstream includes a fill element with an identifier indicating a start of the fill element and fill data after the identifier. The fill data includes at least one flag identifying whether enhanced spectral band replication (eSBR) processing is to be performed on audio content of the at least one block of the encoded audio bitstream.
Other classes of embodiments relate to encoding and transcoding audio bitstreams containing metadata identifying whether enhanced spectral band replication (eSBR) processing is to be performed.
Throughout this disclosure, including in the claims, the expression performing an operation “on” a signal or data (e.g., filtering, scaling, transforming, or applying gain to, the signal or data) is used in a broad sense to denote performing the operation directly on the signal or data, or on a processed version of the signal or data (e.g., on a version of the signal that has undergone preliminary filtering or pre-processing prior to performance of the operation thereon).
Throughout this disclosure, including in the claims, the expression “audio processing unit” is used in a broad sense, to denote a system, device, or apparatus, configured to process audio data. Examples of audio processing units include, but are not limited to encoders (e.g., transcoders), decoders, codecs, pre-processing systems, post-processing systems, and bitstream processing systems (sometimes referred to as bitstream processing tools). Virtually all consumer electronics, such as mobile phones, televisions, laptops, and tablet computers, contain an audio processing unit.
Throughout this disclosure, including in the claims, the term “couples” or “coupled” is used in a broad sense to mean either a direct or indirect connection. Thus, if a first device couples to a second device, that connection may be through a direct connection, or through an indirect connection via other devices and connections. Moreover, components that are integrated into or with other components are also coupled to each other.
The MPEG-4 AAC standard contemplates that an encoded MPEG-4 AAC bitstream includes metadata indicative of each type of SBR processing to be applied (if any is to be applied) by a decoder to decode audio content of the bitstream, and/or which controls such SBR processing, and/or is indicative of at least one characteristic or parameter of at least one SBR tool to be employed to decode audio content of the bitstream. Herein, we use the expression “SBR metadata” to denote metadata of this type which is described or mentioned in the MPEG-4 AAC standard.
The top level of an MPEG-4 AAC bitstream is a sequence of data blocks (“raw_data_block” elements), each of which is a segment of data (herein referred to as a “block”) that contains audio data (typically for a time period of 1024 or 960 samples) and related information and/or other data. Herein, we use the term “block” to denote a segment of an MPEG-4 AAC bitstream comprising audio data (and corresponding metadata and optionally also other related data) which determines or is indicative of one (but not more than one) “raw_data_block” element.
Each block of an MPEG-4 AAC bitstream can include a number of syntactic elements (each of which is also materialized in the bitstream as a segment of data). Seven types of such syntactic elements are defined in the MPEG-4 AAC standard. Each syntactic element is identified by a different value of the data element “id_syn_ele.” Examples of syntactic elements include a “single_channel_element( )” a “channel_pair_element( )” and a “fill_element( )” A single channel element is a container including audio data of a single audio channel (a monophonic audio signal). A channel pair element includes audio data of two audio channels (that is, a stereo audio signal).
A fill element is a container of information including an identifier (e.g., the value of the above-noted element “id_syn_ele”) followed by data, which is referred to as “fill data.” Fill elements have historically been used to adjust the instantaneous bit rate of bitstreams that are to be transmitted over a constant rate channel. By adding the appropriate amount of fill data to each block, a constant data rate may be achieved.
In accordance with embodiments on the invention, the fill data may include one or more extension payloads that extend the type of data (e.g., metadata) capable of being transmitted in a bitstream. A decoder that receives bitstreams with fill data containing a new type of data may optionally be used by a device receiving the bitstream (e.g., a decoder) to extend the functionality of the device. Thus, as can be appreciated by one skilled in the art, fill elements are a special type of data structure and are different from the data structures typically used to transmit audio data (e.g., audio payloads containing channel data).
In some embodiments of the invention, the identifier used to identify a fill element may consist of a three bit unsigned integer transmitted most significant bit first (“uimsbf”) having a value of 0x6. In one block, several instances of the same type of syntactic element (e.g., several fill elements) may occur.
Another standard for encoding audio bitstreams is the MPEG Unified Speech and Audio Coding (USAC) standard (ISO/IEC 23003-3:2012). The MPEG USAC standard describes encoding and decoding of audio content using spectral band replication processing (including SBR processing as described in the MPEG-4 AAC standard, and also including other enhanced forms of spectral band replication processing). This processing applies spectral band replication tools (sometimes referred to herein as “enhanced SBR tools” or “eSBR tools”) of an expanded and enhanced version of the set of SBR tools described in the MPEG-4 AAC standard. Thus, eSBR (as defined in USAC standard) is an improvement to SBR (as defined in MPEG-4 AAC standard).
Herein, we use the expression “enhanced SBR processing” (or “eSBR processing”) to denote spectral band replication processing using at least one eSBR tool (e.g., at least one eSBR tool which is described or mentioned in the MPEG USAC standard) which is not described or mentioned in the MPEG-4 AAC standard. Examples of such eSBR tools are harmonic transposition, QMF-patching additional pre-processing or “pre-flattening,” and inter-subband sample Temporal Envelope Shaping or “inter-TES.”
A bitstream generated in accordance with the MPEG USAC standard (sometimes referred to herein as a “USAC bitstream”) includes encoded audio content and typically includes metadata indicative of each type of spectral band replication processing to be applied by a decoder to decode audio content of the USAC bitstream, and/or metadata which controls such spectral band replication processing and/or is indicative of at least one characteristic or parameter of at least one SBR tool and/or eSBR tool to be employed to decode audio content of the USAC bitstream.
Herein, we use the expression “enhanced SBR metadata” (or “eSBR metadata”) to denote metadata indicative of each type of spectral band replication processing to be applied by a decoder to decode audio content of an encoded audio bitstream (e.g., a USAC bitstream) and/or which controls such spectral band replication processing, and/or is indicative of at least one characteristic or parameter of at least one SBR tool and/or eSBR tool to be employed to decode such audio content, but which is not described or mentioned in the MPEG-4 AAC standard. An example of eSBR metadata is the metadata (indicative of, or for controlling, spectral band replication processing) which is described or mentioned in the MPEG USAC standard but not in the MPEG-4 AAC standard. Thus, eSBR metadata herein denotes metadata which is not SBR metadata, and SBR metadata herein denotes metadata which is not eSBR metadata.
A USAC bitstream may include both SBR metadata and eSBR metadata. More specifically, a USAC bitstream may include eSBR metadata which controls the performance of eSBR processing by a decoder, and SBR metadata which controls the performance of SBR processing by the decoder. In accordance with typical embodiments of the present invention, eSBR metadata (e.g., eSBR-specific configuration data) is included (in accordance with the present invention) in an MPEG-4 AAC bitstream (e.g., in the sbr_extension( ) container at the end of an SBR payload).
Performance of eSBR processing, during decoding of an encoded bitstream using an eSBR tool set (comprising at least one eSBR tool), by a decoder regenerates the high frequency band of the audio signal, based on replication of sequences of harmonics which were truncated during encoding. Such eSBR processing typically adjusts the spectral envelope of the generated high frequency band and applies inverse filtering, and adds noise and sinusoidal components in order to recreate the spectral characteristics of the original audio signal.
In accordance with typical embodiments of the invention, eSBR metadata is included (e.g., a small number of control bits which are eSBR metadata are included) in one or more of metadata segments of an encoded audio bitstream (e.g., an MPEG-4 AAC bitstream) which also includes encoded audio data in other segments (audio data segments). Typically, at least one such metadata segment of each block of the bitstream is (or includes) a fill element (including an identifier indicating the start of the fill element), and the eSBR metadata is included in the fill element after the identifier.
In some implementations, encoder 1 (which optionally includes a pre-processing unit) is configured to accept PCM (time-domain) samples comprising audio content as input, and to output an encoded audio bitstream (having format which is compliant with the MPEG-4 AAC standard) which is indicative of the audio content. The data of the bitstream that are indicative of the audio content are sometimes referred to herein as “audio data” or “encoded audio data.” If the encoder is configured in accordance with a typical embodiment of the present invention, the audio bitstream output from the encoder includes eSBR metadata (and typically also other metadata) as well as audio data.
One or more encoded audio bitstreams output from encoder 1 may be asserted to encoded audio delivery subsystem 2. Subsystem 2 is configured to store and/or deliver each encoded bitstream output from encoder 1. An encoded audio bitstream output from encoder 1 may be stored by subsystem 2 (e.g., in the form of a DVD or Blu ray disc), or transmitted by subsystem 2 (which may implement a transmission link or network), or may be both stored and transmitted by subsystem 2.
Decoder 3 is configured to decode an encoded MPEG-4 AAC audio bitstream (generated by encoder 1) which it receives via subsystem 2. In some embodiments, decoder 3 is configured to extract eSBR metadata from each block of the bitstream, and to decode the bitstream (including by performing eSBR processing using the extracted eSBR metadata) to generate decoded audio data (e.g., streams of decoded PCM audio samples). In some embodiments, decoder 3 is configured to extract SBR metadata from the bitstream (but to ignore eSBR metadata included in the bitstream), and to decode the bitstream (including by performing SBR processing using the extracted SBR metadata) to generate decoded audio data (e.g., streams of decoded PCM audio samples). Typically, decoder 3 includes a buffer which stores (e.g., in a non-transitory manner) segments of the encoded audio bitstream received from subsystem 2.
Post-processing unit 4 of
Metadata generator 106 is coupled and configured to generate (and/or pass through to stage 107) metadata (including eSBR metadata and SBR metadata) to be included by stage 107 in the encoded bitstream to be output from encoder 100.
Encoder 105 is coupled and configured to encode (e.g., by performing compression thereon) the input audio data, and to assert the resulting encoded audio to stage 107 for inclusion in the encoded bitstream to be output from stage 107.
Stage 107 is configured to multiplex the encoded audio from encoder 105 and the metadata (including eSBR metadata and SBR metadata) from generator 106 to generate the encoded bitstream to be output from stage 107, preferably so that the encoded bitstream has format as specified by one of the embodiments of the present invention.
Buffer memory 109 is configured to store (e.g., in a non-transitory manner) at least one block of the encoded audio bitstream output from stage 107, and a sequence of the blocks of the encoded audio bitstream is then asserted from buffer memory 109 as output from encoder 100 to a delivery system.
Buffer memory (buffer) 201 stores (e.g., in a non-transitory manner) at least one block of an encoded MPEG-4 AAC audio bitstream received by decoder 200. In operation of decoder 200, a sequence of the blocks of the bitstream is asserted from buffer 201 to deformatter 205.
In variations on the
With reference again to
The system of
Audio decoding subsystem 202 of decoder 200 is configured to decode the audio data extracted by parser 205 (such decoding may be referred to as a “core” decoding operation) to generate decoded audio data, and to assert the decoded audio data to eSBR processing stage 203. The decoding is performed in the frequency domain and typically includes inverse quantization followed by spectral processing. Typically, a final stage of processing in subsystem 202 applies a frequency domain-to-time domain transform to the decoded frequency domain audio data, so that the output of subsystem is time domain, decoded audio data. Stage 203 is configured to apply SBR tools and eSBR tools indicated by the SBR metadata and the eSBR metadata (extracted by parser 205) to the decoded audio data (i.e., to perform SBR and eSBR processing on the output of decoding subsystem 202 using the SBR and eSBR metadata) to generate the fully decoded audio data which is output (e.g., to post-processor 300) from decoder 200. Typically, decoder 200 includes a memory (accessible by subsystem 202 and stage 203) which stores the deformatted audio data and metadata output from deformatter 205, and stage 203 is configured to access the audio data and metadata (including SBR metadata and eSBR metadata) as needed during SBR and eSBR processing. The SBR processing and eSBR processing in stage 203 may be considered to be post-processing on the output of core decoding subsystem 202. Optionally, decoder 200 also includes a final upmixing subsystem (which may apply parametric stereo (“PS”) tools defined in the MPEG-4 AAC standard, using PS metadata extracted by deformatter 205 and/or control bits generated in subsystem 204) which is coupled and configured to perform upmixing on the output of stage 203 to generate fully decoded, upmixed audio which is output from decoder 200. Alternatively, post-processor 300 is configured to perform upmixing on the output of decoder 200 (e.g., using PS metadata extracted by deformatter 205 and/or control bits generated in subsystem 204).
In response to metadata extracted by deformatter 205, control bit generator 204 may generate control data, and the control data may be used within decoder 200 (e.g., in a final upmixing subsystem) and/or asserted as output of decoder 200 (e.g., to post-processor 300 for use in post-processing). In response to metadata extracted from the input bitstream (and optionally also in response to control data), stage 204 may generate (and assert to post-processor 300) control bits indicating that decoded audio data output from eSBR processing stage 203 should undergo a specific type of post-processing. In some implementations, decoder 200 is configured to assert metadata extracted by deformatter 205 from the input bitstream to post-processor 300, and post-processor 300 is configured to perform post-processing on the decoded audio data output from decoder 200 using the metadata.
Elements 201 and 202 of APU 210 are identical to the identically numbered elements of decoder 200 (of
Deformatter 215 is coupled and configured to demultiplex each block of the bitstream to extract SBR metadata (including quantized envelope data) and typically also other metadata therefrom, but to ignore eSBR metadata that may be included in the bitstream in accordance with any embodiment of the present invention. Deformatter 215 is configured to assert at least the SBR metadata to SBR processing stage 213. Deformatter 215 is also coupled and configured to extract audio data from each block of the bitstream, and to assert the extracted audio data to decoding subsystem (decoding stage) 202.
Audio decoding subsystem 202 of decoder 200 is configured to decode the audio data extracted by deformatter 215 (such decoding may be referred to as a “core” decoding operation) to generate decoded audio data, and to assert the decoded audio data to SBR processing stage 213. The decoding is performed in the frequency domain. Typically, a final stage of processing in subsystem 202 applies a frequency domain-to-time domain transform to the decoded frequency domain audio data, so that the output of subsystem is time domain, decoded audio data. Stage 213 is configured to apply SBR tools (but not eSBR tools) indicated by the SBR metadata (extracted by deformatter 215) to the decoded audio data (i.e., to perform SBR processing on the output of decoding subsystem 202 using the SBR metadata) to generate the fully decoded audio data which is output (e.g., to post-processor 300) from APU 210. Typically, APU 210 includes a memory (accessible by subsystem 202 and stage 213) which stores the deformatted audio data and metadata output from deformatter 215, and stage 213 is configured to access the audio data and metadata (including SBR metadata) as needed during SBR processing. The SBR processing in stage 213 may be considered to be post-processing on the output of core decoding subsystem 202. Optionally, APU 210 also includes a final upmixing subsystem (which may apply parametric stereo (“PS”) tools defined in the MPEG-4 AAC standard, using PS metadata extracted by deformatter 215) which is coupled and configured to perform upmixing on the output of stage 213 to generate fully decoded, upmixed audio which is output from APU 210. Alternatively, a post-processor is configured to perform upmixing on the output of APU 210 (e.g., using PS metadata extracted by deformatter 215 and/or control bits generated in APU 210).
Various implementations of encoder 100, decoder 200, and APU 210 are configured to perform different embodiments of the inventive method.
In accordance with some embodiments, eSBR metadata is included (e.g., a small number of control bits which are eSBR metadata are included) in an encoded audio bitstream (e.g., an MPEG-4 AAC bitstream), such that legacy decoders (which are not configured to parse the eSBR metadata, or to use any eSBR tool to which the eSBR metadata pertains) can ignore the eSBR metadata but nevertheless decode the bitstream to the extent possible without use of the eSBR metadata or any eSBR tool to which the eSBR metadata pertains, typically without any significant penalty in decoded audio quality. However, eSBR decoders configured to parse the bitstream to identify the eSBR metadata and to use at least one eSBR tool in response to the eSBR metadata, will enjoy the benefits of using at least one such eSBR tool. Therefore, embodiments of the invention provide a means for efficiently transmitting enhanced spectral band replication (eSBR) control data or metadata in a backward-compatible fashion.
Typically, the eSBR metadata in the bitstream is indicative of (e.g., is indicative of at least one characteristic or parameter of) one or more of the following eSBR tools (which are described in the MPEG USAC standard, and which may or may not have been applied by an encoder during generation of the bitstream):
For example, the eSBR metadata included in the bitstream may be indicative of values of the parameters (described in the MPEG USAC standard and in the present disclosure): harmonicSBR[ch], sbrPatchingMode[ch], sbrOversamplingFlag[ch], sbrPitchInBins[ch], sbrPitchInBins[ch], bs_interTes, bs_temp_shape[ch][env], bs_inter_temp_shape_mode[ch][env], and bs_sbr_preprocessing.
Herein, the notation X[ch], where X is some parameter, denotes that the parameter pertains to channel (“ch”) of audio content of an encoded bitstream to be decoded. For simplicity, we sometimes omit the expression [ch], and assume the relevant parameter pertains to a channel of audio content.
Herein, the notation X[ch][env], where X is some parameter, denotes that the parameter pertains to SBR envelope (“env”) of channel (“ch”) of audio content of an encoded bitstream to be decoded. For simplicity, we sometimes omit the expressions [env] and [ch], and assume the relevant parameter pertains to an SBR envelope of a channel of audio content.
As noted, the MPEG USAC standard contemplates that a USAC bitstream includes eSBR metadata which controls the performance of eSBR processing by a decoder. The eSBR metadata includes the following one-bit metadata parameters: harmonicSBR; bs_interTES; and bs_pvc.
The parameter “harmonicSBR” indicates the use of harmonic patching (harmonic transposition) for SBR. Specifically, harmonicSBR=0 indicates non-harmonic, spectral patching as described in Section 4.6.18.6.3 of the MPEG-4 AAC standard; and harmonicSBR=1 indicates harmonic SBR patching (of the type used in eSBR, as described Section 7.5.3 or 7.5.4 of the MPEG USAC standard). Harmonic SBR patching is not used in accordance with non-eSBR spectral band replication (i.e., SBR that is not eSBR). Throughout this disclosure, spectral patching is referred to as a base form of spectral band replication, whereas harmonic transposition is referred to as an enhanced form of spectral band replication.
The value of the parameter “bs_interTES” indicates the use of the inter-TES tool of eSBR.
The value of the parameter “bs_pvc” indicates the use of the PVC tool of eSBR.
During decoding of an encoded bitstream, performance of harmonic transposition during an eSBR processing stage of the decoding (for each channel, “ch”, of audio content indicated by the bitstream) is controlled by the following eSBR metadata parameters: sbrPatchingMode[ch]; sbrOversamplingFlag[ch];
The value “sbrPatchingMode[ch]” indicates the transposer type used in eSBR: sbrPatchingMode[ch]=1 indicates non-harmonic patching as described in Section 4.6.18.6.3 of the MPEG-4 AAC standard; sbrPatchingMode[ch]=0 indicates harmonic SBR patching as described in Section 7.5.3 or 7.5.4 of the MPEG USAC standard.
The value “sbrOversamplingFlag[ch]” indicates the use of signal adaptive frequency domain oversampling in eSBR in combination with the DFT based harmonic SBR patching as described in Section 7.5.3 of the MPEG USAC standard. This flag controls the size of the DFTs that are utilized in the transposer: 1 indicates signal adaptive frequency domain oversampling enabled as described in Section 7.5.3.1 of the MPEG USAC standard; 0 indicates signal adaptive frequency domain oversampling disabled as described in Section 7.5.3.1 of the MPEG USAC standard. The value “sbrPitchInBinsFlag[ch]” controls the interpretation of the sbrPitchlnBins[ch] parameter: 1 indicates that the value in sbrPitchlnBins[ch] is valid and greater than zero; 0 indicates that the value of sbrPitchlnBins[ch] is set to zero.
The value “sbrPitchlnBins[ch]” controls the addition of cross product terms in the SBR harmonic transposer. The value sbrPitchinBins[ch] is an integer value in the range [0,127] and represents the distance measured in frequency bins for a 1536-line DFT acting on the sampling frequency of the core coder.
In the case that an MPEG-4 AAC bitstream is indicative of an SBR channel pair whose channels are not coupled (rather than a single SBR channel), the bitstream is indicative of two instances of the above syntax (for harmonic or non-harmonic transposition), one for each channel of the sbr_channel_pair_element( ).
The harmonic transposition of the eSBR tool typically improves the quality of decoded musical signals at relatively low cross over frequencies. Harmonic transposition should be implemented in the decoder by either DFT based or QMF based harmonic transposition. Non-harmonic transposition (that is, legacy spectral patching or copying) typically improves speech signals. Hence, a starting point in the decision as to which type of transposition is preferable for encoding specific audio content is to select the transposition method depending on speech/music detection with harmonic transposition be employed on the musical content and spectral patching on the speech content.
Performance of pre-flattening during eSBR processing is controlled by the value of a one-bit eSBR metadata parameter known as “bs_sbr_preprocessing”, in the sense that pre-flattening is either performed or not performed depending on the value of this single bit. When the SBR QMF-patching algorithm, as described in Section 4.6.18.6.3 of the MPEG-4 AAC standard, is used, the step of pre-flattening may be performed (when indicated by the “bs_sbr_preprocessing” parameter) in an effort to avoid discontinuities in the shape of the spectral envelope of a high frequency signal being input to a subsequent envelope adjuster (the envelope adjuster performs another stage of the eSBR processing). The pre-flattening typically improves the operation of the subsequent envelope adjustment stage, resulting in a highband signal that is perceived to be more stable.
Performance of inter-subband sample Temporal Envelope Shaping (the “inter-TES” tool), during eSBR processing in a decoder, is controlled by the following eSBR metadata parameters for each SBR envelope (“env”) of each channel (“ch”) of audio content of a USAC bitstream which is being decoded: bs_temp_shape[ch][env]; and bs_inter_temp_shape_mode[ch][env].
The inter-TES tool processes the QMF subband samples subsequent to the envelope adjuster. This processing step shapes the temporal envelope of the higher frequency band with a finer temporal granularity than that of the envelope adjuster. By applying a gain factor to each QMF subband sample in an SBR envelope, inter-TES shapes the temporal envelope among the QMF subband samples.
The parameter “bs_temp_shape[ch][env]” is a flag which signals the usage of inter-TES. The parameter “bs_inter_temp_shape_mode[ch][env]” indicates (as defined in the MPEG USAC standard) the values of the parameter γ in inter-TES.
The overall bitrate requirement for including in an MPEG-4 AAC bitstream eSBR metadata indicative of the above-mentioned eSBR tools (harmonic transposition, pre-flattening, and inter_TES) is expected to be on the order of a few hundreds of bits per second because only the differential control data needed to perform eSBR processing is transmitted in accordance with some embodiments of the invention. Legacy decoders can ignore this information because it is included in a backward compatible manner (as will be explained later). Therefore, the detrimental effect on bitrate associated with of inclusion of eSBR metadata is negligible, for a number of reasons, including the following:
Thus, embodiments of the invention provide a means for efficiently transmitting enhanced spectral band replication (eSBR) control data or metadata in a backward-compatible fashion. This efficient transmission of the eSBR control data reduces memory requirements in decoders, encoders, and transcoders employing aspects of the invention, while having no tangible adverse effect on bitrate. Moreover, the complexity and processing requirements associated with performing eSBR in accordance with embodiments of the invention are also reduced because the SBR data needs to be processed only once and not simulcast, which would be the case if eSBR was treated as a completely separate object type in MPEG-4 AAC instead of being integrated into the MPEG-4 AAC codec in a backward-compatible manner.
Next, with reference to
A block of an MPEG-4 AAC bitstream may include at least one “single_channel_element( )” (e.g., the single channel element shown in
A fill_element (referred to herein as a fill element) of an MPEG-4 AAC bitstream includes an identifier (“ID2” of
The fill data (e.g., an extension payload thereof) can include a header or identifier (e.g., “header1” of
When the header (e.g., the extension_type field) initializes an SBR object type, SBR metadata (sometimes referred to herein as “spectral band replication data,” and referred to as sbr_data( ) in the MPEG-4 AAC standard) follows the header, and at least one spectral band replication extension element (e.g., the “SBR extension element” of fill element 1 of
The MPEG-4 AAC standard contemplates that a spectral band replication extension element can include PS (parametric stereo) data for audio data of a program. The MPEG-4 AAC standard contemplates that when the header of a fill element (e.g., of an extension payload thereof) initializes an SBR object type (as does “header1” of
In accordance with some embodiments of the present invention, eSBR metadata (e.g., a flag indicative of whether enhanced spectral band replication (eSBR) processing is to be performed on audio content of the block) is included in a spectral band replication extension element of a fill element. For example, such a flag is indicated in fill element 1 of
In accordance with some embodiments of the invention, eSBR metadata is included in a fill element (e.g., fill element 2 of
In a first class of embodiments, the invention is an audio processing unit (e.g., a decoder), comprising:
The flag is eSBR metadata, and an example of the flag is the sbrPatchingMode flag. Another example of the flag is the harmonicSBR flag. Both of these flags indicate whether a base form of spectral band replication or an enhanced form of spectral replication is to be performed on the audio data of the block. The base form of spectral replication is spectral patching, and the enhanced form of spectral band replication is harmonic transposition.
In some embodiments, the fill data also includes additional eSBR metadata (i.e., eSBR metadata other than the flag).
The memory may be a buffer memory (e.g., an implementation of buffer 201 of
It is estimated that the complexity of performance of eSBR processing (using the eSBR harmonic transposition, pre-flattening, and inter_TES tools) by an eSBR decoder during decoding of an MPEG-4 AAC bitstream which includes eSBR metadata (indicative of these eSBR tools) would be as follows (for typical decoding with the indicated parameters):
It is known that DFT based transposition typically performs better than the QMF based transposition for transients.
In accordance with some embodiments of the present invention, a fill element (of an encoded audio bitstream) which includes eSBR metadata also includes a parameter (e.g., a “bs_extension_id” parameter) whose value (e.g., bs_extension_id=3) signals that eSBR metadata is included in the fill element and that eSBR processing is to be performed on audio content of the relevant block, and/or a parameter (e.g., the same “bs_extension_id” parameter) whose value (e.g., bs_extension_id=2) signals that an sbr_extension( ) container of the fill element includes PS data. For example, as indicated in Table 1 below, such a parameter having the value bs_extension_id=2 may signal that an sbr_extension( ) container of the fill element includes PS data, and such a parameter having the value bs_extension_id=3 may signal that an sbr_extension( ) container of the fill element includes eSBR metadata:
In accordance with some embodiments of the invention, the syntax of each spectral band replication extension element which includes eSBR metadata and/or PS data is as indicated in Table 2 below (in which “sbr_extension( )” denotes a container which is the spectral band replication extension element, “bs_extension_id” is as described in Table 1 above, “ps_data” denotes PS data, and “esbr_data” denotes eSBR metadata):
In an exemplary embodiment, the esbr_data( ) referred to in Table 2 above is indicative of values of the following metadata parameters:
For example, in some embodiments, the esbr_data( ) may have the syntax indicated in Table 3, to indicate these metadata parameters:
In Table 3, the number in the center column indicates the number of bits of the corresponding parameter in the left column.
In some embodiments, the invention is a method including a step of encoding audio data to generate an encoded bitstream (e.g., an MPEG-4 AAC bitstream), including by including eSBR metadata in at least one segment of at least one block of the encoded bitstream and audio data in at least one other segment of the block. In typical embodiments, the method includes a step of multiplexing the audio data with the eSBR metadata in each block of the encoded bitstream. In typical decoding of the encoded bitstream in an eSBR decoder, the decoder extracts the eSBR metadata from the bitstream (including by parsing and demultiplexing the eSBR metadata and the audio data) and uses the eSBR metadata to process the audio data to generate a stream of decoded audio data.
Another aspect of the invention is an eSBR decoder configured to perform eSBR processing (e.g., using at least one of the eSBR tools known as harmonic transposition, pre-flattening, or inter_TES) during decoding of an encoded audio bitstream (e.g., an MPEG-4 AAC bitstream) which does not include eSBR metadata. An example of such a decoder will be described with reference to
The eSBR decoder (400) of
In operation of decoder 400, a sequence of blocks of an encoded audio bitstream (an MPEG-4 AAC bitstream) received by decoder 400 is asserted from buffer 201 to deformatter 215.
Deformatter 215 is coupled and configured to demultiplex each block of the bitstream to extract SBR metadata (including quantized envelope data) and typically also other metadata therefrom. Deformatter 215 is configured to assert at least the SBR metadata to eSBR processing stage 203. Deformatter 215 is also coupled and configured to extract audio data from each block of the bitstream, and to assert the extracted audio data to decoding subsystem (decoding stage) 202.
Audio decoding subsystem 202 of decoder 400 is configured to decode the audio data extracted by deformatter 215 (such decoding may be referred to as a “core” decoding operation) to generate decoded audio data, and to assert the decoded audio data to eSBR processing stage 203. The decoding is performed in the frequency domain. Typically, a final stage of processing in subsystem 202 applies a frequency domain-to-time domain transform to the decoded frequency domain audio data, so that the output of subsystem is time domain, decoded audio data. Stage 203 is configured to apply SBR tools (and eSBR tools) indicated by the SBR metadata (extracted by deformatter 215) and by eSBR metadata generated in subsystem 401, to the decoded audio data (i.e., to perform SBR and eSBR processing on the output of decoding subsystem 202 using the SBR and eSBR metadata) to generate the fully decoded audio data which is output from decoder 400. Typically, decoder 400 includes a memory (accessible by subsystem 202 and stage 203) which stores the deformatted audio data and metadata output from deformatter 215 (and optionally also subsystem 401), and stage 203 is configured to access the audio data and metadata as needed during SBR and eSBR processing. The SBR processing in stage 203 may be considered to be post-processing on the output of core decoding subsystem 202. Optionally, decoder 400 also includes a final upmixing subsystem (which may apply parametric stereo (“PS”) tools defined in the MPEG-4 AAC standard, using PS metadata extracted by deformatter 215) which is coupled and configured to perform upmixing on the output of stage 203 to generated fully decoded, upmixed audio which is output from APU 210.
Control data generation subsystem 401 of
Aspects of the invention include an encoding or decoding method of the type which any embodiment of the inventive APU, system or device is configured (e.g., programmed) to perform. Other aspects of the invention include a system or device configured (e.g., programmed) to perform any embodiment of the inventive method, and a computer readable medium (e.g., a disc) which stores code (e.g., in a non-transitory manner) for implementing any embodiment of the inventive method or steps thereof. For example, the inventive system can be or include a programmable general purpose processor, digital signal processor, or microprocessor, programmed with software or firmware and/or otherwise configured to perform any of a variety of operations on data, including an embodiment of the inventive method or steps thereof. Such a general purpose processor may be or include a computer system including an input device, a memory, and processing circuitry programmed (and/or otherwise configured) to perform an embodiment of the inventive method (or steps thereof) in response to data asserted thereto.
Embodiments of the present invention may be implemented in hardware, firmware, or software, or a combination of both (e.g., as a programmable logic array). Unless otherwise specified, the algorithms or processes included as part of the invention are not inherently related to any particular computer or other apparatus. In particular, various general-purpose machines may be used with programs written in accordance with the teachings herein, or it may be more convenient to construct more specialized apparatus (e.g., integrated circuits) to perform the required method steps. Thus, the invention may be implemented in one or more computer programs executing on one or more programmable computer systems (e.g., an implementation of any of the elements of
Each such program may be implemented in any desired computer language (including machine, assembly, or high level procedural, logical, or object oriented programming languages) to communicate with a computer system. In any case, the language may be a compiled or interpreted language.
For example, when implemented by computer software instruction sequences, various functions and steps of embodiments of the invention may be implemented by multithreaded software instruction sequences running in suitable digital signal processing hardware, in which case the various devices, steps, and functions of the embodiments may correspond to portions of the software instructions.
Each such computer program is preferably stored on or downloaded to a storage media or device (e.g., solid state memory or media, or magnetic or optical media) readable by a general or special purpose programmable computer, for configuring and operating the computer when the storage media or device is read by the computer system to perform the procedures described herein. The inventive system may also be implemented as a computer-readable storage medium, configured with (i.e., storing) a computer program, where the storage medium so configured causes a computer system to operate in a specific and predefined manner to perform the functions described herein.
A number of embodiments of the invention have been described. Nevertheless, it will be understood that various modifications may be made without departing from the spirit and scope of the invention. Numerous modifications and variations of the present invention are possible in light of the above teachings. It is to be understood that within the scope of the appended claims, the invention may be practiced otherwise than as specifically described herein. Any reference numerals contained in the following claims are for illustrative purposes only and should not be used to construe or limit the claims in any manner whatsoever.
Number | Date | Country | Kind |
---|---|---|---|
15159067 | Mar 2015 | EP | regional |
This application is a continuation of U.S. patent application Ser. No. 17/831,080, filed Jun. 2, 2022, which is a continuation of U.S. patent application Ser. No. 16/932,479, filed Jul. 17, 2020, now U.S. Pat. No. 11,367,455, which is a division of U.S. patent application Ser. No. 16/568,802, filed Sep. 12, 2019, now U.S. Pat. No. 10,734,010, which is a continuation of U.S. patent application Ser. No. 16/269,161, filed Feb. 6, 2019, now U.S. Pat. No. 10,453,468, which is a continuation of U.S. patent application Ser. No. 16/208,325, filed Dec. 3, 2018, now U.S. Pat. No. 10,262,669, which is a continuation of U.S. patent application Ser. No. 15/546,965, filed on Jul. 27, 2017, now U.S. Pat. No. 10,262,668, which is the U.S. National Stage of PCT/EP2016/055202, filed on Mar. 10, 2016, which claims priority to U.S. Provisional Application No. 62/133,800, filed Mar. 16, 2015 and European Patent Application No. 15159067.6, filed Mar. 13, 2015, each of which is incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
6502069 | Grill | Dec 2002 | B1 |
6680972 | Liljeryd | Jan 2004 | B1 |
7283955 | Liljeryd | Oct 2007 | B2 |
7447631 | Truman | Nov 2008 | B2 |
8200481 | Xu et al. | Jun 2012 | B2 |
8332059 | Herre | Dec 2012 | B2 |
8391371 | Klein | Mar 2013 | B2 |
8489391 | Kurniawati | Jul 2013 | B2 |
8494843 | Sung | Jul 2013 | B2 |
8515768 | Baumgarte | Aug 2013 | B2 |
8831958 | Lee | Sep 2014 | B2 |
10134413 | Villemoes | Nov 2018 | B2 |
10262668 | Villemoes | Apr 2019 | B2 |
10262669 | Villemoes | Apr 2019 | B1 |
10453468 | Villemoes | Oct 2019 | B2 |
10553232 | Villemoes | Feb 2020 | B2 |
10734010 | Villemoes | Aug 2020 | B2 |
10818306 | Villemoes | Oct 2020 | B2 |
10943595 | Villemoes | Mar 2021 | B2 |
11289106 | Kjoerling | Mar 2022 | B2 |
20030093271 | Tsushima | May 2003 | A1 |
20030233234 | Truman | Dec 2003 | A1 |
20040078194 | Liljeryd et al. | Apr 2004 | A1 |
20040078205 | Liljeryd | Apr 2004 | A1 |
20070156397 | Chong | Jul 2007 | A1 |
20070160043 | Kim | Jul 2007 | A1 |
20090319283 | Schnell | Dec 2009 | A1 |
20100023336 | Shmunk | Jan 2010 | A1 |
20100217607 | Neuendorf | Aug 2010 | A1 |
20100262427 | Chivukula | Oct 2010 | A1 |
20110170711 | Rettelbach et al. | Jul 2011 | A1 |
20110257984 | Thierry | Oct 2011 | A1 |
20120016667 | Gao | Jan 2012 | A1 |
20120029924 | Duni | Feb 2012 | A1 |
20120035918 | Frankkila | Feb 2012 | A1 |
20120035936 | Kurniawati | Feb 2012 | A1 |
20120065753 | Choo | Mar 2012 | A1 |
20120243692 | Ramamoorthy | Sep 2012 | A1 |
20120245947 | Neuendorf | Sep 2012 | A1 |
20120265540 | Fuchs | Oct 2012 | A1 |
20120328124 | Kjoerling | Dec 2012 | A1 |
20130006644 | Jiang | Jan 2013 | A1 |
20130041673 | Nagel et al. | Feb 2013 | A1 |
20140016785 | Neuendorf et al. | Jan 2014 | A1 |
20140016787 | Neuendorf | Jan 2014 | A1 |
20140019146 | Neuendorf | Jan 2014 | A1 |
20140222434 | Nagel | Aug 2014 | A1 |
20140236605 | Rettelbach | Aug 2014 | A1 |
20140310011 | Biswas | Oct 2014 | A1 |
20140365231 | Hoerich | Dec 2014 | A1 |
20140372131 | Disch | Dec 2014 | A1 |
20150287417 | Disch | Oct 2015 | A1 |
20180081645 | Fuchs | Mar 2018 | A1 |
20190103123 | Villemoes | Apr 2019 | A1 |
Number | Date | Country |
---|---|---|
1484822 | Mar 2004 | CN |
1571993 | Jan 2005 | CN |
1659626 | Aug 2005 | CN |
1669072 | Sep 2005 | CN |
102089817 | Jun 2011 | CN |
102144259 | Aug 2011 | CN |
102254560 | Nov 2011 | CN |
102449692 | May 2012 | CN |
102194457 | Feb 2013 | CN |
102177545 | Mar 2013 | CN |
103026408 | Apr 2013 | CN |
102446506 | Jun 2013 | CN |
102282612 | Jul 2013 | CN |
101925950 | Oct 2013 | CN |
102318004 | Oct 2013 | CN |
101540171 | Nov 2013 | CN |
101855918 | Jan 2014 | CN |
102089808 | Feb 2014 | CN |
102754151 | Mar 2014 | CN |
103620678 | Mar 2014 | CN |
103918029 | Jul 2014 | CN |
102687198 | Sep 2014 | CN |
103038819 | Feb 2015 | CN |
103262164 | Jun 2015 | CN |
102789782 | Oct 2015 | CN |
103548077 | Feb 2016 | CN |
103650539 | Mar 2016 | CN |
102754159 | Aug 2016 | CN |
103562994 | Aug 2016 | CN |
103959375 | Nov 2016 | CN |
103971694 | Dec 2016 | CN |
103620679 | Jul 2017 | CN |
103703511 | Aug 2017 | CN |
104240709 | Oct 2019 | CN |
1455345 | Sep 2004 | EP |
1590800 | Nov 2009 | EP |
2392005 | Dec 2011 | EP |
2182513 | Mar 2013 | EP |
2631906 | Aug 2013 | EP |
1926084 | Oct 2013 | EP |
2491555 | Mar 2014 | EP |
2711924 | Mar 2014 | EP |
2676264 | Jan 2015 | EP |
2830047 | Jan 2015 | EP |
2830054 | Jan 2015 | EP |
2146344 | Jul 2016 | EP |
1106824 | Mar 2008 | HK |
2001-521648 | Nov 2001 | JP |
2009-116371 | May 2009 | JP |
2011-527447 | Oct 2011 | JP |
2013-525824 | Jun 2013 | JP |
2013125187 | Jun 2013 | JP |
2014-512020 | May 2014 | JP |
2016-539377 | Dec 2016 | JP |
20050051046 | Jun 2005 | KR |
20070003574 | Jan 2007 | KR |
20070038439 | Apr 2007 | KR |
20100087661 | Aug 2010 | KR |
20130008061 | Jan 2013 | KR |
2408089 | Apr 2011 | RU |
201246183 | Nov 2012 | TW |
201438003 | Oct 2014 | TW |
I524330 | Mar 2016 | TW |
2007138419 | Dec 2007 | WO |
2010003546 | Jan 2010 | WO |
2010087614 | Aug 2010 | WO |
2010090427 | Aug 2010 | WO |
2011026083 | Mar 2011 | WO |
2011048010 | Apr 2011 | WO |
2011110500 | Sep 2011 | WO |
2011124608 | Oct 2011 | WO |
2012110415 | Aug 2012 | WO |
2012126893 | Sep 2012 | WO |
2012137617 | Oct 2012 | WO |
2013068587 | May 2013 | WO |
2013158804 | Oct 2013 | WO |
2014115225 | Jul 2014 | WO |
2014118155 | Aug 2014 | WO |
2014118185 | Aug 2014 | WO |
2014118185 | Aug 2014 | WO |
2014124377 | Aug 2014 | WO |
2014165668 | Oct 2014 | WO |
2014199632 | Dec 2014 | WO |
Entry |
---|
3GPP TS 26.404, “Generation Partnership Project; Technical Specification Group Services and System Aspects; General Audio Codec audio processing functions; Enhanced aacPlus general audio codec; Enhanced aacPlus encoder SBR part (Release 6)” 2004. |
Anonymous: “ISO/IEC 14496-3:2009, Fourth Edition, subpart 1”, MPEG Meeting Oct. 22-26, 2007, Motion Picture Expert Group or ISO/IEC JTC1/SC29/WG11, May 15, 2009. |
Zhong, H. et al “QMF Based Harmonic Spectral Band Replication” AES Convention Signal Processing, Oct. 19, 2011, pp. 1-7. |
Anonymous: “ISO/IEC 23003-3:201x/DIS of Unified Speech and Audio Coding”, No. N11863, Feb. 9, 2011. |
Dongbing Liu, “A brief analysis of frequency band replication in audio coding”, Journal of Liaoning University (Natural Science Edition), published on Apr. 30, 2011. |
Haishan Zhong et al, “QMF Based Harmonic Spectral Band Replication”, AES E-Library, published on Oct. 19, 2011. |
Hu, Rui-Min, “AVS-P10 Mobile Speech and Audio Standard and Primary Technology” 2010. |
Jiang, Lin et al “AVS2 Speech and Audio Coding Scheme for High Quality at Low Bitrates” IEEE International Conference on Multimedia and Expo Workshops Sep. 8, 2014. |
Liu, Dantong “Research and Implementation of a New Type Hi-Fi Wideband Audio Coding Algorithm” 2009. |
Nagel, F. et al “A Continuous Modulated Single Sideband Bandwidth Extension” IEEE 2010, pp. 357-360. |
Qingwei Guo, “Analysis and testing of band replication techniques”, Electronics Quality, published on Dec. 20, 2007. |
Quackenbush, Schuyler, et al “MPEG Unified Speech and Audio Coding” IEEE Multimedia, vol. 20, Issue 2, Apr.-Jun. 2013, pp. 72-78. |
Ravi K. Chivukula, Fast Algorithms for Low-Delay SBR Filterbanks in MPEG-4 AAC-ELD, «IEEE Transactions on Audio, Speech, and Language Processing» , published on Oct. 10, 2011. |
Rongshan Yu, et al, “Perceptually Enhanced Bit-Plane Coding for Scalable Audio”, «2006 IEEE International Conference on Multimedia and Expo» , published on Dec. 31, 2006. |
Rose Matthias “MPEG Audio Codec: From MP3 to xHE-ACC” 2012. |
Seng, Chong Kok, et al “Low Power Spectral Band Replication Technology for the MPEG-4 Audio Standard” ICICS-PCM, Dec. 15-18, 2003, pp. 1408-1412. |
Werner, Michael et al “An Enhanced SBR Tool for Low-Delay Applications” AES Convention 127, Oct. 1, 2009, USA. |
Xiaoming Li, “Research on general coding methods for speech and audio signals”, Chinese Doctor's Theses Full-text Database (Information Science and Technology Series), published on Mar. 15, 2015. |
Yamamoto, Y et al, “A New Bandwidth Extention Technology for MPEG Unified Speech and Audio Coding”, IEEE International Conference on Acoustics, Speech and Signal Processing, published on May 31, 2013. |
Yang Lu, “An improved frequency band replication method”, «Semiconductor Technology» , vol. 6, published on Dec. 31, 2004. |
Zernicki, T. et al “Enhanced Coding of High-Frequency Tonal Components in MPEG-D USAC Through Joint Application of ESBR and Sinusoidal Modeling” IEEE 2011, pp. 501-504. |
Zhai Zhibo, “Research on audio codec algorithm and DSP implementation”, «Chinese Master's Theses Full-text Database» , vol. 5, published on May 15, 2006. |
Zhang, Li-Yan, et al “Bandwidth extension method based on nonlinear audio characteristics classification”, Speech and Audio Signal Processing Lab, Journal on Communications, Aug. 2013, vol. 34, No. 8. |
Anonymous: “ISO/IEC 14496-3:2009, Fourth Edition, subpart 4”, MPEG Meeting Oct. 22-26, 2007, Motion Picture Expert Group or ISO/IEC JTC1/SC29/WG11, May 15, 2009. 182 pages. |
Number | Date | Country | |
---|---|---|---|
20230368805 A1 | Nov 2023 | US |
Number | Date | Country | |
---|---|---|---|
62133800 | Mar 2015 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16568802 | Sep 2019 | US |
Child | 16932479 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17831080 | Jun 2022 | US |
Child | 18318443 | US | |
Parent | 16932479 | Jul 2020 | US |
Child | 17831080 | US | |
Parent | 16269161 | Feb 2019 | US |
Child | 16568802 | US | |
Parent | 16208325 | Dec 2018 | US |
Child | 16269161 | US | |
Parent | 15546965 | US | |
Child | 16208325 | US |