This application relates to and claims priority from Japanese Patent Application No. 2006-190775, filed on Jul. 11, 2006, the entire disclosure of which is incorporated herein by reference.
The present invention relates to digital wireless communication apparatus, and particularly relates to superior technology for suppressing click noise while maintaining call distance even when code errors occur in ADPCM code and alleviating deterioration in communication quality.
ADPCM (adaptive differential PCM) methods are often used as audio encoding methods for digital cordless telephones. ADPCM encoding methods have the property where click noise that is unexpectedly abrupt to the ear is generated when code errors occur when the influence of weak electric fields, phasing, and electromagnetic interference etc. is incurred so as to cause coding errors in audio data, thus causing audio quality to substantially deteriorate. In order to suppress this click noise, methods subjecting frame data where code errors have been detected by frame error checks such as Cyclic Redundancy Checks to muting processing are typical. However, in cases where there is one main unit acting as a base station as with a digital cordless telephone, there is the problem that the call distance is substantially limited. Further, this causes a voice to be suddenly muted during a call, which causes discomfort for the caller.
In order to resolve this problem, the applicant proposed digital wireless communication apparatus 300 shown in
When error information is detected at the error detector 220, the determination time adjustment section 200 outputs an error detection signal indicating a frame period where code substitution processing may be validly executed to the code substituter 210. The code substituter 210 sequentially monitors a high-speed scale factor yu(k) and a low-speed scale factor yl(k) managed within the quantization scale factor adapter 170 every one sampling for data sections outputting error detection signals, and in the event that yl(k−1) for one sample previous exceeds one of a plurality of threshold values and y(k−1) of one sample previous exceeds a threshold value corresponding to l(k) and yl(k) at this time, it is predicted that click noise will occur, and l(k) is substituted with predetermined code l′(k).
The adaptive de-quantizer 110 then generates a quantization differential signal dq(k) based on ADPCM code l(k) (or l′(k)) and quantization scale factor y(k), and outputs the quantization differential signal dq(k) to the adaptive predictor 120, regenerative signal calculator 140, and tone and changing point detector 190.
The prediction signal limiter 130 compares a prediction signal se(k) and the value of a PCM output so(k−1) for one sample previous. In the event that the input signal is lower than a certain frequency so that so(k−1) is a maximum and se(k) is inverted code for so(k−1), or in the event that the input signal is higher than a certain frequency so that so(k−1) is a maximum and se(k) is a maximum of inverted code of so(k−1), it is predicted that this will generate click noise, se(k) is substituted with the same value as for so(k−1), and these are outputted as se′(k). The prediction signal limiter 130 outputs prediction signal se(k) as is to the regenerative signal calculator 140 when it is not necessary to carry out limiting processing.
The regenerative signal calculator 140 generates a regenerative signal sr(k) based on the quantization differential signal dq(k) and prediction signal se(k) (or se′(k)). The output limiter 14 compresses a regenerative signal sr(k) to a PCM signal so(k). Here, “k” is a variable indicating sampling time.
Further, detection of the input frequency is carried out by determining whether or not a convergent value of a1(k) exceeds a predetermined threshold value utilizing a frequency following characteristic of polar prediction function a1(k) shown in
However, the digital wireless communication apparatus 300 shown in
Further, discomfort will occur for a few hundred to a few thousand samples after even when correct code is received thereafter rather than directly after the erroneous detection in the click noise. There are also cases where rather than a code error occurring once being generated as click noise at this time, this error is accumulated across a few hundred to a few thousand samples so as to give code with a substantial differential for which click noise occurs. With this kind of click noise suppression, a period of a few thousand samples after error detection is necessary in order for a circuit for suppressing click noise to operate.
In this situation, carrying out the determination of the click noise from the relationship between frequency determination results of the saturation signal deviating from the dynamic range and the PCM output makes it easy for erroneous or non-detection to occur and invites deterioration of sound quality.
The present invention therefore tackles the problem of, in the event that encoding errors occur for various input signals, making it possible to suppress click noise occurring due to code that could not be predicted or click noise occurring due to correct code after a few hundred samples to a few thousand samples from a frame errors are detected for, and making it possible to suppress deterioration of communication quality.
In order to resolve the aforementioned problems, a digital wireless communication apparatus of the present invention is equipped with an ADPCM decoder for decoding ADPCM encoded audio data and detecting code errors of audio data. An ADPCM decoder is provided with a multiplier calculating a partial prediction signal composed of the product of a polar prediction coefficient for generating a regenerative signal and a quantized regenerative signal, a display conversion section for converting the partial prediction signal from floating point representation to an absolute value display, and a limiter executing processing for substituting limit values in the partial prediction signal satisfying overflow conditions during conversion of the partial prediction signal from floating point representation to an absolute value display in the event that the error detector determines that there is a code error in the audio data for a predetermined number of frames of the audio data. According to this configuration, it is possible to suppress overflow during conversion of a partial prediction signal from floating point representation to absolute value representation and click noise can be suppressed.
According to a further aspect of the present invention, an ADPCM decoder comprises a limiter executing processing for substituting limit values in the prediction signal satisfying overflow conditions during addition of all of the partial prediction signals for generating the prediction signal for a predetermined number of the audio data frames in the event that the error detector determines that a code error is present in the audio data. According to this configuration, it is possible to suppress overflow during generation of a prediction signal and click noise can therefore be suppressed.
According to the present invention, in the event that encoding errors occur for various input signals, it is possible to suppress click noise occurring due to code that could not be predicted or click noise occurring due to correct code after a few hundred samples to a few thousand samples from a frame errors are detected for, and it is possible to suppress deterioration of communication quality.
When a frame error is detected in received ADPCM code l(k) by error detector 22 using a cyclic redundancy check, a frame error detection signal is outputted to determination time adjustment section 20. In the event that a frame error is detected, determination time adjustment section 20 outputs an error detection signal indicating a frame period (for example, a period from a few hundred to a few thousand samples) where click noise suppression processing is effective to code substituter 21 and adaptive predictor 12.
When an error detection signal is received from determination time adjustment section 20, in the event that predetermined conditions are satisfied based on the values of a high-speed scale factor yu(k), low speed scale factor yl(k) and ADPCM code l(k), the code substituter 21 substitutes ADPCM code l(k) with predetermined code l′(k) across a frame period indicated by the error detection signal from the determination time adjustment section 20. The details of processing for substituting ADPCM code l(k) with predetermined code I′(k) are disclosed in Japanese Patent Laid-open Publication No. 2006-50476 and are not described here.
ADPCM code l(k) is for performing encoding and transfer after a differential signal d(k) for a prediction signal and a quantized PCM signal is quantized on the transmission side. Namely, at the adaptive quantizer on the transmission side, the differential signal d(k) is converter to a logarithm taking 2 as a base, and is then normalized by scale factor y(k). The value of the log2 (d(k))−y(k) obtained in this way is then quantized, and ADPCM code l(k) is generated by code substitution.
The adaptive de-quantizer 11 then generates a quantization differential signal dq(k) based on ADPCM code l(k) (or l′(k)) and quantization scale factor y(k), and outputs the quantization differential signal dq(k) to the adaptive predictor 12 with a limit function, regenerative signal calculator 13, and tone and changing point detector 17.
The adaptive predictor 12 with a limit function generates a prediction signal se(k) and polar prediction coefficient a2(k) based on quantization differential signal dq(k) and speed variable tr(k). The adaptive predictor 12 with a limit function executes limiting processing for suppressing click noise for an internal variable (partial prediction signal) for generating the prediction signal se(k) across a frame period indicated by an error detection signal from the determination time adjustment section 20.
The regenerative signal calculator 13 generates a regenerative signal sr(k) based on the quantization differential signal dq(k) and prediction signal se(k).
Output limiter 14 compresses a regenerative signal sr(k) to a PCM signal so(k).
Quantization scale factor adapter 15 generates scale factor y(k), high-speed scale factor yu(k) and low-speed scale factor yl(k) based on the ADPCM code l(k) (or l′(k)) and adaptive speed control variable al(k).
The scale factor y(k), high-speed scale factor yu(k) and low-speed scale factor yl(k) are generated as shown in the following equation.
y(k)=al(k)·yu(k−1)+[1−al(k)]·yl(k−1)
yu(k)(1−2−5)·y(k)+2−5·W [I(k)]
yl(k)(1−2−6)·yl(k)+2−6·yu(k)
The value of W[l(k)] is defined as shown in
Quantization scale factor adapter 15 outputs the scale factor y(k) to adaptive de-quantizer 11 and outputs low-speed scale factor yl(k) to the tone and changing point detector 17. Further, quantization scale factor adapter 15 outputs a high-speed scale factor yu(k−1) for one sample previous and low-speed scale factor yl(k−1) to code substituter 21.
Adaptive speed controller 16 generates an adaptive speed control variable al(k) based on the scale factor y(k), ADPCM code l(k) (or l′(k)), speed variable tr(k), and control variable td(k). The tone and changing point detector 17 generates a speed variable tr(k) and control variable td(k) based on the polar prediction coefficient a2(k), quantization differential signal dq(k), and low-speed scale factor yl(k).
The above signals are all sampled digital signals with the character k within parenthesis for each signal indicating sampling time.
Prediction signal se(k) is calculated as follows.
Here, sez(k) is calculated as follows.
Further, regenerative signal sr(k) is defined as follows.
sr(k−i)=se(k−i)+dq(k−i)
With either prediction coefficient, sequential updating employing the simplified gradient method takes place.
In
The A1 display converter 80 converts a polar prediction coefficient A1 to floating point representation. The SR1 display converter 81 converts a regenerative signal SR1 to floating point representation. The multiplier 82 multiplies the polar prediction coefficient A1 and the regenerative signal SR1. WA1MANT display converter 85 converts the multiplication results from a floating point representation to an absolute value display. WA1MAG display converter 86 converts the multiplication results from an absolute value display to a two's compliment display and outputs this as prediction signal WA1.
WA1MANT display converter 85 then converts the floating point representation to an absolute value display in accordance with the following equation.
When WA1EXP<=26,
WA1MAG=(WA1MANT<<7)>>(26−WA1EXP)
When WA1EXP>26,
WA1MAG=(WA1MANT<<7)<<(WA1EXP−26)
WA1EXP indicates a floating point representation exponent section (maximum value 28) for prediction signal WA1, WA1MANT indicates a floating point representation mantissa section (eight bit) for prediction signal WA1, and WA1MAG indicates an absolute value display (fifteen bit) for prediction signal WA1.
Here, the amount of left shift of WA1MANT is considered. WA1MAG is 15 bit data and no problems occur if the amount of left shift of WA1MANT of the eight bits of data is up to seven bits. However, in the event that a maximum value of 28 is taken and the value of WA1EXP is 27 or 28, WA1MANT is shifts eight or nine bits to the left. The most significant bit of WA1MANT is therefore shifted out due to the value of WA1MANT
The prediction signal WA1 calculator 58 with a limit function therefore executes the limit processing shown in
If a frame error has not occurred (step 501; NO), determination unit 83 determines whether or not the value of WA1EXP is 26 or less (step 502). If the value of WA1EXP is 26 or less (step 502; YES), WA1MANT display converter 85 executes calculation of WA1MAG=(WA1MANT<<7)>>(26-WA1EXP) (step 503). On the other hand, if the value of WA1EXP is 27 or 28 (step 502; NO), WA1MANT display converter 85 executes the calculation of WA1MAG=(WA1MANT<<7)<<(WA1EXP−26) (step 504).
If a frame error occurs (step 501; YES). determination unit 83 determines whether the value of WA1EXP is 27 and the value of WA1MANT is larger than 0x7F, or the value of WA1EXP is 28 and the value of WA1MANT is larger than 0x3F (step 505). In the event that the value of WA1EXP is 27 and the value of WA1MANT is 0x7F or less, or in the event that the value of WA1EXP is 28 and the value of WA1MANT is 0x3F or less, the processing of step 502 is executed.
In the event that the value of WA1EXP is 27 and the value of WA1MANT is larger than 0x7F, or the value of WA1EXP is 28 and the value of WA1MANT is larger than 0x3F (step 505; YES), when the calculation of WA1MAG=(WA1MANT<<7)<<(WA1EXP−26) is executed, the uppermost bit of WA1MANT shifts out to the left and WA1MAG limiter 84 therefore substitutes a predetermined limit value (for example, 0x7F00) in WA1MAG
The adder 90 adds prediction signals WB1 to WB6 and outputs the results of this addition as SEZI. The SEZI shifter 96 shifts SEZI one bit to the right, and outputs the result as SEZ. The adder 91 adds SEZ1 and WA2 and outputs the results of this addition as preSEI. The adder 92 adds preSEI and WA1 and outputs the results of this addition as SEI. The SEI shifter 95 shifts SEZ one bit to the right, and outputs the result as SE.
The process of adding preSEI and WA1 is now considered. As described above, under certain conditions (step 505; YES), a limit value is substituted at WA1MAG In doing so, when preSEI and WA1 are added, it is possible that SEI may overflow.
The prediction signal adder 78 with a limit function therefore executes the limit processing shown in
In the event that an error detection signal is received (step 702; YES), the determination unit 93 determines whether or not the most significant bits of preSEI and WA1 are 9, and that the most significant bit of SEI is 1 (step 703). In the event that the most significant bits of preSEI and WA1 are 0 and the most significant bit of SEI is 1 (step 703; YES), it is shown that SEI code is determined as a result of the overflow, and SEI limiter 94 substitutes a positive limit value (for example, 0x7FF) in SEI (step 704).
In the event that the most significant bits for preSEI and WA1 respectively are 0 and the most significant bit of SEI is 0 (step 703; NO), the determination unit 93 determines whether or not the most significant bits of preSEI and WA1 are 1 and the most significant bit of SEI is 0 (step 705). In the event that the most significant bits of preSEI and WA1 are 1 and the most significant bit of SEI is 0 (step 705; YES), it is shown that SEI code is determined as a result of the overflow, and SEI limiter 94 substitutes a negative limit value (for example, 0x800) in SEI (step 706).
In the event that the most significant bits of preSEI and WA1 are 1 and the most significant bit of SEI is not 0 (step 705; NO), prediction signal adder 78 with a limit function omits the processing routine.
According to this embodiment, in the event that encoding errors occur for various input signals, it is possible to suppress click noise occurring due to code that could not be predicted or click noise occurring due to correct code after a few hundred samples to a few thousand samples from a frame errors are detected for, and it is possible to suppress deterioration of communication quality.
Number | Date | Country | Kind |
---|---|---|---|
2006-190775 | Jul 2006 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
4751736 | Gupta et al. | Jun 1988 | A |
4860313 | Shpiro | Aug 1989 | A |
5787129 | Willming | Jul 1998 | A |
6680986 | Hemmati | Jan 2004 | B1 |
6690739 | Mui | Feb 2004 | B1 |
6734920 | Ghosh et al. | May 2004 | B2 |
7295617 | Shimotoyodome | Nov 2007 | B2 |
7391813 | Shinsho | Jun 2008 | B2 |
20010040927 | Chu | Nov 2001 | A1 |
20060029140 | Shinsho | Feb 2006 | A1 |
Number | Date | Country |
---|---|---|
2004-050476 | Feb 2006 | JP |
Number | Date | Country | |
---|---|---|---|
20080015849 A1 | Jan 2008 | US |