The present invention relates generally to equalization, detection and decoding techniques and, more particularly, to sequence estimation techniques with reduced complexity.
A magnetic recording read channel converts an analog read channel into an estimate of the user data recorded on a magnetic medium. Read heads and magnetic media introduce noise and other distortions into the read signal. As the information densities in magnetic recording increase, the intersymbol interference (ISI) becomes more severe as well, (i.e., the channel impulse response becomes longer). In read channel chips, a Viterbi detector is typically used to detect the read data bits in the presence of intersymbol interference and noise. When the channel impulse response is long, however, the hardware complexity associated with the Viterbi detector becomes prohibitively large, as the number of states considered by the Viterbi detector grows exponentially with the length of the channel impulse response. A number of techniques have been proposed or suggested for reducing the complexity of Viterbi detectors.
For example, the hardware complexity of the Viterbi detector can be reduced by using a reduced-state trellis that considers only a shortened impulse response, and canceling intersymbol interference due to the tail of the impulse response for each state by using past survivor symbols as local feedback. See, e.g., J. W. M. Bergmans, “Digital Baseband Transmission and Recording,” Kluwer Academic Publishers, 326 (1996) or U.S. Pat. No. 6,690,754, issued to Haratsch et al., entitled “Method and Apparatus for Reducing the Computational Complexity and Relaxing the Critical Path of Reduced-State Sequence Estimation (RSSE) Techniques,” incorporated by reference herein.
The error rate performance of reduced-state Viterbi detectors with local feedback can approach the performance of full-state Viterbi detectors without local feedback that implement maximum likelihood sequence estimation (MLSE). The maximum achievable data rate of a Viterbi detector implementation with local feedback, however, is considerably lower compared to a Viterbi detector implementation without local feedback, as significantly more operations have to be performed within one clock period. A need therefore exists for a method and apparatus for performing reduced-state Viterbi detection with local feedback at the high data rates that are required by evolving high-end storage applications.
Generally, a method and apparatus are disclosed for improving the maximum data rate of reduced-state Viterbi detectors with local feedback in magnetic recording systems. The maximum data rate that may be achieved by the disclosed reduced-state Viterbi detectors is improved by precomputing a number of candidate branch metrics and performing pipelined selection of one of the precomputed values. Precomputing the branch metrics for possible symbol combinations in the channel memory makes it possible to shorten the critical path. In an alternative embodiment, intersymbol interference estimates or inter symbol interference-free signal estimates are precomputed, and branch metric are computed based on the selected precomputed values.
A read channel signal is processed in a magnetic recording device by precomputing branch metrics, intersymbol interference estimates or intersymbol interference-free signal estimates for speculative sequences of one or more channel symbols; selecting one of the precomputed values based on at least one decision from at least one corresponding state; and selecting a path having a best path metric for a given state.
A more complete understanding of the present invention, as well as further features and advantages of the present invention, will be obtained by reference to the following detailed description and drawings.
The present invention increases the maximum data rate that may be achieved by reduced-state Viterbi detectors. According to one aspect of the invention, branch metrics, ISI-free signal estimates or ISI estimates are precomputed, and the correct values are selected based on survivor symbols or ACS decisions. In this manner, the computations of ISI estimates, ISI-free signal estimates or branch metrics are removed from the critical path. According to another aspect of the invention, branch metrics, ISI-free signal estimates or ISI estimates can be selected in a pipelined fashion using a multiplexer network structure that corresponds to the structure of the trellis considered by the detector.
For a detailed discussion of reduced-state Viterbi detection with local feedback, which is also known as Reduced-State Sequence Estimation (RSSE), (Delayed) Decision-Feedback Sequence Estimation (DFSE), and Parallel Decision-Feedback Equalization (PDFE), see, for example, U.S. Pat. No. 6,690,754 to Haratsch et al., entitled “Method and Apparatus for Reducing the Computational Complexity and Relaxing the Critical Path of Reduced-State Sequence Estimation (RSSE) Techniques,” incorporated by reference herein, and the references cited therein. See also, Lee and Messerschmidt, “Digital Communication,” Kluwer Academic Publishers, 2nd ed. (1994).
The modulator 110 maps an information symbol bn into a channel symbol an. For ease of illustration, it is assumed that the number of information bits per information symbol is one. In other words, the information symbol bn is equivalent to a single information bit bn. The modulator 110 maps an information symbol bn to a two-level channel symbol an according to following rule:
The techniques discussed herein can easily be applied to other modulation schemes and more than two signal levels. For a discussion of reduced-state Viterbi detection for an exemplary modulation scheme with five signal levels, see, U.S. patent application Ser. No. 09/471,920, entitled, “Method and Apparatus for Shortening the Critical Path of Reduced Complexity Sequence Estimation Techniques,” incorporated by reference herein.
The ISI channel 100 is modeled as an FIR filter, and the channel output at time n is given by
where zn is the ISI channel output, {fi′}, 0≦i≦L are the channel coefficients, L is the channel memory, and wn is noise. The decision of a detector 120 that corresponds to bn is denoted by b′n.
The ISI channel output zn depends on the current channel symbol an and the past L transmitted channel symbols {an−i}, 1≦i≦L. This output can be described as a function of the L past transmitted channel symbols using a finite state machine (FSM) model, where the channel state at time n is defined by
αn=(an−1,an−2, . . . ,an−L). (3)
The channel state is equivalently defined in terms of the L past transmitted information bits:
βn=(bn−1,bn−2, . . . ,bn−L). (4)
It is apparent from equations (3) or (4) that the number of channel states is given by
2L. (5)
To simplify the notation, the integer value corresponding to the vector (bn−1, . . . , bn−L+1, bn−L) will be used to represent the channel state βn. For example, 0n will stand for βn (0, . . . , 0,0) and 1n will stand for βn=(0, . . . , 0,1).
The FSM process describing the ISI channel 100 can be visualized using a trellis diagram 200, shown in
First, the Viterbi algorithm calculates branch metrics for the state transitions from σn to σn+1. For a channel with additive white Gaussian noise, the optimum blanch metric is the Euclidean distance between the received symbol rn and the ideal ISI channel output zn that corresponds to the respective state transition. For a transition from state σn, the branch metric is given by
where an is the channel symbol that is associated with a transition from state σn to a successor state σn+1. The techniques described herein are independent from the way branch metrics are computed, i.e., branch metrics can also by computed by using the absolute value of the difference between the received symbol rn and the ideal ISI channel output zn.
In the trellis 200 of
The three operations to determine the best survivor path into a new state σn+1, i.e., adding up corresponding path metrics of predecessor states σn and branch metrics for the extensions into the new state σn+1, comparing the path metrics of these extended sequences, and selecting the extension with the minimum path metric as the survivor sequence for the new state, are referred to as add-compare-select (ACS), which can be described by the following equation:
Γn+1(σn+1)=min (Γn(σn)+λn(σn,an)). (7)
As previously indicated, the invention can also be applied when branch metrics are computed differently. As known in the art, for certain branch metric definition, the best path into a state is given by the path with the maximum (instead of minimum) path metric. For such cases, the ACS operation described by equation (7) involves a maximum instead of a minimum operation.
In the example of
As indicated above, the disadvantage of MLSE is that its complexity grows exponentially with the channel memory. Considering fewer states for the detection of the most likely data sequence reduces the required hardware or computational effort. Reduced-state Viterbi Detection with local feedback accomplishes this by merging several separate states into one single reduced state and keeping only one survivor path per reduced state. The ISI that is not considered in the reduced state is cancelled for each reduced-state by using channel symbols from the corresponding survivor path in a local feedback fashion. Reduced-state Viterbi detection with local feedback is also known as “Reduced-State Sequence Estimation (RSSE)”, “(Delayed) Decision-Feedback Sequence Estimation”, “Parallel Decision-Feedback Equalization”, etc.
In the simplest variant of RSSE, a reduced state β′n is obtained by not considering all L information symbols, but only the past K information symbols for the definition of a trellis state:
β′n=(bn−1, bn−2, . . . , bn−K), 0≦K≦L, (8)
where K is referred to as the truncated channel memory. The number of states in the reduced-state trellis is then given by
2K. (9)
The reduced state β′n does not contain information about the ISI caused by the channel symbols (an−K−1, an−K−2, . . . , an−L). Conceptually, this reduced state is obtained by grouping all original states βn as defined in Equation (4) with the same information symbol sequence (bn−1, bn−2, . . . , bn−K), but different sequences (bn−K−1, bn−K−2, . . . , bn−L) into one single reduced state β′n. Therefore, this reduced state does not make any statement about the ISI associated with the channel coefficients (fK+1, fK+2, . . . , fL). But an estimate for this ISI component can be computed by considering the respective channel symbols from the survivor sequence into this state. The ISI corresponding to a state is not known a-priori as in MLSE, but must be determined at each detection step by using channel symbols from the corresponding survivor path. Let σn denote a state in the reduced-state trellis, i.e., σn=β′n. The ISI estimate un (σn) for a state σn is calculated at time step n as
where ân−i(σn) is the channel symbol that corresponds to the survivor sequence into state σn and that is associated with trellis step n−i The first term on the right hand side of equation (10) computes the ISI component that is known a-priori due to the definition of the reduced state in equation (8). The second term on the right hand side of equation (10) is the ISI component caused by channel taps that were ignored in the reduced-state definition of equation (8). This ISI term is calculated at each detection step for a given state by using respective survivor symbols as local feedback.
With the ISI estimate un(σn), the branch metric for the transition that emanates from state σn to reach a successor state σn+1 and corresponds to channel symbol an can be computed as:
λn(σn,an)=(rn−f0·an−un(σn))2. (11)
As in MLSE, the most likely survivor path into the state σn+1 with the path metric Γn+1(σn+1) among the path extensions from all possible predecessor states {σn} is determined with an ACS operation:
The version of RSSE where a reduced state is defined by considering just a truncated channel memory as in equation (8) is referred to as (Delayed) Decision-Feedback Sequence Estimation (DFSE), described, for example, in A. Duel-Hallen and C. Heegard, “Delayed Decision-Feedback Sequence Estimation,” IEEE Transaction on Communications, 428-436 (May 1989). A reduced-state trellis can also be constructed by applying set partitioning principles to the channel symbol alphabet, as suggested in M. V. Eyuboglu and S. U. Qureshi, “Reduced-State Sequence Estimation With Set Partitioning and Decision-Feedback,” IEEE Transactions on Communications, 13-20 (January 1988). Recently, even more general rules for the definition of reduced states were given in B. E. Spinnler and J. Huber, “Design of Hyper States for Reduced-State Sequence Estimation,”, AEU (Electronics and Communication), 17-26 (1996). The present invention can be applied to such general RSSE methods. In addition, the present invention can be applied to another subclass of RSSE, referred to as Parallel Decision-Feedback Equalization, described in Lee and Messerschmidt, “Digital Communication,” 2nd nd ed. (1994). These publications are each incorporated by reference herein.
Now, RSSE will be explained for the case that L=4 and K=1. Then, a state in the reduced-state trellis is defined according to equation (8) as:
β′n=(bn−1) (13)
and the number of states in the reduced-state trellis is equal to 21=2.
As shown in
Reduced-state Viterbi detection with local feedback that implements, e.g., RSSE, is associated with less computational complexity than full-state Viterbi detection that implements MLSE for the same channel memory L, as it processes less states. However, this comes at the expense of a significantly longer critical path, which is drawn in
The present invention employs two techniques to increase the maximum data rate that may be achieved by the reduced-state sequence estimator 500. First, as discussed below in conjunction with
The correct branch metrics are selected at stage 720, discussed below in conjunction with
In the exemplary uncoded channel model described above, the input into the reduced-state detector is given by equation (2), and a state in the reduced-state trellis is defined by equation (8). A state in the reduced-state trellis is denoted by σn, i.e., σn=β′n. A branch metric for the transition from state σn to σn+1 that corresponds to the information bit sequence bn, bn−1, . . . bn−L is given by
where an−i is the channel symbol that corresponds to the information bit bn−i. This is the same branch metric that was referred to as λn(σn, an) in the context of equation (11). To account for all possible bit sequences, 2L+1 branch metrics have to be precomputed. For a transition from state σn to σn+1, there are 2L−K branch metric candidates that correspond to the same bit sequence bn−1, bn−2, . . . , bn−K, which is determined by σn, but different speculative bit sequences bn−K−1, bn−K−2, . . . , bn−L. For each state and transition in the reduced-state trellis, the appropriate branch metric is selected based on the L−K survivor symbols ân−K−1, ân−K−2, . . . , ân−L that correspond to this state. The selection of the branch metric associated with the transition from state σn=0n to σn+1=0n+1 is shown in
To reduce the hardware for the precomputation, the branch metrics do not have to be fully precomputed. Instead, ISI-free signal estimates can be precomputed, and branch metrics are then calculated using the correct ISI-free signal estimates that are selected based on past survivor symbols as shown in
In total, 2L ISI-free signal estimates have to be precomputed, but only 2K+1 branch metrics are calculated in this architecture. However, the Euclidean distance metric computation,
λn=(qn−f0an)2 (16)
is in the critical path, while the computation of ISI-free signal estimates is outside the critical path.
The correct ISI-free signal estimates are selected at stage 920, discussed below in conjunction with
To reduce the hardware for the precomputation even further, ISI estimates instead of ISI-free signal estimates can be precomputed, and ISI-free signal estimates and branch metrics are then calculated using the correct ISI estimates that are selected based on past survivor symbols as shown in
In total, 2L ISI estimates have to be precomputed, but only 2K ISI-free signal estimates and 2K+1 branch metrics are calculated in this architecture. An ISI-free signal estimate is then computed according to:
qn=rn+q′n, (18)
and the corresponding branch metric is given by
λn=(qn−f0·an)2. (19)
It is noted that the improved data rate achieved by the present invention comes at the expense of increased hardware complexity, as shown, for example, in
In the precomputation architectures of FIGS. 8 (branch metrics), 10 (ISI-free signal estimates) and 11 (intersymbol interference estimates), a 2L−K-to-1 multiplexer 810, 1010, 1110 lies in the critical path. Although the computation of the branch metrics, ISI-free signal estimates or ISI estimates is not part of the critical path anymore, the delay due to the multiplexer 810, 1010, 1110 still depends on the channel memory. In a straightforward tree-wise implementation of the 2L−K-to-1 multiplexer 810, 1010, 1110 using 2L−K-1 2-to-1 multiplexers, the delay is equal to the delay of L−K 2-to-1 multiplexers, potentially mitigating the speed-up achieved by precomputing branch metrics, ISI-free signal estimates or ISI estimates.
The present invention recognizes that when branch metrics, ISI-free signal estimates or ISI estimates are precomputed L−K time steps in advance, they can be selected using L−K levels of 2-to-1 multiplexers that are driven by ACS decisions and where each level is associated with a pipeline stage. However, only a single 2-to-1 multiplexer is part of the critical path, and the delay associated with the selection of collect values becomes independent of the channel memory.
In
Generally, branch metrics are precomputed two or more time units in advance and then selected over two or more clock periods. At each stage 1310, 1320, 1330 shown in
In
In
Among other benefits, the present invention allows for a VLSI implementation of reduced-state Viterbi detectors with local feedback for data rates that are significantly increased relative to conventional designs. Even larger data rate increases can be achieved when two or more trellis steps are processed within once clock period using a multi-step trellis. To achieve this additional speed advantage, the invention disclosed here can be combined with the multi-step detection method disclosed in United States Patent Application entitled “Method and Apparatus for Multiple Step Viterbi Detection with Local Feedback,” filed contemporaneously herewith and incorporated by reference herein. The invention uses an architecture that is very regular making it suitable for high-speed implementation. Viterbi detectors with local feedback can achieve better error rate performance than postprocessor-based structures in the magnetic recording application. Therefore, reduced-state Viterbi detection with local feedback is an attractive detector structure for future read channel chips. The use of reduced-state Viterbi detection with local feedback in the magnetic recording application is described in E. F. Haratsch, “Viterbi Detector Architectures for Magnetic Recording,” 2003 International Symposium on VLSI Technology, Systems, and Applications, 243-46, Oct. 6-8, 2003. Post-processor based detector structures are discussed in Z. A. Keirn et al., “On the Use of Redundant Bits for Magnetic Recording: Single Parity Codes and Reed-Solomon ECC,” IEEE Transactions on Magnetics, 225-30 (January 2004), and the references therein.
Another benefit of the invention is that ACS decisions can be used to select precomputed branch metrics, ISI-free signal estimates or ISI estimates as shown in
In a register-exchange survivor memory implementation, survivor symbols for each state are stored and updated at each detection step. In a trace-back implementation, however, ACS decisions are stored as pointers in a memory, and the detected symbols ale obtained by tracing back the pointers that correspond to a survivor path. As the trace-back architecture does not require the updating of all survivor symbols at each detection step, it is associated with less power consumption than the register-exchange architecture. However, the trace-back architecture is associated with larger detection latency and therefore not suitable for the reduced-state Viterbi detector shown in
The techniques described herein can be employed, e.g., to detect data in the presence of intersymbol interference and noise in magnetic recording read channels. The disclosed reduced-state Viterbi detectors with local feedback improve the detection of read data bits compared to post-processor based structures. In particular, the invention can be used to implement a read channel that performs noise-predictive data detection and achieves the ever increasing high data rates that are required by evolving storage applications. For a discussion of noise-predictive detection in magnetic recording, see, e.g., R. D. Cideciyan et al., “Noise Predictive Maximum Likelihood Detection Combined With Parity-Based Post-Processing,” IEEE Trans on Magnetics, 714-20 (March 2001), and E. F. Haratsch, “Viterbi Detector Architectures for Magnetic Recording,” International Symposium on VLSI Technology, Systems, and Applications, 243-46 (October 2003).
The simplified block diagram for a read channel incorporating noise-predictive reduced-state Viterbi detection is shown in
where an are the data symbols defined as in equation (1), hi are the equalization target coefficients, M is the equalization target order, and vn is the noise at the output of the FIR equalizer. The equalization target is chosen such that its frequency spectrum matches the characteristics of the read channel well. The impulse response associated with the equalization target can be described by the equation:
H(D)=h0+h1·D+h2·D2+ . . . +hM·DM. (21)
The error rate performance of a lead channel can be improved by employing a noise-predictive FIR (NP-FIR) filter 1820 after the FIR equalizer 1810 that whitens the noise. The impulse response associated with the NP-FIR can be characterized with the polynomial:
P(D)=p0+p1·D+p2·D2+ . . . +pN·DN, (22)
where pi, 0≦i≦N are the coefficients and N is the order of the NP-FIR filter.
The subsequent reduced-state Viterbi detector considers a channel response with the polynomial:
F(D)=f0+f1·D+f2·D2+ . . . +fM+N·DM+N=H(D)·P(D), (23)
and the signals at the input of the reduced-state Viterbi detector are given by:
where fi, 0≦i≦L, are the channel coefficients of the channel seen by the reduced-state Viterbi detector, L is the channel memory, and wn is the remaining noise at the output of the NP-FIR filter 1820. The channel memory L would be typically equal to L=M+N, but the reduced-state detector could also consider a channel with shorter channel memory, i.e. L<M+N. The channel coefficients fi are given by the convolution of the equalization target and the impulse response of the NP-FIR filter 1820 (see equation (23)). Equation (24) is equivalent to equation (2). Therefore, the features of the invention can be applied to the read channel application, i.e., a reduced-state can be defined as in equation (8), branch metrics can be precomputed as in equation (14) using the channel coefficients defined by (23), and an ACS operation can be performed as in equation (12). A correct branch metric for a transition in the trellis can be selected using the architectures shown in
The invention can also be applied when a parity check code is used to achieve coding gain. For example, when a one-bit parity check code is used, a state σn in the full-state trellis is given by:
σn=(sn−1;bn−1,bn−2, . . . , bn−L), (25)
where sn is the running parity syndrome given by the XOR-sum:
sn=bn⊕sn−1. (26)
The total number of states in the reduced-state trellis that accounts for the parity check code is given by:
2×2L (27)
Analogous to equation (8), a state σn in the reduced-state trellis can be defined by considering only the past K information bits or symbols:
σn=(sn−1;bn−1,bn−2, . . . ,bn−K), (28)
and the number of states in the reduced-state trellis is equal to:
2×2K. (29)
A conventional implementation of a reduced-state Viterbi detector that considers the reduced-state trellis defined according to equation (28) would use equations (10)-(12) to compute ISI estimates, blanch and path metrics. However, due to the local feedback required for the computation of ISI estimates, it is challenging to achieve very high data rates. However, the maximum achievable data rate can again be increased significantly by precomputing branch metrics and selecting correct ones as described above. Alternatively, ISI-free signal estimates or ISI estimates can be precomputed and correct ones can be selected as described above.
Branch metrics can be precomputed for possible bit sequences according to equation (14). As described above for L=4 and K=1, the required branch metric λn (bnbn−1xxx) for a transition from state σn=(sn−1;bn−1) is selected among the precomputed branch metrics λn (bnbn−1000), λn(bnbn−1001), λn(bnbn−1010), λn(bnbn−1011), λn(bnbn−1100), λn(bnbn−1101), λn(bnbn−1110), and λn(bnbn−1111) based on survivor symbols or ACS decisions.
The invention can also be applied to signal-dependent detection, which is sometimes referred to as data-dependent detection and explained in detail in the co-pending United States Patent Application entitled “Method and Apparatus for Generating Filter Tap Weights and Biases for Signal Dependent Branch Metric Computation,” incorporated by reference herein. In signal-dependent detection, more than one signal-dependent (SD) NP-FIR filters operate in parallel to whiten the noise.
In
P(D;1)=p0(1)+p1(1)·D+pN(1)·DN. (30)
The filter coefficients of the different SD NP-FIR filters 1920 can differ; as in a signal-dependent channel the noise statistics depend on the transmitted data or bit sequence. The generation of filter coefficients for the SD NP-FIR filters is described in co-pending United States Patent Application entitled “Method and Apparatus for Generating Filter Tap Weights and Biases for Signal Dependent Branch Metric Computation,” incorporated by reference herein.
For the considered channel with two SD NP-FIR filters 1920, the reduced-state Viterbi detector 1930 would compute branch metrics considering two different channel impulse responses with the polynomials F(D;1) and F(D;2) that are given by:
F(D;1)=f0(1)+f1(1)·D+ . . . fM+N(1)·DM+N=H(D)·P(D;1), and (31)
F(D;2)=f0(2)+f1(2)·D+ . . . fM+N(2)·DM+N=H(D)·P(D;2). (32)
In a signal-dependent channel, the filter coefficients fi that are used to compute a branch metric depend on the transmitted data or bit sequence. For two SD NP-FIR filters 1920, branch metrics are precomputed according to equation (14) for a first group of bit sequences (bn−1bn−2 . . . bn−L) using filter coefficients fi(1), and for a second group of bit sequences (bn−1bn−2 . . . bn−L) the filter coefficients fi(2) are used.
For example, signal-dependent branch metrics for transitions from states σn to σn+1 that correspond to all bit sequences starting with (bnbn−1)=(00) or (bnbn−1)=(11) are computed using channel coefficients fi(1) and the sample rn(1):
Continuing this example, signal-dependent branch metrics for all bit sequences that start with (bnbn−1)=(01) or (bnbn−1)=(10) are computed using the second of channel coefficients fi(2) and the second sample rn(2):
Comparing the signal-dependent branch metric equations (33)-(36) with the non signal-dependent branch metric equation (14), signal-dependent blanch metrics are computed using the same underlying function, but the choice of the sample rn and channel coefficients fi depends on the bit sequence for which the branch metric is computed. The precomputation of signal-dependent branch metrics was illustrated here using two signal-dependent NP-FIR filters and a particular grouping of bit sequences, but it is apparent how signal-dependent blanch metrics are precomputed for more than two signal-dependent NP-FIR filters and other groupings. E.g., all possible bit sequences of length L can be divided into more than two groups, for which separate samples rn and separate sets of channel coefficients fi would be used to precompute branch metrics.
The selection of the correct branch metric, the ACS operation and the SMU are implemented as described above for the non-signal dependent detector. Therefore all the benefits of the invention apply to signal-dependent detection as well. In a further variation of the present invention, signal-dependent ISI-free signal estimates or intersymbol interference estimates can be precomputed, instead of branch metric, as would be apparent to a person of ordinary skill in the art based on the present disclosure. Then, signal-dependent blanch metrics would be computed based on selected signal-dependent ISI-free signal estimates of ISI estimates as described above.
It is to be understood that the embodiments and variations shown and described herein are merely illustrative of the principles of this invention and that various modifications may be implemented by those skilled in the art without departing from the scope and spirit of the invention.
This application is a continuation application of U.S. patent application Ser. No. 10/853,090, filed May 25, 2004 and a continuation-in-part of pending U.S. application Ser. No. 11/234,446, filed Sep. 26, 2005, which is a divisional of U.S. application Ser. No. 09/834,668, now U.S. Pat. No. 7,000,175, each incorporated by reference herein.
Number | Date | Country | |
---|---|---|---|
Parent | 09834668 | Apr 2001 | US |
Child | 11234446 | Sep 2005 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10853090 | May 2004 | US |
Child | 11691847 | Mar 2007 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11234446 | Sep 2005 | US |
Child | 11691847 | Mar 2007 | US |