This application is based upon and claims the benefit of priority from Japanese patent application No. 2005-095735, filed on Mar. 29, 2005, the disclosure of which is incorporated in its entirety herein by reference.
1. Field of the Invention
The present invention relates to encoding and decoding technology for transmitting or storing speech signals at low bit rates. In particular, the present invention relates to code conversion (transcoding) technology for converting a first code sequence obtained by encoding a speech signal with a first speech coding scheme into a second code sequence that is decodable with another speech coding scheme.
2. Description of the Related Art
Code Excited Linear Prediction (CELP) is well known as one of the speech coding schemes that encode a speech signal efficiently at medium and low bit rates. The CELP scheme is described in:
[1] M. R. Schroeder and B. S. Atal, “Code excited linear prediction: high quality speech at very low bit rates,” Proc. of IEEE Int. Conf. on Acoustics, Speech and Signal Processing, pp. 937-940, 1985.
According to the CELP scheme, the encoder separates, from the input speech signal, Linear Prediction (LP) coefficients for characterizing a linear prediction filter and an excitation signal for exciting this LP filter. The encoder encodes the LP coefficients and the excitation signal, and transmits them to the decoder. The decoder sets the received LP coefficients to its LP filter and excites this LP filter with the received excitation signal to reproduce a high quality speech signal.
This excitation signal is expressed by a weighted sum of Adaptive Codebook (ACB) and Fixed Codebook (FCB). The ACB contains pitch periods of the input speech signal, whereas the FCB consists of random numbers and pulses. Multiplying the ACB and FCB components by their respective gains (ACB gain and FCB gain) yields the excitation signal.
When a 3G (third generation) mobile-network and a wired packet network, for example, are to be interconnected, standard speech coding schemes used in these networks may be different. Thus, in order to achieve direct connection of these two networks, code conversion technology between different speech coding schemes (i.e. transcoding) would be required. Tandem connection is known as one of the transcoding technologies for speech coding.
With reference to
In
Regarding the speech encoding and decoding scheme, details are found in the reference [1] above and in
[2] 3GPP TS 26.090, “AMR Speech Codec; Transcoding Functions.”
However, the code conversion apparatus in
US2003/0065508A(reference [3]) discloses a code conversion apparatus which converts the first input code sequence into the code sequence of the second speech coding scheme without decoding a non-speech part within the first code sequence.
In this code conversion apparatus, a code separation part separates a non-speech code within the first code sequence into a plural number of element codes, and a non-speech code conversion part converts these element codes into a plural number of element codes for the second speech coding scheme. This code conversion apparatus multiplexes the second element codes obtained by this conversion to output the second non-speech code sequence. The code conversion apparatus further multiplexes this second non-speech code sequence and a second speech code sequence being converted by a speech code conversion part, and outputs the second code sequence.
This code conversion apparatus requires a non-speech code conversion circuit which converts a first non-speech code sequence into a second non-speech code sequence. This non-speech code conversion requires a large amount of processing. For example, consider a case where the non-speech code sequence conforming to the AMR scheme is to be converted into the non-speech code sequence conforming to ITU-T Recommendation G.729. Each of the code sequences contains LP coefficient information indicating spectrum envelope and power information for every frame as comfortable noise (CN) information.
However, the encoder for the AMR scheme transmits at every 8 frames average values over 8 frames of the LP coefficients and power information. On the other hand, the encoder for the G.729 transmits average values over the previous 6 frames or values for the present frame of the LP coefficient information non-periodically. The encoder for the G.729 also transmits average values over the previous 3 frames or values for the present frame of the power information.
Namely, between these two speech coding schemes, not only concrete codes for the CN information but also transmission intervals for each element code are different. Therefore, the non-speech code conversion circuit given in the reference [3] requires a large amount of processing for converting the element codes.
The first exemplary feature of the invention provides code conversion apparatus with a reduced amount of processing for the code conversion stated above.
According to a first exemplary aspect of the invention, there is provided a code conversion method to convert a first code sequence conforming to a first speech coding scheme into a second code sequence conforming to a second speech coding scheme. The method includes the following steps. The first step discriminates whether the first code sequence corresponds to a speech part or to a non-speech part, and generates a numerical value that indicates the discrimination result as a control flag. The second step converts the first code sequence into the second code sequence and outputs said second code sequence, when the value of the control flag corresponds to the speech part. The third step outputs the second code sequence that corresponds to the value of the control flag, when the value of the control flag corresponds to the non-speech part.
The first exemplary aspect of the invention reduces the amount of processing regarding the non-speech code, when the first code sequence conforming to the first speech coding scheme is converted into the second code sequence conforming to the second speech coding scheme. The reason for this is that the first exemplary aspect of the invention discriminates, based on the information obtained from the first code sequence, whether the code sequence corresponds to a speech part or to a non-speech part. A numerical value indicating this discrimination result is generated as a control flag. And the first exemplary aspect of the invention generates the non-speech part of the second code sequence, based on the value of this control flag. Conversion of the non-speech part code sequence according to the first exemplary aspect of the invention does not require the process consisting of decoding with the first speech coding scheme and re-encoding with the second speech coding scheme.
The first exemplary aspect of the invention significantly reduces the amount of processing in comparison with the conversion process where the non-speech part code sequence as represented by the reference [2] is converted into the non-speech part code sequence for other speech coding schemes. The reason for this is that the first exemplary aspect of the invention does not convert the first non-speech code sequence into the non-speech code sequence for the second speech coding scheme but generates the code sequence corresponding to the non-speech part for the second speech coding scheme (or outputs a pre-stored code sequence) based on the information indicating the type of the code sequence obtained from the first code sequence. Therefore, the amount of computation required for the code conversion can be significantly reduced.
Other features and aspects of the invention will become apparent from the descriptions of the preferred embodiments.
The above and further objects, novel features and advantages of the present invention will be more fully understood from the following detailed description when read together with the accompanying drawings in which:
First, outlines and principles of the present invention are explained.
In the description below, “non-speech” means sounds other than voice and music. “Non-speech” includes silence, noise, tones, etc.
The method of the present invention has the following basic steps.
[STEP A] This step discriminates, using information contained in each frame of the first code sequence, whether the first code sequence within the frame corresponds to speech or non-speech part, and generates a control flag indicating the discrimination result.
[STEP B] This step converts the first code sequence into the second code sequence, when the control flag indicates speech part.
[STEP C] This step generates the second code sequence corresponding to the value of the control flag, when the control flag indicates non-speech part. STEP C may read and output the pre-stored second code sequence that corresponds to type information of non-speech.
STEP A can be replaced by the following STEPs A1 and A2.
[STEP A1] This step decodes a speech signal from the first code sequence with the first decoding method.
[STEP A2] This step generates a control flag that indicates whether the said first code sequence corresponds to speech or non-speech part, using the decoded speech signal.
The present invention, based on the information obtained from the first code sequence, discriminates the type information that indicates to which of a speech part or a non-speech part the first code sequence corresponds. Further, the present invention discriminates the type information of the non-speech part. If the number of types of the non-speech part is only one, then the number of values of the control flag for this non-speech part is one. When the first code sequence corresponds to the non-speech part, the present invention generates, based on the value of this control flag, a non-speech code sequence for the second speech coding scheme without performing the process of code conversion (decoding with the first speech coding scheme and re-encoding the decoded signal with the second speech coding scheme).
Thus, the present invention reduces, in accordance with the ratio of the non-speech part to the whole code sequence, the amount of processing required for decoding the first code sequence with the speech decoding circuit for the first speech coding scheme and then re-encoding the speech signal obtained by the said decoding with the speech encoding circuit for the second speech coding scheme. In general, the time ratio for the non-speech part is larger than that for the speech part. Therefore, the effect of reduction in the required amount of processing realized by the present invention is remarkable, even if the speech part is decoded and re-encoded as in tandem connection.
Moreover, the present invention does not require the process that is essential to the technology in the reference [3], namely the process for separating the element codes, converting the separated element codes and multiplexing the converted element codes. For this reason, the present invention can shorten the time required for converting the non-speech code sequence.
Embodiment 1
Next, Embodiment 1 of the present invention will be explained in detail referring to
In
The frame type extracting circuit 1200 separates a header and a payload from the first code sequence supplied to the input terminal 10. Then, the frame type extracting circuit 1200 extracts frame type information from this header, and outputs this frame type information to the discrimination circuit 1300.
The discrimination circuit 1300 receives the frame type information from the frame type extracting circuit 1200. The discrimination circuit 1300 generates a control flag based on this frame type information. The discrimination circuit 1300 outputs this control flag to the first switch 1110, the second switch 1120 and the code sequence generating circuit 1400. The discrimination circuit 1300 outputs a control flag with value “0,” when the frame type information indicates a speech part. The discrimination circuit 1300 outputs a control flag with value “1,” when the frame type information indicates noise. The discrimination circuit 1300 outputs a control flag with value “2,” when the frame type information indicates silence. Namely, based on the frame type information, Embodiment 1 acquires the type information of the first code sequence within the frame.
In general, the first code sequence includes a header and a payload. Since the header contains the frame type information, the discrimination circuit can discriminate whether the decoded signal from the first code sequence within the frame corresponds to the speech part or to the non-speech part (silence or noise) without decoding the first code sequence.
The details of the header and the frame type information are described in
[4] 3GPP TS 26.101, “AMR Speech Codec Frame Structure.”
The payload contains code sequences corresponding to parameters representing a speech signal (speech parameters), when the frame type information indicates speech. Here, the speech parameters include e.g. LP coefficients, ACB, FCB, ACB gain and FCB gain. On the other hand, the payload contains code sequences representing noise (noise parameters), when the frame type information indicates non-speech. The noise parameters include e.g. LP coefficients and frame energy.
The size of payload for non-speech is smaller than that for speech, or zero. Namely, the size of payload has different values for the speech part and the non-speech part.
Therefore, by discriminating the size of payload or the size of frame in the first code sequence instead of discriminating the frame type information, the discrimination circuit of Embodiment 1 may discriminate for each frame whether the decoded signal from the first code sequence corresponds to the speech part or to the non-speech part.
According to the reference [4] above, a relationship between the type of payload (speech, non-speech or silence), the size of payload and the frame type is as given in
In
Here, Embodiment 1 can be modified so that when the control flag is “0” or “1” the first switch outputs the first code sequence to the speech decoding circuit 1050.
Though the code sequence conversion circuit 1100 of Embodiment 1 has a similar structure to that in
The code sequence generating circuit 1400 generates the second code sequence corresponding to the first code sequence of the non-speech part, and outputs this second code sequence to the second switch 1120. Here, “to generate the second code sequence corresponding to the first code sequence of the non-speech part” means “to generate the second code sequence for noise, silence or tones corresponding to the value of the control flag.”
Next, a case where the control flag indicates silence is explained. In generating the second non-speech code sequence, the code sequence generating circuit 1400 refers to the value of the control flag.
For example, if the second speech coding scheme conforms to 3GPP AMR Codec, the size of payload for silence is 0 bit as mentioned above. In this case, the second code sequence generated consists of the header (frame type is 15) only.
And, for example, if the second speech coding scheme conforms to ITU-T Recommendation G.711, the code indicating silence is 0×FF and the payload consists of the 0×FF codes whose number is equal to the number of the samples corresponding to the frame length. For instance, if the frame length is 20 msec and the sampling frequency is 8000 Hz, the number of the samples corresponding to the frame length is calculated to be 160. Therefore, the payload in this case is 1280 bit data having 160 0×FF codes.
The details of G.711 is given in
[5] ITU-T Recommendation G.711, “Pulse Code Modulation (PCM) of Voice Frequencies.”
Whereas the above description concerns an example of generating the second code sequence for silence, it is possible in the present Embodiment to generate the second code sequence for noise. For example, the code sequence generating circuit 1400 internally stores pre-encoded noise conforming to the second speech coding scheme. Then, the code sequence generating circuit 1400 can generate this encoded noise in accordance with the value of the control flag.
Here, the code sequence generating circuit may be modified to output a second code sequence corresponding to a predetermined substitute signal (for example, a substitute signal determined by an upper apparatus of this embodiment) when the control flag value is a value other than “0(speech)”. For instance, the code sequence generating circuit may be modified to output the second code sequence corresponding to “silence” even when the control flag value indicates non-speech part (“silence”, “noise”, “tone” etc. Further, the code sequence generating circuit may be modified to output the second code sequence corresponding to “noise” with small amplitude even when the control flag value indicates non-speech part.
In
Here, as was mentioned above, Embodiment 1 may be modified so that when the control flag is “0” or “1” the second switch 1120 outputs the second code sequence being output from the speech encoding circuit 1060 to the output terminal 20.
Since the embodiment does not necessitate any modifications of the speech decoding circuit and the speech encoding circuit, said speech decoding circuit or said speech encoding circuit conforming to respective standard coding schemes can be used as it is.
The present Embodiment brings about effects of reducing the amount of processing, when the input speech coding scheme (the first scheme) and the output speech coding scheme (the second scheme) are of the same kind or even of different kinds. For example, when the input speech coding scheme and the output speech coding scheme are of the same kind, this corresponds to altering the bit rate. Even in this case, Embodiment 1 reduces the amount of processing for the non-speech part.
Further, if the first coding scheme of the first code sequence is the same as the second coding scheme of the second code sequence, the embodiment may also be modified as next. In this case, this modification does not require the code conversion function of the speech part. Namely, in the modification, the code conversion 1100 of
Embodiment 2
In the present Embodiment, the code sequence conversion circuit 1100 of tandem connection in Embodiment 1 is replaced by a second code sequence conversion circuit 2100. Thus, the second code sequence conversion circuit 2100 will be explained below.
The second code sequence conversion circuit 2100 performs code conversion for each code corresponding to the speech parameters of the first code sequence of the speech part being supplied from the first switch 1110. And the second code sequence conversion circuit 2100 outputs to the second switch 1120 a code sequence that consists of the codes converted by this code conversion. The details of the code conversion without the tandem connection are described in
[6] Hong-Goo Kang et al., “Improving transcoding capability of speech coders in clean and frame erasured channel environments,” Proc. of IEEE Workshop on Speech Coding 2000, pp. 78-80, 2000.
Embodiment 3
In
Here, the speech signal detection circuit 3200 calculates this control flag by making use of such feature quantity characterizing the speech signal as pitch periodicity, spectrum slope, speech power, etc. that are computable from the decoded speech signal. Namely, the speech signal detection circuit sets a corresponding value to the control flag, discriminating whether these feature quantities correspond to a speech part or to a non-speech part. This control flag may classify the non-speech part into a noise part and a silence part, as is found in the output of the discrimination circuit 1300 in Embodiment 1.
For example, in the case of the feature quantity of speech power, the simplest way is to correspond a part having a relatively large power to the speech part and a part having a relatively small power to the non-speech part. Thus, the speech signal detection circuit 3200 sets “0” to the control flag when the power is large and “1” when power is small.
The details of the method of classifying the speech signal into speech and non-speech part are described in
[7] 3GPP TS 26.094, “AMR Speech Codec; Voice Activity Detector (VAD).”
The non-speech part is not restricted to noise or silence. For instance, tone signals may also be considered as non-speech part. In this case, the speech signal detection circuit 3200 provides an additional function of tone signal detection circuit. And this speech signal detection circuit sets, e.g. “3” to the control flag when the decoded speech signal corresponds to tone signals.
The details of the method of detecting tone signals are described in EP-A-1395065, “Tone detector and method therefore.” (Reference [8])
In
The control flag is supplied to the speech encoding circuit 1061 from the speech signal detection circuit 3200. When this control flag value is “0” (indicating speech part), the speech encoding circuit 1061 re-encodes with the second speech coding scheme the decoded speech signal being output from the speech decoding circuit 1050. Then, the speech encoding circuit 1061 supplies the code sequence obtained through this re-encoding to the second switch 1120 as the second code sequence. The speech encoding circuit 1061 has a similar structure to that of the speech encoding circuit 1060 in Embodiment 1, except that the processing of speech encoding is performed or not performed on the basis of the value of the control flag.
The code sequence generating circuit 3400 generates the second code sequence corresponding to silence, noise or tones, when the control flag being output from the speech signal detection circuit 3200 indicates other values than the value of the speech part. The second code sequence thus generated is supplied to the second switch 1120. Here, the code sequence generating circuit 3400 generates the second code sequence corresponding to silence or noise in the same manner as the code sequence generating circuit 1400 in
As the code sequence generating circuit 1400 of
Embodiment 4
In the present Embodiment, the code sequence generating circuit 1400 in Embodiment 1 is replaced by a code sequence output circuit 3000. Such replacement may be applied to Embodiments 2 and 3.
Hereafter, the code sequence output circuit will be explained.
The code sequence output circuit 3000 consists of a memory circuit 3001 and an output circuit 3002.
The memory circuit 3001 pre-stores the second code sequence corresponding to non-speech part (silence, etc.) in relation to the values of the control flag.
For example, when the second speech coding scheme conforms, to 3GPP AMR Codec, the second code sequence consists of the header (the frame type is 15) only, because the size of payload for silence is 0 bit as described above.
When the second speech coding scheme conforms to ITU-T G.711, the payload consists of the 0×FF codes whose number is equal to the number of the samples corresponding to the frame length. For instance, if the frame length is 20 msec and the sampling frequency is 8000 Hz, the number of the samples corresponding to the frame length is calculated to be 160. The payload in this case is considered to be 1280 bit data having 160 0×FF codes. The details of ITU-T G.711 is given in the reference [5] mentioned earlier.
The above explanation is for generating the second code sequence for silence. Similar to Embodiment 1, a code sequence for noise may also be pre-stored in the memory circuit 3001.
The output circuit 3002 reads out the second code sequence stored in the memory circuit 3001 in accordance with the value of the control flag, and supplies this second code sequence to the second switch 1120.
In this embodiment, similar to Embodiment 1, the second switch 1120 outputs to the output terminal 20 the second code sequence being output from the speech encoding circuit 1060, when the control flag is “0” (indicating speech part). When the control flag is either “1” (indicating noise) or “2” (indicating silence), the second switch 1120 outputs the second code sequence being output from the code sequence output circuit 3000. Here, similar to Embodiment 1, the second switch 1120 may supply to the output terminal 20 the second code sequence being output from the speech encoding circuit 1060, when the control flag is either “0” or “1.”
Embodiment 5
The code conversion apparatus in each of the above described Embodiments according to the present invention may be realized under the control of a computer such as a digital signal processor. In Embodiment 5, the code conversion apparatus under the control of a computer such as a digital signal processor will be explained.
The program for executing the following processing is stored in the recording medium 6.
(A) Processing of discriminating whether the first code sequence corresponds to a speech part or to a non-speech part by using the information contained in the first code sequence, and outputting a control flag indicating the discrimination result;
(B) Processing of converting the first code sequence into the second code sequence, when this control flag indicates a speech part; and
(C) Processing of generating the second code sequence for non-speech corresponding to the flag, when this control flag indicates non-speech.
The processing (A) can be realized using the following processing (A1) and (A2).
(A1) Processing of decoding a speech signal from the first code sequence with the first decoding method; and
(A2) Processing of discriminating whether the first code sequence corresponds to speech or non-speech using the decoded speech signal, and outputting a control flag indicating the discrimination result.
In
Further, the processing (C) may be realized by the following processing (C1).
(C1) Processing of outputting the second code sequence corresponding to the control flag, by selecting said second code sequence from the pre-stored second code sequences for non-speech. In this case, it is preferable to pre-store the second code sequences for non-speech in the recording medium 6 as part of the program.
While this invention has been described in connection with certain exemplary embodiments, it is to be understood that the subject matter encompassed by way of this invention is not be limited to those specific embodiments. On the contrary, it is intended for the subject matter of the invention to include all alternatives, modifications and equivalents as can be included with the sprit and scope of the following claims. Further, the inventor's intent is to retain all equivalents even if the claims are amended during prosecution.
Number | Date | Country | Kind |
---|---|---|---|
2005-095735 | Mar 2005 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5835889 | Kapanen | Nov 1998 | A |
5991716 | Lehtimaki | Nov 1999 | A |
6424822 | Mekuria et al. | Jul 2002 | B1 |
6654718 | Maeda et al. | Nov 2003 | B1 |
6678654 | Zinser et al. | Jan 2004 | B2 |
6766291 | Chu et al. | Jul 2004 | B2 |
6832195 | Johnson | Dec 2004 | B2 |
7023880 | El-Maleh et al. | Apr 2006 | B2 |
7092875 | Tsuchinaga et al. | Aug 2006 | B2 |
7310322 | Graf et al. | Dec 2007 | B2 |
7505590 | Apostolopoulos | Mar 2009 | B1 |
7630884 | Murashima | Dec 2009 | B2 |
20020006138 | Odenwalder | Jan 2002 | A1 |
20020016161 | Dellien et al. | Feb 2002 | A1 |
20020118650 | Jagadeesan et al. | Aug 2002 | A1 |
20030065508 | Tsuchinaga et al. | Apr 2003 | A1 |
20030083102 | Blum et al. | May 2003 | A1 |
20050027517 | Jabri et al. | Feb 2005 | A1 |
20050053130 | Jabri et al. | Mar 2005 | A1 |
20050084094 | Gass et al. | Apr 2005 | A1 |
20050258983 | Jabri et al. | Nov 2005 | A1 |
20050265399 | El-Maleh et al. | Dec 2005 | A1 |
20100223053 | Sandgren et al. | Sep 2010 | A1 |
Number | Date | Country |
---|---|---|
1 288 813 | Mar 2003 | EP |
1 288 913 | Mar 2003 | EP |
1 395 065 | Mar 2004 | EP |
1 617 415 | Jan 2006 | EP |
63-231500 | Sep 1988 | JP |
8-330972 | Dec 1996 | JP |
2001-265390 | Sep 2001 | JP |
2001-316753 | Nov 2001 | JP |
2003-76394 | Mar 2003 | JP |
WO 2004095424 | Nov 2004 | WO |
Entry |
---|
H. Purnhagen. An overview of MPEG-4 Audio Version 2. In AES 17th International Conference on High Quality Audio Coding, Florence, Italy, Sep. 1999. |
Bessette, B.; Salami, R.; Lefebvre, R.; Jelinek, M.; Rotola-Pukkila, J.; Vainio, J.; Mikkola, H.; Jarvinen, K.; , “The adaptive multirate wideband speech codec (AMR-WB),” Speech and Audio Processing, IEEE Transactions on , vol. 10, No. 8, pp. 620-636, Nov. 2002. |
H. Kang et al., “Improving Transcoding Capability of Speech Coders in Clean and Frame Erasured Channel Environments,” Proc. of IEEE Workshop on Speech Coding, 2000, pp. 78-80. |
M. Schroeder et al., “Code-excited Linear Prediction (CELP): High-quality Speech at Very Low Bit Rates,” Proc. of IEEE Int. Conf. on Acoustics, Speech and Signal Processing, 1985, pp. 937-940. |
3GPP TS 26.101 V3.3.0, 3rd Generation Partnership Project; Technical specification Group and System Aspects; AMR Speech Codec Frame Structure, 1999, pp. 1-19. |
3G TS 26.090 V3.1.0, 3rd Generation Partnership Project, Mandatory Speech Codec speech processing functions AMR speech codec; Transcoding Functions, 1999, pp. 1-61. |
3G TS 26.094 V3.0.0, 3rd Generation Partnership, Mandatory Speech Codec speech processing functions AMR speech codec; Voice Activity Detector (VAD), 1999, pp. 1-29. |
International Telecommunication Union-T, “Pulse code modulation (PCM) of voice frequencies,” pp. 1-10, 1993. |
Number | Date | Country | |
---|---|---|---|
20060222084 A1 | Oct 2006 | US |