In certain embodiments, an apparatus may comprise a circuit configured to receive a plurality of samples of an input signal. The circuit may update one or more equalizer parameters using partial zero forcing equalization. Further, the circuit may generate an equalized signal based on the plurality of samples of the input signal and the one or more equalizer parameters.
In certain embodiments, a system may comprise an adaptation circuit configured to update one or more equalizer parameters based on a plurality of samples of the input signal, a fraction of the minimum eigenvalue of a covariance matrix of the input signal and a step size. The system may further comprise an equalizer circuit configured to generate an equalized signal based on the plurality of samples of the input signal and the one or more equalizer parameters.
In certain embodiments, a method may comprise receiving a plurality of samples of an input signal. The method may comprise updating one or more equalizer parameters based on the plurality of samples of the input signal, a fraction of the minimum eigenvalue of a covariance matrix of the input signal and a step size. The method may further comprise generating an equalized signal based on the plurality of samples of the input signal and the one or more equalizer parameters.
In the following detailed description of the embodiments, reference is made to the accompanying drawings which form a part hereof, and in which are shown by way of illustrations. It is to be understood that features of the various described embodiments may be combined, other embodiments may be utilized, and structural changes may be made without departing from the scope of the present disclosure. It is also to be understood that features of the various embodiments and examples herein can be combined, exchanged, or removed without departing from the scope of the present disclosure.
In accordance with various embodiments, the methods and functions described herein may be implemented as one or more software programs running on a computer processor or controller. In accordance with another embodiment, the methods and functions described herein may be implemented as one or more software programs running on a computing device, such as a personal computer that is using a disc drive. Dedicated hardware implementations including, but not limited to, application specific integrated circuits, programmable logic arrays, and other hardware devices can likewise be constructed to implement the methods and functions described herein. Further, the methods described herein may be implemented as a computer readable storage medium or device including instructions that when executed cause a processor to perform the methods.
The present disclosure generally relates to the equalization of a signal, and in some embodiments, the present disclosure relates to equalization to reduce or eliminate inter-symbol interference (ISI) of a channel. Some systems, such as electrical, electronic, motor drive, processing, or other systems may receive a signal at a channel. The filtering or other operations of a channel may cause a spreading of individual data symbols passing through the channel. For consecutive symbols, this spreading may cause part of the symbol energy to overlap with neighbouring symbols causing inter-symbol interference (ISI). ISI may degrade the ability of a bit detector to differentiate a current symbol from the diffused energy of the adjacent symbols.
In some embodiments, a partial zero forcing algorithm may be employed to reduce inter-symbol interference (ISI) of a channel. For example, the partial zero forcing equalization algorithm, which does not force the ISI completely to zero, may utilize a fraction (or percentage) of the minimum eigenvalue of the data covariance matrix to equalize the received signal to reduce inter-symbol interference (ISI) as discussed in more detail below.
Referring to
Each of the channel 102, PZF equalizer 104, detector 106, adder 108 and partial zero forcing (PZF) adaptive algorithm 110 may be a separate circuit, part of a system on chip (SOC), firmware, a processor(s), or other system not listed, or any combination thereof.
The channel 102 may receive the signal 112 a(k) and output the noisy signal 114 x(k) which may be a combination of the signal 112 and a noise component added by the channel, such as inter-symbol interference (ISI). In some embodiments, the signal 112 and signal 114 may be bit sequences. More particularly, in some embodiments, a(k) may represent the channel input given as a binary non-return to zero (NRZ) sequence, (e.g., a(k) may take values such as −1 and +1 without returning to zero between symbols).
The PZF equalizer 104 may receive the noisy signal 114 x(k) which is to be equalized, for example, to reduce the noise component or inter-symbol interference (ISI). The PZF equalizer 104 may generate an equalized signal 116 y(k) based on the signal 114. In some embodiments, the samples of x(k) may be used to construct a vector having as many elements as the equalizer has taps. For example, for an equalizer having 2M+1 taps, x(k) may be used to construct a vector xk, represented as:
xk=(xk+M, xk+M−1, . . . , xk, . . . , xk−M+1, xk−M)T (1)
The detector 106 may operate to determine the bit value(s) 118 represented by the samples in the equalized signal 116.
The adder 108 may receive the equalized signal 116 and the signal 112 a(k). The adder 108 may combine the equalized signal 116 and the signal 112 to generate an error signal 120 e(k) which may represent the difference between the equalized signal 116 and the signal 112.
The partial zero forcing (PZF) adaptive algorithm 110 may receive the error signal 120, the noisy signal 114, a partial zero forcing fraction 122 (η), a step size 126 (μ) and the minimum eigenvalue 124 (λmin) of the data covariance matrix of the input signal. From the received signals and data, the partial zero forcing (PZF) adaptive algorithm 110 may generate the parameters 128 (f) of the PZF equalizer 104. For example, in an embodiment where the PZF equalizer is a finite impulse response (FIR) equalizer, the parameters 128 may be tap coefficients of the FIR.
The partial zero forcing (PZF) adaptive algorithm may overcome certain problems associated with zero-forcing equalization. For example, zero-forcing equalization for the equalizer taps may not be possible due to some rank deficiency of the associated linear system of equations.
The following discussion provides an example embodiment of the operations of system 100. The partial zero forcing (PZF) algorithm may deduct a fraction ηλminI from the covariance matrix Rx as follows:
where Rx=E(xkxkT), P is the cross correlation vector given by P=E(xkαk), η is a fraction of unity given by 0<η<1, and I is the identity matrix of compatible dimensions. Equation (2) is the result of minimizing:
By differentiating (3), equation (4) is obtained:
where ek=αk−fTxk is the error between the channel input or desired signal and equalized signal fTxk.
From equation (4), a least-mean-squares (LMS) update of the equalizer parameters or taps may be formulated as:
where μ is the LMS step size.
Equation (5) may take the form:
f(k)=(1+μηλmin)f(k−1)+μekxk (6)
Equation (6) may represent the partial-zero forcing (PZF) update algorithm of block 110 of
In some embodiments, the LMS adaptation parameters in equation (6) (e.g., μ, η and λmin) may be obtained through some ad-hoc testing, such as one based on a trial-and-error approach. On the other hand, in some embodiments, an adaptive approach may be employed to estimate or update the minimum eigenvalue λmin along with the equalizer parameters or taps. The minimum eigenvalue λmin can be expressed as:
where v is the eigenvector of Rx corresponding to the minimum eigenvalue λmin.
The minimum eigenvalue λmin may be found by minimizing equation (7) with respect to the eigenvector v. Since v may be normalized to unity without loss of generality, equation (7) can be rewritten as:
λmin(v)=minΣk(vTxk)2 subject to vTv=1 (8)
In equation (8), ergodicity may be assumed, where the ensemble average used in the computation of Rx has been replaced by a time average. The minimization of the instantaneous form of (8) gives:
where ρ=(vTxk)2 is the Lagrange multiplier.
The update of λmin may be performed using a gradient-based LMS algorithm such as:
where α=vTxk and μν is the LMS step size.
This may allow the update of λmin recursively as:
λmin(k)=λmin(k−1)+(α2−λmin(k−1))/k (11)
In particular, the minimum eigenvalue λmin can be estimated at each iteration using equation (11), which is then used to update the equalizer parameters for use in operations based on equation (6) as shown in equation (12) below:
f(k)=(1+μηλmin(k))f(k−1)+μekxk (12)
As such, equation (12) is a variant of the partial zero-forcing algorithm in which the minimum eigenvalue λmin(k) is updated systematically using equation (11).
Referring to
System 200 can include a channel 102 coupled to a PZF equalizer 104, the PZF equalizer 104 can be coupled to a detector 106 and an adder 108, the adder 108 coupled to a partial zero forcing (PZF) adaptive algorithm 110, the partial zero forcing (PZF) adaptive algorithm 110 can be coupled to the PZF equalizer 104 and a target 202 coupled to the adder 108. Generally, the operations of the channel 102, PZF equalizer 104, detector 106 and partial zero forcing (PZF) adaptive algorithm 110 with respect to signals 112, 114, 116, 118, 122 and 124 may be the same as in
Each of the channel 102, PZF equalizer 104, detector 106, adder 108, partial zero forcing (PZF) adaptive algorithm 110 and the target 202 may be a separate circuit, a system on chip (SOC), firmware, a processor(s), or other system not listed, or any combination thereof.
As illustrated, the target 202 generates a desired or target signal 204 d(k). For example, the target 202 may generate the desired signal 204 by passing the NRZ sequence a(k) 114 through a given target response gk of length Lg and with frequency response G(ω). In some embodiments, the desired signal may be given as:
The equations provided above with regard to
For example, the adder 108 may receive the equalized signal 116 and the desired signal 204. The adder 108 may combine the equalized signal 116 and the desired signal 204 to generate an error signal 206 e(k) which may represent the difference between the equalized signal 116 and the desired signal 204. As such, the error may be computed as:
ek=dk−fTxk (14)
In turn, the partial zero-forcing algorithm for partial response (PR) equalization may be given by equation (6) but with ek as defined by equation (14):
f(k)=(1+μηλmin)f(k−1)+μekxk (15)
or may be given by equation (12) with ek as defined by (14) and λmin(k) as updated using equation (11):
f(k)=(1+μηλmin(k))f(k−1)+μekxk (16)
Referring to
The system may receive a plurality of samples of an input signal, at 302. The system may then update the equalizer parameters based on the plurality of samples of the input signal and a fraction of the minimum eigenvalue of the covariance matrix of the input signal, at 304, for example, as discussed above with regard to
All steps listed for the method 300 may be applied to systems that have equalization of a signal. This and other variations would be apparent to one of ordinary skill in the art in view of this specification. Components and circuits used to perform the operations in the method may be discrete, integrated into a system on chip (SOC), or other circuits. Further, the steps can be carried out in a processor (e.g. a digital signal processor), implemented in software, implemented via firmware, or by other means.
Referring to
System 500 can include a multiple-input single output (MISO) partial zero forcing (PZF) equalizer 502 coupled to an adder 108, the adder 108 coupled to a MISO partial zero forcing (PZF) adaptive algorithm 518, and the MISO PZF adaptive algorithm 518 coupled to the MISO PZF equalizer 502. Each of the MISO PZF equalizer FIRs 502, the adder 108 and the MISO PZF adaptive algorithm 518 may be a separate circuit, a system on chip (SOC), firmware, a processor(s), or other system not listed, or any combination thereof.
As mentioned above, the system 500 may include a MISO PZF equalizer 502 that may receive an overall input signal xi(k) 508 that includes p input signals, x1(k) 508(1), x2(k) 508(2), . . . xp(k) 508(p). Each of the p input signals 508 may be provided to a corresponding filter Fi(ω) 504(1)-504(p). Each of the filters 504(1)-504(p) may output an equalized signal, y1(k) 510(1), y2(k) 510(2), . . . yp(k) 510(p) based on a respective input signal 508 and a set of equalizer parameters f1 512(1), f2 512(2), . . . fp 512(p). The equalized signals y1(k) 510(1)-yp(k) 510(p) may be summed by an adder 506 to generate an overall equalized signal y(k) 514 that may be sent to a detector for bit detection.
The adder 108 may receive the overall equalized signal y(k) 514 and a desired signal 516 d(k). The adder 108 may combine the equalized signal 116 and the signal 516 to generate an error signal 120 e(k) which may represent the difference between the equalized signal 116 and the desired signal 516.
The multiple input, single output (MISO) partial zero forcing (PZF) adaptive algorithm 518 may receive the error signal 120, the p input signals 508 xi(k), i=1,2, . . . , p, a partial zero forcing fraction 520 (β), a step size 126 (μ) and the minimum eigenvalue (λmin) 124 of the data covariance matrix of the input signal. From the received signals and data, the MISO PZF adaptive algorithm 518 may generate the overall parameter vector f 512 including the parameters f1 512(1), f2 512(2), . . . fp 512(p) of the filters 504 of the MISO PZF equalizer 502.
The following discussion provides an example embodiment of the operations of system 500, particularly the MISO PZF adaptive algorithm. The error signal 120 e(k) may be given by:
e(k)=d(k)−y(k)=d(k)−fTxk (17)
where
f=(f1T, f2T, . . . , fpT)T
In some embodiments, the desired signal 516 may be defined as:
where the gi's are the coefficients of the front-end target with length Lg, and the αk's are the NRZ bit sequence written on the track of interest.
Similarly, the overall parameter vector f 512 and the p input signals 508 (xi(k), i=1,2,. . . ,p) may be defined as:
f=(f1T, f2T, . . . , fpT)T
fi=(fi,0, fi,1, . . . , fi,M−1)T (19)
xk=[x1T(k), x2T(k), . . . , xpT(k)]T
xi(k)=[xi(k), xi(k−1), . . . , xi(k−M+1)]T (20)
for i=1, 2, . . . p, where M is the number of parameters (taps) associated with each filter 504 of the MISO PZF equalizer 502, and p is the number of MISO filters 504.
The MISO PZF equalizer 502 may be designed by minimizing the mean-square error criterion:
J(f2, f2, . . . , fp)=E(e2(k)) (21)
The minimization of (21) results in the Wiener solution of the form:
f=R−1P (22)
where
R=E[xkXkT]
P=E[xkd(k)] (23)
As such, the partial zero-forcing parameter vector of the MISO PZF equalizer 502 may be expressed as:
f=(R−βλminI)−1P (24)
where λmin is the minimum eigenvalue of R and β is a fraction of unity (0<β<1) indicating the fraction or fraction of λmin to be subtracted from the diagonal entries of R.
In some embodiments, the equalizer parameters f are estimated using an LMS-type PZF adaptive algorithm of the form:
f(k)=(1+μβλmin(k))f(k−1)+μekxk (25)
where μ is the step size. In turn, the individual MISO filter parameters may be adapted as
fi(k)=(1+μiβλmin)fi(k−1)+μiekxi(k) (26)
for i=1, 2, . . . p, where μi is the step size associated with the ith MISO filter 504(i).
The minimum eigenvalue λmin may be updated iteratively using:
λmin(k)=λmin(k−1)+(α2−λmin(k−1)/k (27)
At each iteration, a new value of λmin is used to update the equalizer parameters of the MISO filters 504 as:
fi(k)=(1+μiβλmin(k))fi(k−1)+μiekxi(k), i=1,2, . . . , p (28)
In some embodiments, equation (28) may represent the MISO PZF adaptive algorithm of block 518 of
Referring to
The DSD 616 can include a system processor 602, which may be a programmable controller, and associated memory 604. The system processor 602 may be part of a system on chip (SOC). A buffer 606 may temporarily store data during read and write operations and can include a command queue. The read/write (R/W) channel 610 can encode data during write operations to, and reconstruct data during read operations from, the data storage medium 608. The data storage medium 608 is shown and described as a hard disc drive, but may be other types of medium, such as a flash medium, optical medium, or other medium, or any combination thereof.
The R/W channel 610 may receive data from more than one data storage medium at a time, and in some embodiments can also receive multiple data signals concurrently, such as from more than one output of a read head. For example, storage systems having two-dimensional magnetic recording (TDMR) systems can have multiple reading or recording elements, and can read from two tracks simultaneously or nearly simultaneously. Multi-dimensional recording (MDR) systems can receive two or more inputs from multiple sources (e.g. recording heads, flash memory, optical memory, and so forth). The R/W channel 610 can combine multiple inputs and provide a single output, as described in examples herein.
The block 618 can implement all of or part of the systems and functionality of systems 100, 200 and 500. In some embodiments, the block 618 may be a separate circuit, integrated into the R/W channel 610, included in a system on chip, firmware, software, or any combination thereof.
The illustrations, examples, and embodiments described herein are intended to provide a general understanding of the structure of various embodiments. The illustrations are not intended to serve as a complete description of all of the elements and features of apparatus and systems that utilize the structures or methods described herein. Many other embodiments may be apparent to those of skill in the art upon reviewing the disclosure. Other embodiments may be utilized and derived from the disclosure, such that structural and logical substitutions and changes may be made without departing from the scope of the disclosure. For example, the figures and above description provide examples of architecture and voltages that may be varied, such as for design requirements of a system. Moreover, although specific embodiments have been illustrated and described herein, it should be appreciated that any subsequent arrangement designed to achieve the same or similar purpose may be substituted for the specific embodiments shown.
This disclosure is intended to cover any and all subsequent adaptations or variations of various embodiments. Combinations of the above examples, and other embodiments not specifically described herein, will be apparent to those of skill in the art upon reviewing the description. Additionally, the illustrations are merely representational and may not be drawn to scale. Certain proportions within the illustrations may be exaggerated, while other proportions may be reduced. Accordingly, the disclosure and the figures are to be regarded as illustrative and not restrictive.
Number | Name | Date | Kind |
---|---|---|---|
6381085 | Du | Apr 2002 | B1 |
20030043894 | Sestok, IV | Mar 2003 | A1 |
20040228397 | Bach | Nov 2004 | A1 |
Entry |
---|
Lee et al., “Partial Zero-Forcing Adaptive MMSE Receiver for DS-CDMA Uplink in Multicell Environments” IEEE Transactions on Vehicular Tech. vol. 51, No. 5, Sep. 2002. |