The present invention relates generally to tone detectors for telephone systems and in particular to an improved tone detector with filter characterized by spectral nulls located to suppress frequencies adjacent the tone to be detected and an improved detection algorithm using roll-off characteristics of the filter and background noise.
Multi-Frequency (MF) tones are used extensively in telecommunications. Examples of MF tones are DTMF and R2. Typical prior art tone detectors include a pre-filter for suppressing out-of-band frequencies, an analysis filter for determining the energy of the input signal at each multi-frequency tone of interest, and a decision logic block for interpreting the multi-frequency energy values output from the analysis filter and in response performing a pass/fail test for determining the presence or absence of a tone at each multi-frequency tone of interest.
Prior art analysis filters have been implemented using standard digital filtering techniques. The analysis window for such prior art digital filters must be carefully chosen. Rectangular windows are often used for simplicity. However, the leakage of energies in the side lobes of the rectangular window is such that other MF frequencies may be incorrectly detected. Also, fast roll-off characteristics (i.e. high order) are usually imposed in order to fail any tone that deviates excessively from its nominal value.
According to one aspect of the present invention there is provided a multi-frequency tone detector with analysis window (i.e. filter size) chosen such that spectral nulls are located at adjacent frequencies of interest. According to another aspect, the decision logic block uses the roll-off characteristics of the filter in conjunction with background noise to determine a threshold pass/fail for any tone that has deviated excessively from its nominal value. The foregoing aspects of the invention result in simpler filter design (i.e. reduced order) relative to prior art tone detectors, while maintaining high tone detection accuracy.
A preferred embodiment of the present invention will now be described more fully with reference to the accompanying drawings in which:
The analysis filters 3 are implemented as DFT filters using a modified Goertzel algorithm, one for each MF (e.g. R2) frequency. The Goertzel filter is centered at the R2 frequency.
According to the preferred embodiment a rectangular window was chosen for the DFT (Goertzel) filter. The choice of a rectangular window results in reduced complexity relative to other filter types. For example, pre-processing the data with either a raised cosine or Kaiser window has a considerable MIPS impact. As indicated above, however, the leakage of the energies in the side lobes can be significant in rectangular windows (especially if two valid frequencies to be detected have a relative twist). Thus, according to an aspect of the invention, the filter size is chosen in such a way that the other MF frequencies fall in its spectral nulls, thereby greatly reducing the leakage effect.
R2 is a special case of MF communication. The six R2 signaling frequencies are situated at 540 Hz, 660 Hz, 780 Hz, 900 Hz, 1020 Hz and 1140 Hz for the backward direction and at 1380 Hz, 1500 Hz, 1620 Hz, 1740 Hz, 1860 Hz and 1980 Hz for the forward direction. Thus, in each direction the frequencies are 120 Hz apart. A window of size N has nulls situated at frequency intervals Fs/N, as shown in
In order to position the nulls at 120 Hz intervals, and assuming a sampling frequency Fs=8 kHz, a window size of 200 samples is chosen for the filter (the minimum window size for nulls at 120 Hz is N=Fs/120 Hz, which is 66.67, such that the smallest integer window is thus N=200).
For example: If the frequency of interest is at 900 Hz, the filter is centered at 900 Hz using a window of 200 samples. Spectral nulls are therefore located at each of the other MF frequencies, i.e. 540 Hz, 660 Hz, 780 Hz, 1020 Hz and 1140 Hz.
For non-equally spaced frequencies (such as DTMF), the approach is not as straight forward as for the equally spaced frequency case. Nonetheless, the windows for each frequency detector (i.e. filter) may be sized in such a way that the closest frequency falls into a null. On the other hand, the window may be chosen such that the interference of the other frequencies is minimized.
For example, if the frequency of interest is the DTMF frequency at 852 Hz., the nearest adjacent frequency is 770 Hz (i.e. separated by 82 Hz). Choosing a window size of N=195 places nulls at intervals of 41 Hz, as shown in
The filters comprising analysis bank 3 may be implemented in many ways. As indicated above, a Goertzel DFT filter was implemented according to the preferred embodiment. Implementations of Goertzel filters are well known in the art (e.g. Burrus, C. S. and T. W. Parks. 1985. DFT/FFT and Convolution Algorithms. New York: Prentice-Hall.). An example of a Goertzel filter for use in the multi-frequency tone detector of the present invention, centered at 900 Hz, is as follows:
The return value “energy” is the tone energy at a specific frequency, which is fed into the decision logic 7.
The frequency deviation algorithm implemented within block 7 uses the roll-off of the filter 3 combined with an estimate of the background energy.
Total Energy is the energy of the output of the pre-filter 1. It is made up of the single frequency energy (E) and background noise (n).
Total Energy=E+n
The frequency energy is made up of the energy within the analysis filter (E_bin) and the leakage energy due to roll-off (E_ro). Thus, for a single tone:
E=E_bin+E—ro
If the frequency deviation is zero, then
E=E_bin and E—ro is zero
Thus the Total Energy is made up of:
where E_back is the background energy relative to the output of analysis filter 3. Thus, the background energy is calculated by subtracting the energy within the analysis filter from the total energy. The Signal-to-Noise Ratio (SNR) of the analysis filter energy relative to the background energy can be represented as:
Thus, there is a direct relationship between SNR_ro and E_ro, the leakage energy due to the roll-off, and consequently the frequency deviation.
For a rectangular window:
Roll-off=(sin(x)/x)2 with
x=π*f*size/Fs
For tolerable frequency deviations up to f=13 Hz, size=200 and Fs=8 kHz x=1.021 and the roll-off is 0.6974. Assuming that the noise (n) is negligible relative to the leaked tone energy E_ro, then:
SNR_ro provides an upper threshold limit for tolerable frequency deviation. If the ratio between E_bin and E_back is less than SNR_ro, frequency deviations of more than 13 Hz are accepted. If the threshold is set above SNR_ro, then frequency deviations of up to 13 Hz will not be tolerated.
The dual tone case is very similar to the single tone case set forth above. However, in the case of dual tones the Total Energy is made up of both energies.
Assuming no twist between the tones (E1=E2) and negligible noise, then for a frequency deviation of 13 Hz for both tones
The situation is a bit more complicated if the tones have relative twist. Assume
In this case, SNR_ro provides the upper threshold limit which, it will be noted, is considerably relaxed relative to the threshold without twist, in order tolerate a frequency deviation of at least 13 Hz when dual tones and twist are present.
The following is a pseudo code implementation for a typical dual tone detector using roll-off:
Although a preferred embodiment of the present invention has been described, those skilled in the art will appreciate that variations and modifications may be made. For example, the embodiment set forth above is implemented via Goertzel DFT filters, whereas the filters 3 can also be implemented as FIR filters or IIR filters. This and all other such alternatives and variations are believed to be within the sphere and scope of the invention as defined by the claims appended hereto.
Number | Date | Country | Kind |
---|---|---|---|
0006576.3 | Mar 2000 | GB | national |
Number | Date | Country | |
---|---|---|---|
Parent | 09808684 | Mar 2001 | US |
Child | 11318775 | Dec 2005 | US |