Method and apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes

Information

  • Patent Grant
  • 8230292
  • Patent Number
    8,230,292
  • Date Filed
    Friday, December 16, 2005
    19 years ago
  • Date Issued
    Tuesday, July 24, 2012
    12 years ago
Abstract
An apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes and which has a function capable of controlling multiple spotty-byte errors within a byte occurred in the limited number of bytes, is provided.
Description
TECHNICAL FIELD

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”.


BACKGROUND TECHNIQUE

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.


DISCLOSURE OF THE INVENTION

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, 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. 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]p1−[μ2t/bED]p2 code),






H
=

[




H





H








H








H








γ
0



H







γ
1



H










γ
i



H










γ

n
-
1




H









γ
0



H







γ
2



H










γ

2

i




H










γ

2


(

n
-
1

)





H































γ
0



H







γ


p
1

+

p
2

-
1




H










γ


(


p
1

+

p
2

-
1

)


i




H










γ


(


p
1

+

p
2

-
1

)



(

n
-
1

)





H






]






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 (μ12)t and b are linearly independent, if (μ12)t≧b, said matrix H′ is a nonsingular matrix including an identity matrix, if (μ12)t<b, said matrix H′ is equal to a check matrix of a code having a minimum Hamming distance (μ12)t+1, namely, a parity check matrix of a (b,b−q) code with a function of detecting (μ12)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 └(μ12)/2┘t and b are linearly independent, └x┘ represents a maximum integer which does not exceed x, if └(μ12)/2┘t≧b, said matrix H″ is a nonsingular matrix including an identity matrix, if └(μ12)/2┘t<b, said matrix H″ is equal to a check matrix of a code having a minimum Hamming distance └(μ12)/2┘t+1, namely, a parity check matrix of a (b,b−r) code with a function of detecting └(μ12)/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]p1−[μ2t/bED]p2 code),






H
=

[




H





H








H








H





H





O

q
×

r










γ
0



H







γ
1



H










γ
i



H










γ

n
-
1




H






O


r


×
b





O


r


×

r










γ
0



H







γ
2



H










γ

2

i




H










γ

2


(

n
-
1

)





H






O


r


×
b





O


r


×

r




































γ
0



H







γ


p
1

+

p
2

-
1




H










γ


(


p
1

+

p
2

-
1

)


i




H










γ


(


p
1

+

p
2

-
1

)



(

n
-
1

)





H






O


r


×
b





I

r






]






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 (μ12)t and b are linearly independent, if (μ12)t≧b, said matrix H′ is a nonsingular matrix including an identity matrix, if (μ12)t<b, said matrix H′ is equal to a check matrix of a code having a minimum Hamming distance (μ12)t+1, namely, a parity check matrix of a (b,b−q) code with a function of detecting (μ12)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 └(μ12)/2┘t and b are linearly independent, └x┘ represents a maximum integer which does not exceed x, if └(μ12)/2┘t≧b, said matrix H″ is a nonsingular matrix including an identity matrix, if └(μ12)/2┘t<b, said matrix H″ is equal to a check matrix of a code having a minimum Hamming distance └(μ12)/2┘t+1, namely, a parity check matrix of a (b,b−r) code with a function of detecting └(μ12)/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]p1−[μ2t/bED]p2−SbED code),






H
=

[




I
b




I
b







I
b







I
b







γ
0



H







γ
1



H










γ
i



H










γ

n
-
1




H









γ
0



H







γ
2



H










γ

2

i




H










γ

2


(

n
-
1

)





H





























γ
0



H







γ


p
1

+

p
2

-
1




H










γ


(


p
1

+

p
2

-
1

)


i




H










γ


(


p
1

+

p
2

-
1

)



(

n
-
1

)





H






]






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 └(μ12)/2┘t and b are linearly independent, └x┘ represents a maximum integer which does not exceed x, if └(μ12)/2┘t≧b, said matrix H″ is a nonsingular matrix including an identity matrix, if └(μ12)/2┘t<b, said matrix H″ is equal to a check matrix of a code having a minimum Hamming distance └(μ12)/2┘t+1, namely, a parity check matrix of a (b,b−r) code with a function of detecting └(μ12)/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 and single-byte error exceeding correction capability (lengthened [μ1t/bEC]p1−[μ2t/bED]p2−SbED code)






H
=

[




I
b




I
b







I
b







I
b




I
b




O

b
×

r










γ
0



H







γ
1



H










γ
i



H










γ

n
-
1




H






O


r


×
b





O


r


×

r










γ
0



H







γ
2



H










γ

2

i




H










γ

2


(

n
-
1

)





H






O


r


×
b





O


r


×

r




































γ
0



H







γ


p
1

+

p
2

-
1




H










γ


(


p
1

+

p
2

-
1

)


i




H










γ


(


p
1

+

p
2

-
1

)



(

n
-
1

)





H






O


r


×
b





I

r






]






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 └(μ12)/2┘t≧b, said matrix H″ is a nonsingular matrix including an identity matrix, if └(μ12)/2┘t<b, said matrix H″ is equal to a check matrix of a code having a minimum Hamming distance └(μ12)/2┘t+1, namely, a parity check matrix of a (b,b−r) code with a function of detecting └(μ12)/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]p1−[μ2t/bED]p2 code),becomes an error control code for controlling random bit errors occurred in a limited number of bytes with a function of correcting μ1 random bit errors occurred in p1 bytes and detecting μ2 random bit errors occurred in p2 bytes, when said value t is set to 1 (t=1). The above object of the present invention is also effectively achieved by that: said lengthened error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes (lengthened [μ1t/bEC]p1−[μ2t/bED]p2 code), becomes an error control code for controlling random bit errors occurred in a limited number of bytes with a function of correcting μ1 random bit errors occurred in p1 bytes and detecting μ2 random bit errors occurred in p2 bytes, when said value t is set to 1 (t=1). 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]p1−[μ2t/bED]p2−SbED code), becomes an error control code for controlling random bit errors occurred in a limited number of bytes with a function of correcting μ1 random bit errors occurred in p1 bytes, and detecting μ2 random bit errors occurred in p2 bytes and single-byte error exceeding correction capability, when said value t is set to 1 (t=1). The above object of the present invention is also effectively achieved by that: said lengthened error control code for controlling multiple spotty-byte errors within a byte occurred in a limited number of bytes (lengthened [μ1t/bEC]p1−[μ2t/bED]p2−SbED code), becomes an error control code for controlling random bit errors occurred in a limited number of bytes with a function of correcting μ1 random bit errors occurred in p1 bytes, and detecting μ2 random bit errors occurred in p2 bytes and single-byte error exceeding correction capability, when said value t is set to 1 (t=1).


Further, the above object of the present invention is also effectively achieved by that: if t≧b/└(μ12)/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/└(μ12)/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/└(μ12)/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/└(μ12)/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, 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,

wM(êx+eA)≦μ1−wM(êx)

where wM(e) is defined by








w
M



(
e
)


=




i
=
0


n
-
1








w
H



(

e
i

)


t









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, exx 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]p1−[μ2t/bED]p2−SbED code and said lengthened [μ1t/bEC]p1−[μ2t/bED]p2−SbED code, said decoding means is constituted by that a syndrome other than SI is newly input into said H″ multiplication means, and when SI0 and said syndrome other than SI is 0, a detection signal is output, SI is newly input into said error vector generating means over GF(2b), said error vector generating means over GF(2b) checks whether the number of erroneous bytes is 1 in the error e′ over GF(2r) or not, and said multi-input sorting means checks whether Hamming weight of SI is larger than μ1t or not.


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,

wM(êx+eA)≦μ1−wM(êx)

where wM(e) is defined by








w
M



(
e
)


=




i
=
0


n
-
1








w
H



(

e
i

)


t









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, exx 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]p1−[μ2t/bED]p2−SbED code and said lengthened [μ1t/bEC]p1−[μ2t/bED]p2−SbED code, said decoding processing is carried out by that a syndrome other than SI is newly input into said H″ multiplication processing step, and when SI≠0 and said syndrome other than SI is 0, a detection signal is output, SI is newly input into said error vector generating processing step over GF(2b), said error vector generating processing step over GF(2b) checks whether the number of erroneous bytes is 1 in the error e′ over GF(2r) or not, and said multi-input sorting processing step checks whether Hamming weight of SI is larger than μ1t or not.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a block diagram illustrating a schematic constitution of an apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to a preferred embodiment of the present invention;



FIG. 2 is a flowchart illustrating processing procedure of entire operation in the apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to the present invention shown in FIG. 1;



FIG. 3 is a diagram illustrating one example of parity check matrix according to the present invention, i.e. a parity check matrix of a shortened (90,64) [41/8EC]2 code having code parameters such that code-length N=90 bits, information-length K=64 bits, check-length R=26 bits, byte-length b=8 bits, the number of correctable bits within a byte t=1 bit, the number of correctable spotty byte errors is equal to that of detectable spotty byte errors, that is, μ12=4, and the maximum number of erroneous bytes p1=p2=2;



FIG. 4 is a diagram illustrating a parity check matrix of an encoding (90,64) [41/8EC]2 systematic code which is obtained by applying the elementary row operation of the parity check matrix shown in FIG. 3;



FIG. 5 is a conceptual diagram illustrating a circuit for generating check information of 26 bits from input information data whose K is 64 bits by means of the parity check matrix as a concrete example of an encoding circuit (upper 14 bits) configured based on the encoding (90,64) [41/8EC]2 systematic code shown in FIG. 4;



