The present invention relates generally to methods for automatically tuning single sideband voice signals.
Single Sideband modulation (SSB) is very efficient in the use of the frequency spectrum. Other common modulations, such as amplitude modulation (AM) and frequency modulation (FM), are very inefficient. AM takes twice as much spectrum and FM can take 4 to 8 times the spectrum. Since frequency spectrum is a scarce resource, any technology that can conserve frequency spectrum is of high value.
SSB is also very power-efficient. Compared to AM, SSB communications can be made with less than one tenth the power. Reducing the transmitted power reduces the interference to other communication services and thereby also improves the frequency spectrum usage.
However, SSB signals need to be tuned within approximately 10 Hertz (Hz) to avoid significant audio distortion. Signals mistuned much beyond this limit sound either like a deep rumble or like Donald Duck, depending on the direction of mistuning.
One solution has been to transmit only on certain specific frequencies (channels). However, this requires that both the high-frequency transmitter and receiver be tuned to exactly the correct frequency. This may require tuning to within about 20 parts per billion, depending on the carrier frequency. This degree of accuracy is expensive to implement, particularly over a wide range of environmental conditions and must be maintained over the expected lifetime of the radio. This is the reason that Marine HF SSB radios have a “clarifier” control for operator adjustment of the receiver frequency. This adjustment is somewhat difficult to use and requires practice to adjust for adequate audio quality. A second disadvantage of channelized operation is reduced spectral efficiency. It is often advantageous to slightly change frequency to avoid RF interference instead of abandoning the channel altogether and shifting to another channel.
A second solution, well-known to those skilled in the art, is to add a known frequency audio tone (pilot tone) to the transmitted signal. If the receiving station knows the transmitted pilot tone frequency, it can automatically adjust the received frequency to set the received pilot tone to the desired frequency. There are at least three disadvantages to this solution. First, the transmitter and receiver must be designed to work with the same pilot tone frequency and amplitude. This discourages the formation of ad hoc communications and is incompatible with existing radio infrastructure. Considering the large number of SSB transceivers in use today, updating this equipment is impractical and inventions using pilot tones are of limited utility. Second, the added pilot tone needlessly consumes transmitter power. Maximum transmitted power is usually limited by regulation; so wasted power reduces range and the readability of the signal. Finally, receiver bandwidth is limited to minimize noise, and interference. Therefore, if the receiver is mistuned by more than a few hundred Hz, the pilot tone can be filtered off and the automatic tuning will fail.
Several tuning techniques attempt to use the properties of voice signals to automatically tune SSB voice signals (see, for example, “Co-Channel Interference Separation” by Robert Dick, December 1980, “Tune SSB Automatically” by Robert Dick, QEX magazine, January/February 1999, “A Blind Automatic Frequency Control Algorithm for Single Sideband” by Gary Geissinger, QEX magazine July/August 2005, and “Communications Receivers” by Dr. Ulrich Rohde. None of these techniques have successfully and consistently tuned actual voice SSB signals.
In contrast with the above prior art, the invention requires no modifications to the transmitter and so a receiver equipped with this invention can be used with any SSB transmitter in use today. It can also correct for much larger tuning errors. As discussed in detail below, this invention analyzes the properties of the transmitted human voice, independent of language and retunes the receiver to the actual transmitted signal frequency with a high degree of accuracy. This can be done faster than a trained operator can retune the radio.
It is an object of the present invention to provide new methods and systems for automatically tuning single sideband voice signals that do not require specially modified transmitters. This invention has the additional advantage that it can be either implemented internally in new receivers or implemented with external hardware and/or Personal Computers (or other computing device) and an existing SSB receiver.
In order to achieve this object and others, a method for tuning a receiver comprises receiving a voice signal, optionally filtering the signal, processing the signal in the time domain, converting the signal to the frequency domain, processing the signal in the frequency domain, converting the modified signal from the frequency domain to a correlation domain, processing the signal in the correlation domain and analyzing the processed signal from the correlation domain to determine the receiver tuning error.
The receiver tuning error can be used for any purpose known to those skilled in the art. For example, the radio operator could be notified of the receiver tuning error to enable retuning of the radio. An automatic retuning of the radio could also be performed using the receiver tuning error obtained using the invention. Also, the Receiver Increment Tuning (RIT) function found on many radios could be used applying the receiver tuning estimate, which function does not change the frequency setting displayed on the radio but does change the tuning. An advantage of this is that if the RIT is cleared, then the radio is back to the original frequency.
In accordance with one embodiment of the invention, processing of the signal in the time domain may entail removing the effects of the speaker's vocal tract by center clipping the signal. In the time domain, this may involve determining a level at which to center clip the signal based on a root mean squared (RMS) or mean absolute deviation (MAD) criteria. The center clipped signal is then windowed, using a triangular window, for example, and zero padding the signal. In the frequency-domain, phase information is removed. In addition, undesired frequencies may be removed (including negative frequencies) and frequency components whose magnitude is less than a predetermined percentage of the largest frequency component.
The pitch and frequency offset of the voice sample can be estimated in the correlation domain. This preferably involves correcting for the undesired effects of time domain windowing. To estimate the pitch and offset frequency, the signal in the correlation domain is preferably curve-fit using a regression of at least 5 points. Then, the location of the peak magnitude of the signal is determined by interpolation and the offset frequency and pitch are calculated based thereon.
Analysis of the processed signal may involve determining whether the peak magnitude is above a threshold indicative of a voiced sound and if not, the processed signal is disregarded. This eliminates the effects in the tuning method of unvoiced sounds and pauses in the voice, which often causes errors in prior art methods.
Analysis of the processed signal may further involve comparing the peak magnitudes at one-half and/or two times the estimated pitch frequency to determine if pitch doubling or halving has occurred, which often causes errors in prior art methods.
If all the frequency components of the voice pitch were present in this frequency domain data, it would be trivial to determine the receiver tuning error of a closely tuned signal. However, typical SSB transmitters filter off frequency components below about 300 Hz. The majority of adult voices have a pitch from about 50 Hz to about to 250 Hz, so the fundamental pitch and several harmonics can be filtered off before transmission. Therefore, with a single measurement, it is only possible to know the receiver tuning error to within a multiple of the pitch. This problem is further aggravated when the receiver is significantly mistuned as the receiver filters can remove additional pitch harmonics from the transmitted signal. For these reasons, it is necessary to do further processing of the signal after extracting the pitch and frequency offset for a short voice segment.
The natural variation in voice pitch over time makes it possible to determine the actual receiver tuning error from multiple estimates of pitch and frequency offset. In one particularly advantageous embodiment of the invention, a cost function is formed from multiple estimates of the receiver tuning error and used to determine the actual receiver tuning error. In the cost function, voiced sounds far from a trial estimated receiver tuning error contribute a larger error to the cost function.
Another particularly advantageous embodiment of the invention uses a statistical test to determine if enough samples of the voice have been taken to determine the receiver tuning error accurately. Specifically, it is determined whether a statistically significant difference is present between the best estimate of the receiver tuning error from the cost function and a second best estimate. If so, the first estimate is considered as the actual receiver tuning error. Otherwise, another segment of the received voice signal is processed.
An advantage of using a statistical test is that it is not known a priori how many speech segments must be processed. Natural speech has pauses and fricative (unvoiced) sounds that do not contribute to an estimate of the receiver tuning error. As such, the time required for acquiring sufficient voiced speech segments is unknown. The alternative used in the prior art is to process an excessive length of speech. This long processing time improves the likelihood (but does not guarantee) that enough voiced sounds will have been processed, but at the cost of greatly increased tuning time.
The invention, together with further objects and advantages hereof, may best be understood by reference to the following description taken in conjunction with the accompanying drawings, wherein like reference numerals identify like elements and wherein:
Referring to the accompanying drawings wherein like reference numerals refer to the same or similar elements, a flow chart of a general embodiment of a method for tuning a receiver or radio in accordance with the invention is shown in
A preferred embodiment of use of this invention is within a SSB radio. However, it is to be understood that other implementations including Personal Computers, PDA's and custom external hardware fall within the scope of this invention.
It is further understood that the scope of this invention includes operation with traditional analog-based radios, analog radios with audio Digital Signal Processing (DSP) and radios with RF and/or IF DSP processing.
It will be obvious to those skilled the art that this invention can be implemented on demodulated voice signals in either digital or analog form. Also included within the scope of this invention is the processing of the voice signals before the SSB demodulator, at what is commonly called the Intermediate Frequency in either analog or digital form.
In a preferred embodiment, the demodulated voiced signal is input to the invention in either analog or digital form. If radio is implemented with DSP, then the ADC and filtering step described below are usually unnecessary.
It is understood by those skilled in the art of digital signal processing that the voice signal must by sampled at greater than the Nyquist frequency. Since SSB receivers commonly filter voice signals to a 3 kHz maximum frequency, this means that the sampling frequency must be greater than 6 kHz. It is advantageous to increase the sampling frequency further as it improves the resolution in the correlation domain and therefore improves the estimates of pitch and frequency offset. The correlation domain is also sometimes referred to as the convolution domain. A preferred embodiment uses at least 11 kHz, but other sample rates are covered under the scope of this invention.
Continuous speech collection and processing is provided wherein while one speech record is being processed, a subsequent speech record is being collected. That is, the signal processing on a speech record does not have to be completed in order to obtain another speech record so that no part of the voice input is missed during the signal processing. The signal processing of the speech record is shown schematically in
The audio filtering (step 20) is designed to eliminate any DC component and high frequency noise from the digitized signal while passing the desired audio or SSB signal. This step can be deleted if the receiver design otherwise eliminates these undesired components.
Time domain processing (step 22) is shown schematically in
Time domain center clipping is shown in
Y(t)=0 for |x(t)|<=clip
Y(t)=x(t)−clip for x(t)>clip
Y(t)=x(t)+clip for x(t)<−clip
Various methods for setting the clip level as a percentage of the peak amplitude have been used in speech processing. However, using a clipping level based on the peak amplitude emphasizes noise spikes common on high-frequency SSB signals. In investigations for this invention, it was found that two other criteria better fit the signal characteristics, RMS (root mean squared) and MAD (mean absolute deviation). Since noise spikes have high amplitude but low energy, the RMS criteria tends to minimize the contribution of noise spikes to the threshold level. In a preferred embodiment, it has been determined that 30% of the RMS level is the best clipping level. Nevertheless, other percentages of the RMS or MAD level may also be used in the invention.
Windowing (step 30) is used to produce the best results in the frequency domain. While windowing is generally known to those skilled in the art of signal processing, its application of receiver tuning is different. In stationary signal analysis, the window length is selected based on the required frequency domain resolution. When tuning a receiver, the frequency domain resolution is not a concern and short windows should be used to approximate stationary conditions required for pitch estimation in spite of the non-stationary characteristics of a voice signal. However, longer windows are desirable to more accurately estimate the pitch, particularly for low-pitched male speakers. In a preferred embodiment, a 40 msec window is used. Other window lengths can be used in this invention.
Second, the shape of the window function can be selected to ensure that the frequency transform of the window is non-negative at all frequencies to enable window corrections to be performed in the correlation domain. Without such corrections in prior art tuning methods, such as the Dick method, it is likely that the pitch frequency estimate will be too high because the undesired effects of the window function in the correlation domain attenuated the peak at the actual pitch.
An example of a window that is always positive in the frequency domain and whose correlation domain effects are easy to correct is the triangle window. Its frequency transform has a sin2f/f2 shape. Although such a triangular window is a preferred window, other windows can be used in the invention.
With respect to window leakage, it is well known by those skilled in the art that short time windowing creates greater leakage in the frequency domain. Such leakage will cause errors in the estimate of the frequency offset. An algorithm in accordance with the invention assumes that at the peak of the correlation magnitude function, the phase is only determined by the frequency tuning error. However, this algorithm is correct only if there is no energy at any frequencies besides the offset pitch frequencies.
In an alternative embodiment, multiple width windows are used. The pitch is first estimated with the window discussed above. If the pitch is found to be too low for accurate estimation (less than about 4 cycles in the window), then the processing of the record is restarted with a window of approximately twice the length. If sufficient computing power is available, this technique will converge faster and more reliably to the correct tuning frequency. The use of multiple windows for tuning a receiver is believed to be novel.
A further consideration in windowing the voice signal is whether to overlap the windows. Overlapping of time records before frequency transforms is known by those skilled in the art for noise reduction averaging of steady-state signals. However, its application to receiver tuning is believed to be novel.
For instance, prior art for receiver tuning indicates that it is best that the windows not overlap by more than 50%, so they are not too redundant. Those skilled in the art know this is correct if overlapped processing is used for noise reduction because the estimates are not statistically independent. However, in this invention, overlap processing is used in conjunction with the cost function to self-align the window with short voiced sounds, not noise reduction.
When overlap processing was implemented on actual SSB received signals, it was found for a 40 msec triangular window that performance is optimized by using 75% overlap (25% delay) as shown in
The final step in the preferred time domain processing is to zero pad the time record (step 30). Zero padding is a technique that is known to those skilled in the art of autocorrelation computation to avoid aliasing in the autocorrelation domain. However, use of zero padding to improve the accuracy of pitch and frequency offset estimation in automatically tuning a SSB radio is believed to be novel.
Forward Fast Fourier Transform (FFT-step 32) is a signal processing technique known to those skilled in the art to convert the time domain signal into the frequency. The FFT is a preferred embodiment for conversion to the frequency domain, but other transforms such as Discrete Fourier, Discrete Cosine, Wigner, Cohen, Gabor and Wavelet transforms are also included in this invention as other transform methods obvious to those skilled in the art.
Frequency domain processing is shown schematically in
Low and high frequency results that are known to be outside of the range of the receiver audio response are also set to zero to minimize errors in subsequent calculations. In particular, powerline hum and high frequency noise is eliminated by this operation.
Conversion of the frequency domain results to magnitude only (removing the phase information) (step 36) eliminates all absolute time information from the results. Therefore, the algorithm does not distinguish between voice records at the beginning and end of a conversation and all voiced sounds are treated equally. Conversion to magnitude only can be done by any of several techniques and approximations known to those skilled in the art.
Center clipping in the frequency domain (step 38) involves elimination of all sounds not produced by the vocal cords. This is desirable in order to determine an accurate estimate of the pitch and offset frequency of the voice record. One way to do this is to set all frequency components that are less than a predetermined percentage, e.g., 5%, of the largest component to zero using an appropriate clipping function (which may be defined in a similar manner as the time domain clipping function described above).
In a preferred embodiment, the center clipped magnitude data is directly converted to the correlation domain. However, other frequency domain processing can be performed at this point and is included within the scope of this invention.
Specifically, if further signal processing includes the logarithm of the magnitude, this will generate a result in the correlation domain similar to the Cepstrum, which is known to those skilled in the art. The magnitude data can also be raised to an integer or fractional power, which will emphasize or de-emphasize the difference in the magnitudes of the frequency domain peaks.
As a final frequency domain processing enhancement included within the scope of this invention, the frequency spectrum can be zero padded and a larger inverse frequency transform used. This will increase the resolution in the correlation or convolution domain yielding improved pitch and frequency offset estimates without increasing the time domain sampling rate.
Once center clipping and any further signal processing discussed above has been performed in the frequency domain, the processed results are converted back to a time-like domain called the correlation domain by applying an inverse Fast Fourier Transform (step 40). Inverse Fast Fourier Transforms are known to those skilled in the art. As with the frequency domain transform mentioned earlier, the inverse transform can be accomplished by other well known transforms such as Discrete Fourier Transform, Discrete Cosine, Wigner, Cohen, Gabor and Wavelet transforms as are also included in this invention as other transform methods obvious to those skilled in the art.
A preferred embodiment of correlation domain processing is shown schematically in
The first step in the preferred correlation domain processing is to correct for the windowing effect (step 42). Although short time windows are necessary because of the non-stationary pitch of normal voice, it invariably causes problems in the correlation domain. In particular, short time domain windowing greatly reduces the desired peak for low-pitched male speakers in the correlation domain. If not corrected, this often leads to a gross error in the estimation of the pitch and offset frequency. Hence, window correction in the correlation domain is performed. This step is entirely novel and provides substantial advantages over the prior art.
More specifically, the time domain windowing of the voice signal causes the correlation to roll off with increasing τ. There is a desire if not need to remove this window effect before estimating the pitch and frequency offset. However, due to the non-linear operations in the frequency domain, a simple analytical mathematical description of the window effect in the correlation domain cannot be written. Fortunately, it has been discovered that a linear approximation to the measured actual windowing error works well when using test waveforms at a range of pitch from about 50 Hz to about 250 Hz.
In a preferred embodiment, after window correction in the correlation domain, the pitch is roughly estimated, for example, by determining the largest magnitude sample. If this is outside the normal range of voice pitch, the voice record is discarded. The voice is also tested for a phenomenon known to those skilled in the art of speech processing called pitch doubling. The peak is also compared to the correlation magnitude at one half and twice the pitch. If the magnitude of the peak is not 40% greater than these frequencies, the voice record is discarded. (Other percentages can be used within the scope of this invention.) This step is believed to be entirely novel and provides substantial advantages over the prior art for receiver tuning.
If the correlation of the voice record passes these tests, the peak magnitude is more precisely estimated by curve fitting to interpolate the location of the maximum magnitude. The location of the magnitude peak corresponds to the voice pitch period during the windowed voice record. There are many curve fitting routines well known to those skilled in the art and these could be used in this invention. In a preferred embodiment, a second order least squares regression on the correlation magnitude squared is used as it has a low computational load (step 44). It will be recognized by those skilled in the art that the complexity of this interpolation can be reduced or the interpolation completely eliminated by increasing the sampling rate of the received voice signal or zero padding in the frequency domain as discussed above at the cost of increased complexity in the frequency transforms. These variations fall within the scope of this invention.
It has been suggested to use a 3 point fit to a parabola to interpolate between the computed values of the correlation (the Dick method), and this can be used in the invention. However, this is extremely sensitive to noise and other errors.
Thus, in accordance with one embodiment of the invention, instead of using a 3 point curve fit to a parabola, a significant advantage is obtained by using regression fitting to 5 or more points centered around the peak sample of the correlation magnitude squared to improve the accuracy. The regression technique will smooth out any errors in individual points. Smoothing the noise is very important because the phase function is very sensitive to small errors in the estimation of the real and imaginary values at the peak.
To find the pitch period corresponding to the maximum correlation magnitude, the derivative of the above curve fit is computed and set to zero, a well-known technique for finding the maximum.
The last step in the correlation domain processing is to estimate the offset frequency from the phase at the correlation magnitude peak (step 46). Again any of the curve fitting techniques well known to those skilled in the art could be used in this invention. In a preferred embodiment, the phase is estimated by again using a second order, 5 point least squares regression on the real and imaginary parts of the correlation centered around the peak sample of the correlation magnitude squared and computing the phase estimate from the real and imaginary curve fit estimates at the magnitude peak.
From the real and imaginary estimates, the frequency offset is computed using the formula;
f
e
=f
p arctan(im/re)/(2π)
where
In an alternative embodiment, the entire conversion to the correlation domain can be eliminated by curve fitting in the frequency domain. Those skilled in the art will recognize that the second order, 5 point least squares regression curve fit equations can be transformed to the frequency domain. The resulting calculated polynomial coefficients are identical to those calculated in the correlation domain, so the pitch and frequency offset resulting estimates are identical by each embodiment.
This concludes the signal processing (step 18).
Referring back to
If the magnitude of the correlation peak is not sufficiently large, then it is assumed that the speech record does not contain a voiced sound. Therefore, it should not be used to estimate the receiver tuning error. This determination is important because the receiver audio signal can often have long pauses in the speech that add many invalid noisy estimates to the receiver tuning error.
It is important in the invention to determine not only when audio is present, but also if it is voiced or unvoiced sounds. Voiced sounds have the pitch information needed to estimate the mistuning, unvoiced sounds are more like noise and have no useful information for automatic tuning.
In the tuning method of Dick discussed in the papers mentioned above, all time records affect the mistune frequency estimate and the only weighting is the energy in the correlation peak. It was an unstated assumption that unvoiced sounds and noise will have a low correlation and therefore the weighted effect will be small. However, since clearly the majority of the time records could be noise or unvoiced sound, these easily accumulate to a serious error source in estimating the mistuning error.
It was found that an important factor to determine if a voiced signal was present in the record was to measure the ratio of the correlation peak magnitude squared to the sum of all the correlation squared magnitudes. In one practical embodiment, if this ratio is less than about 0.3%, then the measurement is rejected. This number depends on the sample rate. The ratio of 0.3% was selected based on empirical measurements at 11 kHz sample rate.
When a voiced sound is present in the speech record with good signal to noise ratio, within the valid pitch range and the radio has not been retuned during the speech record, the cost function is updated (step 50). This step is entirely novel and provides substantial advantages over the prior art. The cost function provides significantly more accurate receiver tuning error estimates than histogram techniques used in the prior art.
The histogram technique used in prior art, often returns a receiver tuning error estimate off by a multiple of the average pitch. For example, the receiver tuning error estimate can be off by 100 Hz to 200 Hz, whereas by contrast, in the invention, the cost function is accurate to within 5 Hz. A 5 Hz error is not audible, whereas 100-200 Hz is very objectionable.
The cost function is constructed such that voiced sounds that are far from estimated receiver tuning error contribute a large error to the cost function. Therefore, the frequency that has the lowest cost function value is considered to be the receiver tuning error.
The cost function is also designed to allow a simple test to determine if enough voice records have been processed for an accurate receiver tuning error estimate (step 54).
Mathematically, the cost function is preferably a least squares estimate of the receiver tuning error. It is defined as:
J(f)=Σwi*[Int(nipi+ei−f)]2
where:
f possible receiver tuning frequency error
wi correlation peak power cubed of the ith record
Int Nearest integer (rounding, not truncating)
ni Int((f−ei)/pi), pitch multiple of tuning error
pi estimated pitch of i measurement
ei estimated offset frequency of the ith measurement
i Measurement index
This function is used to generate an array J(f) for integer f from −900 to +1100 (as shown in
Other weighting functions and cost functions fall within the scope of this invention. It should also be noted that f can be scaled to any desired frequency resolution.
One of the virtues of the formation and consideration of the cost function is that it forms an excellent basis for determining when to end the algorithm as discussed below.
To determine how many voice measurements are required in the SSB automatic tuning program, the ratio of the cost function of the second best estimate (next best minimum) is divided by the global minimum (best estimate.) This ratio must be greater than the F-Test value if the receiver tuning error estimate is to be considered significantly better than any other frequency.
The F Test is a standard statistical test well known to those skilled in the art of statistics. Any other of statistical test used to determine a significant difference between hypotheses can be used in this invention. However, the use of statistical tests in a method for automatically tuning a radio is believed to be novel.
If the difference is not statically significant to the desired confidence level, the processing should be continued up to the maximum number of records. That is, if the criterion for ending the test is not met, it is easy to continue the test by adding new measurements to the existing cost function without re-computing the previous results.
In a preferred embodiment, the value of F for a given confidence level and number of samples is found in a lookup table. It is within the scope of this invention that the F value could also be interpolated from a smaller table or computed by a formula such as the following approximation when the number of measurements is large.
F˜n/(n−2){(4n−4)/(n−4)/n}1/2y+n/(n−2)
where
y˜t−(2.30753+0.27061t)/(1+0.99229t+0.04481t2)
and
t={−2ln(1−P)}1/2
As stated above, if the ratio does not exceed the F-Test value, the program continues to analyze voice time records. Since the algorithm depends on the natural variation of the voice pitch, it is highly unlikely to converge to a good estimate of the receiver tuning error in a few time records. To save computation time, in a preferred embodiment, the confidence test is only run after the cost function has been updated 100 times. The test is then run after each additional 50 cost function updates up to the maximum number of records allowed (step 52). Other numbers of records and updates are within the scope of this invention.
It is continuously determined whether the next speech record is finished and once finished, the signal processing begins on the next speech record along with the subsequent determination of the presence of a voiced sound with good signal to noise and interference ratio therein.
When 50 additional updates are obtained, a determination is made as to whether the results, i.e., the updated cost, are statistically significant (step 54).
If the results are significant, then the radio can be tuned (step 56).
If the results are not significant, i.e., there is little difference in the cost function value between the best tuning estimate and the second best tuning estimate, a determination is made whether the maximum number of records has been reached (step 58). If not, a determination is made as to whether the speech record being collected is finished (step 14) and the method proceeds to obtain an additional set of new records containing voiced sound with good signal to noise and interference ratios. If the maximum number of records has been reached, then it is assumed that the transmission cannot be tuned in accordance with the invention and the process is stopped (step 60).
The invention, in any of the embodiments described above, is a significant improvement over prior art automatic tuning methods wherein a fixed number of tests are considered. Considering a fixed number of tests results in the receiver being often tuned to an incorrect frequency. Increasing the number of tests could reduce the number of errors, but at the cost of greatly increased times for most estimates.
While a particular embodiment of the invention has been shown and described, it will be obvious to those skilled in the art that changes and modifications may be made without departing from the invention in its broader aspects, and, therefore, the aim in the appended claims is to cover all such changes and modifications as fall within the true spirit and scope of the invention.