Embodiments according to the invention relate to error correction and error detection of digital signals and particularly to an apparatus and a method for correcting at least one bit error within a coded bit sequence.
Due to the high integration density of electronic circuits and storages, the frequency of errors increases.
Apart from 1-Bit-errors, increasingly also 2-Bit-errors and general multi-bit errors are to be considered, i.e. to be corrected and to be detected. In particular, in error correction it is important to correct the occurred errors quickly, if possible within the current clock cycle in order to prevent a delayed processing of the corrected data as compared to the uncorrected data.
Frequently, data are written into a storage under an address and read out after some time. Here it is possible that the data when read out of the storage are faulty or corrupt and have to be corrected after reading it out.
Here, both one bit errors, two bit errors and generally multi-bit errors occur, which are caused randomly with decreasing probability, and also errors occur in which all memory cells take on the value 0 erroneously, which is to be referred to as “All-0”, and also errors where all memory cells take on the value 1, to be referred to here as “All-1”.
It is also of special interest to detect possible address errors with a high probability, as a faulty address for example when reading out of a storage, may lead to completely different data. It is possible to correct one bit errors by Hamming code or Hsia-codes and 2-Bit-errors relatively fast by BCH-Codes implemented in parallel.
Disadvantageous with prior solutions for 1-bit and 2-bit error correction is, for example, that the errors “All-0” and “All-1” are not part of error detection. Generally, it is of high interest to improve the reliability of error correction and error detection concepts.
A syndrome generator for forming an error syndrome of a linear code C of length n with an H-matrix H=(h1, . . . , hn) of n columns h1, . . . , hn of m components each such that the H-matrix is an (m, n)-matrix, wherein a codeword v=v1, . . . , vn of the code C comprises a first subword x1, . . . , xk+m of length k+m and a second subword a1, . . . , al of length l, wherein n=k+l+m. The code C is configured for correcting 1, . . . , t-bit errors in bits of the first subword and to detect 1, . . . , l bit errors in bits of the second subword so that the columns of the H-matrix H corresponding to the bits of the first subword are forming a first (m, k+m)-sub-matrix Hx=(h1x, . . . , hk+mx) and so that the columns of the H-matrix H corresponding to the bits of the second subword are forming a second sub-matrix Ha=(h1a, . . . , hla). All linear combinations of up to t columns of the first submatrix Hx, which do not result in the zero vector, are pairwise different. Moreover, all linear combinations of the columns of the second submatrix Ha are different from all linear combinations of up to t columns of the first sub-matrix Hx, which do not result in the zero vector, wherein t≧1, k>0, k+m≧4, and l>t+1.
Moreover, a syndrome generator for forming an error syndrome of a linear code C of length n having m check bits and an H-matrix H is provided, wherein a codeword v=v1, . . . , vn of the code C comprises a first subword u1, . . . , uk, c1, . . . , cm of length k+m and a second subword a1, . . . , al of length l with n=k+m+l. The code C is configured for correcting 1-bit, . . . , t-bit errors in bits of the first subword u1, . . . , uk, c1, . . . , cm and to detect errors in bits of the second subword a1, . . . , al. The H-matrix H=(Hu, Ha, Hc) of the code C is determined so that it consists of a first (m, k+m)-sub-matrix Hx=(Hu, Hc)=(h1x, . . . , hk+mx) having k+m columns with m components and a second (m, l)-sub-matrix Hy=Ha=(h1y, . . . , hly) having l columns with m components, so that an error syndrome is associated to each 1-bit, . . . , t-bit error in the bits u1, . . . , uk, c1, . . . , cm, so that pairwise different error syndromes unequal 0 are associated to different errors of said errors, respectively, and so that to each 1-bit error, . . . n-bit error in the bits a1, . . . , al, an error syndrome is associated that differs from each error syndrome of a 1-bit error, . . . , t-bit error in the bits u1, . . . , uk, . . . , cm. The first sub-matrix Hx is an H-matrix of a linear t-bit error correcting code of the length k+m, and wherein an arbitrary linear combination of the columns h1y, . . . , hly of the second sub-matrix Hy is unequal to an arbitrary linear combination of t columns of the first sub-matrix Hx, wherein t≧1, k+m≧4, and l>t+1.
Moreover, a circuitry comprising a syndrome generator configured to generate a syndrome based on a parity check matrix and a binary word comprising a first set of bits and a second set of bits is provided. For the first set of bits an error correction of one or more correctable bit errors within the first set is provided by the parity check matrix and for the second set of bits an error detection of one or more detectable bit errors within the second set is provided by the parity check matrix. The parity check matrix comprises a first subset of columns that are associated with the first set of bits within the binary word, and a second subset of columns that are associated with the second set of bits within the binary word. Syndromes generated by the first subset of columns in case one of the one or more correctable errors occurs within the first set of bits are all pairwise different for the one or more correctable errors and are also different from all syndromes generated by the second subset of columns in case an arbitrary error occurs within the second set of bits.
An embodiment of the invention provides an apparatus for correcting at least one bit errors within a coded bit sequence. The apparatus comprises an error syndrome generator and a bit error corrector. The error syndrome generator is configured to determine an error syndrome of a coded bit sequence derived by a multiplication of a check matrix with the coded bit sequence. The check matrix comprises a first sub-matrix, a second sub-matrix and a third sub-matrix. Each sub-matrix comprises a plurality of lines, wherein each line comprises a plurality of binary components. Further, at least a first predefined component or a second predefined component of each line of the first sub-matrix comprises a first bit value. The second sub-matrix comprises lines being linearly independent from each other and the first predefined component and the second predefined component of each line of the second sub-matrix comprises a same second bit value. The third sub-matrix comprises lines being linearly independent from each other and the first predefined component or the second predefined component of each line of the third sub-matrix comprises the first bit value. Further, an XOR-sum of the first predefined components of all lines of the first sub-matrix and the third sub-matrix is equal to the second bit value and an XOR-sum of the second predefined components of all lines of the first sub-matrix and the third sub-matrix is equal to 0. Additionally, a result of a multiplication of the check matrix and a test vector is equal to a result of a multiplication of the second sub-matrix and a resulting vector, wherein at least one component of the resulting vector comprises the second bit value. Further, the bit error corrector is configured to correct a bit error within the coded bit sequence based on the determined error syndrome of the coded bit sequence.
By using an error syndrome determined according to a check matrix with properties described above, the error correction and error detection abilities of the proposed concept may be significantly better than with known concepts. For example, the proposed concept enables one to differentiate every 1-bit error from All-1-errors or All-0-errors. Thus, it may not be the case that a word, which is read out of a storage, in case of a correctable 1-bit error is mixed up with an All-0-error or an All-1-error.
Embodiments according to the invention will be detailed subsequently referring to the appended drawings, in which:
In the following, the same reference numerals are partly used for objects and functional units having the same or similar functional properties and the description thereof with regard to a figure shall apply also to other figures in order to reduce redundancy in the description of the embodiments.
A syndrome generator for forming an error syndrome of a linear code C of length n with an H-matrix H=(h1, . . . , hn) of n columns h1, . . . , hn of m components each such that the H-matrix is an (m, n)-matrix, wherein a codeword v=v1, . . . , vn of the code C comprises a first subword x1, . . . , xk+m of length k+m and a second subword a1, . . . , al of length l with n=k+m+l. The code C is configured for correcting 1, . . . , t-bit errors in bits of the first subword and to detect 1, . . . , l bit errors in bits of the second subword so that the columns of the H-matrix H corresponding to the bits of the first subword are forming a first (m, k+m)-sub-matrix Hx=(h1x, . . . , hk+mx) and so that the columns of the H-matrix H corresponding to the bits of the second subword are forming a second sub-matrix Ha=(h1a, . . . , hla). All linear combinations of all subsets of up to t columns of the first submatrix Hx, which do not result in the zero vector, are pairwise different. Moreover, all linear combinations of all subsets of the columns of the second submatrix Ha are different from all linear combinations of all subsets of up to t columns of the first sub-matrix Hx, which do not result in the zero vector, wherein t≧1, k>0, k+m≧4, and l>t+1.
Before the proposed concept is described in greater detail, some theoretical basics and basic terms on linear block codes, in particular Hamming codes, Hsiao codes and BCH-codes are briefly presented. For example, these are also described in “Fujiwara, E., Code Design for Dependable Systems, Wiley, 2006, p. 49-53, p. 98-101 and in Tzschach, H. and Haflinger, G., Codes für den störungsgesicherten Datentransfer, Oldenburg Verlag, 1993, p. 111-121”.
A Hamming code is a linear block code with a code distance 3. If m is the number of check bits, its length is n=2m−1. The number of data bits is k=2m−1−m. As any linear code, the Hamming code may as usual be described by a generator matrix G, briefly G-matrix, and a check matrix H (also called parity-check matrix), briefly H matrix. The check matrix of a unshortened Hamming code is an (m,n) matrix whose columns are any possible different 2m−1 binary vectors unequal to 0. These columns are also described as m-digit binary numbers, and the following applies
H=(h1, . . . , h2
wherein ibin designates the representation of i as an m-digit binary number.
A Hamming code may be shortened, as any other linear block code by eliminating a certain number of columns in the check matrix of the unshortened code. Apart from that, columns may also be exchanged in thus the check matrix may be transformed.
From the check matrix of a linear code a generator matrix may be determined, briefly called G matrix. The generator matrix is a (k,n) matrix. If k information bits u1, . . . , uk are present, the same are coded by the generator matrix into a code word v
v=(v1, . . . , vn)=u·G=(u1, . . . , uk)·G
If a word v′=v′1, . . . , v′n is checked whether it is a code word, a syndrome S is formed, with
S=H·v′T
with S=S1, . . . , Sm. If S=0, no error is detected. If S=hi, a 1-bit error is present in the i-th bit of v′.
The error correction of the bits v′1, . . . , v′n may be done by correction circuits K1, . . . , Kn which determine a correction value Δvi from the error syndrome S, which is XORed (linked by a logical XOR function) with v′i. For i=1, . . . , n in case of a 1-bit error the correction circuit K, outputs a value 1, if S=hi. If the error syndrome is equal to 0, the correction circuit Ki outputs the value 0.
A Hsiao-code is a linear code with a code distance of 4. If the Hsiao-code has m check bits, its check matrix H consists of all m-digit binary vectors comprising an odd number of ones. The length of an (unshortened) Hsiao-code with m check bits is n=2m−1, as there are 2m−1 different m-digit binary vectors having an odd number of ones. By deleting columns and by reordering columns of the unshortened Hsiao-code, a check matrix of a shortened Hsiao-code is obtained. Testing a word v′=v′1, . . . , v′n is again done by checking the error syndrome
S=H·v′T
If S=hj, i.e. equal to the j-th column of the check matrix, a 1-bit error is corrected in the j-th bit, by XOR-ing (applying a logical XOR-function) a correction value Δvj=1 with v′j. This correction value Δvj may be determined from the error syndrome S by a correction circuit Kj. The correction circuit Kj then outputs a value 1, if S=hj. If S is a binary vector with an even number of ones, an incorrectable error is indicated.
As the application of the proposed concept to BCH-codes (Bose-Chaudhuri-Hocquenghem-Codes) is also of special interest, some characteristics of BCH-codes are to be described. For example, they are also described in “Tzschach, H. and Haβlinger, G.: Codes für den störungssicheren Datentransfer, Oldenburg Verlag 1993, p. 111-121” and “Lin, S., Costello, D.: Error Control Coding, Prentice Hall, 1983, chapter 6”.
A BCH-code is a special cyclic code and thus a linear code. A BCH-code may be described as a cyclic code by a special generator polynomial G(z) and as a linear code by a generator matrix G and by a check matrix H.
In case of a 2-bit error correcting BCH-code, the generator polynomial may in its simplest form be represented as
G(z)=mα(z)·mα
Here, mα(z) is a primitive polynomial also serving as a modular polynomial of the considered Galois field. α is a primitive element of the Galois field and root of the polynomial. The polynomial mα
G(z)=mα(z)·mα
Without integrating the overall parity, the check matrix may be represented in its separated form as
wherein α is a primitive element of the Galois field GF(2M) and the exponents of a are each to be interpreted modulo 2M−1. The parity may be included in the error detection by selecting the check matrix as
wherein in the last row there are only ones.
A 1-bit error in the i-th bit position is described as [i], an L-bit error in the positions i1, i2, . . . , il as [i1, i2, . . . , iL]. To each error [i1, . . . , iL] an n-component error vector e(i1, . . . , iL)=(e0, . . . , en−1) is associated, wherein
The component ej of the error vector e[i1, . . . , iL] is equal to 1 exactly when the corresponding j-th bit is faulty.
To an error [il, . . . , iL] with the error vector e=e[i1, . . . , iL] an error syndrome
is associated.
By deleting columns and by reordering columns of the check matrix HBCHsep, a shortened BCH-code is obtained which is adapted to a required word width.
If the parity is not considered, the code distance is 5 and if the parity is considered, the code distance is 6. Then, 1-bit errors and 2-bit errors may be corrected using the syndrome. The syndromes of all 3-bit errors, parity included, are different from the syndromes of all 1-bit and 2-bit errors, but they may be the same among themselves.
The encoding of a BCH-code and a shortened BCH-code as a special linear code may be done with the help of a generator matrix and the decoding with the help of a check matrix. The connection between the generator polynomial and generator matrix and H-matrix is, for example, described in Lin, S. and Costello, D.: Error Control Coding, Prentice-Hall, 1983, p. 92-95”.
In the following, the inventive concept is described by some general and some detailed embodiments.
Further, the second sub-matrix Ha comprises lines being linearly independent from each other (i.e. each line of the second sub-matrix is linearly independent from each other line of the second sub-matrix) and the first predefined component and the second predefined component of each line of the second sub-matrix Ha comprises a same second bit value (0 or 1) which is different from the first bit value. The third sub-matrix Hc comprises lines being linearly independent from each other and the first predefined component or the second predefined component of each line of the third sub-matrix Hc comprises the first bit value (1 or 0).
An XOR-sum of the first predefined components of all lines of the first sub-matrix Hu and the third sub-matrix Hc is equal to the second bit value 0 and the XOR-sum of the second predefined components of all lines of the first sub-matrix Hu and the third sub-matrix Hc is equal to the second bit value 0. Additional results of a multiplication of the check matrix H and a test vector is equal to a result of a multiplication of the second sub-matrix Ha and a resulting vector, wherein at least one component of the resulting vector comprises the second bit value (0 or 1). Further, the bit error corrector 120 corrects a bit error within the coded bit sequence 102 based on the determined error syndrome 112 of the coded bit sequence 102 to obtain a corrected bit sequence 122.
By using an error syndrome 112 derivable by a check matrix described above, an error correction circuit for 1-bit and 2-bit errors can be realized, which is able to detect also the errors All-0 and All-1, for example. In other words, the apparatus 100 enables to differentiate every 1-bit error from errors All-1 and All-0. Thus, for example, it may not be the case anymore that a word read out of a storage in case of a correctable 1-bit error is mixed up with an All-0 or All-1 error. The detection and/or correction of All-0 and All-1 errors is of high interest, because these failures are very common.
The first bit value and the second bit value may be logical 0 or logical 1, or a high level or a low level of a signal in the circuitry. Therefore, there are two possible cases. Either the first bit value is equal to 1 (logical 1) and the second bit value is equal to 0 (logical 0) or the first bit value is equal to 0 and the second bit value is equal to 1. Both cases represent equivalent implementations of the described concept.
Further, a line of a matrix may be a row or a column of a matrix. Since a matrix is easy to transpose, the inventive concept can be realized independent from whether a line of a matrix is a row or a column. Therefore, there are again two possible cases. Either each mentioned line of a matrix is a column of the respective matrix and the same components (e.g. first predefined components or second predefined components) of each line of a matrix represents a row of this matrix. Otherwise each line of a matrix is a row of the respective matrix and the same components of the lines of a matrix represent a column of this matrix.
Consequently, in connection with the described concept, of each line of the first sub-matrix, of the second sub-matrix and of the third sub-matrix is a column of the respective sub-matrix. The first predefined components of the lines of the first sub-matrix Hu, of the second sub-matrix Ha and of the third sub-matrix Hc represent a row of the check matrix H and the second predefined components of the lines of the first sub-matrix Hu, of the second sub-matrix Ha and of the third sub-matrix Hc represent another row of the check matrix H. Alternatively, each line of the first sub-matrix Hu, of the second sub-matrix Ha and of the third sub-matrix Hc is a row of the respective sub-matrix. The first predefined components of the lines of the first sub-matrix Hu, of the second sub-matrix Ha and the third sub-matrix Hc represent a column of the check matrix H and the second predefined components of the lines of the first sub-matrix Hu, of the second sub-matrix Ha and of the third sub-matrix Hc represent another column of the check matrix H.
Each line of a matrix comprises a plurality of binary components. In other words, each component is either equal to 1 or equal to 0. In this connection, a first predefined component and a second predefined component may be actually the first and the second component of a line, but they can also be arbitrary other components (e.g. the last and the next to last component or the third component and the fifth component or another predefined component combination). However, the first predefined component of the first sub-matrix, the second sub-matrix and the third sub-matrix are the same components within the lines of the respective matrix, which is accordingly valid for the second predefined components of the lines of the first sub-matrix, the second sub-matrix and the third sub-matrix. For example, if the first predefined component is the n-th component of a line of the first sub-matrix, then the first predefined component of a line of the second sub-matrix means also the n-th component of the line. Same is valid for the third sub-matrix as well as for the whole check matrix.
The check matrix may also be called parity-check matrix.
For example, the check matrix may be represented in a separated form. Further, the check matrix may be a check matrix of a shortened Hamming code, a shortened Hsiao-code or a shortened BCH-code, for example.
The error syndrome generator 110 may determine the error syndrome 112 by multiplying the check matrix with the coded bit sequence 102. Alternatively, the error syndrome generator 110 may comprise a storage containing a look-up table. This look-up table may contain information about error syndromes corresponding to different coded bit sequences 102. In other words, the look-up table may contain for each possible coded bit sequence the corresponding error syndrome derived by a multiplication of the check matrix with the coded bit sequence 102. In this example, the error syndrome generator 110 may easily determine the error syndrome 112 by taking the stored error syndrome associated with the coded bit sequence 102.
The error syndrome generator 110, the bit error corrector 120 and/or other optional elements described later on may be independent hardware units or part of a computer or microcontroller as well as a computer program or a software product for running on a computer or microcontroller.
The error syndrome generator 110, the bit error corrector 120 and/or other optional components described later on may be implemented independent from each other or at least partly together. For this, for example, the functionality of the error syndrome generator 110, the bit error corrector 120 and/or other optional components described below may be at least partly united to a combined hardware unit or software unit by a synthesis tool.
During a multiplication of the check matrix H with the coded bit sequence 102, a first group of bits of the coded bit sequence 102 is multiplied with the first sub matrix, a second group of bits of the coded bit sequence is multiplied with the second sub-matrix and a third group of bits of the coded bit sequence is multiplied with the third sub-matrix. In other words, the error syndrome of the coded bit sequence is derived based on a multiplication of the first sub-matrix with a first group of bits of the coded bit sequence, a multiplication of the second sub-matrix with the second group of bits of the coded bit sequence, and a multiplication of the third sub-matrix with a third group of bits of the coded bit sequence.
In some embodiments of the invention, the first group of bits may represent information bits, the second group of bits may represent address bits and the third group of bits may represent check bits. Therefore, the first group of bits may also be called information bits or payload data bits or useful data bits, the second group of bits may be called address bits and the third group of bits may be called check bits.
For example, the coded bit sequence or part of the coded bit sequence may be stored by an addressable storage, also called a storage unit, memory or memory unit (e.g. read only memory, random access memory or non volatile memory).
The first group of bits (data bits) may be independent from the second group of bits (address bits). Therefore, only the first group of bits and the third group of bits of the coded bit sequence may be stored at an address of the addressable storage indicated by the second group of bits. Alternatively, the coded bit sequence may also be coded by an inner code, so that at least one bit of the first group of bits depends on at least one bit of the second group of bits.
In the following, an embodiment of the invention is described in more detail. In this example, the lines of the matrices are columns, the first predefined components of the lines of the matrices represent the first row of the matrices, the second predefined components of the lines of the matrices represent the second rows of the matrices, the first bit value is equal to 1 and the second bit value is equal to 0. If the description of the detailed embodiment several additional and/or optional features can be implemented all together or one or some of them may be implemented independent from the other features described.
It is illustrated in
v=(u,a)·G
In the storage 12 under the address a the code word v is stored, whose bits depend both on the payload data (information bits) and also on the address (address bits). If the generator matrix is used in its systematic form
G=(Ik+1,Pk+Lm)
The code word v has the form v=u, a, c and the check bits c added to the payload data bits and the address bits are designated by
c=(u,a)·P,
while the payload data bits u and the address bits a, are not modified in this example. Ik+l is the (k+l) dimensional identity matrix and P is a (k+l,m) matrix determining the test equations of the code.
The encoding including the address bits for a generator matrix in the systematic form is illustrated in
ST=(s1,s3)T=(S1,S2, . . . ,Sm)T=H·(u′l, . . . ,u′ka′l, . . . ,a′l,c′l, . . . ,c′m)T.
The address bits a1′, . . . , a′l−1 provided by the address generator and the constant value 1 form, as described in detail later, the address bits a′1, . . . , a′l. The check matrix H of the shortened BCH-code consists of a first (m,k) sub-matrix Hu, a second (m,l) sub-matrix Ha and a third (m,m) sub-matrix Hc, wherein the first k columns of the check matrix H form the sub-matrix Hu, the subsequent l columns form the sub-matrix Ha and the last m columns the sub-matrix Hc. A sub-matrix may also be called a partial matrix. The following applies here:
For the components S1, S2, . . . , Sm of the syndrome S=(S1, . . . , Sm)=(s1, s3) applies
(s1,s3)T=(S1, . . . ,Sm)T=(Hu,Ha,Hc)·(u′1, . . . ,u′k,a′1, . . . ,a′l,c′1, . . . ,c′m)T,
and the syndrome generator 31 realizes at its m outputs for i=1, . . . , m the Boolean functions
Si=hi,juu′1⊕ . . . ⊕hi,kuu′k⊕hi,lua′1⊕ . . . ⊕hi,laa′l⊕hi,lcc′1⊕ . . . ⊕hi,mcc′m
which are uniquely determined by the elements hi,ju, hi,ja, hi,jc of the sub-matrices Hu, Ha, Hc. A concrete implementation, e.g. by XOR-gates, is easy realizable, so that the proposed syndrome generator is easily described by the concrete form of the matrices Hu, Ha, Hc.
The matrices Hu, Ha, Hc are determined by deleting certain columns and by reordering columns from the columns of the (m,2M−1) check matrix HunverkBCH of an unshortened 2-bit error correcting BCH-code of length 2M−1 such that m+l+k<2M−1. Here, the check matrix of the unshortened code is selected in its separated form, for example. The matrix HunverkBCH then has the following form
As the i-th column of the matrix H1 is determined by αi, i=0, . . . , 2M−2 and α is a primitive element of the Galois field GF(2M), all 2M−1 M-digit binary vectors, except for 0, occur as columns of H1. Now a j-th component and a k-th component of the first M components of the check matrix are selected, wherein j≠k. The j-th component is designated as the first (selected) component (first predefined component) and the k-th component as the second (selected) component (second predefined component).
As α is a primitive element of the Galois field GF(2M), and all 2M−1 possible m-digit binary vectors occur as columns of the check matrix H1, there are for each of the values 01, 10 and 11 2M−2 columns of the check matrix H1 taking on the value 01, 10 and 11 in the two selected components (predefined components). Apart from that, there are 2M−2−1 columns of the matrix H1 taking on the value 00 in the two selected components. All columns of the check matrix HunverkBCH are classified into four disjoint sets Sp00, Sp10, Sp01 and Sp11, wherein Sp00 contain all 2M−2−1 columns with the first two components 00, Sp10 all 2M−2 with the first two components 10, Sp01 all 2M−2 columns with the first two components 01 and Sp11 all 2M−2 columns with the first two components 11.
According to the described concept, l linearly independent columns h1a, . . . , hla form the matrix Ha
Ha=(h1a, . . . , hla),
wherein hjaεSp00 applies.
As the first two components of Sp00 are equal to 00 (first predefined component and second predefined component of each line of the first sub-matrix comprises the same second bit value), there are m−2 linearly independent columns, and l≦m−2 applies. For l=m−2, the (l, l) matrix {tilde over (H)}a, resulting from Ha, by deleting the first two lines (which say 0, . . . 0) may be invertible.
In other words, a number of bits of the second group of bits of the coded bit sequence may be smaller than or equal to a number of bits of the third group of bits of the coded bit sequence minus 2.
The columns of the matrix Hc,
H=(h1c, . . . ,hmc),
are selected so that they are linearly independent and that their first two components (first predefined component and second predefined component) are unequal 00 (first predefined component or second predefined component of each line of the third sub-matrix comprises the first bit value), so that for i=1, . . . , m the following applies
hicε{Sp10∪Sp01∪Sp11}
The columns of the matrix Hc form the set SpH
The columns of the matrix Hu,
Hu=(h1u, . . . ,hku),
are selected so that the first two components are unequal 00 (first predefined component or second predefined component of each line of the second sub-matrix comprises the first bit value), so that for i=1, . . . , k the following applies
hiuε{Sp10∪Sp01∪Sp11}\SPH
In other words, the lines (in this example, the columns) of the first sub-matrix are all different from the lines of the third sub-matrix.
In addition to that, the columns of the matrices Hu, Ha, Hc are determined so that the following applies:
In other words, each component of the test vector being multiplied with the component of a line of the first sub-matrix and of the third sub-matrix comprises the first bit value and each component of the test vector being multiplied with a component of a line of the second sub-matrix comprises the second bit value.
In the following it is to be described how the matrices Hu, Ha, Hc of the inventive syndrome generator may be determined practically.
From the sets Sp10, Sp01 and Sp11, the sets Spe10, Spe01, Spe11 are formed by deleting two random columns each and summarizing the deleted column into the sets Sp210, Sp201 and Sp211. Thus, the set Sp201 contains the two columns which were deleted from the set Sp01 in order to determine the set Spe01.
From the set {Spe10∪Spe01∪Spe11} m linearly independent columns are determined, designated by h1c, . . . hmc and which form the matrix (third sub-matrix)
Hc=(h1c, . . . , hmc).
As a set, these columns are combined into the set SpH
From the set Sp00 l columns are determined which are linearly independent. These columns are designated by h1a, . . . , hla and they form the matrix (second sub-matrix)
Ha=(h1a, . . . , hla).
The matrix Hu (first sub-matrix) consists of k columns hlu, . . . , hku, wherein
hiuε{Spe10∪Spe01∪Spe11}\SPH
apply and wherein at least one column from Spe10, at least one column from Spe01 and at least one column from Spe11 is contained in {h1u, . . . , hku}.
Thus, Hu contains at least one column whose first two components are equal to 10, at least one column whose first two components are equal to 01 and at least one column whose first two components are equal to 11.
More general, the first sub-matrix comprises at least one line with the first predefined component being equal to the first bit value and the second predefined component being equal to the second bit value, at least one line with the first predefined component being equal to the second bit value and the second predefined component being equal to the first bit value and at least one line with the first predefined component and the second predefined component being equal to the first bit value.
Now, the XOR-sum of the first and the second components of the columns of Hu and Hc are determined. Depending on the value of this XOR-sum, the following four cases are considered:
From the matrices Hu and Hc obtained so far, now the vector a″1, . . . , a″l is determined by solving the linear equation system
If i, 1≦i≦l so that a″i=0, then by the check matrix H=(Hu Ha Hc) determined so far, the syndrome generator is determined. At the input 314 of
Then, in Hu a column hju with the value of the first two components (0,1) is for example replaced by a column hεSp201 which was not part of Hu before. The matrix Hu modified this way is designated by Hu′. The solution of the linear equation system
then inevitably leads to a solution with
and hju+h≠0.
If a″1, . . . , a″l is the solution of equation (9), then after this modification of Hu into Hu′ a″i=0. As illustrated in
The just determined H-matrix may then determine, for example, the XOR trees implementing the syndrome generator. In this example, the syndrome generator has, for example, the following advantageous characteristics:
The concept described for determining a syndrome generator by determining its check matrix may be generalized relatively easily, if further conditions regarding columns of the check matrix are to be fulfilled. As an example of such a condition the case is regarded that in each column of the check matrix the number of ones in a subset of components (predefined plurality of components) of the column is odd. In other words, an XOR-sum of a predefined plurality of components of each line of the check matrix H is equal to a same bit value. As an example for such a subset, here the lower N components of each column are regarded belonging to the matrix H3. The number of ones in the lower N components thus is to be odd. If this condition is fulfilled, the parity P may be determined as an XOR-sum via the components of the sub-syndrome s3, which may be done by an XOR tree with only N inputs. For the determination of the overall parity from the data bits, the address bits and the check bits, however, an XOR tree with n inputs is required, wherein n is the length of the code.
For example, for a parity bit a row may be added to the check matrix comprising only ones. In other words, a predefined same component of all lines of the check matrix may comprise a same bit value.
From the columns of the check matrix HunverkBCH with 2M−1 columns, the columns of this matrix are determined fulfilling the required condition. It is here the columns comprising an odd number of ones in the N bottom components. Depending on whether the first two components of these columns are 00, 10, 01 or 11, these columns are associated to the set Sp*00, Sp*10, Sp*01 and Sp*11.
Based on these sets Sp*00, Sp*10, Sp*01 and Sp*11 just as described for the set Sp00, Sp10, Sp01 and Sp11, a check matrix H*=(H*u, H*a, H*c) and thus a syndrome generator may be determined, so that the columns of its check matrix H* comprise an additional characteristic. Here it is the characteristic that the bottom N components comprise an odd number of ones.
A concrete example is described for N=7 and the Galois field GF(27). As a modular polynomial, the primitive polynomial mα=z7+z3+1 is used, for example, indicated in
“Peterson, W., and Weldon, E.: Error Correcting Codes, 2. Auflage, MIT Press, 1972, Annex C, S. 476”. The length of the unshortened code is n=27−1=127. The H-matrix of the unshortened BCH-code for the 2-bit error correction then is
wherein the exponents j of a′ are to be regarded as modulo 127, so that for example the exponent 3·126 means (3·126) modulo 127=124. The values αi and α3i in the column αi, α3i are initially illustrated in the vector illustration as 2 seven digit binary vectors, combined into a 14-digit binary vector and regarded as a 14-digit binary number. This 14 digit binary number may be represented as a decimal number.
The following applies
(α0,α0)=(00000010000001)bin=129
(α1,α3)=(00000100001000)bin=264
(α2,α6)=(00001001000000)bin=576
Wherein the 129 is the decimal value for the first column, 264 is the decimal value for the second column and 576 is the decimal value for the third column.
Here, the left most bit is the first bit and the right most bit is the fourteenth bit. The first bit and the second bit are underlined. These are the bits whose XOR-sum across all columns of the check matrix of the shortened BCH-code are 0,0. The columns of the unshortened H-matrix are then given by the following decimal numbers.
129, 264, 576, 1060, 2098, 4107, 8280, 1261, 2398, 4701, 9285, 3212, 6496, 12854, 8363, 1482, 2932, 5663, 11377, 7351, 14627, 13962, 10704, 6061, 12154, 6895, 13646, 11988, 6541, 13160, 8950, 399, 888, 1663, 3143, 6172, 12393, 9470, 3535, 7004, 13901, 10444, 5572, 11012, 4768, 9490, 3737, 7489, 14892, 12530, 9647, 4074, 8038, 15878, 14512, 13723, 12241, 7077, 14138, 10955, 4604, 9055, 725, 1285, 2600, 5202, 10301, 5363, 10535, 5802, 11586, 7860, 15675, 16067, 14780, 14331, 11239, 5006, 10096, 2751, 5475, 10798, 4322, 8486, 1698, 3330, 6672, 13321, 11464, 7652, 15126, 12985, 8659, 1973, 3891, 7683, 15384, 15561, 15852, 16342, 15261, 13281, 9150, 1003, 1902, 3654, 7188, 14377, 13530, 11773, 8151, 16149, 15009, 12698, 10201, 3045, 5918, 11897, 6391, 12551, 9912, 2523, 4981, 9751, 2225, 4371, 8721
Based on these 127 columns, now the sets Sp00, Sp10, Sp01 and Sp11 are formed, whose first two components in binary representation are 00, 10, 01 and 11. Thus, for example the columns 129, 264 and 576 are part of set Sp00, as the first two components of these numbers are equal to 00 in a binary representation.
Based on the sets Sp00, Sp10, Sp01 and Sp11, the sets Sp*00, Sp*10, Sp*01 and Sp*11 are determined by the additional condition that the columns of the check matrix in their binary representation in the bits 8-14 comprise an odd number of ones. Thus, the columns 1, 2 and 3 (129, 264, 567) belong to Sp*00, as these columns belong to Sp00 and in addition to that comprise, in the bits 8-14 one 1 each, i.e. an odd number of ones.
The following applies:
Sp*00={129, 264, 576, 2098, 1261, 2398, 1482, 1663, 3535, 3737, 3330, 1003, 1902, 3654, 2523, 2225}
Sp*10={8280, 9285, 12154, 11988, 8950, 10444, 11012, 9647, 12241, 10301, 11239, 100%, 8486, 9150,11897,9912}
Sp*01={4107, 4701, 5663, 7351, 6541, 6172, 4768, 7077, 4604, 5202, 5363, 5802, 7860, 5006, 4322, 6672, 7652, 8151, 4981, 4371}
Sp*11={14627, 13160, 14892, 15675, 16067, 15126, 15561, 13281, 14377, 16149, 12698, 12551}.
From the set Sp*10, the set Spe10 is formed, by removing the two columns 9647, 12241 and combining these two columns into the set Sp210={9647, 12241}. The following applies.
Spe10={8280, 9285, 12154, 11988, 8950, 10444, 11012, 10301, 11239, 10096, 8486, 9150, 11897, 9912}.
From the set Sp*01, the set Spe01 is formed, by removing the two columns 7077, 4604 and combining these two columns into the set Sp201={7077, 4604}. The following applies:
Spe01={4107, 4701, 5663, 7351, 6541, 6172, 4768, 5202, 5363, 5802, 7860, 5006, 4322, 6672, 7652, 8151, 4981, 4371}.
From the set Sp*11, the set Spe11 is formed, by removing the two columns 16149, 13281 and combining these two columns into the set Sp211={16149, 13281}. The following applies:
Spe11={14627, 13160, 14892, 15675, 16067, 15126, 15561, 14377, 12698, 12551}.
From the set Sp*00, m−2=14−2=12 linearly independent vectors are selected forming the matrix Ha. The following applies:
Ha=(129, 264, 576, 2098, 1261, 2398, 1482, 3737, 3330, 1003, 3654, 2225).
From the set Spe10∪Spe01∪Spe11 14 linearly independent columns are determined forming the matrix Hc. The following applies:
Hc=(8280, 4107, 6672, 9285, 4768, 11012, 6172, 5202, 8486, 4371, 4322, 10444, 12551, 14377).
These columns form the set SpH
SpH
From the set {Spe10∪Spe01∪Spe11}\spH
Hu=(4701, 14627, 6541, 13160, 14892, 10301, 5802, 5006, 10096, 12698, 9912, 5663, 11988, 8950, 15675, 7351).
For the XOR-sum of the first two components of the columns of Hu and Hc the value 10 results. To obtain a value 00 for this sum, a column with the first two components 01 is replaced by a column with the first two components 11 of Spe11, so that the XOR-sum now is 00. Concretely, column 7351 is replaced by column 16149 of Spe11. The matrix Hu is now:
Hu=(4701, 14627, 6541, 13160, 14892, 10301, 5802, 5006, 10096, 12698, 9912, 5663, 11988, 8950, 15675, 16149)
From the thus determined matrices Hu, Ha, Hc now the vector a″1, . . . , a″l is determined for which
applies.
Due to
SAll1=00010000110110
a″1, . . . , a″12 is determined as the solution of the linear equation system
sAll1=Ha·(a″1, . . . , a″12)T
for a′1, . . . , a′12=101000000011. As e.g. a′2=0, the syndrome generator is determined by the just determined check matrix simply by an implementation of the corresponding linear equations with a synthesis tool, for example.
The parity signal results in the presented embodiment as an XOR operation of the components of the sub-syndrome s3, i.e. by an XOR operation of the components 8 to 14 of the syndrome S. If the condition that the components 8 to 14 of the check matrix contain an odd number of ones is not required, the check matrix may also be supplemented by a line consisting of all ones. In a 2-bit error correcting BCH-code, then an odd number of check bits is obtained.
It is illustrated in
More general, the NOR-gate 34 and the AND-gate 35 may also be called same-bit-value-detector. A same-bit-value-detector may provide a signal indicating whether or not all bits of the first group of bits and all bits of the third group of bits of the coded bit sequence comprise a same bit value (All-0 or All-1).
Here, hiu is the i-th column of the matrix Hu and h a column of the matrix Hu or a column of the matrix Hc, wherein h≠hiu.
Correction circuits are for example also described in “Okamo, H. and Imai, H.: A Construction Method for Decoders of BCH-Codes for Bose Chaudhuri-Hocquenghem and Reed Salomon Codes, IEEE Trans. Comp. C 36, No 10, pp. 1165-1171, 1985”.
Thereby, hjc is the jth column of matrix Hc and h is a column of the matrix Hu or the matrix Hc with h≠hjc.
wherein ha is a column of matrix Ha, h a column of the matrices Hu, Ha, Hc with h≠ha and h* and h′ are columns of matrices Hu and Hc with h*≠h′.
For i=1, . . . , l, for the correction value Δai, the following applies
Thereby, hia is the ith column of matrix Ha and h is a column of matrices Hu, Ha, Hc with h≠hia.
In
ukorrOR=Δu1⊕Δu2⊕ . . . ⊕Δuk
at its output.
In
ukorrXOR=Δu1⊕Δu2⊕ . . . ⊕Δuk
at its output.
In
ckorrOR=Δc1Δc2 . . . Δcm
at its output.
In
ckorrXOR=Δc1⊕Δc2⊕ . . . ⊕Δcm
at its output.
Since the used BCH code is shortened, it can happen that a multi-bit error is mapped to the syndrome S(1) of a 1-bit error, wherein S(1) is equal to a column of the check matrix of the unshortened BCH code, which had been deleted when reducing the matrix. This situation can be detected easily when the signals ukorrOR and ckorrOR are both equal 0, but the error syndrome S(1) of a 1-bit error exists.
The proposed concept is now to be described at a particularly simple example of a unshortened Hamming code having four information bits u1, u2, u3, u4, four check bits c1, . . . , c4 and two address bits a1, a2. The word width k=4, m=4 and l=2 are selected to be small intentionally in order to be able to illustrate the concept as clearly as possible.
The check matrix of the unshortened Hamming code is
The set Sp00 of the columns of the check matrix whose first two components are equal to 0,0 is
Sp00={(0010)T,(0001)T,(0011)T}.
The set Sp01 of the columns of the check matrix whose first two components are equal to 0,1 is
Sp01={(0110)T,(0101)T,(0111)T,(0100)T},
The set Sp10 of the columns of the check matrix whose first two components are equal to 1,0 is
Sp10={(1010)T,(1001)T,(1011)T,(1000)T}.
The set Sp11 of the columns of the check matrix whose first two components are equal to 1,1 is
Sp11={(1110)T,(1101)T,(1111)T,(1100)T}.
As columns of the (second) sub-matrix Ha, two linearly independent columns are selected from Sp00, e.g. columns (0010)T, (0001)T.
As columns of the (third) sub-matrix Hc, four columns are selected from Sp10 and Sp01 namely columns (0100)T, (0111)T, (1000)T, (1001)T, that are linearly independent. As columns of the (first) sub-matrix Hu, four columns are selected from Sp11, namely columns (1100)T, (1101)T, (1110)T, (1111)T. In the first two components, each of the values 10, 01, 11 occurs an even number of times, so that the XOR-sum of the first and second components of the matrix
is equal 00. For the syndrome S=S1, S2, S3, S4, we have
S=H·(u,a,c)T
S1=u1+u2+u3+u4+c1+c4
S2=u1+u2+u3+u4+c2+c3
S3=u2+u4+a1+c3
S4=u3+u4+a2+c3+c4
For the two-dimensional binary vector a″1, a″2, determined according to equation (7), the following results
and, hence,
with the solution a″1=1 and a″2=0.
Since a″2=0, constantly a2=1 is set, which results in equations
S1=u1+u2+u3+u4+c1+c4
S2=u1+u2+u3+u4+c2+c3
S3=u2+u4+a1+c3
S4=u3+u4+1+c3+c4
which logically describes a syndrome generator according to the described concept, whose implementation may be realized, for example, with a commercially available synthesis tool.
The available addresses are here only addresses a1, a2=0,1 and a1, a2=1,1. The syndrome of the vector (0000a1, a2 0000) is S=(00a11) and, hence, unequal 0. The syndrome of the vector (1111a1, a21111) is equal S=(00ā11) and, hence, unequal 0. Hence, the vectors (0000a1, a20000) and (1111a1, a21111) are never code vectors.
Vector 0000a1, a2 0100 will be considered as an example of a vector having a one in the bits stored in the memory. The associated syndrome is S=(01a11). The same has at least 2 ones. By checking all possible 1-bit errors, it is easy to confirm that no 1-bit error can modify the vector 0000a1, a20100 into a code word with the error syndrome S=0.
A respective statement applies for all vectors having exactly one 1 in bits u1, u2, u3, u4 c1, c2, c3, c4. An example for the circuit for determining the correction values K1u, K2u, K3u, K4u, K1a, K1c, K2c, K3c, K4c is shown in
The correction circuit K1u 81 outputs the correction values Δu1=1 exactly when S=1100.
The correction circuit K2u 82 outputs the correction values Δu2=1 exactly when S=1110.
The correction circuit K3u 83 outputs the correction values Δu3=1 exactly when S=1101.
The correction circuit K4u 84 outputs the correction values Δu4=1 exactly when S=1111.
The correction circuit K1a 85 outputs the correction values Δa1=1 exactly when S=0010.
The correction circuit K1c 86 outputs the correction values Δc1=1 exactly when S=1000.
The correction circuit K2c 87 outputs the correction values Δc2=1 exactly when S=0100.
The correction circuit K3c 88 outputs the correction values Δc3=1 exactly when S=0111.
The correction circuit K4c 89 outputs the correction values Δc4=1 exactly when S=1001.
The illustrated concept is also applicable when bits u=u1, . . . , uk consist of K payload data and q bits derived therefrom. Then with k=K+q, the following applies
u1, . . . ,uk,=u1, . . . ,uK,w1, . . . ,wq.
Bits w1, . . . , wq can also be referred to as inner check bits and these bits as check bits of an inner code that are determined from bits u1, . . . , uK by
Thereby, f1, . . . , fq are K-digit boolean functions and k=K+q applies. If the boolean functions f1, . . . , fq are linear, then the inner code is linear. If at least one of these functions is non-linear, then the code is non-linear.
Bits u1, . . . , uk=u1, . . . , uK, w1, . . . , wq are corrected, for example, by a shortened BCH code correcting a 2-bit error by using its check bits c1, . . . , cm. For obtaining a particularly high probability for error detection of errors in bits ul, . . . , uk after the possible error correction by the BCH code, error detection in bits ul, . . . , uk can be performed by using the check bits of the inner code, without having to increase the number of check bits of the external code.
As an example, a non-linear code described in document DE 10 2006 005 836 or “Gössel, M., Otcheretny, V., Sogomonyan, E. and Marienfeld, D.: New Methods of Concurrent Checking, Springer Verlag 2008, p. 49-53” may be used, where, here, two internal check bits are determined by
w1=u1u2⊕u3u4⊕ . . . ⊕uK−1uK
and
w2=u2u3⊕u4u5⊕ . . . ⊕uKu1
Any arbitrary error that does not corrupt simultaneously all bits u1, . . . , uk can then be detected advantageously at least with the probability ½ as, for example, described in “Gössel, M., Otcheretny, V., Sogomonyan, E. and Marienfeld, D.: New Methods of Concurrent Checking, Springer Verlag 2008, p. 49-53”. It is also possible to include the address bits into the determination of the check bits of the inner code. For example, w1 and w2 can be determined as
w1=u1u2⊕u3u4⊕ . . . ⊕uK−1uK⊕a1a2⊕ . . . ⊕al−1a1
and
w2=(u2u3⊕u4u5⊕ . . . ⊕uKa1⊕a2a3⊕ . . . ⊕alu1)
It is also possible that bits w1, . . . , wq only depend on address bits a1, . . . , al and not on bits u1, . . . , uk. For example, bits w1, w2 can be determined by
w1,w2=(a1+2a2+ . . . +2i−1a1) mod 3
By using the proposed concept, an error correction circuit for 1-bit and 2-bit errors in which the address bits are integrated into error detection, wherein also the errors All-0 and All-1 may be detected as being errors in any address values, may be enabled.
Further, the described concept may enable to write, under any address any data, in particular also the value (0, . . . , 0), (1, . . . , 1) into all data bits without all memory cells being occupied by 0 (1), so that All-1 (All-0) is under no address a valid codeword in all memory cells.
Likewise, the circuitry may enable to differentiate every 1-bit-error from errors “All-1” and “All-0”, which is advantageous. Thus, it may not be the case that a word read out of storage in case of a correctable 1-bit error is mixed up with an error “All-0” or in “All-1”.
In the following, the very detailed example described before is explained in more general words also indicating some of the optional or additional features.)
There is a circuitry for generating a m-digit syndrome S=(S1, . . . , Sm) of a code C correcting at least a 1-bit error of a code word of the length n having a check matrix H for correcting errors of bits stored in an addressable memory. A first group u=u1, . . . , uk of k bits, a second group a=a1, . . . , al of l bits and a third group c=c1, . . . , cm of m bits exist, and the first group of k bits and the third group of m bits are stored in addressable memory under the address a. In the error-free case, bits c=c1, . . . , cm are derived logically from bits u=u1, . . . , uk and a=a1, . . . , al by XOR connections, n=k+l+m, wherein the circuitry has n inputs, where the bits u1, . . . , uk, a1, . . . , al, c1, . . . , cm are applied, wherein bits u1, . . . , uk, c1, . . . , cm are output from the memory when applying the address a1, . . . , al and the values of the error syndrome S=S1, . . . , Sm are determined by
S=H·(u,a,c)T
and (u,a,c)T is the transposed column vector of the row vector (u,a,c) and the check matrix H.
The check matrix H consists of three sub-matrices Hu, Ha, Hc, wherein the sub-matrix Hu consists of k first columns of H, the sub-matrix Ha consists of l second columns of H and the sub-matrix Hc consists of the residual m columns of H, so that
H=(Hu,Ha,Hc)
applies.
Further, there is a first predefined component and a second predefined component of columns of Hu and Hc each unequal [0,0] and such that the XOR-sum of these first predefined components of the columns of Hu and the columns of Hc component-by-component and the XOR-sum of the second predefined components of the columns of Hu and Hc component-by-component are each equal to 0.
The values of the first predefined component and the values of the second predefined component of columns of Ha are each equal to [0,0].
The l columns of matrix Ha are linearly independent.
The m columns of matrix Hc are linearly independent.
Further, there is a bit position r,1≦r≦l so that
applies, wherein
a″1, . . . ,a″r−1,a″r+1, . . . ,a″lε{0, 1}
with m+l+k≦2m−1 and l≦m−2.
According to an aspect, k correction circuits K1u, . . . , Kku having each m inputs and an output for generating correction values Δu1, . . . , Δuk for XOR connection with bits u′1, . . . , u′k read out from the memory are simultaneously connected to m outputs of the circuit mentioned before outputting the m components of the error syndrome S=S1, . . . , Sm.
Further, the correction circuits K1u, . . . , Kku when C is a 1-bit error correcting code, in the case of a 1-bit error or no error for j=1, . . . , k realize a m-digit boolean function Kju(S) with
wherein hju is the jth column of the sub-matrix Hu.
Alternatively or additionally, the correction circuits K1u, . . . , Kku, when C is a 1-bit error and 2-bit error correcting code, in the case of a 1-bit error or a 2-bit error or no error for j=1, . . . , k realize a m-digit boolean function Kju(S) with
wherein hju is the jth column of Hu and h is an arbitrary column of Hu or Hc.
According to another aspect, the circuitry is configured such that the logical rth address bit ar is set to 1 when a1, a2, . . . , ar−1, . . . , al=0, . . . , 0 and when
a1,a2 . . . ,ar−1,ar+1, . . . ,al=a″1,a″2 . . . ,a″r−1,a″r+1, . . . ,a″l
wherein
a″1,a″2 . . . ,a″r−1,a″r+1, . . . ,a″l
is determined such that
applies.
Further, it may be configured such that ar is constantly set to 1.
According to a further aspect, a further sub-circuit Fo having k+m inputs and an output for detecting the allocation All-0 of a memory cells exists, realizing an (k+m)-digit boolean function F0(u,c), for which the following applies:
F0(u,c)=
According to an aspect, a further sub-circuit F1 having k+m inputs and an output for detecting the allocation All-1 of a memory cells exists, realizing an (k+m)-digit boolean function F1(u,c), for which the following applies:
F1(u,c)=u1u2 . . . ukc1 . . . cm.
Further, the check matrix H may be supplemented by a row
According to another aspect, there are q components i1, i2, . . . , iq of the columns of the check matrix H, so that for every column h of the check matrix H, the XOR-sum of the values of these components is each equal 1.
Additionally, a circuit component having q inputs and an output for forming the XOR-sum of the q components si1, . . . , siq of the error syndrome for forming the parity P,
P=si1⊕ . . . ⊕siq
may exist.
According to an aspect, a further sub-circuit for address error detection (same-bit-value-detection) may exist, which outputs an error signal at its output in the case of an address error.
Further, the sub-circuit for address error detection in the case that the code C is a 1-bit error detecting code may output, in the case of a 1-bit error or no error, the value Ea(S) with
wherein ha is an arbitrary column of sub-matrix Ha.
Additionally, the sub-circuit for address error detection in the case that the code C is a 1-bit error and 2-bit error correcting code may output, in the case of a 1-bit error, a 2-bit error or no error, the value Ea(S) with
wherein ha is an arbitrary column of matrix Ha, h an arbitrary column of matrices Hu, Ha, Hc with h≠ha.
According to another aspect, l additional correction circuits K1a, . . . , Kla having m inputs and one output exist, so that for j=1, . . . , l the correction circuit Kja for the case that C is a 1-bit error correcting code realizes a l-digit boolean function Kja(s), for which
applies, wherein haj is the jth column of check matrix Ha.
According to a further aspect, l additional correction circuits K1a, . . . , Kla having m inputs and one output exists, so that for j=1, . . . , l the correction circuit Kja for the case that C is a 1-bit error and 2-bit error correcting code realizes a l-digit boolean function Kja(S), for which
applies, wherein hja is the jth column of check matrix of Ha and h an arbitrary column of matrices Hu and Hc with h′≠hja.
Additionally, the I outputs of correction circuits K1a, . . . , Kla may be connected to inputs of a circuit having l inputs and one output, realizing the logical OR-connection of its inputs.
According to an aspect, m additional correction circuits K1c, . . . , Kmc having m inputs and one output exist, wherein in the case that C is a 1-bit error correcting code for j=1, . . . , m, the correction circuit Kjc realizes a m-digit boolean function Kjc(S), for which, in the case for 1-bit error or no error, the following applies
and hjc is the jth column of sub-matrix Hc.
According to another aspect m additional correction circuits K1c, . . . , Kmc having m inputs and one output exist, wherein, in the case that C is a 1-bit and a 2-bit error correcting code, for j=1, . . . ,m the correction circuit Kjc realizes a m-digit boolean function Kjc(S), for which the following applies in the case of a 1-bit error, a 2-bit error or no error:
wherein hjc is the jth column of sub-matrix Hc and h an arbitrary column of sub-matrices Hu or Hc with h≠hjc.
According to a further aspect, the k outputs of the correction circuits K1u, . . . , Kku are connected into the inputs of a circuit having k inputs and one output, realizing a logic OR connection of its inputs.
According to an alternative aspect, the m outputs of correction circuits K1u, . . . , Kku are connected to the inputs of a circuit having k inputs and an output realizing a logical XOR connection of its inputs.
Further, the m outputs of the correction circuits K1c, . . . , Kmc may be connected to the inputs of a circuit having m inputs and one output realizing a logic OR-connection of its inputs.
Additionally, the m outputs of correction circuits K1c, . . . , Kmc may be connected to the inputs of a circuit having m inputs and one output realizing a logic XOR-connection of its inputs.
According to an aspect, the bits uk, . . . , uk−v stored in the memory are determined from the bits u1, . . . , uk−v−1 stored in the memory and the address bits a1, . . . , al by v+1 circuits fk, fk−1, . . . , fk−v each having k−v−1+l inputs and one output, realizing the (k−v+l)-digit boolean functions
Additionally, the boolean functions fk, . . . , fk−v may not depend on address bits a1, . . . , al.
Further, the boolean functions fk, . . . , fk−v may not depend on bits u1, . . . uk−v−1.
Additionally, at least one of the boolean functions fk, . . . , fk−v may be non-linear. Further, v may be equal to 1.
Additionally, fk may be defined by:
fk(u1, . . . , uk−2, a1, . . . ai)=(u1u2⊕u3u4⊕ . . . ⊕uk−3uk−2⊕a1a2 . . . ⊕al−1al)
and optionally fk−1 may be defined by:
fk−1(u1, . . . , uk−2, a1, . . . , al)=(u2u5⊕u4u5⊕ . . . ⊕uk−4uk−3⊕uk−2a1⊕a2a3 . . . ⊕a1u1)
According to an aspect, the check matrix Hunverk of the not shortened BCH code has the form
and the respective exponent j of aj is to be interpreted modulo 2M−1.
According to another aspect, the correction circuit Kiu are at least partly jointly implemented, the correction circuits Kjc and Kiu are at least partly jointly implemented and/or the correction circuits Kic, Kiu and Kja are at least partly jointly implemented.
Some embodiments according to the invention relate to an apparatus for correcting at least one bit error within a coded bit sequence comprising a means for determining an error syndrome and a means for correcting bit errors. The means for determining an error syndrome may determine an error syndrome of a coded bit sequence derived by a multiplication of a check matrix with the coded bit sequence. The check matrix comprises a first sub-matrix, a second sub-matrix and a third sub-matrix, each sub-matrix comprising a plurality of lines, each line comprising a plurality of binary components. At least a first predefined component or a second predefined component of each line of the first sub-matrix comprises a first bit value. Further, the second sub-matrix comprises lines being linearly independent from each other. The first predefined component and the second predefined component of each line of the second sub-matrix comprises a same second bit value. The third sub-matrix comprises lines being linearly independent from each other and the first predefined component or the second predefined component of each line of the third sub-matrix comprises the first bit-value. Further, either an XOR-sum of the first predefined components of all lines of the first sub-matrix and the third sub-matrix is equal to the bit value 0 and an XOR-sum of the second predefined components of all lines of the first sub-matrix and the third sub-matrix is equal to the bit value 0. Additionally, a result of a multiplication of the check matrix and the test vector is equal to a result of a multiplication of the second sub-matrix and a resulting vector, wherein at least one component of the resulting vector comprises the second bit value. The means for correcting bit errors may correct a bit error within the coded bit sequence based on the determined error syndrome of the coded bit sequence.
Some further embodiments according to the invention may relate to a decoder 1500 for decoding a faulty, coded bit sequence as it is shown in
Further, an XOR-sum of the first predefined components of all lines of the first sub-matrix and the third sub-matrix is equal to the second bit value and an XOR-sum of the second predefined components of all lines of the first sub-matrix and the third sub-matrix is equal to 0. Additionally, the result of a multiplication of the check matrix and a test vector is equal to a result of a multiplication of the second sub-matrix and a resulting vector, wherein at least one component of the resulting vector comprises the second bit value. Further, the method 1600 comprises correcting 1620 a bit error within the coded bit sequence based on the determined error syndrome of the coded bit sequence.
Additionally, the method 1600 may comprise further steps representing one or more of the optional aspects of the proposed concept described above.
Hc=(h1c, . . . ,hmc)
From the set Spe00 l columns are determined which are linearly independent. These columns are designated by hla, . . . , hla and they form the matrix (second sub-matrix).
Ha=(h1a, . . . ,h1a).
The matrix Hu (first sub-matrix) consists of k columns h1u, . . . , hku, wherein
hiuε{Spe10∪Spe01∪Spe11}\SPH
apply and wherein at least one column from Spe10, at least one column from Spe01 and at least one column from Spe11 is contained in (h1u, . . . , hku).
Subdividing the Galois field GF(2M) as schematically shown in
The following part of the specification describes two special cases of the proposed error correction and detection in more detail.
The suggestions described below in connection with
The data bits may be stored unmodified in the memory.
Without address error detection, the following may happen: If an address error occurs, data are read from an erroneous address location and these data may be completely different from the requested data. Therefore it is desirable to detect address errors with high probability. If an address error is mapped to an error syndrome of a correctable error or to the error syndrome 0, the address error might not be detected and consequently result in a miscorrection or in no correction.
Furthermore, it may also be desired that All-0 and All-1 situations can be detected for an arbitrary address. Accordingly, the problems that might be solved are:
As alternatives to the solution(s) proposed herein, in particular with respect to
As another alternative, in case of 2-bit ECC, additional check bits may have to be added, to guarantee the necessary high error detection probability for the arbitrary address errors since a relatively large number of arbitrary errors might be mapped to 1-bit and 2-bit error syndromes or in general to t-bit error syndroms. The costs are typically a large wordlength of the memory.
According to the suggestions that will be described in more detail in connection with
Only the few address errors mapped to the syndrome 0 are not detected. An address error detection of 99.2% for 256 data bits and of 96.875% for 64 bits can be achieved without enlarging the number of check bits for the ordinary Hsiao Code.
Addresses may be mapped to fewer compacted address bits. It is possible to map arbitrary addresses to compacted address bits which are always ≠0 for arbitrary addresses. The number of compacted address bits may be equal to the number of check bits minus 2 of the code. Address errors are also mapped to errors in the compacted address bits. The submatrix of the H-matrix corresponding to the compacted address bits may be denoted by HA. The columns of the sub-matrix HA of the H-matrix corresponding to the compacted address bits are linearly independent.
According to some examples for implementation, the first two rows of the sub-matrix Ha (or of the matrix HA) are both All-1 rows. The XOR-sum of the columns of the H-matrix corresponding to the data and check bits is 0. It can be shown that All-1 or All-0 is mapped to a non-correctable error of the code for an arbitrary address.
The columns of the sub-matrix Hc corresponding to the check bits may be an identity matrix and the H-matrix is in the systematic form. Therefore, data bits can be directly written into the memory and read also unchanged from the memory. The proposed solution is typically relatively cost effective with no additional check bits or ROMs needed.
The decoder is designed such that no address error is mapped to a syndrome of a correctable error. The decoder may be further designed such that All-1 and All-0 has a syndrome of a non-detectable error for an arbitrary address. The addresses may be compacted for fewer compacted address bits which are always ≠0. An address error may be mapped to an error of the compacted address bits.
A code word of an error correcting code C is stored in a memory Spei 12. The memory Spei 12 has k+m binary data inputs, via which m check bits c1, . . . , cm and k data bits u1, . . . , uk are provided as input to the memory Spei, which are stored under (or at) the write address a1, . . . , al. The write address a1, . . . , al is applied to the l bit wide address line of the memory. The check bits c1, . . . , cm are determined on the basis of the k data bits u1, . . . , uk and the address bits a1, . . . , al of the write address in a unambiguous manner, as will be described below.
When reading the possibly erroneous check bits c′1, . . . , c′m and the possibly erroneous data bits u′1, . . . , u′k from the memory Spei 12 under a read address a′1, . . . , a′1, the possibly erroneous check bits c′1, . . . , c′m and the possibly erroneous data bits u′1, . . . , u′k are presented at the m+k binary inputs of a syndrome generator arrangements Syndb 31. The syndrome generator arrangements Syndb 31 comprises further l binary inputs at which the read address a′1, . . . , a′l is provided, under which the possibly erroneous check bits and possibly erroneous data bits have been read out from the memory Spei 12. The syndrome generator arrangement Syndb 31 outputs, on the basis of the inputted data bits u′1, . . . , u′k, the check bits c′1, . . . , c′m and the address bits a′1, . . . , a′l of the read address, a m-component error syndrome S1, . . . , Sm.
The syndrome generator arrangement Syndb 31 is configured such that the error syndrome of an arbitrary error in the read address is different from all syndroms of a 1-Bit error (or of 1-bit errors) in the data bits or in the check bits. Since 1-Bit errors in the data bits and in the check bits are correctable using the code C, it may be desirable that an arbitrary address error that shall be detected, but shall not result in a correction of the data bits or check bits, is different in its error syndrome from the error syndrome of each 1-bit error in the data bits and the check bits.
When the bits of the read address a′1, . . . , a′l are presented at the input(s) of the combinational circuit Akomp 1922 for compacting of the address bits, then this circuit outputs at its output the bits A1 . . . , A′b of the compacted address. The combinational circuit Akomp 1922 is configured that the bits A′1, . . . , A′b are determined according to the relation
A′1, . . . ,A′b=F(a′1, . . . ,a′1),
wherein F is a function that maps l-tuple binary values in b-tuple binary values, wherein special useful implementation examples of the function F will be described below.
The syndrome generator Synd 1931 is in this implementation example configured so that it outputs an error syndrome S1, . . . , Sm, that is determined by
S1, . . . ,Sm=H·(c′1, . . . ,c′m,u′1, . . . ,u′k,A′1, . . . ,A′b)T,
wherein H is a H-matrix of the code C, wherein in this implementation example the H-Matrix is considered in its systematic form. Note that the columns (or generally, the elements) of H-matrix Hcould be arranged in a different manner so that the order of check bits c, the information bits u, and the compacted address bits A may be changed. Accordingly, the error syndrome S1, . . . , Sm may be alternatively determined by
S1, . . . ,Sm=H·(u′1, . . . ,u′k,A′1, . . . ,A′b,c′1, . . . ,c′m)T,
for example.
The address line, that carries the write address, is connected with the l-component input of the combinational circuit Akomp1 2034 and is also fed into the address input of the memory Spei 12. The data line which carries the data bits u1, . . . , uk is connected to both the k first inputs of the combinational circuit Prü 21 for forming the check bits and also such to k first data inputs of the memory Spei 12. The b bit wide output of the combinational circuit Akomp1 2034 is fed to the further b binary inputs of the combinational circuit Prü 21. The m bit wide output of the circuit Prü 21 is connected with the further m data inputs of the memory Spei 12.
When the write-signal is active, the data provided at the data inputs of the memory are written to the memory at the provided address. The write-signal is not depicted in
The address line that carries the read address is connected with the l-component input of the combinational circuit Akomp2 2035 and also fed to the address input of the memory Spei 12.
The first m data outputs of the memory Spei 12 carrying the possibly erroneous check bits C′1, . . . , c′m are connected with m first inputs of the syndrome generator Synd 1931. The further k data outputs of the memory Spei 12 carrying the possibly erroneous data bits u′1, . . . , u′k are connected with further k inputs of the syndrome generator Synd 1931. The output of the combinational circuit Akomp2 2035 is connected with the further b inputs of the syndrome generator Synd 1931. When the read-signal is active, the data stored at the applied address are output to the corresponding data outputs of the memory. The read-signal is not depicted in
The combinational circuit Akomp1 2034 is configured so that it forms the compacted bits A1, . . . , Ab according to the relation
A1, . . . ,Ab=F(a1, . . . ,al)
on the basis of the write address a1, . . . , al, wherein F is a combinational function that maps l-tuple binary values to b-tuple binary values.
The combinational circuit Akomp2 2035 is configured so that it forms the compacted bits A′1, . . . , A′b according to the relation
A′1, . . . ,A′b=F(a′1, . . . ,a′l)
on the basis of the read address a′1, . . . , a′l, wherein F is the same combinational function as it is implemented for the circuit Akomp1 2034. Useful implementation examples of the function F are described below.
The syndrome generator Synd 1931 is configured so that it forms the error syndrome S using the H-matrix of the code C according to the relation
S=H·[c′1, . . . ,c′m,u′1, . . . ,u′k,A′1, . . . ,A′b]T,
wherein H has the form
H=(Hc,Hu,HA),
Hc is a m-dimensional identity matrix, Hu=(h1u, . . . , hku) is a (m, k)-matrix. The first two components of each column hiu are unequal [1,1]. The number of 1-s (ones) in every column of Hu and Hc is odd. Thus Hc Hu are forming an H-matrix of a 1-bit-error correction and a 2-bit-error detection Hsiao-Code. The matrix HA=h1A, . . . , hbA is a (m, b)-matrix for which the following holds:
with b=m−2 and each column of the matrix H having an odd number of ones. Ib is the b-dimensional identity matrix. The matrix HA corresponds approximately to the matrix Ha mentioned above, where instead of the address bits a1, . . . , al compacted address bits A1, . . . , Ab are used.
We shall now demonstrate:
if the error syndrome of an address error of the read address is unequal 0, then it is different from every error syndrome of 1-Bit errors in the data bits or in the check bits.
Assume a1, . . . , al with A1, . . . , Ab=F(a1, . . . , al) to be the correct read address and, in case of an address error φ, a1f, . . . , alf with A1f, . . . , Abf=F(a1f, . . . , alf) the erroneous read address, then the difference ΔA1, . . . , ΔAb of the compacted, correct read address and the compacted erroneous read address is equal to
ΔA1, . . . ,ΔAb=A1⊕A1f, . . . ,Ab⊕Abf.
The error syndrome sφ corresponding to the address error φ, ist then
We shall now consider two cases:
and sφ exhibits an even number of ones. However, each column of the matrices Hc and Hu has an odd number of ones. Since each 1-bit error in the data or in the check bits corresponds to an error syndrome that is equal to one column of the matrices Hr or Hu, the error syndrome sφ is unequal to each error syndrome of a 1-bit error in the data bits or the check bits.
The first two components of sφ are now equal to [1,1]. Since the first two components of each column of the matrices Hc and Hu are unequal [1,1] in each case (i.e., for each column), the error syndrome sφ is different from every error syndrome of a 1-bit error in the data bits or check bits.
It is of course possible to interchange or swap individual rows of the H-matrix H without changing the spirit of the invention. The arrangement of the rows of the H-matrix H, and consequently also in the matrix HA have been chosen herein in order to facilitate a simple and comprehensible description. It is possible to interchange or swap the first row with the fourth row. Consequently the second row and the fourth row of the matrix HA will present all ones in this case, and the swapped new first row is then the previous fourth row
and so on.
Circuit portions or sub circuits that are implemented in a separate manner in the implementation example of
The circuitry in
The address line which carries the write address a1, . . . , al when writing or the read address a′1, . . . , a′l when reading, is connected with the l bit wide input of the combinational circuit Akomp 2142. This combinational circuit 2142 outputs at its output the compacted bits A1, . . . , Ab of the write address or the compacted bits A′1, . . . , A′b of the read address, respectively. The circuit Akomp 2142 is configured to determine the compacted bits according to the relation
A1, . . . ,Ab=F(a1, . . . ,al)
and
A′1, . . . ,A′b=F(a′1, . . . ,a′l).
In this context F is a combinational function that maps the l-tuple binary values to b-tuple binary values, wherein b<l.
Furthermore the address line which carries upon writing the write address a1, . . . , al or upon reading the read address a′1, . . . , a′l is connected with the l bit wide address input of the memory Spei 12.
The b bit wide output of the combinational circuit Akomp 2142 is connected with first b binary inputs of the check bit former 2143.
The m bit wide output of the check bit former 21 is connected with the m-bit wide input of the demultiplexer DEMUX 2144. The m bit wide first output of the demultiplexer DEMUX 2144 is connected with m first data inputs of the memory Spei 12, further k data inputs of which are connected with the input line that carries the data bits u1, . . . , uk and which is in addition connected to the 1-input of the multiplexer MUX 2141.
The m bit wide 0-output of the demultiplexer DEMUX 2144 is fed to a first m bit wide input of the XOR-circuit 2146, of which a second m bit wide input is connected with the first m data outputs of the memory Spei 12, which outputs upon reading the possibly erroneous check bits c′1, . . . , c′m, and which in the case of the reading operation are combined in the XOR-circuit 2146 with the bits c*1, . . . , c*m to yield the error syndrome S1, . . . , Sm, which is provided at the output of the XOR-circuit.
When reading, the possibly erroneous data bits u′1, . . . , u′k that are provided to the 0-input of the multiplexer MUX 2141, are output at the second k bit wide output of the memory Spei 12. When reading, the 0-input of the multiplexer 2141 is connected with its output so that the possibly erroneous data bits u′1, . . . , u′k are provided at the second k bit wide input of the check bit former Prü 21. The compacted bits A′1, . . . , A′b are provided at the first b bit wide input of the check bit former Prü 21.
The check bit former Prü 21 is configured to form the check bits c*1, . . . , c*m according to the relation
c*1, . . . ,c*m=(u′1, . . . ,u′k,A′1, . . . ,A′b)·P
and provides them at its output. In this context, P designates the parity matrix of the contemplated code C.
When writing, the 1-input of the multiplexer 2141 is connected with its output so that the data bits u1, . . . , uk are provided at the second, k bit wide input of the check bit former Prü 21. Now the compacted bits A1, . . . , Ab are provided at the first b bit wide input of the check bit former Prü 21. The check bit former Prü 21 is configured so that it forms the check bits C1, . . . , Cm according to the relation
c1, . . . ,cm=(u1, . . . ,uk,A1, . . . ,Ab)·P
and provides them at its output.
Since the multiplexer MUX 2141 in
Since the demultiplexer DEMUX 2144 in
In
The circuit components of
Since the multiplexer MUX 2141 in
In case the circuitry, as it is for example illustrated in
Then the error detection circuit FE 2451 may be configured to output, for each syndrome of a 1-Bit-error in the data bits or check bits that is equal to a column of the H-matrix of the contemplated code C, a first value E1, and to output a value E0 different to the first value E1, when the error syndrome is equal 0, and to output a further value E2, when the syndrome is unequal 0 and assumes a value that is not equal to a column of the matrices Hu or Hc. The value E2 indicates an uncorrectable error when the code C is a 1-bit error correcting and 2-Bit error detecting shortened Hsiao code.
Only those multi-bit errors that are mapped to a syndrome equal 0 are not detected, and only those multi-bit errors that are mapped to a syndrome, which is equal to one of the columns of the H-matrix, which are assigned to the data bits or the check bits, are corrected erroneously. All further multi-bit errors are detected as uncorrectable errors. In other words: When multi-bit errors are mapped to a syndrome that does not correspond to any column of the H-matrix relative to the data bits or the check bits, these multi-bit errors are indicated as non-correctable (uncorrectable) errors.
In the described implementation example it holds that R=2. It is also possible that the error detection circuit outputs a first value E0 when the error syndrome is equal 0 and when the error syndrome is the error syndrome of a correctable error, and outputs a second value E1 different from the first value when via the error syndrome an error is indicated that is not correctable by the code. In this case it is possible to choose R=1.
u1cor, . . . ,ukcor=u′1⊕e1, . . . ,u′k⊕ek.
In this implementation example it is assumed, that all columns of the H-matrix of the used code C present an odd number of ones and are pairwise different, wherein however not all possible columns with an odd number of ones and m components actually occur as columns of the H-matrix, because the code is a so called shortened Hsiao-code.
All 1-Bit errors in the data bits or the check bits can be corrected.
The error detection circuit FE1 2562 is here configured that it determines a first value E′0 when the error syndrome is equal 0, that it determines a second, different value E′1 when the error syndrome exhibits an odd number of ones, and that it determines a third value E′2, when the error syndrome is unequal to 0 and presents an even number of ones.
In case a 1-Bit error occurs in the data bits or the check bits, then the error syndrome exhibits an odd number of ones, and error signal output by the error detection circuit FE1 is equal E′1.
However, it is also possible that an error syndrome occurs with an odd number of ones in the case of a multi-bit error, for example a 3-Bit error or a 5-Bit-error. In this situation it is possible that a multi-bit error corresponds to an error syndrome with an odd number of ones, which does not appear as column of the H-matrix. By using the error detection circuit FE2 2563 such a case can be detected.
The error detection circuit FE2 2563 is here configured that it checks whether actually a single correction signal e1, . . . , ek+m equal 1 has been produced by the decoder Dec 2561, when the first error detection circuit FE1 2562 determines a value E′1. In this manner it can be excluded that a multi-bit error, that results in an error syndrome with an odd number of ones, but that is not equal to any column of the H-matrix corresponding to the data bits or the check bits, is erroneously indicated as a correctable 1-bit error.
The error detection circuits FE1 2562 and FE2 2563 together form an error detection circuit, that generate an error signal on the basis of the error syndrome and of the decoder-determined correction signals.
A1, . . . ,A4=F(a1, . . . ,a6)=[F1(a1, . . . ,a6), . . . ,F4(a1, . . . ,a6)].
Hence, l=6 and b=4 is considered in this implementation example.
The compaction is performed in this implementation example according to the relation
(A1, . . . ,A4)T=K·(a1, . . . ,a6)T (15)
with
so that
A1=a1⊕a5⊕a6=F1(a1, . . . ,a6)
A2=a2⊕a5⊕a6=F2(a1, . . . ,a6)
A3=a3⊕a5=F3(a1, . . . ,a6)
A4=a4⊕a6=F4(a1, . . . ,a6).
All columns of the matrix K are pairwise different and have an odd number of ones.
The circuitry of
The inputs 1, 5 and 6 are connected, via the XOR gates 2671 and 2673, to the output 1. The inputs 2, 5 and 6 are connected, via the XOR gates 2672 and 2674, to the output 2. The inputs 3 and 5 are connected, via the XOR gate 2675, to the output 3. The inputs 4 and 6 are connected, via the XOR gate 2676, to the output 4.
In some applications it may be useful that during compacting of the address bits in compacted address bits no address is mapped to compacted bits, which are equal to
The function F may in this case be chosen such that for all combinations a1, . . . , alε{0,1}l it holds that
F(a1, . . . ,al)≠0.
It is possible to set a first compacted bit of the compacted b bits identical to equal 1 and to compact the address bits a1, . . . , al onto the remaining b−1 bits, for example using a (b−1, l)-matrix K+ in the form
(A2, . . . ,Ab)T=K+·(a1, . . . ,al)T.
It is equally possible to derive compacted bits A*1, . . . , A*b from already determined compacted bits A1, . . . , Ab, such that the new compacted bits A*1, . . . , A*b can never assume the value 0, . . . , 0.
This approach shall be illustrated using an example of 4 compacted bits.
From the four determined compacted bits, which might possible assume the value 0,0,0,0, the modified compacted bits A*1, A*2, A*3, A*4 can be formed according to the relation
A*1A1*=A1
A*2A2*=A2,
A*3A3*=A3,
A*4A4*=A4,
so that the following also holds:
A*1A1*=F1(a1, . . . ,a6)=(a1⊕a5⊕a6)
A*2A2*=F2(a1, . . . ,a6)=a2⊕a5⊕a6,
A*3A3*=F3(a1, . . . ,a6)=a3⊕a5,
A*4A4*=F4(a1, . . . ,a6)=a4⊕a6.
A possible implementation of the determination of the modified compacted bits A*1, A*2, A*3, A*4 is schematically shown in
The input 1 is connected with the first input of an OR gate 2782 with two inputs and one output, and also connected with a first input of a NOR gate 2781 with four inputs and an output. The input 2 is connected with the output 2 and with a second input of the NOR gate 2781. The input 3 is connected with the output 3 and with a third input of the NOR gate 2781. The input 4 is connected with the output 4 and the fourth input of the NOR gate 2781, the output of which is fed into the second input of the OR gate 2782. The output of the OR gate 2782 is also the output 1 of the circuitry.
In order to achieve that none of the addresses is compacted to a compacted value
it is possible to set one bit of the compacted bits, for example A1, constant equal 1. This approach shall be explained for an implementation example with six address bits a1, . . . , a6, which are to be compacted to four bits, of which A1 is set to A1=1.
The remaining compacted bits A2, A3, A4 can be determined, for example, according to the relation
(A2,A3,A4)T=K+·(a1, . . . ,a6)T (17)
with
All columns of the matrix K+ are pairwise different.
The invention is now explained using an actual or realistic implementation example with 64 data bits u1, . . . , u64, 8 check bits c1, . . . , c8 and 21 address bits a1, . . . , a21, which are compacted to 6 compacted bits A1, . . . , A6, of which the bit A1 is set to constant equal 1.
A shortened Hsiao code C in systematic form is used. All columns of the H matrix of the code C have an odd number of ones.
The code is a 1-bit-error-correcting and 2-bit-error-detecting code.
For address errors an error detection and no error correction is realized.
First, the address bits a1, . . . , a21 are compacted to 6 bits 1, A2, . . . , A6, wherein for the 5 bits A2, . . . , A6 the following holds:
(A2, . . . ,A6)T=K+·(a1, . . . ,a21)T. (19)
In this example, K+ is a (5,21)-matrix, the columns of which are all unequal 0 and pairwise different from each other. A constant bit 1 is adjoined to the 5 bits A2, . . . , A6. This constant bit 1 results in that each address a1, . . . , a21 is mapped to a 6-component vector [1, A2, . . . , A6]≠0. Since the columns of K+ are all unequal 0 and pairwise different, two different addresses, that differ from each other in only one bit or two bits, can never be mapped to the same vector 1, A2, . . . , A6.
In this manner, all 1-bit and all 2-bit errors in the bits a1, . . . , a21 are reliably detected.
The H matrix of the code is the H matrix of a shortened Hsiao-code.
We assume that the generator matrix G of the code is used in its systematic form. The generator matrix G=(P70,8, I70) is then formed by a 70-dimensional identity matrix I70 and a (70,8)-parity matrix P70,8. Since the G matrix is used in its systematic form, the data bits can be written unchanged in the memory.
The H matrix is also used in its systematic form. The systematic form of the H matrix has the benefit that the hardware, which is used for the implementation of the parity matrix during coding, can also be employed during decoding for determining the error syndrome.
The H matrix has the form
H=(I8,P8,70T)=(Hc,Hu,HA) with I8=Hc and P8,70T=Hu,HA. (20)
All columns of the matrix H are unequal 0, pairwise different, and each column has an odd number of ones.
In the preceding equation
In particular, the sub-matrix Hc (check bits-related sub matrix) has the form
The columns of the matrix Hc are linearly independent.
The columns h1c, . . . , h8c of the matrix Hc are chosen so that
wherein ⊕ designates the component-wise addition modulo-2.
The matrix HA (compressed address bits-related sub matrix) has the form
The first two components of each column of the matrix HA are [1,1], i.e., the matrix is constant in these components. The third to eight row form a 6-dimensional identity matrix.
The matrix Hu (user data bits-related sub matrix) with
Hu=(h1u,h2u, . . . ,h64u)
has the following properties:
The first 6 columns h1u, . . . , h6u of Hu are:
Each of these 6 columns has 3 ones. It holds:
h1u⊕h2u⊕h3u⊕h4u⊕h5u⊕h6u=[0,0,0,0,0,0,0]T=0. (26)
The remaining 58 columns h7u, . . . , h64u of the matrix Hu are determined as 29 pairs of successive columns hiu, hi+1u, i=7, 9, 11, . . . , 63 such that hiu has three components that are equal 1 and hi+1u has five components that are equal 1. hiu and hi+1u are complementary to each other. If the r-th component of hiu is equal 1, then the r-th component of hi+1u is equal 0. If the r-th component of hiu is equal 0, then the r-th component of hi+1u is equal 1. The first two components of hiu and hi+1u are either equal [0,1] or [1,0] and therefore unequal [1,1]. For the component-wise XOR combination of hiu and hi+1u we have
huu⊕hi+1u=[1,1,1,1,1,1,1,1]T
The columns hiu and hi+1u are determined based on the following considerations:
In an analogous manner we have:
The 58 columns h7u, . . . , h64u are chosen as 29 pairs of complementary columns. The first 30 columns consist of 15 first pairs of complementary columns, wherein the first column of each pair is one of the 15 column vectors with 3 ones and the first two components 0,1. The associated second complementary column is then one of the 15 column vectors with 5 ones and the first two components 1,0.
The remaining 28 columns consist of 14 second pairs of complementary columns, wherein the first column of each of these second pairs is one of 15 column vectors with 3 ones and the first two components 1,0. The associated second complementary column is then one of the 15 column vectors with 5 ones and the first two components 0,1.
For the component-wise XOR-sum of the 58 columns h7u, . . . , h64u or the 29 pairs [h7u, h8u], [h9u, h10u], . . . , [h63u, h64u] of complementary columns we have
[h7u⊕h8u]⊕[h9u⊕h10u]⊕ . . . ⊕[h63u⊕h64u]=[1,1,1,1,1,1,1,1]T (27)
from which using equations (22), (24) and (26) it follows
h1c⊕ . . . ⊕h8c⊕h1u⊕ . . . ⊕h6u⊕h7u⊕ . . . ⊕h64u=0 (28)
and therefore
Next the error correction and error detection properties of the preceding implementation example are described.
The H matrix H is, as previously explained, a H matrix of a shortened Hsiao code, and all columns of the H matrix have an odd number of ones.
For the data bits and the check bits we have:
In case the error syndrome is equal [1,1] in the first two components, then it differs from the error syndrome of an arbitrary 1-bit error in the data bits and check bits, that is either equal [0,0], [1,0] or [0,1] in the first two components. It is indicated as a non-correctable error and detected in a reliable manner.
In case the first two bits of the error syndrome of an address error are equal [0,0], then the number of the components that are equal 1 is even. Since a 1-bit error in the data bits and check bits presents an odd number of ones, the address error is detected as a non-correctable error when the error syndrome is ≠0.
These statements are now explained more in detail.
The modification of the compressed (compacted) address values ΔA2, . . . , ΔA6 is defined by
ΔA2, . . . ,ΔA6=A2⊕A2f, . . . ,A6⊕A6f. (30)
[A2, . . . , A6]T=K+·[a1, . . . , a21]T are the compacted values of the correct address bits and [A2f, . . . , A6f]T=KT·[a1f, . . . , a21f]T[A2, . . . , A6]T=K+·[a1, . . . , a21]T[A2f, . . . , A6f]T=KT. [a1f, . . . , a21f]T the compacted values of the erroneous address bits. The syndrome resulting from an address error S(A) is
Every address error for which holds ΔA2, . . . , ΔA6≠0,0,0,0,0, results in a syndrome unequal 0.
If the number of ones in ΔA2, . . . , ΔA6 is odd, then the first two components of S(A) are equal [1,1], and the address error is detected as non-correctable error. If the number of ones in ΔA2, . . . , ΔA6 is even and if ΔA2, . . . , ΔA6≠0,0,0,0,0, then the number of the components of S(A) that are equal 1 is even so that the error is detected as non-correctable error.
If ΔA2, . . . , ΔA6=0,0,0,0,0, although an address error exists in the address bits a1, . . . , a21, then the error is not detected. This case occurs very seldom.
It may be of interest that two special errors, in which all memory cells assume the value 0 or all memory cells assume the value 1, are reliably detected independent from the value of the address.
In case all memory cells assume the value 0, then this is typically called an All-0 error. In case all memory cells assume the value 1, then this is typically called an All-1 error.
In other words, if all memory cells have the value 0, then an All-0 error has occurred (is present). Since the address bits and the compacted address bits are not stored, an All-0 error means that all data bits and check bits are equal 0 and the compacted address bits A2, . . . , A6 can assume arbitrary values, including
If all memory cells have the value 1, then an All-1 error has occurred (is present). Since the address bits and the compacted address bits are not stored, an All-1 error means that all data bits and check bits are equal 1 and the compacted address bits A2, . . . , A6 can assume arbitrary values, including
We now determine the error syndrome S(All-0) for an All-0 error. We have
At the same time we have
[A2, . . . ,A6]T=K+·[a1, . . . ,a21]T.
If the number of the values A2, . . . , A6 that are equal 1 is odd, then the first two components of the error syndrome S (All-0) are equal [0,0] and the error syndrome presents an even number of ones. In this manner the error All-0 is detected as a non-correctable error. If the number of the values A2, . . . , A6 that are equal 1 is even, then the first two components of the error syndrome s(All 0) are equal [1,1]. In this manner the error All-0 is detected as a non-correctable error.
Irrespective of the value of the address bits, All-0 is detected as a non-correctable error.
We now determine the error syndrome S(All-1) for an All-1 error. We have
Care has been taken that the columns of Hc and Hu have been determined that
If the number of the values A2, . . . , A6 that are equal 1 is odd, then the first two components of the error syndrome S(All-1) are equal [0,0] and the error syndrome has an even number of ones. In this manner All-1 is detected as a non-correctable error. If the number of the values A2, . . . , A6 that are equal 1 is even, then the first two components of the error syndrome S(All-1) are equal [1,1]. In this manner an All-1 is detected as an uncorrectable error.
Irrespective of the value of the address bits, All-1 is detected as an uncorrectable error.
The functionality of the error detection and correction will be explained subsequently using actual examples for 64 data bits, 8 check bits and 21 address bits. The code C that is used, is constructed via its H matrix H. The sub matrices Hc and HA, as well as the first 6 column vectors of the Matrix Hu are already given by the equations (21), (23) and (25). The remaining 58 column vectors of the Matrix Hu are chosen according to the description above as 29 pairs of complementary column vectors. The H matrix H of the code C can be selected according to
The sub matrices Hu, HA form the transposed P8,70T of the parity matrix P70,8 of the code C:
The parity matrix can be obtained from P8,70T by transposing:
P70,8=(P8,70T)T (36)
The parity matrix P70,8 of the example code is represented in equation (37). One obtains P70,8 from P8,70T by interchanging (“swapping”) the rows and the columns.
In the contemplated implementation examples 64 data bits u1, . . . , u64 are to be stored in the memory under the address a1, . . . , a21. For forming the 8 check bits associated with the 64 data bits, in a first step the 21 address bits a1, . . . , a21 are compacted on the basis of the matrix K+ to 6 bits A1, . . . , A6. The (5,21) matrix K+ can be chosen, according to at least some aspects of the invention, as follows:
All columns of the matrix K+ are unequal 0 and pairwise different.
The compacted address bits A2, . . . , A6 of the write address are formed due to (19) according to the relation
(A2, . . . ,A6)T=K+·(a1, . . . ,a21)T
and the compacted bit A1 is set to A1=1. The check bits c1, . . . , c8 to be written are generated as a function of the data bits and the compacted address bits using the parity matrix P70,8:
(c1, . . . , c8, u1, . . . , u64, A1, . . . , A6)·HT=0(c1, . . . , c8)=(u1, . . . , uq, A1, . . . , A6)·P70,8·(c1, . . . , c8, u1, . . . , u64, A1, . . . , A6) is a codewort of the systematic code C and it holds that
(c1, . . . ,c8,u1, . . . ,u64,A1, . . . ,A6)·HT=0
The check bits and the data bits are stored in memory under the address a1, . . . , a21.
It is possible that the check bits and the data bits stored in memory and also the address bits are erroneous.
If the values c1, . . . , c8, u1, . . . , u64, 1, A2, . . . , A6 differ from the values c′1, . . . , c′8, u′1, . . . , u′64, 1, A′2, . . . , A′6, then typically an error has occured.
An error can be described by an error vector
f=(f1c, . . . ,f8c,f1u, . . . ,f64u,f1A, . . . ,f6A)=(c1⊕c′1, . . . ,c8⊕c′8,u1⊕u′1, . . . ,u64⊕u′64,1⊕1,A2⊕A′2, . . . ,A6⊕A′6).
If
then typically no error has occurred. If
then an error has occurred. The error syndrome Sf of an error f is
Sf=(S1, . . . , S8)T=H·fT
For explaining the mode of operation of the invention, we contemplate first the case that the 7-th data bit u′7 is erroneous and that all other bits are not erroneous. We assume that the read address a′1=a1, . . . , a′21=a21 is equal to the write address and thus also the compacted address bits of the read address are equal to the compacted bits of the write address.
The error vector is then
and the error syndrome sf is
sfT=H·fT=(10000011)T.
The error syndrome is equal to the 7-th column of the matrix Hu. Since sf≠0 and has an odd number of ones, a correction signal e7u=1 is generated by the decoder Dec 2561. No further correction signals ≠0 are output by the decoder. The corrected 7-th data bit u7cor is then u7cor=u′7⊕e7u=x′7⊕1=
The error syndrome sf presents an odd number of ones and for the first two components we have s1, s2≠1,1. Furthermore, the syndrome s corresponds to the 15-th column of the matrix H, that is to column vector that corresponds to the 7-th data bit. The decoder determines correction signals of the form
e1, . . . ,e72=e1c, . . . ,e8c,e1u, . . . ,e64u
to the check bits and the data bits on the basis of the error syndrome s, wherein eic=0 for i=1, . . . , 8, eju=0 for j=1, . . . , 6,8, . . . , 64 and e7u=1.
The check bits and the data bits to be corrected are then combined with the corresponding correction signals to yield the corrected check bits and data bits:
We now consider the case that the 5-th check bit c′5 and the 29-th data bit u′29 are erroneous. It is assumed that no further errors are present.
The error vector f is then
and the error syndrome sf is
SfT=H·fT=(10101010)T,
which corresponds to the component-wise XOR-sum of the 5-th column (00001000)T of the matrix Hc and the 29-th column (10100010)T of the matrix Hu. The error syndrome Sf is unequal 0, and has an even number of ones. A non correctable error is indicated.
We now describe the mode of operation of the invention for a first address error. Let us consider the case in which the read address a′1, a21′ differs from the write address a1, . . . , a21 in the 13-th bit, i.e., a′13≠a13. It is assumed that no further error has occurred. We have
and the address error affects the compacted address bits in a manner that 1, A′2, . . . , A′6 differs from 1, A2, . . . , A6 by 0,0,0,1,1,0 and ΔA1, ΔA2, . . . , ΔA6=0,0,0,1,1,0. The constant value A1=A′1=1 can not be erroneous.
The error vector f is
and the error syndrome Sf is then
The error syndrome Sf is equal to the component-wise XOR-sum of the fourth column (1,1,0,0,0,1,0,0)T and the fifth column (1,1,0,0,0,0,1,0)T of HA. Since the error syndrome sf is unequal 0 and has an even number of ones, the address error is detected as a non-correctable error.
Now a second address error shall be considered. According to this error the read address and the write address differ in the 8-th and in the 18-th bit, i.e. a′8≠a8 and a′18≠a18. No further errors are assumed.
We now have
The compacted address bits 1, A′2, . . . , A′6 of the read address differ from the compacted address bits 1, A2, . . . , A6 of the write address by 0,0,1,0,1,1.
The error vector f is
and the error syndrome Sf is
and it is equal to the component-wise XOR-sum of the third, fifth and sixth column of the matrix HA.
Since the first two components of SfT are equal 1,1 and the error syndrome of each 1-bit error in the data bits or the check bits in the first two components is unequal 1,1, the address error(s) is detected as uncorrectable error.
In order to achieve an address error detection with about 99.9%, a new code is proposed for error correction of t-bit errors in the data bits and check bits and very high error detection probability for arbitrary address errors. Detection of address errors with 99.9% can now be achieved with much less check bits as it is possible until now.
In memories, it may be desired to correct t-bit errors and to detect multi-bit errors, e.g., for t=2. Of special importance are address errors with potentially catastrophic consequences. Address errors have to be detected with very high probability. In a currently used design (internal knowledge of the assignee), address errors may be detected with 98.8% by use of 21 check bits, but a higher probability is desired.
Errors may be corrected and detected by use of their error syndromes. An error is typically mapped to an error syndrome, and the error syndrome determines what type of error occurred and whether it can be corrected, or only detected. For a code length of n there are 2n−1 arbitrary errors. If the syndrome has m components, there are only 2m error syndromes and in general 2n−m errors are mapped to each syndrome.
If an arbitrary error which is not a t-bit error is mapped to a syndrome corresponding to a t-bit error, when t-bit errors are corrected, then the arbitrary error is miscorrected. This is one of the reasons for the relatively high miscorrection rate of arbitrary errors if the code is used for error correction of t-bit errors with t≧1, for example, for the above mentioned design currently used within the assignee.
According to what will be described in more detail below with respect to
As an example, for a currently contemplated new design with 256 data bits and 21 check bits, >99.9% detection probability for address errors can be achieved, as compared to 98.8% detection probability that could be achieved with preceding designs. This result can be achieved by a syndrome generator that implements a parity matrix with special properties, as will be explained below.
It is known to a person skilled in the art to detect and to correct errors in a sequence of bits by error-detecting and error-correcting codes. For example, k data bits or information bits u=u1, . . . , uk may be supplemented by m check bits c=c1, . . . , cm, so that the bits v1, . . . , vn=c1, . . . , cm, u1, . . . , uk form a codeword of a code C.
It is also possible to add the check bits of the right side to the information bits. Then, u1, . . . , uk, c1, . . . , ci is a codeword of the considered code.
Since the unmodified information bits are bits of a codeword, the code is called a systhematic code.
The invention is not restricted to systematic codes. Also, non-systhematic codes can be used.
If the code C is a linear systhematic or non-systhematic linear code, then a codeword v may be determined from the information bits by
v=u·G
wherein G is the generator matrix of the code. G may be either in systhematic or in non-systhematic form as it is known to an ordinary expert in this field.
A G-matrix in non-systhematic form can be always transformed into a G-matrix in systhematic form by component-wise XOR-combining of rows and by permuting columns of the G-matrix in non-systhematic form.
On the other hand, a G-matrix in its systhematic form can also be transformed in arbitrarily given non-systhematic form of the code by component-wise XOR-combining the rows and by permuting the columns of the G-matrix in its systhematic form.
Since it is often advantageous to store data unmodified in the memory, which is possible if the codes are used in their systhematic form, the invention is described mainly by examples with the codes in their systhematic form.
Of course, the invention can also be used, if the considered code is a non-systhematic code.
If C is a linear code, then a codeword v may be determined by
v=u·G,
wherein G is the generator matrix of the code, G is here a (k, n) matrix with n−k=m.
A codeword v=v1, . . . , vn may be changed by errors into an erroneous word v′=v′1, . . . , v′n. An error may be described by an error vector. The error vector e=e1, . . . , en is defined by
e=e1, . . . ,en=v1⊕v′1, . . . ,vn⊕v′n.
If the i-th component e, of the error vector e is equal to 1, vi and v′i are different and an error exists in the i-th bit. If ei=0, vi and v′i are not different and there is no error in the i-th bit.
The error syndrome s of a sequence v′=v′1, . . . , v′n is determined by
ST=H·[v′1, . . . ,v′n]T=H·[e1, . . . ,en]T.
Here, H is the H matrix or parity check matrix of the code C and ST is the transposed vector of the row vector S=S1, . . . , Sm. Hence, ST is a column vector. Likewise, [v′1, . . . , v′n]T and [e1, . . . , en]T designate the transposed column vectors of the row vectors v′ and e. The matrix H here is a m,n-matrix.
Note that in the above equation the erroneous code word v′ can be split up as the sum of the corresponding (error-free) code word v and the corresponding error vector e. The syndrome of an (error-free) code word is 0, so that the syndrome of the erroneous codeword v′ is equal to the syndrome of the corresponding error vector e, as demonstrated in the above equation.
The error syndrome S may be determined by a syndrome generator from the bits v′1, . . . , v′n. For linear codes, the syndrome generator may be a combinational circuit with n inputs and m outputs, into which the bits v′1, . . . , v′n are input and which outputs the associated error syndrome S. The syndrome generator may be realized using XOR gates.
If all components of the error vector e are equal to 0, no error is present and v′=v applies. For a code vector, v′=v applies and the error syndrome is equal to 0|T, wherein 0| here designates an m-component column vector whose components are all 0 (accordingly its transpose 0|T designates an m-component row vector).
If exactly one component of the error vector e is equal to 1, a 1-bit error exists. If exactly t components of the error vector e are equal to 1, then a t-bit error exists.
If the code C is a t-bit error correcting code with t≧1, then the error syndromes of all 1-bit to t-bit errors are pair-wise different and based on the existing syndrome it may be determined by a decoder which bits are to be corrected. In principle, this is easily possible using a table, which is, however, often elaborate for realistic word widths, which is why special correction methods have been developed for the different codes. The correction of bits may take place by XOR-ing the bit to be corrected with the correction value.
The decoder and the corresponding XOR-combinations may be combined to form a corrector. If negated values of the bits or of the correction values are used, the combinations of the bits to be corrected and the correction values may be implemented by XNOR gates.
If the code C is a T-bit error detecting code with T≧1, then the error syndromes of all 1-bit to T-bit errors are unequal to 0 and each 1-bit to T-bit error unequal 0 may be differentiated from a correct codeword by the fact that the error syndrome corresponding to the same is ≠0|.
An example for a 1-bit error correcting code is the Hamming code and a known example for a 1-bit error correcting and 2-bit error detecting code is the Hsiao code.
Examples for t-bit error correcting codes for t≧2 are the BCH codes, for example described in the textbook by Lin, S. And Costello, D. “Error Control Coding, Fundamentals and Applications” Prentice Hall, pp. 141-170, 1983. Apart from that, reference is further to be made to the paper by Okano, H. And Imai, K. “A construction method of high-speed decoders using ROM's for Bose-Chaudhuri Hocqenhem and Reed Solomon codes” IEEE trans. Comp C 36, pp. 1165-1171, 1987.
For a first embodiment,
The syndrome generator Synd 110 is implemented so that it forms an m-bit wide error syndrome s=S1, . . . , sm according to the following relation
ST=H·(v′)T (39)
Here, H is the H matrix (parity check matrix) of the considered linear code C. H is an (m, n) matrix, wherein m is the number of check bits of the code C and n is the length of the code.
The column vector ST designates the transposed vector of the row vector S=S1, . . . , SmL. Accordingly, (v′)T designates the transposed vector of the row vector v′.
The H matrix H of the code C comprises a first sub-matrix Hx which is a (m, k) matrix, and a second sub-matrix Ha which is an (m, l) matrix, so that the following applies
H=(Hx,Ha). (40)
The sub-matrix Ha may also be referred to as Hy. The letter “x” when used as an exponent or index may be understood as relating to parts of the code word for which an error correction is intended (up to t-bit errors), and the letter “y” as exponent or index may be understood as relating to parts of the code word for which an error detection is intended (depending on the embodiment, up to the entire length said part of the code word, i.e., up to l bits).
Here v′=v′1, . . . , v′n=x′1, . . . , x′k+m, a′1, . . . , a′l with x′=x′1, . . . , x′k+m and y′=y′1, . . . , y′l is an n digit binary word with n=k+m+l which resulted from a codeword v=v1, . . . , vn=x1, . . . , xk+m, y1, . . . , yl of the considered code C due to errors. Note that the vector x′=x′1, . . . , x′k+m corresponds to the combination or concatenation of the possibly erroneous information bits u′=u′1, . . . , u′k and the check bits c′=c′1, . . . , c′m shown in, for example,
If no error exists and if v′=v=x1, . . . , xk+m, a1, . . . , al is a codeword of a code C, then the error syndrome S determined by equation (39) is equal to 0.
If v′=x′1, . . . , x′k+m, a′1, . . . , a′l≠x1, . . . , xk+m, a1, . . . , al, wherein x1, . . . , xk+m, a1, . . . , al is a codeword of a code C, then it is possible that the subcircuit Cor/Det 120 corrects errors and/or detects errors.
It is here provided in the circuitry in
The syndrome generator Synd 110 is configured so that it outputs a different error syndrome for each 1-bit to t-bit error in the bits x′1, . . . , x′k+m, so that the error syndromes output by the syndrome generator Synd 110 are different pair-wise for all 1-bit to t-bit errors in the bits x′1, . . . , X′k+m.
Apart from that, the syndrome generator Synd 110 is configured so that for any random error in the bits a′1, . . . , a′l, i.e. for any random 1-bit, 2-bit, . . . , l-bit error in the bits a′1, . . . , a′l it outputs an error syndrome which is different from all error syndromes output by the syndrome generator Synd 110 in case of a 1-bit to t-bit error in the bits x′1, . . . , x′k+m. If an error exists in the bits x′1, . . . , x′k+m and if the bits a1=a′1, . . . , al=a′l are correct, it may be described by an error vector
If an error exists in the bits a′1, . . . , a′l and if the bits x1=x′1, . . . , xk+m=x′k+m are correct, it may be described by an error vector
For an error in the bits x′1, . . . x′k+m with the error vector ex, the error syndrome Sx determined by the syndrome generator Synd 110 and output at its output is equal to
and for an error in the bits a′1, . . . , a′l with the error vector ea, the error syndrome Sy determined by the syndrome generator Synd 110 and output at its output is equal to
The H matrix H=(Hx, Ha) may be determined so that for any possible errors in the bits a′1, . . . , a′l, i.e. for any combinations of e1a, . . . , ela unequal
the error syndromes Sa determined by the syndrome generator according to equation (34) are different from all error syndromes Sx determined according to equation (33) by the syndrome generator Synd 110, if 1-bit to t-bit errors occurred in the bits x′1, . . . , x′k+m, wherein these error syndromes are also pair-wise different for any possible combinations of the bits e1x, . . . , ek+mx with a single one to t ones.
An error syndrome here is an m-component binary vector, wherein m is the number of check bits of the code C.
An error in the bits a′1, . . . , a′l may not be detected as an uncorrectable error by its error syndrome determined by the syndrome generator Synd 110, if the syndrome
is associated to this particular bit combination a′1, . . . , a′l by the syndrome generator. As there are in general 2m different m-component binary vectors and thus also 2m different error syndromes of which 2m−1 error syndromes are unequal
this is a very seldom case.
A corrector/detector Cor/Det 120 is connected downstream to the syndrome generator Synd 110 in
It outputs a correction vector e1cor=0, . . . , ek+mcor=0 so that no correction takes place in the bits x′1, . . . , x′k+m when S=0| or when S=Sa≠0| and e1a, . . . , ela comprises at least one 1. In the latter case, the error signal E takes on a value which is different from the value of the error signal E when S=0 or when S=Sx apply.
It is possible that the word width R of the error signal E is equal to 1. The word width R of the error signal E may also be greater than 1. It may then be differentiated using the error signal whether a 1-bit error occurred in the bits x′1, . . . , x′k+m, a t-bit error occurred in the bits x′1, . . . , x′k+m or a random non-correctable error occurred in the bits a′1, . . . , a′l.
In the following, an implementation example is to be considered, wherein t=2, so that 1-bit errors and 2-bit errors in the bits x′1, . . . , x′k+m may be corrected and (almost all) errors in the bits a′1, . . . , a′l shall be detected. 2·M=m applies.
A possible H matrix H=(Hx, Ha) may be determined by
Here, α is a generating element of the Galois field GF(2M), αi
0| denotes here an M-dimensional column vector with its M components equal to 0.
The exponents i1, . . . , ik+m of αi
The matrix H comprises m=2·M rows, so that the associated code C comprises m=2·M check bits.
It may be advantageous to select also the exponents r1, . . . , rl in the matrix Ha so that they are pair-wise different, when l≦2M−1 applies. The m=2·M components of the columns hix, i=1, . . . , k+m of the matrix Hx consist of M first components belonging to αi
As axis a generating element of the Galois field GF(2M), αr
The matrix Hx is an H matrix of a shortened BCH code when k+m<2M−1 and the H matrix of an unshortened BCH code when k+m=2M−1, wherein the BCH code is a 1-bit error and 2-bit error correcting BCH code with a code distance d≧5, so that all error syndromes
Sx=Hx·(e1x, . . . ,ek+mx) (35)
for 1-bit errors and for 2-bit errors in the bits x′1, . . . , x′k+m are pair-wise different and unequal 0|.
As the exponents i1, . . . , ik+m are pair-wise different, also αi
For a 1-bit error in the b-th bit 1≦b≦k+m the syndrome generator Synd 110 then determines an error syndrome
and for a 2-bit error in the a-th and b-th bit
wherein due to αi
The sub-matrix
Hx1=(αi
consisting of M rows is an H matrix of a linear code of the length k+m with Q=M check bits. It here consists of the first Q=M rows of the matrix Hx. The code associated with the H matrix Hx1 is a Hamming code with the code distance d=3, so that all 1-bit errors and all 2-bit errors in the bits x′1, . . . , x′k+m lead to an error syndrome Sx1≠0|, wherein Sx1 consists of the first Q=M columns of the error syndrome Sx according to equation (35) with
Sx1=Hx1·(e1x, . . . ,ek+mx)T (36)
The Q=M first rows of the matrix Ha which correspond to the Q rows of the matrix Hx1 are the rows of the matrix Ha which each form an l-component row vector of only zeros. In the considered embodiment, these are the first Q=M rows of the matrix Hy.
As α is a generating element of the Galois field GF(2M), αp≠0| for pε{0,1, . . . , M−2} applies, and each column of the matrix Ha comprises at least one 1.
In
The first M-bit wide output lines of the syndrome generator Synd 110 which carry the subsyndrome S1 are connected to M first inputs of a corrector Cor 2921 and simultaneously to M inputs of an NOR circuit 2922 having M inputs and a 1-bit wide output. The second M-bit wide output lines of the syndrome generator Synd 110 are connected to M second inputs of the corrector Cor 2921 and simultaneously to M inputs of an OR circuit 2923 having M inputs and a 1-bit wide output.
The 1-bit wide output of the NOR circuit 2922 is connected to a first input of an AND gate 2924 having two inputs and one output, wherein the second input of the AND gate 2924 is connected to the output of the OR circuit 2923.
The AND gate 2924 outputs the error signal Eat its 1-bit wide output. Here E=1 applies when S1=0| and S2≠0|, so that E=1 indicates an error in the bits a′1, . . . , a′l.
We have E=0 when S1≠0| or S2=0| apply. Here, the subsyndrome S2=(S12, . . . , SM2) being an M-digit binary number may in principle take on 2M different values.
If no error occurs in the bits a′1, . . . , a′l, then S2=0|. It is also possible that S2=0| when certain errors occurred in the bits a′1, . . . , a′l, so that the following applies
Ha·(e1a, . . . ,ela)T=0|.
If all values αr
If the values αr
The corrector Cor 2921 in
For 1-bit and 2-bit errors in the bits x′1, . . . , x′k+m the correction values ecor,x=e1cor,x, . . . , ek+mcor,x are determined by the corrector Cor 2921, for example using a 2-bit error correcting BCH code and as it is described for example in Okano, H. and Imai, K. “A construction method of high-speed decoders using ROM's for Bose-Chaudhuri Hocqenhem and Reed Solomon codes”, IEEE trans. Comp. C 36, pp. 1165-1171, 1987.
In an embodiment, t≧2 so that the linear t-bit error correcting code is an at least 2-bit error correcting code.
For the bits a′1, . . . , a′l no correction values are formed. Errors in these bits are only detected.
The bits x1, . . . , xk+m written into the memory Spei 12 at a write address a=a1, . . . , al for example consists of k data bits u1, . . . , uk and m check bits c1, . . . , cm which, together with the bits of the write address a1, . . . , al at which the data bits and the check bits were written into the memory, form a codeword c1, . . . , cm, u1, . . . , uk, a1, . . . , al of a linear code C of the length n=k+m+l with m check bits. If the H matrix of the code C is designated by H, the following applies
The bits x′1, . . . , x′k+m read out of the memory Spei 12 at the read address a′ are here applied to a first k+m-bit wide input of a syndrome generator Synd 110, at whose second l-bit wide input the bits a′1, . . . , a′l of the read address are applied and which outputs an error syndrome S at its m=2·M-bit wide output whose first M components form the subsyndrome S1 and whose second M components form the subsyndrome S2. Here, the syndrome generator Synd 110 is configured so that it provides the components of the error syndrome at its output according to the H matrix H and M≧2.
The H matrix of the code C is here determined so that errors in bits of the bits X′1, . . . , x′k+m are corrected and errors in the address bits y′1=a′1, . . . , y′l=a′l are detected.
If, for example, t=2 then 1-bit errors and 2-bit errors in the bits x′1, . . . , x′k+m are corrected.
The H matrix may here have the following form
wherein αi
The syndrome generator Synd 110 is configured so that it comprises, at its 2·M outputs, an error syndrome
ST=H·[x′1, . . . ,x′k+m,a′1, . . . ,a′l]T=H·[c′1, . . . ,c′m,u′1, . . . ,u′k,a′1, . . . ,a′l]T (37)
with m=2·M whose first M components form the subsyndrome S1 and whose second M components form the subsyndrome S2. The m=2·M bit output of the syndrome generator Synd 110 is connected to the m-bit wide input of the subcircuit Cor/Det′ 3037 which is configured so that at its first k+m-bit wide output it forms a correction signal ecor,x=e1cor,x, . . . , ek+mcor,x for the bits x′1, . . . , x′k+m which are combined, according to their respective bit positions, into
xcor=x1cor, . . . ,xk+mcor=x′1⊕e1cor,x, . . . ,x′k+m⊕ek+mcor,x (38)
in the XOR circuit 3038 which comprises k+m XOR gates, each having two inputs and one output.
The subcircuit Cor/Det′ 3037 is here configured so that, at its second, here 2-bit wide output which carries the error signal E2,
Apart from that, the first M components of the output of the syndrome generator Synd 110 are connected to the M-bit wide input of a NOR circuit 3034 having M inputs and one output, while the second M components of the output of the syndrome generator Synd 110 are connected to the M-bit wide input of an OR circuit 3035 having M inputs and one output. The output of the NOR circuit 3034 and the OR circuit 3035 are each connected to an input of an AND gate 3036 having two inputs and one output wherein the same outputs a 1-bit error signal E1 at its output.
The subcircuit Cor/Det 120 of
The error signal E1 is equal to 1, when simulataneously S1=0| and S2≠0|. E1=1 may indicate an address error. The error signal E1 is equal to 0, when S2=0| or when S1≠0|. For E1=0 no address error can exist, except for very few specific constellations of the bits y′1, . . . , y′l (or a′1, . . . , a′l), the probability of which is 2−M, which are mapped to S2=0|.
The bits x1, . . . , xk+m written into the memory Spei 12 at a write address a=a1, . . . , al* here, for example, consists of k data bits u1, . . . , uk and m check bits c1, . . . , cm which form a codeword c1, . . . , cm, u1, . . . , uk, A1, . . . , Al of a linear code C of the length n=k+m+l having m check bits together with the compacted bits A1, . . . , Al of the write address a1, . . . , al* at which the data bits and the check bits have been written into the memory. If the H matrix of the code C is designated by H, the following applies
The bits x′1, . . . , x′k+m read out of the memory Spei 12 at the read address a′ are here applied to a first k+m-bit wide input of a syndrome generator Synd 3141 at whose second l-bit wide input the bits A′1, . . . , A′l of the compacted bits of the read address are applied and which outputs an error syndrome S at its m=2·M bit wide output whose first M components form the subsyndrome S1 and whose second M components form the subsyndrome S2. The syndrome generator Synd 3141 is configured so that it provides the components of the error syndromes according to the H matrix Hat its output and M≧2 applies. The H matrix of the code C is here determined so that errors in bits of the bits x′1, . . . , x′k+m are corrected and errors in compacted address bits y′1=A′1, . . . , y′l=A′l are detected.
If, for example, t=2, then 1-bit errors and 2-bit errors in bits of the bits x′1, . . . , x′k+m are corrected and errors in the bits A′1, . . . , A′l which may, for example, be caused by errors in the bits a1, . . . , al* are detected. The subcircuit 3142 may be configured so that the compacted address bits A1, . . . , Al are formed by l Boolean functions according to the following relation
l*>l applies and f1, f2, . . . , fl each are l*-ary Boolean functions.
It may here be advantageous that
for all values of the addresses a1, . . . , al* applies. It is possible that
applies, wherein K is a binary (l, l*) matrix. In this case, the subcircuit 3142 may be realized by XOR gates.
It is likewise possible that always y1=A1=1 applies and
applies, wherein K+ is a binary (l−1, l*) matrix. It then applies that y1, . . . , yl=A1, . . . , Al is always unequal
It is possible that due to an error all bits x′1, . . . ,x′k+m are erroneously equal to 0. Such an error may be called an All-0-error. It is possible that the bits x′1, . . . , x′k+m are stored into memory cells which erroneously all take on the value 0. Then, the subsyndrome is S1=0|. If the matrix Ha is determined so that
applies, then the subsyndrome S2 is equal
S2=(αr
when the address bits are non-compacted and is equal to
S2=(αr
when the address bits a1, . . . , al* have been compacted into l compacted address bits A1, . . . , Al.
If, for example, m=2·M and l=M, then there are M different M-dimensional column vectors αr
for all occupations of the address bits a1, . . . , al* then the subsyndrome determined according to equation (41) is S2≠0| and the error All-0 is detected for a random value of the address.
For example, the following may be determined
so that the first compacted address bit A1 is always equal 1. In other words, an All-0 error in the bits x′1, . . . , x′k+m which may have been caused by the fact that all values of the memory cells into which x1, . . . , xk+m was written erroneously take on the value 0 then leads to an error syndrome with S1=0| and S2≠0| and the error is detected as a non-correctable error.
For example,
αr
may be determined, wherein IM is the M-dimensional identity matrix. Then, the following applies
(S2)T=IM·[1,A2, . . . ,AM]T=[1,A2, . . . ,AM]T≠0|T.
It is also possible that due to an error all bits x′1, . . . , x′k+m erroneously take on the value 1. Such an error may be called an All-1 error.
If a matrix Hx is used for which
h1x+h2x+ . . . +hk+mx=0
applies, wherein 0 here designates the column vector with 2·M zeroes, then an All-1 error is detected analog to an All-0 error.
In
In some applications, data bits or coded bits may also be protected by a password against unauthorized access. The data bits can only by correctly decoded if the password or identifier bits are known to the receiver. Identifier bits may be also denoted as identifier bits.
Unexpectedly, the concept of data protection by a password or by identifier bits can be easily included into the concept of the invention as will be now described by an example.
It will be, for instance, shown how an erroneous password or erroneous identifier bits will result in an uncorrectable error. The corresponding error signal of an uncorrectable error may for instance automatically stop the readout of the data from the memory.
The error-free bits x1, . . . , xk+m may consist of m check bits c1, . . . , cm and k data bits u1, . . . , uk, wherein the check bits are formed so that
H·[c1, . . . ,cm,u1, . . . ,uk,id1, . . . ,idl]T=0|
applies and c1, . . . , cm, u1, . . . , uk, id1, . . . , idl is a codeword of the considered code C.
It is considered here that both the bits x1, . . . , xk+m written into the memory, when they are read out, may be disturbed by errors in x′1, . . . , x′k+m≠x1, . . . , xk+m and that also bits may be read out at an erroneous address a′=a′1, . . . , a′l*≠a1, . . . , al* so that also the compacted bits A′1, . . . , A′l2, formed from the read address a′1, . . . , a′l* may be erroneous, and also that the identifier bits id1, . . . , idl1 may be different from the correct identifier bits. The memory Spei 12 comprises an address input to which either a write address a=a1, . . . , al* or a read address a′=a′1, . . . , a′l* may be applied. Control signals of the memory, like the write enable signal or the read enable signal, are not indicated in
The bits x1, . . . , xk+m written into the memory Spei 12 at a write address a=a1, . . . , al* here for example consist of k data bits u1, . . . , uk and m check bits c1, . . . , cm which, together with the compacted bits A1, . . . , Al2 of the write address a1, . . . , al* at which the data bits and the check bits have been written into the memory, and the identifier bits id1, . . . , idl1, form a codeword c1, . . . , cm, u1, . . . , uk, A1, . . . , Al2, id1, . . . , idl1 of a linear code C of the length k+m+l with m check bits. If the H matrix of the code C is designated by H, the following applies
The bits x′1, . . . , x′k+m read out of the memory Spei 12 at the read address a′ are here applied to a first k+m-bit wide input of a syndrome generator Synd 3361, at whose second l2-bit wide input the bits A′1, . . . , A′l2 of the compacted bits of the read address are applied and at whose third l1-bit wide input the possibly erroneous identifier bits id′1, . . . , id′l1 are applied and which outputs at its m=2·M bit wide output an error syndrome S whose first M components form the subsyndrome S1 and whose second M components form the subsyndrome S2. Here, the syndrome generator Synd 3361 is configured so that it provides the components of the error syndromes according to the H matrix Hat its output and that M≧2 applies.
The H matrix of the code C is here determined so that errors in bits of the bits x′1, . . . , x′k+m are corrected and errors in the compacted address bits and in identifier bits, i.e. in the bits y′1 . . . , y′l=A′1, . . . , A′l2, id′1, . . . , id′l1 are detected.
If, for example, t=2, then 1-bit errors and 2-bit errors in the bits x′1, . . . , x′k+m are corrected and errors in the bits A′1, . . . , A′l2 which may for example have been caused by errors in the bits a1, . . . , al*, and errors in the bits id′1, . . . , id′l1 are detected.
The syndrome generator Synd 3471 comprises (t−1)·M first outputs for outputting (t−1)·M first components of an error syndrome S determined by the syndrome generator according to the H matrix of the code C which form a subsyndrome S1, and M further outputs for outputting M further components of the error syndrome which are designated by S2. In this embodiment, t≧3 is assumed. The Galois field used for determining the H matrix is GF(2M).
The (t−1)·M first outputs of the syndrome generator Synd 3471 which carry the value S1 are connected to the (t−1)·M inputs of an NOR circuit 3473 having (t−1)·M inputs and one output which is connected to a first input of an AND gate 3475 having 2 inputs and one output. The M second outputs of the syndrome generator Synd 3471 which carry the value S2 are connected to the M inputs of an OR circuit 3474 having M inputs and one output connected to the second input of the AND gate 3475 which outputs an error signal Eat its output. The error signal E is equal to 1, if the (t−1) components of S1 are equal to 0 and if S2 is not equal to 0|. The error signal E=1 indicates an address error.
The t·M outputs of the syndrome generator Synd 3471 are connected to t·M inputs of a corrector Cor 3472 which outputs a k+m-component correction value ecor for correcting possibly erroneous k+m bits of the word v′ at its k+m outputs, wherein k+m designates the number of bits (length of the portion of the word of v′) for which an error correction is in principle possible, up to t bit errors within said set of k+m bits.
If t=3, the H matrix of the code C may have the following form
H=(Hx,Ha)
with
wherein αi
If t=4, the H matrix of the code C may have the following form
H=(Hx,Ha)
with
wherein αi
There is a syndrome generator Synd 3581 having n inputs to which an n-component word v′=v′1, . . . , v′n=x′1, . . . , x′k+m, y′1, . . . , y′l is applied which may have resulted due to errors from a codeword v=v1, . . . , vn of a linear code C of the length n having 2·M+1=m check bits.
The syndrome generator Synd 3581 comprises a first 1-bit wide output for outputting a first component SP of an error syndrome S determined by the syndrome generator according to the H matrix of the code C, M second outputs for outputting M second components of an error syndrome S determined by the syndrome generator according to the H matrix of the code C designated by S1 and M further outputs for outputting M further components of the error syndrome designated by S2. In this embodiment, t=2 is assumed. The syndrome SP is the component of the error syndrome S associated with the parity. The Galois field used for determining the H matrix is GF(2M).
The M second outputs of the syndrome generator carrying the value S1 are connected to the M inputs of an NOR circuit 3584 having M inputs and one output connected to a first input of an AND gate 3586 having two inputs and one output. The M third outputs of the syndrome generator carrying the value S2 are connected to the M inputs of an OR circuit 3585 having M inputs and one output connected to the second input of the AND gate 3586 which outputs an error signal E1 at its output.
Apart from that, the 2·M+1 outputs of the syndrome generator Synd 3581 are connected to 2·M+1 inputs of a corrector/detector Cor/Det 3587 which outputs at its k+m first outputs a k+m-component correction value ecor for correcting possible erroneous k+m bits x′1, . . . , x′k+m of the word v′ and which outputs at further R outputs a further error signal E2, wherein in the considered embodiment R=2.
One possible H matrix is
H=(Hx,Ha)
with
The matrices Hx′ and Ha′ here each consist of the lines 2 to 2M+1 of the matrices Hx and Ha.
The first component SP of the error syndrome is determined by
SP=x′1⊕x′2⊕ . . . ⊕x′k+m. (42)
The following applies
It is further possible to include the parity so that a H matrix H=(Hx, Ha) is formed with
so that only such exponents i1, . . . , ik+m of the generating element α are used that αi
The different representations of elements of a Galois field are known to the person skilled in the art.
For a better understanding of the invention, with reference to an embodiment, the determination of a H matrix with elements of a Galois field GF(2M) is now described, as it is for example described in Lin, S. and Costello, D. “Error Control Coding”, Prentice Hall, 1983 on pages 148 and 149 with reference to page 33.
In this respect, the H matrix
with elements of the Galois field GF(2M) with the modular polynomial p(X)=1+X+X4 is to be considered. The exponents of the generating element α are to be interpreted modulo 241=15, so that e.g. (3·14=42=12 modulo 15) applies.
The 16 elements of the Galois field may be given in the exponential representation, in the polynomial representation and in the vector or tuple representation, wherein the different representations are illustrated in table 1.
As according to table 1 the following applies: α0=[1000]T, α1=[0100]T, α2=[0010]T, α3=[0001]T, α6=[0011]T, . . . , α12=[1111]T, α14=[1001], for the matrix (43) the following results
Some embodiments have been described with respect to columns of the above-described matrices. However, the person skilled in the art understands that all concepts described above are equally applicable to rows of the above-described matrices by employing the above-described concepts.
Although some aspects have been described in the context of an apparatus, it is clear that these aspects also represent a description of the corresponding method, where a block or device corresponds to a method step or a feature of a method step. Analogously, aspects described in the context of a method step also represent a description of a corresponding unit or item or feature of a corresponding apparatus.
Depending on certain implementation requirements, embodiments of embodiments can be implemented in hardware or in software. The implementation can be performed using a digital storage medium, for example a floppy disk, a DVD, a CD, a ROM, a PROM, an EPROM, an EEPROM or a FLASH memory, having electronically readable control signals stored thereon, which cooperate (or are capable of cooperating) with a programmable computer system such that the respective method is performed.
Some embodiments according to embodiments comprise a non-transitory data carrier having electronically readable control signals, which are capable of cooperating with a programmable computer system, such that one of the methods described herein is performed.
Generally, embodiments of the present invention can be implemented as a computer program product with a program code, the program code being operative for performing one of the methods when the computer program product runs on a computer. The program code may for example be stored on a machine readable carrier.
Other embodiments comprise the computer program for performing one of the methods described herein, stored on a machine readable carrier.
In other words, an embodiment of the inventive method is, therefore, a computer program having a program code for performing one of the methods described herein, when the computer program runs on a computer.
A further embodiment of the inventive methods is, therefore, a data carrier (or a digital storage medium, or a computer-readable medium) comprising, recorded thereon, the computer program for performing one of the methods described herein.
A further embodiment of the inventive method is, therefore, a data stream or a sequence of signals representing the computer program for performing one of the methods described herein. The data stream or the sequence of signals may for example be configured to be transferred via a data communication connection, for example via the Internet.
A further embodiment comprises a processing means, for example a computer, or a programmable logic device, configured to or adapted to perform one of the methods described herein.
A further embodiment comprises a computer having installed thereon the computer program for performing one of the methods described herein.
In some embodiments, a programmable logic device (for example a field programmable gate array) may be used to perform some or all of the functionalities of the methods described herein. In some embodiments, a field programmable gate array may cooperate with a microprocessor in order to perform one of the methods described herein. Generally, the methods are performed by any hardware apparatus.
While this invention has been described in terms of several advantageous embodiments, there are alterations, permutations, and equivalents which fall within the scope of this invention. It should also be noted that there are many alternative ways of implementing the methods and compositions of the present invention. It is therefore intended that the following appended claims be interpreted as including all such alterations, permutations, and equivalents as fall within the true spirit and scope of the present invention.
The above described embodiments are merely illustrative for the principles of the present invention. It is understood that modifications and variations of the arrangements and the details described herein will be apparent to others skilled in the art. It is the intent, therefore, to be limited only by the scope of the impending patent claims and not by the specific details presented by way of description and explanation of the embodiments herein.
Although each claim only refers back to one single claim, the disclosure also covers any conceivable combination of claims.
This application is a continuation-in-part of U.S. application Ser. No. 13/975,621, filed on Aug. 26, 2013, which is a continuation of U.S. application Ser. No. 12/943,520, filed on Nov. 10, 2010.
Number | Name | Date | Kind |
---|---|---|---|
3623155 | Hsiao et al. | Nov 1971 | A |
3714629 | Hong et al. | Jan 1973 | A |
5657331 | Metzner et al. | Aug 1997 | A |
5938773 | Hauck | Aug 1999 | A |
7721177 | Gammel et al. | May 2010 | B2 |
7849388 | Esumi et al. | Dec 2010 | B2 |
8230292 | Fujiwara et al. | Jul 2012 | B2 |
20020018389 | Ito | Feb 2002 | A1 |
20030023930 | Fujiwara et al. | Jan 2003 | A1 |
20040221098 | Ito | Nov 2004 | A1 |
20060200729 | Ito | Sep 2006 | A1 |
20060282756 | Gammel et al. | Dec 2006 | A1 |
20070038919 | Sekiguchi | Feb 2007 | A1 |
20070110188 | Esumi et al. | May 2007 | A1 |
20070162821 | Hwang et al. | Jul 2007 | A1 |
20090049369 | Goessel et al. | Feb 2009 | A1 |
20090106633 | Fujiwara et al. | Apr 2009 | A1 |
20090228758 | Choi et al. | Sep 2009 | A1 |
20100169737 | Litsyn | Jul 2010 | A1 |
20110119559 | Kamoshida | May 2011 | A1 |
20120117431 | Bremler-Barr et al. | May 2012 | A1 |
Entry |
---|
Anfinson et al., “A Linear Algebraic Model of Algorithm-Based Fault Tolerance”, 1988, IEEE. |
Chen et al., “Error-Correcting Codes for Semiconductor Memory Applications: A State-of-the-Art Review”, Mar. 1984, IBM j> Res. Develop, vol. 28, No. 2. |
Hsiao, M. Y., “A Class of Optimal Minimum Odd-weight-column SEC-DED Codes”, Jul. 1970, IBM Journal of Research and Development, vol. 14, Iss. 4, pp. 395-401. |
Notice of Allowance dated May 21, 2013 for U.S. Appl. No. 12/943,520. 27 Pages. |
U.S. Appl. No. 13/975,621, filed Aug. 26, 2013. |
U.S. Appl. No. 12/943,520, filed Nov. 10, 2010. |
Number | Date | Country | |
---|---|---|---|
20150007001 A1 | Jan 2015 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12943520 | Nov 2010 | US |
Child | 13975621 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13975621 | Aug 2013 | US |
Child | 14327796 | US |