FIG. 6 is a conceptual diagram illustrating a circuit for generating check information of 26 bits from input information data whose K is 64 bits by means of the parity check matrix as a concrete example of an encoding circuit (lower 12 bits) configured based on the encoding (90,64) [41/8EC]2 systematic code shown in FIG. 4;



FIG. 7 is a block diagram illustrating a schematic configuration of a decoding circuit for codes having functions disclosed in the present invention;



FIG. 8 is a conceptual diagram for explaining a syndrome generating circuit (upper 14 bits) configured concretely based on the (90,64) [41/8EC]2 code shown in FIG. 3;



FIG. 9 is a conceptual diagram for explaining a syndrome generating circuit (lower 12 bits) configured concretely based on the (90,64) [41/8EC]2 code shown in FIG. 3;



FIG. 10 is a configuration diagram of an H′ decoding circuit configured concretely based on the (90,64) [41/8EC]2 code shown in FIG. 3;



FIG. 11 is a configuration diagram of an H″ multiplication circuit configured concretely based on the (90,64) [41/8EC]2 code shown in FIG. 3;



FIG. 12 is a block diagram illustrating a schematic configuration of a parallel decoding circuit over GF(2r) for the (90,64) [41/8EC]2 code shown in FIG. 3;



FIG. 13 is a circuit configuration diagram illustrating one example of an error vector generating circuit for (i,j) in the parallel decoding circuit over GF(2r) shown in FIG. 12;



FIG. 14 is a configuration diagram illustrating an error vector calculating circuit over GF(2r) in the parallel decoding circuit over GF(2r) shown in FIG. 12;



FIG. 15 is a block diagram illustrating a schematic configuration of an error vector generating circuit over GF(2b) for the (90,64) [41/8EC]2 code shown in FIG. 3;



FIG. 16 is a configuration diagram illustrating a circuit for generating upper 4 bits of bit-error pointer (ê) 71 produced by the decoder from bit-error pointer over GF(2r) for the first byte as an example of a t-bit error correction decoding circuit in the error vector generating circuit over GF(2b) shown in FIG. 15;



FIG. 17 is a configuration diagram illustrating a circuit for generating lower 4 bits of the bit-error pointer (ê) 71 produced by the decoder from the bit-error pointer over GF(2r) for the first byte as an example of the t-bit error correction decoding circuit in the error vector generating circuit over GF(2b) shown in FIG. 15;



FIG. 18 is a configuration diagram illustrating a circuit for detecting an error exceeding correction capability on the first byte as an example of the t-bit error correction decoding circuit in the error vector generating circuit over GF(2b) shown in FIG. 15;



FIG. 19 is a configuration diagram illustrating a 12-inputs sorting circuit in the error vector generating circuit over GF(2b) shown in FIG. 15;



FIG. 20 is a circuit configuration diagram illustrating one example of a miscorrection determining circuit in i-th byte in the error vector generating circuit over GF(2b) shown in FIG. 15;



FIG. 21 is a configuration diagram illustrating a bit-by-bit exclusive logical sum circuit in the miscorrection determining circuit in i-th byte shown in FIG. 20;



FIG. 22 is a configuration diagram illustrating a bit-by-bit selection circuit in the miscorrection determining circuit in i-th byte shown in FIG. 20;



FIG. 23 is a configuration diagram illustrating a 16-inputs sorting circuit in the miscorrection determining circuit in i-th byte shown in FIG. 20; and



FIG. 24 is a configuration diagram illustrating an inverting circuit for 1 byte as one example of an inverting circuit for the (90,64) [41/8EC]2 code shown in FIG. 3.





DESCRIPTION OF REFERENCE NUMERALS






    • 1 Syndrome generating circuit


    • 2 Encoding circuit


    • 3 Circuit (data communication channel such as memory or the like)


    • 4 Decoding circuit


    • 5 Error correction circuit


    • 6 H′ decoding circuit


    • 7 H″ multiplication circuit


    • 8 Parallel decoding circuit over GF(2r)


    • 9 Error vector generating circuit over GF(2b)


    • 10 Inverting circuit


    • 20 Multi-input parity check circuit


    • 21 Multi-input parity check circuit


    • 22 2-input exclusive logical sum circuit


    • 23 3-input parity check circuit


    • 30 Input information data


    • 31 Transmitted word


    • 32 Received word


    • 33 Syndrome(S)


    • 34 Output information data


    • 35 Uncorrectable error detection signal (UCE)


    • 36 Upper q bits (SI) on syndrome (S) 33


    • 37 Lower 3r bits (SIISIIISIV) on syndrome (S) 33


    • 38 Byte-by-byte sum of errors (eA)


    • 39 Product (S′I) of upper q bits SI36 on syndrome (S) 33 and transposed matrix (H″T) of matrix H″


    • 40 Bit-error pointer over GF(2r)


    • 41 Uncorrectable error detection signal (DS(0))


    • 42 Bit-error pointer over GF(2b)


    • 43 Uncorrectable error detection signal (DS(1))


    • 44 2-input AND gate circuit


    • 50 Error vector generating circuit for (i,j)


    • 51 Error vector calculating circuit over GF(2r)


    • 52 Error for (i,j)


    • 53 Correctable signal for (i,j)


    • 54 24-input OR gate circuit


    • 55 66-input NOR gate circuit


    • 56 2-input AND gate circuit


    • 60 S′·{tilde over (H)}iT calculating circuit


    • 61 S′·{tilde over (H)}jT calculating circuit


    • 62 S′·B(i,j)T calculating circuit


    • 63 Multi-input parity check circuit


    • 64 Multi-input parity check circuit


    • 65 Multi-input parity check circuit


    • 66 12-input NOR gate circuit


    • 67 2-input AND gate circuit


    • 68 Bit-by-bit OR arithmetic circuit


    • 69 11-input OR gate circuit


    • 70 t-bit error correction decoding circuit


    • 71 Bit-error pointer (ê) produced by the decoder


    • 72 Detection signal in i-th byte


    • 73 12-input sorting circuit


    • 74 Miscorrection determining circuit in i-th byte


    • 75 2-input OR gate circuit


    • 76 2-input AND gate circuit


    • 80 NOT gate circuit


    • 81 3-input AND gate circuit


    • 82 4-input AND gate circuit


    • 83 5-input AND gate circuit


    • 84 5-input OR gate circuit


    • 85 6-input OR gate circuit


    • 86 15-input OR gate circuit


    • 90 Bit-by-bit exclusive logical sum circuit


    • 91 16-input sorting circuit


    • 92 4-input OR gate circuit


    • 93 12-input NOR gate circuit


    • 94 NOT gate circuit


    • 95 3-input AND gate circuit


    • 96 Bit-by-bit selection circuit


    • 97 Multi-input parity check circuit


    • 98 2-input multiplexer circuit


    • 99 2-input exclusive logical sum circuit


    • 100 apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes





THE BEST MODE FOR CARRYING OUT THE INVENTION

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. FIG. 1 is a block diagram illustrating a schematic constitution of the 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 (herein after, abbreviated as the spotty-byte error correction and detection apparatus 100). As shown in FIG. 1, the spotty-byte error correction and detection apparatus 100 comprises an encoding circuit 2, a circuit 3, a decoding circuit 4 and the like.


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. FIG. 2 is a flowchart illustrating processing procedure of the entire operation of the spotty-byte error correction and detection apparatus 100 according to the present invention shown in FIG. 1.


As shown in FIG. 2, when the input information data (D) 30 is input into the encoding circuit 2, the encoding circuit 2 generates check information (C) using a parity check matrix (H), mentioned in detail later (step S200). Then, the encoding circuit 2 adds the check information (C) to the input information data (D) 30, and transmits it as a transmitted word (V) 31 to the circuit 3 as the data communication channel such as a memory or the like (step S201). A received word (V′) 32 through the circuit 3, which possibly includes an error, is input into the decoding circuit 4 (step S202).


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]p1−[μ2t/bED]p2 code. For example, in the case of a code for correcting 3 spotty-byte errors occurred in 2 bytes, the code is expressed as [Tt/bEC]2 code, and μ12=3, p1=p2=2.


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/└(μ12)/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]p1−[μ2t/bED]p2 code), has a constitution as expressed by the following Expression 1.









H
=

[




H





H








H








H








γ
0



H







γ
1



H










γ
i



H










γ

n
-
1




H









γ
0



H







γ
2



H










γ

2

i




H










γ

2


(

n
-
1

)





H





























γ
0



H







γ


p
1

+

p
2

-
1




H










γ


(


p
1

+

p
2

-
1

)


i




H










γ


(


p
1

+

p
2

-
1

)



(

n
-
1

)





H






]





[

Expression





1

]







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 (μ12)t and b are linearly independent.

H′=[h0′,h1′, . . . , hb-1′]  [Expression 2]


if (μ12)t≧b, the matrix H′ is a nonsingular matrix including an identity matrix, and if (μ12)t<b, the matrix H′ is equal to a check matrix of a code having a minimum Hamming distance (μ12)t+1, namely, a parity check matrix of a (b,b−q) code with a function of detecting (μ12)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 └(μ12)/2┘t and b are linearly independent. └x┘ represents a maximum integer which does not exceed x.

H″=[h0″,h1″, . . . , hb-1″]  [Expression 3]


if └(μ12)/2┘t≧b, the matrix H″ is a nonsingular matrix including an identity matrix, and if └(μ12)/2┘t<b, the matrix H″ is equal to a check matrix of a code having a minimum Hamming distance └(μ12)/2┘t+1, namely, a parity check matrix of a (b,b−r) code with a function of detecting └(μ12)/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/└(μ12)/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]p1−[μ2t/bED]P2 code can be defined. A parity check matrix (H) of 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 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]p1−[μ2t/bED]p2 code) can be constituted as shown in the following Expression 5.









