This application claims priority from Chinese Patent Application No. 200610116315.8, filed Sep. 21, 2006, the entire disclosure of which is incorporated herein by reference.
The disclosure relates generally to signal detection methods; especially to methods for detecting speech and noise in an audio frame sequence.
The present disclosure describes devices, systems, and methods for voice activity detection. It will be appreciated that several of the details set forth below are provided to describe the following embodiments in a manner sufficient to enable a person skilled in the relevant art to make and use the disclosed embodiments. Several of the details and advantages described below, however, may not be necessary to practice certain embodiments of the invention. Additionally, the invention can include other embodiments that are within the scope of the claims but are not described in detail with respect to
One aspect of several embodiments of the present disclosure relates generally to a method for voice activity detection and is useful for distinguishing speech from noise in an audio frame sequence. In several embodiments, the method can include the following processing stages:
In certain embodiments, in the method described above, stage 1 can further contain the following processing stages:
In the method described above, computing the weighted linear prediction energy can include the following calculation stages:
Establishing an n×n matrix A based on the Nth-order linear prediction coefficients a1˜aN. n is the number of sample points in the current frame. Matrix A can be represented as A=[Kij], in which 1≦i, j≦n, and both i and j are natural numbers. Kij=1 when i−j=0; Kij=0 when i−j<0 or i−j>N; and Kij=ai−j when 0<i−j≦N;
Calculating the inverse matrix of A as A−1=[Kij]−1, in which 1≦i, j≦n, and both i and j are natural numbers;
Calculating intermediate parameters b1˜bN as bi=K1, i+1−1, 1≦i≦N, where N is an integer;
Calculating an intermediate parameter sequence z(i) where i is an integer between 0 and N−1, as follows:
z(0)=s(0) when i=0;
when 1≦i<N, where s(i) are sample points of the current frame.
Calculating the weighted linear prediction energy (LPE) as follows:
In stage 4 of the method described above, the method can include setting a threshold. If the derived weighted energy is larger than the threshold, the frame is indicated as a speech frame; otherwise, the frame is indicated as a noise frame. In certain embodiments, the threshold is set as the average weighted energy of multiple previous frames, or the threshold can be set according to the noise energy.
In stage 5 of the method described above, the linear prediction analysis can be performed during speech encoding.
In certain embodiments, the method of voice activity detection described above can also include calculating the zero-crossing rate (ZCR) of the sample points in each frame as follows:
In other embodiments, the method of voice activity detection described above can also include a decision stage based on a low-frequency energy (LFE) of the current frame. The LFE can be calculated for the sample points of each frame as follows:
LFE=h(i)s(i)
where h(i) is a low-pass filter, and s(i) is the sample points of the current frame. In the LFE decision stage, whether the frame contains speech can be determined based on the calculated LFE.
In other embodiments, the method of voice activity detection described above can also include a decision stage based on a total energy (TE) of the current frame. A total energy of the current frame can be calculated for the sample points of each frame as follows:
where s(i) are sample points of the current frame.
In the TE decision stage, whether the frame contains speech can be determined based on the calculated TE.
Another aspect of the present disclosure relates generally to a device for voice activity detection useful for distinguishing speech from noise. The device can include
when 1≦i<N, where s(i) are sample points of the current frame and calculates the weighted linear prediction energy
In one aspect of several embodiments of the present disclosure, linear prediction analysis is not performed during extraction of signal characteristics. Instead, the linear prediction coefficients of the first frame is used as the initial value for the linear prediction coefficient variable. The weighted linear prediction energy of successive frames can then be calculated based on the value contained in the linear prediction coefficient variable. If the current frame is indicated to contain speech, then linear prediction analysis is performed on the current frame during encoding. The resulting linear prediction coefficients can be used to update the value of the linear prediction coefficient variable. As a result, several embodiments of the present disclosure can reduce calculation complexity while maintaining satisfactory level of detection.
Stage S1: performing linear prediction analysis on the first frame in the audio sequence and calculate Nth-order linear prediction coefficients of the first frame; the calculated coefficients are then used as the initial value for the linear prediction coefficient variable.
Stage S2: computing a weighted linear prediction energy of the first frame based on the Nth-order linear prediction coefficients derived from stage S1.
Methods for calculating the weighted liner prediction energy for a frame can include the following stages:
Stage 1, Establishing an n×n matrix A based on the Nth-order linear prediction coefficients a1˜aN. n is the number of sample points in the current frame. Matrix A can be represented as A=[Kij], in which 1≦i, j≦n, and both i and j are natural numbers. Kij=1 when i−j=0; Kij=0 when i−j<0 or i−j>N; and Kij=ai−j when 0<i−j≦N.
Stage 2: calculating the inverse matrix of A as A−1=[Kij]−1, in which 1≦i, j≦n, and both i and j are natural numbers.
Stage 3: calculating intermediate parameters b1˜bN as bi=K1, i+1−11≦i≦N, where N is an integer.
Stage 4: calculating an intermediate parameter sequence z(i) where i is an integer between 0 and N−1, as follows:
z(0)=s(0) when i=0;
when 1≦i<N, where s(i) are sample points of the current frame.
Stage 5: Calculating the weighted linear prediction energy (LPE) as
The following description uses fourth order linear prediction coefficients as examples to illustrate the method described above for computing a weighted linear prediction energy:
First, intermediate coefficients b1, b2, b3, b4 can be computed according to the matrix operations described above in stages 1-3 as follows:
b4=−a4+2a3a1+a22−3a2a12+a14
b3=a3+2a2a1a−a13
b2=−a2+a12
b1=−a1
Then, as described in stage 4 above, the intermediate sequence can be calculated as z(0)=s(0) when i=0; and
when i=1, 2, . . . , N−1.
Finally, as described in stage 5 above, the weighted linear prediction energy can be calculated as:
Stage S3: determining whether the current frame contains speech signal based on the weighted linear prediction energy calculated in Stage S2. In one embodiment, stage 3 can include setting a threshold, which can be determined by the noise energy. Stage 3 can also include if the weighted energy is larger than the threshold, the frame is indicated as a speech frame; otherwise, the frame is indicated as a noise frame.
Stage S4: receiving a new frame as the current speech frame.
Stage S5: calculating the weighted linear prediction energy of the current frame according to Nth-order linear prediction coefficient using techniques similar to that described in Stage 2.
Stage S6: determining whether the current frame contains speech signal based on the weighted linear prediction energy similar to the techniques described in Stage 3. If a speech signal exists, the process continues to the next stage; otherwise, indicate that the current frame is a noise frame and skips to Stage S8. The threshold can be set according to the noise energy or the averaged weighted linear prediction energy of the mth speech frame (m is pre-determined figure) from the first frame.
Stage S7: using the acquired Nth-order linear prediction coefficients of the current frame from the linear prediction analysis to update the Nth-order linear prediction coefficient variable. Subsequent linear prediction analysis can be performed during speech encoding. Thus, the Nth-order linear prediction coefficient used during each loop is that of the most recent speech frame.
Stage S8: determining whether the current frame is the last one in the audio frame sequence. If yes, the process ends; otherwise, revert to Stage 4.
In certain embodiments, the method described above can also include a combination of a signal zero-crossing rate analysis, a low frequency energy analysis, and a total energy analysis.
Signal Zero-Crossing rate is generally referred to as the number of times the sample signal fluctuates between being positive and being negative within a certain time period. Zero-crossing rate of a frame can be represented as
where n is the number of the sample points of the current frame, and s(0)˜s(n−1) are individual sample points of the current frame.
Low-frequency energy of a frame can be calculated as: LFE=h(i)s(i), where h(i) is a low-pass filter of 10-order with the cut-off frequency of about 500 k, s(i) represents sample points of the current frame, and represents a convolution operation.
Total energy of the current frame can be calculated as:
are sample points of the current frame.
In some embodiments, a decision stage can include comparing the calculated ZCR, LFE, and/or TE values with a threshold. If any parameter is larger than its corresponding threshold, a speech signal is indicated; otherwise, a noise signal is indicated. The thresholds of ZCR, LFE, and TE can be similarly set as that of the weighted linear prediction energy. For example, the thresholds of ZCR, LFE, and TE can be the averaged value of the first m frames.
Linear prediction analysis component 53 first performs linear prediction analysis of the first frame, and obtains Nth-order linear prediction coefficients of the first frame. The Nth-order linear prediction coefficients of the first frame is stored into the linear prediction coefficient variety storage component 54 as the initial value of the N-order linear prediction coefficient variable. The matrix set-up component 511 sets up a n×n matrix A according to the N-order linear prediction coefficients a1˜aN, where n is the number of sample points of the current frame. Matrix A could be represented as A=[Kij], in which 1≦i, j≦n, both i and j are natural numbers. Elements in matrix A is defined by: Kij=1, when i−j=0, i and j are natural numbers; Kij=0, when i−j<0 or i−j>N; Kij=ai−j, when 0<i−j≦N. Inverse matrix of A is computed as A−1, by which the weights b1˜bN are calculated using following equations: bi=K1, i+1−1, 1≦i≦N, and N is an integral number, and i, j are natural numbers.
The coefficient conversion component 513 calculates intermediate coefficients b1˜bN: bi=K1, i+1−1, where i is a natural number from 1 to N. The linear prediction weighted energy solution component 514 first calculates the intermediate sequences z(i), where i is an integral number from 0 to N−1. When l=0, z(0)=s(0); when 1≦i<n,
in which s(i) are samples of the current frame. Then based on the intermediate sequence z(0)−z(N−1), LPE is determined as
The above-mentioned LPE is transmitted to the speech/noise decision component 52 to determine whether a speech signal exists. A threshold can be set inside the speech/noise decision component 52. When the LPE is larger than the threshold, a speech signal exists in this frame. Otherwise, a noise signal exists. The threshold can be an averaged value of the LPE of the first several frames from the first frame, or it can be set based on the noise energy.
When the speech/noise decision component 52 decides that the frame contains a speech signal, component 52 sends this frame to linear prediction analysis component 53, which performs an linear prediction analysis on the frame. The resulted Nth-order linear prediction coefficients are saved into the Nth-order linear prediction coefficient variable. The procedure is performed in the speech coding process, which ensures that the saved value of the Nth-order linear prediction coefficient variable is the latest linear prediction coefficient of the speech signal.
Voice activity detection device 50 can also include a ZCR decision component (not shown), which calculates a ZCR value of the sample points in each speech frame as:
where n is the number of sample points in the current frame, s(0)˜s(n−1) are the sample points of the frame, and determines whether the frame contains a speech signal based on the ZCR values of the sample points of the frame.
Voice activity detection device 50 can also include a LFE decision component (not shown), which calculates a LFE value of the sample points of each speech frame as: LFE=h(i)s(i), in which h (i) is the low pass filter, s(i) is the sample point signal of the current frame. Then, according to the LFE of the sample points of each speech frame, the speech signal is decided.
Voice activity detection device 50 can also include a TE decision component (not shown), which calculates the total energy of the sample points of each speech frame as:
where s(i) is the sample point signal of the current frame. Then according to TE of the sample point of each speech frame, the speech signal is decided.
Embodiments of the methods and devices described above can reduce the complexity of the voice detection process. For example, the ZCR procedure typically does not utilize multiplication, 10N Low frequency filter needs 10N multiplication, TE uses N multiplication, and LP coefficients need 4N multiplications. Therefore, 15N multiplications are used. According to conventional techniques, voice activity detection implements linear prediction analysis. The linear prediction analysis of any order at least involves
multiplications. For a 256-point frame, suppose speech and noise's presence is half and half, the percentage of saved multiplications can be at least
Thus, the methods and devices disclosed in the application can reduce the complexity and the cost of calculation for voice activity detection.
From the foregoing, it will be appreciated that specific embodiments of the invention have been described herein for purposes of illustration, but that various modifications can be made without deviating from the inventions. Certain aspects of the invention described in the context of particular embodiments may be combined or eliminated in other embodiments. Additionally, where the context permits, singular or plural terms can also include plural or singular terms, respectively. Moreover, unless the word “or” is expressly limited to mean only a single item exclusive from the other items in reference to a list of two or more items, then the use of “or” in such a list means including (a) any single item in the list, (b) all of the items in the list, or (c) any combination of the items in the list. Additionally, the term “comprising” is used throughout the following disclosure to mean including at least the recited feature(s) such that any greater number of the same feature and/or additional types of features or components is not precluded. Accordingly, the invention is not limited, except as by the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
2006 1 0116315 | Sep 2006 | CN | national |
Number | Name | Date | Kind |
---|---|---|---|
5276765 | Freeman et al. | Jan 1994 | A |
5689615 | Benyassine et al. | Nov 1997 | A |
6061647 | Barrett | May 2000 | A |
6188981 | Benyassine et al. | Feb 2001 | B1 |
6633841 | Thyssen et al. | Oct 2003 | B1 |
6823303 | Su et al. | Nov 2004 | B1 |
20040267525 | Lee et al. | Dec 2004 | A1 |
Number | Date | Country | |
---|---|---|---|
20080133226 A1 | Jun 2008 | US |