I. Field
The present invention relates generally to communication, and more specifically to signal quality estimation in a wireless communication system.
II. Background
In a wireless communication system, a transmitter first digitally processes traffic/packet data to obtain coded data. The transmitter then modulates a carrier signal with the coded data to obtain a modulated signal that is more suitable for transmission via a wireless channel. The modulation may be performed based on various modulation schemes. One modulation scheme that is widely used throughout the world is continuous phase modulation (CPM). With CPM, the phase of the carrier signal is modulated by the coded data in a continuous rather than abrupt manner. As a result, CPM has several desirable characteristics such as (1) a constant envelope for the modulated signal, which allows the signal to be transmitted using an efficient power amplifier, and (2) a compact spectrum for the modulated signal, which enables efficient utilization of the available frequency spectrum.
A modulated signal generated with CPM (or simply, a CPM signal) has a fairly complex waveform that can complicate the design of a receiver used to process the CPM signal. To simplify the receiver design, the CPM signal may be approximated as a phase shift keying (PSK) modulated signal, as described below. This approximation for the CPM signal is sufficiently accurate for many applications and is often used for a CPM receiver.
A CPM receiver often needs to derive an estimate of the received signal quality. In general, signal quality (which is denoted as “C/I” herein) may be quantified by a carrier-to-interference ratio, a signal-to-noise ratio, a signal-to-noise-and-interference ratio, and so on. The C/I estimate may be used for various purposes such as, for example, to select an appropriate data rate for data transmission. The approximation of the CPM signal as a PSK modulated signal, while simplifying the receiver design, results in an inaccurate C/I estimate for certain operating conditions. The inaccurate C/I estimate can degrade system performance.
There is therefore a need in the art for techniques to derive a more accurate C/I estimate for a CPM signal.
Methods and apparatus are presented herein to address the above stated need. A CPM signal may be represented as (and formed with) a set of pulse shaping functions, as described below. To simplify the receiver design, a CPM signal may be approximated as a PSK modulated signal that is formed with just the “dominant” pulse shaping function, which is the pulse shaping function having the largest energy among all pulse shaping functions for the CPM signal. Channel estimation and data detection may be more simply performed based on this CPM-to-PSK approximation. However, if the receiver processing is performed based on this approximation, then an estimate of the signal power in the received CPM signal would contain mostly the power due to the dominant pulse shaping function, and the power due to the remaining pulse shaping functions would be treated as noise instead of signal. This then results in an inaccurate C/I estimate for high C/I conditions.
A more accurate C/I estimate may be obtained for a received CPM signal by accounting for the CPM-to-PSK approximation. A signal power estimate and a noise power estimate may be obtained for the received CPM signal. These power estimates have errors due to the CPM-to-PSK approximation. The difference A between the energy of the dominant pulse shaping function and the energy of the remaining pulse shaping functions may be determined, for example, by theoretical derivation, computer simulation, or empirical measurement. An approximation error may be estimated based on the signal power estimate and the difference Δ. The C/I estimate may then be computed based on the signal power estimate, the noise power estimate, and the approximation error estimate. The various computation steps for the C/I estimate are described in further detail below. This C/I estimate is relatively accurate even with the CPM-to-PSK approximation and may be used for various purposes such as, for example, selecting an appropriate data rate, scaling of bursts of data prior to decoding, and so on.
In one embodiment, a method is presented for estimating signal quality (C/I) in a communication system utilizing continuous phase modulation (CPM), the method comprising: estimating signal power in a received CPM signal; estimating noise power in the received CPM signal; estimating error due to approximation of the received CPM signal with another modulation format different from CPM; and deriving a C/I estimate for the received CPM signal based on the estimated signal power, the estimated noise power, and the estimated approximation error.
In another embodiment, a method is presented for estimating signal quality (C/I) in a Global System for Mobile Communications (GSM) system, comprising: estimating signal power in a received Gaussian minimum shift keying (GMSK) modulated signal; estimating noise power in the received GMSK modulated signal; estimating error due to approximation of the received GMSK modulated signal as a phase shift keying (PSK) modulated signal; and deriving a C/I estimate for the received. GMSK modulated signal based on the estimated signal power, the estimated noise power, and the estimated approximation error.
In another embodiment, apparatus is presented that is operable to estimate signal quality (C/I) in a wireless communication system utilizing continuous phase modulation (CPM), comprising: a signal estimator operative to estimate signal power in a received CPM signal; a noise estimator operative to estimate noise power in the received CPM signal; and a C/I estimator operative to estimate error due to approximation of the received CPM signal with another modulation format different from CPM and to derive a C/I estimate for the received CPM signal based on the estimated signal power, the estimated noise power, and the estimated approximation error.
The features and nature of the present invention will become more apparent from the detailed description set forth below when taken in conjunction with the drawings in which like reference characters identify correspondingly throughout and wherein:
The word “exemplary” is used herein to mean “serving as an example, instance, or illustration.” Any embodiment or design described herein as “exemplary” is not necessarily to be construed as preferred or advantageous over other embodiments or designs.
The C/I estimation techniques described herein may be used for various types of CPM signals and for various wireless communication systems. For clarity, these techniques are specifically described for a GMSK modulated signal used in GSM.
At receiving entity 150, the RF modulated signal transmitted by transmitting entity 110 is received by an antenna 152 and provided to a receiver unit (RCVR) 154. Receiver unit 154 conditions and digitizes the received GMSK signal and provides a stream of samples. A GMSK demodulator 160 then processes the samples, estimates the C/I of the received GMSK signal, and provides demodulated data. A receive (RX) data processor 162 deinterleaves and decodes the demodulated data to recover the data sent by transmitting entity 110. The processing by GMSK demodulator 160 and RX data processor 162 is complementary to the processing performed by GMSK modulator 120 and TX data processor 112, respectively, at transmitting entity 110.
Controllers 130 and 170 direct operation at transmitting entity 110 and receiving entity 150, respectively. Memory units 132 and 172 provide storage for program codes and data used by controllers 130 and 170, respectively.
The GMSK signal, s(t), may be expressed in continuous time t as follows:
where φ(t) is the phase pulse/function determined by filter 214 and integrator 216;
θ0 is an arbitrary phase value; and
exp(jx)= cos(x)+j sin(x).
For simplicity, equation (1) shows a baseband representation for the GMSK signal, so that the “ωt” term for the angular frequency of the carrier signal is omitted from equation (1). Equation (1) indicates that the code symbols {a(n)} are embedded in the phase of the GMSK signal. Equation (1) also indicates that the phase of the GMSK signal is obtained by multiplying each code symbol a(n) with a delayed version of the phase function, φ(t−nT), and summing the scaled and delayed phase functions for all code symbols. For simplicity, the parentheses “{ }” for {b(n)} and {a(n)} are omitted in the following description.
The phase-modulated GMSK signal shown in equation (1) may be represented as a superposition/sum of amplitude-modulated signals in discrete time n, as follows:
where {circle around (×)} denotes a convolution operation;
ci(n) denotes the i-th pulse shaping function; and
ai(n) denotes the input symbols for pulse shaping function ci(n).
Equation (2) indicates that the complex GMSK signal, s(n), may be expressed as a sum of amplitude-modulated signals. Each amplitude-modulated signal is generated by convolving a pulse shaping function ci(n) with its corresponding input symbols ai(n). For GMSK, there are eight pulse shaping functions, which are denoted as ci(n) for i=0, 1, . . . 7. Of these eight functions, c0(n) is the dominant pulse shaping function and is much larger than the remaining pulse shaping functions. The input symbols ai(n) for each pulse shaping function may be derived from the code symbols a(n) based on a known transformation associated with that function. There is a one-to-one mapping between ai(n) and a(n) for each pulse shaping function. For GMSK, differential encoding is performed on the input bits b(n) to obtain the code symbols a(n), and the input symbols a0(n) for the dominant pulse shaping function c0(n) may be expressed as:
a0(n)=jn·b(n), Eq (3)
where j=√{square root over (−1)}. The decomposition of a CPM signal to amplitude-modulated pulse (AMP) representation, the pulse shaping functions, and the generation of the input symbols for these pulse shaping functions are described by P. A. Laurent in a paper entitled “Exact and Approximate Construction of Digital Phase Modulations by Superposition of Amplitude Modulated Pulses (AMP),” IEEE Transactions on Communications, Vol. COM-34, No. 2, February 1986.
where {hacek over (c)}i(n)=ci(n){circle around (×)}p(n) is the i-th pulse shaping function observed by the received GMSK signal, r(n). The function {hacek over (c)}i(n) is obtained by convolving the original pulse shaping function, ci(n), with the impulse response p(n) for the propagation channel.
Within GMSK demodulator 160, a rotator 330 performs phase rotation on the received GSM signal, r(n), to undo the effect of the differential encoding by GMSK modulator 120. Rotator 330 rotates each successive sample in the received GMSK signal by −90° (e.g., rotate the first sample by −90°, the second sample by −180°, the third sample by −270°, the fourth sample by 0°, the fifth sample by −90°, and so on). The rotated GMSK signal, {tilde over (r)}(n), may be expressed as:
where {tilde over (c)}i(n)=j−n·{hacek over (c)}i(n)=j−n·ci(n){circle around (×)}p(n) is the i-th “effective” pulse shaping function for the rotated GMSK signal, {tilde over (r)}(n);
To simplify the receiver processing, the rotated GMSK signal may be approximated as a binary phase shift keying (BPSK) signal, as follows:
{circumflex over (r)}(n)=b0(n){circle around (×)}{tilde over (c)}0(n)+{tilde over (w)}(n), Eq (6)
where {circumflex over (r)}(n) is the estimated GMSK signal. The GMSK-to-BPSK approximation shown in equation (6) relies on the fact that the dominant pulse shaping function, c0(n), is much larger than the remaining pulse shaping functions. In this case, a single term for {tilde over (c)}0(n) in the summation for the rotated GMSK signal, {tilde over (r)}(n), in equation (5) is used for the estimated GMSK signal, {circumflex over (r)}(n), in equation (6). The estimated GMSK signal, {circumflex over (r)}(n), is a good approximation of the rotated GMSK signal, {tilde over (r)}(n), when c0(n) is much larger than all other pulse shaping functions. Since the estimated GMSK signal, {circumflex over (r)}(n), contains only one pulse shaping function, channel estimation and data detection are simplified.
A channel estimator 340 receives the rotated GMSK signal, {tilde over (r)}(n), and derives an estimate of the channel impulse response, ĥ(n), observed by the rotated GMSK signal. The channel estimation is performed in accordance with the GMSK-to-BPSK approximation shown in equation (6), so that input symbols b0(n) for a known training sequence are used to derive the channel impulse response estimate, as described below. Because of this GMSK-to-BPSK approximation, the channel impulse response estimate approximates and resembles the dominant effective pulse shaping function, or ĥ(n)≈{tilde over (c)}0(n).
A data detector 350 receives the rotated GMSK signal, {tilde over (r)}(n), and the channel impulse response estimate, ĥ(n), and performs data detection to recover the input symbols b0(n) for the dominant pulse shaping function. Data detector 350 may implement a maximum likelihood sequence estimator (MLSE) that determines a sequence of symbols that is most likely to have been transmitted given the rotated GMSK signal, {tilde over (r)}(n), and the channel impulse response estimate, ĥ(n). Data detection for GSM is known in the art and not described herein. Data detector 350 provides hard decisions/bit estimates {circumflex over (b)}0(n), which are estimates of the input symbols b0(n). The bit estimates {circumflex over (b)}0(n) are deinterleaved and decoded by RX data processor 162 to obtain decoded data (not shown in
To obtain a C/I estimate, a signal estimator 360 receives and convolves the channel impulse response estimate, ĥ(n), with the bit estimates, {circumflex over (b)}0(n), to generate a reconstructed signal. This reconstructed signal is an estimate of the signal component in the rotated GMSK signal due to the dominant pulse shaping function. A summer 362 receives and subtracts the reconstructed signal from the rotated GMSK signal to obtain a noise estimate, ŵ(n), as follows:
ŵ(n)={tilde over (r)}(n)−{circumflex over (b)}0(n){circle around (×)}ĥ(n), Eq (7)
where ŵ(n) is an estimate of the noise {tilde over (w)}(n) in the rotated GMSK signal. Although not shown in
A signal power estimator 344 computes an estimate of the signal power, Psignal, as follows:
where M is the number of taps for the channel impulse response estimate, ĥ(n). M is also the length of the channel impulse response estimate. The signal power estimate may also be derived based on the output from signal estimator 360, or Psignal=E[|{circumflex over (b)}0(n){circle around (×)}ĥ(n)|2], where E [x] is the expected value of x. A noise power estimator 364 computes an estimate of the noise power, Pnoise, as follows:
In GSM, data is transmitted in bursts, with each burst carrying a sequence of N input bits, or b(0) . . . b(N-1). The noise power estimate may be computed for each burst.
A C/I estimator 370 may then compute a C/I estimate (or a burst SNR estimate) for the received GMSK signal, as follows:
Equation (10) indicates that, assuming the error due to the GMSK to BPSK approximation is negligible, the accuracy of the C/I estimate is dependent on the accuracy of the channel impulse response estimate, ĥ(n). This is because the signal and noise power estimates are both derived based on ĥ(n).
The C/I estimate obtained as shown in equation (10) is relatively accurate for low C/I conditions (e.g., for a received C/I of 12 dB or lower). However, this C/I estimate saturates for high C/I conditions (e.g., for a received C/I of 16 dB or more). The value to which the C/I estimate saturates is dependent on the manner in which the channel impulse response is estimated.
The saturation of the C/I estimate in equation (10) is due to the approximation of the received GMSK signal with just the dominant pulse shaping function {tilde over (c)}0(n), as shown in equation (6). For high C/I conditions, channel estimator 340 provides an accurate channel impulse response estimate for the estimated GMSK signal, so that ĥ(n)→{tilde over (c)}0(n). Also for high C/I conditions, data detector 350 provides accurate bit estimates based on the rotated GMSK signal, so that {circumflex over (b)}0(n)→b0(n). The noise estimate, ŵ(n), then includes the channel noise as well as signal components for all pulse shaping functions except for the dominant pulse shaping function. The noise estimate ŵ(n) may thus be expressed as:
ŵ(n)≈b1(n){circle around (×)}{tilde over (c)}1(n)+b2(n){circle around (×)}{tilde over (c)}2(n)+ . . . +{tilde over (w)}(n). Eq (11)
The “≈” sign in equation ( 11) may be replaced with an “=” sign if ĥ(n)={tilde over (c)}0(n) and {circumflex over (b)}0(n)=b0(n). The noise power estimate with the approximation error may then be expressed as:
The C/I estimate in equation (10) may then be expressed as:
where L is the length of the dominant effective pulse shaping function, {tilde over (c)}0(n).
Equation (13) indicates that the approximation of the received GMSK signal with just the dominant pulse shaping function, {tilde over (c)}0(n), results in the remaining pulse shaping functions {tilde over (c)}1(n), {tilde over (c)}2(n), and so on, being treated as noise instead of as signal. Consequently, even with no channel noise, or E[|{tilde over (w)}(n)|2]=0, the C/I estimate saturates at C/Isat, which is:
where Pdom is the power of the dominant effective pulse shaping function; and
Computer simulation indicates that C/Isat is approximately 20 dB for GMSK. The power Prem may be viewed as an error due to GMSK-to-BPSK approximation. At low
C/I conditions, the approximation error is less than the channel noise and has negligible impact on the accuracy of the C/I estimate. However, at high C/I conditions, the approximation error is larger than the channel noise and causes the C/I estimate to saturate at C/Isat.
The true C/I for the received GMSK signal may be expressed as:
The second equality in equation (15) follows from the fact that the rotation operation by rotator 330 does not change the signal power or noise power. The power of the signal components is the same in the received GMSK signal, r(n), and the rotated GMSK signal, {tilde over (r)}(n). Furthermore, the channel noise power is the same as the rotated noise power, or E[|w(n)|2]=E[|{tilde over (w)}(n)|2]. For an additive white Gaussian noise (AWGN) channel with a flat frequency response, equation (15) may be expressed as:
As shown in equations (13) and (16), the saturation of the C/I estimate results from treating the signal power in the remaining pulse shaping functions as a noise component in equation (13) instead of as a signal component in equation (16).
A more accurate C/I estimate, C/Iest, may be obtained for the received GMSK signal by accounting for the GMSK-to-BPSK approximation error, as follows:
where Perror is an estimate of Prem. Equation (17) is obtained using equations (13) and (16). As noted above, Prem is approximately 20 dB smaller than Pdom. Also, Pdom may be assumed to be equal to the signal power, or
In this case, Perror, may be estimated based on the signal power, as follows:
where Δ is the difference between Pdom and Prem(in dB) and is estimated as Δ≈20 dB in equation (19) for GMSK.
The assumption shown in equation (18) is generally more accurate for high C/I conditions than low C/I conditions because the channel impulse response estimate is more accurate for high C/Is. Consequently, the accuracy of the estimate shown in equation (18) is dependent on the C/I of the received GMSK signal. However, an appropriate value may be selected for the parameter Δ such that an accurate C/I estimate may be obtained for a wide range of received C/Is.
As shown in equation (17) the approximation error estimate, Perror, is subtracted from the noise power estimate E[|ŵ(n)|2] in the computation of C/Iest. The result of this subtraction may be zero or a negative value due to various reasons such as, for example, the use of a finite number of samples to estimate the signal power and noise power. If this occurs, then C/Iest may be set to a predetermined maximum C/I value, or C/Iest=C/ Imax.
For an AWGN channel, the impulse response p(n) contains a single tap of unit magnitude, and {tilde over (c)}i(n)=j−n·ci(n). For a multipath channel, the impulse response p(n) contains multiple taps. The value for Δ may be determined via computer simulation, empirical measurement, and so on, and (for simplicity) by assuming using the same delta value as that for an AWGN channel.
The signal power for the received CPM signal is then estimated based on an approximation of the received CPM signal as a PSK signal (block 414). The signal power estimate, Psignal, may be computed based on the channel impulse response estimate, as shown in equation (8), or based on a reconstructed signal. The noise in the received CPM signal is computed and the noise power is estimated based on the CPM-to-PSK approximation (block 416). For example, the noise estimate may be computed as shown in equation (7) and the noise power estimate, Pnoise, may be computed as shown in equation (9). The CPM-to-PSK approximation error is then estimated based on the signal power estimate, Psignal, and the parameter Δ, for example, as Perror=10−Δ/10×Psignal (block 418). The C/I estimate for the received CPM signal is then derived based on the signal power estimate, Psignal, a the noise power estimate, Pnoise, and the approximation error estimate, Perror. (block 420), as follows:
The C/I estimate may further be post-processed (e.g., filtered over multiple bursts) to obtain a more reliable estimate of the received C/I.
Process 400 may be used to derive an accurate C/I estimate for any CPM signal that is approximated as a PSK signal. In general, the received CPM signal may be approximated with one or multiple pulse shaping functions. The parameter Δ would then indicate the difference between the energy of all pulse shaping functions used to appropriate the PSK signal and the energy of all remaining pulse shaping functions.
As noted above, the channel impulse response estimate impacts both the signal power estimate and the noise power estimate, both of which in turn impact the C/I estimate. The channel impulse response may be estimated in various manners. Several channel estimation schemes are specifically described below for GSM.
GSM defines eight different training sequences (or midambles) that may be sent in the training sequence field. Each training sequence contains 26 bits and is defined such that the first five bits (labeled as ‘A’) are repeated and the second five bits (labeled as ‘B’) are also repeated, as shown in
where u0(n) represents the input symbols for the dominant pulse shaping function c0(n), which are derived based on the training sequence bits u(n) and using the same transformation as for b0(n). Because of the GMSK-to-BPSK approximation, the estimated GSM signal, {circumflex over (r)}(n), for the training sequence may be viewed as containing only the input symbols u0(n) for the dominant pulse shaping function c0(n).
The correlation between the samples in the rotated GMSK signal, {tilde over (r)}(n), and the truncated training sequence, v(n), may be expressed as:
where v0(i) is a 16-bit truncated portion of the 26-bit sequence u0(n), “*” denotes a complex conjugate, K=16, and w′(n) is post-processed noise obtained from processing {tilde over (w)}(n) in {tilde over (r)}(n) with v*0(i). Equation (23) indicates that the correlation result z(n) for each time offset n is approximately equal to a scaled version of the channel tap at that time offset. The correlation result z(n) may thus be used as the channel tap estimate for that time offset. The correlation may be performed for different time offsets in a small window (e.g., of 10 bit periods) centered at the expected peak in the correlation, which is the start of the first ‘B’ portion. Because the autocorrelation of the truncated training sequence is zero for time offsets of +5 to −5 bit periods, the channel tap estimates do not contain correlation error for these time offsets.
The correlation as shown in
The C/I estimate derived as described herein may be advantageously used for various purposes. Some exemplary uses are described below.
The C/I estimate may be used to select an appropriate data rate (or simply, a rate) for data transmission. For example, in GSM, an Adaptive Multi-Rate (AMR) vocoder is used to encode speech data. The AMR vocoder supports multiple coder/decoder (codec) modes, and each codec mode is associated with a specific rate. For example, AMR Full Rate supports 8 codec modes for 8 rates of 12.2, 10.2, 7.95, 7.4, 6.7, 5.9, 5.15, and 4.75 kbps. The codec mode for 12.2 kbps has the highest rate and lowest compression ratio, and the AMR vocoder generates 12.2 kbps ×20 msec=244 bits for each 20 msec block of speech data. Each 20 msec block of data is encoded to obtain 456 code bits that can be transmitted in a fixed frame structure used in GSM. The AMR vocoder provides different amounts of redundancy for different codec modes. The codec mode with the highest rate provides the least amount of redundancy, which then results in the least error correction capability. The converse is true for the codec mode with the lowest rate. Codec modes for higher rates are thus typically used for good channel conditions, and codec modes for lower rates are usually used for bad channel conditions. This adaptation between data coding and channel conditions is used to achieve a good tradeoff between voice quality and communication error rates.
A receiving entity (which may be a wireless device or a base station) may derive a C/I estimate for each burst, as described above, and use this C/I estimate as a channel quality indicator. C/I estimates for multiple bursts may be filtered, e.g., based on a running average. The (filtered or unfiltered) C/I estimate may be compared against a set of C/I thresholds, e.g., on a burst-by-burst basis. Based on the result of the comparison, the receiving entity may determine whether to request the transmitting entity to use a different codec mode that can achieve a better tradeoff between voice quality and probability of reliable transmission. For example, if the C/I estimate exceeds a predetermined C/I threshold, then the channel condition may be considered to be sufficiently improved, and the receiving entity may request a codec mode that performs less compression and thus provides higher voice quality. This benefit is obtained at the expense of less error protection, which may be acceptable because of the improved channel condition. A C/I threshold as high as 28 dB may be used for certain instances. The techniques described herein allow the receiving entity to estimate and report high received C/Is, which allows for the selection of codec modes with higher rates for good channel conditions.
C/I estimates may also be used to scale multiple bursts received via a wireless channel, prior to decoding. For GSM, the transmitting entity may partition each block of data into multiple subblocks and may transmit each subblock as a burst in one time slot. The wireless channel may distort each transmitted burst with a different channel response and may further degrade each transmitted burst with different amount of noise. The receiving entity receives the transmitted bursts and processes each received burst to obtain soft-decision metrics (or simply, “soft metrics”) for the burst. A soft metric is a multi-bit value obtained by the receiving entity for a single-bit (or “hard”) value sent by the transmitting entity. The receiving entity may scale the soft metrics for each received burst for a given data block with a scaling factor that is determined based on the C/I estimate for that burst. The scaling of each burst based on its C/I estimate allows different bursts to be given appropriate weight in the decoding process based on their C/I estimates.
A C/I estimate may also be used as a bad frame indicator (BFI) to determine whether a received burst is “good” or “bad”. For example, a C/I estimate may be derived for each burst and compared against a C/I threshold. The burst may be declared “good” if the C/I estimate is above the C/I threshold and other criteria (if any) are met and “bad” otherwise. The burst may be further decoded if deemed to be “good” and discarded otherwise. The bad frame indicator may also be used for other purposes. For example, if the burst is deemed to be “good”, then pertinent information may be collected and used for automatic frequency control (AFC), time tracking, and so on. Different C/I thresholds may be used for different purposes.
Some exemplary uses of the C/I estimate have been described above. The C/I estimate may also be used for other purposes, and this is within the scope of the invention.
The C/I estimation techniques described herein may be implemented by various means. For example, these techniques may be implemented in hardware, software, or a combination thereof. For a hardware implementation, the processing units used to perform C/I estimation (e.g., the processing units shown in
For a software implementation, the C/I estimation techniques may be implemented with modules (e.g., procedures, functions, and so on) that perform the functions described herein. The software codes may be stored in a memory unit (e.g., memory unit 172 in
The previous description of the disclosed embodiments is provided to enable any person skilled in the art to make or use the present invention. Various modifications to these embodiments will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other embodiments without departing from the spirit or scope of the invention. Thus, the present invention is not intended to be limited to the embodiments shown herein but is to be accorded the widest scope consistent with the principles and novel features disclosed herein.
Number | Name | Date | Kind |
---|---|---|---|
5214675 | Mueller et al. | May 1993 | A |
5371471 | Chennakeshu et al. | Dec 1994 | A |
6154489 | Kleider et al. | Nov 2000 | A |
6333953 | Bottomley et al. | Dec 2001 | B1 |
6449246 | Barton et al. | Sep 2002 | B1 |
6487255 | Arslan et al. | Nov 2002 | B1 |
Number | Date | Country | |
---|---|---|---|
20060007994 A1 | Jan 2006 | US |