H
=

[




H





H








H








H





H





O

q
×

r










γ
0



H







γ
1



H










γ
i



H










γ

n
-
1




H






O


r


×
b





O


r


×

r










γ
0



H







γ
2



H










γ

2

i




H










γ

2


(

n
-
1

)





H






O


r


×
b





O


r


×

r




































γ
0



H







γ


p
1

+

p
2

-
1




H










γ


(


p
1

+

p
2

-
1

)


i




H










γ


(


p
1

+

p
2

-
1

)



(

n
-
1

)





H






O


r


×
b





I

r






]





[

Expression





5

]







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 (μ12) t and b are linearly independent.

H′=[h0′,h1′, . . . , hb-1′]  [Expression 6]


if (μ12)t≧b, the matrix H′ is a nonsingular matrix including an identity matrix, and if (μ12)t<b, the matrix H′ is equal to a check matrix of a code having a minimum Hamming distance (μ12) t+1, namely, a parity check matrix of a (b,b−q) code with a function of detecting (μ12)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 └(μ12)/2┘t and b are linearly independent. └x┘ represents a maximum integer which does not exceed x.

H″=[h0″,h1″, . . . , hb-1″]  [Expression 7]


if └(μ12)/2┘t≧b, the matrix H″ is a nonsingular matrix including an identity matrix, and └(μ12)/2┘t<b, the matrix H″ is equal to a check matrix of a code having a minimum Hamming distance └(μ12)/2┘t+1, namely, a parity check matrix of a (b,b−r) code with a function of detecting └(μ12)/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 (μ12-1) bits.


In the case of parameter t≧b/└(μ12)/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.













e

i
1


·

H

i
1

T


+

+


e

i

v
1



·

H

i

v
1


T


+


e

i


v
1

+
1



·

H

i


v
1

+
1


T


+

+


e

i


v
1

+

v
2




·

H

i


v
1

+

v
2



T


+

+


e

i


v
1

+

v
2

+

+

v

λ
-
1


+
1



·

H

i


v
1

+

v
2

+

+

v

λ
-
1


+
1


T


+





+


e

i


v
1

+

v
2

+

+

v
λ




·

H

i


v
1

+

v
2

+

+

v
λ



T





0






0
<




x
=
1



v
1

+

+

v
λ






w
M



(

e

i
x


)






μ
1

+

μ
2





,

0
<




x
=
1

λ



v
x





p
1

+


p
2






0




v
1




p
1

+

p
2



,

0


v
2



min


(





(


μ
1

+

μ
2


)

/
2



,


p
1

+

p
2



)



,









,

0


v
λ



min


(





(


μ
1

+

μ
2


)

/
λ



,


p
1

+

p
2



)







[

Expression





9

]







Where, eix represents the ix-th byte in an error vector e, λ=┌b/t┐, └y┘ represents a maximum integer which is y or less, and ┌z┐ represents a minimum integer which is z or more.


Further, i1, i2, . . . , iv1+v2+ . . . +vλ (0≦i1, i2, . . . , iv1+v2+ . . . +vλ≦n−1) are all different from one another, and wM(e) is defined by the following Expression 10 and represents the number of spotty-byte error. wH(ei) is a Hamming weight over Galois field GF(2) in a vector ei.











w
M



(
e
)


=




i
=
0


n
-
1








w
H



(

e
i

)


t








[

Expression





10

]







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







Ω
i

=


{


e

i
1


,

e

i
2


,





,

e

i

ρ
1




}

.






Where, wM(eix)≦λ and










x
=
1


ρ
1





w
M



(

e

i
x


)



=

l
1





Further, a set of l2 (l2≦μ2) spotty-byte errors occurred in ρ22≦p2) bytes is designated as







Ω
j

=


{


e

j
1


,

e

j
2


,





,

e

j

ρ
2




}

.






Where, wM(ejx)≦λ and










x
=
1


ρ
2





w
M



(

e

j
x


)



=

l
2





In this case, [μ1t/bEC]p1−[μ2t/bED]p2 code satisfies the relationship expressed by the following Expression 11 in error pattern of Ωi and Ωj.












e

i
1


·

H

i
1

T


+


e

i
2


·

H

i
2

T


+

+


e

i

ρ
1



·

H

i

ρ
1


T







e

j
1


·

H

j
1

T


+


e

j
2


·

H

j
2

T


+

+


e

j

ρ
2



·

H

j

ρ
2


T







[

Expression





11

]







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.












e

i
1


·

H

i
1

T


+


e

i
2


·

H

i
2

T


+

+


e

i
V


·

H

i
V

T


+






e

i

V
+
1



·

H

i

V
+
1


T


+





+


e

i

ρ
1



·

H

i

ρ
1


T







e

j
1


·

H

j
1

T


+


e

j
2


·

H

j
2

T


+

+






+





e

j
V



·

H

j
V

T


+


e

j

V
+
1



·

H

j

V
+
1


T


+

+


e

j

ρ
2



·

H

j

p
2


T







[

Expression





12

]







Therefore, the following Expression 13 can be obtained from the Expression 12.












(


e

i
1


+

e

j
1



)

·

H

i
1

T


+


(


e

i
2


+

e

j
2



)

·

H

i
2

T


+

+


(


e

i
V


+

e

j
V



)

·

H

i
V

T


+


e

i

V
+
1



·

H

i

V
+
1


T


+





+


e

i

ρ
1



·

H

i

ρ
1


T


+


e

j
V


·

H

j
V

T


+


e

j

V
+
1



·

H

j

V
+
1


T


+

+


e

j

ρ
2



·

H

j

ρ
2


T




0




[

Expression





13

]







Where, wM(eix+ejx)≦λ holds with respect to x=1, 2, . . . , V. In the Expression 13, when (eix+ejx) is replaced by eix and ρ12−V=v1+v1+ . . . +vλ is premised, the necessary and sufficient condition shown in the Expression 9 holds.


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.












e

i
1


·


[




H








γ

i
1




H
′′








γ

2


i
1





H
′′













γ


(


p
1

+

p
2

-
1

)



i
1





H
′′





]

T


+

+


e

i


v
1

+
1



·


[




H








γ

i


v
1

+
1





H
′′








γ

2


i


v
1

+
1






H
′′













γ


(


p
1

+

p
2

-
1

)



i


v
1

+
1






H
′′





]

T


+






…e

i


v
1

+

v
2

+

+

v
λ




·


[




H








γ

i


v
1

+

v
2

+

+

v
λ






H
′′








γ

2


i


v
1

+

v
2

+

+

v
λ







H
′′













γ


(


p
1

+

p
2

-
1

)



i


v
1

+

v
2

+

+

v
λ







H
′′





]

T



=


[



0




0




0




0




0



]

T





[

Expression





14

]







In








(




y
=
1



v
1

+

v
2

+

+

v
λ





e

i
y



)

·

H







T



=
0





of the Expression 14, since H′ is a matrix where any Min((μ12)t, b) columns are linearly independent, the following Expression 15 can be obtained.













y
=
1



v
1

+

v
2

+

+

v
λ





e

i
y



=
0




[

Expression





15

]







In the Expression 15, when the both sides are multiplied by H″T from the right, the following Expression 16 can be obtained.











(




y
=
1



v
1

+

v
2

+

+

v
λ





e

i
y



)

·

H

′′





T



=
0




[

Expression





16

]







In the Expression 14 and the Expression 16, when ei1·H″T,








e

i
2


·

H

′′





T



,





,


e

i


v
1

+

v
2

+

+

v
λ




·

H

′′





T








·H″T are designated as x1, x2, . . . , xv1+v2+ . . . +vλ respectively, the following Expression 17 can be obtained. Since H″ is a matrix where any Min(└(μ12)/2┘t, b) columns are linearly independent, then x1≠0, x2≠0, . . . , or







x


v
1

+

v
2

+

+

v




(


μ
1

+

μ
2


)

/
2







0





holds.











