This invention relates to a method of converting a user bitstream into a coded bitstream by means of an overall channel code, to a recording device using said method of converting a user bitstream into a coded bitstream by means of an overall channel code and a playback device for decoding a user bit stream coded using the method of converting a user bitstream into a coded bitstream by means of an overall channel code.
In the literature of run length limited coding, the Repeated Maximum Transition Run, i.e. RMTR, constraint is often referred to as the MTR constraint. Originally, the maximum transition-run (MTR) constraint as introduced by J. Moon and B. Brickner, in “Maximum transition run codes for data storage systems”, IEEE Transactions on Magnetics, Vol. 32, No. 5, pp. 3992-3994, 1996, (for a d=0 case) specifies the maximum number of consecutive “1”-bits in the NRZ bitstream (where a “1” indicates a transition in the related bi-polar channel bitstream). Equivalently, in the (bi-polar) NRZI bitstream, the MTR constraint limits the number of successive 1T runs. As argued above, the MTR constraint can also be combined with a d-constraint, in which case the MTR constraint limits the number of consecutive minimum runlengths, as is the case for the 17PP code which is used in the Blu-Ray disc (BD) format. The basic idea behind the use of MTR codes is to eliminate the so-called dominant error patterns, that is, those patterns that would cause most of the errors in the partial response maximum likelihood (PRML) sequence detectors used for high density recording. A highly efficient rate 16→17 MTR code limiting the number of consecutive transitions to at most two for d=0 has been described by T. Nishiya, K. Tsukano, T. Hirai, T. Nara, S. Mita, in “Turbo-EEPRML: An EEPRML channel with an error correcting post-processor designed for 16/17 rate quasi MTR code”, Proceedings Globecom '98, Sydney, pp. 2706-2711, 1998. Another argument in favor of the RMTR constraint is to limit the back-tracking depth (or trace-back depth) of the Viterbi (PRML) bit-detector. The disclosure of U.S. Pat. No. 5,943,368 aims to encode data into a channel bitstream that prohibits the generation of single-frequency components (which can be a long repetition of (minimum) runlengths).
The RMTR constraint has recently regained some interest in the optical recording community. The ETM-code disclosed in K. Kayanuma, C. Noda and T. Iwanaga, “Eight to Twelve Modulation Code for High Density Optical Disk”, Technical Digest ISOM-2003, Nov. 3-7, 2003, Nara, Japan, paper We-F-45, pp. 160-161 has d=1, k=10 and r=5 constraints, this r constraint being just one lower than the RMTR of 17PP. For d=1 and RMTR r=2, the theoretical Shannon capacity amounts to:
C(d=1,k=∞,r=2)=0.679286. (1)
So, a code with rate better than ⅔ is still feasible. For an even more aggressive RMTR constraint r=1, the theoretical Shannon capacity amounts to:
C(d=1,k=∞,r=1)=0.650900. (2)
This shows that r=2 is the lowest RMTR constraint that is possible for a code rate not lower than that of the 17PP code.
Recently, in K. A. S. Schouhamer Immink, “Method and Apparatus for Coding Information, Method and Apparatus for Decoding Coded Information, Method of Fabricating a Recording Medium, the Recording Medium and Modulated Signal”, PCT Patent WO 02/41500 A1, International Filing Date 11 Nov. 2000, and in K. A. S. Immink, J.-Y. Kim, S.-W. Suh, S. K. Ahn, “Efficient dc-Free RLL Codes for Optical Recording”, IEEE Transactions on Communications, Vol. 51, No. 3, pp. 326-331, March 2003, some very efficient d=1 codes were disclosed with a code-rate that is very close to the Shannon capacity for d=1, given by C(d=1, k=∞, r=∞)=0.6942. As an example, a code with a rate of R= 9/13 has been realized, which has a code efficiency
such that 1−η=0.28%. However, these very efficient RLL codes suffer from the absence of an RMTR constraint (r=∞); therefore, the latter 9-to-13 d=1 code cannot yield the practical capacity benefit of 5% (through adapted PRML sequence detection) that is offered by d=1 codes with r=2.
The performance gain due to the RMTR constraint has been studied experimentally for high-density optical recording channels derived from the Blu-ray Disc (BD) system. Experiments have been performed using the increased-density BD rewritable system with the disc capacity increased from the standard 23.3-25-27 GB to 35 GB. PRML (Viterbi) bit detection has been employed.
Performance of the Viterbi bit detector has been measured based on the sequenced amplitude margin (SAM) analysis. In the relevant range of capacities around 35 GB, 1 dB gain in SAMSNR means almost 6% disc capacity increase.
Channel codes with different RMTR constraints have been compared to each other. In order to separate read-channel performance gain due to the imposed RMTR constraint from the corresponding write-channel gain, two different Viterbi bit detectors have been used: one which is aware of the RMTR constraint, and the other which is not. In the second case the performance gain can be attributed solely to the improved spectral content of the data written on the disc (such that it is better matched to the characteristics of the write channel used).
When the 17PP channel code with the RMTR constraint r=6 (as used in the BD system) is employed, SAMSNR of 11.66 dB is achieved for both RMTR-aware and RMTR-unaware bit detectors, i.e. no RMTR-related performance gain is observed in the read channel. When the channel code with r=2 is used, SAMSNR of 12.55 dB and 12.07 dB are achieved for the RMTR-aware and RMTR-unaware bit detectors correspondingly. As one can see, a total RMTR-related SAMSNR increase of about 0.9 dB is gained with respect to the case of r=6, which corresponds with about 5% disc capacity increase.
At very high densities for a d=1 constrained storage system well beyond the 25 GB of Blu-ray Disc (e.g. capacities on a 12 cm disc in the range of 33-37 GB), consecutive 2T runs are the Achilles' heel for the bit-detection. Such sequences of 2T runs bounded by larger runlengths at both sides, are called 2T-trains.
Currently, the 17PP code of Blue-Disk has a so-called RMTR constraint (Repeated Maximum Transition Runlength) of r=6, which means that the number of consecutive minimum runlengths is limited to 6 or, equivalently, the maximum length of the 2T-train is 12 channel bits. The 17PP code is based on the parity-preserve principle for DC-control.
It is a disadvantage of the presently known codes that these long trains consisting of consecutive 2T runs reduce the performance of the bit detector.
It is therefore the objective of the present invention to provide a code with particularly chosen constraints that improves the performance of the bit-detector.
Solution
This objective is achieved by the present invention by performing the following steps:
Using the same d=1 constraint as for 17PP a reduced RMTR constraint of r=2 allows a better performance of the bit detection. The bit-detection performance is improved considerably, which in turn enables a significant capacity increase (about 5%) compared to the 17PP coding which employs r=6. In addition, an extra capacity increase of 1.25% up to 1.4% can be realized through a much more efficient code construction, yielding a better code rate then the R=⅔ of the 17PP code.
To construct such a code the code is divided into a number of sub-codes that together form the overall code. The sub-codes are used in a sequential order and are cyclically repeated. Each sub-code is used to process a received mi-bit information word, converting the mi-bit information word into an ni-bit code word. This ensures the systematic coding of the information words into code words. To ensure that the d constraint together with the r constraint are complied with, the ni-bit code words are being divided into a number of Tmax different code-word types and are being arranged into Tmax coding classes of coding states such that, for a given sub-code, an ni-bit code word of type t (where t is an integer number between 1 and Tmax) can be concatenated with an ni+1-bit code word of the next sub-code if said subsequent code word of said next sub-code belongs to one of coding states of the coding class with index Tmax+1−t. The code word type thus defines which coding class is used to select a coding state from. By prescribing this selection of coding class, the encoding of the next information word into a code word using the next sub-code will be performed in such a way that the code word, when appended to the current code word will comply with the d constraint together with the r constraint.
In an embodiment of the method the code-word type is determined by a number of trailing bits of said code-word.
The trailing bits of the code word can be used to determine the code word type since the trailing bits of the code word have a substantial impact on the compliance with the d constraint and the r constraint of the concatenation of the code word with those trailing bits and the next code word which is concatenated to the trailing bits of the code word.
In a further embodiment of the method the code-word type is determined by all bits of said code-word, together with a number of bits of at least one preceding code-word.
When the size of the code words is relatively short compared to the number of bits affected by the r constraint a single code word may no longer have sufficient (trailing) bits to uniquely define a code word type. To solve this problem multiple code words may considered together as an ensemble and the trailing bits of this ensemble then define the code word type of the ensemble for the purpose of determining the coding class to be used for obtaining the next code word.
In a further embodiment of the method the concatenated N-bit code words satisfy a dkr-constraint, where d and k refer to, respectively, the minimum number and the maximum number of zero-bits between two consecutive one-bits in the coded bitstream, and where r indicates the maximum number of consecutive minimum runs of d zero-bits each preceded by a one-bit.
The introduction of the k constraint allows the improved adaptation of the code to the channel, for instance, for the purpose of control loops for the required adaptation in a receiver, like is needed for timing recovery.
In a further embodiment of the method the number of different code-word types and non-empty coding classes, wherein a non-empty coding class is defined to have at least one coding state, which number is denoted T, is not larger than Tmax=1+(d+1)×(r+1).
Limiting the number of non-empty coding classes to a value of T which is smaller or equal Tmax which is in turn defined by the d constraint and the r constraint by the formula Tmax=1+(d+1)×(r+1) allows the design of compact and efficient codes that satisfy the d and r constraint with a minimum amount of coding classes and coding states to reduce the complexity compared to the situation where the number of coding classes is equal to its maximum value Tmax.
In a further embodiment of the method the number of different code-word types and coding classes, denoted T, equals Tmax=1+(d+1)×(r+1).
In the case of a code without empty coding classes the equation for the optimum number of coding classes T is 1+(d+1)×(r+1) so that T equals Tmax.
In a further embodiment of the method with constraints d=1 and r=2, Tmax equals 7.
A code with constraints d=1 and r=2 according to the invention can be realized with a maximum of 7 coding classes, thus limiting the number of coding classes to limit the complexity of encoding and decoding.
In a further embodiment of the method T=Tmax=7 and the number of sub-codes S equals 6.
With the constraints d=1 and r=2, the maximum number of coding classes is 7 and a code using only 6 sub-codes can be constructed thus further limiting the complexity of the encoding and decoding.
In a further embodiment of the method five of the six sub-codes have a mapping with m=8 and n=12, and the sixth sub-code has a mapping with m=8 and n=11. Using at least one sub code with a mapping different from the mapping of the other five sub-codes allows the coding rate to be adjusted more closely to the channel capacity compared to the situation where all mappings for all sub-codes are identical.
The resulting overall code thus more closely approximates the channel capacity resulting in a more efficient use of the available channel capacity.
In a further embodiment of the method T=Tmax=7 and the number of sub-codes S equals 3.
It has been found that a code can be constructed having 7 coding classes using a set of three sub-codes only. This again allows the limitation of the complexity of the encoding and decoding.
In a further embodiment of the method two of the three sub-codes have m=9 and n=13, and the third sub-code has m=9 and n=14.
Using at least one sub code with a mapping different from the mapping of the other two sub-codes allows the coding rate to be adjusted more closely to the channel capacity compared to the situation where all mappings for all sub-codes are identical. The resulting overall code thus more closely approximates the channel capacity resulting in a more efficient use of the available channel capacity.
In a further embodiment of the method T=Tmax=7 and the number of sub-codes S equals 1.
It has been found that a code can be constructed having 7 coding classes using only one sub-code. This again allows the limitation of the complexity of the encoding and decoding.
In a further embodiment of the method the single sub-code has a mapping with m=4 and n=6.
A mapping with m=4 and n=6 constitutes a substantial reduction in complexity and allows a soft-decision decoding.
In a further embodiment of the method the single sub-code has a mapping with m=2 and n=3.
A mapping with m=2 and n=3 constitutes a substantial reduction in complexity and allows a soft-decision decoding.
In a further embodiment of the method, for each of the sub-codes, each of said T≦Tmax non-empty coding classes of coding states comprises p1, p2, . . . , pmax coding states, wherein the trivial empty coding classes are omitted, such that for the numbers representing the non-zero number of states of the non-empty coding classes p1≦p2≦ . . . ≦pmax, and with pmax giving the total number of coding states for said considered sub-code, and each of the pi coding states of a given considered class “i”, is also a coding state of all classes that have an index larger than “i”.
In a further embodiment of the method where d=1 and r=2, for each sub-code the trailing bits are specified for the different code word types by the following set of rules, that is,
the n-bit code words of the 1st type end with
“00”,
the n-bit code words of the 2nd type end with
“0010”,
the n-bit code words of the 3rd type end with
“001010”,
the n-bit code words of the 4th type end with
“00101010”,
the n-bit code words of the 5th type end with
“001”,
the n-bit code words of the 6th type end with
“00101”,
the n-bit code words of the 7th type end with
“0010101”,
and wherein the leading bits of the code words belonging to the different coding classes are determined by the following set of rules, that is,
the n-bit code words of a coding state of the 1st class start with
“00”,
the n-bit code words of a coding state of the 2nd class start with
“00” or “0100”,
the n-bit code words of a coding state of the 3rd class start with
“00”, “0100” or “010100”,
the n-bit code words of a coding state of the 4th class start with
“00”, “0100”, “010100” or “01010100”,
the n-bit code words of a coding state of the 5th class start with
“00”, “0100”, “010100”, “010101000” or “100”,
the n-bit code words of a coding state of the 6th class start with
“00”, “0100”, “010100”, “0101010100”, “100” or “10100”,
the n-bit code words of a coding state of the 7th class start with
“00”, “0100”, “010100”, “01010100”, “100”, “10100” or “1010100”.
A method for converting information words into code words using a code with the constraints d=1 and r=2, having 7 coding classes results in a set of code word types defined by the trailing bits of the code words and a set of coding classes comprising coding states defined by the leading bits of the code words produced by that coding state.
In a further embodiment of the method, with the above case of 6 sub codes and 8 bit input words, for the first sub-code the number of coding states for each of the T=7 classes of coding states amounts to p1=11, p2=15, p3=17, p4=17, p5=24, p6=27 and p7=28, and where for the second sub-code the number of coding states for each of the 7 classes of coding states amounts to p1=10, p2=14, p3=15, p4=16, p5=22, p6=25 and p7=26, and where for the third sub-code the number of coding states for each of the 7 classes of coding states amounts to p1=9, p2=13, p3=14, p4=14, p5=20, p6=23 and p7=24 and where for the fourth sub-code the number of coding states for each of the 7 classes of coding states amounts to p1=8, p2=11, p3=13, p4=13, p5=19, p6=21 and p7=22 and where for the fifth sub-code the number of coding states for each of the 7 classes of coding states amounts to p1=8, p2=11, p3=12, p4=12, p5=17, p6=19 and p7=20 and where for the sixth sub-code the number of coding states for each of the 7 classes of coding states amounts to p1=7, p2=10, p3=11, p4=12, p5=16, p6=18 and p7=19.
For a coding method using 6 sub-codes these are the amount of coding states per coding class per sub-code. The design has been chosen such that the maximum number of coding states considered over all sub codes is minimized.
Each sub-code comprises the same amount of coding classes but the coding classes comprise different number of coding states, dependent on the considered sub-code. As can be seen above the number of coding states for each coding class for each sub-code increases along with the number of the coding class for that sub-code.
In a further embodiment of the method, with the above case of a three sub codes and 9 bit input words, for the first sub-code the number of coding states for each of the T=7 classes of coding states amounts to p1=7, p2=10, p3=11, p4=11, p5=16, p6=18 and p7=19, and where for the second sub-code the number of coding states for each of the 7 classes of coding states amounts to p1=8, p2=12, p3=13, p4=13, p5=19, p6=21 and p7=22, and where for the third sub-code the number of coding states for each of the 7 classes of coding states amounts to p1=10, p2=14, p3=15, p4=16, p5=22, p6=25 and p7=26.
For a coding method using 3 sub-codes these are the amount of coding states per coding class per sub-code.
In a further embodiment of the method, with the above case of a single sub code and 4 bit input words, the number of coding states for each of the T=7 classes of coding states amounts to p1=3, p2=4, p3=5, p4=5, p5=7, p6=8 and p7=8. For a coding method using a single sub-code these are the amount of coding states per coding class. The design has been chosen such that the maximum number of coding states considered over all sub codes is minimized.
In a further embodiment of the method a finite k-constraint is realized through an extra coding state. Introducing an extra coding state allows the method to select the new coding state to start the encoding of the next information word from in case that the all-zero code word is emitted from that state where in the code without extra state, a next all-zero code-word would be emitted. The Finite State Machine can then be designed using the extra coding state to ensure that the finite k-constraint is automatically met.
In a further embodiment of the method with the above case of a single sub-code and 2-bit input words, the number of non-trivial coding classes T equals 6, with coding class number 4 being the empty one, yielding p4=0, and where the number of coding states for each of the 6 non-trivial coding classes of coding states amounts to p1=2, p2=2, p3=3, p5=4, p6=5 and p7=5.
This is an implementation of a coding method comprising a coding class that comprises no coding states, i.e. an empty coding class. Choosing this set of coding classes with the indicated number of coding states allows an efficient code with a 2-to-3 mapping to be constructed. The 2-to-3 mapping allows an efficient implementation of a soft decision detection since it reduces the complexity in terms of the number of branches that leaves from each state of the Finite State Machine, which number equals 2m.
In a further embodiment of the method the parity-preserve property is realized through a number of extra coding states.
Extra coding states in the coding classes provides a new, extra, coding state which can be used whenever the parity preserve property is violated in a current state, so that overall a parity preserving code is obtained.
In a further embodiment of the method a finite k-constraint is realized through an extra coding shell on top of the basic 2-to-3 mapping of the code.
In a further embodiment of the method with constraints d=2 and r=2, Tmax equals 10.
With 10 coding classes a method for converting information words into code words that complies with the constraints d=2 and r=2 can be constructed.
In a further embodiment of the method the number of coding classes T equals the maximum number of coding classes Tmax which equals 10 and the number of sub-codes S equals 4.
In a further embodiment of the method three of the four sub-codes have a mapping with m=8 and n=15, and the fourth sub-code has a mapping with m=8 and n=14. This allows a close approximation of the channel capacity
In a further embodiment of the method where d=2 and r=2 for each sub-code the trailing bits are specified for the different code word types by the following set of rules, that is,
the n-bit code words of the 1st type end with
“000”,
the n-bit code words of the 2nd type end with
“000100”,
the n-bit code words of the 3rd type end with
“000100100”,
the n-bit code words of the 4th type end with
“000100100100”,
the n-bit code words of the 5th type end with
“00010”,
the n-bit code words of the 6th type end with
“00010010”,
the n-bit code words of the 7th type end with
“00010010010”,
the n-bit code words of the 8th type end with
“0001”,
the n-bit code words of the 9th type end with
“0001001”,
the n-bit code words of the 10th type end with
“0001001001”,
and wherein the leading bits of the code words belonging to the different coding classes are determined by the following set of rules, that is,
the n-bit code words of a coding state of the 1st class start with
“000”,
the n-bit code words of a coding state of the 2nd class start with
“000” or “001000”,
the n-bit code words of a coding state of the 3rd class start with
“000”, “001000” or “001001000”,
the n-bit code words of a coding state of the 4th class start with
“000”, “001000”, “001001000” or “001001001000”,
the n-bit code words of a coding state of the 5th class start with
“000”, “001000”, “001001000”, “001001001000” or “01000”,
the n-bit code words of a coding state of the 6th class start with “000”, “001000”, “001001000”, “001001001000”, “01000” or “01001000”,
the n-bit code words of a coding state of the 7th class start with “000”, “001000”, “001001000”, “001001001000”, “01000”, “01001000” or “01001001000”,
the n-bit code words of a coding state of the 8th class start with “000”, “001000”, “001001000”, “001001001000”, “01000”, “01001000”, “01001001000” or “1000”,
the n-bit code words of a coding state of the 9th class start with “000”, “001000”, “001001000”, “001001001000”, “01000”, “01001000”, “01001001000”, “1000” or “1001000”,
the n-bit code words of a coding state of the 10th class start with “000”, “001000”, “001001000”, “001001001000”, “01000”, “01001000”, “01001001000”, “1000”, “1001000” or “1001001000”.
In a further embodiment of the method with the above case for four sub-codes and 8 bit input words, for the first sub-code the number of coding states for each of the T=10 classes of coding states amounts to p1=8, p2=11, p3=12, p4=12, p5=16, p6=17, p7=18, p8=24, p9=26 and p10=26, and where for the second sub-code the number of coding states for each of the 10 classes of coding states amounts to p1=7, p2=10, p3=11, p4=11, p5=15, p6=16, p7=16, p8=21, p9=23 and p10=24, and where for the third sub-code the number of coding states for each of the 10 classes of coding states amounts to p1=7, p2=9, p3=10, p4=10, p5=13, p6=14, p7=15, p8=19, p9=21 and p10=22, and where for the fourth sub-code the number of coding states for each of the 10 classes of coding states amounts to p1=6, p2=8, p3=9, p4=9, p5=12, p6=13, p7=13, p8=18, p9=19 and p10=20.
For a coding method using 4 sub-codes these are the amount of coding states per coding class per sub-code. The design has been chosen such that the maximum number of coding states considered over all sub codes is minimized.
Each sub-code comprises the same amount of coding classes but the coding classes comprise different number of coding states, dependent on the considered sub-code. As can be seen above the number of coding states for each coding class for each sub-code increases along with the number of the coding class for that sub-code.
The invention will now be described based on figures and tables.
A d=1 r=2 code for nine bit information words
As has been discussed above, the Shannon capacity of the combined RLL constraints d=1 and r=2 amounts to C(d=1,k=∞,r=2)=0.679286. A code with mapping of user bits onto channel bits of 27-to-40 may be possible to construct, since it has a rate R=0.675≦C(d=1,k=∞,r=2): the efficiency of this new code η=R/C(d=1,k=∞,r=2) is such that only the small fraction 1−η=0.63% is lost compared to the theoretical upper limit. Obviously, code books with 27-bit entries are much too large to be of any practical use. In order to circumvent this problem, a solution is proposed that follows the lines of the algorithm presented in J. J. Ashley and B. H. Marcus, “Time-Varying Encoders for Constrained Systems: an Approach to Limiting Error Propagation”, IEEE Transactions on Information Theory, Vol. 46, No. 3, pp. 1038-1043, May 2000. The latter approach generalizes the well known state-splitting algorithm or ACH-algorithm as disclosed by R. L. Adler, D. Coppersmith, and M. Hassner, “Algorithms for Sliding Block Codes. An Application of Symbolic Dynamics to Information Theory”, IEEE Transaction on Information Theory, Vol. IT-29, 1983, pp. 5-22, used for the construction of efficient sliding block codes, for a concatenation of a number of codes at multiple phases, where the encoding and decoding proceeds cyclically from one phase to the next. Practically, for the new code with rate R= 27/40, the overall code can be realized as a cyclic concatenation of three sub-codes, denoted C1, C2 and C3, with respective mappings 9-to-13, 9-to-13 and 9-to-14. Such a repetition is shown in
In the general case, the overall code is realized by a number of S sub-codes. The generalized ACH-algorithm looks for a set of S approximate eigenvectors, one for each sub-code, with νik denoting the i-th coefficient of the approximate eigenvector for the k-th sub-code, that satisfies the set of inequalities, for all states i of the corresponding state-transition diagram (STD) that describes the RLL constraints, and for all sub-codes k (with a mapping mk-to-nk for the k-th sub-code):
ΣjDi,jm
Note that when k=S, the next sub-code with index k+1 due to the cyclic repeat-period of the sub-codes is the one with index equal to 1. In the above equation, D represent the so-called adjacency-matrix or connection-matrix for the STD: its matrix elements are equal to one if the corresponding two STD-states are connected in the graph, and are equal to zero if they are not connected. For the new code with RLL constraints d=1 and r=2, the three sub-codes have the parameters m1=m2=m3=9, and n1=13, n2=13 and n3=14. (Note that any scrambled order of these three mappings is also a valid order for the further code-construction, and falls within the scope of the current invention.) The cyclic repetition of the three sub-codes (denoted C1, C2 and C3) is shown schematically in
Σj=17Di,j13νj2≧29νi1, i=1,2, . . . ,7, (4)
Σj=i7Di,j13νj3≧29νi2, i=1,2, . . . ,7, (5)
and
Σj=17Di,j14νj1≧29νi3, i=1,2, . . . ,7. (6)
For the RLL constraints d=1 and r=2, the STD is shown in
7
6
5
4
3
2
1
From Table 1, it is clear that the following hierarchy in fan-out applies (with STD-state σ3 having the largest fan-out):
Fσ
The new RLL code is constructed on the basis of a plurality of coding states, one set of coding states for each sub-code. According to the present invention, these coding states are arranged into seven classes as follows:
the n-bit code words of the 1st class of coding states belong to Fσ
the n-bit code words of the 2nd class of coding states belong to Fσ
the n-bit code words of the 3rd class of coding states belong to Fσ
the n-bit code words of the 4th class of coding states belong to Fσ
the n-bit code words of the 5th class of coding states belong to Fσ
the n-bit code words of the 6th class of coding states belong to Fσ
the n-bit code words of the 7th class of coding states belong to Fσ
Due to this specific ordering of the coding classes according to the present invention, a coding state of a coding class i is also a coding state of all coding classes with index j not smaller than i, that is, j≧i. It is thus convenient to order the possible patterns of leading bits of code words as follows:
In addition, it is for the code-construction according to the present invention beneficial to consider the following ordering of the trailing bit patterns (with the arrival state of the STD also indicated, both the original one and the renumbered one) as outlined in Table 3. According to the present invention, code words can be divided into 7 different types as specified by their trailing bit pattern
1
2
3
4
5
6
7
It should be noted that the ordered trailing bit patterns (of Table 3) are the mirrored versions of the corresponding ordered leading bit patterns (of Table 2). Next, the already mentioned renumbering of the STD-states is discussed. It is now convenient to renumber the states of the STD in terms of the ordering of the trailing bit-patterns as they were listed in Table 3. This new numbering is outlined in the last two columns of Table 3. The new renumbered states are denoted {grave over (σ)}i. With this new numbering, code words of type i will arrive in the (renumbered) STD-state with the same index, that is, {grave over (σ)}i; consequently, code words of type i can be concatenated with any code word that belongs to a coding state of class 8−i as a subsequent code word. It is to be noted that code words belonging to a coding state of class 8−i have leading bit patterns (from Table 2) with index l where 1≦l≦8−i. As an example, code words of type 3 (end with trailing bit pattern . . . 001010|) can be concatenated with code words from coding states of class 5, which implies that the latter code words may start with the leading bit patterns (Table 2) i=1, i=2, . . . , i=5. This division of code words into 7 different types of code words, and the arrangement of coding states into 7 different coding classes, forms the basis for the further code construction: in this way, the RLL constraints d=1 and r=2 always remain satisfied (also upon concatenation of code words of cyclically consecutive sub-codes). From Table 3, it is clear that the following hierarchy in fan-out applies for the renumbered STD-states:
F{grave over (σ)}
The renumbered STD-state {grave over (σ)}1 has the largest fan-out of all, and {grave over (σ)}7 the smallest one, with an enumerative ranking according to the decreasing fan-out from {grave over (σ)}1 to {grave over (σ)}7. With the renumbered STD-states, and a correspondingly rearranged connection matrix, denoted {grave over (D)}, the approximate eigenvector inequalities (for the “new” eigenvectors {tilde over (ν)}) are rewritten as:
Σj=17{grave over (D)}l,j13{tilde over (ν)}j2≧29{tilde over (ν)}l1, l=1,2, . . . ,7, (9)
Σj=17{grave over (D)}l,j13{tilde over (ν)}j3≧29{tilde over (ν)}l2, l=1,2, . . . ,7, (10)
and
Σj=17{grave over (D)}l,j14{tilde over (ν)}j1≧29{tilde over (ν)}l3, l=1,2, . . . ,7. (11)
The leading bit patterns and trailing bit patterns of possible code words have been identified in Tables 2 and 3. The number of code words of length n that start with the leading bit pattern i and that end with the trailing bit pattern j is denoted Wi,j[n]. After close inspection, it turns out that:
{grave over (D)}l,jn=Σi=18−lWi,j[n]. (12)
With this knowledge, the approximate eigenvector inequalities can be rewritten into the form:
Σi=1lΣj=17Wi,j[13]{tilde over (ν)}j2≧29{tilde over (ν)}8−l1, l=1,2, . . . ,7, (13)
Σi=1lΣj=17Wi,j[13]{tilde over (ν)}j3≧29{tilde over (ν)}8−l2, l=1,2, . . . ,7, (14)
and
Σi=1lΣj=17Wi,j[14]{tilde over (ν)}j1≧29{tilde over (ν)}8−l3, l=1,2, . . . ,7. (15)
The number of coding states per coding class is denoted by the vector ps for the s-th sub-code (s=1,2,3). Its relation to the approximate eigenvector {tilde over (v)}s is given by (for the i-th component, with 1≦i≦7):
pis={tilde over (ν)}8−is. (16)
Note that with this advantageous construction, the coding classes have a numbering system that is exactly complementary to the numbering system of the renumbered STD-states; this could already have been obvious from Table 1, where the renumbering of STD-states was mentioned, but not explained. Further, again due to the specific construction of the different coding classes, the following inequality holds (for each of the sub-codes s with s=1,2,3):
p1s≦p2s≦p3s . . . ≦p7s. (17)
An example Code-Design: a code with k=∞
First, the case without k-constraint (k=∞) is considered. The number of code words with specific leading bit pattern (i) and trailing bit pattern (j), denoted Wi,j[n], for length n=13 and n=14 are given by:
An example Code-Design: a code with a k-constraint
In order to generate a k-constraint without making use of an adapted STD with the k-constraint explicitly included, it is advantageous to limit the number of leading and trailing zeroes in the code words. The maximum number of leading zeroes in a code word is denoted l0; the maximum number of trailing zeroes is denoted r0. The number of code words with specific leading bit pattern i and trailing bit pattern j, with the additional constraint on l0 and r0, is denoted Wi,jl
Wi,j[n]≡Wi,j∞,∞. (20)
The additional constraint k=18 is realized with the choice l0=r0=9. The matrices W9,9[n] for code word length n=13 and n=14, are given by:
A practical set of approximate eigenvectors of the rewritten approximate eigenvector inequalities is given by:
{tilde over (v)}1={19,18,16,11,11,10,7}, (23)
{tilde over (v)}2={22,21,19,13,13,12,8}, (24)
{tilde over (v)}3={26,25,22,16,15,14,10}. (25)
The first sub-code, denoted C1, with 9-to-13 mapping, has a total of 19 coding states; the second sub-code, denoted C2, also with 9-to-13 mapping, has a total of 22 coding states; and the third sub-code, denoted C3, with 9-to-14 mapping, has a total of 26 coding states. The distribution of the total number of coding states (for each sub-code) over the 7 different coding classes is governed by the approximate eigenvector (for the given sub-code), as indicated by Eq. (16).
The Construction of Code Tables for a code with k=18 The code-tables are further constructed in such a way that a code word (with all its possible next-states) can appear only in one particular coding state. For the decoding operation, this means that the next code word uniquely specifies the “next-state” function of a current code word.
Encoding
For encoding of a 9-bit user word, one needs to know:
(1) the sub-code Ci with which the current user word has to be encoded; and:
(2) the state j of the sub-code Ci, denoted Ci-Sj and the corresponding code table that is to be used for the encoding.
In the process of encoding, the encoder generates as output:
(1) the code word according to the code table that is to be used; and:
(2) the next sub-code that is to be used for the encoding of the next 9-bit user word, which is simply Ci+1 (which, for i=3, equals C1 due to the cyclic repetition of the three sub-codes); and:
(3) the next state of the next sub-code Ci+1 according to the code table that is to be used upon encoding for the current user word, where this next state will specify which code table is to be used for the encoding of the next 9-bit user word with the next sub-code Ci+1.
Decoding
The process of decoding is described on the basis of
The process of decoding is further explained as follows. At the input of the decoder, there are two code words, code word Wi encoded with sub-code Cp, and code word Wi+1 encoded with the next sub-code Cp+1. For both code words, and independent on the sub-code that applies to each of the code words Wi and Wi+1, an index can be derived (e.g. based on enumerative decoding for a d=1 RLL constraint: the index ranges from 0 to 609 for a code word of 13 channel bits, and from 0 to 986 for a code word of 14 channel bits). The respective indices are denoted Ii and Ii+1 for the current and next code words. Next, the index Ii+1 is converted into a “next-state” of the current code word Wi by means of a special conversion table (with is dependent on the sub-code that applies to the considered word Wi+1): this table maps each (index of a) code word onto the state to which it belongs for the considered sub-code (which is here Cp+1). This “next-state” is denoted NSi. The combination of the index of the current code word Wi, that is Ii, in combination with its decoded next-state NSi are the input of a special decoding table for the given sub-code Cp, which yields the decoded (9-bit) user word.
DC-control through the use of guided scrambling
All RLL codes used in optical recording (EFM, EFMPlus and 17PP) are DC-free, that is, they have almost no content at low frequencies. This property is an example of a frequency domain constraint. Here, restrictions are enforced on the energy content per time unit of the sequence at certain frequencies, that is, on the power spectral density function of the sequence. (Constraints like runlength constraints are called time-domain constraints.) Most of these constraints belong to the family of spectral null constraints, where the power density function of the sequence must have a zero of a certain order at certain specific frequencies. The constraint that specifies a zero at DC, the zero frequency, is referred to as the DC-free constraint. The NRZI channel bits shall be represented by the bipolar values ±1. A sequence x1,x2, . . . is called DC-free if its running digital sum (RDS)
RDSi=x1+ . . . +xi
takes on only finitely many different values. In that case, the power spectral density function vanishes at DC.
The DC-free property is needed in optical recording for a number of reasons. Firstly, it is necessary to separate the data signal from low-frequency disc noise such as fingerprints, dust or defects. Secondly, DC-free coding is needed for control of the slicer level in the case of non-linearities in the physical signals like pit-land asymmetries as disclosed by A. F. Stikvoort and J. A. C. van Rens, in “An all-digital bit detector for compact disc players”, IEEE J. Sel. Areas Commun., 10, 1: 191-200, 1992. And thirdly, servo systems used for tracking of the laser spot position typically require a DC-free data signal.
Guided Scrambling
Guided Scrambling (GS) can be used for realizing DC-control as is described by K. A. S. Immink, in “Codes for Mass Data Storage Systems”, The Netherlands: Shannon Foundation Publishers, 1999. Guided Scrambling works as follows. A number Nscr of input words 41a, 41b, 41c, 41d, 41i forms a so-called scrambling block 40. The very first s bits of a scrambling block are scrambling bits, which can be chosen freely. Each of these 2s options generate RLL encoded scrambling blocks after the following two operations: firstly, the input bits are passed through a scrambler that is implemented as a linear shift back register, based on a scrambler polynomial; secondly, the scrambled input bits are encoded with the new RLL code (with its three sub-codes) into an RLL channel bitstream. For each of the 2s options, the DC-content is evaluated, e.g. in terms of the variance of the running digital sum, also known as the “sum variance”. The option with the “best” DC-suppression properties is then selected.
Distribution of 9-bit ECC Symbols
A d=1 r=2 code for eight bit information words
As has been discussed above, the Shannon capacity of the combined RLL constraints d=1 and r=2 amounts to C(d=1,k=∞,r=2)=0.679286. A code with mapping of user bits onto channel bits of 48-to-71 may be possible to construct, since it has a rate R=0.676056≦C(d=1,k=∞,r=2): the efficiency of this new code η=R/C(d=1,k=∞,r=2) is such that only the small fraction 1−η=0.48% is lost compared to the theoretical upper limit. Obviously, code books with 48-bit entries are much too large to be of any practical use. In order to circumvent this problem, a solution is proposed that follows the lines of the algorithm disclosed by J. J. Ashley and B. H. Marcus, in “Time-Varying Encoders for Constrained Systems: an Approach to Limiting Error Propagation”, IEEE Transactions on Information Theory, Vol. 46, No. 3, pp. 1038-1043, May 2000. The latter approach generalizes the well known state-splitting algorithm or ACH-algorithm as disclosed by R. L. Adler, D. Coppersmith, and M. Hassner, in Algorithms for Sliding Block Codes. An Application of Symbolic Dynamics to Information Theory”, IEEE Transaction on Information Theory, Vol. IT-29, 1983, pp. 5-22 used for the construction of efficient sliding block codes for a concatenation of a number of codes at multiple phases, where the encoding and decoding proceeds cyclically from one phase to the next. Practically, for the new code with rate R= 48/71, the overall code can be realized as a cyclic concatenation of six sub-codes, denoted C1, C2, C3, C4, C5 and C6, with respective mappings 8-to-12, 8-to-12, 8-to-12, 8-to-12, 8-to-12 and 8-to-11.
In the general case, the overall code is realized by a number of S sub-codes. The generalized ACH-algorithm looks for a set of S approximate eigenvectors, one for each sub-code, with νik denoting the i-th coefficient of the approximate eigenvector for the k-th sub-code, that satisfies the set of inequalities, for all states i of the corresponding state-transition diagram (STD) that describes the RLL constraints, and for all sub-codes k (with a mapping mk-to-nk for the k-th sub-code):
ΣjDi,jmνjk+1≧2n
Note that when k=S, the next sub-code with index k+1 due to the cyclic repeat-period of the sub-codes is the one with index equal to 1. In the above equation, D represent the so-called adjacency-matrix or connection-matrix for the STD: its matrix elements are equal to one if the corresponding two STD-states are connected in the graph, and are equal to zero if they are not connected. For the new code with RLL constraints d=1 and r=2, the six sub-codes have the parameters m1=m2=m3=m4=m5=m6=8, and n1=n2=n3=n4=n5=12 and n6=11. (Note that any scrambled order of these six mappings is also a valid order for the further code-construction, and falls within the scope of the current invention.) The cyclic repetition of the six sub-codes C1, C2, C3, C4, C5 C6 where each sub-code C1, C2, C3, C4, C5, C6 converts an 8 bit user word 51a, 51b, 51c, 51d, 51e, 51f into channel word 52a, 52b, 52c, 52d, 52e, 52f as is shown schematically in
Σj=17Di,j12νj2≧28νi1, i=1,2, . . . ,7, (27)
Σj=17Di,j12νj3≧28νi2, i=1,2, . . . ,7, (28)
Σj=17Di,j12νj4≧28νi3, i=1,2, . . . ,7, (29)
Σj=17Di,j12νj5≧28νi4, i=1,2, . . . ,7, (30)
Σj=17Di,j12νj6≧28νi5, i=1,2, . . . ,7, (31)
and
Σj=17Di,j11νj1≧28νi6, i=1,2, . . . ,7. (32)
With the renumbered STD-states, and a correspondingly rearranged connection matrix, denoted {grave over (D)}, the approximate eigenvector inequalities (for the “new” eigenvectors {tilde over (ν)}) are rewritten as:
Σj=17{grave over (D)}l,j12{tilde over (ν)}j2≧28{tilde over (ν)}l1, l=1,2, . . . ,7, (33)
Σj=17{grave over (D)}l,j12{tilde over (ν)}j3≧28{tilde over (ν)}l2, l=1,2, . . . ,7, (34)
Σj=17{grave over (D)}l,j12{tilde over (ν)}j4≧28{tilde over (ν)}l3, l=1,2, . . . ,7, (35)
Σj=17{grave over (D)}l,j12{tilde over (ν)}j5≧28{tilde over (ν)}l4, l=1,2, . . . ,7, (36)
Σj=17{grave over (D)}l,j12{tilde over (ν)}j6≧28{tilde over (ν)}l5, l=1,2, . . . ,7, (37)
and
Σj=17{grave over (D)}l,j11{tilde over (ν)}j1≧28{tilde over (ν)}l6, l=1,2, . . . ,7. (38)
The leading bit patterns and trailing bit patterns of possible code words have been identified in Tables 2 and 3. The number of code words of length n that start with the leading bit pattern i and that end with the trailing bit pattern j is denoted Wi,j[n]. After close inspection, it turns out that:
{grave over (D)}l,jn=Σi=18−lWi,j[n]. (39)
With this knowledge, the approximate eigenvector inequalities can be rewritten into the form:
Σi=1lΣj=17Wi,j[12]{tilde over (ν)}j2≧28{tilde over (ν)}8−l1, l=1,2, . . . ,7, (40)
Σi=1lΣj=17Wi,j[12]{tilde over (ν)}j3≧28{tilde over (ν)}8−l2, l=1,2, . . . ,7, (41)
Σi=1lΣj=17Wi,j[12]{tilde over (ν)}j4≧28{tilde over (ν)}8−l3, l=1,2, . . . ,7, (42)
Σi=1lΣj=17Wi,j[12]{tilde over (ν)}j5≧28{tilde over (ν)}8−l4, l=1,2, . . . ,7, (43)
Σi=1lΣj=17Wi,j[12]{tilde over (ν)}j6≧28{tilde over (ν)}8−l5, l=1,2, . . . ,7, (44)
and
Σi=1lΣj=17Wi,j[11]{tilde over (ν)}j1≧28{tilde over (ν)}8−l6, l=1,2, . . . ,7. (45)
The number of coding states per coding class is denoted by the vector ps for the s-th sub-code (s=1,2,3,4,5,6). Its relation to the approximate eigenvector {tilde over (v)}s is given by (for the i-th component, with 1≦i≦7):
pis={tilde over (ν)}8−is. (46)
Note that with this advantageous construction, the coding classes have a numbering system that is exactly complementary to the numbering system of the renumbered STD-states; this could already have been obvious from Table 1, where the renumbering of STD-states was mentioned, but not explained. Further, again due to the specific construction of the different coding classes, the following inequality holds (for each of the sub-codes s with s=1,2,3,4,5,6):
p1s≦p2s≦p3s . . . ≦p7s. (47)
An example Code-Design: a code with a k-constrain of k=∞
First, the case without k-constraint (k=∞) is considered. The number of code words with specific leading bit pattern (i) and trailing bit pattern (j), denoted Wi,j[n], for length n=12 and n=11 are given by:
An example Code-Design: a code with a k-constraint In order to generate a k-constraint without making use of an adapted STD with the k-constraint explicitly included, it is advantageous to limit the number of leading and trailing zeroes in the code words. The maximum number of leading zeroes in a code word is denoted l0; the maximum number of trailing zeroes is denoted r0. The number of code words with specific leading bit pattern i and trailing bit pattern j, with the additional constraint on l0 and r0, is denoted Wi,jl
Wi,j[n]≡Wi,j∞,∞. (50)
The additional constraint k=22 is realized with the choice l0=r0=11 for the sub-codes with mapping of 8-to-12, and with the choice l0=r0=10 for the single sub-code with mapping of 8-to-11. The matrices W11,11[12] and W10,10[11] are given by:
Note that with this choice of the number of leading and trailing zeroes in a code word (of length n=12 or n=11), only the all-zero code word is omitted (which implies that the matrix element at position (1,1) is decreased by unity as compared to the previous set of both matrices). A practical set of approximate eigenvectors of the rewritten approximate eigenvector inequalities is given by:
{tilde over (v)}1={28,27,24,17,17,15,11}, (53)
{tilde over (v)}2={26,25,22,16,15,14,10}, (54)
{tilde over (v)}3={24,23,20,14,14,13,9}, (55)
{tilde over (v)}4={22,21,19,13,13,11,8}, (56)
{tilde over (v)}5={20,19,17,12,12,11,8}, (57)
{tilde over (v)}6={19,18,16,12,11,10,7}. (58)
The first sub-code, denoted C1, with 8-to-12 mapping, has a total of 28 coding states; the second sub-code, denoted C2, also with 8-to-12 mapping, has a total of 26 coding states; the third sub-code, denoted C3, also with 8-to-12 mapping, has a total of 24 coding states; the fourth sub-code, denoted C4, also with 8-to-12 mapping, has a total of 22 coding states; the fifth sub-code, denoted C5, also with 8-to-12 mapping, has a total of 20 coding states; and the sixth sub-code, denoted C6, with 8-to-11 mapping, has a total of 19 coding states. The distribution of the total number of coding states (for each sub-code) over the 7 different coding classes is governed by the approximate eigenvector (for the given sub-code), as indicated by Eq. (46).
Construction of Code Tables for a Code with k=22
The code-tables are further constructed in such a way that a code word (with all its possible next-states) can appear only in one particular coding state. For the decoding operation, this means that the next code word uniquely specifies the “next-state” function of a current code word.
Encoding
For encoding of a 8-bit user word, one needs to know:
(1) the sub-code Ci with which the current user word has to be encoded; and:
(2) the state j of the sub-code Ci, denoted Ci-Sj and the corresponding code table that is to be used for the encoding.
In the process of encoding, the encoder generates as output:
(1) the code word according to the code table that is to be used; and:
(2) the next sub-code that is to be used for the encoding of the next 8-bit user word, which is simply Ci+1 (which, for i=6, equals C1 due to the cyclic repetition of the six sub-codes); and:
(3) the next state of the next sub-code Ci+1 according to the code table that is to be used upon encoding for the current user word, where this next state will specify which code table is to be used for the encoding of the next 8-bit user word with the next sub-code Ci+1.
Decoding
The process of decoding is described on the basis of
The process of decoding is further explained as follows. At the input of the decoder, there are two code words, code word Wi encoded with sub-code Cp, and code word Wi+1, encoded with the next sub-code Cp+1. For both code words, and independent on the sub-code that applies to each of the code words Wi and Wi+1, an index can be derived (e.g. based on enumerative decoding for a d=1 RLL constraint: the index ranges from 0 to 376 for a code word of 12 channel bits, and from 0 to 232 for a code word of 11 channel bits). The respective indices are denoted Ii and Ii+1 for the current and next code words. Next, the index Ii+1 is converted into a “next-state” of the current code word Wi by means of a special conversion table (with is dependent on the sub-code that applies to the considered word Wi+1): this table maps each (index of a) code word onto the state to which it belongs for the considered sub-code (which is here Cp+1). This “next-state” is denoted NSi. The combination of the index of the current code word Wi, that is Ii, in combination with its decoded next-state NSi are the input of a special decoding table for the given sub-code Cp, which yields the decoded (8-bit) user word.
DC-control Through the use of Guided Scrambling
Just like with the 9-bit oriented code discussed previously guided scrambling can be used for DC-control.
Distribution of 8-bit ECC Symbols
A code with a more compact mapping of 4-to-6
d=1 & r=2 RLL Codes suitable for Soft-Decision RLL Decoding
The r=2 RLL constraint is advantageous for the performance of the channel detector (which can be a PRML bit-detector for hard-decision bit-detection, and a BCJR channel detector for soft-decision bit-detection). For instance, for hard-decision bit-detection, the r=2 constraint yields a capacity gain of about 5% over the situation with r≧6. It is therefore the aim of the current ID to generate a d=1 RLL code with the following properties:
A Code with compact 4-to-6 mapping.
It is the purpose of the current code-design to have a channel code with a compact mapping of user bits onto channel bits, so that the hardware complexity of, for example, the soft-decision SISO-RLL decoder (in terms of the total number of branches) can be kept low. The new code has a mapping of 4-to-6 of user bits onto channel bits (thus a code rate R=⅔). As has been discussed above, the Shannon capacity of the combined RLL constraints d=1 and r=2 amounts to C(d=1,k=∞,r=2)=0.679286. A code with mapping of user bits onto channel bits of 4-to-6 may be possible to construct, since it has a rate R=0.6667≦C(d=1,k=∞,r=2).
Construction of a sliding-block code is based on the ACH-algorithm as disclosed by R. L. Adler, D. Coppersmith, and M. Hassner, in “Algorithms for Sliding Block Codes. An Application of Symbolic Dynamics to Information Theory”, IEEE Transaction on Information Theory, Vol. IT-29, 1983, pp. 5-22. This algorithm looks for a set of approximate eigenvectors, with νi denoting the i-th coefficient of the approximate eigenvector that satisfies the set of inequalities for all states i of the corresponding state-transition diagram (STD) that describes the RLL constraints (for a code with m-to-n mapping):
ΣjDi,jnνj≧2mνi. (59)
In the above equation, D represent the so-called adjacency-matrix or connection-matrix for the STD: its matrix elements are equal to one if the corresponding two STD-states are connected in the graph, and are equal to zero if they are not connected. For the new code with RLL constraints d=1 and r=2, the code has the parameters m=4 and n=6. This implies that the following inequalities have to be satisfied for the envisaged new code:
Σj=17Di,j6νj≧24νi, i=1,2, . . . 7. (60)
With the renumbered STD-states, and a correspondingly rearranged connection matrix, denoted {grave over (D)}, the approximate eigenvector inequalities (for the “new” eigenvectors {tilde over (ν)}) are rewritten as:
Σj=17{grave over (D)}l,j6{tilde over (ν)}j≧24{tilde over (ν)}l, l=1,2, . . . ,7. (61)
The leading bit patterns and trailing bit patterns of possible code words have been identified in Tables 2 and 3. The number of code words of length n that start with the leading bit pattern i and that end with the trailing bit pattern j is denoted Wi,j[n]. After close inspection, it turns out that:
{grave over (D)}l,jn=Σi=18−lWi,j[n]. (62)
With this knowledge, the approximate eigenvector inequalities can be rewritten into the form:
Σi=1lΣj=17Wi,j[6]{tilde over (ν)}j≧24{tilde over (ν)}8−l, l=1,2, . . . ,7. (63)
The number of coding states per coding class is denoted by the vector p. Its relation to the approximate eigenvector {tilde over (v)} is given by (for the i-th component, with 1≦i≦7):
pi={tilde over (ν)}8−i. (64)
Note that with this advantageous construction, the coding classes have a numbering system that is exactly complementary to the numbering system of the renumbered STD-states; this could already have been obvious from Table 1, where the renumbering of STD-states was mentioned, but not explained. Further, again due to the specific construction of the different coding classes, the following inequality holds:
p1≦p2≦p3 . . . ≦p7. (65)
Additional Measures for One-Symbol Look-Ahead Sliding-Block Decoder
In order to limit error propagation, the new code is constructed such that the decoder needs to look ahead one channel word of 6 channel bits, that is, for the decoding of a given user word, one needs the corresponding 6-bit channel word Wi together with the next 6-bit channel word Wi+1 as shown in see
Σp=1{tilde over (ν)}1ni,jp≦Wi,j. (66)
Per coding class, a number of coding states is associated. The adapted approximate eigenvector inequality has to be rewritten as:
Σi=1lΣj=17ni,jp{tilde over (ν)}j≧24, (67)
p=1+{tilde over (ν)}8−l+1, . . . ,{tilde over (ν)}8−1,
and l=1,2, . . . ,7.
In the latter equation, it is assumed that {tilde over (ν)}8=0; further, the inequality applies only in the case that the left-limit of the running index p is not larger than its right-limit (otherwise, for a given l where the left-limit of p is larger than the right-limit of p, no extra coding states need to be considered).
An example Code-Design: a code with a k-constraint of k=∞
First, the case without k-constraint (k=∞) is considered. The number of code words with specific leading bit pattern (i) and trailing bit pattern (j), denoted Wi,j[n], for length n=6 is given by:
The total number of code words with length n=6 equals 21 (as it should be since the number of d=1 sequences of length 6 equals Nd=1(6)=21). They are listed in Table 4, together with the index i, j (referring to leading and trailing bit-patterns), and together with the word multiplicity as prescribed by the approximate eigenvector that satisfied Eq. (63). The code words are listed in a lexicographic ordering according to the following indexing (starting from index 1 up to 21; with I the index of a 6-bit code word with bits bj):
I=1+Σj=16bjNd=1(6−j). (69)
1
5
2
1
6
1
5
3
1
5
2
1
7
1
5
2
1
6
1
5
4
Approximate Eigenvector AE
A approximate eigenvector (denoted AE) satisfying Eq. (63) is given by:
{tilde over (v)}={8,8,7,5,5,4,3}. (70)
It leads to a code with word allocations that satisfy Eq. (67). This is explained in the remainder of this paragraph. The 8 different coding states are generated step-by-step, according to successive values of the parameter l in Eq. (67).
STAGE-(a) l=1, 3 coding states p=1,2,3
All code words with i=1 can be used. Two coding states are realized through the combination 8+8(=16) (two times), the 3rd coding state is realized through the combination 5+5+7=17, so that effectively one entry is lost for further use (in next coding states, at higher values of l). One code word (with multiplicity 4) is not used, but will be of use later on in the code construction.
STAGE-(b) l=2, 1 coding state p=4
All code words with a leading bit-pattern index not larger than i=2 can be used. The 4th coding state S4 can be realized through the combination 8+8(=16). In addition to the one code word that was left over at stage (a), again one code word (with multiplicity 5) is not used in this stage, and will be used later on.
STAGE-(c) l=3, 1 coding state p=5
All code words with a leading bit-pattern index not larger than i=3 can be used. The 5th coding state S5 can be realized through the combination 8+5+4(=17). This means that one entry is lost for further use (in next coding states, at higher values of l). In addition all remaining code words from the two previous steps have been used.
STAGE-(d) l=4, no coding states. The code word with index i=4 will be used in the subsequent stage.
STAGE-(e) l=5, 2 coding states p=6,7
All code words with a leading bit-pattern index not larger than i=5 can be used. The two states S6 and S7 can be realized through the combinations 8+8(=16) and 8+5+3(=16). The last code word (nr. 18) will be used in the next stage.
STAGE-(f) l=6, 1 coding state p=8
All code words with a leading bit-pattern index not larger than i=6 can be used. The last coding state S8 is realized through the combination 8+5+4(=17), which implies that one entry is lost.
This completes the construction of all 8 coding states S1, S2, . . . up to S8. Note that the last code word (nr. 21, |101010|) is not used at all in this code construction.
The parameters ni,jp (as used in Eq. (66) and Eq. (67)) are listed for the 8 different coding states (only the non-zero elements are noted) in table 6:
All other parameters ni,jp (that are not listed) are zero. It can be readily verified that for all indices i, j (with the exception of i, j=7,4), one has:
Σp=18ni,jp≡Wi,j, (71)
so that the ≦-condition of Eq. (66) is converted into equality for all the entries involved. The only exception is that, for all coding states p, n7,4p=0, whereas W7,4=1. The corresponding word, with index nr. 21 and equal to |101010|, must thus not be used to reach a valid code. One possible allocation of code words to coding states is shown in Table 7.
An example Code-Design: a code with a k-constraint of k=14
In this section, it is our aim to generate a k-constraint without making use of an adapted STD with the k-constraint explicitly included. Long sequences of zeroes can be generated by many successive repetitions of the all-zero word |000000| (which is used in coding state S1). The all-zero word has also one table entry in coding state S1 with as next state S1: in this way, the all-zero word can be used repetitively, thus prohibiting a finite k-constraint on the maximum number of zeroes in a runlength. The word allocation in coding state S1 according to Table 7 is given in Table 8.
A finite k-constraint can be realized through the following steps:
Step-1. Duplicating coding state S1 into an extra coding state S9, where the first 5 entries (which use the all-zero code word) are replaced by the code word that has not been used until now in the code construction (that is, code word nr. 21), while their next-state is maintained unaltered.
Step-2. In all coding states, code words that end with at least two zeroes . . . 00| and that have S1 as next state, are deviated to S9 as next state.
Table 9 yields two coding states, S1 and the new one S9, after implementation of Steps 1 and 2. The aspects that are crucial have been underlined. The complete table with all 9 coding states (and for each state, its 16 entries) can be found below in table 10.
S9
101010
101010
101010
101010
101010
The maximum number of consecutive zeroes equal to (14) is realized as follows:
-010|entry-0S1000000|entry-6S9000000|S7010101|0-.
A Practical Method for Decoding
The process of decoding is described on the basis of
The process of decoding is further explained as follows. At the input of the decoder, there are two code words, code word Wi and code word Wi+1. For both code words, an index can be derived (e.g. based on enumerative decoding for a d=1 RLL constraint: the index ranges from 0 to 20 for a code word of 6 channel bits). The respective indices are denoted Ii and Ii+1 for the current and next code words. Next, the index Ii+1 is converted into a “next-state” of the current code word Wi by means of a special conversion table: this table maps each (index of a) code word onto the state to which it belongs. This “next-state” is denoted NSi. The combination of the index of the current code word Wi, that is Ii, in combination with its decoded next-state NSi are the input of a special decoding table, which yields the decoded (4-bit) user word.
DC-control Through the use of Guided Scrambling
Just like with the 9-bit oriented code and byte oriented code discussed previously guided scrambling can be used for DC-control.
Distribution of 8-bit ECC Symbols
Complexity Considerations for SISO-RLL Decoding
The combination of soft-decision (SISO) bit-detection with runlength limited (RLL) coding is disclosed by E. Yamada, T. Iwaki and T. Yamaguchi, in “Rurbo Decoding with Run Length Limited Code for Optical Storage”, Japanese Journal of Applied Physics, Part-1, Vol. 41, pp. 1753-1756, 2002. For the sake of clarity, only the two-stage approach with separate SISO-channel detector and SISO-RLL decoder is considered as shown in
After retrieval from the channel or record carrier 93 the SISO-channel detector processes the HF signal thus retrieved, converts the HF signal into NRZ channel bits and provides the NRZ channel bits to the SISO-RLL decoder 95. The SISO RLL decoder 95 converts the NRZ channel bits into user bits, after which the user bits are processed by the LDPC decoder 96 to obtain the source bits.
The traditional PRML detector is replaced by a SISO-Channel Detector 94, which produces LLRs (log-likelihood-ratios) for the NRZ channel bits. Note that, apart from the BCJR-algorithm, also other algorithms exist for producing the LLR soft-info on the NRZ channel bits: in this sense, the reference made to SISO-Channel Detector 94 in the
The 17PP code is not constructed on the basis of the ACH-algorithm; it is a synchronous variable-length code with different mappings, all with code rate R=⅔. The practical mappings of the 17PP code are (from user bits to channel bits): 2-to-3, 4-to-6, 6-to-9 and 8-to-12. It has been pointed out by T. Miyauchi and Y. Iida, in “Soft-Output Decoding of 17PP Code”, Technical Digest ISOM 2003 (International Symposium on Optical Memory), Nara, Japan, paper We-PP-13, pp. 314-315 that the 17PP RLL code as used in the BD standard, when transformed from a variable-length code structure into a FSM-based code structure (for the purpose of decoding only), has a high state-complexity with 21 states and 79 branches (per stage of the trellis with 2 input bits and 3 channel bits along the branches). For each group of 4 user bits, this implies the double complexity, that is, 158 branches.
The new RLL code of the current invention has 9 coding states, and per coding state a number of 16 branches, making a total of 144 branches. This implies that the new RLL code has 10% less hardware complexity for SISO-RLL decoding than the 17PP code of BD; and it should be recalled that the new RLL code has on top of that, the advantageous r=2 constraint, whereas 17PP has only r=6.
Alternative Code Words
It is clear from the above code construction that some combinations of 6-bit code words do not occur in the encoded channel bitstream. This relates to some of the entries of a given code word that have been “lost” during code construction. Each of the “lost” entries can be used as an alternative coding entry for exactly one entry in the coding state where said code word occurs (it does not need to be the same code word). This insight generates some freedom at the encoder side, which can be used as a side-channel, or for some other statistical properties of the encoded channel bitstream (like DC-control).
Generalization of the Code According to the Invention
For the above codes, a new construction method for RLL codes with d=1 and r=2 has been derived. It turns out that the new construction method is generic, in the sense that it can be applied to any combination of the d and r constraint.
The method relates to the conversion of a user bitstream into a coded bitstream (also known as channel bitstream) by means of an overall channel code. Such a channel code converts a group of M information bits into a group of N code word bits. The first group of bits is also commonly referred to as an information word, the second group of bits is known as a code word or channel word. The overall channel code may be realized through the concatenation of a number S of sub-codes in a well-defined order that is cyclically repeated with a predetermined repeat period: each of the sub-codes receives mi-bit information words at its input, that are converted into ni-bit code words, where mi and ni are integers characteristic for each of the considered sub-codes. Further, for each sub-code, the second characteristic integer number ni is greater than the first characteristic integer number in mi; also, the sum of the mi-numbers of all sub-codes within the repeat period of the overall code equals M, and the sum of the ni-numbers of all sub-codes within the repeat period of the overall code equals N. The key-feature in the new construction method is that, for each i-th sub-code, its ni-bit code words are being divided into a number of T different types and are being arranged into T classes of coding states such that, for the given i-th sub-code, an ni-bit code word of type t (where t is an integer number between 1 and T) can be concatenated with an ni+1-bit code word of the next sub-code if this subsequent code word of the next sub-code belongs to one of coding states of the class with index T+1−t. For RLL code construction comprising the d and r constraints, it can be derived that T=1+(d+1)×(r+1).
The latter statement will be first explained for the number of different code word types. A code-word type is defined in terms of the trailing bits of a code-word. Further, a code-word type with a low index puts less restrictions of the leading bits of the subsequent code-word than a code-word type with a high index. The code-word type nr. 1 allows concatenation with any subsequent code-word. Code-words belonging to code-word type 1 all end with d+1 zeroes, that is:
| . . . 0d+1|nr. 1
Subsequently, code-words belonging to code-word type 2, 3, . . . , r+2 all end with 10d. Note that this last run is a run with minimum run length (d+1 channel bits). Preceding this last run 10d, one can distinguish r+1 cases: code-word type 2 has a run larger than the minimum run length, code-word type 3 has exactly one minimum run length preceding the last run 10d, code-word type 4 has exactly two minimum run lengths preceding the last run 10d, . . . , and code-word type r+2 has exactly r minimum run lengths preceding the last run 10d. These r+1 different cases are listed below:
Next, code-words belonging to code-word type (r+2)+1, (r+2)+2, . . . , (r+2)+(r+1) all end with 10d−1. Note that this last run cannot be a complete run since its run length is exactly one bit shorter than the minimum run length (of length (d+1 channel bits). Preceding this last run 10d−1, one can distinguish r+1 cases: code-word type (r+2)+1 has a run larger than the minimum run length, code-word type (r+2)+2 has exactly one minimum run length preceding the last run 10d−1, code-word type (r+2)+3 has exactly two minimum run lengths preceding the last run 10d−1, . . . , and code-word type (r+2)+(r+1) has exactly r minimum run lengths preceding the last run 10d−1. These r+1 different cases are listed below:
This enumeration of different code-word types is continued along the same lines as above: each time, the number of channel bits in the start of the last run is reduced by exactly one channel bit. At a given stage, one arrives at the situation that the start of the last run comprises exactly two bits, given by 10. The number of different code-word types (r+1) are listed below:
Finally, the last step in this enumeration of different code-word types is reached when one arrive at the situation that the start of the last run comprises exactly one bit given by 1. The number of different code-word types (r+1) are listed below:
In total, there are (d+1) enumeration steps (enumerating the different code-word types); for each enumeration step, there are r+1 different code-word types. In total, this amounts to the number of different code-word types given above, T=1+(d+1)×(r+1).
Before introducing the concept of a coding class, the leading bit-patterns are enumerated in a similar way as the code-word types (but with the respective leading bit-pattern obtained as the mirrored version from right to left of the trailing bit-pattern of the corresponding code-word type). This results in a catalogue of the possible leading bit-patterns:
An RLL channel code comprises a number of coding states. In the current invention, each coding state is at least a member of one coding class. A coding class with index t comprises all code-words that have a leading bit-pattern with index i such that 1≦i≦t. The structure of code-word types on the one hand, and coding classes on the other hand, leads to the following property, as is used in the new code construction method: a code-word belonging to code-word type t can only be followed by a code-word if that code-word belongs to one of the coding states of coding class T+1−t.
It is further convenient to note that, due to the structure of code-word types and coding states as outlined above, that each of the pi coding states of a given considered coding class i, is also a coding state of all coding classes that have an index larger than i.
For the cases of the above examples in section 1 and 2 (d=1 and r=2), there are T=7 different coding classes and code word types. Practical codes have been derived as outlined in the above sections for a 9 bit oriented code, a byte oriented code and a code with a compact 4-to-6 mapping, all with d=1 and r=2.
For the case with d=2 and r=2, there are T=10 different coding classes and code word types. For the latter case, a practical code construction is described in the next sub section.
An Extremely Efficient RLL Code for d=2 and r=2
The Shannon capacity of the combined RLL constraints d=2 and 7=2 amounts to C(d=2,k=∞,r=2)=0.544997. A code with mapping of user bits onto channel bits of 32-to-59 may be possible to construct, since it has a rate R=0.542373≦C(d=2,k=∞,r=2): the efficiency of this new code η=R/C(d=2,k=∞,r=2) is such that only the small fraction 1−η=0.48% is lost compared to the theoretical upper limit. Obviously, code books with 32-bit entries are much too large to be of any practical use. In order to circumvent this problem, a solution is proposed that follows the lines of the algorithm presented by] J. J. Ashley and B. H. Marcus, in “Time-Varying Encoders for Constrained Systems: an Approach to Limiting Error Propagation”, IEEE Transactions on Information Theory, Vol. 46, No. 3, pp. 1038-1043, May 2000. The latter approach generalizes the well known state-splitting algorithm or ACH-algorithm as disclosed by R. L. Adler, D. Coppersmith, and M. Hassner, in “Algorithms for Sliding Block Codes. An Application of Symbolic Dynamics to Information Theory”, IEEE Transaction on Information Theory, Vol. IT-29, 1983, pp. 5-22, (used for the construction of efficient sliding block codes) for a concatenation of a number of codes (at multiple phases), where the encoding and decoding proceeds cyclically from one phase to the next (or, from one code to the next). Practically, for the new code with rate R= 32/59, the overall code can be realized as a cyclic concatenation of four sub-codes, denoted C1, C2, C3, and C4, with respective mappings 8-to-15, 8-to-15, 8-to-15 and 8-to-14.
In the general case, the overall code is realized by a number of S sub-codes. The generalized ACH-algorithm looks for a set of S approximate eigenvectors, one for each sub-code, with νik denoting the i-th coefficient of the approximate eigenvector for the k-th sub-code, that satisfies the set of inequalities, for all states i of the corresponding state-transition diagram (STD) that describes the RLL constraints, and for all sub-codes k (with a mapping mk-to-nk for the k-th sub-code):
ΣjDi,jm
Note that when k=S, the next sub-code with index k+1 due to the cyclic repeat-period of the sub-codes is the one with index equal to 1. In the above equation, D represent the so-called adjacency-matrix or connection-matrix for the STD: its matrix elements are equal to one if the corresponding two STD-states are connected in the graph, and are equal to zero if they are not connected. For the new code with RLL constraints d=2 and r=2, the four sub-codes have the parameters m1=m2=m3=m4=8, and n1=n2=n3=15 and n4=14. (Note that any scrambled but fixed order of these four mappings is also a valid order for the further code-construction, and falls within the scope of the current invention.) The cyclic repetition of the four sub-codes (denoted C1, C2, C3 and C4) is shown schematically in
This implies that the following inequalities have to be satisfied for the envisaged new overall code:
Σj=110Di,j15νj2≧28νi1, i=1,2, . . . ,10, (73)
Σj=110Di,j15νj3≧28νi2, i=1,2, . . . ,10, (74)
Σj=110Di,j15νj4≧28νi3, i=1,2, . . . ,10, (75)
and
Σj=110Di,j14νj1≧28νi4, i=1,2, . . . ,10. (76)
Some parameters of the above equations are now explained. For the RLL constraints d=2 and r=2, the STD is shown in
10
9
8
7
6
5
4
3
2
1
From Table 11, it is clear that the following hierarchy in fan-out applies (with STD-state σ4 having the largest fan-out):
Fσ
The new RLL code is constructed on the basis of a plurality of coding states, one set of coding states for each sub-code. According to the present invention, these coding states are arranged into T=1+(d+1)×(r+1)=10 (since d=r=2) classes as follows:
the n-bit code words of the 1st class of coding states belong to Fσ
the n-bit code words of the 2nd class of coding states belong to Fσ
the n-bit code words of the 3rd class of coding states belong to Fσ
the n-bit code words of the 4th class of coding states belong to Fσ
the n-bit code words of the 5th class of coding states belong to Fσ
the n-bit code words of the 6th class of coding states belong to Fσ
the n-bit code words of the 7th class of coding states belong to Fσ
the n-bit code words of the 8th class of coding states belong to Fσ
the n-bit code words of the 9th class of coding states belong to Fσ
the n-bit code words of the 10th class of coding states belong to Fσ
Due to this specific ordering of the coding classes according to the present invention, a coding state of a coding class i is also a coding state of all coding classes with index j not smaller than i, that is, j≧i. It is thus convenient to order the possible patterns of leading nits of code words as follows:
In addition, it is for the code-construction according to the present invention beneficial to consider the following ordering of the trailing bit patterns (with the arrival state of the STD also indicated, both the original one and the renumbered one) as outlined in Table 13. According to the present invention, code words can be divided into T=10 different code-word types as specified by the trailing bit pattern of the corresponding code-words.
1
2
3
4
5
6
7
8
9
10
It should be noted that the ordered trailing bit patterns (of Table 13) are the mirrored versions of the corresponding ordered leading bit patterns (of Table 12). Next, the already mentioned renumbering of the STD-states is discussed. It is now convenient to renumber the states of the STD in terms of the ordering of the trailing bit-patterns as they were listed in Table 13. This new numbering is outlined in the last two columns of Table 13. The new renumbered states are denoted {grave over (σ)}i. With this new numbering, code words of type i will arrive in the (renumbered) STD-state with the same index, that is, {grave over (σ)}i; consequently, code words of type i can be concatenated with any code word that belongs to a coding state of class T+1−i=11−i as a subsequent code word. It is to be noted that code words belonging to a coding state of class T+1−i=11−i have leading bit patterns (from Table 12) with index l where 1≦l≦11−i. As an example, code words of type 3 (end with trailing bit pattern . . . 000100100|) can be concatenated with code words from coding states of class 8, which implies that the latter code words may start with the leading bit patterns (Table 12) i=1, i=2, . . . , i=8. This division of code words into T=10 different types of code words, and the arrangement of coding states into T=10 different coding classes, forms the basis for the further code construction: in this way, the RLL constraints d=2 and r=2 always remain satisfied, also upon concatenation of code words of cyclically consecutive sub-codes. From Table 13, it is clear that the following hierarchy in fan-out applies for the renumbered STD-states:
F{grave over (σ)}
The renumbered STD-state {grave over (σ)}1 has the largest fan-out of all, and {grave over (σ)}10 the smallest one, with an enumerative ranking according to the decreasing fan-out from {grave over (σ)}1 to {grave over (σ)}10. With the renumbered STD-states, and a correspondingly rearranged connection matrix, denoted {grave over (D)}, the approximate eigenvector inequalities (for the “new” eigenvectors {tilde over (ν)}) are rewritten as:
Σj=110{grave over (D)}l,j15{tilde over (ν)}j2≧28{tilde over (ν)}l1l=1,2, . . . ,10, (79)
Σj=110{grave over (D)}l,j15{tilde over (ν)}j3≧28{tilde over (ν)}l2l=1,2, . . . ,10, (80)
Σj=110{grave over (D)}l,j15{tilde over (ν)}j4≧28{tilde over (ν)}l3l=1,2, . . . ,10, (81)
and
Σj=110{grave over (D)}l,j14{tilde over (ν)}j1≧28{tilde over (ν)}l4l=1,2, . . . ,10. (82)
The leading bit patterns and trailing bit patterns of possible code words have been identified in Tables 12 and 13. The number of code words of length n that start with the leading bit pattern i and that end with the trailing bit pattern j is denoted Wi,j[n]. After close inspection, it turns out that:
{grave over (D)}l,jn=Σi=111−lWi,j[n]. (83)
(where the number 11 is obtained from T+1 with T=10). With this knowledge, the approximate eigenvector inequalities can be rewritten into the form:
Σi=1lΣj=110Wi,j[15]{tilde over (ν)}j2≧28{tilde over (ν)}11−l1, l=1,2, . . . ,10, (84)
Σi=1lΣj=110Wi,j[15]{tilde over (ν)}j3≧28{tilde over (ν)}11−l2, l=1,2, . . . ,10, (85)
Σi=1lΣj=110Wi,j[15]{tilde over (ν)}j4≧28{tilde over (ν)}11−l3, l=1,2, . . . ,10, (86)
and
Σi=1lΣj=110Wi,j[14]{tilde over (ν)}j1≧28{tilde over (ν)}11−l4, l=1,2, . . . ,10. (87)
The number of coding states per coding class is denoted by the vector ps for the s-th sub-code (s=1,2,3,4). Its relation to the approximate eigenvector {tilde over (v)}s is given by (for the i-th component, with 1≦i≦10):
pis={tilde over (ν)}11−is. (88)
Note that with this advantageous construction, the coding classes have a numbering system that is exactly complementary to the numbering system of the renumbered STD-states; this could already have been obvious from Table 11, where the renumbering of STD-states was mentioned, but not explained. Further, again due to the specific construction of the different coding classes, the following inequality holds (for each of the sub-codes s with s=1,2,3,4):
p1s≦p2s≦p3s . . . ≦p10s. (89)
Code-Design: Case with k=∞
First, the case without k-constraint (k=∞) is considered. The number of code words with specific leading bit pattern (i) and trailing bit pattern (j), denoted Wi,j[n], for length n=15 and n=14 are given by:
Code-Design: Case with k-constraint
In order to generate a k-constraint without making use of an adapted STD with the k-constraint explicitly included, it is advantageous to limit the number of leading and trailing zeroes in the code words. The maximum number of leading zeroes in a code word is denoted l0; the maximum number of trailing zeroes is denoted r0. The number of code words with specific leading bit pattern i and trailing bit pattern j, with the additional constraint on l0 and r0, is denoted Wi,jl
Wi,j[n]≡Wi,j∞,∞. (92)
The additional constraint k=26 is realized with the choice l0=r0=13 for the four sub-codes. The matrices W13,13[15] and W13,13[14] are given by:
Note that with this choice of the number of leading and trailing zeroes in a code word of length n=14, only the all-zero code word is omitted (which implies that the matrix element at position (1,1) is decreased by unity as compared to the matrix without k-constraint); for the case of n=15, in addition the two code words |1014| and |0141| are also omitted. A practical set of approximate eigenvectors of the rewritten approximate eigenvector inequalities is given by:
{tilde over (v)}1={26,26,24,18,17,16,12,12,11,8}, (95)
{tilde over (v)}2={24,23,21,16,16,15,11,11,10,7}, (96)
{tilde over (v)}3={22,21,19,15,14,13,10,10,9,7}, (97)
{tilde over (v)}4={20,19,18,13,13,12,9,9,8,6}. (98)
The first sub-code, denoted C1, with 8-to-15 mapping, has a total of 26 coding states; the second sub-code, denoted C2, also with 8-to-15 mapping, has a total of 24 coding states; the third sub-code, denoted C3, also with 8-to-14 mapping, has a total of 22 coding states; the fourth sub-code, denoted C4, with 8-to-14 mapping, has a total of 20 coding states. The distribution of the total number of coding states (for each sub-code) over the T=10 different coding classes is governed by the approximate eigenvector (for the given sub-code).
Construction of Code Tables for Case with k=26
The code-tables are further constructed in such a way that a code word (with all its possible next-states) can appear only in one particular coding state. For the decoding operation, this means that the next code word uniquely specifies the “next-state” function of a current code word.
Encoding and Decoding with Code for Case with k=26
Encoding
For encoding of a 8-bit user word, one needs to know:
(1) the sub-code Ci with which the current user word has to be encoded; and:
(2) the state j of the sub-code Ci, denoted Ci-Sj and the corresponding code table that is to be used for the encoding.
In the process of encoding, the encoder generates as output:
(1) the code word according to the code table that is to be used; and:
(2) the next sub-code that is to be used for the encoding of the next 8-bit user word, which is simply Ci+1 (which, for i=4, equals C1 due to the cyclic repetition of the four sub-codes); and:
(3) the next state of the next sub-code Ci+1 according to the code table that is to be used upon encoding for the current user word, where this next state will specify which code table is to be used for the encoding of the next 8-bit user word with the next sub-code Ci+1.
Decoding
The decoding is state-independent, that is, it is not required to know the state in which the encoder encoded the 8-bit user word (that is now considered to be decoded). State-independent decoding is achieved by the fact that every code word and next-state combination that may occur, occurs only once in one single code table (among all the coding tables). Further, for the decoding of a code word into a user word, it is also required to know the next-state of the current code word. The latter next-state can be derived from the next code word that immediately follows the current code word. The fact that this is possible is obtained by the construction of the coding states, whereby each code word (independent of its next state) can only occur in a single code table among all the coding tables; so, the next code word unambiguously determines the next state of the current code word. It should be noted that the next state of a given code word (that was encoded with a sub-code Cp) is one out of the possible states of the next sub-code, that is, Cp+1.
The process of decoding is further explained as follows. At the input of the decoder, there are two code words, code word Wi encoded with sub-code Cp, and code word Wi+1 encoded with the next sub-code Cp+1. For both code words, and independent on the sub-code that applies to each of the code words Wi and Wi+1, an index can be derived (e.g. based on enumerative decoding for a d=2 RLL constraint). The respective indices are denoted Ii and Ii+1 for the current and next code words. Next, the index Ii+1 is converted into a “next-state” of the current code word Wi by means of a special conversion table (with is dependent on the sub-code that applies to the considered word Wi+1): this table maps each (index of a) code word onto the state to which it belongs for the considered sub-code (which is here Cp+1). This “next-state” is denoted NSi. The combination of the index of the current code word Wi, that is Ii, in combination with its decoded next-state NSi are the input of a special decoding table for the given sub-code Cp, which yields the decoded (8-bit) user word.
RLL Codes with d=1 and RMTR-constraint r=2 with a compact 2-to-3 mapping
In relation to hard-decision bit-detection, some new d=1 RLL codes with an RMTR-constraint of r=2 were proposed above, which have a very high efficiency for 9-bit user words at the input of the RLL encoder in section 1, and for 8-bit user words or bytes at the input of the RLL encoder in section 2. These codes have a large complexity in terms of number of coding states; further, they have at their input user words of length 8 or 9 bits. The latter two aspects make these highly efficient d=1 & r=2 RLL codes not suited for soft-decision RLL decoding, since, in order to limit the hardware complexity in such case, one can only allow a limited number of coding states and should have a concise code mapping from user bits onto channel bits. However, the insights that have lead to the code-construction of the latter two d=1 & r=2 RLL codes with extremely high efficiency, will be exploited also in the current ID to generate a new code, that has all properties as specified in the next section, and which make it much better suited for soft-decision SISO-RLL decoding. A first attempt for this purpose has resulted into a new code with 4-to-6 mapping, as outlined above. The current second attempt involves the most compact mapping that is possible, that is, a code with a 2-to-3 mapping.
d=1 & r=2 RLL Codes Suitable for Soft-Decision RLL Decoding
The r=2 RLL constraint is advantageous for the performance of the channel detector (which can be a PRML bit-detector for hard-decision bit-detection, and a BCJR channel detector or Max-log-MAP channel detector for soft-decision bit-detection). For instance, for hard-decision bit-detection, the r=2 constraint yields a capacity gain of about 5% over the situation with r≧6. It is therefore the aim of the current ID to generate a d=1 RLL code with the following properties:
It is the purpose of the current code-design to have a channel code with a compact mapping of user bits onto channel bits, so that the hardware complexity of the soft-decision SISO-RLL decoder (in terms of the total number of branches) can be kept low. The new code has a mapping of 2-to-3 of user bits onto channel bits (thus a code rate R=⅔). As has been discussed before, the Shannon capacity of the combined RLL constraints d=1 and r=2 amounts to C(d=1,k=∞,r=2)=0.679286. A code with mapping of user bits onto channel bits of 2-to-3 may be possible to construct, since it has a rate R=0.6667≦C(d=1,k=∞,r=2).
Construction of a sliding-block runlength limited (RLL) code is based on the ACH-algorithm as disclosed by R. L. Adler, D. Coppersmith, and M. Hassner, in “Algorithms for Sliding Block Codes. An Application of Symbolic Dynamics to Information Theory”, IEEE Transaction on Information Theory, Vol. IT-29, 1983, pp. 5-22. This algorithm looks for an approximate eigenvector, with νi denoting the i-th coefficient of the approximate eigenvector that satisfies the set of inequalities for all states i of the corresponding state-transition diagram (STD) that describes the RLL constraints (for a code with m-to-n mapping):
ΣjDi,jnνj≧2mνi. (89)
In the above equation, D represent the so-called adjacency-matrix or connection-matrix for the STD: its matrix elements are equal to one if the corresponding two STD-states are connected in the graph, and are equal to zero if they are not connected. For the new code with RLL constraints d=1 and r=2, the code has the parameters m=2 and n=3. This implies that the following inequalities have to be satisfied for the envisaged new code (with the numbers of states in the state-transition diagram describing the RLL constraints being equal to 7; see next subsection):
Σj=17Di,j3νj≧22νi, i=1,2, . . . ,7. (90)
State-Transition Diagram (STD)
It should be noted that the state-transition diagram (STD) describes the basic runlength constraints that have to be satisfied by the channel bitstream. An RLL code that satisfies these runlength constraints is based on a finite-state machine (FSM) comprising a certain number of states. Along the branches of the FSM of the code, the code-words of the RLL code are shown. Consider the RLL-encoder to be in a given FSM-state; for each of the 2m=4 input words, there is a unique branch leaving said FSM-state. Each of the branches is uniquely characterized by a branch-label, which is the code-word, together with the “next state” which is the arrival state of said branch. Concatenation of the code-words according to the structure of the FSM leads to a channel bitstream that satisfies the runlength constraints as outlined in the STD.
For the RLL constraints d=1 and r=2, the STD is shown in
Next, the fan-out of each STD-state is analyzed. The fan-out of a given STD-state is the collection of code words (of a given length) that can leave from that state. For STD-state σi, the fan-out is denoted Fσ
7
6
5
4
3
2
1
From Table 14, it is clear that the following hierarchy in fan-out applies (with STD-state σ3 having the largest fan-out):
Fσ
The new RLL code is constructed on the basis of a plurality of coding states. According to the present invention, these coding states are arranged into (a maximum of) seven classes (Tmax=1+(d+1)×(r+1) which equals 7 for d=1 and r=2) as follows:
the n-bit code words of the 1st class of coding states belong to Fσ
the n-bit code words of the 2nd class of coding states belong to Fσ
the n-bit code words of the 3rd class of coding states belong to Fσ
the n-bit code words of the 4th class of coding states belong to Fσ
the n-bit code words of the 5th class of coding states belong to Fσ
the n-bit code words of the 6th class of coding states belong to Fσ
the n-bit code words of the 7th class of coding states belong to Fσ
Due to this specific ordering of the coding classes according to the present invention, a coding state of a coding class i is also a coding state of all coding classes with index j not smaller than i, that is, j≧i. It is thus convenient to order the possible patterns of leading bits of code words as follows (where in some cases, it is also required to indicate the relevant bits of one or even two of the subsequent code-words):
In addition, it is for the code-construction according to the present invention beneficial to consider the following ordering of the trailing bit patterns (with the arrival state of the STD also indicated, both the original one and the renumbered one) as outlined in Table 16. According to the present invention, code words can be divided into 7 different types as specific by their trailing bit pattern. With the short code-word length of only 3 bits (for the 2-to-3 mapping), a code-word type will depend on the bits of the current code word, and also on some (if not all) bits of the previously emitted code-word.
1
2
3
4
5
6
7
It should be noted that the ordered trailing bit patterns (of Table 16) are the mirrored versions of the corresponding ordered leading bit patterns (of Table 15). Next, the already mentioned renumbering of the STD-states is discussed. It is now convenient to renumber the states of the STD in terms of the ordering of the trailing bit-patterns as they were listed in Table 16. This new numbering is outlined in the last two columns of Table 16. The new renumbered states are denoted {grave over (σ)}i. With this new numbering, code words of type i will arrive in the (renumbered) STD-state with the same index, that is, {grave over (σ)}i; consequently, a basic rule is that:
code words of type i can be concatenated with any code word that belongs to a coding state of class 8−i as a subsequent code word.
It is to be noted that code words belonging to a coding state of class 8−i have leading bit patterns (from Table 15) with index l where 1≦l≦8−i. As an example, code words of type 3 (end with trailing bit pattern . . . 001010|) can be concatenated with code words from coding states of class 5, which implies that the latter code words may start with the leading bit patterns (Table 15) i=1, i=2, . . . , i=5. This division of code words into 7 different types of code words, and the arrangement of coding states into 7 different coding classes, forms the basis for the further code construction: in this way, the RLL constraints d=1 and r=2 always remain satisfied (also upon concatenation of code words). From Table 16, it is clear that the following hierarchy in fan-out applies for the renumbered STD-states:
F{grave over (σ)}
The renumbered STD-state {grave over (σ)}1 has the largest fan-out of all, and {grave over (σ)}7 the smallest one, with an enumerative ranking according to the decreasing fan-out from {grave over (σ)}1 to {grave over (σ)}7. With the renumbered STD-states, and a correspondingly rearranged connection matrix, denoted {grave over (D)}, the approximate eigenvector inequalities (for the “new” eigenvectors {tilde over (ν)}) are rewritten as:
Σj=17{grave over (D)}l,j3{tilde over (ν)}j≧22{tilde over (ν)}l, l=1,2, . . . ,7. (93)
The number of coding states per coding class is denoted by the vector p. Its relation to the approximate eigenvector {tilde over (v)} is given by (for the i-th component, with 1≦i≦7):
pi={tilde over (ν)}8−i. (94)
Note that with this advantageous construction, the coding classes have a numbering system that is exactly complementary to the numbering system of the renumbered STD-states; this could already have been obvious from Table 14, where the renumbering of STD-states was mentioned, but not explained. Further, again due to the specific construction of the different coding classes, the following inequality holds:
p1≦p2≦p3 . . . ≦p7. (95)
The Concept of Trivial Coding Classes
In the above reasoning, it has been assumed that all STD-states are visited as arrival states when emitting code-words from the FSM-codes of the RLL encoder. This corresponds with the situation of an approximate eigenvector where all its components are non-zero. However, in a code-construction by means of the ACH-algorithm, it is possible that some STD-states have a component of the approximate eigenvector that equals 0. Let us consider just for the sake of simplicity, the case where there is only one such STD-state, with index 8−j such that {tilde over (ν)}8−j=0 (the case with more than one such an STD-state is a trivial extension). The corresponding coding class has then index j, with pj=0, that is, the coding class is empty, since it contains no coding states. Such an empty coding class is referred to as trivial coding class. Therefore, the actual number of non-trivial (non-empty) coding classes, denoted Ncc, must satisfy the relation Ncc≦Tmax=1+(d+1)×(r+1). The hierarchy in the number of coding states for the different coding classes as outlined in Eq. (95), only applies for the non-trivial coding classes. This is explained for the practical example with d=1 and r=2 where coding class j is a trivial coding class (pj=0). The hierarchy in the numbers pi of the non-trivial coding classes then reads as (for the general case with the maximum number of coding classes equal to Tmax=1+(d+1)×(r+1)):
p1≦p2≦ . . . ≦pj−1≦pj+1≦ . . . ≦pT
Practical Design Choices.
As a convenient approximate eigenvector, one can chose v={3,5,5,2,4,2,0}, or, {tilde over (v)}={5,5,4,0,3,2,2}. For the numbers pj, which is the number of coding states in a coding class, one gets p={2,2,3,0,4,5,5}. There is one trivial empty coding class, that is, the one with index j=4. So, the number of non-trivial coding classes, denoted T or Ncc, equals 6. Denoting the coding classes by CCi, the following distribution of coding states over the coding classes results:
Following is a listing of Code-Words as they can be used in Each of the Coding Classes Coding Class CC1
Coding Class CC2
Same as for CC1.
Coding Class CC3
Coding Class CC4
Not applicable since trivial coding state.
Coding Class CC5
Coding Class CC6
Coding Class CC7
Same as for CC6.
Code Tables: Code with DC-control via Guided Scrambling
It should be noted that coding states Σ1 and Σ2 are using code words |000| and |001|; the three other coding states, Σ3, Σ4 and Σ5 use the other three code-words, |010|, |100| and |101|. These are two disjoint sets of code-words. As such, this effect can be used to limit the decoding window for the look-ahead decoding (to three next 3-bit code-words, in addition to the current 3-bit code-word). The code-table derived from the above considerations is listed as “Code-Table (A)” below:
Next, the parity-preserving property should be realized for this code in order to apply DC-control with it. As an intermediate step, Code-Table (A) is transformed into Code-Table (B) with some shuffles of table-entries within one and the same state. “Code-Table (B)” is listed below:
Code Tables with Parity-Preserve Property for DC-control
The above Code-Table (B) is not yet parity-preserving. By addition of two extra states, a parity-preserving RLL code is realized. The final Code-Table (C) becomes:
k=13 constraint through an extra coding shell
It is obvious from the above coding tables (PP version and non-PP version of the code) that it is possible to emit an infinite stream of zeroes (infinite repetition of entry “0” with user di-bit “00” from FSM-state Σ1). The objective is to realize a finite k-constraint through an extra coding shell to be carried out after the execution of the FSM-encoder. The description will now concentrate on the PP-version of the code, with its 7-state FSM. It can be analyzed from the coding table that a bit-pattern of |101|010| cannot be produced by this encoder. This aspect is used to perform substitutions on the channel bitstream based on this special pattern. At the encoder, this extra set of substitutions is carried out in an integrated way with the FSM-encoder; at the decoder, this extra set of substitutions is carried out before the sliding-block decoder (in case of hard-decision bit-detection). Describing this set of substitutions at the encoder as integrated with the FSM-encoder; the following 10 special cases have to be distinguished:
For each of these input patterns, the channel bitstream would become, by use of the code tables of the PP-version (Code-Table (C) above):
|000|000|000|000| (97)
By use of the substitutions, the channel bitstream is replaced by:
|000|101|010|010| (98)
It should be noted that the latter 12-bit string in the channel bitstream is unique since it cannot be generated by use of the FSM-encoder. Further, the current-state (cs) and next-state (ns) in the FSM-encoder at the beginning and end of the 12-but string are not changed: this makes it possible to perform the backward substitution at the side of the decoder on the channel bitstream without requiring the knowledge of the encoder state. This is beneficial for minimization of error propagation. Further, these substitutions preserve the overall PP-property of the code. It can be checked that a k=13 constraint can be realized in this way.
A d=1, r=2, k=12 RLL Code with Compact 2-to-3 Mapping, Suitable for Soft-Decision RLL Decoding
As a convenient approximate eigenvector for this example, one can chose v={6,10,10,5,9,4,6}, or, {tilde over (v)}={10,10,9,6,6,5,4}. For the numbers pj which is the number of coding states in a coding class, we then have p={4,5,6,6,9, 10, 10}. There is no trivial empty coding class, so, the number of non-trivial coding classes, denoted T or Ncc, equals T=Tmax=7. Denoting the coding classes by CCi, the following represents the distribution of coding states over the coding classes:
Code-Words that can be used in Each of the Coding Classes
Coding Class CC1
Coding Class CC2
Coding Class CC3
Coding Class CC4
Coding Class CC5
Coding Class CC6
Coding Class CC7
Code-Table without k-constraint
The resulting Code-Table for the 10-state FSM with the d=1, k=∞, r=2 RLL constraints is shown below:
Code-Table with k=12-constraint
It should be noted that in the above Code-Table, the code-word |101| with next-state Σ5 (as available from Coding-Class CC7) is not used. Therefore, it can be used to realize a finite k-constraint, that is, k=12, by duplicating state Σ1 with its first entry (|000| with next-state Σ1) replaced by said unused code-word |101| with next-state Σ5 into an additional coding state, denoted Σ11; also, the first entry of the 1 st Coding State Σ1 itself is changed from |000| with next-state Σ1 into |000| with next-state Σ11.
The resulting Code-Table for the 11-state FSM with the d=1, k=12, r=2 RLL constraints is shown below:
Number | Date | Country | Kind |
---|---|---|---|
04104449 | Sep 2004 | EP | regional |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/IB2005/052933 | 9/8/2005 | WO | 00 | 3/12/2007 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2006/030349 | 3/23/2006 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5943368 | Bergmans et al. | Aug 1999 | A |
6265994 | Kahlman | Jul 2001 | B1 |
6469645 | Coene | Oct 2002 | B2 |
6486804 | Coene | Nov 2002 | B2 |
6639525 | Coene | Oct 2003 | B2 |
6731699 | Pozidis et al. | May 2004 | B2 |
7119721 | Coene | Oct 2006 | B2 |
20010040518 | Coene | Nov 2001 | A1 |
Number | Date | Country |
---|---|---|
0241500 | May 2002 | WO |
Number | Date | Country | |
---|---|---|---|
20070257826 A1 | Nov 2007 | US |