The present application relates generally to channel detection/error correction code decoding systems and, more specifically, to a system and method for decoding data with a symbol based error correction code, such as a Q'ary LDPC Code.
Several communications systems, including magnetic recording channels, experience inter-symbol-interference (ISI). In general, a channel detector is employed to recover ISI channel inputs. Usually, a maximum-a-posteriori (MAP) detector or soft output Viterbi algorithm (SOVA) is used as the channel detector. Both detectors compute soft information (likelihood information) which might be used by an outer error correction code.
In order to improve reliability of communication systems, conventional systems employ different error correction codes. Among these, a Low Density Parity Check (LDPC) code is an excellent error correction code (ECC). The LDPC codes can be applied to a variety of communication systems, including magnetic recording channels.
A system for decoding data is provided. The system includes a symbol based error correction code device. The system includes a channel detector configured to generate probability mass function (PMF) information. The system further includes a decoder coupled to the channel detector. The decoder is configured to use the extrinsic PMF information from the channel detector to perform an error correction code operation. The decoder also is configured to generate extrinsic PMF information for use in the channel detector. Optionally, one may use a symbol based interleaver between the channel detector and ECC decoder.
A magnetic drive apparatus for use in a data decoding system is provided. The magnetic drive apparatus includes a channel detector configured to recover inter-symbol-interference channel inputs and generate a first set of PMF information based on the channel outputs. The magnetic drive apparatus also includes an ECC decoder configured to perform a symbol-based error correction code operation. The detector further is configured to output the PMF information to the ECC decoder. The ECC decoder is configured to use the PMF information to perform an error correction code operation.
A method for decoding data is provided. The method includes receiving inter-symbol-interference channel outputs. A channel detector generates PMF information (symbol probabilities) based at least in part on the received channel outputs. The method also includes performing a symbol based error correction code operation using the PMF information from the channel detector; and generating full PMF information from the first PMF information for used in the channel detector.
Before undertaking the DETAILED DESCRIPTION OF THE INVENTION below, it may be advantageous to set forth definitions of certain words and phrases used throughout this patent document: the terms “include” and “comprise,” as well as derivatives thereof, mean inclusion without limitation; the term “or,” is inclusive, meaning and/or; the phrases “associated with” and “associated therewith,” as well as derivatives thereof, may mean to include, be included within, interconnect with, contain, be contained within, connect to or with, couple to or with, be communicable with, cooperate with, interleave, juxtapose, be proximate to, be bound to or with, have, have a property of, or the like; and the term “controller” means any device, system or part thereof that controls at least one operation, such a device may be implemented in hardware, firmware or software, or some combination of at least two of the same. It should be noted that the functionality associated with any particular controller may be centralized or distributed, whether locally or remotely. Definitions for certain words and phrases are provided throughout this patent document, those of ordinary skill in the art should understand that in many, if not most instances, such definitions apply to prior, as well as future uses of such defined words and phrases.
For a more complete understanding of the present disclosure and its advantages, reference is now made to the following description taken in conjunction with the accompanying drawings, in which like reference numerals represent like parts:
Properly designed symbol-based LDPC codes (Q'ary LDPC or “QLDPC” codes), can outperform a similar rate binary LDPC code over perpendicular magnetic channels at the expense of increased encoder and decoder complexity. Accordingly, symbol based ECCs can be utilized in multiple applications for several communications systems for their superior error correction capabilities. For example, the symbol based ECC can be included in a device that reads data from a magnetic communication medium.
The ECC device 100 includes a channel detector 105, such as a MAP or SOVA detector. The output of the channel detector 105 is input into a bit-based de-interleaver (inverse interleaver) 110. The bit-based de-interleaver 110 outputs log likelihood ratios (LLRs) to a soft decision decoder 115, such as an LDPC decoder. The output of the soft decision decoder 115 is input to a bit-based interleaver 130.
Soft decision decoders of bit based error correction codes require the LLRs from the channel detector 105. Similarly, soft decision decoders 220 (described in more detail herein below with respect to
PMF(xi)={Pr(xi=fj);fjεGF(q)}. [Eqn. 1].
Therefore, according to equation 1, for three-bit symbols, PMF(xi) is a 1×8 vector.
Traditional MAP and SOVA detectors compute the bit LLRs from which it is possible to extract the probabilities of each individual bit. When using a bit based interleaver 110 between the channel detector 105 and soft decision decoder 115 (such as an LDPC decoder), consecutive bits in the decoder domain will be independent. When bits forming a symbol are not correlated, the PMF entries can be computed according to Equation 2 by taking the product of the bit probabilities associated with the particular GF(q) symbol:
In Equation 2, fjk represents k'th bit of symbol fj. For example, assuming 2 bit symbols, the PMF for i=0:
Although computing the PMF by multiplying the bit probabilities is simple and trivial, it is not optimal and does not lead to very good performance. The problems are as follows:
Consecutive bit errors can result when the channel detector 115 fails. These consecutive errors are usually +−+ . . . error events. That is, for the input sequence of {010} the detector delivers {101}. These type or error events are also called “Nyquist” error events.
The existence of the error events also implies that the bit errors are correlated. Binary codes, however, are unable to take this error event information into account. Furthermore, the LDPC soft decision decoder 115 assumes that the bits participating in a parity check equation are not correlated, which can be achieved by using a combination of parity check matrix design and bit interleaving. Clearly, this approach destroys the error events information.
Conversely, symbol based codes can take into account the error event information in the decoding process. The logical way of using the error event information for symbol based decoding is to pass this information via the PMFs. That is, the symbol probabilities corresponding to error events should have higher probabilities. Assuming GF(8), for the case of a three-bit Nyquist error event, the PMF entries for ‘010’ and ‘101’ should have similar and high probabilities and the remaining PMF entries should have very low probabilities. Therefore, it is important that the method of computing the PMFs should reflect the error event information.
In some example, PMF is computed by multiplying individual bit probabilities. If the detector is not sure about a particular decision or the decision is erroneous, usually the magnitude of the LLR associated with that bit is very close zero, implying that the probabilities of the bit taking the value of ‘0’ or ‘1’ are almost the same. For example, assume the detector includes three consecutive bit errors (such as ‘010’ detected as ‘101’) and associated bit probabilities are {0.51, 0.51, 0.51}. In this example, if the PMF is computed by multiplication for GF(8), the eight PMF entries will be approximately ‘0.125’, implying that all eight GF(8) symbols are equally likely. Therefore, computing the PMFs by multiplying individual bit probabilities destroys the error event information.
As such, a first problem occurs when computing the PMFs from the channel detector in such a way that the error event information is preserved in the PMF. Furthermore, this computation should not increase the complexity of the channel detector and it should not require extensive changes in the existing systems.
The second problem occurs when an iterative detection/decoding system is adapted. For this case, the extrinsic information is exchanged between the detector and the decoder. The solution to the first problem addresses computing the extrinsic PMF information from the channel detector for use in the symbol based ECC decoder that also computes PMFs. Therefore, the second problem is how to use the extrinsic PMF information from the symbol based ECC decoder at the channel detector. The channel detector 105 (such as traditional MAP or SOVA channel detectors) accepts binary extrinsic LLR information. One trivial solution to this problem is to compute the LLR information from PMFs. This approach, however simple, does not deliver very good performance and limits the potential gains of turbo equalization.
The symbol-based iterative device 200 can be any symbol based device, such as a Q'ary iterative device. The symbol-based iterative device 200 includes a channel detector 205, such as a MAP or SOVA detector. In some embodiments, channel detector 205 computes LLRs. PMFs are computed from LLRs 210 and computed PMFs optionally interleaved through an inverse symbol interleaver 215 and then fed into the symbol based ECC decoder 220. The decoder computes PMFs and from the symbol interleaved PMFs 225, LLRs are computed 230 for use in the detector as extrinsic a-priori information. In the example illustrated in
In some embodiments, the PMF from the symbol-based ECC decoder 220 can be converted back into LLR format for used by the channel detector 205 in the next iteration by PMF-to-LLR conversion 230. In some embodiments, the PMF to LLR conversion block 230 is not included. The PMF to LLR conversion can be avoided if the decoder interleaved PMF entries are combined with branch metric computation at the channel detector 205.
The write path 300 includes a bit-to-symbol conversion block 305, user symbols de-interleaver block 310, an encoding block 315 (such as a QLDPC encoder), an encoded symbols interleaver block 320, and a symbol-to-bit conversion block 325 coupled to the channel 330.
Referring back to
Given an N state trellis, the probability of a bit conditioned to the received noisy message can be computed by summing the probability over all valid transitions associated with the transitions bit x:
If there is no transition between St−1 and St caused by transition bit x, then P(St−1,St,ut=x)=0. If St−1,tx is used to represent the set of all valid transitions between St−1 and St caused by transition bit x, the above equation can be simplified as Equation 6:
Using the notation illustrated in Equation 7:
y=(y1t−1,yt,yt+1m) y1t−1=(y1, . . . , yt−1) yt+1m=(yt+1, . . . , ym) [Eqn. 7];
the chain rule of probabilities; and the Markov property of the ISI channel, the join probability can be computed as in Equation 8:
In Equation 8, states St−1x and Stx represent the beginning and the end states of the transition caused by transition bit ut=x. Additionally, the values α, β and γ are defined by Equations 9A-9C:
αt−1(St−1x)=Pr(y1t−1,St−1x) [Eqn. 9A];
βt(Stx)=Pr(yt+11|Stx) [Eqn. 9B];
γtx(St−1x,Stx)=Pr(yt,Stx|St−1x) [Eqn. 9C].
Forward variable α and backward variable β can be computed recursively using the chain rule of probabilities and the Markov property of the ISI channel as in Equations 10A and 10B:
The well known branch metric γ can be computed assuming a Gaussian noise probability density function (pdf). Further, Equations 4, 6, 8 and 9A-9 can be re-written as Equation 11:
Equation 11 can be further simplified by observing that for a given state St−1x and input ut=x, only the state Stx=f(St−1x,x) can be reached in the trellis. Therefore, Equation 11 can be rewritten by removing the summation over Stx as Equation 12:
This also is a well known LLR expression of the BCJR (MAP) algorithm in probability domain.
The summation term in the numerator and the denominator of Equation 12, is given by Equation 13:
Tt−1,tx=αt−1(St−1x)·γt(St−1x,f(St−1x,x))·βt(Stx), for xε{0,1} [Eqn. 13].
Equation 13 represents the probability of moving from state St−1x to state Stx with transition bit x given the received noisy channel output sequence y. For this transition, the branch metric will be γt(St−1x,f(St−1x,0)). The transition from state St−1x to state Stx via transition bit x also represents a data pattern.
In the trellis 400, the transitions caused by ut=0 and ut=1 are represented by dashed and solid lines respectively. Furthermore, in the state representation, the right most bit is the most current bit. Some of the different data patterns associated with different transitions are:
Transition from 00 to 00→pattern (t−2,t−1,t)=000
Transition from 11 to 10→pattern (t−2,t−1,t)=110
Transition from 01 to 10→pattern (t−2,t−1,t)=010
It is noted that, if all transitions are considered, all possible 3 bit patterns result.
The trellis 400 is well suited for a full rate implementation, which only processes one trellis stage at a time. For a half rate implementation, two trellis stages are processed at the same time, resulting in four incoming paths for each destination state. This case is illustrated in the trellis diagram shown in
Each transition corresponds to two trellis stages. Therefore, four incoming paths exist for each destination state. For example, a transition occurs from state ‘11’ to state ‘00’ via state ‘10’ with transition bits ‘00.’ Similarly, the transition from state ‘00’ to state ‘11’ is via state ‘01’ with transition bits ‘11.’
Transition from 11 to 00 via 10→pattern (t−3,t−2,t−1,t)=1100 (transition bits=00)
Transition from 10 to 00 via 00→pattern (t−3,t−2,t−1,t)=1000 (transition bits=00)
Transition from 01 to 10 via 11→pattern (t−3,t−2,t−1,t)=0110 (transition bits=10)
Considering two stages at a time for half rate (½) implementation, the data patterns are four bits. Similarly, for a ⅓ rate implementation, the data patterns associated with three consecutive transitions will be five bits. For quarter rate (¼) implementation, the data patterns will be six bits. Formulating the previously mentioned relation as follows: For 2n state trellis with 1/k rate implementation, the length of the data patterns associated with the transitions will be (n+k) and the transitions cover all possible length (n+k) data patterns.
Since each transition in the trellis 600 represents a data pattern, the MAP detector 205 uses Equation 7 to compute the data pattern probability. Since a single stage of the trellis 600 is involved in creating the transition data pattern, the probability of the data pattern is formed by transitioning from St−1 to St with transition bit ut=x according to Equation 14:
Pr(St−1,St,ut=x)=αt−1(St−1)·γt(St−1,f(St−1,x))·βt(St), for xε{0,1} [Eqn. 14].
For 1/k rate implementation, since k trellis stages are involved, the probability of data pattern formed by making the transition from state St−k to St with k transition bits {ut−k+1, . . . ,ut} is given Equation 15:
At a given time instant t, the PMF entries for m bit symbols give the probabilities for all 2m possible binary combinations. Since the transitions correspond to data patterns, the data pattern probabilities can be used to compute the PMFs. For example, for a four state trellis full rate implementation (k=1), the PMFs for three bit symbols are computed as:
If the symbol size m is shorter, then the probabilities of all data patterns are added, with the last m bits being the same as the symbol under consideration: For example, for a four state trellis with half rate (k=½) implementation and three bit symbols, the PMFs are computed as follows:
From 1/k rate implementation of a 2n state trellis, the probability of a data pattern of length n+k (corresponding to a single trellis stage of a 1/k rate detector) can be computed starting from time t−n−k+1 ending at time t as follows:
If n+k=m, then for (t−1)/mth symbol's PMF entry of GF element f1 is according to Equation 18:
PMF(f1={g0,g1, . . . ,gm−1}t)=Pr({u0=g0,u1=g1, . . . , un+k−1=gn+k−1}t) [Eqn. 18].
If the symbol size m<n+k, the PMF can be computed by adding the probabilities of all data patterns with the last m bits the same as the symbol under consideration:
Table 1 shows a list of supported PMF symbol sizes and the frequency of PMF computation for different detector sizes and implementation rates.
1, 2, 3,
2, 4, 6,
3, 6, 9 . . .
4, 8, . . .
1, 2, 3,
2, 4, 6,
3, 6, 9 . . .
4, 8, . . .
4, 5 . . .
1, 2, 3,
2, 4, 6,
3, 6, 9 . . .
4, 8, . . .
4, 5 . . .
1, 2, 3,
2, 4, 6,
3, 6, 9 . . .
4, 8, . . .
4, 5, 6
Supported symbol sizes, denoted bold in Table 1, utilize a single trellis stage of the 1/k rate detector (corresponding to a data pattern of size n+k). For half, third, quarter and higher rate implementations of the detector, symbol sizes that are not multiples of k can be supported as well, provided that the intermediate branch values are stored for processing. That is, for a 1/k rate detector, the transition probabilities corresponding to each of the k transitions are stored. These values are then used to compute the intermediate forward and backward variables which are utilized for PMF computation.
Further, for a symbol size of m, the PMF shows the probabilities of m consecutive bits that make up the symbol. For example, assuming m=3, then PMF0 shows the joint probabilities of bits (0,1,2), PMF1 shows the joint probability of bits (3,4,5).
A one bit transition from one state to the next corresponds to data patterns of length (n+k)=(n+1).
“s” trellis stages of a 1/k rate 2n state detector correspond to a data pattern of (n+k.s) because each trellis stage corresponds to k transition bits and states are represented by n bits.
A 1/k rate 2n state detector stages include a granularity of k bits, that is, k bits per transition.
The different rate detectors for supported symbol sizes and PMF computation frequency are:
Full rate detector: For this case, the MAP detector 205 considers one transition at a time, that is, transitions from state St−1 to St with transition bit ut:
As a result, PMF computation is done at every m-th trellis stage. For instance, if m=2, then PMF0=Pr[u0u1] at t=2 which corresponds to two transition bits u0u1. Similarly, PMF1=Pr[u2u3] at t=4 which corresponds to two transition bits u2u3.
Half rate detector: for this case, the MAP detector 205 considers two transitions at a time, that is, transitions from state St−2 to St with transition bits ut−1 ut−2:
In this example, symbol sizes that are multiple of k are supported since the first trellis stage corresponds to transition bits {0,1}, second trellis stage corresponds to bits {2,3} and third trellis stage corresponds to bits {4,5} and i-th trellis stage corresponds to bits {2*i,2*i+1}. Accordingly, the trellis includes steps of two (2). Therefore, a half rate detector only supports symbol sizes that are multiple of two (2).
For example, let's consider m=8 for half rate eight state trellis. For this case, PMFk represents probability of the symbol made of bits {k−7, k−6, . . . , k}. Similarly, the next PMF represents probability of symbols made of bits {k+1, k+2, . . . k+8}. The data patterns for different number of trellis stages are as follows:
Single trellis stage data pattern is for five (5) bits {0,1,2,3,4}.
Two (2) trellis stages' data pattern is for seven (7) bits {0,1, . . . ,5,6}.
Three (3) trellis stages' data pattern is for nine (9) bits {0,1, . . . ,7,8}
To cover the required eight (8) bit symbol size, a three half rate trellis stages is utilized, which correspond to a data pattern size of 3+2*3=9 bits. Therefore, if first PMF is computed from the 3rd trellis stage, the next PMF computation will occur m/k=8/2=4 half rate stages later, that is, at 3+4=7th half rate trellis stage.
⅓ rate and ¼ rate detectors: for these cases, the same arguments given for half rate detector apply.
For a 2n state trellis with 1/k rate implementation, the results in Table 1 can be summarized as follows:
Supported symbol sizes: m=k.x for x=0, 1, . . .
PMF computation frequency: m/k
Any supported symbol size that is greater than n+k requires PMF computation involving more than one 1/k rate trellis stages. Therefore, the transition probabilities are stored for all required stages. Supported symbol sizes: m=k.x for m<n+k and x=0, 1, . . . (Shown bold in Table 1).
In some embodiments, the MAP detector 205 is implemented in the log domain. This transforms the multiplications of all probability terms into additions of the logarithms of the probabilities and the Equation 17 becomes:
As mentioned earlier, if the symbol size m is shorter than n+k, the PMF is computed by adding the probabilities of all data patterns with the last m bits being the same as the symbol under consideration (such as in Equation 19). For log domain implementation of Equation 19, a Jacobian approximation can be used for the summation of the probabilities:
log(p1+p2)=max(log(p1),log(p2)) [Eqn. 21].
This is the same approximation used for max-log-MAP process and this simplification does not cause significant performance degradation. If an exact answer is sought for the logarithm of the PMF given by Equation 19, then a correction term indexed by log(p1)-log(p2) is added to Equation 21, which can be costly to implement.
Following Jacobian approximation, Equation 17 becomes Equation 22:
In Equation 22, the maximization is done over all combinations of u0, . . . ,un+k−m−1. Since the symbol based ECC decoder 220 is usually implemented in log domain, log(PMFs) are used, which are computed using Equation 22.
In channel detector 105 (e.g., when a MAP detector), the extrinsic LLR information is used in the branch metric computation γtx(St−1x,Stx). The branch metric represents the probability of moving from state St−1x and to state Stx with transition bit x given the received noisy channel output sequence y. If a-priori information about transition bit x exists, this extrinsic information can be used in the branch metric computation as illustrated in Equation 23:
γtx(St−1x,Stx)=Pr(yt,Stx|St−1x)·Pr(ut=x) [Eqn. 23].
If there is no a-priori information about the transition bit, then the multiplication in Equation 23 is not necessary. For the case of turbo equalization, the channel detector 105 and ECC decoder 115 exchange soft information which leads to significant performance improvement. If the ECC 100 is bit based then the ECC decoder 115 computes LLRs, which are directly useable by the detector 105. However, for the case of symbol based ECC 200, the soft decoder 220 computes PMFs. LLRs can be computed from the PMFs, such as in the PMF-to-LLR conversion block 230. Thereafter, the LLRs can be used in the MAP detector 205. However, this approach can decrease the potential turbo equalization gains significantly.
In some embodiments, the MAP detector 205 is configured to utilize ePMF (e.g., extrinsic PMF). The MAP detector 205 can use the ePMF information from the symbol based ECC decoder 220 without computing the LLRs.
The forward and backward variable computations for use by the MAP detector 205 in order to utilize the ePMFs directly are as follows:
Forward variable in a conventional 1/k rate MAP detector is computed according to Equation 24:
For full rate implementation (k=1), Equation 16 simplifies to:
In Equations 24 or 25, the extrinsic LLR information is incorporated into transition probability computation shown in Equation 22. For the case of max-log-map, the multiplications in Equations 24 and 25 become additions and the summation is replaced by a max operation.
Furthermore, all paths leading to the destination state in forward variable computation share exact same transition bits. For 1/k rate implementation, the transitions are caused by k transition bits. For example, for a half rate four state trellis, as illustrated in
Additionally, since all transitions ending at a destination state have the same transition bits, in Equation 24, the forward variable can be computed without taking a-priori information into account in the γ (transition probability) computation. This binary a-priori information can be included to the computed forward variable as according to Equations 26 and 27:
Equation 26 computes the probability of the k-bit transition sequence. Since PMF represents m bit symbol probability, for k=m the PMF can be used in Equation 27 directly as illustrated in Equation 28:
For example, when the MAP detector 205 is a half rate (i.e., k=2), four state detector and the decoder 220 is a two bit symbol based ECC (i.e., m=2, GF(2)), the forward variable can be computed according to Equations 29A-29D:
For max-log-map algorithm, the multiplications in the above example become additions and the summation term before PMF multiplication is replaced by a max operation.
Therefore, for GF(2m) ECC code and a 1/k rate MAP detector 205, the extrinsic PMF from the ECC decoder 220 is easily used for the forward variable computation of the MAP detector 205
by simply multiplying the computed forward variable with a relevant PMF entry.
In Table 2, for different rate and state detectors, the supported PMF symbol sizes are shown. A 1/k rate MAP detector 205 covers symbol sizes that are multiples of k. The MAP detector 205 can multiply the computed forward variable with a relevant PMF entry.
For example, with a half rate eight state trellis and a symbol size of m=8, the PMFk represents probability of the symbol made of bits {k−7,k−6, . . . ,k}. Similarly the next PMF represents probability of symbols made of bits {k+1,k+2, . . . k+8}. Therefore, when computing the first PMF from the 3rd trellis stage, the next PMF computation will be performed (m/k)=(8/2)=4 half rate stages later, that is, at a 3+4=7th half rate trellis stage.
In another example, the MAP detector 205 is a quarter rate detector including only two bit symbols. Each trellis stage corresponds to four transition bits. The computed forward variable is multiplied with the probability of the four bit transition sequence. Since two bit symbols are included, the transition sequence probability is computed by multiplying two appropriate PMFs as illustrated in Equations 30A and 30B:
Pr(x0=1,x1=0,x2=1,x3=1)=PMF(1011)0 [Eqn. 30A].
Pr(x0=1,x1=0,x2=1,x3=1)=PMF(10)0·PMF(11)0 [Eqn. 30B].
For supported symbol sizes in Table 2 that are smaller than the number of transition bits per trellis stage (k), the transition bit sequence probability is computed by multiplying k/m appropriate PMF values.
1, 2, 3, 4,
1, 2, 4, 6,
1, 3, 6, . . .
1, 2, 4, 8,
1, 2, 3, 4,
1, 2, 4, 6,
1, 3, 6, . . .
1, 2, 4, 8,
1, 2, 3, 4,
1, 2, 4, 6,
1, 3, 6, . . .
1, 2, 4, 8,
5 . . .
1, 2, 3, 4,
1, 2, 4, 6,
1, 3, 6, . . .
1, 2, 4, 8,
5, 6 . . .
In Table 2, the supported symbol sizes, denoted bold, utilize single trellis stages of the MAP detector 205.
The MAP detector 205 also can perform backward variable computation with ePMF Information. The MAP detector 205 can compute the backward variable according to Equation 31:
For full rate implementation (k=1), Equation 31 simplifies to Equation 32:
In Equations 31 or 32, the extrinsic LLR information is incorporated into transition probability computation shown in Equation 23. For max-log-map detector, the multiplications in Equations 31 and 32 become additions and the summation is replaced by a max operation.
When the MAP detector 205 is configured to use ePMF information, the forward variable computation approach is not used for backward variable computation because all paths merging in the destination state for backward variable computation have different transition bits. For example in a ½ rate 4 state trellis, as illustrated in
The MAP detector 205 utilizes ePMF in backward variable computation by multiplying the transition probability of each path ending at a destination state with an appropriate PMF value. For symbol size of m and detector implementation rate of k, if m=k.x (x=1, 2, 3, . . . ), x trellis stages are evaluated at a time and the combined transition probability is multiplied with the appropriate PMF entry.
For example, assuming m=6, k=½ and n=3, with transition bits ‘011001’ cause a transition from a state ‘000’ to state ‘001’ via states ‘001’ and ‘110’ after 3 half rate transitions. For this transition sequence, one of the summation terms in Equation 31 (corresponding to one of the possible paths ending at state ‘000’) will be:
γt(000,001)01·γt+2(001,110)10·γt+4(110,001)01·βt+4(001).
Above, the superscripts denote the transition bits and each transition probability is also a multiplication of two full rate trellis stage probabilities as illustrated in Equation 33:
γt (000,001)01=γt(000,000)0·γt+1(000,001)1 [Eqn. 33].
In this example, the PMF is included into backward variable computation as follows:
γt(000,001)01·γt+2(001,110)10·γt+4(110,001)01·βt+4(001)·PMF(011001)t+4
This approach can be generalized according to Equation 34:
In one illustrative example, the MAP detector 205 is a 1/k rate 2n state detector for m bit symbols. The MAP detector 205 is configured to use the ePMF information in a backward variable computation, where m=k and n=m. For example, first the backward variables at time t+k are updated according to Equation 35:
βt+k(St+k=[x0x1 . . . xn−1])=βt+k(St+k=[x0x1 . . . xn−1])·PMFt+k([x0x1 . . . xk−1]) [Eqn. 35].
The backward variable is then computed according to Equation 31.
When the MAP detector 205 is a half rate (k=2) rate, four state detector and the soft decoder 215 is a two bit symbol based ECC (i.e., m=2, GF(4)), the backward variable is computed as according to Equations 36A-36D:
In this example, Equation 34 is repeated at every 1/k rate trellis stage, i.e., m/k frequency shown in the previous stages is valid for backward variable computation as well.
In some embodiments, the channel detector 205 is a SOVA detector (hereinafter referred to as SOVA detector 205). SOVA detector 205 can be used as the channel detector for ISI channels. SOVA detector 205 can perform the same processes as discussed for MAP detector 205 to generate PMF and use extrinsic PMF (ePMF).
In block 805, the channel detector 205 receives a stream of bits with inter-symbol-interference. The channel detector 205 commences an operation to recover the bits in block 810. The channel detector 205 generates extrinsic PMF information in block 815. This PMF information is input to the symbol-based decoder 220, such as a Q'ary LDPC. In block 820, the symbol-based decoder 215 performs an error correction code operation based on the extrinsic PMF information from the channel detector 205. The symbol-based decoder 220 generates and outputs full PMF information in block 825. The full PMF information is used to make hard decisions. Additionally, in block 830, the symbol-based decoder 220 generates extrinsic PMF information to be delivered to the channel detector 205 for the next iteration in a turbo equalization process. The extrinsic PMF information is generated by removing the extrinsic PMF information input to the symbol-based ECC decoder 220 from the full PMF computed by the symbol-based ECC decoder 220.
The symbol based ECC device 900 can include the same structure and functionality as the symbol-based iterative device 200, illustrated in
In some embodiments, a symbol based ECC device 900 can be included in a transceiver or receiver of a base station 905 and a transceiver or receiver mobile station 910. The base station 905 and mobile station 910 each transmit and receive communications via a wireless communication channel. For example, the base station 905 can include a transceiver 907 that includes symbol-based ECC device 900. The symbol-based ECC device 900 further includes write path 300 (not specifically illustrated) to encode communications for the mobile stations 910. The base station 905 transmits the encoded communications to the mobile station 910. The mobile station can include a receiver 912 coupled to an antenna 914. The receiver 912 can include the symbol based ECC device 900. The mobile station 910 can receive the communications from the base station 905 over the wireless communication channel 915. The symbol based ECC device 900 recovers the ISI symbols and performs symbol-based soft decision decoding.
Additionally, the symbol based ECC 900 can be included in a computer 920 that reads data from a magnetic communication medium 925. The computer 920 includes a magnetic drive apparatus 930. The magnetic drive apparatus 930 includes the symbol-based iterative device 900 and the write path 300. In some embodiments, the symbol-based iterative device 900 and the write path 300 are disposed in separate components (not illustrated) within the computer 920. The magnetic drive apparatus 930 is configured to read data from the magnetic communication medium 925. The magnetic drive apparatus 930 recovers the symbols and performs symbol-based soft decision decoding. In some embodiments, the magnetic drive apparatus 930 can write data to the magnetic communication medium 925.
In some embodiments, the communication medium 925 is an optical communication medium. In such embodiments, the computer 920 includes an ECC device 900 configured to recover symbols from an optic channel. Additionally, embodiments using different communication channels could be used without departing from the scope of this disclosure.
Although the present disclosure has been described with an exemplary embodiment, various changes and modifications may be suggested to one skilled in the art. It is intended that the present disclosure encompass such changes and modifications as fall within the scope of the appended claims.
The present application is related to U.S. Provisional Patent No. 61/245,996, filed Sep. 25, 2009, entitled “SYSTEM AND METHOD FOR MAP DETECTOR FOR Q'ARY LOW DENSITY CHECK PARITY CODES”. Provisional Patent No. 61/245,996 is assigned to the assignee of the present application and is hereby incorporated by reference into the present application as if fully set forth herein. The present application hereby claims priority under 35 U.S.C. §119(e) to U.S. Provisional Patent No. 61/245,996.
Number | Name | Date | Kind |
---|---|---|---|
7016440 | Singer et al. | Mar 2006 | B1 |
7020185 | Balachandran et al. | Mar 2006 | B1 |
7685494 | Varnica et al. | Mar 2010 | B1 |
7876860 | Varnica et al. | Jan 2011 | B1 |
20030161388 | Schilling | Aug 2003 | A1 |
20040225940 | Kerr et al. | Nov 2004 | A1 |
20040264555 | Hegde et al. | Dec 2004 | A1 |
20050180492 | Dent | Aug 2005 | A1 |
20070030926 | Brown et al. | Feb 2007 | A1 |
20070061666 | Nakai | Mar 2007 | A1 |
20070217626 | Sharma et al. | Sep 2007 | A1 |
20070274418 | Hegde et al. | Nov 2007 | A1 |
20080215831 | Argon et al. | Sep 2008 | A1 |
20090249165 | Gracie et al. | Oct 2009 | A1 |
20100098185 | Miyazaki | Apr 2010 | A1 |
20110131264 | Hars | Jun 2011 | A1 |
Number | Date | Country | |
---|---|---|---|
20110075287 A1 | Mar 2011 | US |
Number | Date | Country | |
---|---|---|---|
61245996 | Sep 2009 | US |