{






x
1

+

x
2

+

+

x


v
1

+

v
2

+

+

v
λ




=
0









γ

i
1




x
1


+


γ

i
2




x
2


+

+


γ

i


v
1

+

v
2

+

+

v
λ






x


v
1

+

v
2

+

+

v
λ





=
0









γ

2






i
1





x
1


+


γ

2


i
2





x
2


+

+


γ

2


i


v
1

+

v
2

+

+

v
λ







x


v
1

+

v
2

+

+

v
λ





=
0














γ


(


p
1

+

p
2

-
1

)



i
1





x
1


+


γ


(


p
1

+

p
2

-
1

)



i
2





x
2


+

+


γ


(


p
1

+

p
2

-
1

)



i


v
1

+

v
2

+

+

v
λ







x


v
1

+

v
2

+

+

v
λ





=
0








[

Expression





17

]








In the Expression 17, when v1+v2+ . . . +vλ (≦p1+p2) expressions from top are expressed by matrix, the following Expression 18 is obtained.










[



1


1





1





γ

i
1





γ

i
2








γ

i


v
1

+

v
2

+









+

v
λ









γ

2


i
1






γ

2


i
2









γ

2


i


v
1

+

v
2

+









+

v
λ
























γ


(


v
1

+

v
2

+

+

v
λ

-
1

)



i
1






γ


(


v
1

+

v
2

+

+

v
λ

-
1

)



i
2









γ


(


v
1

+

v
2

+

+

v
λ

-
1

)



i


v
1

+

v
2

+

+

v
λ








]






[








x
1






x
2






x
3











x


v
1

+

v
2

+

+

v
λ






]

=

[



0




0




0









0



]







[

Expression





18

]







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.










[




x
1






x
2






x
3











x


v
1

+

v
2

+

+

v
λ






]

=

[



0




0




0









0



]





[

Expression





19

]







In the Expression 19, x1=0, x2=0, . . . , xv1+v2+ . . . +vλ=0 holds, and thus the Expression 19 contradicts x1≠0, x2≠0, . . . ,







x


v
1

+

v
2

+

+

v




(


μ
1

+

μ
2


)

/
2







0





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, μ12=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((μ12)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.










H


=


I
8

=

[



1


0


0


0


0


0


0


0




0


1


0


0


0


0


0


0




0


0


1


0


0


0


0


0




0


0


0


1


0


0


0


0




0


0


0


0


1


0


0


0




0


0


0


0


0


1


0


0




0


0


0


0


0


0


1


0




0


0


0


0


0


0


0


1



]






[

Expression





20

]







According to Min(└(μ12)/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.










H
′′

=

[



1


0


0


0


0


0


1


0




0


1


0


0


0


0


1


0




0


0


1


0


0


0


1


1




0


0


0


1


0


0


1


1




0


0


0


0


1


0


0


1




0


0


0


0


0


1


0


1



]





[

Expression





21

]







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 FIG. 3.


As shown in FIG. 3, in order to clarify the location of each row corresponding to H′ and H″ of the parity check matrix (H), the boundary there between is shown by drawing a solid line.


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 FIG. 3. As mentioned above, according to H″=[γ0γ1γ2γ3γ4γ5γ18γ20], γ3H″=γ30γ1γ2γ3γ4γ5γ18γ20]=[γ3γ4γ5γ6γ7γ8γ21γ23] can hold. This exponential representation is converted into vector representation (for example, γ0=(100000)T or the like), the exponential representation corresponds to a section “a” shown in FIG. 3, and this section “a” is clearly the section γ3H″ of the parity check matrix (H). Similarly, when the other component of the parity check matrix (H) is converted into the vector representation, as a whole, it becomes a constitution of 26 rows and 90 columns expressed by bits shown in FIG. 3.


As to μ12=3, according to Min((μ12)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.










H


=

[



1


0


0


0


0


0


0


1




0


1


0


0


0


0


0


1




0


0


1


0


0


0


0


1




0


0


0


1


0


0


0


1




0


0


0


0


1


0


0


1




0


0


0


0


0


1


0


1




0


0


0


0


0


0


1


1



]





[

Expression





22

]







According to Min(└(μ12)/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.










H
′′

=

[



1


1


1


1


1


1


1


1




0


0


0


0


1


1


1


1




0


0


1


1


0


0


1


1




0


1


0


1


0


1


0


1



]





[

Expression





23

]







As to t=2, for example, in a [T2/EC]2 code having parameters such that μ12=3 and p1=p2=2, according to Min((μ12)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(└(μ12)/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.










H
′′

=

[



1


0


0


0


0


0


0


1




0


1


0


0


0


0


0


1




0


0


1


0


0


0


0


1




0


0


0


1


0


0


0


1




0


0


0


0


1


0


0


1




0


0


0


0


0


1


0


1




0


0


0


0


0


0


1


1



]





[

Expression





24

]







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]p1−[μ2t/bED]p2−SbED code.


In this embodiment, the parity check matrix (H) of R rows and N columns which is used for the [μ1t/bEC]p1−[μ2t/bED]p2−SbED code, has a constitution as expressed by the following Expression 25.









H
=



[




I
b




I
b







I
b







I
b







γ
0



H
′′






γ
1



H
′′









γ
i



H
′′









γ

n
-
1




H
′′








γ
0



H
′′






γ
2



H
′′









γ

2





i




H
′′









γ

2


(

n
-
1

)





H
′′




























γ
0



H
′′






γ


p
1

+

p
2

-
1




H
′′









γ


(


p
1

+

p
2

-
1

)


i




H
′′









γ


(


p
1

-

p
2

-
1

)



(

n
-
1

)





H
′′









]






[

Expression





25

]







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 └(μ12)/2┘t and b are linearly independent. └x┘ represents a maximum integer which does not exceed x.

H″=[h0″,h1″, . . . , hb-1″]  [Expression 26]


if └(μ12)/2┘≧b, the matrix H″ is a nonsingular matrix including an identity matrix, and if └(μ12)/2┘t<b, the matrix H″ is equal to a check matrix of a code having a minimum Hamming distance └(μ12)/2┘t+1, namely, a parity check matrix of a (b, b−r) code with a function of detecting └(μ12)/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/└(μ12)/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]p1−[μ2t/bED]p2−SbED code can be defined. The parity check matrix (H) of R rows and N columns which is used for the lengthened [μ1t/bEC]p1−[μ2t/bED]p2−SbED code can be constituted as shown in the following Expression 28.









H
=



[




I
b




I
b







I
b







I
b




I
b




O

b
×

r










γ
0



H
′′






γ
1



H
′′









γ
i



H
′′









γ

n
-
1




H
′′





O


r


×
b





O


r


×

r










γ
0



H
′′






γ
2



H
′′









γ

2





i




H
′′









γ

2


(

n
-
1

)





H
′′





O


r


×
b





O


r


×

r




































γ
0



H
′′






γ


p
1

+

p
2

-
1




H
′′









γ


(


p
1

+

p
2

-
1

)


i




H
′′









γ


(


p
1

-

p
2

-
1

)



(

n
-
1

)





H
′′





O


r


×
b





I

r






]






[

Expression





28

]







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 └(μ12)/2┘t and b are linearly independent. └x┘ represents a maximum integer which does not exceed x.

H″=[h0″,h1″, . . . , hb-1″]  [Expression 29]


if └(μ12)/2┘t≧b, the matrix H″ is a nonsingular matrix including an identity matrix, and if └(μ12)/2┘t<b, the matrix H″ is equal to a check matrix of a code having a minimum Hamming distance └(μ12)/2┘t+1, namely, a parity check matrix of a (b,b−r) code with a function of detecting └(μ12)/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 (μ12−1) bits.


In the case of parameter t≧b/└(μ12)/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.













e

i
b


·

H

i
b

T


+


e

i
1


·

H

i
1

T


+

+


e

i

v
1



·

H

i

v
1


T


+

e

i


v
1

+
1



+

H

i


v
1

+
1


T

+

+


e

i


v
1

+

v
2




·

H

i


v
1

+

v
2



T


+

+


e

i


v
1

+

v
2

+

+

v

λ
-
1


+
1



·

H

i


v
1

+

v
2

+

+

v

λ
-
1


+
1


T


+

+


e

i


v
1

+

v
2

+

+

v
λ




·

H

i


v
1

+

v
2

+

+

v
λ



T




0








0
<




x
=
1



v
1

+









+

v
λ






w
M



(

e

i
x


)





μ
1


,

0
<




x
=
1

λ



v
x




p
1










0


v
1



p
1


,

0


v
2



min


(





(


μ
1

+

μ
2


)

/
2



,

p
1


)



,









,

0


v
λ



min


(





(


μ
1

+

μ
2


)

/
λ



,

p
1


)








[

Expression





31

]







Where, eib represents a byte error occurred in the ib-th byte in an error vector e, eix represents the ix-th byte in the error vector e, λ=┌b/t┐, └y┘ represents a maximum integer which is y or less, and ┌z┐ represents a minimum integer which is z or more.


Further, ib, i1, i2, . . . , iv1+v2+ . . . +vλ (0≦ib, i1, i2, . . . , iv1+v2+ . . . +vλ≦n−1) are all different from one another, and wM(e) is defined by the Expression 10 and represents the number of spotty-byte error.


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]p1−[μ2t/bED]p2 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 (H) shown in the Expression 1.


<A> The Encoding Method and the Configuration of the Circuit for Realizing the Encoding Method


First, the concrete method of the encoding process to be executed by the encoding circuit 2 shown in FIG. 1 is explained.


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 FIG. 3. The check information (C) can be generated by the following Expression 32.

C=D·HRT  [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 FIG. 3 having 90 bits of code length and 64 bits of the information length by deleting 414 columns of the column vector corresponding to the latter 414 bits. When the elementary row operation in the parity check matrix H of this code is applied, the parity check matrix H as a systematic code can be constructed. FIG. 4 shows the parity check matrix of the (90,64)[41/8EC]2 systematic code.


In the parity check matrix of the (90,64)[41/8EC]2 systematic code shown in FIG. 4, d0 to d63 correspond to the information bit, and c0 to c25 correspond to the check bit. In the parity check matrix of the (90,64) [41/8EC]2 systematic code shown in FIG. 4, a matrix composed of column vectors of d0 to d63 corresponding to information bit becomes the information section HR of the parity check matrix.


The parity check matrix shown in FIG. 4 is used for the encoding, and the parity check matrix shown in FIG. 3 is used for the decoding. Since the matrix obtained by applying the elementary row operation is equivalent to the original matrix, the property of the code expressed by the parity check matrix shown in FIG. 4 is not different from property of the code expressed by the parity check matrix shown in FIG. 3 at all. Therefore, the parity check matrix shown in FIG. 4 is used for the encoding.


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 FIG. 4, an operation for obtaining the sum of bits corresponding to locations where “1” exists excluding bit corresponding to c0 over GF(2) (namely, the sum modulo 2: mod 2) should be performed.


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 FIG. 5, the input of the multi-input parity check circuit 20(0) is these 29 bits, and the output of the multi-input parity check circuit 20(0) is the check bit c0. The other check bits c1 to c25 can be generated similarly to the check bit c0. The configuration of upper 14 bits of the encoding circuit 2 (composed of the multi-input parity check circuits 20(0) to 20(25)) for generating the check bits c0 to c25 of 26 bits in parallel is shown in FIG. 5, and the configuration of the lower 12 bits of the encoding circuit 2 (composed of the multi-input parity check circuits 20(0) to 20(25)) for generating the check bits c0 to c25 of 26 bits in parallel is shown in FIG. 6.


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]

<B> The Decoding Method and the Configuration of the Circuit for Realizing the Decoding Method


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 FIG. 3.


Since p1=p2=2 in the check matrix of the (90,64) [41/8EC]2 code shown in FIG. 3, as shown in the Expression 1, the check matrix has a 4-tiered structure composed of the parity check matrices H′ and H″. As a result, a syndrome where q=8 bits obtained from the first tier is designated as SI, a syndrome where r=6 bits obtained from the second tier is designated as SII, a syndrome where r=6 bits obtained from the third tier is designated as SIII, and a syndrome where r=6 bits obtained from the fourth tier is designated as SIV.


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′·HT=S=[SISIISIIISIV]  [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)≦μ12) occurred in the iII-th byte, the syndrome (S) 33 is expressed by the following Expression 35.

S=[eI·H′T+eII·H′TieI·H″TjeII·H″T2ieI·H″T2jeII·H″T3ieI·H″T3jeII·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((μ12)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 FIG. 3, since H′ is the identity matrix, eA=eI+eII=SI.

(eI+eIIH′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+eIIH″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′ISIISIIISIV]=[e′I+e′IIie′Iie′II2ie′I2je′II3ie′I3je′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 exx holds or not according to the following Expression 39. In other words, when the following Expression 39 holds, exx, 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.

wM(ê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.










A

(

i
,
j

)


-
1


=


[





H
~


(

i
,
j

)








B

(

i
,
j

)






]

=

[





H
~

i








H
~

1







B

(

i
,
j

)






]






[

Expression





40

]







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)T and S′·{tilde over (H)}jT become error sizes e′I and e′II. The errors occurred in two bytes can be corrected by using them. When the byte positions i and j where S′·B(i,j)T=0 are nonexistent, the errors are detected as uncorrectable error.


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 FIG. 7.


As shown in FIG. 1, the decoding circuit 4 comprises the syndrome generating circuit 1 and the error correction circuit 5.


As shown in FIG. 7, the error correction circuit 5 comprises an H′ decoding circuit 6, an H″ multiplication circuit 7, a parallel decoding circuit 8 over GF(2r), an error vector generating circuit 9 over GF(2b) and an inverting circuit 10.


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 FIG. 7 is explained below.


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]p1−[μ2t/bED]p2 code), 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 (H) shown in the Expression 25, and the lengthened code expressed by the parity check matrix (H) shown in the Expression 28 (lengthened [μ1t/bEC]p1−[μ2t/bED]p2−SbED code), their decoding method and the circuit constitutions are basically the same as the above-mentioned decoding method and circuit constitution.


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 FIG. 3.


<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 FIG. 3 has a 4-tiered structure, the syndrome (S) 33 is also divided into four sections accordingly, and SI=(S0S1S2S3S4S5S6S7), SII=(S8S9S10S11S12S13), SIII=(S14S15S16S17S18S19)l SIV=(S20S21S22S23S24S25).

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).



FIGS. 8 and 9 are diagrams illustrating the syndrome generating circuit 1 which is constituted based on the parity check matrix of the (90,64) [41/8EC]2 code shown in FIG. 3. In FIG. 8, upper 14 bits of the syndrome (S) 33 such as S0, S1, . . . , S13 are generated, and in FIG. 9, lower 12 bits of the syndrome (S) 33 such as S14, S15, . . . , S25 are generated.


As shown in FIGS. 8 and 9, in this embodiment, in the syndrome generating circuit 1, first, received information (vq′), (q=0, 1, . . . , 89) having the bit “1” of each corresponding row of the parity check matrix of the (90,64) [41/8EC]2 code shown in FIG. 3 is input into 26 multi-input parity check circuits 21(p), (p=0, 1, . . . , 25).


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 FIG. 3, among the received word v0′, v1′, . . . , and v89′ of 90 bits. The multi-input parity check circuit 21(0) of FIG. 8 inputs the received information of 12 bits and outputs the value S0. This is applied also to the other bits Sp, (p=1, . . . , 25) of the syndrome (S) 33.


<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 FIG. 10. In (eI+eII)·H′TT=SI shown in the Expression 36, since H′ is a matrix where any Min((μ12)t, b) columns are linearly independent, eI+eII (=eA) can be obtained. Therefore, logic synthesis is carried out so that the H′ decoding circuit can be realized by combined circuits.


In the case of the (90,64) [41/8EC]2 code shown in FIG. 3, since H′ is the identity matrix, eA=eI+eII=SI. That is, with respect to eA=(eA0eA1eA2eA3eA4eA5eA6eA7), SI=(S0S1S2S3S4S5S6S7), as shown in FIG. 10, eA0=S0, eA1=S1, eA2=S2, eA3=S3, eA4=S4, eA5=S5, eA6=S6, eA7=S7.


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 FIG. 11. A calculation such that S′I=(eI+eII)·H″T=eA·H″T shown in the Expression 37 is carried out. The information eA having bit “1” of each corresponding row in H″ shown in the following Expression 43 is input into the H″ multiplication circuit 7. The H″ multiplication circuit 7 performs the calculation of S′p (p=0, 1, . . . , 5) modulo 2 for the input information eA, and then outputs this.










H
′′

=

[



1


0


0


0


0


0


1


0




0


1


0


0


0


0


1


0




0


0


1


0


0


0


1


1




0


0


0


1


0


0


1


1




0


0


0


0


1


0


0


1




0


0


0


0


0


1


0


1



]





[

Expression





43

]







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 eA0, eA6 corresponding to the location where “1” exists on the 0th row of the parity check matrix H″ shown in the Expression 43, among eA=(eA0eA1eA2eA3eA4eA5eA6eA7) 38 with 8 bits.


In FIG. 11, the exclusive logical sum circuit 22 inputs the information eA of 2 bits (namely, the values of 2 bits eA0, eA6), and outputs the value S′0.


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.










S


=


(


S
I


|

S
II

|

S
III

|

S
IV


)

=


(



S
0




S
1




S
2




S
3




S
4




S
5



|


S
8



S
9



S
10



S
11



S
12



S
13


|


S
14



S
15



S
16



S
17



S
18



S
19


|


S
20



S
21



S
22



S
23



S
24



S
25



)

=

(



S
0




S
1




S
2




S
3




S
4




S
5



|


S
6




S
7




S
8




S
9




S
10




S
11



|


S
12




S
13




S
14




S
15




S
16




S
17



|


S
18




S
19




S
20




S
21




S
22




S
23




)







[

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 FIG. 12.


As shown in FIG. 12, the parallel decoding circuit 8 over GF(26) is composed of error vector generating circuits for (i,j) 50(0) . . . 50(65) (herein after, 50(m) and 0≦m≦65) that are circuits which select 66 pieces








(



12




2



)






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)}iT, S′·{tilde over (H)}jT, S′·{tilde over (B)}(i,j)T for the byte positions i and j. In other words, the error vector generating circuits 50(0) to 50(65) for (i,j) calculate S′·{tilde over (H)}iT, S′·{tilde over (H)}jT, S′·{tilde over (B)}(i,j)T for the i-th byte and j-th byte (0≦i≦j≦11) in 12 bytes of the code word, and output errors 52(m) to be E′m,i, E′m,j, 0≦m≦65, 0≦i<j≦11 (each are vectors of r bits), and correctable signals 53(m), 0≦m≦65.


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 FIG. 12, first, 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 the error vector generating circuit 50(m) for (i,j).


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 FIG. 13. As shown in FIG. 13, the error vector generating circuit 50(m) for (i,j) comprises an S′·{tilde over (H)}iT calculating circuit 60, an S′·{tilde over (H)}jT calculating circuit 61 and an S′·{tilde over (B)}(i,j)T calculating circuit 62.


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.










H
~

=

[



1


1


1


1


1


1


1


1


1


1


1


1




1


γ



γ
2




γ
3




γ
4




γ
5




γ
6




γ
7




γ
8




γ
9




γ
10




γ
11





1



γ
2




γ
4




γ
6




γ
8




γ
10




γ
12




γ
14




γ
16




γ
18




γ
20




γ
22





1



γ
3




γ
6




γ
9




γ
12




γ
15




γ
18




γ
21




γ
24




γ
27




γ
30




γ
33




]





[

Expression





45

]






γ
=

[



0


0


0


0


0


1




1


0


0


0


0


1




0


1


0


0


0


0




0


0


1


0


0


0




0


0


0


1


0


0




0


0


0


0


1


0



]





[

Expression





46

]







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.












H
~

0

=


[



1




1




1




1



]

=

[



1


0


0


0


0


0




0


1


0


0


0


0




0


0


1


0


0


0




0


0


0


1


0


0




0


0


0


0


1


0




0


0


0


0


0


1




1


0


0


0


0


0




0


1


0


0


0


0




0


0


1


0


0


0




0


0


0


1


0


0




0


0


0


0


1


0




0


0


0


0


0


1




1


0


0


0


0


0




0


1


0


0


0


0




0


0


1


0


0


0




0


0


0


1


0


0




0


0


0


0


1


0




0


0


0


0


0


1




1


0


0


0


0


0




0


1


0


0


0


0




0


0


1


0


0


0




0


0


0


1


0


0




0


0


0


0


1


0




0


0


0


0


0


1



]











H
~

1

=


[



1




γ





γ
2






γ
3




]

=

[



1


0


0


0


0


0




0


1


0


0


0


0




0


0


1


0


0


0




0


0


0


1


0


0




0


0


0


0


1


0




0


0


0


0


0


1




0


0


0


0


0


1




1


0


0


0


0


1




0


1


0


0


0


0




0


0


1


0


0


0




0


0


0


1


0


0




0


0


0


0


1


0




0


0


0


0


1


0




0


0


0


0


1


1




1


0


0


0


0


1




0


1


0


0


0


0




0


0


1


0


0


0




0


0


0


1


0


0




0


0


0


1


0


0




0


0


0


1


1


0




0


0


0


0


1


1




1


0


0


0


0


1




0


1


0


0


0


0




0


0


1


0


0


0



]







[

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.










A

(

0
,
1

)


=


[





H
~

0





H
~

1




B

(

0
,
1

)





]

=



[




1


0


0


0


0


0




0


1


0


0


0


0




0


0


1


0


0


0




0


0


0


1


0


0




0


0


0


0


1


0




0


0


0


0


0


1




1


0


0


0


0


0




0


1


0


0


0


0




0


0


1


0


0


0




0


0


0


1


0


0




0


0


0


0


1


0




0


0


0


0


0


1




1


0


0


0


0


0




0


1


0


0


0


0




0


0


1


0


0


0




0


0


0


1


0


0




0


0


0


0


1


0




0


0


0


0


0


1




1


0


0


0


0


0




0


1


0


0


0


0




0


0


1


0


0


0




0


0


0


1


0


0




0


0


0


0


1


0




0


0


0


0


0


1







|







1


0


0


0


0


0




0


1


0


0


0


0




0


0


1


0


0


0




0


0


0


1


0


0




0


0


0


0


1


0




0


0


0


0


0


1




0


0


0


0


0


1




1


0


0


0


0


1




0


1


0


0


0


0




0


0


1


0


0


0




0


0


0


1


0


0




0


0


0


0


1


0




0


0


0


0


1


0




0


0


0


0


1


1




1


0


0


0


0


1




0


1


0


0


0


0




0


0


1


0


0


0




0


0


0


1


0


0




0


0


0


1


0


0




0


0


0


1


1


0




0


0


0


0


1


1




1


0


0


0


0


1




0


1


0


0


0


0




0


0


1


0


0


0







|



0


0


0


0


0


0


0


0


0


0


0


0




1


1


0


0


0


0


1


0


1


0


0


0




1


0


1


0


0


0


0


1


1


0


0


0




1


1


0


1


1


0


1


0


1


1


0


1




0


0


0


0


0


0


0


0


0


0


0


0




1


0


1


0


0


1


0


1


1


0


0


0




1


0


1


0


0


1


0


1


1


0


0


0




0


0


1


0


0


1


1


1


1


0


0


0




1


0


0


0


0


0


0


1


1


0


0


0




0


0


0


0


0


0


0


0


0


0


0


0




0


1


1


0


0


1


1


1


0


1


1


1




1


0


1


0


0


1


0


1


1


0


0


0




1


0


1


0


0


0


0


1


1


0


0


0




0


0


0


0


0


1


1


0


0


0


0


0




0


0


1


0


0


1


0


0


1


0


0


0




0


0


0


0


0


0


0


0


0


0


0


0




1


0


1


0


1


1


0


1


1


0


1


0




1


1


0


0


1


0


1


0


1


1


1


1




1


1


0


0


1


1


1


0


1


1


1


0




0


1


1


0


1


1


1


1


0


1


1


0




0


0


0


0


0


1


0


0


0


0


0


0




1


0


1


0


0


1


0


1


1


0


0


0




1


0


1


0


1


1


0


1


1


1


1


0




0


0


0


0


0


0


0


0


0


0


0


0




]









[

Expression





48

]







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.










A

(

0
,
1

)


-
1


=


[





H
~


(

0
,
1

)








B

(

0
,
1

)






]

=

[





H
~

0








H
~

1







B

(

0
,
1

)






]






[

Expression





49

]








H
~

0


=

[



1


0


0


0


0


1


0


0


0


1


0


0


0


0


0


0


0


0


0


0


0


1


0


1




0


0


0


0


0


0


0


0


0


0


0


0


1


0


0


0


0


0


1


1


0


0


0


0




0


0


0


0


0


0


1


0


0


0


0


0


1


0


0


0


0


0


0


0


1


0


0


0




1


0


0


0


0


0


1


0


0


0


0


0


0


0


0


0


0


0


0


0


0


1


0


0




0


0


1


0


1


1


0


0


0


0


0


0


0


0


0


0


0


0


0


0


1


0


0


1




1


0


0


0


0


0


1


0


0


1


0


0


0


0


0


0


0


0


0


0


1


0


0


1



]





[

Expression





50

]








H
~

1


=

[



0


0


0


0


0


1


0


0


0


1


0


0


0


0


0


0


0


0


0


0


0


1


0


1




1


0


0


0


0


0


1


0


0


0


0


0


0


0


0


1


0


0


0


0


0


1


0


0




1


0


0


0


0


0


1


0


0


1


0


0


0


0


0


0


0


0


0


0


0


1


0


0




0


1


0


0


1


0


0


0


0


0


0


0


0


0


0


0


0


0


0


1


0


0


1


0




0


0


1


0


0


1


0


0


0


0


0


0


0


0


0


0


0


0


0


0


1


0


0


1




0


0


1


0


0


0


0


0


0


0


0


1


0


0


0


0


0


0


0


0


1


0


0


1



]





[

Expression





51

]








B
~


(

0
,
1

)



=

[



1


0


0


0


0


0


0


1


0


0


0


0


1


1


0


0


0


0


0


0


0


0


0


0




0


1


0


0


0


0


0


1


1


0


0


0


0


0


1


0


0


0


0


0


0


0


0


0




0


0


1


0


0


0


0


0


1


1


0


0


0


0


0


1


0


0


0


0


0


0


0


0




0


0


0


1


0


0


0


0


0


1


1


0


0


0


0


0


1


0


0


0


0


0


0


0




0


0


0


0


1


0


0


0


0


0


1


1


0


0


0


0


0


1


0


0


0


0


0


0




0


0


0


0


0


1


1


0


0


0


0


1


1


0


0


0


0


0


0


0


0


0


0


0




0


0


0


0


0


0


1


0


0


0


0


0


0


1


0


0


0


0


1


1


0


0


0


0




0


0


0


0


0


0


0


1


0


0


0


0


0


1


1


0


0


0


0


0


1


0


0


0




0


0


0


0


0


0


0


0


1


0


0


0


0


0


1


1


0


0


0


0


0


1


0


0




0


0


0


0


0


0


0


0


0


1


0


0


0


0


0


1


1


0


0


0


0


0


1


0




0


0


0


0


0


0


0


0


0


0


1


0


0


0


0


0


1


1


0


0


0


0


0


1




0


0


0


0


0


0


0


0


0


0


0


1


1


0


0


0


0


1


1


0


0


0


0


0



]





[

Expression





52

]







In the S′·{tilde over (H)}0T calculating circuit 60, each column of {tilde over (H)}0T corresponds to information to be input, and for example, the 0-th row of {tilde over (H)}0T corresponds to S′0 of input information. So, in order to generate each bit of S′·{tilde over (H)}0T, the information of the syndrome S′ corresponding to the bit having “1” may be added to each row direction of {tilde over (H)}0 over GF(2) (calculation of mod 2).


In other words, first, the S′·{tilde over (H)}0T calculating circuit 60 inputs syndrome information (S′p), (p=0, 1, . . . , 23) having bit “1” of each corresponding row of {tilde over (H)}0T into 6 multi-input parity check circuits 63(u), (u=0, 1, . . . , 5), respectively. Next, the S′·{tilde over (H)}0T calculating circuit 60 carries out a calculation of Mod 2 for these syndrome information, and outputs E′0,0 and E′0,1 as the result of the calculation.


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 FIG. 13 inputs the 5 bits syndromes s′0, s′5, s′9, s′21 and s′23. The multi-input parity check circuit 63(0) outputs the 0-th bit of E′0,0 that is 52(0). The same is applied also to the other bits of E′0,0.


As shown in FIG. 13, the S′·{tilde over (H)}1T calculating circuit 61 is composed of 6 multi-input parity check circuits 64(w), (w=0, 1, . . . , 5), and the S′·{tilde over (B)}(0,1)T calculating circuit 62 is composed of 12 multi-input parity check circuits 65(z), (z=0, 1, . . . , 11). These calculating circuits can be constructed by the method similar to that of the S′·{tilde over (H)}0T calculating circuit 60.


Here, the process of the error vector generating circuit 50(0) for (0,1) is explained in more detail. As shown in FIG. 13, the 24 bits syndrome S′ is input into the multi-input parity check circuits 63(u), (u=0, 1, . . . , 5), so that E′0,0 is generated. The 24 bits syndrome S′ is input into the multi-input parity check circuits 64(w), (w=0, 1, . . . , 5), so that E′0,1 is generated.


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)T=0 is a pair of erroneous bytes, these circuits detect that S′·{tilde over (B)}(0,1)T=0, and can correct errors in the pair (i,j) of bytes.


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 FIG. 14.


As shown in FIG. 14, the error calculating circuit 51 over GF(26) inputs all errors E′m,i corresponding to the i-th byte into bit-by-bit OR arithmetic circuit 68, and finally outputs the bit-error pointer (e′) 40 over GF(26). These circuits integrate the errors E′m,i from the pairs (i,j) of bytes correspond to the i-th bytes, and output the error ei′ in i-th byte.


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 FIG. 15.


As shown in FIG. 15, the error vector generating circuit 9 over GF(28) comprises t-bit error correction decoding circuits 70, a 12-inputs sorting circuit 73 and miscorrection determining circuits 74 in i-th byte. The error vector generating circuit 9 over GF(2) is a circuit that inputs the bit-error pointer (e′) 40 over GF(26) and the byte-by-byte sum of errors (eA) 38, and outputs the bit-error pointer (e) 42 over GF(28) and the uncorrectable error detection signal (DS(1)) 43.


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 FIG. 15, the bit-error pointer (e′) 40 over GF(26) is divided into each 6 bits, and then is input into the 2-bit error correction decoding circuits 70, respectively.


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 FIG. 16, a circuit which outputs lower 4 bits of the bit-error pointer (ê) 71 produced by the decoder for the first byte is shown in FIG. 17, and a circuit (namely, a detection signal output unit) which outputs the detection signal 72 in 1 byte for outputting “1” at the time of detecting an error exceeding the correction capability is shown in FIG. 18.


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 FIG. 16, since êI·H″T=eI′ on the first byte of information and H″ is a matrix where any 4 columns shown in the Expression 24 are linearly independent, namely, since H″ is a check matrix of the double-bit error correction code, the error êI whose weight is 2 or less as a result of decoding by H″ and the error eI′ over GF(26) are uniquely-determined.


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.












TABLE 1







ê8ê9ê10ê11ê12ê13
e6′e7′e8′e9



ê14ê15
e10′e11









0 0 0 0 0 0
0 0 0 0



0 0
0 0



0 1 0 0 0 0
0 1 0 0



0 0
0 0



0 0 0 1 0 0
0 0 0 1



0 0
0 0



0 0 0 0 0 1
0 0 0 0



0 0
0 1



0 0 0 0 0 0
0 0 1 1



0 1
1 1



1 0 1 0 0 0
1 0 1 0



0 0
0 0



1 0 0 0 1 0
1 0 0 0



0 0
1 0



1 0 0 0 0 0
0 1 1 1



1 0
0 0



0 1 1 0 0 0
0 1 1 0



0 0
0 0



0 1 0 0 1 0
0 1 0 0



0 0
1 0



0 1 0 0 0 0
1 0 1 1



1 0
0 0



0 0 1 1 0 0
0 0 1 1



0 0
0 0



0 0 1 0 0 1
0 0 1 0



0 0
0 1



0 0 1 0 0 0
0 0 0 1



0 1
1 1



0 0 0 1 0 1
0 0 0 1



0 0
0 1



0 0 0 1 0 0
0 0 1 0



0 1
1 1



0 0 0 0 1 0
1 1 1 1



1 0
1 0



0 0 0 0 0 1
1 1 1 1



1 0
0 1



0 0 0 0 0 0
1 1 0 0



1 1
1 1



1 0 0 0 0 0
1 0 0 0



0 0
0 0



0 0 1 0 0 0
0 0 1 0



0 0
0 0



0 0 0 0 1 0
0 0 0 0



0 0
1 0



0 0 0 0 0 0
1 1 1 1



1 0
0 0



1 1 0 0 0 0
1 1 0 0



0 0
0 0



1 0 0 1 0 0
1 0 0 1



0 0
0 0



1 0 0 0 0 1
1 0 0 0



0 0
0 1



1 0 0 0 0 0
1 0 1 1



0 1
1 1



0 1 0 1 0 0
0 1 0 1



0 0
0 0



0 1 0 0 0 1
0 1 0 0



0 0
0 1



0 1 0 0 0 0
0 1 1 1



0 1
1 1



0 0 1 0 1 0
0 0 1 0



0 0
1 0



0 0 1 0 0 0
1 1 0 1



1 0
0 0



0 0 0 1 1 0
0 0 0 1



0 0
1 0



0 0 0 1 0 0
1 1 1 0



1 0
0 0



0 0 0 0 1 1
0 0 0 0



0 0
1 1



0 0 0 0 1 0
0 0 1 1



0 1
0 1



0 0 0 0 0 1
0 0 1 1



0 1
1 0










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′ē8custom charactere6′ē8′ē9′ē10custom characterē6′e7′e8′ē9′ē11custom charactere6′ē7′e8′ē9custom charactere6′ē7′e8′e11′  [Expression 53]


Where, ē′x is logical inverse of ex′, e6′ē7′ē8′ is e6custom characterē7custom characterē8′, custom character represents a logical sum and custom character represents a logical product.


Therefore, as shown in FIG. 16, first, the bit-error pointers 40 e′6, e′7, e′8, e′9, e′10 and e′11 over GF(26) are input into NOT gate circuits 80, respectively, so that ēx′ is generated. And then e6′,ē7′,ē8′ is input into a 3-input AND gate circuit 81, e6′,ē89′,ē10′ is input into a 4-input AND gate circuit 82, ē6′,e7′,e8′,ē9′,ē11′ is input into a 5-input AND gate circuit 83, e6′,ē7′,e8′,ē9′ is input into a 4-input AND gate circuit 82, and e6′,ē7′,e8′,e11′ is input into a 4-input AND gate circuit 82 respectively. Signals output from the respective AND gate circuits are input into a 5-input OR gate circuit 84, so that the value ê8 of the first bit of the first byte of information is obtained.


As shown in FIGS. 16 and 17, the values ê9, . . . and ê15 of other bits are obtained similarly by the NOT gate circuit 80, the 3-input AND gate circuit 81, the 4-input AND gate circuit 82, the 5-input AND gate circuit 83, the 5-input OR gate circuit 84, and 6-input OR gate circuit 85.


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 FIG. 18.


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′e11custom charactere7′e8′e9′e10custom charactere7′e8′e9′e11custom charactere7′e8′e9′e10custom charactere6′e8′e9′e10custom charactere6′e7′e9′e10′e11custom charactere6′e7′e8′e10′e11custom charactere6′e7′e8′e10′e11custom charactere6′e7′e9′e10′e11custom charactere6′e7′e8′e10′e11custom charactere6′e7′e8′e10′e11custom charactere6′e7′e8′e10′e11custom charactere6′e7′e8′e10′e11custom charactere6′e7′e8′e10′e11  [Expression 54]


Therefore, as shown in FIG. 18, first, the bit-error pointers 40 e′6, e′7, e′8, e′9, e′10, e′11 over GF(26) are input into the NOT gate circuit 80, so that ēx′ is generated.


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 FIG. 19.


As shown in FIG. 19, 12 bits input information is sorted, a 2-input and 2-output circuit which is constructed by a pair of the 2-input OR gate circuit 75 and the 2-input AND gate circuit 76, is treated as a cell, and the cell is connected in multi-tiered manner for 12 inputs. The sorting circuit is a circuit that generally outputs 1 to upper x-bit of n-bit when the number of 1 is x bits present in n-bit inputs, and outputs 0 from all the residual outputs. The general constitution of this circuit is described in Non-Patent Document 13.


As shown in FIG. 19, the 12-input sorting circuit 73 which is a 12-input and 12-output circuit, uses 39 cells (namely, 78 gates) to be capable of being realized by maximally 9-tiered cells (9-gate tier). For example, as the input information of 12 bits, in the case of the information whose weight is 6 such as (001011001011), the output of the 12-input sorting circuit 73 is (111111000000).


A constitutional example of the miscorrection determining circuit 74 in i-th byte is shown in FIG. 20.


For example, a constitutional example of the miscorrection determining circuit 74 in 1 byte concretely constructed for the first byte, is shown in FIG. 20. As shown in FIG. 20, the miscorrection determining circuit 74 in 1 byte comprises bit-by-bit exclusive logical sum circuit 90, 16-input sorting circuit 91, and bit-by-bit selection circuit 96.


The process of the miscorrection determining circuit 74 in 1 byte is explained in more detail. As shown in FIG. 20, the bit-error pointers of bytes produced by decoder other than the first byte (ê) 71 ê0 . . . ê7ê16 . . . ê95 and the byte-by-byte sum of errors (eA) 38 are input into the bit-by-bit exclusive logical sum circuit 90. Further, the bit-error pointer of the first byte (ê) 71 ê8 . . . ê15 produced by the decoder, and the byte-by-byte sum of errors (eA) 38 are input into the bit-by-bit exclusive logical sum circuit 90.


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.

wM(ê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, exx 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 FIG. 21. As shown in FIG. 21, the bit-by-bit exclusive logical sum circuit 90 is a circuit that obtains exclusive logical sum of bits of two signals having 8 bits.


The process of the bit-by-bit exclusive logical sum circuit 90 is explained in more detail below. As shown in FIG. 21, 0-th bits of the 8-bit signals are input into multi-input exclusive logical sum circuits 97. The respective signals output from the multi-input parity check circuits 97 are collected to be output as 8-bit signal finally.


A constitutional example of the 16-input sorting circuit 91 is shown in FIG. 23. As shown in FIG. 23, the 16-input sorting circuit 91 sorts 16 bits input information, a 2-input and 2-output circuit which is constructed by a pair of the 2-input OR gate circuit 75 and the 2-input AND gate circuit 76, is treated as a cell, and the cell is connected in multi-tiered manner for 16 inputs. The sorting circuit is a circuit that generally outputs 1 to upper x-bit of n-bit when the number of 1 is x bits present in n-bit inputs, and outputs 0 from all the residual outputs.


As shown in FIG. 23, the 16-input sorting circuit 91 which is a 16-input and 16-output circuit uses the 63 cells (namely, 126 gates) and can be realized by maximally 10-tiered cells (10-gate tiers).


Finally, a concrete constitutional example of the bit-by-bit selection circuit 96 is explained.


As shown in FIG. 22, the bit-by-bit selection circuit 96 is a circuit that selects each bits of two signals having 8 bits according to the control signal (namely, the output of the 3-input AND gate circuit 95).


The process of the bit-by-bit selection circuit 96 is explained in more detail. As shown in FIG. 22, 0-th bits of the 8 bits signals are input into 2-input multiplexer 98. When the control signal is 0, the 2-input multiplexer 98 outputs an upper signal, and when the control signal is 1, the 2-input multiplexer 98 outputs a lower signal. Similarly, signals of bits other than 0-th bit are selected according to the control signal. The respective signals output from the 2-input multiplexer 98 are collected and output as the 8-bit signal finally.


The above explains the [41/8EC]2 code having code parameters such as b=8, t=1, μ12=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.


(f) Constitution of the Inverting Circuit 10


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 FIG. 24. The inverting circuit 10 shown in FIG. 24 is a circuit that inverts the received bit value on the bit position where an error location is concretely indicated to correct the received word (V′) 32. In FIG. 24, v8′ to v15′ are 8 bits corresponding to the first byte of the received word (V′) 32, and v8* to v15* are the output bits after correction.


The inverting circuit 10 comprises a plurality of exclusive logical sum circuits. In the inverting circuit 10 in the first byte shown in FIG. 24, eight exclusive logical sum circuits 99 in total, obtain exclusive logical sum of corresponding bit error pointers ei (i=8, 9, . . . , 15) for the 8 bits input v8′ to v15′, and for example, when the bit error pointer is “1”, the value of the input bit is inverted and corrected.


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, μ12=4, p1=p2=2 shown in FIG. 3. In the parallel decoding circuit 8 over GF(2r), for example, when the sequential decoding that uses the Berlekamp-Massey method is carried out, the existing methods which obtain error position and error according to error locator polynomial expression and error evaluation polynomial expression, may be used. The means for realizing the methods may be hardware or software.


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 └(μ12)/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.


INDUSTRIAL APPLICABILITY

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.


THE LIST OF REFERENCES



  • Patent Document 1:

  • Japanese Patent Application Laid-Open No. 2004-7217

  • Patent Document 2:

  • Japanese Patent Application No. 2003-416978

  • Patent Document 3:

  • Japanese Patent Application No. 2004-239392

  • Patent Document 4:

  • Japanese Patent Application No. 2004-287810

  • Patent Document 5:

  • Japanese Patent Application Laid-Open No. 2002-374175

  • Non-patent Document 1:

  • “A General Class of Maximal Codes for Computer Applications” written by S. J. Hong and A M. Patel, IEEE Transactions on Computers, Vol. C-21, No. 12, pp. 1322-1331, 1972

  • Non-patent Document 2:

  • “Odd-Weight-Column b-Adjacent Error Correcting Codes” written by E. Fujiwara, Transactions of the IECE Japan, Vol. E61, No. 10, pp. 781-787, 1978

  • Non-patent Document 3:

  • “Single Byte Error correcting-Double Byte Error Detecting Codes for Memory Systems” written by S. Kaneda and E. Fujiwara, IEEE Transactions on Computers, Vol. C-31, No. 7, pp. 596-602, July

  • Non-patent Document 4:

  • “Fault-Tolerant Memory Design in the IBM Application System/400™” written by C. L. Chen and L. E. Grosbach, Proceedings of Annual International Symposium on Fault-Tolerant Computing, pp. 393-400, June 1991

  • Non-patent Document 5:

  • “A class of Odd-Weight-Column SEC-DED-SbED Codes for Memory System Applications” written by S. Kaneda, IEEE Transactions on Computers, Vol. C-33, No. 8, pp. 737-739, August 1984

  • Non-patent Document 6:

  • “Error Control Coding for Computer Systems” written by T. R. N. Rao and Eiji Fujiwara, Prentice-Hall, 1989

  • Non-patent Document 7:

  • “Single b-Bit Byte Error Correcting and Double Bit Error Detecting Codes for Memory Systems” written by E. Fujiwara and M. Hamada, IEICE Transactions on Fundamentals, Vol. E76-A, No. 9, pp. 1442-1448, September 1993

  • Non-patent Document 8:

  • “A Class of Error Control Codes for Byte Organized Memory Systems—SbEC-(Sb+S)ED Codes—” written by M. Hamada and E. Fujiwara, IEEE Transactions on Computers, Vol. 46, No. 1, pp. 105-109, January 1997

  • Non-patent Document 9:

  • “Random Double Bit Error Correcting—Single Byte Error Correcting (DEC-SbEC) Codes for Memory Systems” written by G. Umanesan and E. Fujiwara, IEICE Transactions on Fundamentals, Vol. E85-A, No. 1, pp. 273-276, January 2002

  • Non-patent Document 10:

  • “A Class of Codes for Correcting Single Spotty Byte Errors” written by G. Umanesan and E. Fujiwara, IEICE Transactions on Fundamentals, Vol. E86-A, No. 3, pp. 704-714, March 2003

  • Non-patent Document 11:

  • “One Constitution Method for Error Correcting Codes to be Easily Decoded” written by Hideki Imai and Hiroshi Fujiya, IEICE Transaction, 1979

  • Non-patent Document 12:

  • “Reed-Solomon Codes and Their Applications” written by S. B. Wicker and V. K. Bhargava, IEEE Press, 1994

  • Non-patent Document 13:

  • “The minimal Test Set for Multioutput Threshold Circuits Implemented as Sorting Networks” written by S. J. Piestrak, IEEE Transactions on Computers), Vol. 42, No. 6, pp. 700-712, June


Claims
  • 1. 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; anda 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,whereinsaid encoding means generates said transmission 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 comprisesa syndrome generating means for generating a syndrome of said received word based on said parity check matrix; andan error correction means for correcting and detecting said errors in said received word based on said syndrome generated by said syndrome generating means,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.
  • 2. An apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to claim 1, wherein 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 for correcting μ1 spotty-byte errors occurred in p1 bytes and detecting μ2 spotty-byte errors occurred in p2 bytes (lengthened [μ1t/bEC]p1−[μ2t/bED]p2 code),
  • 3. An apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to claim 1, wherein 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 for 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]p1−[μ2t/bED]p2−SbED code),
  • 4. An apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to claim 1, wherein 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 for 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]p1−[μ2t/bED]p2−SbED code),
  • 5. An apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to claim 1, wherein 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 for correcting μ1 spotty-byte errors occurred in p1 bytes and detecting μ2 spotty-byte errors occurred in p2 bytes ([μ1t/bEC]p1−[μ2t/bED]p2 code),
  • 6. An apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to any one of claims 2 or 3 or 4 or 5, wherein 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 in said received word by inverting bit value of said received word corresponding to error 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,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(2); andan inverting means.
  • 7. An apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to claim 6, wherein 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 on (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).
  • 8. An apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to claim 7, wherein said error correction means outputs a third uncorrectable error detection signal representing that an error exceeding correction capability is detectedby 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).
  • 9. An apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to claim 7, wherein 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 outputs a detection signal in i-th byte and 1 byte of a 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).
  • 10. An apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to claim 7, wherein 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 a 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 pointers (ê) 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).
  • 11. An apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to claim 9, wherein said error vector generating means over GF(2b) 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.
  • 12. An apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to claim 11, wherein said miscorrection determining means in i-th byte carries out said miscorrection determination by the following miscorrection determination expression, wM(êx+eA)≦μ1−wM(êx)where wM(e) is defined by
  • 13. An apparatus for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to claim 12, wherein with respect to said [μ1t/bEC]p1−[μ2t/bED]p2−SbED code and said lengthened [μ1t/bEC]p1−[μ2t/bED]p2−SbED code,said decoding means is constituted by thata syndrome other than SI is newly input into said H″ multiplication means, and when SI≠0 and said syndrome other than SI is 0, a detection signal is output,SI is newly input into said error vector generating means over GF(2b), said error vector generating means over GF(2b) checks whether the number of erroneous bytes is 1 in the error e′ over GF(2r) or not, and said multi-input sorting means checks whether Hamming weight of SI is larger than μ1t or not.
  • 14. 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; anda 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,wherein 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; andan 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.
  • 15. A method for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to claim 14, wherein 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 for correcting μ1 spotty-byte errors occurred in p1 bytes and detecting μ2 spotty-byte errors occurred in p2 bytes ([μ1t/bEC]p1−[μ2t/bED]p2 code),
  • 16. A method for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to claim 14, wherein 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 for correcting μ1 spotty-byte errors occurred in p1 bytes and detecting μ2 spotty-byte errors occurred in p2 bytes (lengthened [μ1t/bEC]p1−[μ2t/bED]p2 code),
  • 17. A method for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to claim 14, wherein 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 for 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]p1−[μ2t/bED]p2−SbED code),
  • 18. A method for correcting and detecting multiple spotty-byte errors within a byte occurred in a limited number of bytes according to claim 14, wherein 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 for 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]p1−[μ2t/bED]p2−SbED code),
Priority Claims (1)
Number Date Country Kind
2005-060818 Mar 2005 JP national
PCT Information
Filing Document Filing Date Country Kind 371c Date
PCT/JP2005/023545 12/16/2005 WO 00 11/14/2007
Publishing Document Publishing Date Country Kind
WO2006/095489 9/14/2006 WO A
Foreign Referenced Citations (5)
Number Date Country
2002-374175 Dec 2002 JP
2004-7217 Jan 2004 JP
2005-176244 Jun 2005 JP
2006-60465 Mar 2006 JP
2006-101429 Apr 2006 JP
Related Publications (1)
Number Date Country
20090106633 A1 Apr 2009 US