The present disclosure relates to stereo sound encoding, in particular but not exclusively switching between “stereo coding modes” (hereinafter also “stereo modes”) in a multichannel sound codec capable, in particular but not exclusively, of producing a good stereo quality for example in a complex audio scene at low bit-rate and low delay.
In the present disclosure and the appended claims:
Historically, conversational telephony has been implemented with handsets having only one transducer to output sound only to one of the user's ears. In the last decade, users have started to use their portable handset in conjunction with a headphone to receive the sound over their two ears mainly to listen to music but also, sometimes, to listen to speech. Nevertheless, when a portable handset is used to transmit and receive conversational speech, the content is still mono but presented to the user's two ears when a headphone is used.
With the newest 3GPP speech coding standard as described in Reference [1], of which the full content is incorporated herein by reference, the quality of the coded sound, for example speech and/or audio that is transmitted and received through a portable handset has been significantly improved. The next natural step is to transmit stereo information such that the receiver gets as close as possible to a real life audio scene that is captured at the other end of the communication link.
In audio codecs, for example as described in Reference [2], of which the full content is incorporated herein by reference, transmission of stereo information is normally used.
For conversational speech codecs, mono signal is the norm. When a stereo signal is transmitted, the bit-rate often needs to be doubled since both the left and right channels of the stereo signal are coded using a mono codec. This works well in most scenarios, but presents the drawbacks of doubling the bit-rate and failing to exploit any potential redundancy between the two channels (left and right channels of the stereo signal). Furthermore, to keep the overall bit-rate at a reasonable level, a very low bit-rate for each channel is used, thus affecting the overall sound quality. To reduce the bit-rate, efficient stereo coding techniques have been developed and used. As non-limitative examples, the use of three stereo coding techniques that can be efficiently used at low bit-rates is discussed in the following paragraphs.
A first stereo coding technique is called parametric stereo. Parametric stereo coding encodes two, left and right channels as a mono signal using a common mono codec plus a certain amount of stereo side information (corresponding to stereo parameters) which represents a stereo image. The two input, left and right channels are down-mixed into a mono signal, and the stereo parameters are then computed usually in transform domain, for example in the Discrete Fourier Transform (DFT) domain, and are related to so-called binaural or inter-channel cues. The binaural cues (Reference [3], of which the full content is incorporated herein by reference) comprise Interaural Level Difference (ILD), Interaural Time Difference (ITD) and Interaural Correlation (IC). Depending on the signal characteristics, stereo scene configuration, etc., some or all binaural cues are coded and transmitted to the decoder. Information about what binaural cues are coded and transmitted is sent as signaling information, which is usually part of the stereo side information. A particular binaural cue can be also quantized using different coding techniques which results in a variable number of bits being used. Then, in addition to the quantized binaural cues, the stereo side information may contain, usually at medium and higher bit-rates, a quantized residual signal that results from the down-mixing. The residual signal can be coded using an entropy coding technique, e.g. an arithmetic coder. Parametric stereo coding with stereo parameters computed in a transform domain will be referred to in the present disclosure as “DFT stereo” coding.
Another stereo coding technique is a technique operating in time-domain (TD). This stereo coding technique mixes the two input, left and right channels into so-called primary channel and secondary channel. For example, following the method as described in Reference [4], of which the full content is incorporated herein by reference, time-domain mixing can be based on a mixing ratio, which determines respective contributions of the two input, left and right channels upon production of the primary channel and the secondary channel. The mixing ratio is derived from several metrics, e.g. normalized correlations of the input left and right channels with respect to a mono signal version or a long-term correlation difference between the two input left and right channels. The primary channel can be coded by a common mono codec while the secondary channel can be coded by a lower bit-rate codec. The secondary channel coding may exploit coherence between the primary and secondary channels and might re-use some parameters from the primary channel. Time-domain stereo coding will be referred to in the present disclosure as “TD stereo” coding. In general, TD stereo coding is most efficient at lower and medium bit-rates for coding speech signals.
A third stereo coding technique is a technique operating in the Modified Discrete Cosine Transform (MDCT) domain. It is based on joint coding of both the left and right channels while computing global ILD and Mid/Side (M/S) processing in whitened spectral domain. This third stereo coding technique uses several tools adapted from TCX (Transform Coded eXcitation) coding in MPEG (Moving Picture Experts Group) codecs as described for example in References [6] and [7] of which the full contents are incorporated herein by reference; these tools may include TCX core coding, TCX LTP (Long-Term Prediction) analysis, TCX noise filling, Frequency-Domain Noise Shaping (FDNS), stereophonic Intelligent Gap Filling (IGF), and/or adaptive bit allocation between channels. In general, this third stereo coding technique is efficient to encode all kinds of audio content at medium and high bit-rates. The MDCT-domain stereo coding technique will be referred to in the present disclosure as “MDCT stereo coding”. In general, MDCT stereo coding is most efficient at medium and high bit-rates for coding general audio signals.
In recent years, stereo coding was further extended to multichannel coding. There exist several techniques to provide multichannel coding but the fundamental core of all these techniques is often based on single or multiple instance(s) of mono or stereo coding techniques. Thus, the present disclosure presents switching between stereo coding modes that can be part of multichannel coding techniques such as Metadata-Assisted Spatial Audio (MASA) as described for example in Reference [8] of which the full content is incorporated herein by reference. In the MASA approach, the MASA metadata (e.g. direction, energy ratio, spread coherence, distance, surround coherence, all in several time-frequency slots) are generated in a MASA analyzer, quantized, coded, and passed into the bit-stream while MASA audio channel(s) are treated as (multi-)mono or (multi-)stereo transport signals coded by the core coder(s). At the MASA decoder, MASA metadata then guide the decoding and rendering process to recreate an output spatial sound.
The present disclosure provides stereo sound signal encoding devices and methods as defined in the appended claims.
The foregoing and other objects, advantages and features of the stereo encoding and decoding devices and methods will become more apparent upon reading of the following non-restrictive description of illustrative embodiments thereof, given by way of example only with reference to the accompanying drawings.
In the appended drawings:
As mentioned hereinabove, the present disclosure relates to stereo sound encoding, in particular but not exclusively to switching between stereo coding modes in a sound, including speech and/or audio, codec capable in particular but not exclusively of producing a good stereo quality for example in a complex audio scene at low bit-rate and low delay. In the present disclosure, a complex audio scene includes situations, for example but not exclusively, in which (a) the correlation between the sound signals that are recorded by the microphones is low, (b) there is an important fluctuation of the background noise, and/or (c) an interfering talker is present. Non-limitative examples of complex audio scenes comprise a large anechoic conference room with an A/B microphones configuration, a small echoic room with binaural microphones, and a small echoic room with a mono/side microphones set-up. All these room configurations could include fluctuating background noise and/or interfering talkers.
The stereo sound processing and communication system 100 of
Still referring to
The left 103 and right 123 channels of the original analog sound signal are supplied to an analog-to-digital (A/D) converter 104 for converting them into left 105 and right 125 channels of an original digital stereo sound signal. The left 105 and right 125 channels of the original digital stereo sound signal may also be recorded and supplied from a storage device (not shown).
A stereo sound encoder 106 codes the left 105 and right 125 channels of the original digital stereo sound signal thereby producing a set of coding parameters that are multiplexed under the form of a bit-stream 107 delivered to an optional error-correcting encoder 108. The optional error-correcting encoder 108, when present, adds redundancy to the binary representation of the coding parameters in the bit-stream 107 before transmitting the resulting bit-stream 111 over the communication link 101.
On the receiver side, an optional error-correcting decoder 109 utilizes the above mentioned redundant information in the received digital bit-stream 111 to detect and correct errors that may have occurred during transmission over the communication link 101, producing a bit-stream 112 with received coding parameters. A stereo sound decoder 110 converts the received coding parameters in the bit-stream 112 for creating synthesized left 113 and right 133 channels of the digital stereo sound signal. The left 113 and right 133 channels of the digital stereo sound signal reconstructed in the stereo sound decoder 110 are converted to synthesized left 114 and right 134 channels of the analog stereo sound signal in a digital-to-analog (D/A) converter 115.
The synthesized left 114 and right 134 channels of the analog stereo sound signal are respectively played back in a pair of loudspeaker units, or binaural headphones, 116 and 136. Alternatively, the left 113 and right 133 channels of the digital stereo sound signal from the stereo sound decoder 110 may also be supplied to and recorded in a storage device (not shown).
For example, (a) the left channel of
In the illustrative, non-limitative implementation of
Stereo mode switching in the IVAS codec (IVAS stereo encoding device 200 and IVAS stereo decoding device 800) refers, in the described, non-limitative implementation, to switching between the DFT, TD and MDCT stereo modes.
The following nomenclature is used in the present disclosure and the accompanying figures: small letters indicate time-domain signals, capital letters indicate transform-domain signals, I/L stands for left channel, r/R stands for right channel, m/M stands for mid-channel, s/S stands for side channel, PCh stands for primary channel, and SCh stands for secondary channel. Also, in the figures, numbers without unit correspond to a number of samples at a 16 kHz sampling rate.
Differences exist between (a) the DFT stereo encoder 300 and encoding method 350, (b) the TD stereo encoder 400 and encoding method 450, and (c) the MDCT stereo encoder 500 and encoding method 550. Some of these differences are summarized in the following paragraphs and at least some of them will be better explained in the following description.
The IVAS stereo encoding device 200 and encoding method 250 performs operations such as buffering one 20-ms frame (as well known in the art, the stereo sound signal is processed in successive frames of given duration containing a given number of sound signal samples) of stereo input signal (left and right channels), few classification steps, down-mixing, pre-processing and actual coding. A 8.75 ms look-ahead is available and used mainly for analysis, classification and OverLap-Add (OLA) operations used in transform-domain such as in a Transform Coded eXcitation (TCX) core, a High Quality (HQ) core, and Frequency-Domain BandWidth-Extension (FD-BWE). These operations are described in Reference [1], Clauses 5.3 and 5.2.6.2.
The look-ahead is shorter in the IVAS stereo encoding device 200 and encoding method 250 compared to the non-modified EVS encoder by 0.9375 ms (corresponding to a Finite Impulse Response (FIR) filter resampling delay (See Reference [1], Clause 5.1.3.1). This has an impact on the procedure of resampling the down-processed signal (down-mixed signal for TD and DFT stereo modes) in every frame:
The resampling in the DFT stereo encoder 300, the TD stereo encoder 400 and the MDCT stereo encoder 500, is done from the input sampling rate (usually 16, 32, or 48 kHz) to the internal sampling rate(s) (usually 12.8, 16, 25.6, or 32 kHz). The resampled signal(s) is then used in the pre-processing and the core encoding.
Also, the look-ahead contains a part of down-processed signal (down-mixed signal for TD and DFT stereo modes) signal that is not accurate but rather extrapolated or estimated which also has an impact on the resampling process. The inaccuracy of the look-ahead down-processed signal (down-mixed signal for TD and DFT stereo modes) depends on the current stereo coding mode:
The redressed/extrapolated signal part in the look-ahead is not subject to actual coding but used for analysis and classification. Consequently, the redressed/extrapolated, signal part in the look-ahead is re-computed in the next frame and the resulting down-processed signal (down-mixed signal for TD and DFT stereo modes) is then used for actual coding. The length of the re-computed signal depends on the stereo mode and coding processing:
It is noted that the lengths of the redressed, respectively extrapolated signal part in the look-ahead are mentioned here as an illustration while any other lengths can be implemented in general.
Additional information regarding the DFT stereo encoder 300 and encoding method 350 may be found in References [2] and [3]. Additional information regarding the TD stereo encoder 400 and encoding method 450 may be found in Reference [4]. And additional information regarding the MDCT stereo encoder 500 and encoding method 550 may be found in References [6] and [7].
The following Table I lists in a sequential order processing operations for each frame depending on the current stereo coding mode (See also
The IVAS stereo encoding method 250 comprises an operation (not shown) of controlling switching between the DFT, TD and MDCT stereo modes. To perform the switching controlling operation, the IVAS stereo encoding device 200 comprises a controller (not shown) of switching between the DFT, TD and MDCT stereo modes. Switching between the DFT and TD stereo modes in the IVAS stereo encoding device 200 and coding method 250 involves the use of the stereo mode switching controller (not shown) to maintain continuity of the following input signals 1) to 5) to enable adequate processing of these signals in the IVAS stereo encoding device 200 and method 250:
While it is straightforward to maintain the continuity for signal 1) above, it is challenging for signals 2)-5) due to several aspects, for example a different down-mixing, a different length of the re-computed part of the look-ahead, use of Inter-Channel Alignment (ICA) in the TD stereo mode only, etc.
The operation (not shown) of controlling switching between the DFT, TD and MDCT stereo modes comprises an operation 255 of stereo classification and stereo mode selection, for example as described in Reference [9], of which the full content is incorporated herein by reference. To perform the operation 255, the controller (not shown) of switching between the DFT, TD and MDCT stereo modes comprises a stereo classifier and stereo mode selector 205.
Switching between the TD stereo mode, the DFT stereo mode, and the MDCT stereo mode is responsive to the stereo mode selection. Stereo classification (Reference [9]) is conducted in response to the left l and right r channels of the input stereo signal, and/or requested coded bit-rate. Stereo mode selection (Reference [9]) consists of choosing one of the DFT, TD, and MDCT stereo modes based on stereo classification.
The stereo classifier and stereo mode selector 205 produces stereo mode signaling 270 for identifying the selected stereo coding mode.
The operation (not shown) of controlling switching between the DFT, TD and MDCT stereo modes comprises an operation of memory allocation (not shown). To perform the operation of memory allocation, the controller of switching between the DFT, TD and MDCT stereo modes (not shown) dynamically allocates/deallocates static memory data structures to/from the DFT, TD and MDCT stereo modes depending on the current stereo mode. Such memory allocation keeps the static memory impact of the IVAS stereo encoding device 200 as low as possible by maintaining only those data structures that are employed in the current frame.
For example, in a first DFT stereo frame following a TD stereo frame, the data structures related to the TD stereo mode (for example TD stereo data handling, second core-encoder data structure) are freed (deallocated) and the data structures related to the DFT stereo mode (for example DFT stereo data structure) are instead allocated and initialized. It is noted that the deallocation of the further unused data structures is done first, followed by the allocation of newly used data structures. This order of operations is important to not increase the static memory impact at any point of the encoding.
A summary of main static memory data structures as used in the various stereo modes is shown in Table II.
An example implementation of the memory allocation/deallocation encoder module in the C source code is shown below.
The TD stereo mode may consist of two sub-modes. One is a so-called normal TD stereo sub-mode for which the TD stereo mixing ratio is higher than 0 and lower than 1. The other is a so-called LRTD stereo sub-mode for which the TD stereo mixing ratio is either 0 or 1; thus, LRTD is an extreme case of the TD stereo mode where the TD down-mixing actually does not mix the content of the time-domain left l and right r channels to form primary PCh and secondary SCh channels but get them directly from the channels l and r.
When the two sub-modes (normal and LRTD) of the TD stereo mode are available, the stereo mode switching operation (not shown) comprises a TD stereo mode setting (not show). To perform the TD stereo mode setting, forming part of the memory allocation, the stereo mode switching controller (not shown) of the IVAS stereo encoding device 200 allocates/deallocates certain static memory data structures when switching between the normal TD stereo mode and the LRTD stereo mode. For example, an IC-BWE data structure is allocated only in frames using the normal TD stereo mode (See Table II) while several data structures (BWEs and Complex Low Delay Filter Bank (CLDFB) for secondary channel SCh) are allocated only in frames using the LRTD stereo mode (See Table II). An example implementation of the memory allocation/deallocation encoder module in the C source code is shown below:
Mostly, only the normal TD stereo mode (for simplicity referred further only as the TD stereo mode) will be described in detail in the present disclosure. The LRTD stereo mode is mentioned as a possible implementation.
The stereo mode switching controlling operation (not shown) comprises an operation of stereo switching updates (not shown). To perform this stereo switching updates operation, the stereo mode switching controller (not shown) updates long-term parameters and updates or resets past buffer memories.
Upon switching from the DFT stereo mode to the TD stereo mode, the stereo mode switching controller (not shown) resets TD stereo and ICA static memory data structures. These data structures store the parameters and memories of the TD stereo analysis and weighted down-mixing (401 in
Upon switching from the TD stereo mode to the DFT stereo mode, the stereo mode switching controller (not shown) resets the DFT stereo data structure. This DFT stereo data structure stores parameters and memories related to the DFT stereo processing and down-mixing module (303 in
Also, the stereo mode switching controller (not shown) transfers some stereo-related parameters between data structures. As an example, parameters related to time shift and energy between the channels l and r, namely a side gain (or ILD parameter) and ITD parameter of the DFT stereo mode are used to update a target gain and correlation lags (ICA parameters 202) of the TD stereo mode and vice versa. These target gain and correlation lags are further described in next Section 1.2.5 of the present disclosure.
Updates/resets related to the core-encoders (See
1.2.5 ICA encoder
In TD stereo frames, the stereo mode switching controlling operation (not shown) comprises a temporal Inter-Channel Alignment (ICA) operation 251. To perform operation 251, the stereo mode switching controller (not shown) comprises an ICA encoder 201 to time-align the channels l and r of the input stereo signal and then scale the channel r.
As described in the foregoing description, before TD down-mixing, ICA is performed using ITD synchronization between the two input channels l and r in the time-domain. This is achieved by delaying one of the input channels (I or r) and by extrapolating a missing part of the down-mixed signal corresponding to the length of the ITD delay; a maximum value of the ITD delay is 7.5 ms. The time alignment, i.e. the ICA time shift, is applied first and alters the most part of the current TD stereo frame. The extrapolated part of the look-ahead down-mixed signal is recomputed and thus temporally adjusted in the next frame based on the ITD estimated in that next frame.
When no stereo mode switching is anticipated, the 7.5 ms long extrapolated signal is re-computed in the ICA encoder 201. However, when stereo mode switching may happen, namely switching from the DFT stereo mode to the TD stereo mode, a longer signal is subject to re-computation. The length then corresponds to the length of the DFT stereo redressed signal plus the FIR resampling delay, i.e. 8.75 ms+0.9375 ms=9.6875 ms. Section 1.4 explains these features in more detail.
Another purpose of the ICA encoder 201 is the scaling of the input channel r. The scaling gain, i.e. the above mentioned the target gain, is estimated as a logarithm ratio of the l and r channels energies smoothed with the previous frame target gain at every frame regardless of the DFT or TD stereo mode being used. The target gain estimated in the current frame (20 ms) is applied to the last 15 ms of the current input channel r while the first 5 ms of the current channel r is scaled by a combination of the previous and current frame target gains in a fade-in/fade-out manner.
The ICA encoder 201 produces ICA parameters 202 such as the ITD delay, the target gain and a target channel index.
The stereo mode switching controlling operation (not shown) comprises an operation 253 of detecting time-domain transient in the channel l from the ICA encoder 201. To perform operation 253, the stereo mode switching controller (not shown) comprises a detector 203 to detect time-domain transient in the channel l.
In the same manner, the stereo mode switching controlling operation (not shown) comprises an operation 254 of detecting time-domain transient in the channel r from the ICA encoder 201. To perform operation 254, the stereo mode switching controller (not shown) comprises a detector 204 to detect time-domain transient in the channel r.
Time-domain transient detection in the time-domain channels l and r is a pre-processing step that enables detection and, therefore proper processing and encoding of such transients in the transform-domain core encoding modules (TCX core, HQ core, FD-BWE).
Further information regarding the time-domain transient detectors 203 and 204 and the time-domain transient detection operations 253 and 254 can be found, for example, in Reference [1], Clause 5.1.8.
To perform stereo encoder configurations, the IVAS stereo encoding device 200 sets parameters of the stereo encoders 300, 400 and 500. For example, a nominal bit-rate for the core-encoders is set.
Referring to
The DFT stereo encoding method 350 also comprises an operation 352 for applying a DFT transform to the channel r from the time-domain transient detector 204 of
The DFT stereo encoding method 350 further comprises an operation 353 of stereo processing and down-mixing in DFT domain. To perform operation 353, the DFT stereo encoder 300 comprises a stereo processor and down-mixer 303 to produce side information on a side channel S. Down-mixing of the channels L and R also produces a residual signal on the side channel S. The side information and the residual signal from side channel S are coded, for example, using a coding operation 354 and a corresponding encoder 304, and then multiplexed in an output bit-stream 310 of the DFT stereo encoder 300. The stereo processor and down-mixer 303 also down-mixes the left L and right R channels from the DFT calculators 301 and 302 to produce mid-channel M in DFT domain. Further information regarding the operation 353 of stereo processing and down-mixing, the stereo processor and down-mixer 303, the mid-channel M and the side information and residual signal from side channel S can be found, for example, in Reference [3].
In an inverse DFT (IDFT) synthesis operation 355 of the DFT stereo encoding method 350, a calculator 305 of the DFT stereo encoder 300 calculates the IDFT transform m of the mid-channel M at the sampling rate of the input stereo signal, for example 12.8 kHz. In the same manner, in an inverse DFT (IDFT) synthesis operation 356 of the DFT stereo encoding method 350, a calculator 306 of the DFT stereo encoder 300 calculates the IDFT transform m the channel M at the internal sampling rate.
Referring to
Down-mixing using the current frame mixing ratio is performed for example on the last 15 ms of the current frame of the input channels l and r while the first 5 ms of the current frame is down-mixed using a combination of the previous and current frame mixing ratios in a fade-in/fade-out manner to smooth the transition from one channel to the other. The two channels (primary channel PCh and secondary channel SCh) sampled at the stereo input channel sampling rate, for example 32 kHz, are resampled using FIR decimation filters to their representations at 12.8 kHz, and at the internal sampling rate.
In the TD stereo mode, it is not only the stereo input signal of the current frame which is down-mixed. Also, stored down-mixed signals that correspond to the previous frame are down-mixed again. The length of the previous signal subject to this re-computation corresponds to the length of the time-shifted signal re-computed in the ICA module, i.e. 8.75 ms+0.9375 ms=9.6875 ms.
In the IVAS codec (IVAS stereo encoding device 200 and IVAS stereo decoding device 800), there is a restructuration of the traditional pre-processing such that some classification decisions are done on the codec overall bit-rate while other decisions are done depending on the core-encoding bit-rate. Consequently, the traditional pre-processing, as used for example in the EVS codec (Reference [1]), is split into two parts to ensure that the best possible codec configuration is used in each processed frame. Thus, the codec configuration can change from frame to frame while certain changes of configuration can be made as fast as possible, for example those based on signal activity or signal class. On the other hand, some changes in codec configuration should not happen too often, for example selection of coded audio bandwidth, selection of internal sampling rate or bit-budget distribution between low-band and high-band coding; too frequent changes in such codec configuration can lead to unstable coded signal quality or even audible artifacts.
The first part of the pre-processing, the front pre-processing, may include pre-processing and classification modules such as resampling at the pre-processing sampling rate, spectral analysis, Band-Width Detection (BWD), Sound Activity Detection (SAD), Linear Prediction (LP) analysis, open-loop pitch search, signal classification, speech/music classification. It is noted that the decisions in the front pre-processing depend exclusively on the overall codec bit-rate. Further information regarding the operations performed during the above described pre-processing can be found, for example, in Reference [1].
In the DFT stereo mode (DFT stereo encoder 300 of
In the TD stereo mode, the front pre-processing is performed by (a) a front pre-processor 403 and the corresponding front pre-processing operation 453 on the primary channel PCh from the time domain analyzer and down-mixer 401, and (b) a front pre-processor 404 and the corresponding front pre-processing operation 454 on the secondary channel SCh from the time domain analyzer and down-mixer 401.
In the MDCT stereo mode, the front pre-processing is performed by a front pre-processor 503 and the corresponding front pre-processing operation 553 on the input left channel l from the time domain transient detector 203 (
Configurations of the core-encoder(s) is made on the basis of the codec overall bit-rate and front pre-processing.
Specifically, in the DFT stereo encoder 300 and the corresponding DFT stereo encoding method 350 (
In the TD stereo encoder 400 and the corresponding TD stereo encoding method 450 (
The DFT encoding method 350 comprises an operation 362 of further pre-processing. To perform operation 362, a so-called further pre-processor 312 of the DFT stereo encoder 300 conducts a second part of the pre-processing that may include classification, core selection, pre-processing at encoding internal sampling rate, etc. The decisions in the front pre-processor 307 depend on the core-encoding bit-rate which usually fluctuates during a session. Additional information regarding the operations performed during such further pre-processing in DFT domain can be found, for example, in Reference [1].
The TD encoding method 450 comprises an operation 458 of further pre-processing. To perform operation 458, a so-called further pre-processor 408 of the TD stereo encoder 400 conducts, prior to core-encoding the primary channel PCh, a second part of the pre-processing that may include classification, core selection, pre-processing at encoding internal sampling rate, etc. The decisions in the further pre-processor 408 depend on the core-encoding bit-rate which usually fluctuates during a session.
Also, the TD encoding method 450 comprises an operation 459 of further pre-processing. To perform operation 459, the TD stereo encoder 400 comprises a so-called further pre-processor 409 to conduct, prior to core-encoding the secondary channel SCh, a second part of the pre-processing that may include classification, core selection, pre-processing at encoding internal sampling rate, etc. The decisions in the further pre-processor 409 depend on the core-encoding bit-rate which usually fluctuates during a session.
Additional information regarding such further pre-processing in the TD domain can be found, for example, in Reference [1].
The MDCT encoding method 550 comprises an operation 555 of further pre-processing of the left channel l. To perform operation 555, a so-called further pre-processor 505 of the MDCT stereo encoder 500 conducts a second part of the pre-processing of the left channel l that may include classification, core selection, pre-processing at encoding internal sampling rate, etc., prior to an operation 556 of joint core-encoding of the left channel l and the right channel r performed by the joint core-encoder 506 of the MDCT stereo encoder 500.
The MDCT encoding method 550 comprises an operation 557 of further pre-processing of the right channel r. To perform operation 557, a so-called further pre-processor 507 of the MDCT stereo encoder 500 conducts a second part of the pre-processing of the left channel l that may include classification, core selection, pre-processing at encoding internal sampling rate, etc., prior to the operation 556 of joint core-encoding of the left channel l and the right channel r performed by the joint core-encoder 506 of the MDCT stereo encoder 500.
Additional information regarding such further pre-processing in the MDCT domain can be found, for example, in Reference [1].
In general, the core-encoder 311 in the DFT stereo encoder 300 (performing the core-encoding operation 361) and the core-encoders 406 (performing the core-encoding operation 456) and 407 (performing the core-encoding operation 457) in the TD stereo encoder 400 can be any variable bit-rate mono codec. In the illustrative implementation of the present disclosure, the EVS codec (See Reference [1]) with fluctuating bit-rate capability (See Reference [5]) is used. Of course, other suitable codecs may be possibly considered and implemented. In the MDCT stereo encoder 500, the joint core-encoder 506 is employed which can be in general a stereo coding module with stereophonic tools that processes and quantizes the l and r channels in a joint manner.
Finally, common stereo updates are performed. Further information regarding common stereo updates may be found, for example, in Reference [1].
Referring to
Referring to
Referring to
1.3 Switching from the TD Stereo Mode to the DFT Stereo Mode in the IVAS Stereo Encoding Device 200
Switching from the TD stereo mode (TD stereo encoder 400) to the DFT stereo mode (DFT stereo encoder 300) is relatively straightforward as illustrated in
Specifically,
A sufficiently long look-ahead is available, resampling is done in the DFT domain (thus no FIR decimation filter memory handling), and there is a transition from two core-encoders 406 and 407 in the last TD stereo frame 501 to one core-encoder 311 in the first DFT stereo frame 502.
The following operations performed upon switching from the TD stereo mode (TD stereo encoder 400) to the DFT stereo mode (DFT stereo encoder 300) are performed by the above mentioned stereo mode switching controller (not shown) in response to the stereo mode selection.
The instance A) of
The instance B) of
Starting with the first DFT stereo frame 602, certain TD stereo related data structures, for example the TD stereo data structure (as used in the TD stereo encoder 400) and a data structure of the core-encoder 407 related to the secondary channel SCh, are no longer needed and, therefore, are de-allocated, i.e. freed by the stereo mode switching controller (not shown).
In the DFT stereo frame 602 following the TD stereo frame 601, the stereo mode switching controller (not shown) continues the core-encoding operation 361 in the core-encoder 311 of the DFT stereo encoder 300 with memories of the primary PCh channel core-encoder 406 (e.g. synthesis memory, pre-emphasis memory, past signals and parameters, etc.) in the preceding TD stereo frame 601 while controlling time instance differences between the TD and DFT stereo modes to ensure continuity of several core-encoder buffers, e.g. pre-emphasized input signal buffers, HB input buffers, etc. which are later used in the low-band encoder, resp. the FD-BWE high-band encoder. Further information regarding the core-encoding operation 361, memories of the PCh channel core-encoder 406, pre-emphasized input signal buffers, HB input buffers, etc. may be found, for example, in Reference [1].
1.4 Switching from the DFT Stereo Mode to the TD Stereo Mode in the IVAS Stereo Encoding Device 200
Switching from the DFT stereo mode to the TD stereo mode is more complicated than switching from the TD stereo mode to the DFT stereo mode, due to the more complex structure of the TD stereo encoder 400. The following operations performed upon switching from the DFT stereo mode (DFT stereo encoder 300) to the TD stereo mode (TD stereo encoder 400) are performed by the stereo mode switching controller (not shown) in response to the stereo mode selection.
The instance A) of
Since the side channels (
Instance B) in
Referring to
Thus, in operations 712 and 713, the stereo mode switching controller (not shown) recalculates the primary PCh and secondary SCh channels of the DFT stereo frame 701 by down-mixing the ICA-processed channels l and r using a stereo mixing ratio of that frame 701.
For the secondary channel SCh, the length (See 714) of the past segment to be recalculated by the stereo mode switching controller (not shown) in operation 712 is 9.6875 ms although a segment of length of only 7.5 ms (See 715) is recalculated when there is no stereo coding mode switching. For the primary channel PCh (See operation 713), the length of the segment to be recalculated by the stereo mode switching controller (not shown) using the TD stereo mixing ratio of the past frame 701 is always 7.5 ms (See 715). This ensures continuity of the primary PCh and secondary SCh channels.
A continuous down-mixed signal is employed when switching from mid-channel m of the DFT stereo frame 701 to the primary channel PCh of the TD stereo frame 702. For that purpose, the stereo mode switching controller (not shown) cross-fades (717) the 7.5 ms long segment (See 715) of the DFT mid-channel m with the recalculated primary channel PCh (713) of the DFT stereo frame 701 in order to smooth the transition and to equalize for different down-mix signal energy between the DFT stereo mode and the TD stereo mode. The reconstruction of the secondary channel SCh in operation 712 uses the mixing ratio of the frame 701 while no further smoothing is applied because the secondary channel SCh from the DFT stereo frame 701 is not available.
Core-encoding in the first TD stereo frame 702 following the DFT stereo frame 701 then continues with resampling of the down-mixed signals using the FIR filters, pre-emphasizing these signals, computation of HB signals, etc. Further information regarding these operations may be found, for example, in Reference [1].
With respect to the pre-emphasis filter implemented as a first-order high-pass filter used to emphasize higher frequencies of the input signal (See Reference [1], Clause 5.1.4), the stereo mode switching controller (not shown) stores two values of the pre-emphasis filter memory in every DFT stereo frame. These memory values correspond to time instances based on different re-computation length of the DFT and TD stereo modes. This mechanism ensures an optimal re-computation of the pre-emphasis signal in the channel m respectively the primary channel PCh with a minimal signal length. For the secondary channel SCh of the TD stereo mode, the pre-emphasis filter memory is set to zero before the first TD stereo frame is processed.
Starting with the first TD stereo frame 702 following the DFT stereo frame 701, certain DFT stereo related data structures (e.g. DFT stereo data structure mentioned herein above) are not needed, so they are deallocated/freed by the stereo mode switching controller (not shown). On the other hand, a second instance of the core-encoder data structure is allocated and initialized for the core-encoding (operation 457) of the secondary channel SCh. The majority of the secondary channel SCh core-encoder data structures are reset though some of them are estimated for smoother switching transitions. For example, the previous excitation buffer (adaptive codebook of the ACELP core), previous LSF parameters and LSP parameters (See Reference [1]) of the secondary channel SCh are populated from their counterparts in the primary channel PCh. Reset or estimation of the secondary channel SCh previous buffers may be a source of a number of artifacts. While many of such artifacts are significantly suppressed in smoothing-based processes at the decoder, few of them might remain a source of subjective artifacts.
1.5 Switching from the TD Stereo Mode to the MDCT Stereo Mode in the IVAS Stereo Encoding Device 200
Switching from the TD stereo mode to the MDCT stereo mode is relatively straightforward because both these stereo modes handle two input channels and employ two core-encoder instances. The main obstacle is to maintain the correct phase of the input left and right channels.
In order to maintain the correct phase of the input left and right channels of the stereo sound signal, the stereo mode switching controller (not shown) alters TD stereo down-mixing. In the last TD stereo frame before the first MDCT stereo frame, the TD stereo mixing ratio is set to β=1.0 and an opposite-phase down-mixing of the left and right channels of the stereo sound signal is implemented using, for example, the following formula for the TD stereo down-mixing:
PCh(i)=r(i)·(1−β)+l(i)·β
SCh(i)=l(i)·(1−β)+r(i)·β
where PCh(i) is the TD primary channel, SCh(i) is the TD secondary channel, l(i) is the left channel, r(i) is the right channel, β is the TD stereo mixing ratio, and i is the discrete time index.
In turn, this means that the TD stereo primary channel PCh(i) is identical to the MDCT stereo past left channel lpast(i) and the TD stereo secondary channel SCh(i) is identical to the MDCT stereo past right channel rpast(i) where i is the discrete time index. For completeness, it is noted that the stereo mode switching controller (not shown) may use in the last TD stereo frame a default TD stereo down-mixing using for example the following formula:
PCh(i)=r(i)·(1−β)+l(i)·β
SCh(i)=l(i)·(1−β)−r(i)·β
Next, in usual (no stereo mode switching) MDCT stereo processing, the front pre-processing (front pre-processors 503 and 504 and front pre-processing operations 553 and 554) does not recompute the look-ahead of the left l and right r channels of the stereo sound signal except for its last 0.9375 ms long segment. However, in practice, the look-ahead of the length of 7.5+0.9375 ms is subject to re-computation at the internal sampling rate (12.8 kHz in this non-limitative illustrative implementation). Thus, no specific handling is needed to maintain the continuity of input signals at the input sampling rate.
Then, in usual (no stereo mode switching) MDCT stereo processing, the further pre-processing (further pre-processors 505 and 507 and front pre-processing operations 555 and 557) does not recompute the look-ahead of the left l and right r channels of the stereo sound signal except of its last 0.9375 ms long segment. In contrast with the front pre-processing, the input signals (left l and right r channels of the stereo sound signal) at the internal sampling rate (12.8 kHz in this non-limitative illustrative implementation) of a length of only 0.9375 ms are recomputed in the further pre-processing.
In other words:
The MDCT stereo encoder 500 comprises (a) front pre-processors 503 and 504 which, in the second MDCT stereo mode, recompute the look-ahead of first duration of the left l and right r channels of the stereo sound signal at the internal sampling rate, and (b) further pre-processors which, in the second MDCT stereo mode, recompute a last segment of given duration of the look-ahead of the left l and right r channels of the stereo sound signal at the internal sampling rate, wherein the first and second durations are different.
The MDCT stereo coding operation 550 comprises, in the second MDCT stereo mode, (a) recomputing the look-ahead of first duration of the left l and right r channels of the stereo sound signal at the internal sampling rate, and (b) recomputing a last segment of given duration of the look-ahead of the left l and right r channels of the stereo sound signal at the internal sampling rate, wherein the first and second durations are different.
1.6 Switching from the MDCT Stereo Mode to the TD Stereo Mode in the IVAS Stereo Encoding Device 200
Similarly to the switching from the TD stereo mode to the MDCT stereo mode, two input channels are always available and two core-encoder instances are always employed in this scenario. The main obstacle is again to maintain the correct phase of the input left and right channels. Thus, in the first TD stereo frame after the last MDCT stereo frame, the stereo mode switching controller (not shown) sets the TD stereo mixing ratio to β=1.0 and alters TD stereo down-mixing by using the opposite-phase mixing scheme similarly as described in Section 1.5.
Another specific about the switching from the MDCT stereo mode to the TD stereo mode is that the stereo mode switching controller (not shown) properly reconstructs in the first TD frame the past segment of input channels of the stereo sound signal at the internal sampling rate. Thus, a part of the look-ahead corresponding to 8.75−7.5=1.25 ms is reconstructed (resampled and pre-emphasized) in the first TD stereo frame.
1.7 Switching from the DFT Stereo Mode to the MDCT Stereo Mode in the IVAS Stereo Encoding Device 200
A mechanism similar to the switching from the DFT stereo mode to the TD stereo mode as described above is used in this scenario, wherein the primary PCh and secondary SCh channels of the TD stereo mode are replaced by the left l and right r channels of the MDCT stereo mode.
1.8 Switching from the MDCT Stereo Mode to the DFT Stereo Mode in the IVAS Stereo Encoding Device 200
A mechanism similar to the switching from the TD stereo mode to the DFT stereo mode as described above is used in this scenario, wherein the primary PCh and secondary SCh channels of the TD stereo mode are replaced by the left l and right r channels of the MDCT stereo mode.
The IVAS stereo decoding device 800 and corresponding decoding method 850 receive a bit-stream 830 transmitted from the IVAS stereo encoding device 200. Generally speaking, the IVAS stereo decoding device 800 and corresponding decoding method 850 decodes, from the bit-stream 830, successive frames of a coded stereo signal, for example 20-ms long frames as in the case of the EVS codec, performs an up-mixing of the decoded frames, and finally produces a stereo output signal including channels l and r.
Core-decoding, performed at the internal sampling rate, is basically the same regardless of the actual stereo mode; however, core-decoding is done once (mid-channel m) for a DFT stereo frame and twice for a TD stereo frame (primary PCh and secondary SCh channels) or for a MDCT stereo frame (left l and right r channels). An issue is to maintain (update) memories of the secondary channel SCh of a TD stereo frame when switching from a DFT stereo frame to a TD stereo frame, resp. to maintain (update) memories of the r channel of a MDCT stereo frame when switching from a DFT stereo frame to a MDCT stereo frame.
Moreover, further decoding operations after core-decoding strongly depend on the actual stereo mode which consequently complicates switching between the stereo modes. The most fundamental differences are the following:
DFT stereo decoder 801 and decoding method 851:
TD stereo decoder 802 and decoding method 852: (Further information regarding the TD stereo decoder may be found, for example, in Reference [4])
MDCT stereo decoder 803 and decoding method 853:
The different operations during decoding, mainly the DFT “vs” TD domain processing, and the different delay schemes between the DFT stereo mode and the TD stereo mode are carefully taken into consideration in the herein below described procedure for switching between the DFT and TD stereo modes.
The following Table III lists in a sequential order the processing operations in the IVAS stereo decoding device 800 for each frame depending on the current DFT, TD or MDCT stereo mode (See also
The IVAS stereo decoding method 850 comprises an operation (not shown) of controlling switching between the DFT, TD and MDCT stereo modes. To perform the switching controlling operation, the IVAS stereo decoding device 800 comprises a controller (not shown) of switching between the DFT, TD and MDCT stereo modes. Switching between the DFT, TD and MDCT stereo modes in the IVAS stereo decoding device 800 and decoding method 850 involves the use of the stereo mode switching controller (not shown) to maintain continuity of the following several decoder signals and memories 1) to 6) to enable adequate processing of these signals and use of said memories in the IVAS stereo decoding device 800 and method 850:
While it is relatively straightforward to maintain the continuity for one channel (mid-channel m in the DFT stereo mode, respectively primary channel PCh in the TD stereo mode or l channel in the MDCT stereo mode) in item 1) above, it is challenging for the secondary channel SCh in item 1) above and also for signals/memories in items 2)-6) due to several aspects, for example completely missing past signal and memories of the secondary channel SCh, a different down-mixing, a different default delay between DFT stereo mode and TD stereo mode, etc. Also, a shorter decoder delay (3.25 ms) when compared to the encoder delay (8.75 ms) further complicates the decoding process.
The IVAS stereo decoding method 850 starts with reading (not shown) the stereo mode and audio bandwidth information from the transmitted bit-stream 830. Based on the currently read stereo mode, the related decoding operations are performed for each particular stereo mode (see Table III) while memories and buffers of the other stereo modes are maintained.
Similarly as the IVAS stereo encoding device 200, in a memory allocation operation (not shown), the stereo mode switching controller (not shown) dynamically allocates/deallocates data structures (static memory) depending on the current stereo mode. The stereo mode switching controller (not shown) keeps the static memory impact of the codec as low as possible by maintaining only those parts of the static memory that are used in the current frame. Reference is made to Table II for summary of data structures allocated in a particular stereo mode.
In addition, a LRTD stereo sub-mode flag is read by the stereo mode switching controller (not shown) to distinguish between the normal TD stereo mode and the LRTD stereo mode. Based on the sub-mode flag, the stereo mode switching controller (not shown) allocates/deallocates related data structures within the TD stereo mode as shown in Table II.
Similarly as the IVAS stereo encoding device 200, the stereo mode switching controller (not shown) handles memories in case of switching from one the DFT, TD, and MDCT stereo modes to another stereo mode. This keeps updated long-term parameters and updates or resets past buffer memories.
Upon receiving a first DFT stereo frame following a TD stereo frame or MDCT stereo frame, the stereo mode switching controller (not shown) performs an operation of resetting the DFT stereo data structure (already defined in relation to the DFT stereo encoder 300). Upon receiving a first TD stereo frame following a DFT or MDCT stereo frame, the stereo mode switching controller performs an operation of resetting the TD stereo data structure (already described in relation to the TD stereo decoder 400). Finally, upon receiving a first MDCT stereo frame following a DFT or TD stereo frame, the stereo mode switching controller (not shown) performs an operation of resetting the MDCT stereo data structure. Again, upon switching from one the DFT and TD stereo modes to the other stereo mode, the stereo mode switching controller (not shown) performs an operation of transferring some stereo-related parameters between data structures as described in relation to the IVAS stereo encoding device 200 (See above Section 1.2.4).
Updates/resets related to the secondary channel SCh of core-decoding are described in Section 2.4.
Also, further information about the operations of stereo decoder configuration, core-decoder configuration, TD stereo decoder configuration, core-decoding, core switching in DFT domain, core-switching in TD domain in Table III may be found, for example, in References [1] and [2].
The stereo mode switching controller (not shown) maintains or updates the DFT OLA memories in each TD or MDCT stereo frame (See “Update of DFT stereo mode overlap memories”, “Update MDCT stereo TCX overlap buffer” and “Reset/update of DFT stereo overlap memories” of Table III). In this manner, updated DFT OLA memories are available for a next DFT stereo frame. The actual maintaining/updating mechanism and related memory buffers are described later in Section 2.3 of the present disclosure. An example implementation of updating of the DFT stereo OLA memories performed in TD or MDCT stereo frames in the C source code is given below.
The DFT decoding method 851 comprises an operation 857 of core decoding the mid-channel m. To perform operation 857, a core-decoder 807 decodes in response to the received bit-stream 830 the mid-channel m in time domain. The core-decoder 807 (performing the core-decoding operation 857) in the DFT stereo decoder 801 can be any variable bit-rate mono codec. In the illustrative implementation of the present disclosure, the EVS codec (See Reference [1]) with fluctuating bit-rate capability (See Reference [5]) is used. Of course, other suitable codecs may be possibly considered and implemented.
In a DFT calculating operation 854 of the DFT decoding method 851 (DFT analysis of Table III), a calculator 804 computes the DFT of the mid-channel m to recover mid-channel M in the DFT domain.
The DFT decoding method 851 also comprises an operation 858 of decoding stereo side information and residual signal S (residual decoding of Table III). To perform operation 858, a decoder 808 is responsive to the bit-stream 830 to recover the stereo side information and residual signal S.
In a DFT stereo decoding (DFT stereo decoding of Table III) and up-mixing (up-mixing in DFT domain of Table III) operation 859, a DFT stereo decoder and up-mixer 809 produces the channels L and R in the DFT domain in response to the mid-channel M and the side information and residual signal S. Generally speaking, the DFT stereo decoding and up-mixing operation 859 is the inverse to the DFT stereo processing and down-mixing operation 353 of
In IDFT calculating operation 855 (DFT synthesis of Table III), a calculator 805 calculates the IDFT of channel L to recover channel l in time domain. Likewise, in IDFT calculating operation 856 (DFT synthesis of Table III), a calculator 806 calculates the IDFT of channel R to recover channel r in time domain.
The TD decoding method 852 comprises an operation 860 of core-decoding the primary channel PCh. To perform operation 860, a core-decoder 810 decodes in response to the received bit-stream 830 the primary channel PCh.
The TD decoding method 852 also comprises an operation 861 of core-decoding the secondary channel SCh. To perform operation 861, a core-decoder 811 decodes in response to the received bit-stream 830 the secondary channel SCh.
Again, the core-decoder 810 (performing the core-decoding operation 860 in the TD stereo decoder 802) and the core-decoder 811 (performing the core-decoding operation 861 in the TD stereo decoder 802) can be any variable bit-rate mono codec. In the illustrative implementation of the present disclosure, the EVS codec (See Reference [1]) with fluctuating bit-rate capability (See Reference [5]) is used. Of course, other suitable codecs may be possibly considered and implemented.
In a time domain (TD) up-mixing operation 862 (up-mixing in TD domain of Table III), an up-mixer 812 receives and up-mixes the primary PCh and secondary SCh channels to recover the time-domain channels l and r of the stereo signal based on the TD stereo mixing factor.
The MDCT decoding method 853 comprises an operation 863 of joint core-decoding (joint stereo decoding of Table III) the left channel l and the right channel r. To perform operation 863, a joint core-decoder 813 decodes in response to the received bit-stream 830 the left channel l and the right channel r. It is noted that no up-mixing operation is performed and no up-mixer is employed in the MDCT stereo mode.
To perform a stereo synthesis time synchronization (synthesis synchronization of Table III) and stereo switching operation 864, the stereo mode switching controller (not shown) comprises a time synchronizer and stereo switch 814 to receive the channels l and r from the DFT stereo decoder 801, the TD stereo decoder 802 or the MDCT stereo decoder 803 and to synchronize the up-mixed output stereo channels l and r. The time synchronizer and stereo switch 814 delays the up-mixed output stereo channels l and r to match the codec overall delay value and handles transitions between the DFT stereo output channels, the TD stereo output channels and the MDCT stereo output channels.
By default, in the DFT stereo mode, the time synchronizer and stereo switch 814 introduces a delay of 3.125 ms at the DFT stereo decoder 801. In order to match the codec overall delay of 32 ms (frame length of 20 ms, encoder delay of 8.75 ms, decoder delay of 3.25 ms), a delay synchronization of 0.125 ms is applied by the time synchronizer and stereo switch 814. In case of the TD or MDCT stereo mode, the time synchronizer and stereo switch 814 applies a delay consisting of the 1.25 ms resampling delay and the 2 ms delay used for synchronization between the LB and HB synthesis and to match the overall codec delay of 32 ms.
After time synchronization and stereo switching (See the synthesis time synchronization and stereo switching operation 864 and time synchronizer and stereo switch 814 of
Finally, as shown in Table III, common stereo updates are performed.
2.3 Switching from the TD Stereo Mode to the DFT Stereo Mode at the IVAS Stereo Decoding Device
Further information regarding the elements, operations and signals mentioned in section 2.3 and 2.4 may be found, for example, in References [1] and [2].
The mechanism of switching from the TD stereo mode to the DFT stereo mode at the IVAS stereo decoding device 800 is complicated by the fact that the decoding steps between these two stereo modes are fundamentally different (see above Section 2.1 for details) including a transition from two core-decoders 810 and 811 in the last TD stereo frame to one core-decoder 807 in the first DFT stereo frame.
First, the core-decoders 810 and 811 of the TD stereo decoder 802 are used for both the primary PCh and secondary SCh channels and each output the corresponding decoded core synthesis at the internal sampling rate. In the TD stereo frame 901, the decoded core synthesis from the two core-decoders 810 and 811 is used to update the DFT stereo OLA memory buffers (one memory buffer per channel, i.e. two OLA memory buffers in total; See above described DFT OLA analysis and synthesis memories). These OLA memory buffers are updated in every TD stereo frame to be up-to-date in case the next frame is a DFT stereo frame.
The instance A) of
Similarly, the stereo mode switching controller (not shown) updates the DFT stereo Bass Post-Filter (BPF) analysis memory (which is used in the OLA part of the windowing in the previous and current frame before the DFT calculating operation 854) of the mid-channel m at the internal sampling rate, input_mem_BPF[ ], using Lovl last samples of the BPF error signal (See Reference [1], Clause 6.1.4.2) of the TD primary channel PCh. Moreover, the DFT stereo Full Band (FB) analysis memory (this memory is used in the OLA part of the windowing in the previous and current frame before the DFT calculating operation 854) of the mid-channel m at the output stereo signal sampling rate, input_mem[ ], is updated using the 3.125 ms last samples of the TD stereo PCh HB synthesis (ACELP core) respectively PCh TCX synthesis. The DFT stereo BPF and FB analysis memories are not employed for the side information channel s, so that these memories are not updated using the secondary channel SCh core synthesis.
Next, in the TD stereo frame 901, the decoded ACELP core synthesis (primary PCh and secondary SCh channels) at the internal sampling rate is resampled using CLDFB-domain filtering which introduces a delay of 1.25 ms. In case of the TCX/HQ core frame, a compensation delay of 1.25 ms is used to synchronize the core synthesis between different cores. Then the TCX-LTP post-filter is applied to both core channels PCh and SCh.
At the next operation, the primary PCh and secondary SCh channels of the TD stereo synthesis at the output stereo signal sampling rate from the TD stereo frame 901 are subject to TD stereo up-mixing (combination of the primary PCh and secondary SCh channels using the TD stereo mixing ratio in TD up-mixer 812 (See Reference [4]) resulting in up-mixed stereo channels l and r in the time-domain. Since the up-mixing operation 862 is performed in the time-domain, it introduces no up-mixing delay.
Then, the left l and right r up-mixed channels of the TD stereo frame 901 from the up-mixer 812 of the TD stereo decoder 802 are used in an operation (not shown) of updating the DFT stereo synthesis memories (these are used in the OLA part of the windowing in the previous and current frame after the IDFT calculating operation 855). Again, this update is done in every TD stereo frame by the stereo mode switching controller (not shown) in case the next frame is a DFT stereo frame. Instance B) of
Specifically, the DFT stereo synthesis memories are updated by the stereo mode switching controller (not shown) using the following sub-operations as illustrated in
(a) The two channels l and r of the DFT stereo analysis memories at the internal sampling rate, input_mem_LB[ ], as reconstructed earlier during the decoding method 850 (they are identical to the core synthesis at the internal sampling rate), are subject to further processing depending on the actual decoding core:
(b) The linearly resampled LB signals corresponding to the 3.125 ms long part of the primary PCh and secondary SCh channels of the TD stereo frame 901 are up-mixed (See 1003) to form left l and right r channels, using the common TD stereo up-mixing routine while the TD stereo mixing ratio from the current frame is used (see TD up-mixing operation 862). The resulting signal is further called “reconstructed synthesis” 1002.
(c) The reconstruction of the first (3.125-1.25 ms) long part of the DFT stereo synthesis memories depends on the actual decoding core:
(d) The 1.25 ms long last part of the DFT stereo synthesis memories is filled up with the last portion of the reconstructed synthesis 1002.
(e) The DFT synthesis window (904 in
Finally, the up-mixed reconstructed synthesis 1002 of the TD stereo frame 901 is aligned, i.e. delayed by 2 ms in the time synchronizer and stereo switch 814 in order to match the codec overall delay. Specifically:
Referring to
Decoding then continues regardless of the current stereo mode with the IC-BWE calculator 815, the ICA decoder 816 and common stereo decoder updates.
2.4 Switching from the DFT Stereo Mode to the TD Stereo Mode at the IVAS Stereo Decoding Device
The fundamentally different decoding operations between the DFT stereo mode and the TD stereo mode and the presence of two core-decoders 810 and 811 in the TD stereo decoder 802 makes switching from the DFT stereo mode to the TD stereo mode in the IVAS stereo decoding device 800 challenging.
Core-decoding may use a same processing regardless of the actual stereo mode with two exceptions.
First exception: In DFT stereo frames, resampling from the internal sampling rate to the output stereo signal sampling rate is performed in the DFT domain but the CLDFB resampling is run in parallel in order to maintain/update CLDFB analysis and synthesis memories in case the next frame is a TD stereo frame.
Second exception: Then, the BPF (Bass Post-Filter) (a low-frequency pitch enhancement procedure, see Reference [1], Clause 6.1.4.2) is applied in the DFT domain in DFT stereo frames while the BPF analysis and computation of error signal is done in the time-domain regardless of the stereo mode.
Otherwise, all internal states and memories of the core-decoder are simply continuous and well maintained when switching from the DFT mid-channel m to the TD primary channel PCh.
In the DFT stereo frame 1201, decoding then continues with core-decoding (857) of mid-channel m, calculation (854) of the DFT transform of the mid-channel m in the time domain to obtain mid-channel M in the DFT domain, and stereo decoding and up-mixing (859) of channels M and S into channels L and R in the DFT domain including decoding (858) of the residual signal. The DFT domain analysis and synthesis introduces an OLA delay of 3.125 ms. The synthesis transitions are then handled in the time synchronizer and stereo switch 814.
Upon switching from the DFT stereo frame 1201 to the TD stereo frame 1202, the fact that there is only one core-decoder 807 in the DFT stereo decoder 801 makes core-decoding of the TD secondary channel SCh complicated because the internal states and memories of the second core-decoder 811 of the TD stereo decoder 802 are not continuously maintained (on the contrary, the internal states and memories of the first core-decoder 810 are continuously maintained using the internal states and memories of the core-decoder 807 of the DFT stereo decoder 801). The memories of the second core-decoder 811 are thus usually reset in the stereo mode switching updates (See Table III) by the stereo mode switching controller (not shown). There are however few exceptions where the primary channel SCh memory is populated with the memory of certain PCh buffers, for example previous excitation, previous LSF parameters and previous LSP parameters. In any case, the synthesis at the beginning of the first TD secondary channel SCh frame after switching from the DFT stereo frame 1201 to the TD stereo frame 1202 consequently suffers from an imperfect reconstruction. Accordingly, while the synthesis from the first core-decoder 810 is well and smoothly decoded during stereo mode switching, the limited-quality synthesis from the second core decoder 811 introduces discontinuities during the stereo up-mixing and final synthesis (862). These discontinuities are suppressed by employing the DFT stereo OLA memories during the first TD stereo output synthesis reconstruction as described later.
The stereo mode switching controller (not shown) suppresses possible discontinuities and differences between the DFT stereo and the TD stereo up-mixed channels by a simple equalization of the signal energy. If the ICA target gain, gICA, is lower than 1.0, the channel l, yL(i), after the up-mixing (862) and before the time synchronization (864) is altered in the first TD stereo frame 1202 after stereo mode switching using the following relation:
y′
L(i)=α·yL(i) for i=0, . . . ,Leq−1
where Leq is the length of the signals to equalize which corresponds in the IVAS stereo decoding device 800 to a 8.75 ms long segment (which corresponds for example to Leq=140 samples at a 16 kHz output stereo signal sampling rate). Then, the value of the gain factor α is obtained using the following relation:
Referring to
Referring to both
(a) The DFT stereo OLA synthesis memories (defined herein above) are redressed (i.e. the inverse synthesis window is applied to the OLA synthesis memories; See 1301).
(b) The first 0.125 ms part 1302 (See 1204 in
(c) The second part (See 1203 in
(d) The part of the TD stereo up-mixed synchronized synthesis 1303 with a length of 2 ms from the previous two steps (b) and (c) is then populated to the output stereo synthesis in the first TD stereo frame 1202.
(e) A smoothing of the transition between the previous DFT stereo OLA synthesis memory 1301 and the TD synchronized up-mixed synthesis 1305 from operation 864 of the current TD stereo frame 1202 is performed at the beginning of the TD stereo synchronized up-mixed synthesis 1305. The transition segment is 1.25 ms long (See 1306) and is obtained using a cross-fading 1307 between the redressed DFT stereo OLA synthesis memory 1301 and the TD stereo synchronized up-mixed synthesis 1305.
2.5 Switching from the TD Stereo Mode to the MDCT Stereo Mode in the IVAS Stereo Decoding Device
Switching from the TD stereo mode to the MDCT stereo mode is relatively straightforward because both these stereo modes handle two transport channels and employ two core-decoder instances.
As an opposite-phase down-mixing scheme was employed in the TD stereo encoder 400, the stereo mode switching controller (not shown) similarly alters the TD stereo channel up-mixing to maintain the correct phase of the left and right channels of the stereo sound signal in the last TD stereo frame before the first MDCT stereo frame. Specifically, the stereo mode switching controller (not shown) sets the mixing ratio β=1.0 and implements an opposite-phase up-mixing (inverse to opposite-phase down-mixing employed in the TD stereo encoder 400) of the TD stereo primary channel PCh(i) and TD stereo secondary channel SCh(i) to calculate the MDCT stereo past left channel lpast(i) and the MDCT stereo past right channel rpast(i). Consequently, the TD stereo primary channel PCh(i) is identical to the MDCT stereo past left channel lpast(i) and the TD stereo secondary channel SCh(i) signal is identical to the MDCT stereo past right channel rpast(i).
2.6 Switching from the MDCT Stereo Mode to the TD Stereo Mode in the IVAS Stereo Decoding Device
Similarly to the switching from the TD stereo mode to the MDCT stereo mode, two transport channels are available and two core-decoder instances are employed in this scenario. In order to maintain the correct phase of the left and right channels of the stereo sound signal, the TD stereo mixing ratio is set to 1.0 and the opposite-phase up-mixing scheme is used again by the stereo mode switching controller (not shown) in the first TD stereo frame after the last MDCT stereo frame.
2.7 Switching from the DFT Stereo Mode to the MDCT Stereo Mode in the IVAS Stereo Decoding Device
A mechanism similar to the decoder-side switching from the DFT stereo mode to the TD stereo mode is used in this scenario, wherein the primary PCh and secondary SCh channels of the TD stereo mode are replaced by the left l and right r channels of the MDCT stereo mode.
2.8 Switching from the MDCT Stereo Mode to the DFT Stereo Mode in the IVAS Stereo Decoding Device
A mechanism similar to the decoder-side switching from the TD stereo mode to the DFT stereo mode is used in this scenario, wherein the primary PCh and secondary SCh channels of the TD stereo mode are replaced by the left l and right r channels of the MDCT stereo mode.
Finally, the decoding continues regardless of the current stereo mode with the IC-BWE decoding 865 (skipped in the the MDCT stereo mode), adding of the HB synthesis (skipped in the MDCT stereo mode), temporal ICA alignment 866 (skipped in the MDCT stereo mode) and common stereo decoder updates.
Each of the IVAS stereo encoding device 200 and IVAS stereo decoding device 800 may be implemented as a part of a mobile terminal, as a part of a portable media player, or in any similar device. Each of the IVAS stereo encoding device 200 and IVAS stereo decoding device 800 (identified as 1400 in
The input 1402 is configured to receive the left l and right r channels of the input stereo sound signal in digital or analog form in the case of the IVAS stereo encoding device 200, or the bit-stream 803 in the case of the IVAS stereo decoding device 800. The output 1404 is configured to supply the multiplexed bit stream 206 in the case of the IVAS stereo encoding device 200 or the decoded left channel l and right channel r in the case of the IVAS stereo decoding device 800. The input 1402 and the output 1404 may be implemented in a common module, for example a serial input/output device.
The processor 1406 is operatively connected to the input 1402, to the output 1404, and to the memory 1408. The processor 1406 is realized as one or more processors for executing code instructions in support of the functions of the various elements and operations of the above described IVAS stereo encoding device 200, IVAS stereo encoding method 250, IVAS stereo decoding device 800 and IVAS stereo decoding method 850 as shown in the accompanying figures and/or as described in the present disclosure.
The memory 1408 may comprise a non-transient memory for storing code instructions executable by the processor 1406, specifically, a processor-readable memory storing non-transitory instructions that, when executed, cause a processor to implement the elements and operations of the IVAS stereo encoding device 200, IVAS stereo encoding method 250, IVAS stereo decoding device 800 and IVAS stereo decoding method 850. The memory 1408 may also comprise a random access memory or buffer(s) to store intermediate processing data from the various functions performed by the processor 1406.
Those of ordinary skill in the art will realize that the description of the IVAS stereo encoding device 200, IVAS stereo encoding method 250, IVAS stereo decoding device 800 and IVAS stereo decoding method 850 are illustrative only and are not intended to be in any way limiting. Other embodiments will readily suggest themselves to such persons with ordinary skill in the art having the benefit of the present disclosure. Furthermore, the disclosed IVAS stereo encoding device 200, IVAS stereo encoding method 250, IVAS stereo decoding device 800 and IVAS stereo decoding method 850 may be customized to offer valuable solutions to existing needs and problems of encoding and decoding stereo sound.
In the interest of clarity, not all of the routine features of the implementations of the IVAS stereo encoding device 200, IVAS stereo encoding method 250, IVAS stereo decoding device 800 and IVAS stereo decoding method 850 are shown and described. It will, of course, be appreciated that in the development of any such actual implementation of the IVAS stereo encoding device 200, IVAS stereo encoding method 250, IVAS stereo decoding device 800 and IVAS stereo decoding method 850, numerous implementation-specific decisions may need to be made in order to achieve the developer's specific goals, such as compliance with application-, system-, network- and business-related constraints, and that these specific goals will vary from one implementation to another and from one developer to another. Moreover, it will be appreciated that a development effort might be complex and time-consuming, but would nevertheless be a routine undertaking of engineering for those of ordinary skill in the field of sound processing having the benefit of the present disclosure.
In accordance with the present disclosure, the elements, processing operations, and/or data structures described herein may be implemented using various types of operating systems, computing platforms, network devices, computer programs, and/or general purpose machines. In addition, those of ordinary skill in the art will recognize that devices of a less general purpose nature, such as hardwired devices, field programmable gate arrays (FPGAs), application specific integrated circuits (ASICs), or the like, may also be used. Where a method comprising a series of operations and sub-operations is implemented by a processor, computer or a machine and those operations and sub-operations may be stored as a series of non-transitory code instructions readable by the processor, computer or machine, they may be stored on a tangible and/or non-transient medium.
Elements and processing operations of the IVAS stereo encoding device 200, IVAS stereo encoding method 250, IVAS stereo decoding device 800 and IVAS stereo decoding method 850 as described herein may comprise software, firmware, hardware, or any combination(s) of software, firmware, or hardware suitable for the purposes described herein.
In the IVAS stereo encoding method 250 and IVAS stereo decoding method 850 as described herein, the various processing operations and sub-operations may be performed in various orders and some of the processing operations and sub-operations may be optional.
Although the present disclosure has been described hereinabove by way of non-restrictive, illustrative embodiments thereof, these embodiments may be modified at will within the scope of the appended claims without departing from the spirit and nature of the present disclosure.
The present disclosure mentions the following references, of which the full content is incorporated herein by reference:
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/CA2021/050114 | 2/1/2021 | WO |
Number | Date | Country | |
---|---|---|---|
62969203 | Feb 2020 | US |