This application claims priority under 35 U.S.C. § 119 to Singapore Patent Application No. 200407882-0 filed on Dec. 31, 2004, which is hereby incorporated by reference.
This disclosure relates generally to communication systems and more specifically to a system and method for supporting multiple speech codecs.
Speech coders and decoders, often referred to collectively as “codecs,” are routinely used in communication systems to encode and decode speech signals. In general, codecs are often implemented in software executed by a digital signal processor (DSP). Different codecs often require different processing times, depending on their complexities and the speed of the processor.
Speech codecs that are widely used in various applications include the International Telecommunication Union-Telecommunications (ITU-T) G.723.1 and G.729A codecs. These are complex codecs that usually require large amounts of processing time and memory. Speech coders for both codecs use Algebraic-Code-Excited Linear-Prediction (ACELP), which is based on the Code-Excited Linear-Prediction (CELP) coding model.
Products used in many communication systems often need to support multiple speech codecs, such as in Digital Simultaneous Voice and Data (DSVD) systems and Voice over Internet Protocol (VoIP) systems. Products such as gateway applications also often need to support multiple channels. Large amounts of processing power and memory are typically needed in these products.
Also, the fixed codebook search algorithms for the G.723.1 (5.3 kbps) and G.729A codecs are based on algebraic codebook searches. Implementing fixed codebook searches for both codecs on a single co-processor could reduce the complexity of the system. This could also allow unused processing power and memory of the DSP to be used for other functions, such as supporting multiple channels and other application-specific modules. However, fixed codebook searches for the G.729A codec use a “depth-first tree search” algorithm, while fixed codebook searches for the G.723.1 codec use a “nested-loop search” or a “focused nested-loop search” algorithm. The “focused nested-loop search” and the “depth-first tree search” algorithms are distinctly different. Attempting to implement these two fixed codebook searches, which are associated with different search algorithms for different codecs, may not result in the desired effect of freeing up processing power or memory. Instead, an additional processing burden would be imposed on the co-processor. Implementing the fixed codebook searches on two different co-processors may be more effective but not necessarily more efficient.
This disclosure provides a system and method for supporting multiple speech codecs.
In a first aspect, a method for performing a search of a codebook is provided. The codebook includes a plurality of tracks each having a plurality of even pulse positions. The method includes partitioning a codevector having a plurality of pulses into a first subset of pulses and a second subset of pulses. Each pulse is assignable to a pulse position in the codevector, and each pulse is associated with a shift bit for indicating an odd position. The method also includes performing a first search for determining a first set of possible pulse positions for the pulses in the codevector. The method further includes performing a second search for determining a second set of possible pulse positions for the pulses in the codevector. In addition, the method includes forming the codevector using the first and second sets of possible pulse positions.
In particular aspects, the method includes repeating the partitioning, performing, and forming steps to produce a second codevector associated with a second codebook. The second codevector includes pulses not associated with shift bits, and the second codebook includes tracks having a plurality of odd and even pulse positions. In other particular aspects, the codebook represents a G.723.1 codebook, and the second codebook represents a G.729A codebook.
In a second aspect, a system includes a processor capable of performing functions for at least one of encoding and decoding communication signals. The system also includes a co-processor capable of performing a search of a codebook to support at least one of encoding and decoding of the communication signals. The codebook includes a plurality of tracks each having a plurality of even pulse positions. The co-processor is capable of performing the search by partitioning a codevector having a plurality of pulses into a first subset of pulses and a second subset of pulses. Each pulse is assignable to a pulse position in the codevector, and each pulse is associated with a shift bit for indicating an odd position. The co-processor is also capable of performing a first search for determining a first set of possible pulse positions for the pulses in the codevector. The co-processor is further capable of performing a second search for determining a second set of possible pulse positions for the pulses in the codevector. In addition, the co-processor is capable of forming the codevector using the first and second sets of possible pulse positions.
In a third aspect, a computer program is embodied on a computer readable medium and is operable to be executed by a processor. The computer program is for performing a search of a codebook, where the codebook includes a plurality of tracks each having a plurality of even pulse positions. The computer program includes computer readable program code for partitioning a codevector having a plurality of pulses into a first subset of pulses and a second subset of pulses. Each pulse is assignable to a pulse position in the codevector, and each pulse is associated with a shift bit for indicating an odd position. The computer program also includes computer readable program code for performing a first search for determining a first set of possible pulse positions for the pulses in the codevector. The computer program further includes computer readable program code for performing a second search for determining a second set of possible pulse positions for the pulses in the codevector. In addition, the computer program includes computer readable program code for forming the codevector using the first and second sets of possible pulse positions.
Other technical features may be readily apparent to one skilled in the art from the following figures, descriptions, and claims.
For a more complete understanding of this disclosure, reference is now made to the following description, taken in conjunction with the accompanying drawings, in which:
As described in more detail below, particular embodiments of this disclosure may support multiple codecs on a single co-processor. For example, the G.723.1 (5.3 kbps) codec and the G.729A codec could be supported on a single co-processor. Also, a single fixed codebook search algorithm may be used for both the G.723.1 codec and the G.729A codec. This may help to simplify the fixed codebook search process so that a single co-processor running the fixed codebook search algorithm may be used for both codecs. As a particular example, the fixed codebook search algorithm of the G.723.1 codec could be modified to be similar to that of the G.729A codec, such as by using a “depth-first tree search” fixed codebook search algorithm with the G.723.1 codec as well as with the G.729A codec.
Fixed codebook search algorithms are typically used in conjunction with a codebook. A codebook, in the CELP context, typically represents an indexed set of L-sample long sequences, referred to as L-dimensional “codevectors.” The codebook includes an index ν ranging from 1 to M, where M represents the size of the codebook. The size of the codebook may be expressed as a number of bits b, where:
M=2b. (1)
An algebraic codebook typically represents a set of indexed codevectors νξ. Each codevector defines a plurality of different positions p and N non-zero amplitudes pulses, where each pulse is assignable to a predetermined valid position p of the codevector. The amplitudes and positions of the pulses of the ξth codevector can be derived from a corresponding index ξ through a rule requiring minimal physical storage. Therefore, algebraic codebooks typically are not limited by storage requirements and are designed for efficient searches.
The conventional G.723.1 (5.3 kbps) codebook search uses a 17-bit algebraic codebook for a fixed code excitation v[n]. Each fixed codevector contains, at most, four non-zero pulses. The four pulses can assume the signs and positions shown in Table 1.
A codebook vector v(n) may be constructed by taking a zero vector of dimension 60 and placing four unit pulses at four locations (each pulse multiplied with its corresponding sign). This can be represented by the following equation:
v(n)=s0δ(n m0)+s1δ(nm1)+s2δ(nm2)+s3δ(nm3),n=0, . . . , 59 (2)
where δ (0) represents a unit pulse.
The positions of the pulses can be simultaneously shifted by one (to occupy odd positions). This may require the use of an extra bit, referred to as a “shift bit.” The last position of each of the last two pulses may fall outside a subframe boundary, which signifies that the pulses are not present.
In some embodiments, each pulse position is encoded in three bits, and each pulse sign is encoded in one bit. This gives a total of sixteen bits for the four pulses. Also, an extra bit may be used to encode the shift, resulting in a 17-bit codebook.
The codebook may be searched by minimizing a mean square error between a weighted speech signal r[n] and a weighted synthesis speech signal. This may be expressed as:
where E represents the error, r represents a target vector containing the weighted speech signal after subtracting a zero-input response of a weighted synthesis filter and a pitch contribution, G represents the codebook gain, vξ represents the algebraic codeword at index ξ, and H represents a lower triangular Toeplitz convolution matrix with diagonal h(0) and lower diagonals h(1), . . . , h(L−1), with h(n) being the impulse response of the weighted synthesis filter Si(z). It can be shown that an optimum codeword is one that maximizes the term:
where Cξ represents a correlation value at index ξ, εξ represents an energy at index ξ, d=HTr represents a correlation between the target vector signal r[n] and the impulse response h(n), and φ=HTH represents the covariance matrix of the impulse response. The vector d and the matrix φ may be computed prior to the codebook search. The elements of the vector d may be computed using the following formula:
The elements of the symmetric matrix φ(i,j) may be computed using the following formula:
The algebraic structure of the codebook allows for very fast search procedures since the excitation vector vξ contains only four non-zero pulses. The conventional G.723.1 (5.3 kbps) codebook search is performed in four nested loops corresponding to each pulse position, where in each loop the contribution of a new pulse is added.
The correlation in equation (4) may be given by:
C=α0d[m0]+α1d[m1]+α2d[m2]+α3d[m3] (7)
where mk represents the position of the kth pulse, and αk represents the sign (±1) of the kth pulse. The energy for even pulse position codevectors in equation (4) may be given by:
For odd pulse position codevectors, the energy in equation (4) may be approximated by the energy of the equivalent even pulse position codevector obtained by shifting the odd position pulses to one sample earlier in time.
To simplify the search procedure, the functions d[j] and φ(mi,mj) may be modified. This simplification may be performed as follows, and it may occur prior to the codebook search. The signal s[j] is defined using the following formula:
s[2j]=s[2j+1]=sign(d[2j])if d[2j]>|d[2j+1]
s[2j]=s[2j+1]=sign(d[2j+1])otherwise. (9)
A signal d′[j] is constructed as given by d′[j]=d[j]s[j]. The matrix φ may be modified by including the signal information, where φ′(i,j)=s[i]s[j]φ(i,j). The correlation in equation (7) may now be expressed as:
C=d′[m0]+d′[m1]+d′[m2]+d′[m3]. (10)
The energy in equation (8) may now be expressed as:
which may be further expanded to obtain:
In conventional G.723.1 (5.3 kbps) codecs, the four pulses are divided into four tracks, each pulse position corresponds to one track, and each track has eight possible pulse positions. In an “exhaustive nested-loop search” approach, there are four nested loops. A “focused nested-loop search” approach is used to simplify the search procedure. A predetermined threshold is tested before entering the last loop, and the loop is entered only if this threshold is exceeded. The maximum number of times the loop can be entered is fixed so that a lower percentage of the codebook is searched. This threshold is computed based on the correlation C as given in equation (10). The maximum absolute correlation max3 and the average correlation av3 due to the contribution of the first three pulses may be found prior to the codebook search. The threshold may be given by:
thr3=av3+(max3−av3)/2. (13)
The fourth loop is then entered only if the absolute correlation (due to three pulses) exceeds the value of thr3. This results in a variable complexity search. To further control the search, the number of times the last loop is entered (for four subframes) may not be allowed to exceed 600 (the average worst case per subframe is 150 times, which can be viewed as searching only 150×8 or 2,000 entries of the codebook, ignoring the overhead of the first three loops). In exhaustive nested-loop searches, 84 or 4,096 possible pulse positions are searched.
In the conventional G.729 codec, the fixed codebook is based on an algebraic codebook structure using an Interleaved Single-Pulse Permutation (ISPP) design. In this codebook, each codebook vector contains four non-zero pulses. Each pulse can have either the amplitude +1 or −1. Also, each pulse can assume the positions given in Table 2, which illustrates the structure of the fixed codebook.
The codebook vector v(n) may be constructed by taking a zero vector of dimension 40 and placing four unit pulses at four locations (each pulse multiplied with its corresponding sign). This can be represented by the following equation:
v(n)=s0δ(nm0)+s1δ(nm1)+s2δ(nm2)+s3δ(nm3),n=0, . . . , 39 (14)
where δ(0) represents a unit pulse.
The fixed codebook may be searched by minimizing a mean squared error as shown in equation (3). The matrix H may be defined as the lower triangular Toeplitz convolution matrix with diagonal h(0) and lower diagonal h(1), . . . , h(39). The matrix φ=HtH may contain the correlations of h(n), and the elements of this symmetric matrix may be given by:
The correlation signal d(n) may be obtained from the target signal r(n) and the impulse response h(n) by:
If νξ is the ξth fixed codebook vector, the codebook may be searched by maximizing the term:
The signal d(n) and the matrix φ may be computed before the codebook search. Only the elements actually needed may be computed, and an efficient storage procedure may speed up the search procedure.
The algebraic structure of the codebook allows for a fast search procedure since the codebook vector vξ contains only four non-zero pulses. The correlation in the numerator of equation (17) for a given vector νξ may be given by:
C=α0d[m0]+α1d[m1]+α2d[m2]+α3d[m3] (18)
where mi represents the position of the ith pulse, and αi represents the amplitude of the ith pulse. The energy in the denominator of equation (17) may be given by:
To simplify the search procedure, the pulse amplitudes may be predetermined by quantizing the signal d(n). This may be done by setting the amplitude of a pulse at a certain position equal to the sign of d(n) at that position. Before the codebook search, the following steps may be performed. The signal d(n) may be decomposed into two parts, its absolute value |d(n)| and its sign (denoted “sign [d (n)] ”). The matrix φ may be modified by including the sign information, such as:
φ′(i,j)=sign[d(i)]sign[d(j)]φ(i,j),i=0, . . . , 39,j=i+1, . . . 39. (20)
The main-diagonal elements of φ may be scaled to remove the factor of two in Equation (19) as follows:
φ′(i,i)=0.5φ′(i,i),i=0 . . . , 39. (21)
The correlation in Equation (18) may now be given by:
C=|d(m0)+|d(m1)|+|d(m2)|+|d(m3)|. (22)
The energy in Equation (19) may now be given by:
which may be further expanded to obtain:
A “focused nested-loop search” approach may be used to further simplify the search procedure. In this approach, a precomputed threshold may be tested before entering the last loop, and the loop is entered only if this threshold is exceeded. The maximum number of times the loop can be entered is also fixed so that a low percentage of the codebook is searched. The threshold may be computed based on the correlation C. The maximum absolute correlation max3 and the average correlation av3 due to the contribution of the first three pulses may be found before the codebook search. The threshold may be given by:
thr3=av3+K3(max3−av3). (25)
The fourth loop may be entered only if the absolute correlation (due to three pulses) exceeds thr3, where 0≦K3<1. The value of K3 controls the percentage of the codebook searched, and it may be set to 0.4 as an example. This results in a variable search time. To further control the search, the number of times that the last loop is entered (for two subframes) may not exceed a certain maximum, which may be set to 180 (the average worst case per subframe is 90 times, so the total possible pulse search combination would be 180*8 or 1,440). In exhaustive nested-loop searches, 84*2 or 8,192 possible pulse positions are searched.
In a fixed codebook search for the G.729A codec, a “depth-first tree search” algorithm is used in place of a “focused nested-loop search.” In the G.729 codec, a fast search procedure based on a nested-loop search approach is used, and only 1,440 possible position combinations are tested in the worst case out of 213 position combinations (17.5 percent). In the G.729A codec, search criteria C2/ε tested for a smaller percentage of possible position combinations using a depth-first tree search approach. In this approach, the P excitation pulses in a subframe are partitioned into M subsets of Nm pulses. The search begins with the first subset and proceeds with subsequent subsets according to a tree structure, whereby subset m is searched at the mth level of the tree. The search may be repeated by changing the order in which pulses are assigned to the position tracks.
In particular codebook structures, the pulses may be partitioned into two subsets (M=2) of two pulses (Nm=2). The codebook search is started with the following assignments of pulses to tracks: pulse i0 is assigned to track T2, pulse i1 is assigned to track T3, pulse i2 is assigned to track T0, and pulse i3 is assigned to track T1. The search starts with determining the positions of pulses i0 and i1 by testing a predetermined search criteria for 2×8 or 16 position combinations (i.e. the positions at two maxima of |d(n)| in track T2 are tested in combination with the eight positions in track T3). Once the positions of pulses i0 and i1 are found, the search proceeds to determine the positions of pulses i2 and i3 by testing the search criteria for the 8×8 or 64 position combinations in tracks T0 and T1. The procedure is repeated by cyclically shifting the pulse assignments to the tracks, such as when pulse i0 is assigned to track T3, pulse i1 is assigned to track T0, pulse i2 is assigned to track T1, and pulse i3 is assigned to track T2. The whole procedure is repeated twice by replacing track T3 with track T4 since the fourth can be placed in either T3 or T4. Thus, in total, (64+16)*4 or 320 position combinations are tested (about 3.9 percent of all possible position combinations). About fifty percent of the complexity reduction in the coder may be attributed to the new algebraic codebook search. This is at the expense of a slight degradation in coder performance (about 0.2 dB drop in the signal-to-noise ratio).
The positions of pulses i0, i1 and i2 may be encoded with three bits each, and the position of pulse i3 may be encoded with four bits. Each pulse amplitude may be encoded with one bit. This gives a total of 17 bits for the four pulses. By defining s=1 if the sign is positive and s=0 if the sign is negative, the sign codeword may be obtained from:
S=s0+2s1+4s2+8s3, (25)
and the fixed codebook codeword may be obtained from:
C=(m0/5)+8(m1/5)+64 (m2/5)+512(2(m3/5)+jx) (26)
where jx=0 if m3=3,8, . . . , 38 and jx=1 if m3=4,9 . . . , 39.
A “focus nested-loop search” algorithm is currently used for conventional G.723.1 and G.729 codebook searches. A “depth-first tree search” algorithm is currently used for G.729A codebook searches. By adopting a single fixed codebook search algorithm for both G.723.1 and G.729A, this may simplify the fixed codebook search process so that a single co-processor running one fixed codebook search algorithm may be used for both codecs.
This disclosure proposes a new G.723.1 codebook search algorithm based on a “depth-first tree search” approach, thus having the desired effect of providing one fixed codebook search for both G.723.1 and G.729A codecs. In general, the proposed G.723.1 codebook search algorithm searches a subset of pulses in a subset of tracks rather than searching in a full range of tracks, thereby reducing the number of possible pulse positions being searched.
The similarities and differences between the G.723.1 and G.729A fixed codebook searches are shown below. There are several fixed parameters for both speech codecs:
The method 200 begins by computing a sign of the correlation signal d(n) at step 210. This may occur in the same or similar manner as in the conventional ITU-T G.723.1 codec. Depending on the sign, cross correlation values d(n) between target signal r(n) and impulse response h(n) are modified at step 215. The main diagonal elements of φp(n) are scaled at step 220 to remove the factor of two as given in equation (11) above. A depth-first tree search is used to find the best possible pulse positions that maximize search criteria at step 225. One example of step 225 is shown in
The method 225 then proceeds with performing a first search for determining a first possible set of pulse positions at step 315, followed by performing a second search for determining a second possible set of pulse positions at step 320. Each search includes two phases (denoted “A” and “B”), providing the following sequence:
In Phase A of Search 1, the positions of pulses i0 and i1 are determined by testing the search criteria for 2×8 or 16 position combinations. In other words, the positions at two maxima of |d(n)| in track T2 (including even and odd indexed pulse positions) are tested in combination with the eight positions in track T3 (including odd and even indexed pulse positions). In this manner, the positions of pulses i0 and i1 are found.
The method 315 begins by determining the two maximum pulse positions in the third track assignable to the first pulse i0 at step 410. Next, the pulse positions in the fourth track are tested in combination with each of the two maximum pulse positions in the third track at step 415. This results in one maximum pulse position being assignable to the second pulse i1. The positions of pulses i0 and i1 for the first set of possible pulse positions are then determined in accordance with the predetermined search criteria at step 420.
In Phase B of Search 1, the search proceeds to determine the positions of pulses i2 and i3 by testing the search criteria for the 8×8 or 64 position combinations in tracks T0 and T1 (including odd and even indexed pulse positions). The method 315 continues by testing the pulse positions in the second track in combination with each of the pulse positions in the first track at step 425. The pulse positions of the third pulse and the fourth pulse in the first set of possible pulse positions are determined in accordance with the predetermined search criteria at step 430. In this manner, the positions of pulses i2 and i3 are found, and a total of 16+64 or 80 possible pulse position combinations have been searched.
In other embodiments, the correlation signal values of each pulse position of the first set are compared at both even and odd indexed pulse positions. Whichever value is higher may be selected and re-assigned as the pulse position. If the odd indexed correlation signal value is higher, the “shift bit” value may be set to one. Otherwise, if the even correlation signal value is higher, the “shift bit” value may be set to zero. This may be summarized as follows:
The method 320 begins by performing a cyclical shift of the pulse assignments to the tracks at step 510. For example, pulse i0 may be reassigned to track T3, pulse i1 may be reassigned to track T0, pulse i2 may be reassigned to track T1, and pulse i3 may be reassigned to track T2.
In Phase A of Search 2, a procedure similar to that of step 315 is performed. The two maximum pulse positions in the fourth track assignable to the first pulse i0 are determined at step 515. The pulse positions in the first track are tested in combination with each of the two maximum pulse positions in the fourth track at step 520. This may result in one maximum pulse position assignable to the second pulse i1. The pulse positions i0 and i1 for the second set of possible pulse positions are then determined in accordance with the predetermined search criteria at step 525.
In Phase B of Search 2, the positions i2 and i3 are determined by testing the search criteria for the 8×8 or 64 position combinations in tracks T3 and T0 (including odd and even indexed pulse positions). The pulse positions in the third track are tested in combination with each of the pulse positions in the second track at step 530. The pulse positions of the third pulse and the fourth pulse of the second set are determined in accordance with the predetermined search criteria at step 535.
In other embodiments, the correlation signal values of each pulse position of the second set are again compared at both even and odd indexed pulse positions. Thus, in total, (64+16)*2 or 160 position combinations are searched. This may compare to, for example, approximately 2,000 positions searched in the original ITU-T G.723.1 fixed codebook search, which represents about 8 percent of the original G.723.1 fixed codebook search.
The first and second sets of possible pulse positions may then be compared. The four final pulse positions are then selected from the first and second sets, and the selected pulse positions and their sign and shift values are used to compute the 17-bit codebook vector. In this way, decoder compatibility may not be lost due to the change in the algorithm. Using this technique, there may be up to a 50 percent or more reduction in the complexity of the G.723.1 (5.3 kbps) algebraic codebook search.
Listening tests were also carried out for different speech test vectors by different subjects. There was generally no significant degradation in the perceived speech quality as compared to the original ITU-T algorithm. As a result, the modified algorithm, while possibly providing a slight degradation in speech quality, results in savings of more than 50 percent in processing power over the standard algorithm.
Based on these algorithmic changes to the G.723.1 codebook search algorithm, it is possible to implement a single co-processor solution that supports codebook searches for multiple speech codecs, such as the G.723.1 (5.3 kbps) and G.729A codecs.
A fixed codebook search may be performed twice in each frame for the G.729A speech codec, while a fixed codebook search may be performed four times in a frame for the modified G.723.1 algorithm. This may be handled in a co-processor design by varying the number of times the fixed codebook search is called by the DSP 802. Also, reconfigurable parameters of both speech codecs can be configured by the DSP 802 before the start of processing by the co-processor 804, and the DSP 802 may pass the parameters to the co-processor 804. The reconfigurable parameters may include:
From the codebook structure for both speech codecs shown in Table 1 and Table 2, it can be seen that the G.729A codebook structure has continuous pulse positions from 0-39, while the G.723.1 (5.3 kbps) codebook structure has only even indexed pulse positions from 0-62. Odd indexed pulse position conditions are taken care of by comparing the correlation signal values |d (n)| at both odd and even indexes. Depending on this comparison, a “shift” value is computed as explained above. In G.729A, there is no concept of even and odd indexed pulse positions, and it is therefore unaffected.
In the co-processor design for supporting both codecs in accordance with this disclosure, a codec flag may be implemented for identifying which codec is to be handled. The codec flag could also indicate which parameters to adopt during operation. As such, the same codec flag may be used to handle the added indexed pulses of G.723.1. During the codebook search for G.729A, the fourth pulse i3 is selected from track T3 or track T4. The algorithm thus starts from track T3, and the process is repeated by replacing track T3 by track T4. When considering this in co-processor 804, the same codec flag may be used to indicate the repetition of the algorithm for G.729A by replacing track T3 by track T4.
While maintaining compatibility with ITU-T G.723.1 and ITU-T G.729A decoders, other portions of the fixed codebook search remains the same. The other portions of the algorithm may include computing the sign of the correlation signal d(n), modifying the cross correlation values, and computing the 17-bit codebook vector.
Codebook searches for both speech codecs include computing the autocorrelation value φ(n) of the impulse response h(n) and computing the cross correlation value d(n) using the target signal r(n) and the impulse response h(n). These values may be computed before the start of a codebook search. The way these values are computed may be similar for both speech codecs, except for differences in subframe size (which is a reconfigurable parameter).
Using the new modified algorithm for the G.723.1 (5.3 kbps) fixed codebook search, a single implementation of the G.723.1 and G.729A codebook searches on the co-processor 804 can be made. Codec selection is made using the codec flag and the reconfigurable parameters, which are controlled by the DSP 802. The co-processor 804 mainly handles aspects of the fixed codebook search. The functionality of the co-processor 804 includes:
check the codec flag for G.723.1 or G.729A encoding;
configure the reconfigurable parameters depending on the codec flag;
compute the co-variance φ(n) and the cross-correlation value d(n);
compute the sign and modify the co-variance values depending on the codec flag;
perform pulse assignment and “depth-first tree search” depending on the codec flag (whole range search is repeated for track T3 and T4 in G.729A, and “shift” value is computed depending on even and odd index value in G.723.1); and
compute the 17-bit codevector based on the pulse position indexes and flags.
In this example, Block A contains a pitch estimator, a Formant Perceptual Weighting filter, and a Harmonic Noise Shaping module. Block B contains Line Spectrum Pair (LSP) routines. Both Blocks A and B may be synchronized so that weighted speech W(z) and noise shaper response P(z) are available for the impulse response calculation. In this manner, processing power is reduced by about 17 percent for G.723.1 (5.3 kbps) and about 11 percent for G.723.1 (6.3 kbps).
Similarly,
In some embodiments, various functions performed in conjunction with fixed codebook searches are implemented or supported by a computer program that is formed from computer readable program code and that is embodied in a computer readable medium. The phrase “computer readable program code” includes any type of computer code, including source code, object code, and executable code. The phrase “computer readable medium” includes any type of medium capable of being accessed by a computer, such as read only memory (ROM), random access memory (RAM), a hard disk drive, a compact disc (CD), a digital video disc (DVD), or any other type of memory.
It may be advantageous to set forth definitions of certain words and phrases used throughout this patent document. The term “couple” and its derivatives refer to any direct or indirect communication between two or more elements, whether or not those elements are in physical contact with one another. The term “application” refers to one or more computer programs, sets of instructions, procedures, functions, objects, classes, instances, or related data adapted for implementation in a suitable computer language. The terms “include” and “comprise,” as well as derivatives thereof, mean inclusion without limitation. The term “or” is inclusive, meaning and/or. The phrases “associated with” and “associated therewith,” as well as derivatives thereof, may mean to include, be included within, interconnect with, contain, be contained within, connect to or with, couple to or with, be communicable with, cooperate with, interleave, juxtapose, be proximate to, be bound to or with, have, have a property of, or the like. The term “controller” means any device, system, or part thereof that controls at least one operation. A controller may be implemented in hardware, firmware, software, or some combination of at least two of the same. The functionality associated with any particular controller may be centralized or distributed, whether locally or remotely.
While this disclosure has described certain embodiments and generally associated methods, alterations and permutations of these embodiments and methods will be apparent to those skilled in the art. For example, the above embodiments refer specifically to two codecs (G.723.1 and G.729A). It will be appreciated that various modifications and improvements can be made by a person skilled in the art without departing from the scope of this disclosure. As a particular example, other codecs having ACELP coding and substantially similar structures to the codecs described above could be used. Accordingly, the above description of example embodiments does not define or constrain this disclosure. Other changes, substitutions, and alterations are also possible without departing from the spirit and scope of this disclosure, as defined by the following claims.
Number | Date | Country | Kind |
---|---|---|---|
200407882-0 | Dec 2004 | SG | national |