The present invention relates to the field of communications, and more particularly, to a method and an apparatus for generating an excitation signal for background noise.
In speech communications, speech processing is mainly performed by speech codecs. Since a speech signal has short-time stability, speech codecs generally process the speech signal in frames, each frame being of 10 to 30 ms. All the initial speech codecs have fixed rates, that is, each of the codecs has only one fixed coding rate. For example, the coding rate of a G.729 speech codec is 8 kbit/s, and the coding rate of a G.728 speech codec is 16 kbit/s. As a whole, among these traditional speech codecs with fixed coding rate, the speech codecs with higher coding rate may guarantee coding quality more easily, but occupy more communication channel resources; while the speech codecs with lower coding rate may not guarantee coding quality that easily, but occupy less communication channel resources.
The speech signal includes both a voice signal generated by human speaking and a silent signal generated by gaps in human speaking. The coding rate of the voice signal is referred to as speech (in this case, the speech specifically refers to a signal of human speaking) coding rate, and the coding rate of background noise is referred to as noise coding rate. In speech communications, only the useful voice signal is concerned, while the useless silent signal is not desired to be transmitted, and this decreases transmission bandwidth. However, if merely the voice signal is coded and transmitted and the silent signal is not coded and transmitted, the discontinuity of background noise would occur. Thus a person who is listening at a receiving end will feel rather uncomfortable, and such feeling will be more apparent in the case of stronger background noise so that sometimes the speech would be difficult to understand. In order to solve this problem, the silent signal needs to be coded and transmitted even when no one is speaking Silence compression technology is introduced into speech codecs. In the silence compression technology, the background noise signal is coded with lower coding rate to efficiently decrease communications bandwidth, while the voice signal generated by human speaking is coded with higher coding rate to guarantee communications quality.
At present, an approach for generating an excitation signal for background noise for a G.729B speech codec adds a Discontinuous Transmission System (DTX)/Comfort Noise Generated (CNG) system, i.e., a system for processing background noise, to the prototype of the G.729B speech codec. The system processes 8 kHz-sampled narrowband signals with a frame length of 10 ms for signal processing. According to a CNG algorithm, a level-controllable pseudo white noise is used to excite an interpolated Linear Predictive Coding (LPC) synthesis filter to obtain comfortable background noise, where the level of the excitation signal and the coefficient of the LPC filter are obtained from the previous Silence Insertion Descriptor (SID) frame.
The excitation signal is a pseudo white noise excitation ex(n) which is a mixture of a speech excitation ex1(n) and a Gauss white noise excitation ex2(n). The gain of ex1(n) is relatively small, and ex1(n) is utilized to make the transition from speech to non-speech (such as, noise, etc.) more natural. After the pseudo white noise excitation ex(n) is obtained, ex(n) could be used to excite the synthesis filter to obtain comfortable background noise.
The process for generating the excitation signal is as follows.
Firstly, a target excitation gain {tilde over (G)}t is defined as a square root of average energy of current frame excitations. {tilde over (G)}t is obtained based on the following smoothing algorithm:
For each of two sub-frames which are formed by dividing 80 sampling points, the excitation signal of a CNG module may be synthesized by:
It is defined that
According to the excitation structure of Algebra Code-Excited Linear Prediction (ACELP), it could be known that
If the self-adaptive codebook gain Ga is fixed, the equation expressing {tilde over (G)}t will become a second order equation related to Gf:
The value of Ga may be defined to ensure that the above equation has solutions. Further, the application of some self-adaptive codebook gains with large values may be restricted. Thus, the self-adaptive codebook gain Ga may be randomly selected in the following range:
is used as the value of Gf.
Finally, the excitation signal for the G.729 speech codec may be constructed with the following equation:
ex1(n)=Ga×ea(n)+Gf×ef[n],n=0 . . . 39
The excitation ex(n) may be synthesized in the following manner.
It is assumed that E1 is the energy of ex1(n), E2 is the energy of ex2(n), and E3 is a dot product of ex1(n) and ex2(n):
E1=Σex12(n)
E2=Σex22(n)
E3=Σex1(n)·ex2(n)
It is assumed that α and β are proportional coefficients of ex1(n) and ex2(n) in a mixed excitation respectively, where α is set to 0.6 and β is determined based on the following quadratic equation:
β2E2+2αβE3+(α2−1)E1=0, with β>0.
If there is no solution for β, β will be set to 0 and α will be set to 1. The final excitation ex(n) for the CNG module becomes:
ex(n)=αex1(n)+βex2(n)
The above discussion illustrates the principle of generating an excitation signal for background noise for the CNG module of the G.729B speech codec.
According to the implementation process described above, certain speech excitation ex1(n) may be added when generating an excitation signal for background noise for the G.729B speech codec. However, the speech excitation ex1(n) is just added formally, but actual contents, such as lags of the self-adaptive codebook and positions and signs of the fixed codebook, are all generated randomly, resulting in a strong randomness. Therefore, the correlation between the excitation signal for background noise and the excitation signal for the previous speech frame is poor, so that the transition from a synthesized speech signal to a synthesized background noise signal is unnatural, which makes the listeners feel uncomfortable.
In order to solve the technology problem described above, an embodiment of the present invention provides a method for generating an excitation signal for background noise including: generating a quasi excitation signal by utilizing coding parameters in a speech coding/decoding stage and a transition length of an excitation signal; and obtaining the excitation signal for background noise in a transition stage by generating a weighted sum of the quasi excitation signal and a random excitation signal of a background noise frame.
Accordingly, an embodiment of the present invention further provides an apparatus for generating an excitation signal for background noise including:
In the embodiments of the present invention, the excitation signal for background noise in the transition stage is obtained by generating the weighted sum of the generated quasi excitation signal and the random excitation signal for background noise in the transition stage during which the signal frame is converted from the speech frame to the background noise frame, and the background noise is synthesized by replacing the random excitation signal with the excitation signal in the transition stage. Since information in the two kinds of excitation signals is included in the transition stage, through this synthesizing scheme of comfortable background noise, the transition of a synthesized signal from speech to background noise could be more natural, smooth and continuous, which makes the listeners feel more comfortable.
Some preferred exemplary embodiments of the present invention are described in detail below in conjunction with the accompany drawings.
In the embodiments of the present invention, a process for generating an excitation signal for background noise includes: utilizing an excitation signal of a speech frame, a pitch lag and a random excitation signal of a background noise frame in a transition stage during which a signal frame is converted from the speech frame to the background noise frame. That is, in the transition stage, a quasi excitation signal to be weighted is generated by utilizing the excitation signal of the previous speech frame and the pitch lag of the last sub-frame, and then the excitation signal for background noise in the transition stage is obtained by generating a weighted sum of the quasi excitation signal and the random excitation signal for background noise point by point (i.e., by increasing or decreasing progressively; however, it is not limited to this manner). The specific implementation process will be discussed in connection with the following Figures and embodiments.
Referring to
Step 101: A quasi excitation signal is generated by utilizing coding parameters in a speech coding/decoding stage and a transition length of an excitation signal.
Step 102: The excitation signal for background noise in a transition stage is obtained by generating a weighted sum of the quasi excitation signal and a random excitation signal of a background noise frame.
Preferably, before step 101, the method further includes setting the transition length N of the excitation signal when a signal frame is converted from a speech frame to the background noise frame.
Alternatively, a speech codec pre-stores the coding parameters of the speech frame, where the coding parameters include an excitation signal and a pitch lag which is also referred to as self-adaptive codebook lag.
That is, the received coding parameters of each speech frame, which include the excitation signal and the pitch lag, are stored in the speech codec. The excitation signal is stored in real time in an excitation signal storage old old_exc(i) where iε[0,T−1] and T is the maximum value of the pitch lag Pitch set by the speech codec. If the value of T exceeds a frame length, the last several frames will be stored in the excitation signal storage old_exc(i) For example, if the value of T is the length of two frames, the last two frames will be stored in the excitation signal storage old_exc(i). In other words, the size of the excitation signal storage old_exc(i) is determined by the value of T. In addition, the excitation signal storage old_exc(i) and the pitch lag Pitch are updated in real time, and each frame is required to be updated. Actually, since each frame contains a plurality of sub-frames, Pitch is the pitch lag of the last sub-frame.
The transition length N of the excitation signal is set when the signal frame is converted from the speech frame to the background noise frame. In general, the value of the transition length N is set according to practical requirements. For example, the value of N is set to 160 in this embodiment of the present invention. However, N is not limited to this value.
Then step 101 is performed, where the quasi excitation signal pre_exc(n) is generated by utilizing the coding parameters in the speech coding/decoding stage and the transition length of the excitation signal based on the following equation:
pre_exc(n)=old_exc(T−Pitch+n % Pitch)
In step 102, the excitation signal cur_exc(n) for background noise in the transition stage is obtained by generating the weighted sum of the quasi excitation signal and the random excitation signal of the background noise frame.
That is, if the excitation signal in the transition stage is assumed as cur_exc(n), cur_exc(n) may be represented as:
cur_exc(n)=a(n)pre_exc(n)+β(n)random_exc(n)
Preferably, the weighting factor a(n) is calculated based on the equation a(n)=1−n/N, and the weighting factor β(n) is calculated based on the equation β(n)=n/N, where n is a data sampling point of the signal frame which satisfies nε[0,N−1], and N is the transition length of the excitation signal. In general, the value of N is preferably set to 160.
An exemplary approach for generating the weighted sum according to the embodiment of the present invention is to generate the weighted sum point by point, which, however, is not limited to this. Other approaches for generating the weighted sum, such as, generating an even-point weighted sum, an odd-point weighed sum, etc., may also be used. Specific implementation processes for the other approaches are similar to that for generating the weighted sum point by point, and thus will not be described any more.
Preferably, after the excitation signal cur_exc(n) in the transition stage is obtained, the method may further include obtaining a final background noise signal by utilizing the excitation signal cur_exc(n) in the transition stage to excite an LPC synthesis filter.
It would be appreciated from the above technical solution that, in the embodiment of the present invention, the excitation signal of the speech frame is introduced in the transition stage so that the transition of the signal frame from speech to background noise becomes more natural and continuous, which makes the listeners feel more comfortable.
Specific embodiments of the present invention are described below so as to facilitate those skilled in the art to understand the present invention.
The first embodiment is an implementation process for applying the present invention to a G.729B CNG. It should be noted that, in a G.729B speech codec, the maximum value of pitch lag T is 143. The implementation process is described in detail below.
(1) A speech codec receives each speech frame and stores coding parameters of the speech frames. The coding parameters include an excitation signal and a pitch lag Pitch of the last sub-frame. The excitation signal may be stored in real time in an excitation signal storage old_exc(i), where iε[0,142]. Since the frame length of the G.729B speech codec is 80, the excitation signal of the last two frames is buffered in the excitation signal storage old_exc(i). Of course, the last frame, a plurality of frames or less than one frame may be buffered in the excitation signal storage old_exc(i) according to actual situations.
(2) The transition length N of the excitation signal is set when a signal frame is converted from the speech frame to a background noise frame, where N=160. Since in the G.729B speech codec, the length of each frame is 10 ms and there are 80 data sampling points, the transition length is set to two 10 ms frames.
(3) A quasi excitation signal pre_exc(n) of the speech frame is generated according to the excitation signal storage old_exc(i) based on the following equation:
pre_exc(n)=old_exc(T−Pitch+n % Pitch)
(4) The excitation signal in a transition stage is assumed as cur_exc(n). The excitation signal cur_exc(n) in the transition stage is obtained by generating a weighted sum of the quasi excitation signal and a random excitation signal of the background noise frame based on the following equation:
cur_exc(n)=a(n)pre_exc(n)+β(n)ex(n)
a(n) and β(n) are weighting factors of the two excitation signals. In addition, a(n) decreases with the increasing of the value of n and β(n) increases with the increasing of the value of n, where the sum of a(n) and β(n) is 1. a(n) and β(n) are represented respectively as:
a(n)=1−n/160
β(n)=n/160
(5) A final background noise signal could be obtained by utilizing the excitation signal cur_exc(n) in the transition stage to excite an LPC synthesis filter.
Thus, in the G.729B speech codec, the embodiment of the present invention introduces the quasi excitation signal into the transition stage during which the signal frame is converted from speech to background noise, so that the transition of the signal frame from speech to background noise becomes more natural and continuous, which makes the listeners feel more comfortable.
The second embodiment is an implementation process for applying the present invention to an Adaptive Multi-rate Codec (AMR) CNG. It should be noted that, in the AMR, the maximum value of pitch lag T is 143. The specific implementation process is described in detail below.
(1) A speech codec receives each speech frame and stores coding parameters of the speech frames. The coding parameters include an excitation signal and a pitch lag Pitch of the last sub-frame. The excitation signal is stored in real time in an excitation signal storage old_exc(i), where iε[0,142]. Since the frame length of the AMR is 160, only the excitation signal of the last frame is buffered in the excitation signal storage old_exc(i). Of course, the last frame, a plurality of frames or less than one frame may be buffered in the excitation signal storage old_exc(i) according to actual situations
(2) The transition length N of the excitation signal is set when a signal frame is converted from the speech frame to a background noise frame, where N=160. Since in the AMR, the length of each frame is 20 ms and there are 80 data sampling points, the transition length is set to one 10 ms frame.
(3) A quasi excitation signal pre_exc(n) of the speech frame is generated according to the excitation signal storage old_exc(i) based on the following equation:
pre_exc(n)=old_exc(T−Pitch+n % Pitch)
(4) The excitation signal in a transition stage is assumed as cur_exc(n). The excitation signal cur_exc(n) in the transition stage is obtained by generating a weighted sum of the quasi excitation signal and a random excitation signal of the background noise frame based on the following equation:
cur_exc(n)=a(n)pre_exc(n)+β(n)ex(n)
a(n) and β(n) are weighting factors of the two excitation signals. In addition, a(n) decreases with the increasing of the value of n and β(n) increases with the increasing of the value of n, where the sum of a(n) and β(n) is 1. a(n) and β(n) are represented respectively as:
a(n)=1−n/160
β(n)=n/160
(5) A final background noise signal could be obtained by utilizing the excitation signal cur_exc(n) in the transition stage to excite the LPC synthesis filter.
Thus, in the CNG algorithm of the AMR, similar to the G.729B speech codec, the embodiment of the present invention introduces the quasi excitation signal into the transition stage during which the signal frame is converted from speech to background noise so as to obtain the excitation signal in the transition stage, so that the transition of the signal frame from speech to background noise becomes more natural and continuous, which makes the listeners feel more comfortable.
The third embodiment is an implementation process for applying the present invention to a G.729.1 CNG.
G.729.1 speech codec is a speech codec promulgated recently by the International Telecommunication Union (ITU), which is a broadband speech codec, i.e., the speech signal bandwidth to be processed is 50˜7000 Hz. When processed, an input signal is divided into a high frequency band (4000˜7000 Hz) and a low frequency band (50˜4000 Hz) to be processed respectively. The low frequency band utilizes a CELP model, which is a basic model for speech processing and used by codecs, such as G.729 speech codec, AMR, etc. The basic frame length for signal processing of the G.729.1 speech codec is 20 ms, and the frame for signal processing is referred to as superframe. Each superframe has 320 signal sampling points. After dividing the frequency bands, there are 160 signal sampling points for each frequency band in the superframe. In addition, the G.729.1 speech codec also defines a CNG system for processing noise, where an input signal is also divided into a high frequency band and a low frequency band to be processed respectively. The low frequency band also utilizes a CELP model. The embodiment of the present invention may be applied to the processing procedure in the low frequency band in the G.729.1 CNG system, and the implementation process of applying the embodiment of the present invention to a G.729.1 CNG model is described in detail below.
(1) A speech codec receives each speech coding superframe and stores coding parameters of the speech coding superframes. The coding parameters include an excitation signal and a pitch lag Pitch of the last sub-frame. The excitation signal may be stored in real time in an excitation signal storage old_exc(i), where iε[0,142], since the maximum value of the pitch lag T is 143
(2) A transition length N of the excitation signal is set when a signal frame is converted from the speech coding superframe to a background noise coding superframe, where N=160. That is, the transition stage is a superframe.
(3) A quasi excitation signal pre_exc(n) of the speech coding superframe is generated according to the excitation signal storage old_exc(i) based on the following equation:
pre_exc(n)=old_exc(T−Pitch+n % Pitch)
(4) The excitation signal in a transition stage is assumed as cur_exc(n). The excitation signal cur_exc(n) for background noise in the transition stage is obtained by generating a weighted sum of the quasi excitation signal and a random excitation signal of the background noise coding superframe point by point based on the following equation:
cur_exc(n)=a(n)pre_exc(n)+β(n)ex(n)
a(n) and β(n) are weighting factors of the two excitation signals. In addition, a(n) decreases with the increasing of the value of n and β(n) increases with the increasing of the value of n, where the sum of a(n) and β(n) is 1. a(n) and β(n) are represented respectively as:
a(n)=1−n/160
β(n)=n/160
(5) A final background noise signal could be obtained by utilizing the excitation signal cur_exc(n) in the transition stage to excite an LPC synthesis filter.
Thus, in the G.729.1 speech codec, the excitation signal in the transition stage could be obtained after the quasi excitation signal is introduced into the transition stage during which the signal frame is converted from speech to background noise, so that the transition of the signal frame from speech to background noise becomes more natural and continuous, which makes the listeners feel more comfortable.
In addition, an embodiment of the present invention provides an apparatus for generating an excitation signal for background noise. The schematic structure diagram of the apparatus is shown in
The setting unit 21 is configured to set a transition length N of an excitation signal when a signal frame is converted from a speech frame to a background noise frame.
The quasi excitation signal generation unit 22 is configured to generate a quasi excitation signal pre_exc(n) of the speech frame based on the transition length N set by the setting unit 21. The quasi excitation signal pre_exc(n) is calculated base on the following equation:
pre_exc(n)=old_exc(T−Pitch+n % Pitch)
The transition stage excitation signal acquisition unit 23 is configured to obtain an excitation signal cur_exc(n) for background noise in the transition stage by generating the weighted sum of the quasi excitation signal and a random excitation signal of a background noise frame. The excitation signal cur_exc(n) for background noise in the transition stage may be calculated base on the following equation:
cur_exc(n)=a(n)pre_exc(n)+β(n)random_exc(n)
a(n) and β(n) are represented respectively as:
a(n)=1−n/160
β(n)=n/160
Preferably, the apparatus may further include an excitation unit 24, which is configured to obtain a background noise signal by utilizing the excitation signal obtained by the transition stage excitation signal acquisition unit 23 to excite a synthesis filter.
Preferably, a storage unit is configured to pre-store coding parameters of the speech frame, which include the excitation signal and the pitch lag.
Preferably, the apparatus for generating an excitation signal for background noise may be integrated into an encoding end or a decoding end, or exist independently. For example, the apparatus may be integrated into a DTX in the encoding end, or a CNG in the decoding end.
The functions and effects of the various units in the apparatus have been described in detail with respect to the implementation process of corresponding steps in the methods described above, and thus will not be described any more.
The excitation signal in the transition stage is obtained by generating the weighted sum of the generated quasi excitation signal and the random excitation signal for background noise in the transition stage during which the signal frame is converted from the speech frame to the background noise frame, and the background noise is synthesized by replacing the random excitation signal with the excitation signal in the transition stage. Since information in the two kinds of excitation signals is included in the transition stage, through this synthesizing scheme of comfortable background noise, the transition of a synthesized signal from speech to background noise could be more natural, smooth and continuous, thereby sounding more comfortable.
It should be appreciated for those skilled in the art that all or part of the steps of the methods in the above embodiments may be implemented by related hardware instructed by program. The program may be stored in a computer-readable storage medium. When executed, the program may be used to: generate a quasi excitation signal by utilizing coding parameters in a speech coding/decoding stage and a transition length of an excitation signal; and obtain the excitation signal in a transition stage by generating a weighted sum of the quasi excitation signal and a random excitation signal of a background noise frame. The above mentioned storage medium may be a read-only memory, a magnetic disk or an optical disc.
The above disclosure is only the some exemplary embodiments of the present invention. It should be noted that, for those skilled in the art, various modifications and variations may be made to the present invention without departing from the principle of the present invention. These modifications and variations should be regarded as falling within the protection scope of the present invention.
Number | Date | Country | Kind |
---|---|---|---|
2008 1 0084513 | Mar 2008 | CN | national |
This application is a continuation of International Application No. PCT/CN2009/070854, filed on Mar. 18, 2009, which claims priority to Chinese Patent Application No. 200810084513.X, filed on Mar. 21, 2008, both of which are hereby incorporated by reference in their entireties.
Number | Name | Date | Kind |
---|---|---|---|
5893056 | Saikaly et al. | Apr 1999 | A |
6078882 | Sato et al. | Jun 2000 | A |
6636829 | Benyassine et al. | Oct 2003 | B1 |
7146309 | Benyassine et al. | Dec 2006 | B1 |
Number | Date | Country |
---|---|---|
1470051 | Jan 2004 | CN |
101069231 | Nov 2007 | CN |
101339767 | Jan 2009 | CN |
WO 2007027291 | Mar 2007 | WO |
Entry |
---|
“3G TS 26.090—Technical Specification Group Services and System Aspects; Mandatory Speech Codec speech processing functions AMR speech codec; Transcoding functions,” Dec. 1999, Version 3.1.0, 3rd Generation Partnership Project, Valbonne, France. |
“3GPP TS 26.092—Technical Specification Group Services and System Aspects; Mandatory speech codec speech processing functions; Adaptive Multi-Rate (AMR) speech codec; Comfort noise aspects (Release 6),” Dec. 2004, Version 6.0.0, 3rd Generation Partnership Project, Valbonne, France. |
“G.729—Coding of speech at 8kbit/s using conjugate structure algebraic-code-excited linear-prediction (CS-ACELP), Annex B: A silence compression scheme for G.729 optimized for terminals conforming to Recommendation V7.0,” Nov. 1996, Series G: Transmission Systems and Media, International Telecommunication Union, Geneva, Switzerland. |
“G.729—Coding of speech at 8kbit/s using conjugate structure algebraic-code-excited linear-prediction (CS-ACELP),” Mar. 1996, General Aspects of Digital Transmission Systems, International Telecommunication Union, Geneva, Switzerland. |
Extended European Search Report in corresponding European Application No. 09722292.1 (Mar. 3, 2011). |
Written Opinion from the International Searching Authority in corresponding PCT Application No. PCT/CN2009/070854 (Jun. 11, 2009). |
Number | Date | Country | |
---|---|---|---|
20110022391 A1 | Jan 2011 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2009/070854 | Mar 2009 | US |
Child | 12887066 | US |