The invention relates to communication systems and, more particularly, transmitter and receivers used in wireless communication systems.
In general, a receiver in a wireless communication system does not have a priori knowledge of the physical channel over which the transmitted signal propagates or the time at which a transmitter transmits the signal. Timing synchronization, also known as clock recovery, is the process by which the receiver processes a received signal to determine the precise transition points within the received waveform. In other words, the receiver attempts to “synchronize” or align its clock with the clock of the arriving waveform. This process requires the receiver to estimate or otherwise determine the appropriate “timing offset” of the received signal, i.e., the amount of skew between the transmitter's clock and that of the arriving waveform.
Incorrect determination of the timing offset can have detrimental effects on other receiver operations, such as channel estimation, symbol detection, and the like. For example, an incorrect timing offset may cause the received waveform to be sampled at times during which the waveform is in transition between two symbols resulting in an increased number of symbol detection errors.
In general, timing synchronization in wireless communication systems typically comprises “peak-picking” the output of a sliding correlator between the received signal and a transmit-waveform template. The receiver uses the output of the sliding correlator to estimate the timing offset.
Ultra-wideband (UWB) systems transmit information via baseband transmissions with high penetration capability and rich multipath diversity that can be collected with low-complexity RAKE reception. However, the information-bearing waveforms are impulse-like and have low power, which increases the difficulty in achieving accurate and efficient timing synchronization. Additionally, peak-picking the output of a sliding correlator between the received waveform and the transmit-waveform template is suboptimum in the presence of dense multipath, and results in high receiver complexity with slow acquisition times.
Existing sliding correlator timing synchronization techniques operate with assumptions that are unrealistic in UWB systems. More specifically, many techniques require unrealistic assumptions such as an absence of noise or other interference, absence of multipath, and a priori knowledge of the communication channel. For example, one technique, referred to as coarse bin reversal searching, operates under the assumption that there is no noise. Coarse bin reversal searching estimates the arrival time of the received waveform by dividing each symbol duration into thousands of bins and searching for the bin containing the greatest energy with a sliding correlator. Another technique uses a coded beacon sequence designed in conjunction with a bank of correlators to operate in the absence of multipath. The coded beacon sequence is cross-correlated with the received waveform and estimates the location of the beacon sequence within the received waveform via peak-picking. The location of the beacon sequence is used to estimate the timing offset. Non-data-aided, i.e. blind, timing synchronization techniques operate in the presence of dense multipath but require that there is no time-hopping (TH) within each symbol. Such blind timing synchronization techniques use cross-correlation and rely on dense multipath and the cyclostationarity that arises from the time-hopping restriction. So called “ranging systems” do not use a sliding correlator, but rather use a priori knowledge of the strongest path of the communication channel to estimate the distance between transmitter and receiver.
Consequently, such conventional timing synchronization techniques do not operate functionally in realistic UWB environments. Moreover, many of these conventional timing synchronization techniques for UWB systems, especially those that utilize a sliding correlator with a transmit-waveform template, result in slow acquisition and high receiver complexity.
In general, techniques are described that provide timing synchronization via correlating received waveforms with “dirty” templates, in wireless communication systems, such as ultra-wideband systems (UWB). Unlike exiting UWB timing synchronization techniques and early-late gate narrowband timing synchronization techniques, the techniques described herein peak-pick the output of a sliding correlator with “dirty templates,” i.e. templates that propagate through the UWB communication channel. These dirty templates are segments of the received waveform and are not only distorted by the unknown channel but also noisy and subject to the unknown timing offset. As shown herein, the use of the dirty templates in timing synchronization may achieve increased energy capture, resulting in improved performance and enabling reduced receiver complexity. Further, the described techniques are able to achieve timing synchronization at any desirable resolution, and are applicable to non-UWB systems provided inter-symbol interference is absent or minimal.
In one embodiment, the invention is directed to a method which processes a data stream of information-bearing symbols to form bursts of information symbols and arranges training symbols within the stream of information-bearing symbols to ensure one polarity transition within three training symbols at a receiver to synchronize timing of a transmitter and the receiver. The method outputs the bursts of information-bearing symbols and training symbols as an ultra wideband (UWB) waveform through a communication channel to the receiver.
In another embodiment, the invention is directed to a method which receives an ultra wideband (UWB) waveform through a wireless communication channel, wherein the received UWB waveform comprises bursts of information-bearing symbols. A template is selected to be used for estimating the timing offset of a burst of the received UWB waveform, wherein the template comprises a segment of a burst of the received UWB waveform and the template is correlated with a segment of a burst of the received waveform so as to form an estimate of the timing offset of the received UWB waveform. A stream of symbol estimates is output in accordance with the estimated timing offset.
In yet another embodiment, the invention is directed to a wireless communication device comprising a pulse generator and a pulse shaping unit. The pulse generator processes a data stream of information bearing symbols to form bursts of information bearing symbols and arranges training symbols within the stream of information-bearing symbols to ensure one polarity transition within three training symbols at a receiver to synchronize timing of a transmitter and the receiver. The pulse shaping unit outputs an ultra wideband (UWB) transmission waveform from the bursts of information-bearing symbols and training symbols.
In an additional embodiment, the invention is directed to a wireless communication device comprising an antenna to receive an ultra wideband (UWB) waveform through a wireless communication channel, wherein the received UWB waveform includes bursts of information-bearing symbols, a timing synchronization unit to form an estimation of a timing offset based on the received UWB waveform, and a symbol detector to output a stream of estimate symbols based on the estimate of the timing offset.
In another embodiment, the invention is directed to a system comprising a transmitter and a receiver. The transmitter processes a data stream of symbols to form bursts of information-bearing symbols and generates an ultra wideband (UWB) waveform through a wireless communication channel. The receiver receives the transmitted signal through a wireless communication channel, selects a segment of the received UWB waveform to use as a template, forms an estimate of the timing offset based on the correlation of the template with the received UWB waveform, and outputs a stream of estimate symbols based on the estimate of the timing.
The timing synchronization techniques described herein may offer one or more advantages. For example, peak-picking the output of a sliding correlator with dirty templates allows timing synchronization in realistic UWB environments, and some non-UWB systems as well, provided intersymbol interference is avoided. In particular, the described techniques operate in the presence of noise, multipath, time-hopping, and multiple users. Additionally, timing synchronization can be achieved at any desirable resolution by selecting the time increment at which each correlation is performed within a symbol duration. Moreover, voltage controlled clock (VCC) circuits can be used to implement the receiver, which may yield lower-complexity UWB receivers than with conventional techniques.
Other advantages that may be provided by the described techniques include a selectable trade-off between performance and bandwidth efficiency. Selecting data-aided dirty templates may increase the performance of the described techniques. For example, a dirty template with four training symbols increases the performance by reducing the number of operations required at the receiver to synchronize timing with the transmitter. However, selecting a non-data-aided, template provides a more efficient use of bandwidth.
The details of one or more embodiments of the invention are set forth in the accompanying drawings and the description below. Other features, objects, and advantages of the invention will be apparent from the description and drawings, and from the claims.
Transmitter 4 transmits data as a UWB waveform using a modulation scheme, such as pulse position modulation (PPM) or pulse amplitude modulation (PAM). For simplicity, the examples that follow will be described using antipodal PAM. User separation is achieved via TH codes which time-shift the pulse positions at multiples of the chip duration Tc. Each information-bearing symbol is transmitted over Nf frames each of duration Tf. During each frame, a data modulated ultra short pulse p(t) that has duration Tp<<Tf is transmitted. Each pulse, also referred to as a monocycle, can have a Gaussian, Rayleigh, or other shape used in wireless communications. At time t=t1 transmitter 4 transmits the UWB waveform according to equation (1). The energy per monocycle is denoted ε, s(k) is the kth symbol, and pT(t) denotes the transmitted symbol waveform according to equation (2) with Nf monocycles shifted by the TH code cnf during the nfth frame.
Receiver 8 receives the transmitted UWB waveform through communication channel 6 which is modeled as a tapped-delay line with L+1 taps with coefficients {α1}l=0L and delays {τl}l=0L satisfying τl<τl+1, ∀l. As a result, the waveform arriving at the receiver is given by equation (3). Additionally, channel 6 is modeled as quasi-static, i.e., the channel coefficients and delays remain invariant over one transmission burst, but can change independently from burst to burst.
Denoting the first arrival time at receiver 8 with t2, and the propagation delay through channel 6 as τ0, the first arrival time can be written t2=t1+τ0. Relative to τ0, other path delays can be uniquely described by τl, 0=τl−τ0. Consequently, the aggregate channel, i.e. channel 6 in combination with the pulse shaper of transmitter 4, is given by equation (4). Equation (5) expresses the received waveform where the received symbol waveform is defined according to equation (6). The noise term w(t) includes additive white Gaussian noise (AWGN) and multiple user interference (MUI). Inter-symbol interference is avoided by selecting Tf≧τL,0+Tp and c0=cNf−1=0 which confines pr(t) over an interval of duration [0, Ts).
The received waveform r(t) is received by receiver 8 at time t2, but receiver 8 does not know transmission time t1 or propagation delay τ0. Therefore, receiver 8 initiates recovery techniques, such as timing synchronization, channel estimation and symbol detection, at time t3 when a change in the energy of received waveforms is detected. Receiver 8 initiates recovery techniques at time t3 after the arrival of the first received waveform at time t2 where t3>t2. The timing offset may be viewed as the difference in time between t3 and the starting time of a symbol at or after t3. The first symbol starting after t3 is received at time t defined in equation (7). The arrival time t2 serves as reference while time t1 plays no role. As a result, t2 is set to zero without loss of generality.
t=t2+┌(t3−t2)/Ts┐Ts (7)
Equations (8, 9) allow timing synchronization to be corrected by an integer number nε ε[0, Nf−1] of frames such that t3+nεTf is close to either NTs or (N+1)Ts within one symbol duration.
N:=t3/Ts (8)
ε:=t3−NTs (9)
Data-aided dirty templates based on a finite number of training symbols must satisfy equation (10) where K is the total number of training symbols, i.e. preamble, and K0 is the minimum number of training symbols required to implement the described data-aided timing synchronization with dirty templates.
N≦K−K0 (10)
The techniques described herein may be applied to uplink and/or downlink UWB transmissions, i.e., transmissions from a base station to a mobile device and vice versa. Consequently, transmitter 4 and receiver 8 may be any device configured to communicate using a wireless transmission including a distribution station, a hub for a wireless local area network, a mobile phone, a laptop or handheld computing device, a personal digital assistant (PDA), a device within a wireless personal area network, a device within a sensor network, or other device.
The received UWB waveform 15 is given according to equation (5). Receiver 8 does not know when transmitter 4 began transmitting or the propagation delay of channel 6. Consequently, receiver 8 timing synchronization unit 14 turns on when a change in energy is detected in received waveforms 15. Timing synchronization unit 14 operates on segments of received waveform 15 of duration Ts starting at time (t3+nTf+mTs) for integers nε[0, Nf) and mε[0, M−1] with MTs being the observation interval. Equation (11) expresses this waveform with noise ignored for simplicity. The noise free received wave form can then be expressed according to equation (12) using the definition of t3 in equation (13) and defining the aggregate delay, i.e. delay through the aggregate channel, in equation (14).
Because p(t) has finite support over the interval (0, Tp) only a finite number of k values contribute non zero summands in equation (10). The k values are determined by equations (15, 16)
ε+nTfε[0,Ts)k=N+m+[0,1] (15)
ε+nTfε[Ts,2Ts)k=N+m+[1,2] (16)
Expressing (nTf+ε) as an integer multiple of Ts plus a residue gives equations (17, 18) respectively where no has possible values of 0 and 1 and ε0 has possible values of [0, Ts).
n0:=(ε+nTf)/Ts (17)
ε0:ε=nTf−n0Ts (18)
Using equations (17, 18) equations (15, 16) give k=N+m+n0+[0,1], ε∀ε0εE [0, Tf). Consequently equation (12) can be rewritten according to equation (19).
The pR(t−kTs+ε0) depends only on ε and n, but is independent of N, m, and n0. In other words, as m changes pR(t−kTs+ε0) remains invariant for any given n and ε.
Timing synchronization unit 14 performs a cross correlation between successively observed waveforms xn, m(t), each of duration Ts, to acquire nε. Integrating over one symbol duration Ts, the correlation between successive waveforms xn, m(t) and xn, m+1(t) is given by equation (20). From equation (20) the timing synchronization with data-aided dirty templates is designed below with the description of blind time synchronization using dirty templates following.
Timing synchronization unit 14 uses data-aided dirty templates to increase performance of estimating the timing offset. In some embodiments, training symbols are transmitted at the beginning of each burst to enable timing synchronization unit 14 to estimate the timing offset. As a result, the recovery techniques performed after such timing synchronization will not be substantially affected by the timing offset. Transmitting training symbols reduces the bandwidth of the UWB system, but increases the performance. Therefore, minimizing the number of training symbols results in an optimal trade-off between performance and bandwidth efficiency in data-aided timing synchronization. The techniques described here allow a minimum number of four symbols to be used. In some embodiments, the minimum number of symbols used is four.
In order to find the minimum number of training symbols, equation (20) is rewritten as equation (21) with coefficients A, B, and C defined in equations (22, 23) respectively. In order to minimize the number of training symbols, which results in a low complexity implementation of receiver 8, the dependence of Rxx(n; m) on N, m, and n0 is removed.
Rxx(n;m)=A∫0T
A:=E·s(N+m+n0)s(N+m+n0+1) (22)
B:=E·s(N+m+n0+1)s(N+m+n0+2) (23)
Using the training sequence given by equation (24) and using equations (22,23) the possible values of A, B, and C are given in Table (1). Therefore, the data-aided dirty template is a preamble training sequence of two positive pulses followed by two negative pulses of unit amplitude that is received by receiver 8. Receiver 8 observes successive waveforms over a symbol duration as previously described. Due to the timing offset, the symbol duration long waveforms will include a fraction of two training symbols. However, receiver 8 incrementally correlates successive waveforms over a symbol duration and peak-picks the increment with the greatest result.
In some embodiments, the size of the increment is adjusted to achieve coarse timing synchronization, also referred to as acquisition, by incrementing at the frame level to achieve an integer multiple of the symbol duration, i.e. nε, with ambiguity less than one frame duration. In other embodiments, the size of the increment is adjusted to achieve fine timing synchronization, also referred to as tracking, by incrementing at the chip level to achieve an integer multiple of the frame duration. In further embodiments, the size of the increment is a non-integer value and timing synchronization unit 14 is implemented with voltage controlled clock (VCC) circuitry.
Table 1 explicitly shows all possible values of A, B, and C. The absolute value of Rxx(n; m) remains invariant for all m, N, and n0 and is given by equation (25) where the last equality is obtained through a change of variables. Because the symbol waveform pR(t) contains Nf monocycles, the first integral corresponds to monocycles with indices from └ε0/Tf┘−1 to Nf−1 while the second integral corresponds to monocycles with indices from 0 to └ε0/Tf┘. In the absence of TH codes, i.e. cnf=0, ∀nfε[0, Nf−1], the two integrals in equation (25) can be expressed in closed form respectively as given in equations (26, 27) where Eh(τ) is given in equation (28) and ε1 is given in equation (29).
However, in the presence of TH codes, the two integrals in equations (25) cannot be expressed in closed form but the two integrals do not vary much with and without TH codes for various ε0 values and channel realizations as will be shown in greater detail below. Substituting equations (26, 27) into equation (25) gives equation (30).
The maximum of Rxx(n) of equation (30) occurs at └ε0/Tf┘=0. Consequently, for any ε, a unique nε can be found by peak-picking Rxx(n) across n as shown in equation (31) by using equation (18) and noticing that (ε+nTf)ε[0, 2Ts).
Equation (32) shows that equation (31) leads to estimating the timing offset by correcting t3 with nεTf, which results in acquiring (N+1)Ts. Further, because ε1ε[0, Tf), the acquisition error is bounded by one frame duration, i.e. frame-level resolution. In other words, timing synchronization using dirty template with training symbols is achieved by peak-picking the absolute value of the cross correlation in equation (30) between successive waveforms xn,m(t) each of duration Ts. Correcting the starting time t3 of timing synchronization unit 14 with an estimate obtained from equation (31) yields starting time (N+1)Ts with error less than Tf.
Additionally, if ε1 is uniformly distributed over the interval [0, Ts) then ε1 is uniformly distributed over the interval [0, Tf). As a result, E{t3+nεTf|t3}=(N+1)Ts+Tf/2. An estimate is obtained by computing Rxx(n;m) over pairs of xn,m(t) and averaging their absolute values across the M/2 pairs as given in equation (33).
In order to carry out timing synchronization with a data-aided dirty template, M must at least be 2, i.e. m=[0, 1]. From equations (15, 16) m=1 implies k≧N+3. Therefore, the minimum number of training symbols K must satisfy K−1≧N+3. In other words, N has to be bounded by K−4 for any given number of training symbols K.
Timing synchronization using a non-data-aided template trades-off performance for efficient bandwidth. All pulses in non-data-aided timing synchronization are information-bearing, resulting in efficient use of bandwidth. However, longer observation intervals are required to obtain the same performance as data-aided timing synchronization because the information symbols are not guaranteed to switch from positive to negative within two symbols as was designed in the data-aided technique above.
Blind timing synchronization using dirty templates follows from equation (20). Equation (20) can be rewritten as equation (34) because ∫0T
Rxx(n;m)=E·s(N+m+ns+1)[s(N+m+ns)∫ε
|Rχχ(n;m)|=E·|s(N+m+ns)∫ε
Moreover, with information conveying symbols s(k)ε{±1} being independent and taking the conditional expectation of the absolute value |Rxx(n;m)| for any nε[0, Nf−1] gives equation (36).
Equation (36) removes the dependence of the absolute value |Rxx(n;m)| on N, m, and ns. However, Rxx(n) is still dependent on n for any timing offset ε.
As described previously with data-aided timing synchronization, the symbol waveform pR(t) contains Nf monocycles. As a result, the first integral corresponds to monocycles with indices from 0 to └ε0/Tf┘−1 to Nf−1 while the second integral corresponds to monocycles with indices from 0 to └ε0/Tf┘. Similarly, in the absence of TH codes, i.e. cnf=0, ∀nfε[0, Nf−1], the two integrals in equation (26) can be expressed in closed form respectively as given in equations (27, 28) where Eh(τ) is given in equation (29) and ε1 is given in equation (30).
Substituting equations (27, 28) into equation (36) gives equation (37) because εsε[0, Ts], └εs/Tf┘ is in the interval [0, Nf−1]. Consequently, the maximum of Rxx(n) in equation (37) is given by equation (38).
The maximum occurs at └εs/Tf┘=0 if Eh(ε1)<Eh(Tf)/2 and at └ε0/Tf┘=Nf−1 otherwise. Using the definition of go and noticing that nε[0, Nf−1] gives piece-wise function (39).
Equation (39) peak picks Rxx(n) across n for any ε. In other words, arg maxn {Rxx(n)} gives nε because by correcting t3 with the number of frames given by equation (39), either NTs or (N+1)Ts is acquired with ambiguity<Tf. Table 2 explicitly lists the possible values of t3+arg maxn {Rxx(N)}Tf.
Similar to data-aided timing synchronization, equation (33) estimates Rxx(n;m) by computing Rxx(n;m) over pairs of Xn,m(t) each of duration Ts, and averaging the resulting values across the M/2 pairs. Peak-picking equation (33), i.e.
allows t3 to be corrected with ńεTf results and results in an estimate of a symbol starting time. Equation (33) is not limited to an integer output and synchronization unit 14 can be implemented with VCC circuits.
Timing synchronization unit 14 estimates the timing offset and initiates channel estimator 16 at the start of the first symbol of received waveform 15 after t3 with resolution determined by the number of increments. Channel estimator 16 reduces the effects of channel 6, including attenuation and multipath effects. Matched filter 17 receives the output of channel estimator 16 and separates multiple users of communication system 2. Sampling unit 18 samples the output of matched filter 17 producing an output of symbols. Symbol detector 19 performs symbol detection on the output of matched filter 17 producing a stream of symbol estimates 20.
The embodiment of timing synchronization unit 14 is described for exemplary purposes only. A substantially similar timing synchronization unit may be employed for non-data-aided timing synchronization. Such a timing synchronization unit would correlate M/2 successive symbol duration waveforms pairs. However, instead of correlating dirty templates of training symbols, the non-data-aided timing synchronization unit would correlate dirty templates of information symbols. Because training symbols are not being transmitted, non-data-aided timing synchronization results in increased bandwidth efficiency. However, to achieve similar performance as the data-aided timing synchronization technique M is generally a larger value, resulting in a slower acquisition time and increased complexity.
For reference, exemplary received symbol 30 with symbol duration Ts=NfTf includes Nf=6 pulses, each with duration Tf, transmitted by transmitter 4. Equation (40) expresses exemplary symbol 30 in terms of the aggregate channel given in equation (4). Waveforms 32 and 34 each include two UWB symbols with received pulses represented as triangles to indicate the time spreading multipath effects of channel 6. Positive pulses are represented by pulses with a solid fill, while negative pulses are represented by pulses with a cross-hatch fill. Waveform 32, denoted xτ
Even in the presence TH and unknown multipath, least-squares (LS) optimal timing estimation is given by equation (43). Peak-picking the cross correlation of Ts long received segments of waveforms 32 and 34 allows timing acquisition and tracking in one step or in separate steps at any desirable resolution. Waveforms 32 and 34 guarantee LS estimation of timing off set τ0 via equation (43).
Waveform 40 is designed according to equation (25) such that pairs of positive symbols and pairs of negative symbols are transmitted alternately. Consequently, equation (43) is used to estimate timing offset τ0.
Waveform 50 transmits symbols such that each segment 54A-54E has duration Ts and defines a discrete information-bearing symbol. Waveform 50 propagates through channel 6 and is received by receiver 8 as waveform 52. The triangular pulses of waveform 52 includes pulses illustrating the multipath effects of channel 6 which spreads the energy of the transmitted pulse in time. Although time-hopping is not illustrated in
Although xτ
By taking the absolute value of the averaged cross correlations, the interferer's waveform is eliminated, leaving only the desired user as shown in equation (49).
Data-aided timing synchronization techniques have higher performance than the non-data-aided techniques. For example, data-aided timing synchronization of
The described techniques may provide advantages in UWB communications systems, and non-UWB wireless communication systems where inter-symbol interference is absent or substantially reduced. In particular, the described techniques operate in realistic UWB environments, e.g., environments having the presence of noise, multipath, time-hopping, and multiple users. Timing synchronization with dirty templates peak-pick the output of a sliding correlator with a template that propagates through the wireless communication channel. Because the template propagates through the same communication channel, the resulting energy capture is higher than energy capture using a clean template, i.e., a stored segment of the transmit waveform. Selecting a data-aided, dirty template increases the performance of the described techniques. For example, a dirty template with four symbols increases the performance by reducing the number of operations performed at the receiver. However, selecting a blind, i.e. non-data-aided, template provides a more efficient use of bandwidth.
Additionally, timing synchronization can be achieved at any desirable resolution by selecting the increment at which each correlation is performed within a symbol duration. In some embodiments, voltage controlled clock (VCC) circuits can be used to implement the receiver.
The described techniques can be embodied in a variety of devices that communicate using ultra wideband communication, including base stations, mobile phones, laptop computers, handheld computing devices, personal digital assistants (PDA's), a device within a wireless personal area network, a device within a sensor network, and the like. The devices may include a digital signal processor (DSP), field programmable gate array (FPGA), application specific integrated circuit (ASIC) or similar hardware, firmware and/or software for implementing the techniques. If implemented in software, a computer-readable medium may store computer readable instructions, i.e., program code, that can be executed by a processor or DSP to carry out one of more of the techniques described above. For example, the computer-readable medium may comprise random access memory (RAM), read-only memory (ROM), non-volatile random access memory (NVRAM), electrically erasable programmable read-only memory (EEPROM), flash memory, or the like. The computer-readable medium may comprise computer readable instructions that when executed in a wireless communication device, cause the wireless communication device to carry out one or more of the techniques described herein. These and other embodiments are within the scope of the following claims.
This application claims priority from U.S. Provisional Application Ser. No. 60/453,659, filed Mar. 8, 2003, the entire content of which is incorporated herein by reference.
This invention was made with Government support under Subcontract #497420 awarded by the University of Delaware (Army Prime #DAAD19-01-2-011). The Government may have certain rights in the invention.
Number | Name | Date | Kind |
---|---|---|---|
6556621 | Richards et al. | Apr 2003 | B1 |
6744832 | Miao | Jun 2004 | B2 |
6925109 | Richards et al. | Aug 2005 | B2 |
7068715 | Hoctor et al. | Jun 2006 | B2 |
20010053175 | Hoctor et al. | Dec 2001 | A1 |
20030069025 | Hoctor et al. | Apr 2003 | A1 |
20030108133 | Richards | Jun 2003 | A1 |
20030198212 | Hoctor et al. | Oct 2003 | A1 |
20030198308 | Hoctor et al. | Oct 2003 | A1 |
20040156421 | Yamaguchi | Aug 2004 | A1 |
Number | Date | Country | |
---|---|---|---|
60453659 | Mar 2003 | US |