The present invention relates to the communications field, and more particularly, to a method for speech signal processing and an apparatus for speech signal processing.
In voice communication, speech signals are typically processed in unit of frames. The length of each frame of speech signals is generally 10 milliseconds (ms) to 30ms. For each frame of speech signals, the basic processing process is as follows:
At a transmitter, each frame of speech signals is encoded by a speech encoder, and the encoded bits are packaged into a speech data frame; the speech data frame is transmitted via a communication channel from the transmitter to a receiver; at the receiver, the received speech data frame is decoded by a speech decoder, and the speech signal is recovered.
For a speech decoder, the recovering of a speech signal depends on the accurate reception of the speech data frame transmitted from the transmitter, and the accurate reception of the speech data frame depends on a communication channel. For the communication channel, if communication channel resources are insufficient, loss of speech data frame or error of speech data frame may occur. Currently, the impact on the communication quality of speech data frame caused by the loss of speech data frame or the error of speech data frame in the communication channel can be effectively eliminated by the Frame Erasure Concealment (FEC) technology widely used in the speech coder-decoder (CODEC).
The FEC technologies adopted by different speech CODECs may be different, but generally include operations for performing amplitude attenuation on recovered speech signals.
The FEC technology is employed in the speech CODEC to perform FEC processing on the speech data frame (corresponding to the erasure concealment frame). However, not all the speech signals are vocal signals purely produced by human voice, and the speech signals may also include background noise signals in human inactive intervals (relative to the vocal signal, the background noise signal is a non-speech signal). Energy jump may occur in the recovered signal processed by the erasure concealment because of the existence of the background noise signal (corresponding to the background noise frame produced by the speech encoder), this may cause discomfort to the hearing of the listener. Especially when the background noise frame is lost, the hearing discomfort caused by this kind of energy jump will become more serious.
The technical problem to be solved by embodiments of the present invention is to provide a method and an apparatus for speech signal processing to make the energy transition between the area of erasure concealment signal and the area of background noise signal natural and smooth, so as to improve audio comfortable sensation of the listener.
To solve the above mentioned technical problem, embodiments of the present invention provide a method for speech signal processing. The method includes: when one or more background noise frames subsequent to an erasure concealment frame are obtained, setting energy attenuation gain values for background noise signals corresponding to the obtained background noise frames, to make differences between the energy attenuation gain values of the background noise signals corresponding to the background noise frames and the energy attenuation gain values of signals corresponding to their respective previous frames be within a threshold range; controlling energy attenuation of the background noise signals corresponding to the background noise frames by using the energy attenuation gain values.
Accordingly, embodiments of the present invention provide an apparatus for speech signal processing. The apparatus includes: a background noise frame obtaining unit adapted to obtain one or more background noise frames subsequent to an erasure concealment frame; an energy attenuation gain value setting unit adapted to set energy attenuation gain values for background noise signals corresponding to the obtained background noise frames, to make differences between the energy attenuation gain values of the background noise signals corresponding to the background noise frames and the energy attenuation gain values of signals corresponding to their respective previous frames be within a threshold range; a control unit adapted to control energy attenuation of the background noise signals corresponding to the background noise frames by using the energy attenuation gain values.
In embodiments of the present invention, the energy attenuation gain values are set for the background noise signals corresponding to the obtained background noise frames subsequent to an erasure concealment frame, so that the differences between the energy attenuation gain values of the background noise signals corresponding to the background noise frames and the energy attenuation gain values of signals corresponding to their respective previous frames are within the threshold range; and the energy attenuation of the background noise signals corresponding to the background noise frames is controlled by using the energy attenuation gain values. Therefore, the energy transition between the area of erasure concealment signal and the area of background noise signal may be natural and smooth by setting the energy attenuation gains of the background noise signals and performing energy attenuation on the background noise signals with the energy attenuation gains, and the audio comfortable sensation of the listener may be improved.
Embodiments of the present invention provide a method and an apparatus for speech signal processing, in which energy attenuation may be performed on the background noise signal by setting and using the energy attenuation gain of the background noise signal; therefore, the energy transition between the area of erasure concealment signal and the area of background noise signal may be natural and smooth, and the audio comfortable sensation of the listener may be improved.
In the following description, embodiments of the present invention will be described in detail in conjunction with the accompanying drawings.
101: One or more background noise frames subsequent to an erasure concealment frame are obtained. When only one background noise frame subsequent to the erasure concealment frame is obtained, processing on this background noise frame may be the same as that on the following explained background noise frame B. By way of example, but not limitation, 7 successive background noise frames B, C, D, E, F, G, and H are illustrated in the following. That is, the previous frame of the current obtained first background noise frame B is the erasure concealment frame A, and the respective previous frames of the background noise frames except the first background noise frame B are all background noise frames. The signal corresponding to such background noise frame is a background noise signal. For example, the previous frame of the background noise frame D is the background noise frame C. Specifically, whether the current obtained frame is a background noise frame may be determined according to a flag in the frame head.
102: Energy attenuation gain values are set for the background noise signals corresponding to the obtained background noise frames B, C, D, E, F, G, and H, so that the differences between the energy attenuation gain values of the background noise signals corresponding to the background noise frames B, C, D, E, F, G, and H and the energy attenuation gain values of the signals corresponding to their respective previous frames are within a threshold range. Specifically, the step 102 may be performed as the following:
Firstly, a stored energy attenuation gain value α′ of the erasure concealment signal corresponding to the erasure concealment frame A is obtained.
Secondly, an initial energy attenuation gain value αstart for the background noise frames is set according to the energy attenuation gain value α′ of the erasure concealment signal corresponding to the erasure concealment frame A. The difference between the initial energy attenuation gain value αstart and the energy attenuation gain value α′ of the erasure concealment signal corresponding to the erasure concealment frame is within the threshold range. Specifically, it may let αstart=α′.
Thirdly, the sum value of the initial energy attenuation gain value αstart and an energy attenuation gain added value Δα which is less than the threshold is set to the energy attenuation gain value of the background noise signal corresponding to the first background noise frame B. The sum values of the energy attenuation gain values of the signals corresponding to the respective previous background noise frames of the background noise frames, except the first background noise frame B and the energy attenuation gain added value, are separately set to the energy attenuation gain values of the background noise signals corresponding to the background noise frames except the first background noise frame B. Specifically, it may let: the energy attenuation gain value of the background noise signal corresponding to the background noise frame B αnoiseB=αstart+Δα, that is, αstart is the precondition for αnoiseB; the energy attenuation gain value of the background noise signal corresponding to the background noise frame C αnoiseC=αnoiseB+Δα, that is, αnoiseB is the precondition for αnoiseC; the energy attenuation gain value of the background noise signal corresponding to the background noise frame D αnoiseD=αnoiseC+Δα, that is, αnoiseC is the precondition for αnoiseD; the energy attenuation gain value of the background noise signal corresponding to the background noise frame E αnoiseE=αnoiseD+Δα, that is, αnoiseD is the precondition for αnoiseE; the energy attenuation gain value of the background noise signal corresponding to the background noise frame F αnoiseF=αnoiseE+Δα, that is, αnoiseE is the precondition for αnoiseF; the energy attenuation gain value of the background noise signal corresponding to the background noise frame G αnoiseG=αnoiseF+Δα, that is, αnoiseF is the precondition for αnoiseG; and the energy attenuation gain value of the background noise signal corresponding to the background noise frame H αnoiseH=αnoiseG+Δα, that is, αnoiseG is the precondition for αnoiseH.
It should be noted, when multiple successive background noise frames are obtained and an energy attenuation gain value αnoise of a background noise signal corresponding to a certain background noise frame is satisfied with αnoise≧1 through a similar iterative process as mentioned above, it may let αnoise=1 in order to satisfy the requirement of speech signal processing. For simplicity, the above mentioned iterative process for setting the energy attenuation gain values of the background noise signals corresponding to at least two background noise frames may be expressed in the following equation:
αnoise=αnoise+Δα
if (αnoise≧1)
{αnoise=1}.
In an embodiment, the Δα may, but not limited to, be obtained in one of the following two ways:
where L is the preset number of background noise frames. Specifically, the value of L may be 100.
103: The energy attenuation of the background noise signals corresponding to the background noise frames B, C, D, E, F, G, and H is controlled by using the energy attenuation gain values. Specifically, the step 103 may be performed as the following:
Firstly, the background noise signals corresponding to the background noise frames B, C, D, E, F, G, and H are recovered.
Secondly, amplitude attenuation is performed on the background noise signals by using the energy attenuation gain values, such as, the amplitude attenuation is performed on the background noise signal corresponding to the background noise frame B by using the energy attenuation gain value αnoiseB of the background noise signal corresponding to the background noise frame B, the amplitude attenuation is performed on the background noise signal corresponding to the background noise frame C by using the energy attenuation gain value αnoiseC of the background noise signal corresponding to the background noise frame C, etc.
Specifically, when the number of samples of the background noise signal in each background noise frame is M, the amplitude attenuation is performed on the M samples of the background noise signal corresponding to each background noise frame by using the energy attenuation gain value of the background noise signal corresponding to each background noise frame. For simplicity, the above mentioned process of performing the amplitude attenuation on the M samples of the background noise signal corresponding to each background noise frame may be expressed in the following equation, where noise(n) denotes the amplitude of the nth background noise signal sample in the M background noise signal samples:
if (αnoise<1)
for (n=0; n<M; n++)
{noise(n)=noise(n)×αnoise}
In the method for speech signal processing according to the embodiment of the present invention as shown in
In an embodiment, the step 102, in which energy attenuation gain values are set for the background noise signals corresponding to the obtained background noise frames B, C, D, E, F, G, and H so that the differences between the energy attenuation gain values of the background noise signals corresponding to the background noise frames B, C, D, E, F, G, and H and the energy attenuation gain values of the signals corresponding to their respective previous frames are within the threshold range, may be implemented through the speech signal processing method according to an embodiment of the present invention as shown
Thus, the energy attenuation gain values of the background noise signals corresponding to the background noise frames B, C, D, E, F, G, and H are incremented in a roughly certain order until an energy attenuation gain value of a background noise signal corresponding to a background noise frame reaches 1, while the differences between the energy attenuation gain values of the background noise signals corresponding to the background noise frames B, C, D, E, F, G, and H and the respective energy attenuation gain values of the signals corresponding to their respective previous frames are ensured to be within the threshold range. Therefore, other similar implementation ways may also be considered as other embodiments of the present invention, for example the implementation ways as shown in
Referring to
201: One or more background noise frames subsequent to an erasure concealment frame are obtained. When only one background noise frame subsequent to the erasure concealment frame is obtained, processing on this background noise frame may be the same as that on the following mentioned background noise frame B. By way of example, but not limitation, 7 successive background noise frames B, C, D, E, F, G, and H are illustrated in the following. That is, the previous frame of the current obtained first background noise frame B is the erasure concealment frame A, and the previous frames of the background noise frames except the first background noise frame B are all background noise frames. The signal corresponding to such background noise frame is a background noise signal. For example, the previous frame of the background noise frame D is the background noise frame C. Specifically, whether the current obtained frame is a background noise frame may be determined according to a flag in the frame head.
202: Energy attenuation gain values are set for the background noise signals corresponding to the obtained background noise frames B, C, D, E, F, G, and H, so that the differences between the energy attenuation gain values of the background noise signals corresponding to the background noise frames B, C, D, E, F, G, and H and the energy attenuation gain values of the signals corresponding to their respective previous frames are within a threshold range. The threshold range is a difference value range, between the energy attenuation gain values of the background noise signals corresponding to the background noise frames and the energy attenuation gain values of the signals corresponding to their respective previous frames, which is obtained according to the speech signal quality as required. This threshold is the maximum value of this difference value range. Please refer to the step 102 for the detailed implementation method of 202, which will not be described in detail here.
203: The energy attenuation of the background noise signals corresponding to the background noise frames B, C, D, E, F, G, and H is controlled by using the energy attenuation gain values. Please refer to the step 103 for the detailed implementation method of 203, which will not be described in detail here.
An apparatus for speech signal processing according to an embodiment of the present invention will be described in the following. However, the apparatus for speech signal processing according to embodiments of the present invention is not limited to the following speech decoder.
The background noise frame obtaining unit 51 is adapted to obtain the background noise frames B, C, D, E, F, G, and H subsequent to the erasure concealment frame. That is, the previous frame of the current obtained first background noise frame B is the erasure concealment frame A, and the previous frames of the background noise frames except the first background noise frame B are all background noise frames. The signal corresponding to such background noise frame is a background noise signal. For example, the previous frame of the background noise frame D is the background noise frame C. Specifically, whether the current obtained frame is a background noise frame may be determined according to a flag in the frame head, this is known in the prior art and will not be described in detail.
The obtaining unit 521 is adapted to obtain the stored energy attenuation gain value α′ of the erasure concealment signal corresponding to the erasure concealment frame A.
The first setting unit 522 is adapted to set the initial energy attenuation gain value αstart for the background noise frames according to the energy attenuation gain value α′ of the erasure concealment signal corresponding to the erasure concealment frame A. The difference between the initial energy attenuation gain value αstart and the energy attenuation gain value α′ of the erasure concealment signal corresponding to the erasure concealment frame is within the threshold range. Specifically, it may let αstart=α′.
The second setting unit 523 is adapted to set the sum value of the initial energy attenuation gain value αstart and the energy attenuation gain added value Δα which is less than the threshold to the energy attenuation gain value of the background noise signal corresponding to the first background noise frame B. Specifically, it may let: the energy attenuation gain value of the background noise signal corresponding to the background noise frame B, αnoiseB=αstart+Δα, that is, αstart is the precondition for αnoiseB.
The third setting unit 524 is adapted to set the sum values of the energy attenuation gain values of the signals corresponding to the previous background noise frames of the background noise frames except the first background noise frame B and the energy attenuation gain added value to the energy attenuation gain values of the background noise signals corresponding to the background noise frames except the first background noise frame B. Specifically, it may let: the energy attenuation gain value of the background noise signal corresponding to the background noise frame C, αnoiseC=αnoiseB+Δα, that is, αnoiseB is the precondition for αnoiseC; the energy attenuation gain value of the background noise signal corresponding to the background noise frame D, αnoiseD=αnoiseC+Δα, that is, αnoiseC is the precondition for αnoiseD; the energy attenuation gain value of the background noise signal corresponding to the background noise frame E, αnoiseE=αnoiseD+Δα, that is, αnoiseD is the precondition for αnoiseE; the energy attenuation gain value of the background noise signal corresponding to the background noise frame F, αnoiseF=αnoiseE+Δα, that is, αnoiseE is the precondition for αnoiseF; the energy attenuation gain value of the background noise signal corresponding to the background noise frame G, αnoiseG=αnoiseF+Δα, that is, αnoiseF is the precondition for αnoiseG; and the energy attenuation gain value of the background noise signal corresponding to the background noise frame H, αnoiseH=αnoiseG+Δα, that is, αnoiseG is the precondition for αnoiseH.
It should be noted, when multiple successive background noise frames are obtained and an energy attenuation gain value αnoise of a background noise signal corresponding to a certain background noise frame is satisfied with αnoise≧1 through the similar iterative process as mentioned above, it may let αnoise=1 in order to satisfy the requirement of speech signal processing. For simplicity, the above mentioned iterative process for setting the energy attenuation gain values of the background noise signals corresponding to at least two background noise frames by the setting unit may be expressed in the following equation:
αnoise=αnoise+Δα
if (αnoise≧1)
{αnoise=1}
In an embodiment, the Δα may, but not limited to, be obtained in one of the following two ways:
where L is the preset number of background noise frames. Specifically, the value of L may be 100.
The control unit 53 is adapted to control the energy attenuation of the background noise signals corresponding to the background noise frames B, C, D, E, F, G, and H by using the energy attenuation gain values. Specifically, the control unit 53 may include a background noise signal obtaining unit 531 and a processing unit 532.
The background noise signal obtaining unit 531 is adapted to recover the background noise signals corresponding to the background noise frames B, C, D, E, F, G, and H.
The processing unit 532 is adapted to perform amplitude attenuation on the background noise signals by using the energy attenuation gain values, such as, perform amplitude attenuation on the background noise signal corresponding to the background noise frame B by using the energy attenuation gain value αnoiseB of the background noise signal corresponding to the background noise frame B, perform amplitude attenuation on the background noise signal corresponding to the background noise frame C by using the energy attenuation gain value αnoiseC of the background noise signal corresponding to the background noise frame C, and so on. Specifically, when the number of samples of the background noise signal in each background noise frame is M, amplitude attenuation is performed on the M samples of the background noise signal corresponding to each background noise frame by using the energy attenuation gain value of the background noise signal corresponding to each background noise frame. For simplicity, the process of performing amplitude attenuation on the M samples of the background noise signal corresponding to each background noise frame by the processing unit 532 may be expressed in the following equation, where noise(n) denotes the amplitude of the nth background noise signal sample in the M background noise signal samples:
if (αnoise<1)
for (n=0; n<M; n++)
{noise(n)=noise(n)×αnoise}
In the speech decoder according to the embodiment of the present invention as shown in
In an embodiment, the energy attenuation gain value setting unit 52 is adapted to perform the following functions: setting energy attenuation gain values for the background noise signals corresponding to the obtained background noise frames B, C, D, E, F, G, and H, so that the differences between the energy attenuation gain values of the background noise signals corresponding to the background noise frames B, C, D, E, F, G, and H and the respective energy attenuation gain values of the signals corresponding to their previous frames are within the threshold range. The energy attenuation gain value setting unit 52 may also employ the speech signal processing method according to the embodiment of the present invention as shown in
The schematic diagram of another speech signal amplitude obtained by the speech signal processing according to the embodiment of the present invention as shown in
Thus, the energy attenuation gain values of the background noise signals corresponding to the background noise frames B, C, D, E, F, G, and H are incremented in a roughly certain order until an energy attenuation gain value of a background noise signal corresponding to a background noise frame reaches 1, while the differences between the energy attenuation gain values of the background noise signals corresponding to the background noise frames B, C, D, E, F, G, and H and the respective energy attenuation gain values of the signals corresponding to their previous frames are ensured to be within the threshold range. Therefore, other similar ways implemented may also be considered as other embodiments of the present invention, for example, another speech signal amplitude obtained by the speech signal processing according to the embodiment of the present invention as shown in
It should be noted as follows:
1. In the above mentioned embodiments of the present invention, the background noise frames B, C, D, E, F, G, and H are taken as example for illustration. However, the present invention is also applicable in practical conditions with more or less background noise frames.
2. The above mentioned threshold value may be chosen according to practical conditions from, but not limited to: 2Δα, 2.5 Δα, 3Δα, etc., where
The initial energy attenuation gain value and the energy attenuation gain added value employed in the embodiments of the present invention may be determined according to the threshold range and the practical conditions.
When the lost frame is a background noise frame, since the energy of the erasure concealment signal obtained by the existing FEC technology may be attenuated more steeply than in the case of no background noise frame lost, if a background noise frame subsequent to the erasure concealment frame is obtained, the jump in energy transition between the area of erasure concealment signal and the area of background noise signal may be more obvious than that in the case of no background noise frame lost. In this condition, by employing embodiments of the present invention, the energy transition between the area of erasure concealment signal and the area of background noise signal may effectively be made natural and smooth, so as to improve audio comfortable sensation of the listener.
Additionally, those skilled in the art may understand that all or part flows in the above mentioned embodiments of method may be implemented by instructing related hardware with program. The program may be stored in computer readable storage media. The program, when executed, may include the flows in the above mentioned embodiments of the various methods. The storage media may be magnetic disk, optical disc, Read-Only Memory (ROM), or Random Access Memory (RAM), etc.
Specific embodiments of the present invention are described above. It should be noted that, for those skilled in the art, additional modifications and improvements may be made without departing from the principle of the present invention. These modifications and improvements should be considered as falling in the protection scope of the present invention.
Number | Date | Country | Kind |
---|---|---|---|
200810026901.2 | Mar 2008 | CN | national |
This application is a continuation of International Application No. PCT/CN2009/070826, filed on Mar. 17, 2009, which claims priority to Chinese Patent Application No. 200810026901.2 filed on Mar. 20, 2008, both of which are hereby incorporated by reference in their entireties.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2009/070826 | Mar 2009 | US |
Child | 12820738 | US |