The present disclosure relates generally to full-duplex voice communication systems and, more particularly, to a method for decoding multiple data streams received in such system.
Secure voice operation with full-duplex collaboration is highly desirable in military radio applications. Full-duplex voice communication systems enable users to communication simultaneously. In existing radio products, full-duplex collaboration has been achieved through the use of multiple vocoders residing in each radio as shown in
Therefore, it would be desirable to provide a more cost effective means of achieving full-duplex collaboration in a radio communication system. The statements in this section merely provide background information related to the present disclosure and may not constitute prior art.
A method is provided for decoding data streams in a voice communication system. The method includes: receiving two or more data streams having voice data encoded therein; decoding each data stream into a set of speech coding parameters; forming a set of combined speech coding parameters by combining the sets of decoded speech coding parameters, where speech coding parameters of a given type are combined with speech coding parameters of the same type; and inputting the set of combined speech coding parameters into a speech synthesizer.
Further areas of applicability will become apparent from the description provided herein. It should be understood that the description and specific examples are intended for purposes of illustration only and are not intended to limit the scope of the present disclosure.
The drawings described herein are for illustration purposes only and are not intended to limit the scope of the present disclosure in any way.
The vocoder 20 is configured to receive a plurality of data streams, where each data stream has voice data encoded therein and corresponds to a different channel in the voice communication system. Voice data is typically encoded using speech coding. Speech coding is a process for compressing speech for transmission. Mixed Excitation Linear Prediction (MELP) is an exemplary speech coding scheme used in military applications. MELP is based on the LPC10e parametric model and defined in MIL-STD-3005. While the following description is provided with reference to MELP, it is readily understood that the decoding process of this disclosure is applicable to other types of speech coding schemes, such as linear predictive coding, code-excited linear predictive coding, continuously variable slope delta modulation, etc.
To support multiple data streams, the vocoder includes a stream decoding module 22 for each expected data stream. Although the number of stream decoding modules preferably correlates to the number of expected collaborating speakers (e.g., 3 or 4), different applications may require more or less stream decoding modules. Each stream decoding module 22 is adapted to receive one of the incoming data streams and operable to decode the incoming data stream into a set of speech coding parameters. In the case of MELP, the decoded speech parameters are gain, pitch, unvoiced flag, jitter, bandpass voicing and a line spectral frequency (LSF) vector. It is readily understood that other speech coding schemes may employ the same and/or different parameters which may be decoded and combined in a similar manner as described below.
To further compress the voice data, some or all of the speech coding parameters may optionally have been vector quantized prior to transmission. Vector quantization is the process of grouping source outputs together and encoding them as a single block. The block of source values can be viewed as a vector, hence the name vector quantization. The input source vector is then compared to a set of reference vectors called a codebook. The vector that minimizes some suitable distortion measure is selected as the quantized vector. The rate reduction occurs as the result of sending the codebook index instead of the quantized reference vector over the channel. When speech coding parameters have been vector quantized, the stream decoding modules 22 will also handle the de-quantization step of the decoding process.
Decoded speech parameters from each stream decoding module 22 are then input to a parameter combining module 24. The parameter combining module 24 in turn combines the multiple sets of speech coding parameters into a single set of combined speech coding parameters, where speech coding parameters of a given type are combined with speech coding parameters of the same type. Exemplary methods for combining speech coding parameters are further below.
Lastly, the set of combined speech coding parameters are input to a speech synthesizing portion 26 of the vocoder 20. The speech synthesizer 26 converts the speech coding parameters into audible speech in a manner which is known in the art. In this way, the audible speech will include voice data from multiple speakers. Depending on the combining method, voices from multiple speakers are effectively blended together to achieve full-duplex collaboration amongst the speakers.
An exemplary method for combining speech coding parameters is further described in relation to
In an exemplary embodiment, the weighting metric is derived from an energy value (i.e., gain value) at which a given data stream was received at. Since the gain value is typically expressed logarithmically in decibels ranging from 10 to 77 dB, the gain value is preferably normalized and then converted to a linear value. Thus, a normalized linear gain value may be computed as NLG=power10(gain−10). For MELP, two individual gain values are transmitted for every frame period. In this case, the normalized gain values may be added, that is (gain[0]−10)+(gain[1]−10), before computing a linear gain value. The weighting metric for a given channel is then determined as follows:
Weighting metricch(i)=NLGch(i)/[NLGch(1)+NLGch(2)+ . . . NLGch(n)]
In other words, the weighting metric for a given channel is determined by dividing the normalized linear gain value for the given channel by the summation of the normalized linear gain value for each channel over which speech coding parameters were received. Rather than taking the gain value for the entire signal, it is envisioned that the weighting metric may be derived from the gain value taken at a particular dominant frequency within the signal. It is also envisioned that the weighting metric may be derived from other parameters associated with the incoming data streams.
In another exemplary embodiment, the weighting metric for a given channel is assigned a predefined value based upon the gain value associated with the given channel. For example, the channel having the largest gain value is assigned a weight of one while remaining channels are assigned a weight of zero. In another example, the channel having the largest gain value may be assigned a weight of 0.6, the channel having the second largest gain value is assigned a weight of 0.3, the channel having the third largest gain value is assigned a weight of 0.1, and the remaining channels are assigned a weight of zero. The weight assignment is performed on a frame-by-frame basis. Other similar assignment schemes are contemplated by this disclosure. Moreover, other weighting schemes, such as a perceptual weighting, are also contemplated by this disclosure.
Next, speech coding parameters are weighted at 34 using the weighting metric for the channel over which the parameters were received and combined at 36 to form a set of combined speech coding parameters. In the case of the gain and pitch parameters, the speech coding parameters may be combined as follows:
Gain=w(1)*gain(1)+w(2)*gain(2)+ . . . w(n)*gain(n)
Pitch=w(1)*pitch(1)+w(2)*pitch(2)+ . . . w(n)*pitch(n)
In other words, multiply each speech coding parameter of a given type by its corresponding weighting metric and summing the products to form a combined speech coding parameter for the given parameter type. In MELP, a combined gain value is computed for each half frame.
In the case of the unvoice flag, jitter and bandpass voice parameters, the speech coding parameters from each channel are weighted and combined in a similar matter to generate a soft decision value.
UVFlagtemp=w(1)*uvflag(1)+w(2)*uvflag(2)+ . . . w(n)*uvflag(n)
Jittertemp=w(1)*jitter(1)+w(2)*jitter(2)+ . . . w(n)*jitter(n)
BPVtemp=w(1)*bpv(1)+w(2)*bpv(2)+ . . . w(n)*bpv(n)
The soft decision value is then translated to a hard decision value which may be used as the combined speech coding parameter. For instance, if UVtemp is >0.5, the unvoice flag is set to one; otherwise, the unvoice flag is set to zero. Bandpass voice and jitter parameters may be translated in a similar manner.
In the exemplary embodiment, the LPC spectrum is represented using line spectral frequencies (LSP). To combine the LSP parameters, it is necessary to convert these parameters to the frequency domain; that is, corresponding predictor coefficients. Thus, the LSP vector from each channel is converted to predictor coefficients. The predictor coefficients from the different channels can then be summed together to get a superposition in the frequency domain. More specifically, the parameters may be weighted in the manner described above.
Pred(i)=w1*pred1+w2*pred2+ . . . wn*predn,
where i=1 to 10 Each of the ten combined predictor coefficients is converted back to ten corresponding spectral frequency parameters to form a combined LSP vector. The combined LSP vector will then serve as the input to the speech synthesizer. While this description is provided with reference to LSP representations, it is understood that other representations, such as log area ratios or reflection coefficients, may also be employed. Moreover, the combining techniques described above are easily extended to parameters from other speech coding schemes.
The above description is merely exemplary in nature and is not intended to limit the present disclosure, application, or uses.
Number | Name | Date | Kind |
---|---|---|---|
6081776 | Grabb et al. | Jun 2000 | A |
6917914 | Chamberlain | Jul 2005 | B2 |
20070094018 | Zinser et al. | Apr 2007 | A1 |
20070208565 | Lakaniemi et al. | Sep 2007 | A1 |
Number | Date | Country |
---|---|---|
2891098 | Mar 2007 | FR |
WO 2005093717 | Oct 2005 | WO |
Entry |
---|
Chamberlain, M. W., A 600 bps MELP vocoder for use on HF channels, 2001; Military Communications Conference, 2001. MILCOM 2001. Communication Network—Centric Operations: Creating the Information Force. IEEE; vol. 1, on pp. 447-453 vol. 1. |
A. B. Touimi et al., “A summation algorithm for MPEG-1 coded audio signals: a first step towards audio processing in the compressed domain”, Ann. Telecommun. 55, No. 3-4, 2000. |
Number | Date | Country | |
---|---|---|---|
20080243489 A1 | Oct 2008 | US |