The present invention relates to a method and an apparatus for correcting and detecting spotty-byte error. More specifically, the present invention relates to a method and an apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes and which are used suitably for detecting and correcting “multiple spotty-byte errors within a byte occurred in a limited number of bytes” in the case where a plurality of bits are called a byte, a plurality of bytes compose a word, and errors such that a plurality of spotty-byte errors occurred within a byte is called “multiple spotty-byte errors within a byte”, and when the multiple spotty-byte errors within a byte occurred in a limited number of bytes, we call such errors as “multiple spotty-byte errors within a byte occurred in a limited number of bytes”.
In recent years, as the information-intensive society is developed and the semiconductor technique makes advance, the improvement of reliability of digital data becomes more important. When digital data are tried to be transmitted or recorded accurately, transmission data are influenced by noises or the like in a transmission channel to be transmitted improperly, elements are failed, or recording media or the like are defected, and thus it is necessary to detect and correct errors which occurred due to them. In order to realize the detection and correction of the errors, various error correction and detection codes have been developed on the basis of the code theory.
As the conventional error correction codes, for example, a Hong-Patel code which is excellent as a code for correcting any error occurred within a byte (SbEC code) (where, a mass of b bits is called a byte and b is an integer that is 2 or more.) is disclosed (for example, see Non-Patent Document 1).
Further, an odd number weight string byte error correction code including a single-bit error correction and double-bit error detection code, which is conventionally used the most frequently in high-speed semiconductor memory systems, is disclosed (for example, see Non-Patent Document 2).
A code for correcting single-byte error and detecting double-byte error (SbEC-DbED code) is proposed as a Reed-Solomon code and as a code which is obtained by improving the Reed-Solomon code and is efficient, and it has been already utilized in main memory device of many computer systems or the like (for example, see Non-Patent Documents 3 and 4).
Moreover, as a code for detecting byte errors, a code for correcting single-bit error and detecting double-bit error and single-byte error (SEC-DED-SbED code) is made in public, and is currently applied to main memory device of many computer systems, (for example, see Non-Patent Document 5).
The concrete contents of the mutually related code research and development up to the late 1980s are pan optically described in Non-Patent Document 6.
Thereafter, as a code for high-speed semiconductor memory systems which is newly developed, a code for correcting single-byte error and detecting double-bit error (SbEC-DED code) is disclosed in Non-Patent Document 7, and a code for correcting single-byte error and simultaneously detecting single-bit error and single-byte error (SbEC-(S+Sb)ED code) is disclosed in Non-Patent Document 8. Further, a code for correcting single-byte error and also correcting double-bit error if occurred (SbEC-DEC code) is disclosed in Non-Patent Document 9.
Particularly, as a code which is most related to the present invention, an invention relating to an St/bEC code for correcting single-spotty-byte error, and relating to an St/bEC-SbED code for correcting single-spotty-byte error and detecting single-byte error exceeding t bits within a byte is already disclosed (see Patent Document 1). Where, a “spotty-byte error” is a “t/b error”, i.e. errors up to t bits (t≦b) within a byte composed of b bits. Particularly, the St/bEC code is disclosed in Non-Patent Document 10.
Further, an invention relating to an St/bEC-Dt/bED code for correcting single-spotty-byte error and detecting double-spotty-byte error and relating to an St/bEC-Dt/bED-SbED code for correcting single-spotty-byte and detecting both double-spotty-byte errors and single-byte errors exceeding t bits within a byte is already applied (see Patent Document 2).
In the case of considering a plurality of spotty-byte errors, an error in which only single-spotty-byte error occurred within a byte, is called “single spotty-byte error within a byte”. An invention relating to a general constitution method in which a distance “d” is provided to the single spotty-byte error within a byte has been already filed (see Patent Document 3).
Further, an error in which a plurality of spotty-byte errors (namely, two or more spotty-byte errors) occurred within a byte is called “multiple spotty-byte errors within a byte”. An invention relating to a general constitution method in which a distance “d” is provided to the multiple spotty-byte errors within a byte has been already filed (see Patent Document 4).
Since elements which have input-output of 1-bit data are mainly used as semiconductor memory elements until the mid-1980s, single-bit error correction and double-bit error detection code (SEC-DED code) for correcting an error of one element and detecting errors to two elements is used frequently. However, elements having input-output of 4-bit data start to be a mainstream from the mid-1980s according to high integration of memory elements, and thus the S4EC-D4ED code and the SEC-DED-S4ED code whose byte width “b” is 4 bits (b=4) are mainly used. Further, semiconductor memory elements having input-output of 8-bit and 16-bit data start to be a mainstream from the mid-1990s.
However, when the byte width of 8 bits (b=8) or 16 bits (b=16) is applied to the byte width “b” of the conventional SbEC-DbED code, the proportion of the number of check bits share to the total code length is about 30% to 40%, which is large, and the code rate is reduced, thereby arising a practically significantly important problem.
In memory device using these semiconductor memory elements (DRAM elements, herein after, also simply referred to as element), temporary fault occurs due to noises, alpha particles and the like, or the DRAM elements are deteriorated and are not operated, namely, permanent fault occurs. 80% or more of the recent devices using the DRAM elements temporarily faulted, and particularly in the DRAM elements having multi-bit data input-output of 8 or more bits, the most of bit errors are errors of comparatively small bits such as 1, 2 and 3 bit within a byte.
Among them, a temporary error due to electromagnetic noises and alpha particles with comparatively low-level energy and single-bit error due to the permanent fault of a memory cell are generated most frequently. Recently, since mobile devices loaded with the DRAM elements are used so frequently, the use in unsatisfactory electromagnetic environments should be taken into consideration. In the DRAM elements in electronic devices to be used for high-altitude aircrafts and fighting aircrafts, it is highly possible that the temporary fault having about double-bit error or triple-bit error occurs due to collision of neutron particles or the like of high energy level caused by cosmic ray. In the DRAM elements loaded onto space appliances to be used for satellite communication and space communication, it is necessary to consider the heavy damage due to the collision of particles of a high energy level, and in this case, 2 or more bits error should be taken into consideration.
Since the bit error occurrence is widely ranging as mentioned above, the St/bEC-SbED code which can be structured by giving any value to parameters t and b is a very practical code system, when this code is used for the memory device using the DRAM chips of 8 or more bits. That is, the St/bEC-SbED code is provided with the function capable of correcting spotty-byte error, i.e. one chip error up to t bits (t is smaller than the byte width b and the value of t can be arbitrarily determined by designer who conduct a search on tendency of error) and the function capable of detecting single-byte errors exceeding t-bit errors whose probability of occurrence is low. As a result, the St/bEC-SbED code can correct and detect error by using the significantly smaller number of check bits than that of a conventional error control code such as the Reed-Solomon code (RS code) with which errors are controlled by byte unit.
The St/bEC-Dt/bED-SbED code is a very practical code system for an error to extend to two arbitrary chips (the two arbitrary chips is not limited to adjacent two chips), when this code is used in the memory device using the DRAM chips of 8 or more bits. That is, the St/bEC-Dt/bED-SbED code is provided with the function capable of correcting one chip error up to t (t is smaller than the byte width b) bits (single-spotty-byte error correction, St/bEC), the function capable of detecting spotty-byte error to extend to two elements (double-spotty-byte error detection, Dt/bED) and the function capable of detecting single-byte error exceeding t-bits though whose probability of occurrence is low (single-byte error detection, SbED). As a result, the St/bEC-Dt/bED-SbED code can correct and detect bit error by using the significantly smaller number of check bits than that of a conventional code system which correct and detect bit error by byte unit.
A spotty-byte error control code generally having a distanced over GF(2b) is constructed theoretically for the single spotty-byte error within a byte and the multiple spotty-byte errors within a byte, so that an error to extend to two or more chips can be corrected and detected.
However, an error to extend to a lot of chips seldom occurs at the same time. Generally, an error occurs in a limited number of elements, namely, in a limited number of bytes. In addition, the number of chips on which an error occurs is two or three at most.
The present invention is devised in view of the above circumstances, and it is an object of the present invention to provide a method and an apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes.
It is another object of the present invention to provide a method and an apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes with controlling random bit errors occurred in the limited number of bytes when t=1.
Further, it is still another object of the present invention to provide a method and an apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes with detecting single byte errors exceeding correction capability of multiple spotty-byte errors within a byte whose probability of occurrence is low.
The present invention relates to an apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes, comprising: an encoding means for generating a transmitted word based on input information data; and a decoding means for inputting said transmitted word where errors occurred in an information transmission channel as a received word and correcting and detecting said errors. The above object of the present invention is effectively achieved by that: said encoding means generates said transmitted word by adding check information generated based on a parity check matrix expressing a spotty-byte error control code and said input information data to said input information data, said decoding means comprises a syndrome generating means for generating a syndrome of said received word based on said parity check matrix; and an error correction means for correcting and detecting said errors of said received word based on said syndrome generated by said syndrome generating means. The above object of the present invention is also effectively achieved by that: when said input information data is composed of multiple bytes, where b bits (b is an integer that is 2 or more.) is called a byte, errors up to t bits (1≦t≦b) within a byte is called a spotty-byte error, and errors in which a plurality of said spotty-byte errors occurred within a byte is called multiple spotty-byte errors within a byte, said spotty-byte error control code expressed by said parity check matrix corrects μ1 spotty-byte errors occurred in p1 bytes and detects μ2 spotty-byte errors occurred in p2 bytes. The above object of the present invention is also effectively achieved by that: said value t, said value b, said value p1, said value p2, said value μ1 and said value μ2 are arbitrarily set, where p1≦p2 and μ1≦μ2 hold. The above object of the present invention is also effectively achieved by that: said information transmission channel is an information communication system. The above object of the present invention is also effectively achieved by that: said information transmission channel is a memory system. The above object of the present invention is also effectively achieved by that: said information transmission channel is a bus line circuit.
Further, the above object of the present invention is also effectively achieved by that: said parity check matrix is the following matrix H having R rows and N columns which is used for an error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes with a function of correcting μ1 spotty-byte errors occurred in p1 bytes and detecting μ2 spotty-byte errors occurred in p2 bytes ([μ1t/bEC]p
where R=q+(p1+p2−1) r, N=bn, 0≦i≦n−1 and n=2r−1 hold, said matrix H′ is a binary matrix of q rows and b columns (q≦b) composed of a q-dimension column vector hj′ (0≦j≦b−1) shown in H′=[h0′, h1′, . . . , hb−1′], plural columns whose number is larger than or equal to either smaller one of (μ1+μ2)t and b are linearly independent, if (μ1+μ2)t≧b, said matrix H′ is a nonsingular matrix including an identity matrix, if (μ1+μ2)t<b, said matrix H′ is equal to a check matrix of a code having a minimum Hamming distance (μ1+μ2)t+1, namely, a parity check matrix of a (b,b−q) code with a function of detecting (μ1+μ2)t bits error, said matrix H″ is a binary matrix having r rows and b columns (r≦b) composed of an q-dimensional column vector hj″ (0≦j≦b−1) shown in H″=[h0″, h1″, . . . , hb−1″], plural columns whose number is larger than or equal to either smaller one of └(μ1+μ2)/2┘t and b are linearly independent, └x┘ represents a maximum integer which does not exceed x, if └(μ1+μ2)/2┘t≧b, said matrix H″ is a nonsingular matrix including an identity matrix, if └(μ1+μ2)/2┘t<b, said matrix H″ is equal to a check matrix of a code having a minimum Hamming distance └(μ1+μ2)/2┘t+1, namely, a parity check matrix of a (b,b−r) code with a function of detecting └(μ1+μ2)/2┘t bits error, γ is a primitive element of an r-th degree extension field GF(2r) of GF(2), and γiH″=[γiH0″, γiH1″, . . . , γiHb−1″] holds.
Further, the above object of the present invention is also effectively achieved by that: said parity check matrix is the following matrix H having R rows and N columns which is used for a lengthened error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes with a function of correcting μ1 spotty-byte errors occurred in p1 bytes and detecting μ2 spotty-byte errors occurred in p2 bytes (lengthened [μ1t/bEC]p
where r′≧r, R=q+(p1+p2−1)r′, N=b(n+1)+r′, 0≦i≦n−1 and n=2r′−1 hold, Ir′ is an r′ by r′ identity matrix, O is a zero matrix, said matrix H′ is a binary matrix of q rows and b columns (q≦b) composed of a q-dimensional column vector hj′ (0≦j≦b−1) shown in H′=[h0′, h1′, . . . , hb−1′], plural columns whose number is larger than or equal to either smaller one of (μ1+μ2)t and b are linearly independent, if (μ1+μ2)t≧b, said matrix H′ is a nonsingular matrix including an identity matrix, if (μ1+μ2)t<b, said matrix H′ is equal to a check matrix of a code having a minimum Hamming distance (μ1+μ2)t+1, namely, a parity check matrix of a (b,b−q) code with a function of detecting (μ1+μ2)t bits error, said matrix H″ is a binary matrix of r rows and b columns (r≦b) composed of an r-dimensional column vector hj″ (0≦j≦b−1) shown in H″=[h0″, h1″, . . . , hb−1″], plural columns whose number is larger than or equal to either smaller one of └(μ1+μ2)/2┘t and b are linearly independent, └x┘ represents a maximum integer which does not exceed x, if └(μ1+μ2)/2┘t≧b, said matrix H″ is a nonsingular matrix including an identity matrix, if └(μ1+μ2)/2┘t<b, said matrix H″ is equal to a check matrix of a code having a minimum Hamming distance └(μ1+μ2)/2┘t+1, namely, a parity check matrix of a (b,b−r) code with a function of detecting └(μ1+μ2)/2┘t bits error, γ is a primitive element of an r′-th degree extension field GF(2r′) of GF(2), γiH″=[γiΦ(h0″), γiΦ(h1″), . . . , γiΦ(hb−1″)] holds, (D is an injective homomorphism from GF(2r) to GF(2r′) under addition, namely, Φ:GF(2r)→GF(2r′).
Further, the above object of the present invention is also effectively achieved by that: said parity check matrix is the following matrix H having R rows and N columns which is used for an error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes with a function of correcting μ1 spotty-byte errors occurred in p1 bytes, and detecting μ2 spotty-byte errors occurred in p2 bytes and single-byte error exceeding correction capability ([μ1t/bEC]p
where R=b+(p1+p2−1)r, N=bn, 0≦i≦n−1 and n=2r−1 hold, Ib is a b by b identity matrix, said matrix H″ is a binary matrix of r rows and b columns (r≦b) composed of an r-dimensional column vector hj″ (0≦j≦b−1) shown in H″=[h0″, h1″, . . . , hb−1″], plural columns whose number is larger than or equal to either smaller one of └(μ1+μ2)/2┘t and b are linearly independent, └x┘ represents a maximum integer which does not exceed x, if └(μ1+μ2)/2┘t≧b, said matrix H″ is a nonsingular matrix including an identity matrix, if └(μ1+μ2)/2┘t<b, said matrix H″ is equal to a check matrix of a code having a minimum Hamming distance └(μ1+μ2)/2┘t+1, namely, a parity check matrix of a (b,b−r) code with a function of detecting └(μ1+μ2)/2┘t bits error, y is a primitive element of an r-th degree extension field GF(2r) of GF(2), and γiH″=[γih0″, . . . , γih1″, . . . , γihb−1″] holds.
Further, the above object of the present invention is also effectively achieved by that: said parity check matrix is the following matrix H having R rows and N columns which is used for a lengthened error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes with a function of correcting μ1 spotty-byte errors occurred in p1 bytes, and detecting μ2 spotty-byte errors occurred in p2 bytes and single-byte error exceeding correction capability (lengthened [μ1t/bEC]p
where r′≧r, R=b+(p1+p2−1)r′, N=b(n+1)+r′, 0≦i≦n−1 and n=2r′−1 hold, Ib is a b by b identity matrix, Ir′ is an r′ by r′ identity matrix, O is a zero matrix, said matrix H″ is a binary matrix of r rows and b columns (r≦b) composed of an r-dimensional column vector hj″ (0≦j≦b−1) shown in H″=[h0″, h1″, . . . , hb−1″], plural columns whose number is larger than or equal to either smaller one of t and b are linearly independent, └x┘ represents a maximum integer which does not exceed x, if └(μ1+μ2)/2┘t≧b, said matrix H″ is a nonsingular matrix including an identity matrix, if └(μ1+μ2)/2┘t<b, said matrix H″ is equal to a check matrix of a code having a minimum Hamming distance └(μ1+μ2)/2┘t+1, namely, a parity check matrix of a (b,b−r) code with a function of detecting └(μ1+μ2)/2┘t bits error, γ is a primitive element of an r′-th degree extension field GF(2r′) of GF(2), γiH″=[γiΦ(h0″), γiΦ(h1″), . . . , γiΦ(hb−1″)] holds, Φ is an injective homomorphism from GF(2r) to GF(2r′) under addition, namely, Φ:GF(2r)→GF(2r′).
Further, the above object of the present invention is also effectively achieved by that: said error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes ([μ1t/bEC]p
Further, the above object of the present invention is also effectively achieved by that: if t≧b/└(μ1+μ2)/2J, said matrix H′ and said matrix H″ become matrices where arbitrary b columns are linearly independent, and said parity check matrix (H) corresponds with a parity check matrix of an RS code having a function of correcting p1 bytes error and detecting p2 bytes error. The above object of the present invention is also effectively achieved by that: if t≧b/└(μ1+μ2)/2J, said matrix H′ and said matrix H″ become matrices where arbitrary b columns are linearly independent, and said parity check matrix (H) corresponds with a parity check matrix of a doubly lengthened RS code having a function of correcting p1 bytes error and detecting p2 bytes error. The above object of the present invention is also effectively achieved by that: if t≧b/└(μ1+μ2)/2┘, said matrix H″ becomes a matrix where arbitrary b columns are linearly independent, and said parity check matrix (H) corresponds with a parity check matrix of an RS code having a function of correcting p1 bytes error and detecting p2 bytes error. The above object of the present invention is also effectively achieved by that: if t≧b/└(μ1+μ2)/2┘, said matrix H″ becomes a matrix where arbitrary b columns are linearly independent, and said parity check matrix (H) corresponds with a parity check matrix of a doubly lengthened RS code having a function of correcting p1 bytes error and detecting p2 bytes error.
Further, the above object of the present invention is also effectively achieved by that: said error correction means generates a bit-error pointer for detecting which bit of said received word has an error based on said syndrome, and corrects said error of said received word by inverting bit value of said received word corresponding to erroneous bits based on said generated bit-error pointer, and when detecting that bit error of said received word cannot be corrected, said error correction means outputs an uncorrectable error detection signal. The above object of the present invention is also effectively achieved by that: said error correction means comprises an H′ decoding means; an H″ multiplication means; a parallel decoding means over GF(2r); an error vector generating means over GF(2b); and an inverting means. The above object of the present invention is also effectively achieved by that: said H′ decoding means generates a byte-by-byte sum of errors (eA) based on upper q bits on said syndrome generated by said syndrome generating means, said H″ multiplication means generates a product of said byte-by-byte sum of errors (eA) and a transposed matrix of H″ based on said byte-by-byte sum of errors (eA) generated by said H′ decoding means, said parallel decoding means over GF(2r) generates a bit-error pointer over GF(2r) and a first uncorrectable error detection signal which is output when error correction is regarded as impossible in parallel decoding over GF(2r), based on said product of said byte-by-byte sum of errors (eA) and a transposed matrix of H″ which is generated by said H″ multiplication means, and residual lower bits excluding said upper q bits on said syndrome generated by said syndrome generating means, said error vector generating means over GF(2b) generates a bit-error pointer over (2b) and a second uncorrectable error detection signal which is output when error correction is regarded as impossible, based on said byte-by-byte sum of errors (eA) generated by said H′ decoding means and said bit-error pointer over GF(2r) generated by said parallel decoding means over GF(2r), said inverting means corrects said error in said received word by inverting bit value of said received word corresponding to said bit-error pointer over GF(2b) based on said bit-error pointer over GF(2b) generated by said error vector generating means over GF(2b). The above object of the present invention is also effectively achieved by that: said error correction means outputs a third uncorrectable error detection signal representing that an error exceeding correction capability is detected by obtaining logical OR of said first uncorrectable error detection signal generated by said parallel decoding means over GF(2r) and said second uncorrectable error detection signal generated by said error vector generating means over GF(2b).
Further, the above object of the present invention is also effectively achieved by that: said error vector generating means over GF(2b) comprises a plurality of t-bit error correction decoding means, a multi-input sorting means and a plurality of miscorrection determining means in i-th byte, said plurality of t-bit error correction decoding means outputs a detection signal in i-th byte and 1 byte of bit-error pointer (ê) produced by the decoder from 1 byte of said bit-error pointer (e′) over GF(2r), said multi-input sorting means outputs 1 from upper bits of outputs continuously only as for the number of weights of said plural detection signals in i-th byte which were input, said miscorrection determining means in i-th byte carries out a miscorrection determination and outputs 1 byte of said bit-error pointer (e) over GF(2b). The above object of the present invention is also effectively achieved by that: said error vector generating means over GF(2b) comprises a plurality of t-bit error correction decoding means, a multi-input sorting means and a plurality of miscorrection determining means in i-th byte, said t-bit error correction decoding means is a means which inputs predetermined 1 byte of said bit-error pointer (e′) over GF(2r) and outputs 1 byte of bit-error pointer (ê) produced by the decoder corresponding to said predetermined 1 byte to said miscorrection determining means in i-th byte, and outputs a detection signal in i-th byte that is a signal for detecting an error exceeding correction capability to said multi-input sorting means and said miscorrection determining means in i-th byte, said multi-input sorting means is a means which counts the number of weights (the number of “1”) of said plural detection signals in i-th byte which were input and outputs 1 from upper bits of outputs continuously only as for the number of weights, said miscorrection determining means in i-th byte is a means which inputs said bit-error pointer (ê) produced by the decoder that were output from said t-bit error correction decoding means of all bytes, said detection signal in i-th byte and said byte-by-byte sum of errors (eA), carries out a miscorrection determination and outputs 1 byte of said bit-error pointer (e) over GF(2b). The above object of the present invention is also effectively achieved by that: said error vector generating means over GF(2) outputs an upper second bit signal of signals output from said multi-input sorting means as said second uncorrectable error detection signal, and collects signals output from said miscorrection determining means in i-th byte and outputs said bit-error pointer over GF(2b) having the number of bits of code length.
Further, the above object of the present invention is also effectively achieved by that: said miscorrection determining means in i-th byte carries out said miscorrection determination by the following miscorrection determination expression,
w
M(êx+eA)≦μ1−wM(êx)
where wM(e) is defined by
and represents the number of spotty-byte errors, and wH(ei) represents a Hamming weight over a Galois field GF(2) of a vector ei, when said miscorrection determination expression holds, ex=êx and thus a determination is made that miscorrection is not carried out, and when said miscorrection determination expression does not hold, ex≠êx and thus a determination is made that miscorrection is carried out. The above object of the present invention is also effectively achieved by that: with respect to said [μ1t/bEC]p
Furthermore, the present invention relates to a method for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes, comprising: an encoding processing step of generating a transmitted word based on input information data; and a decoding processing step of inputting said transmitted word where errors occurred in an information transmission channel as a received word and correcting and detecting said errors. The above object of the present invention is effectively achieved by that: in said encoding processing step, said transmitted word is generated by adding check information generated based on a parity check matrix expressing a spotty-byte error control code and said input information data to said input information data, said decoding processing step comprises a syndrome generating processing step of generating a syndrome of said received word based on said parity check matrix; and an error correction processing step of correcting and detecting said errors in said received word based on said syndrome generated by said syndrome generating processing step, when said input information data is composed of multiple bytes, where b bits (b is an integer that is 2 or more.) is called a byte, errors up to t bits (1≦t≦b) within a byte is called a spotty-byte error, and errors in which a plurality of said spotty-byte errors occurred within a byte is called multiple spotty-byte errors within a byte, said spotty-byte error control code expressed by said parity check matrix corrects μ1 spotty-byte errors occurred in p1 bytes and detects 2 spotty-byte errors occurred in p2 bytes, said value t, said value b, said value p1, said value p2, said value μ1 and said value μ2 are arbitrarily set, where p1≦p2 and μ1≦μ2 hold, said information transmission channel is any one of an information communication system, a memory system and a bus line circuit.
Further, the above object of the present invention is also effectively achieved by that: in said error correction processing step, a bit-error pointer for detecting which bit of said received word has an error, is generated based on said syndrome, and said error in said received word is corrected by inverting bit value of said received word corresponding to erroneous bits based on said generated bit-error pointer, and when detecting that bit error of said received word cannot be corrected, an uncorrectable error detection signal is output. The above object of the present invention is also effectively achieved by that: said error correction processing step comprises an H′ decoding processing step; an H″ multiplication processing step; a parallel decoding processing step over GF(2r); an error vector generating processing step over GF(2b); and an inverting processing step. The above object of the present invention is also effectively achieved by that: in said H′ decoding processing step, a byte-by-byte sum of errors (eA) is generated based on upper q bits on said syndrome generated by said syndrome generating processing step, in said H″ multiplication processing step, a product of said byte-by-byte sum of errors (eA) and a transposed matrix of H″ is generated based on said byte-by-byte sum of errors (eA) generated by said H′ decoding processing step, in said parallel decoding processing step over GF(2r), a bit-error pointer over GF(2r) and a first uncorrectable error detection signal which is output when error correction is regarded as impossible in parallel decoding over GF(2r), are generated based on said product of said byte-by-byte sum of errors (eA) and a transposed matrix of H″ which is generated by said H″ multiplication processing step, and residual lower bits excluding said upper q bits on said syndrome generated by said syndrome generating processing step, in said error vector generating processing step over GF(2b), a bit-error pointer over GF(2b) and a second uncorrectable error detection signal which is output when error correction is regarded as impossible, are generated based on said byte-by-byte sum of errors (eA) generated by said H′ decoding processing step and said bit-error pointer over GF(2r) generated by said parallel decoding processing step over GF(2r), in said inverting processing step, said error in said received word is corrected by inverting bit value of said received word corresponding to said bit-error pointer over GF(2b) based on said bit-error pointer over GF(2b) generated by said error vector generating processing step over GF(2b). The above object of the present invention is also effectively achieved by that: in said error correction processing step, a third uncorrectable error detection signal representing that an error exceeding correction capability is detected, is output by obtaining logical OR of said first uncorrectable error detection signal generated by said parallel decoding processing step over GF(2r) and said second uncorrectable error detection signal generated by said error vector generating processing step over GF(2b).
Further, the above object of the present invention is also effectively achieved by that: said error vector generating processing step over GF(2b) comprises a plurality of t-bit error correction decoding processing steps, a multi-input sorting processing step and a plurality of miscorrection determining processing steps in i-th byte, in said t-bit error correction decoding processing step, a detection signal in i-th byte and 1 byte of bit-error pointer (ê) produced by the decoder are output from 1 byte of said bit-error pointer (e′) over GF(2r), in said multi-input sorting processing step, 1 is output from upper bits of outputs continuously only as for the number of weights of said plural detection signals in i-th byte which were input, in said miscorrection determining processing step in i-th byte, a miscorrection determination is carried out and 1 byte of said bit-error pointer (e) over GF(2b) is output. The above object of the present invention is also effectively achieved by that: said error vector generating processing step over GF(2b) comprises a plurality of t-bit error correction decoding processing steps, a multi-input sorting processing step and a plurality of miscorrection determining processing steps in i-th byte, in said t-bit error correction decoding processing step, predetermined 1 byte of said bit-error pointer (e′) over GF(2r) is input, and 1 byte of bit-error pointer (ê) produced by the decoder corresponding to said predetermined 1 byte is output to said miscorrection determining processing step in i-th byte, and a detection signal in i-th byte that is a signal for detecting an error exceeding correction capability is output to said multi-input sorting processing step and said miscorrection determining processing step in i-th byte, in said multi-input sorting processing step, the number of weights (the number of “1”) of said plural detection signals in i-th byte which were input, is counted, and 1 is output from upper bits of outputs continuously only as for the number of weights, in said miscorrection determining processing step in i-th byte, said bit-error pointer (ê) produced by the decoder that were output from said t-bit error correction decoding processing step of all bytes, said detection signal in i-th byte and said byte-by-byte sum of errors (eA) are input, a miscorrection determination is carried out and 1 byte of said bit-error pointer (e) over GF(2b) is output. The above object of the present invention is also effectively achieved by that: in said error vector generating processing step over GF(2), an upper second bit signal of signals output from said multi-input sorting processing step is output as said second uncorrectable error detection signal, and signals output from said miscorrection determining processing step in i-th byte are collected, and said bit-error pointer over GF(2b) having the number of bits of code length is output.
Further, the above object of the present invention is also effectively achieved by that: in said miscorrection determining processing step in i-th byte, said miscorrection determination is carried out by the following miscorrection determination expression,
w
M(êx+eA)≦μ1−wM(êx)
where wM(e) is defined by
and represents the number of spotty-byte errors, and wH(ei) represents a Hamming weight over a Galois field GF(2) of a vector ei, when said miscorrection determination expression holds, ex=êx and thus a determination is made that miscorrection is not carried out, and when said miscorrection determination expression does not hold, ex≠êx and thus a determination is made that miscorrection is carried out. The above object of the present invention is also effectively achieved by that: with respect to said [μ1t/bEC]p
The best mode for carrying out the present invention is explained in detail below with reference to the drawings.
Terms for explaining the present invention are defined as follows. In the embodiment of the present invention, intended digital data are signals in which 0 and 1 are combined (binary codes), and “occurrence of bit error” means that any bit within a code word is changed from 0 into 1 or from 1 into 0. “occurrence of spotty-byte error” means that t bits within a byte composed of b bits (t≦b) is changed from 0 into 1 or from 1 into 0.
In the embodiment, “error” includes all “bit error” and “spotty-byte error” unless otherwise specified. An error such that a plurality of spotty-byte errors occurred within a byte (namely, two or more spotty-byte errors) is called “multiple spotty-byte errors within a byte”. Further, when the multiple spotty-byte errors within a byte occurred in a limited number of bytes, we call such errors as “multiple spotty-byte errors within a byte occurred in a limited number of bytes”.
Here, we first explain the whole constitution of an apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes 100 according to the present invention.
The encoding circuit 2 generates check information for intended digital data (herein after, referred to as input information data 30). The check information executes correction and detection of errors and is composed of any number of check bits.
The circuit 3 corresponds to a data communication channel such as a memory or the like, and in this embodiment, there is a possibility that data through the circuit 3 includes errors. That is, an error does not occur in the data which is output from the encoding circuit 2 and input into the circuit 3, while an error occasionally occurs in the data which is output from the circuit 3.
The decoding circuit 4 comprises a syndrome generating circuit 1 and an error correction circuit 5. The decoding circuit 4 detects whether a received word 32 includes an error, and identifies the error location to correct it. The concrete configuration of the decoding circuit 4 is explained in a decoding process, mentioned later.
In an encoding process and the decoding process, mentioned later, since matrix operation is performed based on the theory concerning to Galois field, the respective data in the encoding circuit 2, the decoding circuit 4 and the data communication channel is expressed by matrix of alphabetical character or vector. Concretely, for example, these data are expressed as input information data D, code (parity check matrix) H, check information C, transmitted word V, received word V′ and syndrome S.
Next, the entire operation of the spotty-byte error correction and detection apparatus 100 of the present invention is explained below.
As shown in
Next, the decoding circuit 4 checks whether an error occurred in the input received word (V′) 32 by using the parity check matrix (H) which is used in the encoding circuit 2. Concretely, the syndrome generating circuit 1 of the decoding circuit 4 generates a syndrome (S) by multiplying the received word (V′) 32 by a transposed matrix (HT) obtained by transposing the parity check matrix (H) expressing code (Step S203). Since the value of the syndrome (S) 33 changes depending on the received word (V′) 32, it is possible to determine whether the received word (V′) 32 includes an error.
The error correction circuit 5 of the decoding circuit 4 detects existence or nonexistence of an error based on the value of the syndrome (S) 33 (step S204), and determines whether the error can be corrected in the case of detecting an error (step S205). When the error can be detected as a result of the determination, the error correction circuit 5 corrects the error (step S206). Then, when the error correction circuit 5 gives a correction process of spotty-byte error to the received word V′, it outputs the corrected received word V′ as received word output information data (V*) 34 (step S207). On the contrary, as a result of the determination at step S205, when an uncorrectable spotty-byte error or the like is detected, the error correction circuit 5 outputs an UCE (Uncorrectable Error) signal 35 as an uncorrectable error detection signal (step S208).
The constitution of the parity check matrix (H) to be used in the encoding circuit 2 and the decoding circuit 4 is explained in detail below. The parity check matrix H of the present invention (herein after, also referred to as H matrix, code matrix or simply check matrix) is a code with a function of correcting and detecting multiple spotty-byte errors occurred in a limited number of bytes.
This embodiment describes general code structuring method capable of structuring for any p1, p2 (p1≦p2), μ1, μ2 (μ1≦μ2), t (t is an integer that is 1 or more but not exceeding b) and b (b is an integer that is 2 or more), a method of capable of actually correcting and detecting errors using the codes, the encoding circuit and the decoding circuit to be used in the method, and that the encoding circuit and the decoding circuit can correct and detect errors concretely.
Concretely, the following shows that μ1 spotty-byte errors occurred in p1 bytes can be corrected, and 2 spotty-byte errors occurred in p2 bytes can be detected.
“An error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes” with a function of correcting μ1 spotty-byte errors occurred in P1 bytes and detecting μ2 spotty-byte errors occurred in p2 bytes, is expressed as [μ1t/bEC]p
Further, in the code structuring method of the present invention, if t=b, as will herein after be described in detail, namely, if t≧b/└(μ1+μ2)/2┘, the code constructed by the present invention corresponds with the Reed-Solomon code (RS code) that is a conventional byte error control code.
When the check information (C) of R bits is added to the input information data (D) 30 of K bits and thus a transmitted word (V) (row vector of N bits) with a length of N=K+R bits for satisfying a certain function can be constructed, a relationship V·HT=0 holds between the transmitted word (V) and a binary parity check matrix (H) of R rows and N columns for defining the error control code. Where, HT is a transposed matrix obtained by transposing row and column of the parity check matrix (H). 0 on the right-hand side of the relationship V·HT=0, represents an all 0 row vector of R bits.
In this embodiment, the parity check matrix (H) of R rows and N columns which is used for the error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes with a function of correcting μ1 spotty-byte errors occurred in p1 bytes and detecting μ2 spotty-byte errors occurred in p2 bytes ([μ1t/bEC]p
where R=q+(p1+p2−1)r, N=bn, 0≦i≦n−1 and n=2r−1 hold.
The matrix H′ constituting the Expression 1 is a binary matrix of q rows and b columns (q≦b) composed of q-dimensional column vector hj′ (0≦j≦b−1)shown in the following Expression 2, and plural columns whose number is larger than or equal to either smaller one of (μ1+μ2)t and b are linearly independent.
H′=[h
0
′,h
1
′, . . . , h
b−1′] [Expression 2]
if (μ1+μ2)t≧b, the matrix H′ is a nonsingular matrix including an identity matrix, and if (μ1+μ2)t<b, the matrix H′ is equal to a check matrix of a code having a minimum Hamming distance (μ1+μ2)t+1, namely, a parity check matrix of a (b,b−q) code with a function of detecting (μ1+μ2)t bits error.
The matrix H″ constituting the Expression 1 is a binary matrix having r rows and b columns (r≦b) composed of r-dimensional column vector hj″ (0≦j≦b−1) shown in the following Expression 3, and plural columns whose number is larger than or equal to either smaller one of └(μ1+μ2)/2┘t and b are linearly independent. └x┘ represents a maximum integer which does not exceed x.
H″=[h
0
″,h
1
″, . . . , h
b−1″] [Expression 3]
if └(μ1+μ2)/2┘t≧b, the matrix H″ is a nonsingular matrix including an identity matrix, and if └(μ1+μ2)/2┘t<b, the matrix H″ is equal to a check matrix of a code having a minimum Hamming distance └(μ1+μ2)/2┘t+1, namely, a parity check matrix of a (b,b−r) code with a function of detecting └(μ1+μ2)/2┘t bits error.
When γ is a primitive element of an r-th degree extension field GF(2r) of GF(2), γiH″ can be defined by the following Expression 4.
γiH″=[γih0″,γih1″, . . . , γihb−1″] [Expression 4]
In this case, a maximum code length N is N=b(2r−1)
In the case of parameter t≧b/└(μ1+μ2)/2┘, since H′ and H″ become matrices where any b columns are linearly independent, the parity check matrix (H) shown in the Expression 1 corresponds with a parity check matrix of a conventional p1 correction p2 detection RS code with a function of correcting p1 bytes error and detecting p2 bytes error.
In this embodiment, a lengthened code of [μ1t/bEC]p
where r′≧r, R=q+(p1+p2−1)r′, N=b(n+1)+r′, 0≦i≦n−1 and n=2r′−1 hold. Ir′ is a r′ by r′ identity matrix, and O is a zero matrix.
The matrix H′ constituting the Expression 5 is a binary matrix of q rows and b columns (q≦b) composed of q-dimensional column vector hj′ (0≦j≦b−1) shown in the following Expression 6, and plural columns whose number is larger than or equal to either smaller one of (μ1+μ2) t and b are linearly independent.
H′=[h
0
′,h
1
′, . . . , h
b−1′] [Expression 6]
if (μ1+μ2)t≧b, the matrix H′ is a nonsingular matrix including an identity matrix, and if (μ1+μ2)t<b, the matrix H′ is equal to a check matrix of a code having a minimum Hamming distance (μ1+μ2) t+1, namely, a parity check matrix of a (b,b−q) code with a function of detecting (μ1+μ2)t bits error.
The matrix H″ constituting the Expression 5 is a binary matrix of r rows and b columns (r≦b) composed of r-dimensional column vector hj″ (0≦j≦b−1) shown in the following Expression 7, and plural columns whose number is larger than or equal to either smaller one of └(μ1+μ2)/2┘t and b are linearly independent. └x┘ represents a maximum integer which does not exceed x.
H″=[h
0
″,h
1
″, . . . , h
b−1″] [Expression 7]
if └(μ1+μ2)/2┘t≧b, the matrix H″ is a nonsingular matrix including an identity matrix, and └(μ1+μ2)/2┘t<b, the matrix H″ is equal to a check matrix of a code having a minimum Hamming distance └(μ1+μ2)/2┘t+1, namely, a parity check matrix of a (b,b−r) code with a function of detecting └(μ1+μ2)/2┘t bits error.
When γ is a primitive element of an r′-th degree extension field GF(2r′) of GF(2), γiH″ can be defined by the following Expression 8.
γiH″=[γiΦ(h0″),γiΦ(h1″), . . . , γiΦ(hb−1″)] [Expression 8]
Where, Φ is an injective homomorphism from GF(2r) to GF(2r′) under addition, namely, Φ is achieved effectively by GF(2r)→GF(2r′). In this case, the maximum code length N is b−2r′+r′. Attention should be paid to that the number of rows r′ of H″ to be used for the second and lower rows of H shown in the Expression 5 can obtain a value larger than r, and the code expressed by the Expression 5 can be constructed for an arbitrary code length by increasing the number of check bits by (μ1+μ2-1) bits.
In the case of parameter t≧b/└(μ1+μ2)/2┘, since H′ and H″ become matrices where any b columns are linearly independent, the parity check matrix (H) shown in the Expression 5 corresponds with a parity check matrix of a conventional p1 correction p2 detection doubly lengthened RS code with a function of correcting p1 bytes error and detecting p2 bytes error.
The following concretely shows that the code expressed by the parity check matrix (H) shown in the Expression 1 corrects μ1 spotty-byte errors occurred in p1 bytes and detects μ2 spotty-byte errors occurred in p2 bytes. In general, the parity check matrix H=[H0, H1, . . . , Hn−1] should satisfy the following necessary and sufficient conditions. Where, Hi is an R×b submatrix.
Where, ei
Further, i1, i2, . . . , iv
The spotty-byte errors correcting and detecting are executed by using the syndrome (S) 33 generated by the syndrome generating circuit 1. The relationship between the syndrome (S) 33 and the parity check matrix (H) is expressed by S=V′·HT. When the received word (V′) 32 includes an error (E) for original transmitted word (V) 31 and the received word (V′) is expressed by V′=V+E, the syndrome (S) 33 becomes S=V′·HT=(V+E) HT=V·HT+E·HT.
Since the relationship V·HT=0 holds as mentioned above, in the end, the syndrome S satisfies a relationship S=E·HT. That is, since the syndrome (S) 33 is determined only by the error (E) without being influenced by the transmitted word (V) 31, a determination on whether the spotty-byte error can be corrected based on the syndrome (S) 33, can be made in accordance with the value of E-HT calculated from the parity check matrix (H) and the error (E).
The necessary and sufficient condition expressed by the Expression 9 shows that the syndrome of all correctable and detectable multiple spotty-byte errors within a byte is different from the syndrome of all other correctable multiple spotty-byte errors within a byte with respect to the correcting-number μ1 and the detecting-number μ2 of the spotty-byte errors.
That is, the syndrome of the multiple spotty-byte errors within a byte whose number is μ2 or less and which occurred in p2 or less bytes should be different from the syndrome of the other multiple spotty-byte errors within a byte whose number is μ1 or less and which occurred in p1 or less bytes.
A set of l1 (l1≦μ1) spotty-byte errors occurred in ρ1 (ρ1≦p1) bytes is designated as
Where, wM(ei
Further, a set of l2 (l2≦μ2) spotty-byte errors occurred in ρ2(ρ2≦p2) bytes is designated as
Where, wM(ej
In this case, [μ1t/bEC]p
Some of spotty-byte errors of Ωi and Ωj occurred in the same byte. In V (0≦V≦p1) bytes, If errors occurred in the same byte, the following Expression 12 can be obtained.
Therefore, the following Expression 13 can be obtained from the Expression 12.
Where, wM(ei
Therefore, the code expressed by the parity check matrix shown in the Expression 1 satisfies the necessary and sufficient condition shown in the Expression 9, so that μ1 spotty-byte errors occurred in p1 bytes are corrected and μ2 spotty-byte errors occurred in p2 bytes are detected. This is concretely explained below.
It is premised that the relationship expressed by the following Expression 14 holds as the syndrome S.
In
of the Expression 14, since H′ is a matrix where any Min((μ1+μ2)t, b) columns are linearly independent, the following Expression 15 can be obtained.
In the Expression 15, when the both sides are multiplied by H″T from the right, the following Expression 16 can be obtained.
In the Expression 14 and the Expression 16, when ei
·H″T are designated as x1, x2, . . . , xv
holds.
In the Expression 17, when v1+v2+ . . . +vλ (≦p1+p2) expressions from top are expressed by matrix, the following Expression 18 is obtained.
Since the matrix of v1+v2+ . . . +vλ rows and v1+v2+ . . . +vλ columns shown in the Expression 18 is a Vandermonde matrix, it is a nonsingular matrix. Therefore, both-hand sides of the Expression 18 are multiplied by an inverse matrix of this matrix from left, the following Expression 19 is obtained.
In the Expression 19, x1=0, x2=0, . . . , xv
which is a premise. Therefore, the code expressed by the Expression 1 satisfies the necessary and sufficient condition expressed by the Expression 9.
Therefore, from the result of the proof that mentioned above, it is proved that the parity check matrix (H) expressed by the Expression 1 has the function of correcting μ1 spotty-byte errors occurred in p1 bytes which is included in the received word (V′) 32 and detecting μ2 spotty-byte errors occurred in p2 bytes which is included in the received word (V′) 32.
Similarly, the lengthened code expressed by the parity check matrix (H) shown in the Expression 5 also satisfies the necessary and sufficient condition shown in the Expression 9, thereby correcting μ1 spotty-byte errors occurred in p1 bytes and detecting μ2 spotty-byte errors occurred in p2 bytes.
The parity check matrix (H) shown in the Expression 1 can be constructed by giving the specific code parameters. This parity check matrix (H) is merely an example, and thus it goes without saying that the present invention is not limited to this.
In a memory system using the memory chip having 8 bits as reading/writing data width, the parameters such that b=8, t=1, μ1=μ2=4 and p1=p2=2 are given and single-bit error within a byte is assumed as the spotty-byte error, so that the parity check matrix (H) of [41/8/EC]2 code with the function of correcting 4 or fewer multiple spotty-byte errors within a byte (in this example, bit error) occurred in one or two bytes, is constructed.
In this case, according to Min((μ1+μ2)t,b)=Min(8,8)=8, a matrix where any 8 columns are linearly independent should be constructed as the matrix H′. As this example, 8×8 (8 rows and 8 columns) identity matrix shown in the following Expression 20 should be constructed.
According to Min(└(μ1+μ2)/2┘t,b)=Min(4,8)=4, a check matrix of quadruple-bit error detection code where any 4 columns are linearly independent should be constructed as the matrix H″. As this example, 6×8 matrix expressed by the following Expression 21 is shown.
If γ is a root of 6-th degree primitive polynominal g(x)=x6+x+1 over GF(2), γ can be expressed as 6-dimensional column vector γ=(010000)T.
That is, the correspondence between exponential representation γi of γ and vector representation of γ is shown as follows.
γ0=(1000000)T, γ1=(010000)T, γ2=(001000)T, γ3=(000100)T, γ4=(000010)T, γ5=(000001)T, γ6=(110000)T, γ7=(011000)T, γ8=(001100)T, γ9=(000110)T, γ10=(000011)T, γ11=(110001)T, γ12=(101000)T, γ13=(010100)T, γ14=(001010)T, γ15=(000101)T, γ16=(110010)T, γ17=(011001)T, γ18=(111100)T, γ19=(011110)T, γ20=(001111)T, γ21=(110111)T, γ22=(101011)T, γ23=(100101)T, γ24=(100010)T, γ25=(010001)T, γ26=(111000)T, γ27=(011100)T, γ28=(001110)T, γ29=(000111)T, γ30=(110011)T, γ31=(101001)T, γ32=(100100)T, γ33=(010010)T, γ34=(001001)T, γ35=(110100)T, γ36=(011010)T, γ37=(001101)T, γ38=(110110)T, γ39=(011011)T, γ40=(111101)T, γ41=(101110)T, γ42=(010111)T, γ43=(111011)T, γ44=(101101)T, γ45=(100110)T, γ46=(010011)T, γ47=(111001)T, γ48=(101100)T, γ49=(010110)T, γ50=(001011)T, γ51=(110101)T, γ52=(101010)T, γ53=(010101)T, γ54=(111010)T, γ55=(011101)T, γ56=(111110)T, γ57=(011111)T, γ58=(111111)T, γ59=(101111)T, γ60=(100111)T, γ61=(100011)T, γ62=(100001)T,
As a result, the matrix H″ shown in the Expression 21 can be expressed as H″=[γ0γ1γ2γ3γ4γ5γ18γ20]. Therefore, as to the parity check matrix (H) shown in the Expression 1, a specific (504, 478) [41/8EC]2 code can be constructed by using H′ and H″. The check matrix of a (90, 64) [41/8EC]2 code obtained by deleting 414 columns from the right most of the (504, 478) [41/8EC]2 code is shown in
As shown in
A check is concretely made whether γ3H″ as the component of the parity check matrix (H) is corresponding to the actual bit value shown in
As to μ1=μ2=3, according to Min((μ1+μ2)t,b)=Min(6,8)=6, a check matrix of 6-bit error detection code where any 6 columns are linearly independent should be constructed as the matrix H′. As this example, 7×8 matrix expressed by the following Expression 22 is shown.
According to Min(└(μ1+μ2)/2┘t,b)=Min(3,8)=3, a check matrix of triple-bit error detection code where any 3 columns are linearly independent should be constructed as the matrix H″. As this example, 4×8 matrix expressed by the following Expression 23 is shown.
As to t=2, for example, in a [T2/EC]2 code having parameters such that μ1=μ2=3 and p1=p2=2, according to Min((μ1+μ2)t,b)=Min (12,8)=8, a matrix where any 8 columns are linearly independent should be constructed as the matrix H′. As this example, 8×8 (8 rows and 8 columns) identity matrix shown in the Expression 20 should be constructed.
According to Min(└(μ1+μ2)/2┘t,b)=Min(6,8)=6, a check matrix of 6-bit error detection code where any 6 columns are linearly independent should be constructed as the matrix H″. As this example, 7×8 matrix expressed by the following Expression 24 is shown.
The above explains one example of the parity check matrix H (code) for the semiconductor memory chip having input/output with byte width b of 8 bits which is used the most frequently. It is apparent that the parity check matrix H of the error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes according to the present invention can be constructed also for the other multi-bit input/output chip to be used frequently such as chip or the like having input/output with byte width b of 16 bits. Further, it is also apparent that the parity check matrix H of the error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes according to the present can be constructed also for any integer t with a value of 1 or more and for any p1, p2, μ1 and μ2.
The above shows the parity check matrix (H) of the error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes. However, it is possible that the error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes with a function of detecting single-byte error exceeding correction capability of multiple spotty-byte errors within a byte can be constructed by H′ is constructed by b by b identity matrix.
That is, an error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes with byte error detection function is a code with a function of correcting μ1 spotty-byte errors occurred in p1 bytes, and detecting μ2 spotty-byte errors occurred in p2 bytes and byte error occurred in one byte. This code expressed as [μ1t/bEC]p
In this embodiment, the parity check matrix (H) of R rows and N columns which is used for the [μ1t/bEC]p
where R=b+(p1+p2−1)r, N=bn, 0≦i≦n−1 and n=2r−1 hold. Ib is a b by b identity matrix.
The matrix H″ constituting the Expression 25 is a binary matrix having r rows and b columns (r≦b) composed of r-dimensional column vector hj″ (0≦j≦b−1) shown in the following Expression 26, and plural columns whose number is larger than or equal to either smaller one of └(μ1+μ2)/2┘t and b are linearly independent. └x┘ represents a maximum integer which does not exceed x.
H″=[h
0
″,h
1
″, . . . , h
b−1″] [Expression 26]
if └(μ1+μ2)/2┘≧b, the matrix H″ is a nonsingular matrix including an identity matrix, and if └(μ1+μ2)/2┘t<b, the matrix H″ is equal to a check matrix of a code having a minimum Hamming distance └(μ1+μ2)/2┘t+1, namely, a parity check matrix of a (b, b−r) code with a function of detecting └(μ1+μ2)/2┘t bits error.
When γ is a primitive element of an r-th degree extension field GF(2r) of GF(2), γiH″ can be defined by the following Expression 27.
γiH″=[γih0″,γih1″, . . . , γihb−1″] [Expression 27]
In this case, the maximum code length N is b(2r−1).
In the case of parameter t≧b/└(μ1+μ2)/2┘, since H″ becomes matrix where any b columns are linearly independent, the parity check matrix (H) shown in the Expression 25 corresponds with a parity check matrix of a conventional p1 correction p2 detection RS code with a function of correcting p1 bytes error and detecting p2 bytes error.
In this embodiment, a lengthened code of the [μ1t/bEC]p
where r′≧r, R=b+(p1+p2−1)r′, N=b(n+1)+r′, 0≦i≦n−1 and n=2r′−1 hold. Ib is a b by b identity matrix and Ir′ is a r′ by r′ identity matrix. Further, O is a zero matrix.
The matrix H″ constituting the Expression 28 is a binary matrix having r rows and b columns (r≦b) composed of r-dimensional column vector hj″ (0≦j≦b−1) shown in the following Expression 29, and plural columns whose number is larger than or equal to either smaller one of └(μ1+μ2)/2┘t and b are linearly independent. └x┘ represents a maximum integer which does not exceed x.
H″=[h
0
″,h
1
″, . . . , h
b−1″] [Expression 29]
if └(μ1+μ2)/2┘t≧b, the matrix H″ is a nonsingular matrix including an identity matrix, and if └(μ1+μ2)/2┘t<b, the matrix H″ is equal to a check matrix of a code having a minimum Hamming distance └(μ1+μ2)/2┘t+1, namely, a parity check matrix of a (b,b−r) code with a function of detecting └(μ1+μ2)/2┘t bits error.
When γ is a primitive element of an r′-th degree extension field GF(2r′) of GF(2), γiH″ can be defined by the following Expression 30.
γiH″=[γiΦ(h0″),γiΦ(h1″), . . . , γiΦ(hb−1″)] [Expression 30]
Where, Φ is an injective homomorphism from GF(2r) to GF(2r′) under addition, namely, Φ is achieved effectively by GF(2r)→GF(2r′). In this case, the maximum code length N is b·2r′+r′. Attention should be paid to that the number of rows r′ of H″ to be used for the second and lower rows of H shown in the Expression 28 can obtain a value larger than r, and the code expressed by the Expression 28 can be constructed for an arbitrary code length by increasing the number of check bits by (μ1+μ2−1) bits.
In the case of parameter t≧b/└(μ1+μ2)/2┘, since H″ becomes matrix where any b columns are linearly independent, the parity check matrix (H) shown in the Expression 28 corresponds with a parity check matrix of a conventional p1 correction p2 detection doubly lengthened RS code with a function of correcting p1 bytes error and detecting p2 bytes error.
The following concretely shows that the code expressed by the parity check matrix (H) shown in the Expression 25 corrects μ1 spotty-byte errors occurred in p1 bytes, and detects μ2 spotty-byte errors occurred in p2 bytes and byte error occurred in one byte. The parity check matrix H=[H0, H1, . . . , Hn−1] should satisfy the necessary and sufficient conditions shown in the Expressions 9 and the following Expression 31. Where, Hi is an R×b submatrix.
Where, ei
Further, ib, i1, i2, . . . , iv
Similarly to the necessary and sufficient condition shown in the Expression 9, it can show that the conditions shown in the Expression 9 and the Expression 31 are satisfied.
Likewise, it can also show that the lengthened code expressed by the parity check matrix (H) shown in the Expression 28 satisfies the necessary and sufficient conditions shown in the Expression 9 and the Expression 31.
The above explains some examples of the method for constituting the parity check matrix (H) of the error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes and the parity check matrix (H) of the error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes having the byte error detection function. Next, the concrete methods and circuit configurations of the encoding process and the decoding process to be executed by using the parity check matrix (H) of the present invention are explained by exemplifying the error control code ([μ1t/bEC]p
First, the concrete method of the encoding process to be executed by the encoding circuit 2 shown in
The encoding circuit 2 generates check information C (row vector) by using input information data D (row vector) 30 and an information section HR of the parity check matrix (H) obtained by applying the elementary row operation of the parity check matrix (H) shown in
C=D·H
R
T [Expression 32]
Concretely, the encoding circuit 2 constitutes a (504, 478)[41/8EC]2 code as the parity check matrix H on the basis of 64 bits of the information bit length and 26 bits of the check bit length in the input information data (D) 30, and thereafter constitutes the (90,64) [41/8EC]2 code shown in
In the parity check matrix of the (90,64)[41/8EC]2 systematic code shown in
The parity check matrix shown in
Next, the encoding circuit 2 generates 26-bit check information (C) based on the Expression 32. As is clear from C=D·HRT shown in the Expression 32, for example, in order to generate the check bit c0 of the check information (C), in the first row of the matrix of the (90, 64) [41/8EC]2 systematic code for the encoding shown in
For example, in the case of obtaining the check bit c0, bits corresponding to locations where “1” exists excluding bit corresponding to c0 are d1, d4, d5, d6, d8, d11, d12, d20, d21, d24, d26, d31, d33, d37, d38, d39, d40, d41, d42, d43, d44, d47, d48, d52, d54, d55, d56, d57, d58 and the sum modulo 2 (mod 2) should be operated for these 29 bits.
In order to realize this, as shown in
The codeword generated by adding the check information (C) generated by the encoding circuit 2 to the input information data (D) 30 is shown in the Expression 33. This codeword becomes the transmitted word (V) (vector of 90 bits) which is transmitted to the circuit 3.
V=[d0,d1, . . . , d57,d58,c0,d59,c1, . . . , c3,d60,c4,d61,c5, . . . , c9,d62,c10,d63,c11, . . . , c25] [Expression 33]
As explained below, when errors occurred in the transmitted word (V) 31 (namely, when the received word 32 includes the errors), the correcting and detecting process for the errors can be executed based on the value of a syndrome (S) 33 generated by using the (90,64) [41/8EC]2 code shown in
Since p1=p2=2 in the check matrix of the (90,64) [41/8EC]2 code shown in
The errors are corrected and detected by using these pieces of information as follows. The syndrome (S) 33 can be obtained from the received word (V′) 32 and the parity check matrix (H) according to the following Expression 34.
V′·H
T
=S=[S
I
S
II
S
III
S
IV] [Expression 34]
Where SIεGF(2q) is a q-dimensional row vector. SII, SIII, SIVεGF(2r) is a r-dimensional row vector respectively.
In the case of the lengthened code shown in the Expression 5, SIεGF(2q) is a q-dimensional row vector. SII, SIII, SIVεGF(2r′) is a r′-dimensional row vector respectively.
For example, when error eI occurred in the iI-th byte and error eII (wM(eI)+wM(eII)≦μ1+μ2) occurred in the iII-th byte, the syndrome (S) 33 is expressed by the following Expression 35.
S=[e
I
·H′
T
+e
II
·H′
T,γieI·H″T+γjeII·H″T,γ2ieI·H″T+γ2jeII·H″T,γ3ieI·H″T+γ3jeII·H″T] [Expression 35]
When attention is paid to SI, the following Expression 36 holds. In the Expression 36, since H′ is a matrix where arbitrary Min((μ1+μ2)t, b) columns are linearly independent, eI+eII(=eA) can be obtained. In the case of the (90,64) [41/8EC]2 code shown in
(eI+eII)·H′T=SI [Expression 36]
Next, eI+eII is multiplied by H″T on the right side, and the multiplied result is S′IεGF(2r). That is, a relationship shown in the following Expression 37 holds.
S′
I=(eI+eII)·H″T [Expression 37]
When eI·H″T and eII·H″T (εGF(2r)) are errors e′I and e″II over GF(2r), and S′=[S′ISIISIIISIV], a relationship shown in the following Expression 38 holds.
S′=[S′
I
S
II
S
III
S
IV
]=[e′
I
+e′
II,γie′I+γie′II,γ2ie′I+γ2je′II,γ3ie′I+γ3je′II] [Expression 38]
S′ shown in the Expression 38 corresponds to the expression of the syndrome of errors e′I and e′II in a double-byte error correction RS code (distance d=5). Therefore, it is possible to obtain error positions iI, iII and the errors e′I, e′II over GF(2r) by using decoding method of the RS code over GF(2r) having distance d of 5. When an error position is not obtained, an error is detected as uncorrectable error.
Errors eI and eII over GF(2b) are obtained from the errors e′I and e′II over GF(2r). That is, eI and eII are obtained according to the relationships: eI·H″T=e′I and eII·H″T=e′II. The obtained results are êI and êII.
Since H″ is a matrix where any Min(2t,b) columns are linearly independent, when a t-bit or more error occurred within a byte, the error is miscorrected (that is, ex≠êx) or is detected as an out-of-control-ability error. However, since the number of bytes where a t-bit or more error occurred, is one at most, so the number of bytes where ex≠êx is also one at most.
It is possible to determine whether miscorrection is carried out or not according to the following Expression 39. That is, it is possible to determine whether ex=êx holds or not according to the following Expression 39. In other words, when the following Expression 39 holds, ex=êx, and thus the determination is made that miscorrection is not carried out. In contrast, when the following Expression 39 does not hold, ex≠êx, and thus the determination is made that miscorrection is carried out.
w
M(êx+eA)≦μ1−wM(êx) [Expression 39]
The relationship shown in the Expression 39 holds when wM(e) satisfies the triangle inequality. Further, a determination of miscorrection with respect to the Hamming distance over GF(2) is disclosed in detail in Non-Patent Document 11.
Finally, in byte that is miscorrected (namely, ex≠êx) or byte that is detected as an out-of-control-ability error, it is possible to restore the error pattern of byte that is miscorrected by obtaining exclusive logical sum of error pattern that is corrected definitely and eA.
In addition, for any p1, p2, μ1 and μ2, it is clear that it is possible to determine whether miscorrection is carried out or not according to the above Expression 39 same as the example mentioned above, and restore error pattern of erroneous byte that is one at most basing on error pattern that is corrected definitely and eA.
The decoding of the RS code can be realized by using a parallel decoding method for codes in which the number of erroneous bytes, P1, including correctable spotty byte errors, is small. A general construction of this parallel decoding method is disclosed in “BURST ERROR PATTERN GENERATION METHOD, AND BURST AND BYTE ERROR DETECTION CORRECTION APPARATUS” (see Patent Document 5).
The parallel decoding method disclosed in Patent Document 5, however, enables high-speed decoding, but when the number of erroneous bytes, p1, including correctable spotty byte errors of code, becomes large, a problem that the amount of circuits becomes large occurs. Although a sequential decoding method such as a Berlekamp-Massey method can be used for the codes in which the number of erroneous bytes, p1, including correctable spotty byte errors, is large, since the decoding by means of the sequential decoding method, is carried out sequentially (i.e. serially), so a problem that the decoding is slow occurs. The construction of the decoding circuit for the RS code using the Berlekamp-Massey method is disclosed in Non-Patent Document 12.
According to the parallel decoding method disclosed in Patent Document 5, for example, the codes where p1=p2=2 is decoded according to the following procedure.
First, a matrix {tilde over (H)}(i,j)=[{tilde over (H)}i {tilde over (H)}j] of 4r×2r is constructed for the parity check matrix {tilde over (H)}=[{tilde over (H)}0 {tilde over (H)}1 . . . {tilde over (H)}n−1] of the RS code over GF(2r) having 4r×nr. Where {tilde over (H)}i is a 4r×r submatrix.
Next, A matrix B(i,j) of 4r×2r is added to the matrix {tilde over (H)}(i,j), so that a nonsingular matrix A(i,j)=[{tilde over (H)}(i,j) B(i,j)] of 4r×4r is constructed.
When an inverse matrix A(i,j)−1 of A(i,j) is obtained, the relationship of the following Expression 40 holds.
Where, {tilde over (H)}i† is a matrix of r×4r, and {tilde over (H)}i†·{tilde over (H)}i=Ir. Ir is an identity matrix of r×r. {tilde over (H)}j† is a matrix of r×4r, and {tilde over (H)}j†·{tilde over (H)}j=Ir. Further, B(i,j)† is a matrix of 2r×4r, and B(i,j)†·B(i,j)=I2r. I2r is an identity matrix of 2r×2r. {tilde over (H)}(i,j)† is a matrix of 2r×4r, and {tilde over (H)}(i,j)†·{tilde over (H)}(i,j)=I2r.
Byte positions i and j where S′·B(i,j)T=0 for {tilde over (H)}i†, {tilde over (H)}j†, B(i,j)† become error positions iI and iII, and S′·B(i,j)†
In the present invention, the schematic configuration of the decoding circuit 4 for realizing the parallel decoding method for the code where p1=p2=2 is shown in
As shown in
As shown in
The H′ decoding circuit 6 generates a byte-by-byte sum of errors (eA) 38 based on the upper q bits SI36 on the syndrome (S) 33.
The H″ multiplication circuit 7 generates a product (S′I) 39 of the upper q bits SI36 on the syndrome (S) 33 and transposed matrix (H″T) of matrix H″ based on the byte-by-byte sum of errors (eA) 38.
The parallel decoding circuit 8 over GF(2r) generates bit-error pointer (e′) 40 over GF(2r) and a DS(0) (Detection Signal) 41 to be output when an error cannot be corrected in the parallel decoding over GF(2r) based on the product (S′I) 39 of the upper q bits SI36 on the syndrome (S) 33 and the transposed matrix (H″T) of matrix H″, and lower 3r bits SIISIIISIV 37 on the syndrome (S) 33.
The error vector generating circuit 9 over GF(2b) converts the error over GF(2r) into an error over GF(2b) based on the byte-by-byte sum of errors (eA) 38 and the bit-error pointer (e′) 40 over GF(2r), and outputs a bit-error pointer (e) 42 over GF(2b) and a DS(1) (Detection Signal) 43 to be output when the error correction is regarded as uncorrectable.
At the end, the inverting circuit 10 inverts a bit value of the received word (V′) 32 corresponding to the error bit based on the bit-error pointer (e) 42 over GF(2b), thereby correcting the error in the received word (V′) 32.
The schematic operating procedure to be performed by the decoding circuit 4 shown in
First, when the received word (V′) 32 composed of N bits is input into the syndrome generating circuit 1, the syndrome generating circuit 1 generates the syndrome (S) 33 of R bits.
Next, the generated syndrome (S) 33 of R bits is divided into an upper q bits SI36 and a lower 3r bits SIISIIISIV37. The upper q bits SI36 on the syndrome (S) 33 are input into the H′ decoding circuit 6. The lower 3r bits SIISIIISIV37 on the syndrome (S) 33 are input into the parallel decoding circuit 8 over GF(2r).
The H′ decoding circuit 6, as detailed later, outputs the byte-by-byte sum of errors (eA) 38 of b bits based on the upper q bits SI36 on the syndrome (S) 33 generated by the syndrome generating circuit 1.
The H″ multiplication circuit 7, as detailed later, outputs the product (S′I) 39 of the upper q bits SI36 on the syndrome (S) 33 and the transposed matrix (H″T) of matrix H″ based on the byte-by-byte sum of errors (eA) 38 generated by the H′ decoding circuit 6.
The parallel decoding circuit 8 over GF(2r), as detailed later, generates a bit-error pointer e′=(e0′ e1 . . . er┌N/b┐−1′) 40 over GF(2r) of r┌N/b┐ bits indicating an error over GF(2r) based on the product (S′I) 39 of the upper q bits SI36 on the syndrome (S) 33 and the transposed matrix (H″T) of matrix H″ that is generated by the H″ multiplication circuit 7, and the lower 3r bits SIISIIISIV37 on the syndrome (S) 33 that is generated by the syndrome generating circuit 1. Where, FYI represents a minimum integer which exceeds y. When the error correction is regarded as impossible in the parallel decoding over GF(2r), the parallel decoding circuit 8 over GF(2r) outputs an uncorrectable error detection signal (DS(0)) 41.
The error vector generating circuit 9 over GF(2b), as detailed later, generates a bit-error pointer e=(e0, e1, . . . , eN−1) 42 over GF(2b) of N bits indicating the error over GF(2b) based on the byte-by-byte sum of errors (eA) 38 generated by the H′ decoding circuit 6 and the bit-error-pointer (e′) 40 over GF(2r) generated by the parallel decoding circuit 8 over GF(2r). The error vector generating circuit 9 over GF(2b) outputs an uncorrectable error detection signal (DS(1)) 43 when the error is regarded as uncorrectable.
Next, the inverting circuit 10 inverts bits of the received word (V′) 32 corresponding to the bit-error pointer (e) 42 over GF(2b) based on the bit-error pointer (e) 42 over GF(2b) of N bits generated by the error vector generating circuit 9 over GF(2b) and the received word (V′) 32.
Finally, the inverting circuit 10 takes out the information word D* of K bits from the received word V* of N bits whose error is corrected, and outputs it as the output information data 34.
Logical sum of the uncorrectable error detection signal (DS(0)) 41 generated by the parallel decoding circuit 8 over GF(2r) and the uncorrectable error detection signal (DS(1)) 43 generated by the error vector generating circuit 9 over GF(2b) is obtained, so that a value of an uncorrectable error detection signal UCE (Uncorrectable Error) 35 is output. For example, when the value of the uncorrectable error detection signal UCE 35 is “1”, “1” means that an error, which exceeds the correction capability, is detected.
As to also the lengthened code expressed by the parity check matrix (H) shown in the Expression 5 (lengthened [μ1t/bEC]p
The concrete constitutional examples of the syndrome generating circuit 1, the H′ decoding circuit 6, the H″ multiplication circuit 7, the parallel decoding circuit 8 over GF(2r), the error vector generating circuit over GF(2b), and the inverting circuit 10 are explained below by using the (90,64) [41/8EC]2 code shown in
<a> The Constitution of the Syndrome Generating Circuit 1
The constitution of the syndrome generating circuit 1 is explained in detail here.
When the received word (V′) 32 composed of N=90 (=64+26) bits is expressed as shown in the following Expression 41, the syndrome generating circuit inputs the received word (V′) 32 and generates the syndrome (S) 33 of R=26 bits composed of S0, S1, . . . , and S25 shown in the following Expression 42.
Since the parity check matrix of the [41/8EC]2 code shown in
V′=(v0′,v1′, . . . , v89′) [Expression 41]
S=(SI|SII|SIII|SIV)=(S0S1S2S3S4S5S6S7|S8S9S10S11S12S13|S14S15S16S17S18S19|S20S21S22S23S24S25) [Expression 42]
As shown in the Expression 34, according to the syndrome S=V′·HT, each row of the transposed parity check matrix (HT) corresponds to information to be input, and for example, the 0th row of the matrix (HT) corresponds to v0′ of input information.
In order to generate each bit of the syndrome (S) 33, therefore, the received information of the received word (V′) 32 corresponding to the bit having “1” may be added to each column direction of the parity check matrix (HT) as the code over GF(2) (calculation of mod 2).
As shown in
Next, in each multi-input parity check circuits 21(p), (p=0, 1, . . . , 25), the sum (mod 2) of modulo 2 is calculated for the input received information (vq′), and its result is Sp.
Concretely, for example, in order to generate the bit S0 of the syndrome (S) 33, the sum (mod 2) of modulo 2 may be obtained for 12 bits v0′, v8′, v16′, v24′, v32′, v40′, v4′, v56′, v64′, v72′, v80′, v88′ corresponding to the locations where “1” exists on the 0th row of the parity check matrix shown in
<b> The constitution of the H′ Decoding Circuit 6
The H′ decoding circuit 6 is explained below.
The H′ decoding circuit 6 is shown in
In the case of the (90,64) [41/8EC]2 code shown in
On the other hand, when H′ is not the identity matrix, a method, mentioned later in <e> is used.
<c> The Constitution of the H″ Multiplication Circuit 7
The H″ multiplication circuit 7 is explained below.
The H″ multiplication circuit 7 is shown in
Concretely, for example, in order to generate the bit S′0 of the product (S′I) 39 of the upper q bits SI36 on the syndrome (S) 33 and the transposed matrix (H″T) of matrix H″, the sum modulo 2 (mod 2) may be obtained for the values of 2 bits eA
In
The exclusive logical sum circuit 22 and a 3-inputs parity check circuit 23 can be used similarly for the other bits S′p of the product (S′I) 39 of the upper q bits SI36 on the syndrome (S) 33 and the transposed matrix (H″T) of matrix H″.
Here, S′ has the constitution shown in the following Expression 44.
<d> The Constitution of the Parallel Decoding Circuit 8 Over GF(26)
The parallel decoding circuit 8 over GF(26) is explained below.
In order to obtain the bit-error pointer 40 over GF(26), the parallel decoding method is used. The entire constitution of the parallel decoding circuit 8 over GF(26) is shown in
As shown in
of set of any 2 bytes in 12 bytes and generate respective errors in i-th and j-th 2 bytes (herein after, (i,j)), and of an error calculating circuit 51 over GF(26) which outputs the bit-error pointer (e′) 40 over GF(26).
The error vector generating circuit 50(m) for (i,j) calculates S′·{tilde over (H)}i†
The error calculating circuit 51 over GF(26) is a circuit that outputs the bit-error pointer (e′) 40 over GF(26). In other words, the error calculating circuit 51 over GF(26) inputs the errors E′m,i and E′m,j that are the output of the error vector generating circuit 50(m) for (i,j) and outputs the bit-error pointer (e′) 40 over GF(26).
Here, the process of the parallel decoding circuit 8 over GF(26) is explained more concretely. As shown in
Next, the error vector generating circuit 50(m) for (i,j) generates errors E′m,i and E′m,j, and inputs the generated errors E′m,i and E′m,j into the error calculating circuit 51 over GF(26). The error calculating circuit 51 over GF(26) outputs the bit-error pointer (e′) 40 over GF(26).
In addition, S′ of 24 bits (the product (S′I) 39 of the upper q bits SI36 on the syndrome (S) 33 and the transposed matrix (H″T) of matrix H″, and the lower 3r bits SIISIIISIV37 on the syndrome (S) 33) is input into a 24-bits-input OR gate circuit 54.
On the other hand, the correctable signals 53(m) generated by the error vector generating circuits 50(m) for (i,j) are input into a 66-inputs NOR gate circuit 55.
The two signals output from the 24-bits-input OR gate circuit 54 and the 66-inputs NOR gate circuit 55 respectively, are input into a 2-inputs AND gate circuit 56. The 2-inputs AND gate circuit 56 outputs an uncorrectable error detection signal (DS(0)) 41. These circuits detect errors when the syndrome is not 0 and all the correctable signals are 0.
Next, the constitutional example of the error vector generating circuit 50(m) for (i,j) is explained below concretely. As an example, the error vector generating circuit 50(0) for (0,1) is shown in
Where, {tilde over (H)} represents a check matrix of the RS code over GF(26) shown in the following Expression 45, and has a code length of 72 bits and a check bit length of 24 bits. γ is an element of GF(26), and as shown in the following Expression 46, it is expressed by a binary 6×6 companion matrix defined by a generator polynominal: g(x)=x6+x+1.
For example, in the error vector generating circuit 50 (0) for (0,1), H0, and H1 correspond to the 0-th and the first columns of the Expression 45, and they are 24×6 matrices shown in the following Expression 47.
Next, a 24×12 matrix {tilde over (H)}(0,1)=[{tilde over (H)}0 {tilde over (H)}1] is constructed from {tilde over (H)}0, {tilde over (H)}1, and a 24×12 matrix B(0,1) is added to {tilde over (H)}(0,1), so that a 24×24 nonsingular matrix A(0,1)=[{tilde over (H)}(0,1) B(0,1)] shown in the following Expression 48 is constructed. Where, B(0,1) is a 24×12 matrix obtained so that A(0,1) becomes a nonsingular matrix, and is one example.
Next, when the inverse matrix A(0,1)−1 of A(0,1) is obtained, a relationship of the following Expression 49 holds. {tilde over (H)}0†, {tilde over (H)}1†, B(0,1)† become matrices shown in the following Expressions 50, 51 and 52, respectively.
In the S′·{tilde over (H)}0†
In other words, first, the S′·{tilde over (H)}0†
Concretely, for example, in order to generate the 0-th bit of E′0,0, the sum modulo 2 (mod 2) may be obtained for the values of 5 bits s′0, s′5, s′9, s′21 and S′23 corresponding to the locations where “1” exist on the 0-th row of {tilde over (H)}0† shown in the Expression 50 among the 24 bits syndromes S′=S′0, S′1, . . . and S′23. The multi-input parity check circuit 63(0) of
As shown in
Here, the process of the error vector generating circuit 50(0) for (0,1) is explained in more detail. As shown in
The 24 bits syndrome S′ is input into the multi-input parity check circuit 65(z), (z=0, 1, . . . , 11). The 12 bits signal output from the multi-input parity check circuits 65(z), (z=0, 1, . . . , 11) is input into the 12-input NOR gate circuits 65, and a correctable signal 53(0) for (0,1) is output. Since the pair (i,j) of bytes where S′·{tilde over (B)}(0,1)†
The correctable signal 53(0) for (0,1) and the output signals from the multi-input parity check circuits 63 and the multi-input parity check circuits 64 are input into 2-input AND gate circuits 67, and E′0,0 and E′0,1 are output. If the pair of bytes is a pair of erroneous bytes, these circuits output errors, otherwise these circuits output a pattern of 0.
Finally, the error vector generating circuit 50(0) for (0,1) outputs the errors E′0,0 and E′0,1 52(0) and the correctable signal 53(0) for (0,1). The error vector generating circuit 50(0) for (0,1) is explained as an example, but the same is applied also to the other bytes (i,j).
The constitutional example of the error calculating circuit 51 over GF(26) is explained below concretely. The error calculating circuit 51 over GF(26) is shown in
As shown in
Concretely, for example, in order to output e′6 of the bit-error pointer (e′) 40 over GF(26), the 0-th bit of E′0,1, E′11,1, . . . , and E′20,1 output from the error vector generating circuit 50(0) for (0,1), the error vector generating circuit 50(11) for (1,2), . . . and the error vector generating circuit 50(20) for (1,11) are input into bit-by-bit OR arithmetic circuit 68, respectively. The bit-by-bit OR arithmetic circuit 68 integrates the 0-th bits of E′ 0,1, E′11,1, . . . and E′20,1 and outputs e6′ by inputting 0-th bits of E′0,1, E′11,1, . . . and E′20,1 having 6 bits into 11-inputs OR circuits 69, respectively.
The e′6 of the bit-error pointer (e′) 40 over GF(26) is explained as an example above, but the same is applied also to the other bit values e′0, and e′65.
<e> The Constitution of the Error Vector Generating Circuit 9 over GF(28)
The error vector generating circuit 9 over GF(28) is explained below. The entire constitution of the error vector generating circuit 9 over GF(28) is shown in
As shown in
The t-bit error correction decoding circuit 70 (in this example, 2-bit error correction decoding circuit) inputs 1 byte of the bit-error pointer (e′) 40 over GF(26), and outputs 1 byte of the bit-error pointer (ê) 71 produced by the decoder and a detection signal 72 in i-th byte as a signal for detecting an error exceeding the correction capability.
The 12-input sorting circuit 73 is a circuit that inputs detection signals 72 in i-th byte output from the t-bit error correction decoding circuits 70, counts the weights (the number of “1”) of the 12 bits information to be input, and expresses 1 from upper bits of the outputs continuously only as for the number of the weights. For example, when there are six “1”s in 12 bits input information, all of the upper 6-bit outputs among the 12-bit outputs of the 12-input sorting circuit 73 output “1”, and all of the residual 6-bit outputs of the 12-input sorting circuit 73 output “0”.
Finally, the miscorrection determining circuit 74 in i-th byte inputs a bit-error pointer (ê) 71 produced by the decoder output from the t-bit error correction decoding circuits 70 of all bytes, the detection signal 72 in i-th byte and the byte-by-byte sum of errors (eA) 38, and outputs 1 byte of the bit-error pointer (e) 42 over GF(28).
The process of the error vector generating circuit 9 on (28) is explained below in more detail. As shown in
The detection signal 72 in i-th byte output from the 2-bit error correction decoding circuit 70 is input into the 12-input sorting circuit 73. In the signal output from the 12-input sorting circuit 73, when the error is detected in the 2-bit error correction decoding circuits 70 of 2 or more bytes, the error is detected as an out-of-control-ability error (on the other hand, when the error is detected in the 2-bit error correction decoding circuit 70 of 1 byte, as detailed later, the error correction is carried out in the miscorrection determining circuits 73 in i-th byte.). In the signal output from the 12-input sorting circuit 73, therefore, the upper second bit signal is output as the uncorrectable error detection signal (DS(1)) 43.
The bit-error pointer (ê) 71 produced by the decoder output from the 2-bit error correction decoding circuits 70 of all bytes, the detection signals 72 in i-th byte, and the byte-by-byte sum of errors (eA) 38 are input into the miscorrection determining circuits 74 in i-th byte, respectively.
The all miscorrection determining circuits 74 in i-th byte collect signals output from the detection signals 72 in i-th byte, and output bit-error pointers 42 over GF(2b) of 90 bits.
The constitutional example of the 2-bit error correction decoding circuits 70 is explained concretely below.
As an example, in the 2-bit error correction decoding circuit 70 for the first byte, a circuit which outputs upper 4 bits of the bit-error pointer (ê) 71 produced by the decoder for the first byte is shown in
The 2-bit error correction decoding circuit 70 for the first byte is a circuit that inputs the first byte of the bit-error pointer (ê) 40 over GF(26), and outputs the first byte of the bit-error pointer (ê) 71 produced by the decoder and the detection signal 72 in 1 byte.
In the above-mentioned 2-bit error correction decoding circuits 70, êI→eI′ is an injection with respect to the error êI as results of decoding by means of H″ and the error eI′ over GF(26). Therefore, the logic synthesis is carried out so that the circuit 70 can be realized by the combinatorial circuit.
Since H″ is the matrix where any 4 columns are linearly independent, namely, it is a check matrix of the double-bit error correction code, in the [41/8EC]2 code, when triple-bit error or quadruple-bit error occurred within 1 byte, the result decoded by H″ is miscorrected or is detected as an out-of-control-ability error. When triple-bit error or quadruple-bit error is miscorrected within 1 byte, as detailed below, a determination of error correction is made so that a determination is made whether an error is miscorrected or not.
Concretely, for example, in
Therefore, the error êI=(ê8ê9ê10ê11ê12ê13ê14ê15) whose weight is 2 or less as a result of decoding by H″ and the error eI′=(e6′ e7′ e8′ e9′ e10′ e11′) over GF(26) establish a relationship shown in the following Table 1.
Here, there are 37 patterns of the errors eI′ over GF(26), but êI for the residual 26-37=27 patterns are detected as out-of-correction-ability error (out-of-control-ability error), and the output of êI is don't-care *.
For example, according to the corresponding relationship between the error êI as the result of the decoding by the H″ and the error eI′ over GF(26) which is shown in the Table 1, when eI′=(e6′e7′e8′e9′e10′e11′)=(100000), (110000), (101000), (100100), (011100), (100010), (101111), (100001), the value ê8 of the first bit of the first byte of information becomes 1.
In addition, in the corresponding relationship between êI as the result of the decoding by H″ and the error eI′ over GF(26) which is shown in the Table 1, the value ê8 of the first bit of the first byte of information is don't-care * with respect to the residual 27 patterns of errors over GF(26) eI′=(e6′ e7′ e8′ e9′ e10′ e11′)=(100110), (110110), (010110), (011110), (101110), (110010), (011010), (111010), (101010), (100011), (010011), (011011), (111011), (101011), (100111), (110111), (010111), (111111), (100101), (110101), (010101), (011101), (101101), (110001), (011001), (111001), (101001).
When these logic functions are simplified, the value ê8 of the first bit of the first byte of information is expressed by a logical expression shown in the following Expression 53.
ê8=e6′ē7′ē8′e6′ē8′ē9′ē10′ē6′e7′e8′ē9′ē11′e6′ē7′e8′ē9′e6′ē7′e8′e11′ [Expression 53]
Where, ē′x is logical inverse of ex′, e6′ē7′ē8′ is e6′ē7′ē8′, represents a logical sum and represents a logical product.
Therefore, as shown in
As shown in
The detection signal output unit of the t-bit error correction decoding circuit 70 (in this example, the 2-bit error correction decoding circuit) can be similarly constructed. The detection signal output unit detects the error êI which is the result of decoding by H″ and is not mapped from the error eI′ over GF(26) as the uncorrectable error. For example, the detection signal output unit of the 2-bit error correction decoding circuit 70 for the first byte is shown in
Concretely, for example, in the first byte of information, in the corresponding relationship between the error êI as the result of the decoding by H″ shown in Table 1 and the error eI′ over GF(26), the value of the detection signal for the residual 27 patterns of the errors over GF(26) eI′=(e6′ e7′ e8′ e9′ e10′ e11′)=(100110), (110110), (010110), (011110), (101110), (110010), (011010), (111010), (101010), (100011), (010011), (011011), (111011), (101011), (100111), (110111), (010111), (111111), (100101), (110101), (010101), (011101), (101101), (110001), (011001), (111001), (101001), is set to 1, so that errors are detected.
Therefore, when these logic functions are simplified, the value of the detection signal is expressed by a logical expression shown in the following Expression 54.
e6′e8′e9′e11′e7′e8′e9′e10′e7′e8′e9′e11′e7′e8′e9′e10′e6′e8′e9′e10′e6′e7′e9′e10′e11′e6′e7′e8′e10′e11′e6′e7′e8′e10′e11′e6′e7′e9′e10′e11′e6′e7′e8′e10′e11′e6′e7′e8′e10′e11′e6′e7′e8′e10′e11′e6′e7′e8′e10′e11′e6′e7′e8′e10′e11 [Expression 54]
Therefore, as shown in
Then, e6′ē8′e9′e11′, e7′ē8′e9′e10′, e7′ē8′e9′e11′, e7′e8′ē9′e10′, e6′e8′ē9′e10′, e6′ē7′e9′e10′ē11′, e6′ē7′ē8′e10′e11′, e6′e7′ē8′e10′ē11′, e6′e7′ē9′ē10′e11′, ē6′e7′ē8′e10′e11′, ē6′e7′e8′e10′ē11′, ē6′e7′e8′ē10′e11′,e6′e7′e8′e10′e11′, e6′ē7′e8′ē10′e11′ are input into the totally 14 4-input AND gates 82 and 5-input AND gates 83, respectively.
Finally, the signals output from the respective AND gate circuits are input into a 14-input OR circuit 86, and the detection signal 72 in 1 byte is output.
The t-bit error correction decoding circuit 70 in the first byte is explained in detail above as an example, but the same is applied also to the other bytes.
A constitutional example of the 12-input sorting circuit 73 is shown in
As shown in
As shown in
A constitutional example of the miscorrection determining circuit 74 in i-th byte is shown in
For example, a constitutional example of the miscorrection determining circuit 74 in 1 byte concretely constructed for the first byte, is shown in
The process of the miscorrection determining circuit 74 in 1 byte is explained in more detail. As shown in
Next, the byte-by-byte sum of errors (eA) 38 and the output from the bit-by-bit exclusive logical sum circuit 90 are input into the 16-input sorting circuit 91. A relationship shown in the following Expression 55 holds according to the relationship shown in the Expression 39.
w
M(êx+eA)+wM(êx)≦μ1 [Expression 55]
Therefore, when the number of “1” is four or less in the output of the 16-input sorting circuit 91, the circuit 91 outputs 1. That is, in the output of the 16-input sorting circuit 91, upper 4 bits are input into the 4-input OR gate circuit 92, and lower 12 bits are input into the 12-input NOR gate circuit 93 respectively. The detection signal in 1 byte is input into a NOT gate circuit 94. Then, the output from the 4-input OR gate circuit 92, the output from the 12-input NOR gate circuit 93 and the output from the NOT gate circuit 94 are input into a 3-inputs AND gate circuit 95.
Finally, using the output from the 3-input AND gate circuit 95 as a control signal, the output from the bit-by-bit exclusive logical sum circuit 90 and the bit-error pointer of the first byte (ê) 71 ê8 . . . ê15 produced by the decoder are input into the bit-by-bit selection circuit 96, and the first byte (e8 . . . e15′) of the bit-error pointer (e) 42 over GF(28) is output from the bit-by-bit selection circuit 96. As a result, when errors are corrected definitely, ex=êx is output, and when errors are miscorrected or when errors are detected as out-of-control-ability errors, exclusive logical sum of the error pattern corrected definitely in the other bytes and eA is obtained, so that error patterns in bytes where errors are miscorrected can be restored.
A constitutional example of the bit-by-bit exclusive logical sum circuit 90 is shown in
The process of the bit-by-bit exclusive logical sum circuit 90 is explained in more detail below. As shown in
A constitutional example of the 16-input sorting circuit 91 is shown in
As shown in
Finally, a concrete constitutional example of the bit-by-bit selection circuit 96 is explained.
As shown in
The process of the bit-by-bit selection circuit 96 is explained in more detail. As shown in
The above explains the [41/8EC]2 code having code parameters such as b=8, t=1, μ1=μ2=4, p1=p2=2 as an example, but it is clear that the above-mentioned circuit can be similarly constructed also for the codes having code parameters other than the above code parameters.
Finally, the constitution of the inverting circuit 10 is explained below.
For example, the inverting circuit 10 concretely constructed for the first byte, is shown in
The inverting circuit 10 comprises a plurality of exclusive logical sum circuits. In the inverting circuit 10 in the first byte shown in
In order to correspond to each bytes respectively, for the received word (V′) of N=90 bits, 90 exclusive logical sum circuits are necessary for the inverting circuit 10. Finally, the inverting circuit 10 obtains the corrected word D* of 64 bits shown in the following Expression 56 from the received word (V′) of N=90 bits.
D*=(v0*v1* . . . v57*v58*v60*v64*v66*v72*v74*) [Expression 56]
The above explains the concrete constitutions of the encoding circuit and the decoding circuit for the error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes by exemplifying the [41/8EC]2 code having code parameters such as b=8, t=1, μ1=μ2=4, p1=p2=2 shown in
It is possible to construct the encoding circuit and the decoding circuit for the error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes which has code parameters other than the above ones according to the following concept.
First, the encoding circuit should generate R bits check information by means of a binary parity check matrix, and can be constructed same as the above.
Further, with respect to decoding, as mentioned above, in the error e′ over GF(2r) obtained by decoding the p1 correction p2 detection RS code, H″ is decoded for each byte and the miscorrection determination is carried out, thereby it is possible to obtain the error over GF(2b) and similarly construct the decoding circuit.
It is possible to construct the encoding circuit and the decoding circuit for the lengthened error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes which is expressed by the parity check matrix shown in the Expression 5 according to the following concept.
First, the encoding circuit should generate R bits check information by means of a binary parity check matrix, and can be constructed same as the above.
Further, with respect to decoding, decoding is possible same as the above by decoding the p1 correction p2 detection RS code over GF(2r′) by means of the parallel decoding method or the sequential decoding method using the Berlekamp-Massey method, and furthermore, converting the error over GF(2r′) into the error over GF(2b) similarly to the above example.
Therefore, it is clear that the decoding circuit can be constructed similarly by changing the parallel decoding circuit 8 over GF(2r) of the above example into a circuit which carries out parallel decoding over GF(2r′), and furthermore, changing r bits of the error vector generating circuit 9 over GF(2b) of the above example into r′ bits.
It is possible to construct the encoding circuit and the decoding circuit for the error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes with byte error detection function which is expressed by the parity check matrix shown in the Expressions 25 and 28 according to the following concept.
First, the encoding circuit should generate R bits check information by means of a binary parity check matrix, and can be constructed same as the above.
Further, with respect to decoding, as mentioned above, after the syndrome is calculated, since H″ is such that plural columns whose number is larger than or equal to either smaller one of └(μ1+μ2)/2┘t and b are linearly independent, when SI≠0 and SII=SIII=SIV=0, a detection is carried out as the case where a byte error is occurred. In addition, in the error e′ over GF(2r) obtained by decoding the p1 correction p2 detection RS code as mentioned above, when the number of erroneous bytes is 1 and the hamming weight of SI is larger than μ1t, a detection is carried out as the case where a byte error is occurred, so that the decoding can be carried out similarly.
Therefore, when a syndrome other than SI is newly input into the H″ multiplication circuit in the above example and SI≠0 and the syndrome other than SI is 0, the decoding circuit outputs a detection signal. Further, SI is newly input into the error vector generating circuit over GF(2b), the error vector generating circuit over GF(2b) checks whether the number of erroneous bytes is 1 in the error e′ over GF(2r) or not, and the sorting circuit checks whether the Hamming weight of SI is larger than μ1t or not, so that the decoding circuit can be clearly constructed similarly.
As described above, in the present invention, with respect to spotty-byte errors having errors up to t bits within a byte, a general code constitution of the error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes with the capability for correcting μ1 spotty-byte errors occurred in p1 bytes and detecting μ2 spotty-byte errors occurred in p2 bytes, is given. Further, the concrete constitutions of the encoding circuit and the decoding circuit as the circuits which can realize correction and detection of error, are shown in the present invention, and the present invention also shows that the check information can be generated and errors can be concretely corrected and detected.
Further, when t=1, the error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes according to the present invention, becomes a code for correcting and detecting random bit errors occurred in a limited number of bytes with the capability for controlling random bit errors occurred in a limited number of bytes.
Further, in the present invention, a general code constitution of the error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes with the function of detecting single-byte error exceeding the correction capability, is given, and the concrete constitutions of the encoding circuit and the decoding circuit as the circuits which can correct and detect the errors are shown, so that the check information can be generated and the errors can be corrected and detected.
The above explanation refers to the applications of the present invention mainly to memory systems, but the present invention is not limited to them, and for example, the present invention can be applied to general information systems or the like which are composed of such circuits, module and device physically independent by byte and where the limited number of errors are likely occurred. Further, the present invention can be applied also to a circuit, a device or a system for communication and transmission such as an optical communication circuit and a bus line circuit.
It goes without saying that the object of the present invention is realized by that a storage medium in which program codes of software for realizing the functions of the apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to the embodiment, is supplied to a system or a device, and the computer (or CPU or MPU) of the system or the device reads and executes the program code stored in the storage medium.
In this case, the program code itself read from the storage medium realizes the function of the embodiment, and the storage medium which stores the program code therein and the program code compose the present invention. As the storage medium for supplying the program code, ROM, flexible disc, hard disc, optical disc, magneto-optical disc, CD-ROM, CD-R, magnetic tape, involatile memory card and the like can be used.
The program code read by the computer is executed so that the function in this embodiment is realized. Furthermore, OS or the like which operates on the computer executes a part or all the actual processes based on instructions of the program code, so that the function in this embodiment is realized by this process.
As described above, in the method and apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to the present invention, the transmitted word which is obtained by adding check information generated based on the parity check matrix expressing the code and the input information data to the input information data, generates a syndrome based on the parity check matrix for the received word which likely has errors occurred in the information transmission channel, and the errors in the received word are corrected and detected based on the syndrome. For this reason, the error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes with the function of correcting and detecting an arbitrary number of multiple spotty-byte errors within a byte occurred in an arbitrary limited number of bytes (the tendency of errors is investigated and a designer can arbitrarily determine the number of the bytes and the number of the spotty-byte errors), can be realized for the spotty-byte errors as up to t-bit errors including single-bit error, double-bit error and triple-bit error within a byte.
As a result, it is possible to treat the constitution of the parity check matrix which is the code for detecting and correcting errors and processing procedure of the decoding in a unified manner, and have no necessity to correspond error occurrence situation, and thus the parity check matrix H and the decoding procedure can be treated in a unified manner by just arbitrarily setting t value, b value, p1 value, p2 value, μ1 value and 2 value in the code function of the present invention, thereby providing the code function which can flexibly correspond the error occurrence situation.
Furthermore, when the integer-bit length t shorter than the byte length as b bits is selected, the number of the check bits can be reduced more significantly than the conventional byte error control code (corresponding to t=b). As a result, the proportion of the check bit number to the code length is reduced, and thus the encoding rate can be not ably improved, thereby realizing data transmission with high efficiency and high reliability.
In other word, according to the method and apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes of the present invention which has a superior function of “controlling multiple spotty-byte errors within multiple bytes occurred in the limited number of bytes” that does not exist in the conventional encoding technique, the number of check bits is reduced and the encoding rate can be improved further than the conventional multiple bytes error control code by means of the Reed-Solomon code. Further, particularly, when t=1, the number of the check bits is reduced and the encoding rate can be improved further than the conventional multiple bits error control code by means of a BCH code. Furthermore, the code function that can flexibly correspond the bit error occurrence situation, can be provided.
Number | Date | Country | Kind |
---|---|---|---|
2005-60818 | Mar 2005 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP2005/023545 | 12/16/2005 | WO | 00 | 11/14/2007 |