The present disclosure relates generally to communications, and more particularly to methods and apparatuses for controlling a packet loss concealment for mono, stereo or multichannel audio encoding and decoding.
Modern telecommunication services generally provide reliable connections between the end users. However, such services still need to handle varying channel conditions where occasional data packets may be lost due to e.g. network congestion or poor cell coverage. To overcome the problem of transmission errors and lost packages, telecommunication services may make use of Packet Loss Concealment techniques (PLC). In the case that data packets are lost due to poor connection, network congestion, etc., the missing information of lost packets in the receiver side may be substituted in the decoder by a synthetic signal. PLC techniques may often be tied closely to the decoder, where the internal states can be used to produce a signal continuation or extrapolation to cover the packet loss. For a multi-mode codec having several operating modes for different signal types, there are often several PLC technologies to handle the concealment. There are many different terms used for the packet loss concealment techniques, including Frame Error Concealment (FEC), Frame Loss Concealment (FLC), and Error Concealment Unit (ECU).
For linear prediction (LP) based speech coding modes, the PLC may be based on adjustment of glottal pulse positions using estimated end-of-frame pitch information and replication of pitch cycle of the previous frame [1]. The gain of the long-term predictor (LTP) converges to zero with the speed depending on the number of consecutive lost frames and the stability of the last good, i.e. error free, frame [2]. Frequency domain (FD) based coding modes are designed to handle general or complex signals such as music. Different techniques may be used depending on the characteristics of last received frame. Such analysis may include the number of detected tonal components and periodicity of the signal. If the frame loss occurs during a highly periodic signal such as active speech or single instrumental music, a time domain PLC, similar to the LP based PLC, may be suitable. In this case the FD PLC may mimic an LP decoder by estimating LP parameters and an excitation signal based on the last received frame [2]. In case the lost frame occurs during a non-periodic or noise-like signal, the last received frame may be repeated in spectral domain where the coefficients are multiplied to a random sign signal to reduce the metallic sound of a repeated signal. For a stationary tonal signal, it has been found advantageous to use an approach based on prediction and extrapolation of the detected tonal components. More details about the above-mentioned techniques can be found in [1][2][3].
A generic error concealment method operating in the frequency domain is the Phase ECU (Error Concealment Unit) [4]. The Phase ECU is a stand-alone tool operating on a buffer of the previously decoded and reconstructed time domain signal. The framework of the Phase ECU is based on the sinusoidal analysis and synthesis paradigm. In this method, the sinusoid components of the last good frame may be extracted and phase shifted. When a frame is lost, the sinusoid frequencies are obtained in DFT (discrete Fourier transform) domain from the past decoded synthesis. First, the corresponding frequency bins are identified by finding the peaks of the magnitude spectrum plane. Then, fractional frequencies of the peaks are estimated using peak frequency bins. The frequency bins corresponding to the peaks along with the neighbours are phase shifted using fractional frequencies. For the rest of the frame the magnitude of the past synthesis is retained while the phase is randomized. The burst error is also handled such that the estimated signal is smoothly muted by converging it to zero. More details on the Phase ECU can be found in [4].
The concept of the Phase ECU may be used in decoders operating in frequency domain. This concept includes encoding and decoding systems which perform the decoding in frequency domain, as illustrated in
Since a frequency domain spectrum is already produced for each frame, the raw material for the Phase ECU can easily be obtained by simply storing the last decoded spectrum in memory. However, if the decoded spectra correspond to frames of the time domain signal with different windowing functions (see
One drawback with applying the frequency domain ECU on individual subframes is that there may be differences between the subframes which will be replicated for each subframe during the lost frame. For consecutive frame losses, this may lead to a repetitious artefact since each subframe may have a slightly different spectral signature. Another problem is that memory requirement is increased, since a spectrum of each subframe needs to be stored.
The window re-dressing solution where the windowing is inversed and reapplied, overcomes the issue of the different spectral signatures since the ECU may be based on a single subframe. However, applying the inverted window and applying a new window involves a division and a multiplication for each sample, where the division is a computationally complex operation and computationally expensive. This solution could be improved by storing a pre-computed re-dressing window in memory, but this would increase the required table memory. In case the ECU is applied on a subpart of the spectrum, it may further require that the full spectrum is re-dressed since the full spectrum needs to have the same window shape.
According to a first aspect, a method is proved to generate a concealment audio subframe of an audio signal in a decoding device. The method comprises generating frequency spectra on a subframe basis where consecutive subframes of the audio signal have a property that an applied window shape of first subframe of the consecutive subframes is a mirrored version or a time reversed version of a second subframe of the consecutive subframes. The method further comprises detecting peaks of a signal spectrum of a previously received audio signal on a fractional frequency scale, estimating a phase of each of the peaks and deriving a time reversed phase adjustment to apply to the peaks of the signal spectrum based on the estimated phase to form time reversed phase adjusted peaks. The method further comprises applying a time reversal to the concealment audio subframe.
A potential advantage provided is that a multi-subframe ECU is generated from a single subframe spectrum by applying a reversed time synthesis. This generating may be suited for cases where the subframe windows are time reversed versions of each other. Generating all ECU frames from a single stored decoded frame ensures that the subframes have a similar spectral signature, while keeping the memory footprint and computational complexity at a minimum.
According to a second aspect, a decoder device configured to generate a concealment audio subframe of an audio signal is proved. The decoder device is configured to generate frequency spectra on a subframe basis where consecutive subframes of the audio signal have a property that an applied window shape of first subframe of the consecutive subframes is a mirrored version or a time reversed version of a second subframe of the consecutive subframes. The decoder device is further configured to detect peaks of a signal spectrum of a previously received audio signal on a fractional frequency scale and to estimate a phase of each of the peaks. The decoder device is further configured to derive a time reversed phase adjustment to apply to the peaks of the signal spectrum based on the estimated phase and to form time reversed phase adjusted peaks by applying the time reversed phase adjustment to the peaks of the signal spectrum. The decoder device is further configured to apply a time reversal to the concealment audio subframe.
According to a third aspect, a computer program is provided. The computer program comprises program code to be executed by processing circuitry of a decoder device configured to operate in a communication network, whereby execution of the program code causes the decoder device to perform operations according to the first aspect.
According to a fourth aspect, a computer program product is provided. The computer program product comprises a non-transitory storage medium including program code to be executed by processing circuitry of a decoder device configured to operate in a communication network, whereby execution of the program code causes the decoder device to perform operations according to the first aspect.
According to a fifth aspect, a method is provided to generate a concealment audio subframe for an audio signal in a decoding device. The method comprises generating frequency spectra on a subframe basis where consecutive subframes of the audio signal have a property that an applied window shape of first subframe of the consecutive subframes is a mirrored version or a time reversed version of a second subframe of the consecutive subframes. A signal spectrum corresponding to a second subframe of a first two consecutive subframes is stored. The method further comprises receiving a bad frame indicator for a second two consecutive subframes. The method further comprises obtaining the signal spectrum, detecting peaks of the signal spectrum on a fractional frequency scale, estimating a phase of each of the peaks and deriving a time reversed phase adjustment to apply to the peaks of the spectrum stored for a first subframe of the second two consecutive subframes based on the estimated phase. The method further comprises applying the time reversed phase adjustment to the peaks of the signal spectrum to form time reversed phase adjusted peaks. The method further comprises applying a time reversal to the concealment audio subframe, combining the time reversed phase adjusted peaks with a noise spectrum of the signal spectrum to form a combined spectrum for the first subframe of the second two consecutive subframes, and generating a synthesized concealment audio subframe based on the combined spectrum.
According to a sixth aspect, a decoder device configured to generate a concealment audio subframe of an audio signal is proved. The decoder device comprises a processing circuitry and a memory operatively coupled with the processing circuitry, wherein the memory includes instructions that when executed by the processing circuitry causes the decoder device to perform operations according to the first or fifth aspect.
According to a seventh aspect, a decoder device is provided. The decoder device is configured to generate a concealment audio subframe of an audio signal, wherein the decoder device is adapted to perform the method according to the fifth aspect.
According to an eighth aspect, a computer program is provided. The computer program comprises program code to be executed by processing circuitry of a decoder device configured to operate in a communication network, whereby execution of the program code causes the decoder device to perform operations according to the fifth aspect.
According to a ninth aspect, a computer program product is provided. The computer program product comprises a non-transitory storage medium including program code to be executed by processing circuitry of a decoder device configured to operate in a communication network, whereby execution of the program code causes the decoder device to perform operations according to the fifth aspect.
The accompanying drawings, which are included to provide a further understanding of the disclosure and are incorporated in and constitute a part of this application, illustrate certain non-limiting embodiments. In the drawings:
The aspects of the present disclosure will now be described more fully hereinafter with reference to the accompanying drawings, in which examples of embodiments are shown. Embodiments may, however, be embodied in many different forms and should not be construed as limited to the embodiments set forth herein. Rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of present embodiments to those skilled in the art. It should also be noted that these embodiments are not mutually exclusive. Components from one embodiment may be tacitly assumed to be present/used in another embodiment.
The following description presents various embodiments of the disclosed subject matter. These embodiments are presented as teaching examples and are not to be construed as limiting the scope of the disclosed subject matter. For example, certain details of the described embodiments may be modified, omitted, or expanded upon without departing from the scope of the described subject matter.
According to other embodiments, processor circuit 902 may be defined to include memory so that a separate memory circuit is not required. As discussed herein, operations of the decoder 900 may be performed by processor 902 and/or network interface 906. For example, processor 902 may control network interface 906 to transmit communications to multichannel audio players and/or to receive communications through network interface 906 from one or more other network nodes/entities/servers such as encoder nodes, depository servers, etc. Moreover, modules may be stored in memory 904, and these modules may provide instructions so that when instructions of a module are executed by processor 902, processor 902 performs respective operations.
In the description that follows, subframe notation shall be used to describe the embodiments. Here, a subframe denotes a part of a larger frame where the larger frame is composed of a set of subframes. The embodiments described may also be used with frame notation. In other words, the subframes may form groups of frames that have the same window shape as described herein and subframes do not need to be part of a larger frame.
Consider a decoder of an encoder and decoder pair where the decoding method generates frequency spectra on a subframe basis. The consecutive subframes may have the property that the applied window shape is mirrored or time reversed versions of each other, as illustrated in
where N denotes the length of the subframe window and Nstep12 is the distance in samples between the starting point of the first and second subframe. The subframe windowing functions w1(n) and w2 (n) are mirrored or time reversed versions of each other. Here, the subframe spectra are obtained from a decoder time domain synthesis, similar to the system outlined in
For correctly received frames, the decoder device 900 may proceed with preforming the frequency domain processing steps, performing the inverse DFT transform and reconstructing the output audio using an overlap-add strategy. Missing or corrupted frames may be identified by the transport layer handling the connection and is signaled to the decoder as a “bad frame” through a Bad Frame Indicator (BFI), which may be in the form of a flag. When the decoder device 900 detects a bad frame through a bad frame indicator (BFI), the PLC algorithm is activated. The PLC follows the principle of the Phase ECU [4]. The stored spectrum {circumflex over (X)}mem(k) is input to a peak detector algorithm that detects peaks on a fractional frequency scale. A set of peaks
may be detected which are represented by their estimated fractional frequency fi and where Npeaks is the number of detected peaks. Similar to the sinusoidal coding paradigm, the peaks of the spectrum are modelled with sinusoids with a certain amplitude, frequency and phase. The fractional frequency may be expressed as a fractional number of DFT bins, such that e.g. the Nyquist frequency is found at f=N/2+1. Each peak may be associated with a number of frequency bins representing the peak. These are found by rounding the fractional frequency to the closest integer and including the neighboring bins, e.g. the Nnear peaks on each side:
where [⋅] represents the rounding operation and Gi is the group of bins representing the peak at frequency fi. The number Nnear is a tuning constant that may be determined when designing the system. A larger Nnear provides higher accuracy in each peak representation, but also introduces a larger distance between peaks that may be modeled. A suitable value for Nnear may be 1 or 2. The peaks of the concealment spectrum {circumflex over (X)}ECU(m, k) may be formed by using these groups of bins, where a phase adjustment has been applied to each group. The phase adjustment accounts for the change in phase in the underlying sinusoid, assuming that the frequency remains the same between the last correctly received and decoded frame and the concealment frame. The phase adjustment is based on the fractional frequency and the number of samples between the analysis frame of the previous frame and where the current frame would start. As illustrated in
where Nlost denotes the number of consecutive lost frames and ϕi denotes the phase of the sinusoid at frequency fi. The term (Nlost−1)Nfull handles the phase progression for burst errors, where the step is incremented with the frame length of the full frame Nfull. For the first lost frame, Nlost=1. For frequencies that are centered on the frequency bins of the spectrum {circumflex over (X)}mem(k) the phase ϕi is readily available just by extracting the angle:
In general, the frequency fi is a fractional number and the phase needs to be estimated in operation 501. One estimation method is to use linear interpolation of the phase spectrum.
where [⋅] and [⋅] represent the operators for rounding down and up respectively. However, this estimation method was found to be unstable. This estimation method further requires two phase extractions, which requires the computationally complex arctan function in case the spectrum is represented with complex numbers in the standard form a+bi. Another phase estimation that was found reliable at relatively low computational complexity is
where ffrac is the rounding error and ϕc is a tuning constant which depends on the window shape that is applied. For the window shape of this embodiment, a suitable value was found to be ϕc=0.33. For another window shape it was found to be ϕc=0.48. In general, it is expected that a suitable value can be found in the range [0.1,0.7]. In operation 502 a time reversed phase adjustment Δϕi is derived as explained above.
The peaks of the concealment spectrum may be formed by applying the phase adjustment to the stored spectrum in operation 503.
The asterisk ‘*’ denotes the complex conjugate, which gives a time reversal of the signal in operation 504. This results in a time reversal of the first ECU subframe. It should be noted that it may also be possible to perform the reversal in time domain after inverse DFT. However, if {circumflex over (X)}ECU(m, k) only represents a part of the complete spectrum this requires that the remaining spectrum is pretreated e.g. by a time reversal before the DFT analysis.
The remaining bins of {circumflex over (X)}ECU(m, k), which are not occupied by the peak bins Gi, may be referred to as the noise spectrum or the noise component of the spectrum. They may be populated using the coefficients of the stored spectrum with a random phase applied:
where ϕrand denotes a random phase value. The remaining bins may also be populated with spectral coefficients that retain a desired property of the signal, e.g. correlation with a second channel in a multichannel decoder system. In operation 505 the peak spectrum {circumflex over (X)}ECU(m,k), where k ∈Gi, is combined with the noise spectrum {circumflex over (X)}ECU(m,k), where k ∉Gi to form a combined spectrum.
In embodiments where noise is generated in the time domain and is windowed and transformed, a time reversal of the noise to match the windowing of the peak components and the combination with the peak spectrum should be performed prior to applying the time reversal described above.
For the generation of the second subframe, which is synthesized in normal (non-reversed) time, the regular phase adjustment may be used.
The ECU synthesis for the second subframe may be formed similar to the first subframe, but omitting the complex conjugate on the peak coefficients.
Once the combined concealment spectrum is generated in operation 505, the combined concealment spectrum may be fed to the following processing steps in operation 506, including inverse DFT and an overlap-add operation which results in an output audio signal.
The output audio signal may be transmitted to one or more speakers such as loudspeakers for playback. The speakers may be part of the decoding device, be a separate device, or part of another device.
Derivation of Phase Correction Formula For Time Reversed ECU Synthesis
Assume the start phase of the sinusoid component is ϕ0 and that the frequency of the sinusoid is f. The desired phase ϕ1 of the sinusoid after advancing by Nstep samples is then
For a time-reversed continuation of the sinusoid, the phase needs to be mirrored in the real axis by applying the complex conjugate or by simply taking the negative phase −ϕ1. Since this phase angle now represents the endpoint of the ECU synthesis frame, the phase needs to be wound back by the length of the analysis frame to get to the desired start phase ϕ2.
To obtain a phase correction Δϕ, the start phase needs to be subtracted, i.e.,
Substituting ϕ2 gives
To add progression for consecutive frame losses (burst loss), a factor corresponding to the number of samples between the starting points of the full frames can be added, Noffset=(Nlost−1)Nfull. This provides the final phase correction
The desired time reversal can be achieved in DFT domain by using a complex conjugate together with a one-sample circular shift. This circular shift can be implemented with a phase correction of 2πk/N which may be included in the final phase correction.
For the coefficients representing a single peak, the frequency bin k of the circular shift can be approximated with the fractional frequency k≈f, and the phase correction may be simplified to
The windows may be designed such that N=Nfull, in which case the expression can be further simplified to
An Alternative Embodiment of the Reversed Time ECU Synthesis
In another embodiment, the phase correction is done in two steps. The phase is advanced in a first step, ignoring the mismatch of the window.
In a second step, the time reversal of the windowing may be achieved by turning the phase back by −ϕm, applying the complex conjugate and restoring the phase with ϕm:
The motivation for this operation can be found by studying the effect of a time reversed window on a sinusoid as illustrated in
Through experimentation, it was found that ϕfrac could be expressed as
where [⋅] denotes the rounding operation. It was also found that ϕO249 , expressed as a positive angle, can be approximated by a linear relation with ffrac. In
where ϕc is a constant. In one embodiment, ϕc may be set to ϕc=0.33, which yields a close approximation. Since ϕ0 is not explicitly known, an alternative approximation of ϕm can be written as
where ϕk
The operation of aligning the mirroring plane with the real axis, applying the complex conjugate and turning the phase back again can be understood as adjusting the phase of the shaped sinusoid to a phase position which is neutral to the complex conjugate (0 or π), thereby only reversing the temporal shape of the signal. The two-step approach is more computationally complex than the formerly described embodiment. However, the observations can also lead to an approximation of ϕ0. It can be seen from
which is the phase approximation used above.
Operations of the decoder device 900 (implemented using the structure of the block diagram of
In operation 1000, processing circuitry 902 generates frequency spectra on a subframe basis where consecutive subframes of the audio signal have a property that an applied window shape of first subframe of the consecutive subframes is a mirrored version or a time reversed version of a second subframe of the consecutive subframes. For example, generating the frequency spectra of for each subframe of the first two consecutive subframes comprises determining:
where N denotes a length of a subframe window, subframe windowing function w1(n) is a subframe windowing function for the first subframe {circumflex over (X)}1(m, k) of the consecutive subframes and w2(n) is a subframe windowing function for the second subframe {circumflex over (X)}2(m,k) of the consecutive subframes, and Nstep12 is a number of samples between a first subframe of the first two consecutive subframes and the second subframe of the first two consecutive subframes.
In operation 1002, the processing circuitry 902 determines if a bad frame indicator (BFI) has been received. The bad frame indicator provides an indication that an audio frame has been lost or has been corrupted.
In operation 1004, the processing circuitry 902 stores, for each correctly decoded audio frame, the spectrum corresponding to the second subframe in memory. For example, for a correctly decoded frame m, the spectrum corresponding to the second subframe {circumflex over (X)}2(m,k) is stored in memory such as {circumflex over (X)}mem(k)={circumflex over (X)}2(m,k). For correctly received frames, the decoder device 900 may proceed with preforming the frequency domain processing steps, performing the inverse DFT transform and reconstructing the output audio using an overlap-add strategy as described above and illustrated in
When the processing circuitry 902 detects a bad frame through a bad frame indicator (BFI) in operation 1002, the PLC operations 1006 to 1030 are performed.
In operation 1006, the processing circuitry 902 obtains the signal spectrum corresponding to the second subframe of a first two consecutive subframes previously correctly decoded and processed. For example, the processing circuitry 902 may obtain the signal spectrum from the memory 904 of the decoding device.
In operation 1008, the processing circuitry 902 detects peaks of the signal spectrum of a previously received audio frame of the audio signal on a fractional frequency scale, the previously received audio frame received prior to receiving the bad frame indicator.
In operation 1010, the processing circuitry 902 determines whether the concealment frame is for the first subframe of two consecutive subframes.
If the concealment frame is for the first subframe, in operation 1012, the processing circuitry 902 estimates the phase of each of the peaks. In one embodiment, calculating a phase estimation for the peaks of the time reversed phase corrected peaks in accordance with:
where ϕi is an estimated phase at frequency fi, ∠{circumflex over (X)}mem(ki) is an angle of spectrum {circumflex over (X)}mem at a frequency bin ki, ffrac is a rounding error, ϕc is a tuning constant, and ki is [fi]. The tuning constant ϕc may be a value in a range between 0.1 and 0.7.
In operation 1014, the processing circuitry 902 derives a time reversed phase correction to apply to the peaks of the signal spectrum based on the estimated phase.
In operation 1016, the processing circuitry 902 applies the time reversed phase correction to the peaks of the signal spectrum to form time reversed phase corrected peaks.
In operation 1018, the processing circuitry 902 applies a time reversal to the concealment audio subframe. In one embodiment, the time reversal may be applied by applying a complex conjugate to the concealment audio subframe.
In operation 1020, the processing circuitry 902 combines the time reversed phase corrected peaks with a noise spectrum of the signal spectrum to form a combined spectrum of the concealment audio subframe.
Turning to
Returning to
If the concealment frame is not for the first subframe as determined in operation 1010, the processing circuitry 902 derives in operation 1024 a non-time reversed phase correction to apply to the peaks of the signal spectrum for a second concealment subframe of the at least two consecutive concealment subframes.
In operation 1026, the processing circuitry 902 applies the non-time reversed phase correction to the peaks of the signal spectrum for the second subframe to form non-time reversed phase corrected peaks.
In operation 1028, the processing circuitry 902 combines the non-time reversed phase corrected peaks with a noise spectrum of the signal spectrum to form a combined spectrum for the second concealment subframe.
In operation 1030, the processing circuitry 902 generates a second synthesized concealment audio subframe based on the combined spectrum.
Turning to
Various operations from the flow chart of
Example embodiments are discussed below.
1. A method of generating a concealment audio subframe of an audio signal in a decoding device, the method comprising:
generating (1000) frequency spectra on a subframe basis where consecutive subframes of the audio signal have a property that an applied window shape of first subframe of the consecutive subframes is a mirrored version or a time reversed version of a second subframe of the consecutive subframes;
receiving (1002) a bad frame indicator; detecting (1008) peaks of a signal spectrum of a previously received audio frame of the audio signal on a fractional frequency scale, the previously received audio frame received prior to receiving the bad frame indicator;
estimating (1012) a phase of each of the peaks; deriving (1014) a time reversed phase correction to apply to the peaks of the signal spectrum based on the phase estimated; applying (1016) the time reversed phase correction to the peaks of the signal spectrum to form time reversed phase corrected peaks;
applying (1018) a time reversal to the concealment audio subframe; combining (1020) the time reversed phase corrected peaks with a noise spectrum of the signal spectrum to form a combined spectrum for the concealment audio subframe; and generating (1022) a synthesized concealment audio subframe based on the combined spectrum.
2. The method of Embodiment 1 wherein a synthesized concealment audio frame comprises at least two consecutive concealment subframes and wherein deriving the time reversed phase correction, applying the time reversed phase correction, applying the time reversal and combining the time reversed phase corrected peaks are performed for a first concealment subframe of the at least two consecutive concealment subframes, the method further comprising:
deriving (1024) a non-time reversed phase correction to apply to the peaks of the signal spectrum for a second concealment subframe of the at least two consecutive concealment subframes;
applying (1026) the non-time reversed phase correction to the peaks of the signal spectrum for the second subframe to form non-time reversed phase corrected peaks;
combining (1028) the non-time reversed phase corrected peaks with a noise spectrum of the signal spectrum to form a combined spectrum for the second concealment subframe; and generating (1030) a second synthesized concealment audio subframe based on the combined spectrum.
3. The method of any of Embodiments 1-2 wherein the concealment audio subframe comprises a concealment audio subframe for one of a lost audio frame and a corrupted audio frame.
4. The method of any of Embodiments 1-3 wherein the bad frame indicator provides an indication that an audio frame is lost or corrupted.
5. The method of any of Embodiments 1-4 further comprising obtaining the signal spectrum of the previously received audio signal frame from a memory of the decoder.
6. The method of any of Embodiments 1-5 wherein applying the time reversal comprises applying a complex conjugate to the concealment audio subframe.
7. The method of any of Embodiments 1-6 further comprising: associating (1100) each peak of the number of peaks with a number of peak frequency bins representing the peak.
8. The method of Embodiment 7 wherein for each peak of the number of peaks, one of the time reversed phase correction and the non-time reversed phase correction is applied (1102) to the peak.
9. The method of any of Embodiment 8 further comprising: populating (1104) remaining bins of the signal spectrum using coefficients of the stored signal spectrum with a random phase applied.
10. The method of any of Embodiments 1-9 wherein estimating the phase of each of the peaks comprises:
calculating a phase estimation for the peaks of the time reversed phase corrected peaks in accordance with:
where (ϕi is an estimated phase at frequency fi, ∠{circumflex over (X)}mem(ki) is an angle of spectrum {circumflex over (X)}mem at a frequency bin ki, ffrac is a rounding error, ϕc is a tuning constant, and ki is [fi].
11. The method of Embodiment 10 wherein ϕc has a value in a range between 0.1 and 0.7.
12. The method of Embodiment 10 wherein calculating the phase estimation for the non-time reversed phase corrected peaks is calculated in accordance with:
where Δϕi denotes a phase correction of a sinusoid at the frequency fi, Nfull denotes a number of samples between two frames, Nlostdenotes a number of consecutive lost frames, and N denotes a length of a subframe window.
13. The method of any of Embodiments 1-12 further comprising applying a random phase to the noise spectrum of the signal spectrum.
14. The method of Embodiment 13 wherein applying the random phase to the noise spectrum comprises applying the random phase to the noise spectrum prior to combining the non-time reversed phase corrected peaks with the noise spectrum.
15. A decoder device (900) configured to generate a concealment audio subframe of a received audio signal, wherein a decoding method of the decoding device generates frequency spectra on a subframe basis where consecutive subframes have a property that an applied window shape is a mirrored version or a time reversed version of each other, the decoder device comprising:
processing circuitry (902); and
memory (904) coupled with the processing circuitry, wherein the memory includes instructions that when executed by the processing circuitry causes the decoder device to perform operations according to any of Embodiments 1-14.
16. A decoder device (900) configured to generate a concealment audio subframe of a received audio signal, wherein a decoding method of the decoding device generates frequency spectra on a subframe basis where consecutive subframes have a property that an applied window shape is a mirrored version or a time reversed version of each other, wherein the decoder device is adapted to perform according to any of Embodiments 1-14.
17. A computer program comprising program code to be executed by processing circuitry (902) of a decoder device (900) configured to operate in a communication network, whereby execution of the program code causes the decoder device (900) to perform operations according to any of Embodiments 1-14.
18. A computer program product comprising a non-transitory storage medium including program code to be executed by processing circuitry (902) of a decoder device (900) configured to operate in a communication network, whereby execution of the program code causes the decoder device (900) to perform operations according to any of Embodiments 1-14.
19. A method of generating a concealment audio subframe for an audio signal in a decoding device, the method comprising:
generating (1000) frequency spectra on a subframe basis where consecutive subframes of the audio signal have a property that an applied window shape of first subframe of the consecutive subframes is a mirrored version or a time reversed version of a second subframe of the consecutive subframes; storing (1004) a signal spectrum corresponding to a second subframe of a first two consecutive subframes;
receiving a bad frame indicator (1002) for a second two consecutive subframes;
obtaining (1006) the signal spectrum;
detecting (1008) peaks of the signal spectrum on a fractional frequency scale;
estimating (1012) a phase of each of the peaks;
deriving (1014) a time reversed phase correction to apply to the peaks of the spectrum stored for a first subframe of the second two consecutive subframes based on the phase estimated;
applying (1016) the time reversed phase correction to the peaks of the signal spectrum to form time reversed phase corrected peaks;
applying (1018) a time reversal to the concealment audio subframe;
combining (1020) the time reversed phase corrected peaks with a noise spectrum of the signal spectrum to form a combined spectrum for the first subframe of the second two consecutive subframes; and
generating (1022) a synthesized concealment audio subframe based on the combined spectrum.
20. The method of Embodiment 19, wherein the synthesized concealment audio frame comprises at least two consecutive concealment subframes and wherein deriving the time reversed phase correction, applying the time reversed phase correction, and combining the time reversed phase corrected peaks are performed for a first concealment subframe of the at least two consecutive concealment subframes, the method further comprising:
deriving (1024) a non-time reversed phase correction to apply to peaks of the signal spectrum for a second subframe of the second two consecutive subframes;
applying (1026) the non-time reversed phase correction to the peaks of the signal spectrum for the second subframe of the second two consecutive subframes to form non-time reversed phase corrected peaks;
combining (1028) the non-time reversed audio subframe with a noise spectrum of the signal spectrum to form a second combined spectrum for the second subframe of the second two consecutive subframes; and generating (1030) a second synthesized audio subframe based on the second combined spectrum.
21. The method of any of Embodiments 19-20 wherein the concealment audio subframe comprises a concealment audio subframe for one of a lost audio frame and a corrupted audio frame.
22. The method of any of Embodiments 19-21 wherein the bad frame indicator provides an indication that an audio frame is lost or corrupted.
23. The method of any of Embodiments 19-22 further comprising obtaining the signal spectrum from a memory of the decoder.
24. The method of any of Embodiments 19-23 wherein applying the time reversal comprises applying a complex conjugate to the concealment audio subframe.
25. The method of any of Embodiments 18-24 further comprising:
associating each peak with a number of peak frequency bins representing the peak.
26. The method of Embodiment 25 further comprising, for each peak of the number of peaks, applying one of the time reversed phase correction and the non-time reversed phase correction to the peak.
27. The method of any of Embodiment 26 further comprising: populating remaining bins of the signal spectrum using coefficients of the spectrum stored with a random phase applied.
28. The method of any of Embodiments 19-27 wherein estimating the phase comprises:
calculating a phase estimation for the time reversed phase corrected peaks in accordance with:
where ϕi is an estimated phase at frequency fi, ∠{circumflex over (X)}mem(ki) is an angle of spectrum {circumflex over (X)}mem at frequency fi, ffrac is a rounding error, ϕc is a tuning constant, and ki is [fi].
29. The method of Embodiment 28 wherein ϕc has a value in a range between 0.1 and 0.7.
30. The method of Embodiment 28 further comprising calculating a phase estimation for the non-time reversed phase corrected peaks in accordance with:
where Δϕi denotes a phase correction of a sinusoid at frequency fi, Nfull denotes a number of frame samples between two frames, Nlostdenotes a number of consecutive lost frames, and N denotes a length of a subframe window.
31. The method of any of Embodiments 19-30 wherein generating the frequency spectra of for each subframe of the first two consecutive subframes comprises determining:
where N denotes a length of a subframe window, subframe windowing function w1(n) is a subframe windowing function for the first subframe {circumflex over (X)}1(m, k)of the consecutive subframes and w2(n) is a subframe windowing function for the second subframe {circumflex over (X)}2(m, k) of the consecutive subframes, and Nstep12 is a number of samples between a first subframe of the first two consecutive subframes and the second subframe of the first two consecutive subframes.
32. The method of any of Embodiments 19-31 further comprising applying a random phase to the noise spectrum of the signal spectrum.
33. The method of Embodiment 32 wherein applying the random phase to the noise spectrum comprises applying the random phase to the noise spectrum prior to combining the non-time reversed phase corrected peaks with the noise spectrum.
34. A decoder device (900) configured to generate a concealment audio subframe of a received audio signal, wherein a decoding method of the decoding device generates frequency spectra on a subframe basis where consecutive subframes have a property that an applied window shape is mirrored version or a time reversed version of each other, the decoder device comprising:
processing circuitry (902); and
memory (904) coupled with the processing circuitry, wherein the memory includes instructions that when executed by the processing circuitry causes the decoder device to perform operations according to any of Embodiments 19-33.
35. A decoder device (900) configured to generate a concealment audio subframe of a received audio signal, wherein a decoding method of the decoding device (900) generates frequency spectra on a subframe basis where consecutive subframes have a property that an applied window shape is a mirrored version or a time reversed version of each other, wherein the decoder device is adapted to perform according to any of Embodiments 19-33.
36. A computer program comprising program code to be executed by processing circuitry (902) of a decoder device (900) configured to operate in a communication network, whereby execution of the program code causes the decoder device (900) to perform operations according to any of Embodiments 19-33.
37. A computer program product comprising a non-transitory storage medium including program code to be executed by processing circuitry (902) of a decoder device (900) configured to operate in a communication network, whereby execution of the program code causes the decoder device (900) to perform operations according to any of Embodiments 19-33.
Explanations are provided below for various abbreviations/acronyms used in the present disclosure.
References are identified below.
[1] T. Vaillancourt, M. Jelinek, R. Salami and R. Lefebvre, “Efficient Frame Erasure Concealment in Predictive Speech Codecs using Glottal Pulse Resynchronisation,” 2007 IEEE International Conference on Acoustics, Speech and Signal Processing-ICASSP 07, Honolulu, HI, 2007, pp. IV-1113-IV-1116.
[2] J. Lecomte et al., “Packet-loss concealment technology advances in EVS,” 2015 IEEE International Conference on Acoustics, Speech and Signal Processing (ICASSP), Brisbane, QLD, 2015, pp. 5708-5712.
[3] 3GPP TS 26.447, Codec for Enhanced Voice Services (EVS); Error Concealment of Lost Packets (Release 12)
[4] S. Bruhn, E. Norvell, J. Svedberg and S. Sverrisson, “A novel sinusoidal approach to audio signal frame loss concealment and its application in the new evs codec standard,” 2015 IEEE International Conference on Acoustics, Speech and Signal Processing (ICASSP), Brisbane, QLD, 2015, pp. 5142-5146.
Generally, all terms used herein are to be interpreted according to their ordinary meaning in the relevant technical field, unless a different meaning is clearly given and/or is implied from the context in which it is used. All references to a/an/the element, apparatus, component, means, step, etc. are to be interpreted openly as referring to at least one instance of the element, apparatus, component, means, step, etc., unless explicitly stated otherwise. The steps of any methods disclosed herein do not have to be performed in the exact order disclosed, unless a step is explicitly described as following or preceding another step and/or where it is implicit that a step must follow or precede another step. Any feature of any of the embodiments disclosed herein may be applied to any other embodiment, wherever appropriate. Likewise, any advantage of any of the embodiments may apply to any other embodiments, and vice versa. Other objectives, features and advantages of the enclosed embodiments will be apparent from the following description.
In the above-description of various embodiments, it is to be understood that the terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting. Unless otherwise defined, all terms (including technical and scientific terms) used herein have the same meaning as commonly understood by one of ordinary skill in the art to which present disclosure belongs. It will be further understood that terms, such as those defined in commonly used dictionaries, should be interpreted as having a meaning that is consistent with their meaning in the context of this specification and the relevant art and will not be interpreted in an idealized or overly formal sense unless expressly so defined herein.
When an element is referred to as being “connected”, “coupled”, “responsive”, or variants thereof to another element, it can be directly connected, coupled, or responsive to the other element or intervening elements may be present. In contrast, when an element is referred to as being “directly connected”, “directly coupled”, “directly responsive”, or variants thereof to another element, there are no intervening elements present. Like numbers refer to like elements throughout. Furthermore, “coupled”, “connected”, “responsive”, or variants thereof as used herein may include wirelessly coupled, connected, or responsive. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. Well-known functions or constructions may not be described in detail for brevity and/or clarity. The term “and/or” includes any and all combinations of one or more of the associated listed items.
It will be understood that although the terms first, second, third, etc. may be used herein to describe various elements/operations, these elements/operations should not be limited by these terms. These terms are only used to distinguish one element/operation from another element/operation. Thus a first element/operation in some embodiments could be termed a second element/operation in other embodiments without departing from the teachings of present disclosure. The same reference numerals or the same reference designators denote the same or similar elements throughout the specification.
As used herein, the terms “comprise”, “comprising”, “comprises”, “include”, “including”, “includes”, “have”, “has”, “having”, or variants thereof are open-ended, and include one or more stated features, integers, elements, steps, components or functions but does not preclude the presence or addition of one or more other features, integers, elements, steps, components, functions or groups thereof. Furthermore, as used herein, the common abbreviation “e.g.”, which derives from the Latin phrase “exempli gratia,” may be used to introduce or specify a general example or examples of a previously mentioned item, and is not intended to be limiting of such item. The common abbreviation “i.e.”, which derives from the Latin phrase “id est,” may be used to specify a particular item from a more general recitation.
Example embodiments are described herein with reference to block diagrams and/or flowchart illustrations of computer-implemented methods, apparatus (systems and/or devices) and/or computer program products. It is understood that a block of the block diagrams and/or flowchart illustrations, and combinations of blocks in the block diagrams and/or flowchart illustrations, can be implemented by computer program instructions that are performed by one or more computer circuits. These computer program instructions may be provided to a processor circuit of a general purpose computer circuit, special purpose computer circuit, and/or other programmable data processing circuit to produce a machine, such that the instructions, which execute via the processor of the computer and/or other programmable data processing apparatus, transform and control transistors, values stored in memory locations, and other hardware components within such circuitry to implement the functions/acts specified in the block diagrams and/or flowchart block or blocks, and thereby create means (functionality) and/or structure for implementing the functions/acts specified in the block diagrams and/or flowchart block(s).
These computer program instructions may also be stored in a tangible computer-readable medium that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable medium produce an article of manufacture including instructions which implement the functions/acts specified in the block diagrams and/or flowchart block or blocks. Accordingly, embodiments of present disclosure may be embodied in hardware and/or in software (including firmware, resident software, micro-code, etc.) that runs on a processor such as a digital signal processor, which may collectively be referred to as “circuitry,” “a module” or variants thereof.
It should also be noted that in some alternate implementations, the functions/acts noted in the blocks may occur out of the order noted in the flowcharts. For example, two blocks shown in succession may in fact be executed substantially concurrently or the blocks may sometimes be executed in the reverse order, depending upon the functionality/acts involved. Moreover, the functionality of a given block of the flowcharts and/or block diagrams may be separated into multiple blocks and/or the functionality of two or more blocks of the flowcharts and/or block diagrams may be at least partially integrated. Finally, other blocks may be added/inserted between the blocks that are illustrated, and/or blocks/operations may be omitted without departing from the scope of embodiments. Moreover, although some of the diagrams include arrows on communication paths to show a primary direction of communication, it is to be understood that communication may occur in the opposite direction to the depicted arrows.
Many variations and modifications can be made to the embodiments without substantially departing from the principles of the present disclosure. All such variations and modifications are intended to be included herein within the scope of present disclosure. Accordingly, the above disclosed subject matter is to be considered illustrative, and not restrictive, and the examples of embodiments are intended to cover all such modifications, enhancements, and other embodiments, which fall within the spirit and scope of present disclosure. Thus, to the maximum extent allowed by law, the scope of present disclosure is to be determined by the broadest permissible interpretation of the present disclosure including the examples of embodiments and their equivalents, and shall not be restricted or limited by the foregoing detailed description.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/EP2020/064394 | 6/4/2020 | WO | 00 |
Number | Date | Country | |
---|---|---|---|
62860922 | Jun 2019 | US |