This application is based upon and claims the benefit of priority from the prior Japanese Patent Application No. 2010-231215, filed on Sep. 24, 2010, the entire contents of which are incorporated herein by reference.
The embodiment relates to a memory system.
As the memory capable of storing mass data for use, a variable resistance memory (ReRAM) and so forth, which can be easily formed in three dimensions, has received attention. Even though any types of cells are used, however, fragmentation of the cell state in several levels to put plural bits in a single cell is effective on achievement of mass storage. With this regard, examples can be found in a NADN-type flash memory.
If such the multi-level cells are used, however, the instability of setting the cell state makes failed write easily occur. Thus, it has a tradeoff with the increase in the number of levels. Therefore, the NADN-type flash memory cannot provide more than 8 or 16 levels and causes a complicated association between data and levels additionally.
A memory system according to the embodiment comprises a cell array including cell units having p or more physical quantity levels (p is a prime of 3 or more); a code generator unit operative to convert binary-represented input data to a write code represented by elements in Zp that is a residue field modulo p; and a code write unit operative to write the write code in the cell unit in accordance with the association of the elements in Zp to different physical quantity levels, wherein the input data is recorded in (p−1) cell units, the (p−1) cell units including no cell unit that applies the same physical quantity level for write in the case where the input data is 0 and for write in the case where only 1 bit is 1.
With reference to the drawings, memory systems according to the embodiments will now be described below.
[Overview of Embodiment]
A memory system attains an increased storage capacity density by achieving fine fabrications, and thinking physical phenomena for use in memory cells and formation of a cell array part in 3-dimensional structures. In addition, for the purpose of improving the storage capacity density after attainment of stable processing steps, the physical quantity of a memory cell is divided into plural levels to provide the memory cell with an ability of multi-level storage as effective means.
In the case of the fine-fabricated multi-level cell, as for data write, failed write may arise easily when data is written with fail in an adjacent level to the originally write-targeted level. As for data read, failed read may arise easily when data is read out with fail, from an adjacent level to the level used to store data in the memory cell, as the corresponding data. As for data hold, a state transition may arise easily between adjacent levels.
Thus, multi-leveling of memory cells impairs the stability of the state and suffers considerable restrictions. If the problem on multi-leveling of memory cells can be overcome for effective use, stable process steps for memory systems can be utilized for longer terms to achieve a higher-density storage capacity.
Therefore, the memory system according to the present embodiment is equipped with an ECC (Error Correcting Code) system using a Lee metric code.
The ECC system using the Lee metric code applies the total number of errors to correct data and accordingly it can correct a large number of cells if errors arise with small level variations. With this regard, it is effective on the error between adjacent levels as described above. On the other hand, as for errors with large level variations, it is possible to correct errors if they fall within the total number of errors. Accordingly, this system can treat wider error distributions.
When 1 cell is used to store multi-levels, each level can be grasped as a height from the base level. Accordingly, it is originally desired to digitize information by a finite integer, particularly, a prime, rather than digitize information in binary. Therefore, the present embodiment uses a Lee metric code in a residue field Zp modulo a prime p used as the element (hereinafter simply referred to as “Zp”).
In this case, data is generally treated in binary outside the memory system and accordingly the conversion from binary to Zp is required. Therefore, for the purpose of realizing a memory system equipped with an efficient on-chip ECC system, the following description is given to the representation conversion from binary to Zp and a specific circuit for ECC using the Lee metric code. Note that the transistors contained in these converter circuits serve as switches and accordingly the representations and operations of data work on the basis of binary operations.
The input binary data and the p-adic code stored in the memory cell have no linear relation between them. Accordingly, the converter circuit can freely set the associated relation between the binary data and the p-adic code. Therefore, if the converter circuit is locked, it is difficult to conversely read the binary data from the p-adic code stored in the memory cell. With this regard, it is possible to enhance the security of the memory system.
The conventionally used memory cell stores data in binary as ‘1’ and ‘0’. Therefore, when a numeral in Zp, such as the Lee metric code, is treated directly, it is required to convert the numeral to a binary previously and then store each digit in the memory cell.
Therefore, with respect to the relation between the error-caused code word and the error quantity, the following description is given with reference to
As shown in
As C is stored as binary inside the memory system, the bit error caused in the memory cell changes the quantity as E depending on the error-caused position.
It is considered here that each numeral in Zp is represented in h-bit binary. The bit error similarly caused in any memory cell corresponds to the code error in the Lee metric code and has the quantity equal to E.
As the code word is represented in h-bit binary, the error quantity of 1-bit error at the position of 20 is equal to ±1 in the code word (1 or p−1 variations in Zp), and the error quantity of 1-bit error at the position of 2h−1 is equal to ±2h−1 (mod p). Thus, the weight on the code error differs from one another depending on the position of the memory cell. Therefore, in order to treat the patterns of bit errors on all memory cells, it is required to respond to all error quantities on the code word.
If the code word is converted into binary and stored in the memory system as above, any types of the configuration of the memory cell in the memory system are allowed. As described above, however, the ECC using the Lee metric code cannot correct errors unless the total error quantity, Σej (j=1−n), is lower than a certain value. In a word, depending on the position of the error-caused memory cell, error correction may not be achieved. With this regard, in the case of the storage in the memory cell in binary, all memory cells cannot be dealt equally.
Thus, it is not appropriate to store binary data in the memory cell as in the conventional case if the Lee metric code is used. Therefore, in the present embodiment, the so-called multi-level memory cell, in which the state of the memory cell, that is, the threshold of a transistor, or the resistance of a resistance element, is divided into plural levels, is used for storage in accordance with direct association of a numeral in Zp to each level. Thus, the above-described problem can be eliminated. Hereinafter, the multi-level memory cell capable of directly storing the numerals in Zp, such as the Lee metric code, may also be referred to as the “p-adic cell”. In addition, the memory system using the p-adic cells may also be referred to as the “p-adic” memory system.
The following description is given with reference to
Hereinafter, an environment outside the p-adic memory system, for example, an IT instrument that handles data in binary is referred to as a “binary world”. In contrast, containing a part that handles data in binary such as operational processing, an environment inside the p-adic memory system that handles data in Zp is referred to as a “p-adic Zp world”. In this case, the “binary world” can be referred to as a “p-adic Z2 world”.
The memory system according to the present embodiment comprises, as interfaces between the “binary world” and the “p-adic Zp world”, a “binary to p-adic” conversion operating circuit operative to convert binary data to Zp data, and a “p-adic to binary” conversion operating circuit operative to convert Zp data to binary data.
The data in the “binary world” (outside) is fed to the “p-adic Zp world” (memory system) via the “binary to p-adic” conversion operating circuit. Inside the memory system, the data is stored in the p-adic cell as it is in the form of the numeral in Zp. When data is recorded as the numeral in Zp in this way, the ECC processing using the Lee metric code can be made easier. The Zp data error-processed by ECC is provided to the “binary world” via the “p-adic to binary” conversion operating circuit.
Thus, the memory system comprises the “binary to p-adic” conversion operating circuit and the “p-adic to binary” conversion operating circuit, and accordingly the p-adic memory system can be handled in the “binary world” without having consciousness about the “p-adic Zp world”.
[Conversion from Binary Data to Zp Data]
Next, as the premise prior to the description of specific circuitry of the “binary to p-adic” conversion operating circuit, the principle of conversion from binary data to Zp data is described.
If Zp=GF(p) is used (“GF” means a Galois field, and “GF(p)” indicates a collection of residues resulted from integers divided by a prime p), p cannot be represented by a power of 2 as a matter of fact. Accordingly, different from the case where GF(2n) is used, it is not possible to use all bit patterns of data directly as the code. Therefore, conversions are required to represent all bit patterns of data, one to one, with elements in Zp.
The elements in Zp can be represented by integers of 0 to p−1 and all these integers can be represented by an h-bit binary each. The bit patterns of h bits are not used all in this case, and accordingly the binary h-bit data cannot be dealt directly as the element in Zp.
In a word, as shown in
On the other hand, as shown in
The following consideration is given to the conversion in which the data D corresponds, one to one, to the code C. This corresponds to the conversion from a 2h-adic number to a p-adic number. The conversion condition is studied to limit several ones of the conditions on selecting the prime p.
As the 1st condition, the condition on treating the binary data D as a δ-digit, 2h-adic number is described.
The number of bits in the batch-processed binary data D is given M=δh. In this case, D includes δ sets of h bits. When these sets are each considered to represent each digit of the 2h-adic number, D can be regarded as the δ-digit, 2h-adic number.
In a word, all bit patterns of M-bit data D can be considered as a representation of such the δ-digit number. This representation is converted to the elements in Zp to form a Lee metric code. Namely, the δ-digit, 2h-adic number is converted to a p-adic number such that the numeral on each digit of the p-adic number is contained in the data of Zp.
Therefore, an optimal p for this conversion is studied.
As the invariable in the conversion from the 2h-adic number to the p-adic number, a δ-digit, 2h-adic integer D(h) composed of M bits and represented by h bits per digit is used. In a word, D(h) can be represented as in Expression 1.
D(h)=d0(2h)0+d1(2h)1+ . . . +dδ−3(2h)δ−3+dδ−2(2h)δ−2+dδ−1(2h)δ−10<dδ−1<2h, 0≦dj<2h [Expression 1]
In Expression 1, d0, d1, . . . , dδ−3, dδ−2, dδ−1 are contained in data represented by collections of h bits.
When the maximum and minimum numbers of numerals represented in the form of D(h) are converted to p-adic numbers, a certain p is found, which allows the indication of the numeral on each digit to be represented in h-bit binary. The condition at that time is that the increase in the number of digits on conversion of the 2h-adic number to the p-adic number is limited to 1 digit at the maximum. In other words, the number of digits after the conversion to the p-adic number is limited to (δ+1) digits at the maximum.
In addition, D(h) can be represented as in Expression 2 with a binary, a0, a1, . . . , aδ−2, aδ−1, aδ, represented by collections of h bits.
D(h)=a0(p)0+a1(p)1+ . . . +aδ−2(p)δ−2+aδ−1(p)δ−1+aδ(p)δaδ+aδ−1≠0, 0≦aj<p [Expression 2]
A relation between δ and h is sought, which can configure the format of D(h) universally. Namely, the minimum number Dmin (h) and the maximum number Dmax (h) of D(h) capable of providing a δ-digit representation at the minimum by selecting h are given as in Expression 3.
Dmin(h)=(2h)δ−1∵dδ−1=1, di=0
Dmax(h)=(2h)δ−1∵dδ−1=di=2h−1 [Expression 3]
Therefore, the minimum number Dmin (h) minus 1 consists of (δ−1) digits and accordingly loses the format of D(h). Then, when a consideration is given to the maximum number Dmax (h−1) composed of collections of (h−1) bits, that is, a 2h−1-adic number, it does not lower below 6 digits as the representation of D(h), if Dmin(h)−1≧Dmax(h−1).
Namely, the condition on δ and h, under which D(h) cannot establish other than a δ-digit, 2h-adic representation, has a relation as in Expression 4.
δ≧h∵(2h)δ−1−1≧(2h−1)δ−1 [Expression 4]
A condition is described as the second condition, under which data D can be treated with a (δ+1)-digit, p-adic representation as shown in Expression 5.
Dmax(h)(mod pδ)≠Dmax(h)(mod pδ+1)=Dmax(h)(mod pδ+2)= . . . ∴(p)δ≦(2h)δ−1<(p)δ+1 [Expression 5]
As can be found from Expression 5, all are integers, and accordingly the condition under which data D can be treated with the (δ+1)-digit, p-adic representation is as in Expression 6.
(p)δ<(2h)δ^(2h)δ≦(p)δ+1 [Expression 6]
Namely, it can be represented as in Expression 7.
(2h)δ/(δ+1)≦p<2h [Expression 7]
Further, as δ/(δ+1)=(1−1/δ)/(1−(1/δ)2)>1−1/δ>1−1/h (h≦δ) and p is a prime, the condition on selecting the prime p is as in Expression 8.
2h−1<p<2h [Expression 8]
In this connection, the minimum value pδ−1 of the δ-digit, p-adic number at this time establishes the following.
pδ−1<(2h)δ−1=Dmin(h) [Expression 9]
Accordingly, data D after the p-adic number conversion cannot consist of (δ−1) digits.
Thus, if the prime p can be selected under the condition shown in Expression 8, the increase in the number of digits on conversion from the 2h-adic number to the p-adic number can be suppressed to 1 at the maximum.
The following description is given to the principle of conversion from a δ-digit, 2h-adic number D=(d0, d2, . . . , dδ−1) in the “binary world” to a (δ+1)-digit, p-adic number D=(a0, a1, . . . , aδ−1, aδ) in the “p-adic Zp world”, which are equivalent as data.
At the start, paying attention to an h-bit binary, it is treated as a numeral A. The numeral A is as in Expression 10.
A=d020+d120+d121+ . . . +dh−32h−3+dh−22h−2+dh−12h−1 [Expression 10]
In addition, the condition on selecting the h-bit prime p is as in Expression 8.
A replacement of dh−1=1 establishes a relation as in Expression 11 because 2h−1≦A<2h.
2h−1−2h=−2h−1<A−p<2h−2h−1=2h−1 [Expression 11]
If 0≦A−p in Expression 11, the coefficient on 2h−1 in the residue becomes 0 and accordingly the residue comes to an (h−1)-bit numeral in Zp.
A replacement of dh−1=0 brings A to the numeral in Zp itself because A<p. Therefore, A−p<0 yields A−p≦−1, and further (2A+1)−2p≦−1.
In a word, the h-bit binary contains only a single p at most under the condition on selecting the prime p shown in Expression 8. Even after the numeral in Zp, such as the residue, is doubled and given an addition of 1, it contains only a single p at most. Therefore, repeating the subtraction of p from an (h+1)-bit binary and counting the number of possible subtractions of p makes it possible to directly obtain a binary representation of the number of pieces of p contained.
The binary A can be represented by an equation E1 (=C020+C121+ . . . +Ch−12h−1+Ch2h+ . . . +Cj−h2j−h+Cj−h+12j−h+1+ . . . +Cj−12j−1+Cj2j) in
At the start, as shown with S1 in
Subsequently, as shown with S2 in
Thereafter, the computation similar to S2 in
Through a series of these computations, the total number of the primes p can be obtained as Ck+1j−h+12j−h+1, Ck+1j−h2j−h, . . . in turn from the top of the powers of 2. Note that the top of the numbers of primes p becomes 2j−h+1 having an index lower by h−1 than the original top 2j in the equation E1. In a word, when the coefficients of the h-bit, p-adic number are obtained, a binary representation of the total number of primes p cannot consist of j digits but reduces to j−(h−1) digits. When the finally-obtained coefficient Ck+10 on p20 is derived, the resultant residue (R00+R012+ . . . +R0h−22h−2+R0h−12h−1)20 indicates the numeral in Zp and becomes the coefficient on a digit having a weight of p0 in the p-adic number.
Further, when the binary representation, Ck+1m, of the number of pieces of p obtained through the above computation steps is used as new data and the computation steps similar to those in
Thereafter, the similar computation steps can be repeated to obtain the coefficients on the digits in the p-adic number in turn.
In a word, a circuit operative to numerate the number of primes p contained in binary data can be configured with a ladder of circuits operative to derive the residues from (h+1)-bit binary data divided by the prime p as can be found.
A square shown with “h res” in
At the start, at the 0-th step (S0 in
Subsequently, (h+1)-bit binary data, of which No. 1 to h−1 bits are the outputs from the previous “h res” circuit block (the residue represented by h bits) and No. 0 bit (the least significant bit) is the most significant bit Dδ−2h−1 (=Dh(δ−2)−1) of dδ−2, is input to the next “h res” circuit block, which generates the residue and a quotient or carry C1h(δ−1)−1 derived from the input binary data divided by the prime p.
Thereafter, until No. 0 bit of (h+1)-bit binary data input to the “h res” circuit block reaches the least significant bit D00 (=D0) of d0, (h(δ−1)+1) “h res” circuit blocks are used to generate carries C10-C1h(δ−1). Binary data expressed by these generated carries C10-C1h(δ−1) indicates the number of the primes p contained in the data D.
The output from the “h res” circuit block having the input of d0 has a binary representation a0 of a (δ+1)-digit, p-adic number D (a0, a1, . . . , aδ−1, aδ).
Subsequently, at the 1st step (S1 in
At the 1st step, numeration of the prime p is executed to the carries C10-C1h(δ−1) from C1h(δ−1) on the rightmost side. At the time of the numeration of the prime p executed to the carries C1h(δ−2)+1-C1h(δ−1), the flow directly generates the residue and a carry C2h(δ−2)+1 by substituting 0 for the most significant bit of (h+1)-bit input binary data and dividing the input binary data by the prime p.
Subsequently, (h+1)-bit binary data, of which No. 1 to h−1 bits are the outputs from the previous “h res” circuit block (the residue represented by h bits) and No. 0 bit (the least significant bit) is C1h(δ−2), is input to the next “h res” circuit block, which generates the residue and a quotient or carry C2h(δ−2) derived from the input binary data divided by the prime p.
Thereafter, until No. 0 bit of (h+1)-bit binary data input to the “h res” circuit block reaches the least significant bit C10 of C10-C1h(δ−1), (h(δ−2)+1) “h res” circuit blocks are used to generate carries C20-C2h(δ−2)+1. Binary data expressed by these generated carries C20-C2h(δ−2)+1 indicates the number of pieces of the prime p2 contained in the data D.
The output from the “h res” circuit block having the input C10 becomes a binary a1 of a (δ+1)-digit, p-adic number D (a0, a1, . . . , aδ−1, aδ).
At the subsequent 2nd step (S2 in
Thereafter, the flow advances up to the (δ−1)-th step (Sδ−1 in
The carries Cδ+10-Cδ+1δ−h at the step Sδ−1 are not used in computation.
Next, the “h res” circuit block shown in
The “h+1 bit mod p” circuit block provides the residue Q modulo the prime p of the input binary A, and provides ‘1’ from PF0 if the input binary A is equal to or more than p and ‘0’ from PF0 if it is lower than p.
In the case of h=7, p=79, relations shown in Expression 12 can establish among the binary A, the binary Q and the prime p.
a=A0+A12+A222+A323+A424+A525+A626+A727
Q≡a(mod p) (a=Q+PF0×p)
Q=Q0+Q12+Q222+Q323+Q424+Q525+Q626 [Expression 12]
The “h+1 bit mod p” circuit block comprises a PF0 generator unit U1, 5 half adders HA1-HA5, and 2 full adders FA1, FA2.
The PF0 generator unit U1 includes serially connected PMOS transistors QP1-QP4 and NMOS transistors QN1-QN5 between the Vcc terminal supplied with a certain voltage and the Vss terminal supplied with the ground voltage. These transistors QP1, QP2, QP3, QP4, QN1, QN2, QN3, QN4 and QN5 are controlled by A0, A4, A5, A7, A0, A1, A2, A3 and A6, respectively.
The PF0 generator unit U1 also includes 5 PMOS transistors QP5-QP9, 3 NMOS transistors QN6-QN8, and an inverter IV1.
The transistors QP5-QP8 are connected between the source and drain of the transistor QP1. The transistor QP9 is connected between the source of the transistor QP1 and the drain of the transistor QP3. The transistors QP5, QP6, QP7, QP8 and QP9 are controlled by A1, A2, A3, A4 and A6, respectively.
The transistors QN6, QN7 are connected between the source of the transistor QN1 and the drain of the transistor QN4. The transistor QN8 is connected between the source of the transistor QN1 and the drain of the transistor QN5 (Vss terminal). The transistors QN6, QN7 and QN8 are controlled by A4, A5 and A7, respectively.
The inverter IV1 has an input connected to a node between the transistors QP4 and QN1. The output from the inverter IV1 provides the carry PF0.
The half adder HA1 has inputs A0 and PF0, an output Q0, and a carry output C0. The half adder HA2 has inputs C0 and A1, an output Q1, and a carry output C1. The half adder HA3 has inputs C1 and A2, an output Q2, and a carry output C2. The half adder HA4 has inputs C2 and A3, an output Q3, and a carry output C3. The full adder FA1 has inputs C3 and A4, a carry input PF0, an output Q4, and a carry output C4. The full adder FA2 has inputs C4 and A5, a carry input PF0, an output Q5, and a carry output C5. The half adder HA5 has inputs C5 and A6, and an output Q6.
In accordance with the above configuration, the PF0 generator unit U1 decides if the binary A input to the “h+1 bit mod p” circuit block is equal to or more than p=79, and provides the result from PF0. If the binary A is equal to or more than p=79, the half adders HA111-HA115 and the full adders FA111-FA112 are used to add 49, a complement of the 8-bit binary 79, to the binary A in order to subtract 79 from the binary A.
The following description is given to the full adder FA and the half adder HA serving as the basic unit for binary addition used in the “h+1 bit mod p” circuit block.
The full adder FA has inputs A, B, a carry input Cin, an output Sout, and a carry output Cout as shown in
The full adder FA includes an XOR (exclusive logical sum) circuit, an XNOR (exclusive not logical sum) circuit, an output circuit U1, and a carry output circuit U2 as shown in
The XOR circuit includes PNOS transistors QP1 and QP2 serially connected between the inputs A and B, and NMOS transistors QN1 and QN2 serially connected between a node n1 of the transistors QP1 and QP2 and the Vss terminal. Among those, the gates of the transistors QP2 and QN1 are connected to the input A. The gates of the transistors QP1 and QN2 are connected to the input B. This configuration leads the node n1 to the output of the XOR circuit.
The XNOR circuit includes NMOS transistors QN3 and QN4 serially connected between the inputs A and B, and PMOS transistors QP3 and QP4 serially connected between a node n2 of the transistors QN3 and QN4 and the Vcc terminal. Among those, the gates of the transistors QN4 and QP3 are connected to the input A. The gates of the transistors QN3 and QP4 are connected to the input B. This configuration leads the node n2 to the output of the XNOR circuit.
The output circuit U1 includes a PMOS transistor QP5 connected between the carry input Cin and the output Sout, and a similarly-connected NMOS transistor QN5, an NMOS transistor QN6 connected between the node n2 and the output Sout, and a PMOS transistor QP6 connected between the node n1 and the output Sout. Among those, the gate of the transistor QP5 is connected to the node n1, that is, the output of the XOR circuit. The gate of the transistor QN5 is connected to the node n2, that is, the output of the XNOR circuit. The gates of the transistors QN6 and QP6 are connected to the carry output Cin. The output circuit U1 also includes an NMOS transistor QN7 between the node n1 and the Vss terminal. The gate of the transistor QN7 is connected to the node n2, that is, the output of the XNOR circuit.
The carry output circuit U2 includes a PMOS transistor QP7 connected between the carry input Cin and the carry output Cout, a similarly-connected NMOS transistor QN8, a PMOS transistor QP8 connected between the input B and the carry output Cout, and a similarly-connected NMOS transistor QN9. Among those, the gates of the transistors QP7 and QN9 are connected to the node n2, that is, the output of the XNOR circuit. The gates of the transistors QN8 and QP8 are connected to the node n1, that is, the output of the XOR circuit. The carry output circuit U2 also includes an NMOS transistor QN10 connected between the Vss terminal and the node n2. The gate of the transistor QN10 is connected to the node n1, that is, the output of the XOR circuit via an inverter.
With the above configuration, the full adder FA executes logical operations on the inputs A and B at the XOR circuit and the XNOR circuit, and feeds the operation result and the carry input Cin to the output circuit U1 and the carry output circuit U2 to create the output Sout and the carry output Cout.
The half adder HA has inputs A, B, an output Sout, and a carry output Cout as shown in
The half adder HA can be configured with general logical gates and inverters as shown in
A consideration is given next to the configuration of the “binary to p-adic” converter unit using an “h+1 bit mod p” circuit block.
Here, the j-th digit is denoted with dj when data is subject to a δ-digit, 2h-adic expression. In this case, dj can be indicated in h-bit binary. For the purpose of representing the coefficient D as the indication of a binary number, though, sub-indexes are used as shown in Expression 13.
dj=Dj0+Dj12+Dj222+ . . . +Djh−32h−3+Djh−22h−2+Djh−12h−1
dj(2h)j=Dhj2hj+Dhj+12hj+1+ . . . +Dh(j+1)−22h(j+1)−2+Dh(j+1)−12h(j+1)−1 [Expression 13]
The input to the operation at the k-th step, that is, the carry at the previous step (the (k−1)-th step) is Ck0-Ckh(δ−k)+k−1, the coefficients of a binary number which sub-index is the powers of 2, and the numeral expressed by this binary indicates the number of pieces of pk contained in the data.
At the k-th step, the input includes h(δ−k)+k pieces of binaries (carries Ck0-Ckh(δ−k)+k−1) as shown in
The 1st “h+1 bit mod p” circuit block <1> receives Ckh(δ−k)+k−h to Ckh(δ−k)+k−1 and 0 on the input binary A0-Ah−1, Ah, and provides Rh(δ−(k+1))+k0 to Rh(δ−(k+1))+kh−1 and Ck+1h(δ−(k+1))+k from the outputs Q0-Qh−1 and the carry PF0, respectively.
The 2nd “h+1 bit mod p” circuit block <2>, not shown, receives the outputs Rh(δ−(k+1))+k0 to Rh(δ−(k+1))+k0 and a carry Ckh(δ−(k+1))+k−1 from the 1st “h+1 bit mod p” circuit block <1> on the input binary A1-Ah and A0, and provides Rh(δ−(k+1))+k0 to Rh(δ−(k+1))+k−1h−1 and Ck+1h(δ−(k+1))+k−1 from the outputs Q0-Qh−1 and the carry PF0, respectively.
Thereafter, as shown in
Thus, the conversion of binary to p-adic number is executed sequentially from the most significant bit of the carry C as in the schematic diagram shown in
A circuit including h(δ−1)+δ+1 pieces of “h+1 bit mod p” circuit blocks thus configured is referred to as the “X to p” circuit block.
As shown in
The following description is given to the core part of the “binary to p-adic” conversion operating circuit, that is, the p-adic” circuit block.
The “p-adic” circuit block receives B0-Bδ+1, I0-Ihδ+δ−1, and provides r0-rhδ+δ−1 as shown in
Specifically, the inputs I0-Ihδ+δ−1 are fed via the control switches SW1 to the “X to p” circuit block as C00-C0hδ+δ−1, respectively. These δ groups of control switches SW1 are controlled by the inputs /B1-/B6 (‘/’ indicates “not”), respectively.
One control switch SW1 includes a transfer transistor TQ operative to connect the input IN with the output OUT, and an NMOS transistor QN operative to pull down the output OUT to the ground voltage. The transfer transistor TQ turns on if the control signal is CNT=‘0’ while the transistor QN turns on if the control signal is CNT=‘1’.
In the case of the control switches SW1, the control signals CNT include /B1-/Bδ. Therefore, I0-Ihδ+δ−1 are provided directly as C00-C0hδ+δ−1 if B=‘1’, and the output turns to ‘0’ independent of the input if B=‘0’. This is effective to prevent the input to the “X to p” circuit block from becoming infinite even if the inputs I0-Ihδ+δ−1 to the “p-adic” circuit block are infinite.
The “X to p” circuit block on receipt of C00-C0hδ+δ−1 provides R00-Rhδh−1, C10-C1hδ+δ−1 as described above.
The outputs C10-C1hδ+δ−h from the “X to p” circuit block pass through the control switches SW2 and turn to rh-rh(δ+1)+δ−h, that is, the outputs from the “p-adic” circuit block. These control switches SW2 are controlled by the inputs /B1-/Bδ. Therefore, these control switches SW2 directly pass C10-C1hδ+δ−h as rh-rh(δ+1)+δ−h if B=‘0’.
The outputs R00-Rhδh−1 from the “X to p” circuit block pass through the control switches SW3 and turn to r0-rh(δ+1)−1, that is, the outputs from the “p-adic” circuit block. These control switches SW3 are controlled by B0□/B1 to B10□/Bδ+1, respectively. Therefore, the control switches SW3 located between R00 and r0, for example, directly provide R00 as r0 only if B0=‘1’ and B1=‘0’.
B1-Bδ+1 for use in control of the control switches SW are timing signals, which are signals that rise sequentially. In sync with this, the paths for the inputs I close at every h bits from the lower bit side and the paths for the outputs r switch to the paths for the outputs R.
In order to provide the result at the present step until the flow enters the computation process at the next step, R corresponding to a coefficient A on each digit of a p-adic number is provided to the later-described external “D-r” register via the control switches SW3 on/off-controlled by the signals resulted from the logical operation with the adjacent timing signals B.
The following description is given to the “binary to p-adic” conversion operating circuit including the above-described circuits grouped together.
The “D-r” register is a register controlled by the timing signal B and the clock clk as shown in
The “D-r” register includes a flip-flop FF composed of 2 inverters at every bit. The flip-flop FF receives Dj (j=0 to hδ−1) via the control switch SW1 and receives rj via the control switch SW2. On the other hand, the flip-flop FF is connected to an inverter IV1 on the output side via the control switch SW3. The output from the inverter IV1 provides Ij.
The control switches SW1-SW3 are controlled by the timing signal B0 and the clock clk. Specifically, the control switch SW1 turns on if /clk□/B0=‘1’, the control switch SW2 if /clk□B0=‘1’, and the control switch SW3 if clk=‘1’, respectively.
Dhδ-Dhδ+δ−1 not contained in the data input to the “D-r” register are held at ‘0’.
In the initial state of the “D-r” register, a binary D0-Dhδ−1 is set, and the rest is filled with ‘0’. Thereafter, when B0 rises, data rj is taken in sync with the fall of clk, and the taken rj is provided as Ij in sync with the rise of clk.
The “D-r” register couples with the “p-adic” circuit block to advance the computation step at every timing signal Bj. The state of variations in each clock is shown in
At each computation step, each digit Aj of a p-adic number is obtained as the output r from the lower side, and this is held at the same timing as that for taking Ij in the second half of the timing signal Bj.
After completion of all the computation steps, the “D-r” register holds the coefficients Ajm on respective digits when the coefficients a on respective digits of p-adic data D are converted to binaries.
Although various cases are compared with each other later, in the system using an actual prime p, the number of computation steps is equal to or below 10, and the number of the “h+1 bit mod p” circuit blocks contained in the “p-adic” circuit block is equal to or below 50.
[Conversion from Zp Data to Binary Data]
A specific circuit is shown below for the conversion from a (δ+1)-digit, p-adic number D=(a0, a1, . . . , aδ−1, aδ) in the “p-adic Zp world” to a δ-digit, 2h-adic number D=(d0, d2, . . . , dδ−1) in the “binary world”, which are equivalent as data.
The conversion from a p-adic number to a 2-adic number can be executed by the operation of numerating the number of primes p contained in the p-adic number and summing up the binary representations of the prime p by the number of the primes. The operation executes the conversion to the binary while lowering the degree one by one from the largest degree in the p-adic number, and uses the fact that the binary finally becomes a 2-adic number of the same number at the zero-degree of the prime p. Therefore, (h+1) bits are obtained through the computation at every h bits, then the least significant bit is separated therefrom, and the computation at the next degree of the power of 2 is executed. Such the computation process is repeated to complete processing.
If the number of pieces of pn+1 contained in the data is represented in binary as C020+C121+ . . . +Cj−12j−1+Cj2j+Cj+12j+1 . . . , the number of pn in the data D can be represented as in the equation E1 (=pn(A020+A121+ . . . +Ah−12h−1)+pn+1(C020+C121+ . . . +Cj−12j−1+Cj2j+Cj+12j+1 . . . )) in
At the start, as shown with S1 in
Subsequently, as shown with S2 in
Thereafter, all the binary representations, pnCkj2j, of the number of pieces of pn are obtained similar to S2 in
At the next step, the binary representations of the number of pieces of pn-1 in the p-adic number are obtained similarly.
Thus, the computation process uses the fact that a prime p is selected such that the number derived from the h-bit binary plus the prime p reaches (h+1) bits or below.
A numeral A in h-bit binary can be represented as in Expression 14, and accordingly 0≦A<2h can establish.
A=a020+a121+ . . . +ah−32h−3+ah−22h−2+ah−12h−1 [Expression 14]
In addition, an h-bit prime p falls within 2h−1<p<2h. Therefore, a relation as in Expression 15 establishes.
2h−1<p+A<2h+1 [Expression 15]
Expression 15 means that even after a prime p is added to the h-bit binary, it can be represented in (h+1)-bit binary or below, under the condition on selecting the prime p shown in Expression 8.
Therefore, the “p-adic to binary” conversion operating circuit operative to convert data from a p-adic number to a binary can be composed of a ladder of h-bit input, (h+1)-bit output adder circuits as can be found.
A square shown with “h+p” in
At the start, at the 0-th step (S0 in
Subsequently, at the 1st step (S1 in
Thereafter, the same steps as the 0-th step and the 1st step are repeated and, at the (δ−1)-th step, the above-described computation is executed to a binary representation of the digit at the 0-th degree in the p-adic representation using a carry Cδ−10-Cδ−1hδ−1 obtained at the previous (δ−2)-th step as a binary representation of the number of p, thereby obtaining h (δ+1) bits of a carry Cδ0-Cδh(δ+1)−1 as the number of pieces of p0, that is, a binary representation of D. In this case, the upper h bits are held at zero in accordance with the setting of the p-adic number and the 2h-adic number associated with D. When Cδhδ-Cδh(δ+1)−1 are excluded from the carries Cδ0-Cδh(δ+1)−1 and the remaining Cδ0-Cδhδ−1 are grouped at every h bits, a binary representation of D, that is, D (d0, d1, . . . , dδ−1) can be obtained.
The following specific description is given to the “h+p” circuit block shown in
The “h+1 bit add p” circuit block in the case of h=7, p=79 is considered. In this case, the relation shown in Expression 16 can establish among the binaries b and Q and the prime p.
b=B0+B12+B222+B323+B424+B525+B626
Q=b+carry×p
Q=Q0+Q12+Q222+Q323+Q424+Q525+Q626+Q727 [Expression 16]
The “h+1 bit add p” circuit block includes 3 half adders HA1-HA3 and 4 full adders FA1-FA4.
The half adder HA1 has inputs Bo and carry, an output Q0, and a carry output C0. The full adder FA1 has inputs B1 and carry, a carry input C0, an output Q1, and a carry output C1.
The full adder FA2 has inputs B2 and carry, a carry input C1, an output Q2, and a carry output C2. The full adder FA3 has inputs B3 and carry, a carry input C2, an output Q3, and a carry output C3. The half adder HA2 has an input B4, a carry input C3, an output Q4, and a carry output C4. The half adder HA3 has an input B5, a carry input C4, an output Q5, and a carry output C5. The full adder FA4 has inputs B6 and carry, a carry input C5, an output Q6, and a carry output Q7.
In accordance with the above configuration, the “h+1 bit add p” circuit block adds p=79 to the input binary B if carry=‘1’.
The circuitry of the full adder FA and the half adder HA is similar to that in
A consideration is given next to the configuration of the “p-adic to binary” conversion operating circuit using the above-described “h+1 bit add p” circuit block.
It is possible to binary-represent data, a coefficient aj on the digit at the j-th degree in a (δ+1)-digit, p-adic representation. For the purpose of distinguishing the coefficient A of this binary representation from coefficients a on other digits, sub-indexes as shown in Expression 17 are used.
aj=Aj0+Aj12+Aj222+ . . . +Ajh−32h−3+Ajh−22h−2+Ajh−12h−1
aj(2h)j=Ahj2hj+Ahj+12hj+1+ . . . +Ah(j+1)−22h(j+1)−2+Ah(j+1)−12h(j+1)−1 [Expression 17]
The input to the operation at the k-th step, that is, the carry at the previous step (the (k−1)-th step) includes Ck0-Ckh(k+1)−1, the coefficients of a binary number which sub-index is the powers of 2. The number expressed by this binary indicates the number of pieces of pδ−k contained in the data.
At the k-th step, h(k+1) pieces of “h+1 bit add p” circuit blocks are used in processing as shown in
The 1st “h+1 bit add p” circuit block <1> receives Ck0, Q−10-Q−1h−1 at the carry and the inputs B0-Bh−1, and provides Ck+10, Q00-Q0h−1 from Q0, Q1-Qh, respectively.
The 2nd “h+1 bit add p” circuit block <2>, not shown, receives Ck1, Q00-Q0h−1 at the carry and the inputs B0-Bh−1, and provides Ck+11, Q10-Q1h−1 from Q0, Q1-Qh respectively.
Thereafter, the “h+1 bit add p” circuit blocks having the similar inputs and outputs are aligned h(k+1) pieces in total as shown in
Thus, the conversion of a p-adic number to a binary is executed sequentially from the least significant bit of a carry C as in a schematic diagram shown in
The circuit including the h “h+1 bit add p” circuit blocks thus configured is referred to as an “a to X” circuit block.
As shown in
Next, the above-described “a to X” circuit blocks are used to configure a circuit for 1 step operative to lower the degree of the p-adic number by 1. Hereinafter, the circuit is referred to as the “p to X” circuit block. The “p to X” circuit block can be used in all the computation steps in common.
The “p to X” circuit block comprises δ “a to X” circuit blocks.
The 1st “a to X” circuit block <1> receives part of the inputs to the “p to X” circuit block, that is, Q−10-Q−1h−1, and Cδ−10-Cδ−1h−1, and provides Q′h−10-Q′h−1h−1 and part of the outputs from the “p to X” circuit block, that is, Cδ0-Cδh−1.
The 2nd “a to X” circuit block <2> receives Qh−10-Qh−1h−1 and part of the inputs to the “p to X” circuit block, that is, Cδ−1h-Cδ−1h2-1, and provides Q′h2-10-Q′h2-1h−1 and part of the outputs from the “p to X” circuit block, that is, Cδh-Cδh2-1. Among the inputs, Qh−10-Qh−1h−1 are signals fed via the control switches SW1, through which the outputs Q′h−10-Q′h−1h−1 from the 1st “a to X” circuit block <1> are controlled by the timing signal Bδ−1.
The 3rd “a to X” circuit block <3> receives Qh2-10-Qh2-1h−1 and part of the inputs to the “p to X” circuit block, that is, Cδ−1h2-Cδ−1h3-1, and provides Q′h3-10-Q′h3-1h−1 and part of the outputs from the “p to X” circuit block, that is, Cδh2-Cδh3-1. Among the inputs, Qh2-10-Qh2-1h−1 are signals fed via the control switches SW2, through which the outputs Q′h2-10-Q′h2-1h−1 from the 2nd “a to X” circuit block are controlled by the timing signal Bδ−2.
Thereafter, similar connections will be made up to the δ-th “a to X” circuit block <δ>.
The inputs and outputs of the “a to X” circuit block are connected via the control switches SW in this way, because the connection of the input is switched between the external input and the internal input at every computation step, and for the purpose of preventing the output from the internal circuit from interfering in the case of the external input.
In the case of the circuitry of
Subsequently, when the timing signal B1 also turns to ‘1’, the (δ−1)-th “a to X” circuit block <δ−1> is activated additionally. This corresponds to the 1st step.
Thereafter, at every sequential rise of the timing signals B2-Bδ−1, the “a to X” circuit block required at each step is activated.
The following description is given to the core part of the 2h-adic converter circuit, that is, the “binary” circuit block.
As shown in
Specifically, the inputs Ih-Ih(δ+1)−1 are fed as Cδ−10-Cδ−1hδ−1 to the “p to X” circuit block via the control switches SW1. These δ pieces of control switches SW1 are controlled by the timing signals B1-Bδ−1. Therefore, the control switches SW1 pass Ih-Ih(δ+1)−1 directly as Cδ−10-Cδ−1hδ−1 if B=‘1’ and keep the outputs at ‘0’ independent of the inputs if B=‘0’.
In addition, the input I0-Ihδ−1 are fed as Q−10-Qh(δ−1)−1h−1 to the “p to X” circuit block via the control switches SW2, respectively. These δ pieces of control switches SW2 are controlled in accordance with Bδ□Bδ−1 to B1□B0, respectively. Therefore, the control switch SW2 located between I0 and Q−10 passes I0 directly as Q−10 only if Bδ=‘1’, Bδ−1=‘0’.
The outputs Cδ0-Cδh(δ+1)−1 from the “p to X” circuit block turn to r0-rh(δ+1)−1, that is, the outputs from the “binary” circuit block via the control switches SW3. These control switches SW3 are controlled by the timing signals Bδ−1-B0. Therefore, the control switches SW3 pass Cδ0-Cδh(δ+1)−1 directly as r0-rh(δ+1)−1 if B=‘1’.
In accordance with the above circuitry, the “p to X” circuit block responds to each computation step while increasing the bit widths of the input and output h-bit by h-bit sequentially. While taking the numerals A on the digits of the p-adic number from the upper digit sequentially at each computation step, and when all the computation steps are completed, a binary representation of data can be obtained.
As described earlier, the timing signals B0-Bδ are the signals that rise in order. In accordance therewith, the paths to the inputs I and outputs r conduct h-bit by h-bit from the upper bit.
The numeral A on each digit of the p-adic number is initially set in the later-described external “A-r” register, and fed to the “A-r” register via the control switch SW3 on/off-controlled by the signal logically operated with the adjacent timing signal B, such that the path switches selectively, until the flow enters the next computation step.
The following description is given to the “p-adic to binary” conversion operating circuit including the above-described circuits grouped together.
The “A-r” register is a register controlled by the timing signal B0 and the clock clk and having the inputs r0-rh(δ+1)−1, A0-Ah(δ+1)−1 and the outputs I0-Ih(δ+1)−1 as shown in
The “A-r” register includes, at every bit, a flip-flop FF composed of 2 inverters. The flip-flop FF receives Aj (j=0 to h(δ+1)−1) via the control switch SW1 and receives rj via the control switch SW2. On the other hand, the output of the flip-flop FF is connected to an inverter IV1 via the control switch SW3. The output from the inverter IV1 provides Ij.
The control switches SW1-SW3 are controlled by the timing signal B0 and the clock clk. Specifically, the control switch SW1 turns on if /clk□/B0=‘1’, the control switch SW2 if /clk□B0=‘1, and the control switch SW3 if clk=‘1, respectively.
The initial state of the “A-r” register includes the digits A0-Ah(δ+1)−1 of the p-adic number.
Thereafter, after the timing signal B0 rises, rj taken in sync with the fall of the clock clk is provided as Ij in sync with the rise of the clock clk.
The “A-r” register couples with the “binary” circuit block to advance the computation step at every timing signal Bj. The state of variations in each clock is similar to
After completion of all the computation steps, the “A-r” register holds a binary representation Dj of the input, that is, the p-adic number A.
Although various cases are compared with each other later, in the system using an actual prime p, the number of computation steps is equal to or below 10, and the number of the “h+1 bit mod p” circuit blocks contained in the “binary” circuit block is equal to or below 50.
[Timing Signal Generator Circuit]
The following description is given to a timing signal generator circuit operative to generate clocks and so forth for use in time-division control of the “binary to p-adic” conversion operating circuit and the “p-adic to binary” conversion operating circuit.
First, the operational concept of the timing signal generator circuit is described.
The timing signal generator circuit is a circuit including later-described unit circuits sequentially connected to generate the steps required at the minimum in accordance with the number of the unit circuits.
The timing signal generator circuit uses the clock ck to shift the state of the unit circuit in the state of ‘1’ to generate the timing signal B at the boundary between the ‘1’ state and the ‘0’ state.
The clocks ck and /ck toggled at the rise of the clock clk are generated from the clock clk at a flip-flop circuit FF shown in
As shown in
Subsequently,
The timing signal generator circuit block comprises a timing signal generator unit U1 operative to generate timing signals B0-B2m+2 from the boundary signals b0-bm output from nodes n between unit circuits; a boundary signal generator unit U2 including unit circuits connected; and a shift direction generator unit U3 operative to generate signals R and L capable of determining the shift direction of the state of the unit circuit.
The timing signal generator unit U1 includes (m+1) OR gates G1 operative to receive L and bj (j=0−m) and provide Bj, and (m+1) NOR gates G2 operative to receive R and bj and provide Bk (k=2m+1 to m+1).
The boundary signal generator unit U2 comprises plural unit circuits as shown in
Each unit circuit U4 includes 2 cross-coupled inverters, and 6 NMOS transistors for transmitting the state of the unit circuit U4 to an adjacent unit circuit U4.
Specifically, the 1st unit circuit U4<1>, for example, includes cross-coupled inverters IV1 and IV2.
Among those, the inverter IV1 includes 3 NMOS transistors QN1-QN3 serially connected between the output node thereof and the Vss terminal. These transistors QN1, QN2, QN3 are controlled by ‘H’ (normally on), the signal R, and the clock ck, respectively.
On the other hand, the inverter IV2 includes 3 NMOS transistors QN4-QN6 serially connected between the output node thereof and the Vss terminal. These transistors QN4, QN5, QN6 are controlled by the output from an inverter IV3 in an adjacent unit circuit U4<2>, the signal L, and the clock ck, respectively.
The 2nd unit circuit U4<2> includes cross-coupled inverters IV3 and IV4.
Among those, the inverter IV3 includes 3 NMOS transistors QN7-QN9 serially connected between the output node thereof and the Vss terminal. These transistors QN7, QN8, QN9 are controlled by the output from the inverter IV2 in the adjacent unit circuit U4<1>, the signal L, and the clock /ck, respectively.
On the other hand, the inverter IV4 includes 3 NMOS transistors QNa-QNc serially connected between the output node thereof and the Vss terminal. These transistors QNa, QNb, QNc are controlled by the output from an inverter IV5 in an adjacent 3rd unit circuit U4<3>, the signal L, and the clock /ck, respectively.
The remaining configuration includes similar unit circuits to the 1st unit circuit U4<1> and the 2nd unit circuit U4<2> alternately connected.
With this configuration, the nodes n between the unit circuits U4 provide the boundary signals b0-bm. In addition, the output from the first inverter IV1 provides a signal F, and the last inverter IVa provides a signal C.
The shift direction generator unit U3 comprises a flip-flop circuit FF as shown in
The shift direction generator unit U3 generates the signals R and L capable of determining the shift direction of the state in accordance with the signals F and C from the node n0 and nm on the both sides of the boundary signal generator unit U2.
The above-described circuit is possible to configure the door that can come and go between the “binary world” and the “p-adic Zp world”.
[Overview of Lee Metric Code]
Next, data processing in the “p-adic Zp world” is described. Here, each digit in a code is referred as a “code word symbol”.
A code word symbol c is an integer shown in Expression 18.
cεGF(p)=Zp, 0≦c<p [Expression 18]
When Lee metrics of these integers are denoted with |c|, and all Lee metrics |c| are represented by integers of p/2 or below, the Lee metrics |c| can be defined as in Expression 19.
As the code C can be considered a row of n(=p−1) code word symbols c, it can be represented by C=(c1, c2, . . . , cn) as shown in
w(C)=|c1|+|c2|+ . . . +|cn| [Expression 20]
The distance between codes can be defined by the sum of Lee metrics of differences between the code word symbols corresponding to the code. Here, a difference between 2 codes C and Y (Lee distance), dL (C, Y), is given as Expression 21.
dL(C,Y)=w(C−Y) [Expression 21]
Further, the minimum Lee distance of the code C can be defined by the minimum metric of the metric w(C) of the code C as shown in Expression 22.
dL(C)=min w(C) [Expression 22]
In this case, the Lee metric code is such a code that has the minimum distance of 2γ between codes having a generator matrix G and a syndrome matrix H shown in Expression 23 and that can correct (γ−1) or lower Lee metric errors.
Here, when the number of symbols in the code C is denoted with n and the number of symbols in the data word D is denoted with k, then γ=n−k where γ represents the number of redundant symbols contained in the code C.
For the purpose of generating the Lee metric code thus configured, the input-converted data, that is, numerals on the digits in a k-digit, p-adic number are regarded as numerals in Zp, which are used as a data word X of the Lee metric code, thereby obtaining a code expression through an operation C=XG based on the generator matrix G. The obtained code word is stored in the memory. Information about the error caused on the stored numeral in Zp is used as a data word Y of the Lee metric code read out of the memory to obtain a syndrome through an operation S=YHt (Ht is a transpose of H) so that the position and quantity of the error can be computed to correct the error.
Next, for the purpose of indicating memory cells optimal to store the Lee metric code, the conditions on the relations between the quantities caused on the Lee metric code are collected.
The Lee metric code in Zp, which is δ-digit, 2h-adic data in the “binary world”, can be used to create a code from (δ+1) pieces of code data as in Expression 24 where the word length of the code is denoted with n, that is, C=(c1, c2, . . . , cn); the word length of data is denoted with k; and the maximum value of the error-correctable Lee metric is denoted with ε=γ−1.
n=p−1, dL(C)≧2γ, k=n−γ, k=κ+δ+1 [Expression 24]
Namely, k=δ+1 corresponds to the maximum word length of data in the Lee metric code.
The selection of the prime p is determined so as to provide δ+1=k, and further as k=n−γ=p−1−ε−1=p−ε−2, Expression 25 provides the condition satisfied by the prime p.
δ+ε+3=p [Expression 25]
The conditions on the prime p are grouped here. The condition on selecting M and p is shown in Expression 26 based on δh=M and Expression 25 where the total number of Lee metrics of correctable errors is denoted with ε, and the number of data bits ECC-processed in batch in the “binary world” is denoted with M.
2h−1<p<2h∩M=h(p−ε−3) [Expression 26]
In this case, the code in Zp has a redundant word length of γ=ε+1=n−k=n−(δ+1) from the data. Accordingly, the number of digits, δ, of data as a 2h-adic number in the “binary world” and the number of code words, n, in the “p-adic Zp world” establish a relation therebetween as in Expression 27.
n−δ=γ+1=ε+2 [Expression 27]
[p-adic Cell]
The following description is given to memory cells used to store each code cj in the Lee metric code C=(c1, c2, . . . , cn) in the “p-adic Zp world”.
If a memory cell can set plural physical quantity values per cell and the quantities physically form an ordered set, such the memory cell is referred to as a “p-adic cell”.
Available examples of the p-adic cell include a memory cell that uses plural thresholds of a MOS transistor as the physical quantities; a memory cell that uses plural resistances of a variable resistance element as the physical quantities; a memory cell that uses the numbers of held flux quanta as the physical quantities; and a memory cell that uses the quantities of trapped charge as the physical quantities. In a word, any memory cell is sufficient if it can hold a certain physical quantity as an element in a quantity-setting ordered set. Hereinafter, the order of the physical quantity is referred to as the “level”.
After the levels of such the memory cell are assigned to the elements in Zp, the memory cell is turned to the p-adic cell.
An example of assignment of Zp to the p-adic cell is shown in
a)-(f) shows examples in the case of the prime p=7, 11, 13, 17, 19, 23. The order of the physical quantity is divided into p pieces, and the resultant divisions are assigned to Zp.
A memory cell operates with fail as an error between order-closer levels with a high possibility. Accordingly, one with a closer Lee metric is assigned to one with a closer level order. This assignment makes the order of the levels as the physical quantities match the order of the representations of Zp inevitably. As the order of Zp is cyclic, there are p ways of assigning the order to a single memory cell. The example shown in
The variation in Lee metric due to the variation in level is detailed in the case of p=7 shown in
Note that the quantity of variation in Lee metric cannot become higher than (p−1)/2. As the order of Zp is cyclic, even if a failed operation with a large leap as shown with the dashed line as the arrow at dL=1 or 2 occurs, such a operation has a low possibility.
a)-(f) shows a typical level variation for each p as the quantity of variation in Lee metric in the case of ε=(p−1)/4 and in the case of ε′=(p−1)/3. The variation in Lee metric as a failed operation on the physical level has almost the same quantity for any prime p at ε and ε′. Therefore, a larger p given to the memory cell that uses the same physical quantity increases the code error and requires a larger error correctable quantity.
Next, a method of reading from the p-adic cell is described with reference to
In the definition of words, “divisionally serial-applying bias” refers to changing the bias in turn in accordance with the level of the memory cell.
ΔΣ modulation (Delta-Sigma Modulation) and so forth can be used to directly sense the physical quantity of the cell level as can be considered. In consideration of write and verify for memory cells, though, the bias given to the memory cell is divisionally serial-applied, and compared with the reference physical quantity Iref to sense which level of bias exceeds Iref. Such a sensing method is described here by way of example.
In the p-adic cell array, the p-adic cells used to store the codes aj of data A=(a1, a2, . . . , an) in Zp are accessed at the same time. As this access method, a conventional method using word lines WL and bit lines BL is assumed, and bias is applied to the p-adic cells arranged on cross-points of 1 word line WL and plural bit lines BL. This bias is a voltage, a current or another physical quantity, which is caused on the bit line BL as the physical quantity comparable with Iref using the sense amp unit t-SA.
The row decoder/word line driver (Row Dec./WL Driver) arranged at one end of the word line WL is used to select a word line WL and divisionally serial-apply bias required for read to the word line WL. The divisions of the bias at this time are in p stages.
The row decoder/word line driver in the code read unit is used at the time of code write as part of the code write unit to divisionally serial-apply bias required for code write to the selected word line WL. The divisions of the bias at this time are in (p−1) stages.
The sense amp unit t-SA is a circuit operative to compare Iref with the physical quantity Icell from the p-adic cell. The sense amp unit t-SA compares Icell with Iref at a sense amp sa, as shown in
The output from the sense amp unit t-SA provides ‘1’ as the signal L only when the contents of data in the latches L1 and L2 are different from each other. Namely, only when the serial cycle first reverses the relation of the orders between Iref and Icell while Icell varies in accordance with the order, the output L turns to ‘1’. The latches L1 and L2 are prepared to have the same initial value so that a correct sense output can be obtained at the first time of the change between Iref and Icell.
The “Zp→h dec” circuit block receives signals Δ0, Δ1, . . . , Δp−2, Δp−1 for use in control of the bias divisionally serial-applied and, in accordance with the inputs, activates h-bit selection lines SL0 to SLh−1 designative of selection registers. The outputs of the sense amp units t-SA corresponding to n p-adic cells selected at the same time by the word line WL are each selectively connected to h registers. The “Zp→h dec” circuit block associates the sense amp units t-SA to the registers through the selection lines SL0 to SLh−1 activated in accordance with the signals Δ0, Δ1, . . . , Δp−2, Δp−1.
The register resets the content, that is, turns it to ‘0’ on receipt of the signal RS and replaces the content by ‘1’ when the signal j and the signal L output from the sense amp unit t-SA both turn to ‘1’.
In the configuration as above, reading from the p-adic cell is as follows.
Before reading, the registers have an initial value of ‘0’.
It is assumed here that sensing is executed in turn from the level 0, and the output L from the sense amp unit t-SA turns to ‘1’ at the step of the level j. At the same time, the “Zp→h dec” circuit block receives an activated signal Δj at the step of the level j so that the “Zp→h dec” circuit block converts j into an h-bit binary to activate the corresponding selection line SL.
As a result, the signals L and j both turn to ‘1’ so that the content in the corresponding register can be rewritten to ‘1’.
Through the above operation, when all steps to the p-adic cell finish, the binary indication A of the elements in Zp stored in the p-adic cell is held in the registers. The A held in the registers are subject to operation processing in the “p-adic Zp world”.
The above description is given to the case where the representation of Zp uses 1 p-adic cell. If a memory cell has a lower number of levels than the selection-desired prime p, the use of p-adic cells in a pair can increase the number of levels. Hereinafter, such the p-adic cells used in a pair may also be referred to as “pair p-adic cells” (a cell unit).
A method of representing Zp with the pair p-adic cells is described.
If it is possible to set n levels in a single p-adic cell, the use of such p-adic cells in a pair makes it possible to set n2 levels. If the number of levels is associated with the prime p, the allowable prime is in the form of p=n2−2, n2−3, n2−5 and so forth under the condition that p is smaller than n2 and cannot be factorized.
A prime p is considered here, which can effectively utilize the most of the levels of the pair p-adic cells.
Subsequently, a consideration is given to the levels of the pair p-adic cells. As can be considered, there are various methods of setting the levels with the combinations of levels of each of the pair p-adic cells. In basic setting, when the level of any one of the pair p-adic cells varies by 1, the level of the pair p-adic cells also varies by 1.
From the viewpoint of error correction, the distance between levels is more important than the specific setting in the pair p-adic cells.
When the elements in Zp are represented by the ±number lines within a range of −(p−1)/2 to (p−1)/2 from the cardinal point of zero, Lee metrics are maximized at both ends seen from the center.
When the number line is regarded as a string, of which pattern varies at the center of the number line, it is considered how to extend the string to prevent Lee metrics from increasing.
For the purpose of preventing Lee metrics from increasing, both ends of the string may be arranged such that they come to the locations with as large level distance as possible, that is, the corners of the matrix shown in FIG. 37, and the variation points on the pattern of the string come to the central part as near as possible.
In this case, it is desired to fold the string as shown in
The above-described assignment of Zp is set such that the level distance from the central level in the matrix matches the Lee metric. Next, the effect by the match with the level distance from other level distances is observed.
The following description is given to an example of the assignment to the prime p.
In the case of a single p-adic cell having the number of levels equal to 3, 4, 5, 6, 7, 8, 9, 10, specific examples of the assignment of the primes p=7, 13, 23, 31, 47, 61, 79, 97 are shown in
As shown in
In the matrix tables shown in
The following description is given to an example of the method of reading from the pair p-adic cells.
The method of reading from the pair p-adic cells is basically similar to the method of reading from a single p-adic cell described with reference to
When the individual single p-adic cells contained in the pair p-adic cells are viewed, they are set to different levels, which are read at the same time accordingly. Therefore, the word lines WL to be selected at the same time are provided with a p-adic cell array <1> including memory cells <1> and a p-adic cell <2> including memory cells <2> as the cell arrays that configure the pair p-adic cells. It is not required to physically distinguish these p-adic cell arrays <1> and <2> from each other and it is sufficient to distinguish them in accordance with the logical concept determined by the assignment of addresses according to the configuration of the cell array at least. As the bias given to the cell array, Δ0-Δl-1 is divisionally serial-applied in the similar manner to
In each p-adic cell array, p-adic cells used to store the codes aj of Zp data A=(a1, a2, . . . , an) are accessed at the same time.
The outputs from the sense amp units t-SA corresponding to n p-adic cells in each p-adic cell array selected by the word line WL at the same time are each connected to one register selectively.
The selective connections between the registers and the outputs of the sense amp units t-SA are controlled by a single signal δ0, δ1, . . . , δl-2, δl-1 that turns to ‘1’ in response to the application timing of the divisionally serial-applied bias, different from the case of
The registers are previously initialized to ‘0’ by the signal RS similar to the case of
A comparison of the performance by the number of levels of the p-adic cell and the pair p-adic cells is made next.
At the start, with respect to the use of a single p-adic cell, the specific examples shown in
L: The number of levels of the p-adic cell.
p: A prime to be used.
h: A minimum number of bits required for binary representation of Zp.
ε: A minimum integer larger than (p−1)/4, which indicates an overall quantity of Lee metrics of error-correctable errors.
ε′: A minimum integer larger than (p−1)/3, which indicates an overall quantity of Lee metrics of error-correctable errors.
Here, ε and ε′ are set on the assumption that the quantity of a failed operation on the physical quantity forming the level of the p-adic cell is almost constant independent of the number of setting levels of the p-adic cell.
M: A value determined by M=h (p−ε−3), which is the quantity of binary data in the “binary world” subject to batch processing by ECC.
M′: A value determined by M=h(p−ε′−3), which is the quantity of binary data in the “binary world” subject to batch processing by ECC.
δ: The number of digits of M as a 2h-adic number.
δ′: The number of digits of M′ as a 2h-adic number.
p−1: The number of p-adic cells required for storing the code word of the Lee metric code.
log2L: The number of bits that can be stored in a p-adic cell when the p-adic cell is made as a binary storing multi-level cell.
M/log2L: The number of memory cells when data M is stored in the “binary world” to a multi-level cell having the same number of levels as the p-adic cell.
The M/log2L is computed under the condition that ECC is not provided.
M′/log2L: The number of memory cells when data M′ is stored in the “binary world” to a multi-level cell having the same number of levels as the p-adic cell.
The M′/log2L is computed under the condition that ECC is not provided.
Redundancy: A ratio between the number of cells when data M is stored with ECC to a p-adic cell in the “p-adic Zp world” and the number of cells when the same data M is stored without ECC to the same p-adic cell used as a multi-level cell in the “binary world”.
Redundancy′: A ratio between the number of cells when data M′ is stored with ECC to a p-adic cell in the “p-adic Zp world” and the number of cells when the same data M′ is stored without ECC to the same p-adic cell used as a multi-level cell in the “binary world”.
ε/(p−1): A proportion of the maximum number of correctable cells when c is used.
ε′/(p−1): A proportion of the maximum number of correctable cells when ε′ is used.
It is considered here that the number of levels is actually equal to 20 at most and the redundancy is equal to 2 or below from the viewpoint of the cost merit if ECC is included. Thus, the columns dotted in
Subsequently, with respect to the pair p-adic cells, the specific examples shown in
L: The number of levels of a single memory cell contained in the pair p-adic cells.
L2-p: The number of extra levels when the levels of the pair p-adic cells are assigned with Zp, which is the number of levels redundantly assigned with ‘0’ in Zp in the specific examples shown in
2 (p−1): The number of p-adic cells required for storing the code word of the Lee metric code.
The number is doubled compared with the table shown in
The ε and ε′ shown in
By the way, on the assumption that the pair p-adic cells are used if the number of levels of the memory cell cannot be made excessively larger, an actual L is assumed equal to or below 10. Therefore, the prime p becomes equal to or below 100. If it is further considered that the redundancy is equal to 2 or below from the viewpoint of the cost merit, the columns dotted in
[Procedure of Data/Code Processing in p-adic Memory System]
Next, with respect to ECC operation in the “p-adic Zp world”, the conversion procedure at the entrance of the “p-adic Zp world”, the procedure of encoding the code input to the memory system as Zp data, the procedure of decoding the code read out of the memory system, and the conversion procedure at the exit of the “p-adic Zp world” are grouped.
It is assumed here that the Zp-determining prime p, the minimum number h of bits required for binary representation of p, the number δ of digits of batch-processed data as a 2h-adic number in the “binary” world, and the total quantity, ε=γ−1, of Lee metrics of correctable errors are previously determined. In addition, it is assumed in the following description that n and k are n=p−1 and k=n−γ, respectively.
The conversion procedure at the entrance of the “p-adic Zp world” is as follows.
(Procedure 0) First, pieces of binary data fed from external to the memory system are grouped at every h bits, and converted to a 2h-adic expressed δ-digit data word D(h) shown in Expression 28 (S1 in
D(h)=(d0,d1, . . . , dδ−1) [Expression 28]
Subsequently, the data word D(h) shown in Expression 28 is converted further to a p-adic expressed (δ+1)-digit data word D(h) shown in Expression 29 (S2 in
D(h)=(a0,a1, . . . ,aδ) [Expression 29]
The procedure of encoding the code input to the memory system as Zp data is as follows.
(Procedure 1) First, the elements a0-aδ in Zp obtained through Procedure 0 are given zeros to obtain k elements a0-ak−1 of data D shown in Expression 30.
D(h)=(a0,a1, . . . ,ak−1) [Expression 30]
Subsequently, this data D is multiplied by a generator matrix G to obtain n code word components c1-Cn of a code C (S3 in
Finally, the code word components c3 are stored in memory cells (S4 in
The procedure of decoding the code read out of the memory system is roughly divided to 7 procedures as follows. Hereinafter, the procedure numbers are serial numbers containing the procedure of encoding. Note that Procedures 2 and 3 shown below are repeated over the elements (m=0 to p−2) in Zp.
(Procedure 2) A code Y read out of memory cells is read out (S5 in
Y=(y1,y2, . . . ,yn)
Y=C+E, E=(e1,e2, . . . ,en) [Expression 32]
Subsequently, the values yj (j=1 to n) of n code word symbols contained in the code Y are multiplied by jm to compute jmyj as numerals in Zp. The symbol value yj can be sought from the level in the case of the multi-level memory cell. In the case of a general binary memory, it is a numeral obtained from binary data. The code Y is multiplied by a transpose of a syndrome matrix H to obtain a syndrome series mS(=YHT) composed of syndromes Sm to Sm+ε as shown in Expression 33 (S6 in
(Procedure 3) First, with regard to the upper limit ε (=γ−1) of the number of correctable symbols, η=ε and u=ηSm−1 are computed to obtain uSm to uSm+ε from the syndrome S1 obtained through Procedure 2. Subsequently, coefficients ψj of a solution searching polynomial Ψ(x) shown in Expression 34 are computed in turn from uSm to uSm+ε (S7 in
Here, if the degree of the coefficient Ψ(x) is η, that is, ψε≠0, then the flow goes to Procedure 5 to obtain a solution. On the other hand, if ψε=0, the flow terminates processing as no solution. Otherwise, in order to further search the possibility of correction, η=ε−1 is replaced to repeat Procedure 2. If the degree of Ψ(x) is η, that is, ψη+1≠0 and ψη≠0, then the flow goes to Procedure 4 to obtain a solution. On the other hand, if ψη=0, the flow terminates processing as no solution. If the flow cannot execute processing in Procedure 3, it halts the error correction as no solution because the error distribution is not supportable.
(Procedure 4) If it is found that no solution can be obtained as a result of ψε≠0 in Procedure 3, a solution is obtained in Procedures 4, 5. First, in Procedure 4, in order to obtain the multiplicity of the solution, a Hasse differential polynomial [Ψ(x)][i] shown in Expression 35 is sought. The coefficients ψj obtained through Procedure 3 are multiplied by a series of binomial coefficients to obtain coefficients of the Hasse differential polynomial (S9 in
(Procedure 5) The elements 1 to p−1 in Zp are substituted into the resultant Hasse differential polynomial to seek all the elements r that can bring the O-order differential polynomial (=Ψ(x)) into zero. Subsequently, as shown in Expression 36, such the degree n is sought that brings the (n−1)-th order differential polynomial into zero over each r and the n-th order differential polynomial into non-zero (S10 in
The obtained r is an inverse element of the position of the code word symbol in the error-caused code, and the corresponding n is the quantity converted from the caused error quantity.
(Procedure 6) In Procedure 6, the error quantity is sought through a conversion from the multiplicity n of the solution. The position of the error-caused code word symbol is t=r−1, and the reverse conversion of the conversion performed to obtain the polynomial for obtaining a solution is applied to n. As there is a relation of utmet=n, the original error quantity et can be derived from n as et=(utm)−1n. The error quantity et is subtracted from the symbol value yt of the code Y read out of memory cells to obtain the symbol value ct of the corrected code C(S11 in
Up to now, as the correct code C stored in the memory system is obtained, the binary data input to the memory system is sought through Procedures 7 and 8.
(Procedure 7) The code C error-corrected through Procedure 6 and the generator matrix G are applied to seek k elements a0 to ak−1 in GF(p) and X (=a0, a1, . . . , ak−1) through a system of linear equations XG=C. Thus, (δ+1) pieces of elements a0 to aδ in Zp can be obtained. The obtained elements, a0 to aδ, are used to create (δ+1)-digit, p-adic expressed data word D(h) (S12 in
(Procedure 8) Finally, the data word D(h) is converted to a δ-digit, 2h-adic expression to express a numeral on each digit in binary. Thus, the restoration of binary data fed to the memory system is completed (S13 in
The following description is given to the principle of the method used in the procedure of data processing in the “p-adic Zp world”. This principle is derived from the improvement in the conventional method and referred to as a “syndrome converting method”.
The components of the code C held in the memory system are the numerals in Zp and they cause variations on receipt of various disturbances at every component and make a change to the code Y consisting of different components as shown in Expression 37.
Y=(yi), yi=ci+ei [Expression 37]
The operation to restore C from Y is decoding. Prior to decoding, a syndrome is derived.
When a certain m is selected from Zp, a syndrome mS is determined as mS=(Sm+l) (l=0 to γ−1). Then S0 is obtained from m=0 and, if |S0|≦γ−1, decoding is started. The syndrome mS has elements, Sm+0, Sm+l, . . . , Sm+γl, which are determined through a matrix operation as in Expression 38 using the H matrix.
Here, Ht is a transpose of H. The G matrix and the H matrix are configured to satisfy GHt=0 (mod p). Accordingly, a replacement of Y=C+E to the components of E is allowed to represent S. If m=0 and E=(e0, e1, . . . , en), then S0=Σej. Thus, S0 corresponds to the total sum of errors in the symbols. If |S0|≦γ−1, errors can be found through the following syndrome converting method. It is also possible to obtain the value of an error on the code component according to the computation even if the condition cannot be satisfied. It is though not possible to determine whether it is the error on a true code or the error on adjacent code. Thus, it cannot be used in error correction. This depends on the fact that the Lee metric between codes has a minimum value of 2γ.
If it can be utilized reliably in error correction, the metrics of error components ei of the code word are all converted in batch next. When the product of fixed elements in a finite field and all elements is obtained, all elements in the finite field can be obtained. This fact is utilized to obtain u as in uSm≡η for the previously determined element η and m that satisfies |Sm|≠0. When the error-containing code Y stored in the memory cell array is multiplexed by u to seek a syndrome, the components derived from mS multiplexed by u, that is, uSm, uSm+1, . . . , uSm+γ+l can be obtained as syndrome components, which are represented by uS. In a word, uS can be represented as in Expression 39.
uS=(uSm,uSm+1, . . . ,uSm+γ+1) [Expression 39]
Note that the total sum uSm of the converted errors after conversion becomes n. In accordance with the total sum, the error component ej can be regarded as in u(j)mej as can be found. These syndromes are only information on errors and can be used to restore the correct code based thereon.
Subsequently, the principle of decoding is described on the assumption that the error is previously known.
The code stored in the memory cell array contains the error E=(e1, e2, . . . , en) (n=p−1). Accordingly, a virtual error on the new syndrome includes {u(1)me1, u(2)me2, . . . , u(n)men}. These n (=p−1) error components are converted and classified into 2 sets J+ and J− as in Expression 40.
J+={jε(1,2, . . . ,n); u(j)mej<p/2}
J−={jε(1,2, . . . ,n); u(j)mej>p/2} [Expression 40]
Namely, it is classified into J+, which is an arrangement of the positions j of the code word symbols cj, if the error quantity of the error code word symbol is u(j)mej<p/2, and into J−, which is an arrangement of the positions j of the code word symbols cj, if the error quantity of the error code word symbol is u(j)mej>p/2. Polynomials Λ(x), V(x) on GF(p) are configured on the basis of these sets as in Expression 41.
Thus, the polynomial Λ(x) is such a polynomial that has a reciprocal number of the error component position j in J+ as a root, and that has a Lee metric u (j)mej of that error component as the multiplicity of the root. On the other hand, the polynomial V(x) is such a polynomial that has a reciprocal number of the error component position j in J− as a root, and that has a Lee metric p−u(j)mej of that error component as the multiplicity of the root. Decoding is a process of finally configuring these polynomials only from the information on the syndromes to solve them, thereby obtaining information on errors. In a word, it is required to seek a relation between these polynomials Λ(x), V(x) and the syndromes. When it is configured with a series polynomial having each syndrome uS on a coefficient of the corresponding degree, it is represented with a rational polynomial having the position of the error composition and the value of the virtual error composition in factors thereof as in Expression 42.
From Expression 42, a relational equation shown in Expression 43 can be established among the polynomials Λ(x), V(x) and the syndrome S(x).
Subsequently, the relational equation shown in Expression 43 is used to seek the polynomials Λ(x), V(x) from the syndrome S(x).
From the syndrome S(x), a polynomial Ψ(x) with a degree of γ−1 or lower shown in Expression 44 is sought.
In an expansion of the polynomial Ψ(x), a coefficient ψj can be sought from a comparison between coefficients of the homogeneous degree on both sides of the expression shown in Expression 44 through an iterative method using the syndrome Si and an already-determined coefficient ψj−1. Coefficients ψ0-ψγ-1 of the polynomial Ψ(x) are sought from syndromes uS1 to uSm+γ-1. The results are shown in Expression 45.
The polynomial Ψ(x) is a polynomial equivalent to Λ(x)/V(x). In this case, the key conditions on prime polynomials λ(x) and ν(x) are given as in Expression 46. Therefore, an appropriate selection of η establishes V(x)=1 such that Ψ(x) can be applied as Λ(x) itself.
v(x)Ψ(x)≡λ(x)(mod xγ)
deg λ(x)−deg v(x)=uSm=η(mod p)
deg λ(x)+deg v(x)<γ [Expression 46]
The condition, deg λ(x)−deg ν(x)=η and deg λ(x)+deg ν(x)≦γ−1, on the degree of the polynomial results in 0≦2 deg ν(x)≦γ−1−η, which establishes deg ν(x)=0 if 0≦γ−1-η≦1 as can be found. Namely, if γ−1≧η≧γ−2, then V(x)=1 and Λ(x)=Ψ(x) can establish so that Ψ(x) can satisfy this condition. In this case, η previously determined by Ψ(x) derived from the syndrome, and η=deg Ψ(x)=deg Λ(x) should establish. If they can establish, all key conditions can be satisfied and accordingly Ψ(x) can be used to obtain a solution. On the other hand, if they cannot establish, no error satisfies the key conditions, resulting in no solution.
This method corresponds to conversions applied to errors, which collect the positions of all error code components into the set J+. Another viewpoint indicates the presence of the possibility of error correction if conversions are executed such that the total sum of the converted errors becomes equal to or lower than γ−1 and higher than γ−2.
The possibility referred above has two meanings. The first is associated with the requirement in which the positions of all error code components are collected in J+, and the degree of Ψ(x) derived from the syndrome is just equal to n. The second is associated with the requirement in which the error quantity can be obtained according to the computation even though |S0|≦γ−1 is not satisfied. This condition is added, though, to exclude failed corrections.
As shown in the next example, this method is applicable to obtain a solution for any error on 1 code word component. This method is also applicable to obtain a solution for any errors on 2 code word components using the syndrome cyclically, as can be found.
In solution searching, a replacement of Λ(x)=Ψ(x) and V(x)=1 is used to search a solution that satisfies the equation from the elements in Zp and, based on the obtained root and multiplicity, an inverse conversion is applied to obtain a true error E.
The following consideration is given to what types of errors can be searched, for the number of roots, that is, the number of components of the error-caused code word, through the syndrome converting method of converting the metrics of errors to seek a solution searching polynomial.
The first study is given to the case where 1 root is obtained from the solution searching polynomial.
When the root is denoted with j−1, the component position in the error code E=(0, ej, . . . , 0) (n=p−1) is j and the error quantity is ej. When they are multiplied by an appropriate u(j)m for conversion such that these are lowered below p/2 each and grouped in J+={j; u(j)mej<p/2}, it is possible to configure a polynomial Ψ(x) shown in Expression 47.
uSm=u(j)mej→Ψ(x)=(1−jx)u(j)
From Expression 47, independent of the quantity of errors, u(j)mej=η can establish always and fall within J+. Therefore, it is possible to obtain the value of the error on 1 code word completely. In this case, however, the minimum distance between code words is 2γ. Accordingly, the true code word cannot be specified if |ej| is equal to or higher than γ, and the error quantities of various errors are obtained in accordance with the selection of m. The error quantities correspond to the code words, respectively, and one of them is the error on the true code word, as in the so-called list correction.
The next study is given to the case where 2 roots are obtained from the solution searching polynomial.
When the roots are denoted with i−1 and j−1, the component positions in the error code E=(0, . . . , ei, . . . , ej, . . . , 0) (n=p−1) are i and j and the error quantities are ei and ej. When they are multiplied by an appropriate u(j)m for conversion such that these are lowered below p/2 each and grouped in J+={i, j; uU(i)mej, u(j)mej<p/2}, it is possible to configure a polynomial Ψ(x) shown in Expression 48. Accordingly, the error quantities can be obtained from the polynomial Ψ(x).
uSm=u(i)mei+u(j)mej→Ψ(x)=(1−ix)u(i)
If the error codes are multiplied by an appropriate u (j)m for conversion such that these are lowered below p/2 each and grouped in J+, it is required for ei and ej to have a certain relation therebetween. This can be satisfied if both are equal. If equal, the conversion by u(j)m can bring any error quantity to η. Therefore, it is possible to obtain the values of the errors on 2 code word components completely.
It is the Lee metric code, however, that has the minimum distance of 2γ between code words. Accordingly, the true code word cannot be specified if |ei|+|ej| is equal to or higher than γ, and the error quantities of various errors are obtained in accordance with the selection of m. The error quantities correspond to the code words, respectively, and one of them is the error on the true code word. By the way, if the distance between 2 errors satisfies a certain condition, an appropriate conversion can be applied to group both in J+. Accordingly, it is not the requirement that both are equal.
The following description is given to a converting method of equalizing 2 code errors.
2 error codes are denoted with i, j and the error quantities are denoted with ei, ei, respectively. In this case, a syndrome is represented by S0=ei+ej. Further, the syndrome is turned to Sm=imei+jmej as can be found from the syndrome computation. In a word, the selection of an appropriate m results in imei≡jmej.
The use of the primitive root and index expression of Zp here to provide ei=α(ei), ej=α(ej), i=α(i), j=α(j) can establish m(i)+(ei)≡m(j)+(ej). Therefore, m can be obtained through m≡−{(ej)−(ei)}/{(j)−(i)}.
Thus, a series of syndromes (Sm, Sm+1, . . . , Sm+γ-1) can be used to obtain the coefficient u that satisfies uSm=η.
As m is not known initially, however, a converting method as below is used to deal various errors on 2 code word symbols. First, m is scanned from 0 to p−2, and the coefficient u for m is computed through u=ηSm−1, thereby obtaining (uSm, uSm+1, . . . , uSm+γ-1). Subsequently, these (uSm, uSm+1, . . . , uSm+γ-1) are used to configure a polynomial Ψ(x). Finally, such m is extracted from the configured polynomial Ψ(x) that satisfies deg Ψ(X)=η. When Ψ(x) is configured at the time of m thus extracted so as to satisfy deg Ψ(x)=η, the Ψ(x) at the time of that m is used to seek the root and multiplicity.
Thus, the method capable of seeking any errors can be obtained if the number of roots in the solution searching polynomial is equal to 2 or below, that is, equal to or below the number of errors in 2 code word components. The next consideration is given to how it is in the case of 3 or more roots.
The condition of obtaining a solution in the case of 3 or more roots is that the error quantities of all roots are converted so as to belong to J+={j; {j (1, 2, . . . , n); u(j)mej<p/2}. At this time, Ψ(x) is configured as a η-th order polynomial shown in Expression 49.
The conversion operable in such the manner for any error quantity exists in the case of 2 roots or below while it is difficult to configure it as a simple conversion in the case of 3 or more roots. Therefore, if errors occur on 2 code word components or below, as the method capable of treating any errors, the above-described conversion in the case of 2 roots and the method of solution searching are used as they are. For the purpose of increasing the error distribution of error components in the case of 3 or more roots grouped in J+, the same method is applied repeatedly to another candidate of η, that is, γ−2=ε−1 as new scanning.
Namely, the flow changes η, min turn from 0 to p−2 over each η of ε and ε−1 to provide u≡ηSm−1, as (uSm, uSm+1, . . . , uSm+ε)→Ψ(x). If deg Ψ(x)=η, then a solution can be obtained from Λ(x)=Ψ(x). This is solved to finish solution searching. If deg Ψ(x)≠η, the error distribution cannot be solved, and the flow terminates as no solution.
This key to solution includes keys to solution for 2 roots and 1 root and can compute any errors caused in random on code word components in the case of 2 roots or below. As for errors on code word components in the case of 3 roots or above, it is possible to correct ε (=γ−1) code word components at the maximum in a special case such as a narrow distribution of error quantities. In particular, if the error quantities distribute such that all error quantities are equal or collected to almost the same value, it is same as in the case of 2 roots or below. Accordingly, it is possible to compute the code word components even if every type of errors occurs. In consideration of failed correction, however, the correction to the true code is executed only in the case of Σ|ej|≦ε. In other cases, the error quantities on various codes, that is, fail-corrected errors are obtained, which contain the error on the true code.
The scan with 2 selections of η increases the conversions for collection to J+ in a distribution of errors on 3 or more code word components. Accordingly, the correctable cases can be increased reliably though the types of distributions additionally correctable are not obvious.
In the case of 3 roots or above, it is not possible to execute the conversion to J+, for ε errors or below, in all the cases where the conventional Euclid method can be applied to seek a solution searching polynomial. Therefore, they cannot be dealt with the syndrome converting method. If the patterns of the error quantities on the error components are analogous to each other, they have no difference and they can be dealt easily with the syndrome converting method even in the case of 3 or more roots. This point provides a large merit.
If the quantity of errors in each memory cell is analogous as in the p-adic cells, the scale of processing and the computation can be made simpler and effective as the on-chip system.
Naturally, the syndrome converting method and the conventional Euclid method can be used together to improve the range of correctable error distributions. The Euclid method, however, uses complicated operation processing and circuits and accordingly impairs the achievement of simpler circuit scales and faster processing. The Euclid method can be used directly in solution searching in the memory system using the Lee metric code naturally.
[Configuration of p-adic Memory System]
The following description is given to the memory system according to the present embodiment using the Lee metric code in the “p-adic Zp world”.
In the “p-adic Zp world”, the largest merit of the memory system is present in the point that ECC using the Lee metric code can be used. Therefore, the memory system is configured on the premise of the use of ECC.
The present memory system is roughly divided into 3 parts: a part operative to execute processing at the entrance to the “p-adic Zp world”; apart operative to execute processing in the “p-adic Zp world”; and a part operative to execute processing at the exit from the “p-adic Zp world”.
The part operative to execute processing at the entrance to the “p-adic Zp world” includes a p-adic converter unit 101. The p-adic converter unit 101 is contained in a code generator unit together with a later-described encoder unit 201. Binary data D input to the “binary world” is first converted at the p-adic converter unit 101 to a p-adic number and provided as data A to the “p-adic Zp world”.
The part operative to execute processing in the “p-adic Zp world” includes an encoder unit 201, a p-adic cell memory unit 202, an error detection/correction unit (203-206), and a decoder unit 207.
The encoder unit 201 receives the data A fed from the p-adic converter unit 101 and makes a generator matrix G react with the data A to yield a Lee metric code, which is then stored and held as a write code C in the p-adic cell memory unit 202.
The p-adic cell memory unit 202 is a large storage capacity memory such as a flash memory, a PRAM and a ReRAM.
At the time of reading data from the p-adic cell memory, the coded data C containing errors is read out as a read code Y.
A syndrome generator unit 203 executes the computation of the syndrome mS by multiplying a syndrome matrix H by the m-th power of the number of coordinates at the position, in accordance with the positions of code word symbols, using the diagonal matrix shown in Expression 50.
If m=0, no error arises in the case of mS=0. Accordingly, for the purpose of executing the final processing step in the “p-adic Zp world”, the code Y is fed to the decoder unit 207. In the case of mS≠0, on the other hand, if the first component S0 of mS in the case of m=0 satisfies |S0|>γ, reliable error correction is impossible. Accordingly, NG signal is provided and the error-containing code Y is fed to the decoder unit 207. In other cases, the syndrome mS is fed to a solution searching polynomial generator unit 204.
The solution searching polynomial generator unit 204 derives a solution searching polynomial Ψ(x) from the syndrome mS with a setting of η=γ−1 and, if the coefficient at the η-th degree is φn≠0, then it feeds the φ(x) to a Hasse differential polynomial generator unit 205. In the case of φn=0, on the other hand, η=γ−2 is set to seek a polynomial Ψ(x) again. If the coefficient at the (η+1)-th degree of the polynomial Ψ(x) is φη+1=0, and if the coefficient at the η-th degree of Ψ(x) is φn≠0, Ψ(x) is the η degree. Accordingly, Ψ(x) is fed to the Hasse differential polynomial generator unit 205. On the other hand, if φn=0, processing is repeated to seek the syndrome mS with increasing m by 1. If the coefficient at the n-th degree of Ψ(x) is φn=0 even when it is repeated until m reaches p−2, error correction is impossible. Accordingly, NG signal is provided and the error-containing code Y is fed to the decoder unit 207.
The Hasse differential polynomial generator unit 205 derives a Hasse differential polynomial from the input Ψ(x), then computes a root r and the multiplicity n of the root, and feeds them as t=r−1 to a code restorer unit 206.
The code restorer unit 206 uses the computed root r and the multiplicity n of the root to seek the positional coordinates of the error-caused code word and the error quantity et, thereby computing the total quantity Σ|et| of Lee metrics of the error quantities. If it is equal to or below γ−1, the unit restores the code data C of the Lee metric code. If it is equal to or above γ−1, on the other hand, it is dealt as uncorrectable because there is the possibility of failed correction. In this case, for the purpose of processing the next η or the next m, the flow shifts processing to the syndrome generator unit 203 or the solution searching polynomial generator unit 204. If η=γ−2 in the case of m=p−2, NG signal is provided and the flow shifts processing to the decoder unit 207.
The decoder unit 207 executes the inverse conversion of the generator matrix G over the code data C to obtain a p-adic number, thereby obtaining the code A. This code A is provided to the “binary world”.
The part operative to execute processing at the exit from the “p-adic Zp world” includes a 2h-adic converter unit 301.
The 2h-adic converter unit 301 converts the code A to a 2h-adic number, that is, binary-represented output data. This is the restored binary data D.
Hereinafter, the circuitry of each block in the “p-adic Zp world” is described with specific examples shown.
As shown in
Among these clocks ck and cl, ck is applied to control a “Counter (1 to p−1)” circuit block and a “Ri (1 to p−1)” register unit, and cl to control an “X k-times” circuit block, a “Ro (0 to k−1)” register unit and a “Rgstr” register.
The “Counter (1 top−1)” circuit block is a circuit having an initial state of 0. It starts counting the number of clocks again at every rise of the clock ck and provides the number. Namely, of ckj (j=1 to p−1), it provides j to an “X k-times” circuit block at the rise of ckj.
The “Ri (1 to p−1)” register unit includes registers operative to store components cj of the code word C and capable of storing (p−1) pieces of numerals in total. The “Ri (1 to p−1)” register unit stores numerals in the individual registers sequentially in sync with the timing of the rise of ck. Namely, data, that is, the element cj is taken into the register at the timing of the rise of ckj+1. At the rise of ckp, (p−1) pieces of elements cj are taken in the registers. In a word, the code C can be thus stored.
The “X k-times” circuit block is a circuit that multiplies the input by the output at every rise of the clock cl. The “X k-times” circuit block multiplies the output by the input j at every rise of cl, (p−ε−2)-times in total. Namely, the rises of cli (i=0 to p−ε−3) bring the output from the “X k-times” circuit block to (j)i+1. This output is fed to the “X Zp” circuit block.
The “Ro (0 to k−1)” register unit includes registers, which can store k pieces of numerals and, in the initial state, store k (=p−ε−2) pieces of components a0-ap-ε-3 of the code A. The “Ro (0 to k−1)” register unit receives the clocks cl, and provides the components a0-ap-ε-3 of the code A in order at every rise of the clock cl. Namely, on receipt of cli (i=0 to p−ε−3), it provides ai.
The “X Zp” circuit block is a circuit operative to execute a multiplication of the input in Zp. The “X Zp” circuit block receives the output (j)i+1 from the “X k-times” circuit block and the output ai from the “Ro (0 to k−1)” register unit at every clock cli, and provides (j)i+1ai. The output numerals (j)1+1ai are summed in a combination of the “h bit AD mod p” circuit block and the “Rgstr” register.
The “h bit AD mod p” circuit block is a circuit that seeks the sum of 2 input numerals modulo p. On the other hand, the “Rgstr” register is a register having an initial state of 0. It blocks any input from the “h bit AD mod p” circuit block at every input of the clock cl and feeds the self-holding contents to the “h bit AD mod p” circuit block. The connection of the “h bit AD mod p” circuit block with the “Rgstr” register as shown in
The following description is given to a product operating circuit contained in the “X Zp” circuit block shown in
At the start, the principle of a circuit operative to execute a multiplication of numerals in Zp is described.
When 2 numerals a and b in Zp are each represented in h-bit binary, the bits are represented as in Expression 51, and the product of the bits is represented by Mab of (h×h) elements.
a=A0+A12+A222+A323+ . . . +Ah−22h−2+Ah−12h−1
b=B0+B12+B222+B323+ . . . +Bh−22h−2+Bh−12h−1 [Expression 51]
Here, h denotes the minimum number of bits capable of representing p in binary.
There are listed 2 articles serving as the basis on the computation used.
(First Article) 0≦a, b≦p−1 establishes 0≦a/2+b≦3/2(p−1)<2(p−1). In a word, even if the process neglects the least significant bit in one of the h-bit binary-represented numerals in Zp, then shifts the digits by 1 digit to regard it as a (h−1)-bit binary number, and adds it to an h-bit represented numeral, the sum contains a single p at most. Therefore, when it is regarded as the sum modulo p, it can be represented in h-bit binary.
(Second Article) 0≦a≦p−1 establishes 2a+1≦2p−2+1=2p−1. In a word, even if the process adds the least significant bit to the h-bit binary-represented numeral to yield a (h+1)-bit number, the sum contains a single p at most. Therefore, when it is regarded as the sum modulo p, it can be represented in h-bit binary.
Therefore, these 2 articles are utilized for computations.
Expression 52 shows a computation step group in the first half using the above first article in which the parts using the above first article are underlined.
At the 1st step in the first-half computation step group, the process first extracts the least significant bit M00 from the resultant h-bit numbers modulo p and then applies 2 to bind the remaining numbers as shown in the equation (b) in Expression 52.
Subsequently, from the term bound by 2, the process executes a multiplication of the least significant bit B0 in the multiplying number b and the multiplied number a to create a (h+1)-bit number (M10+M20+ . . . +Mh−1·02h−2) as shown in Expression 52 (b). At the same time, the process executes a multiplication of the least significant bit B1 in the multiplying number b and the multiplied number a at this moment to create an h-bit number (M01+M112+ . . . +Mh−1·02h−2) as shown in the equation (c) in Expression 52.
Finally, the number (M10+M20+ . . . +Mh−1·02h−2) is added to the number (M01+M112+ . . . +Mh−1·12h−1) to create a new h-bit number (Q00+Q012+ . . . +Q0h−12h−1) as shown in the equation (d) in Expression 52.
Thereafter, similar computation steps are repeated until the process obtains an h-bit number (Qh−20+Qh−212+ . . . +Qh−2h−12h−1) through multiplications of the least significant bit Bh−1 in the multiplying number b and the multiplied number A as shown in the equation (o) in Expression 52.
Expression 53 shows a computation step group in the second half using the above second article in which the parts using the above second article are double-underlined. The equation (p) in Expression 53 follows the equation (o) in Expression 52.
The second-half step group is applied to obtain numerals equal to or below p by subtracting p from the (2h−1)-bit number obtained in the first-half step group.
At the start, the process applies 2h−2 to bind the (h+1)-bit numbers, Qh−302h−2+2h−1(Qh−20+Qh−212+ . . . +Qh−2h−12h−1), from the most significant bit of the (2h−1)-bit number obtained in the first-half step group shown by the equation (o) in Expression 53. This result provides the equation (p) in Expression 53.
Subsequently, the process subtracts p from the (h+1)-bit binary-represented number, Qh−30+2(Qh−20+ . . . +Qh−2h−12h−1), shown in the equation (p) in Expression 53 to obtain an h-bit number (Qh−10+Qh−112+ . . . +Qh−1h−12h−1) as shown in the equation (q) in Expression 53.
Thereafter, similar computation steps are repeated with decreasing the number of bits. Then, the process terminates after it obtains an h-bit number shown in the equation (u) in Expression 53.
When all the computation steps shown in Expressions 52 and 53 complete, the result of multiplications of numerals in Zp provides the h-bit product.
The “X Zp” circuit block is roughly divided into a circuit for processing a computation step group in the first half shown in Expression 52, and a circuit for processing a computation step group in the second half shown in Expression 53.
The circuit for processing the first-half computation step group includes an AND gate G1, and (h−1) “h bit AD mod p” circuit blocks.
The AND gate G1 yields the logical product of the i-th bit (i=0 to h−1) of the multiplied numeral a and the j-th bit (j=0 to h−1) of the multiplying numeral b, and provides it as Mij.
The “h bit AD mod p” circuit block is a circuit operative to seek the sum of 2 numerals in Zp modulo p. The “h bit AD mod p” circuit block has the inputs A0-Ah−1 and B0-Bh−1 and the outputs Q0-Qh−1.
The 1st “h bit AD mod p” circuit block <1> receives M10-Mh−1·0, ‘0’, M01-Mh−1·1 at A0-Ah−2, Ah−1 and B0-Bh−1, and provides Q00-Q0h−1 from Q0-Qh−1, respectively.
The 2nd “h bit AD mod p” circuit block <2> receives Q01-Q0h−1, that is, the output from the “h bit AD mod p” circuit block <1>, ‘0’, and M02-Mh−1·2 at A0-Ah−2, Ah−1 and B0-Bh−1, and provides Q10-Q1h−1 from Q0-Qh−1, respectively.
As described above, the circuit for processing the first-half computation step group includes the “h bit AD mod p” circuit block <1> through the “h bit AD mod p” circuit block <h−1>, of which inputs and outputs are connected in order.
The circuit for processing the second-half computation step group includes (h−1) pieces of “h+1 bit mod p” circuit blocks. The “h+1 bit mod p” circuit block is the circuit shown in
The 1st “h+1 bit mod p” circuit block <1> receives Qh−30 and Qh−20-Qh−2h−1 at A0 and A1-Ah, and provides Qh−10-Qh−1h−1 from Q0-Qh−1, respectively.
The 2nd “h+1 bit mod p” circuit block <2> receives Qh−40 and Qh−10-Qh−1h−1 at A0 and A1-Ah, and provides Qh0-Qhh−1 from Q0-Qh−1, respectively.
As described above, the circuit for processing the second-half computation step group includes the “h+1 bit mod p” circuit blocks <1>-<h−1>, of which inputs and outputs are connected in order.
All the circuits operate not in sync with clocks and decide the output Q when the input Mab is given.
Mention is made here of the circuit scale of the “X Zp” circuit block.
For example, p=17 results in h=5. In this case, the “X Zp” circuit block can be configured with h−1=4 pieces of “h bit AD mod p” circuit blocks and h−1=4 pieces of “h+1 bit mod p” circuit blocks. This means that the “X Zp” circuit block has a smaller circuit scale.
There is a requirement for (2h−2) pieces of such “X Zp” circuit blocks.
Next, the “h bit AD mod p” circuit block shown in
The “h bit AD mod p” circuit block seeks the sum of numerals a and b input from A and B, and provides the residue modulo a prime p of the resultant sum, from Q.
A consideration is given to the case of h=7, p=79. In this case, the numerals a, b, the prime p and the binary representation Q of the residue establish a relation shown in Expression 54.
a=A0+A12+A222+A323+A424+A525+A626
b=B0+B12+B222+B323+B424+B525+B626
p=79=92−2=26+23+22+21+1, a complement of p=27−p=25+24+1=49
a+b≡Q(mod p) (a+b=Q+PF0×p)
Q=Q0+Q12+Q222+Q323+Q424+Q525+Q626 [Expression 54]
The “h bit AD mod p” circuit block comprises a PF0 generator unit U1, 6 half adders HA1-HA6, and 8 full adders FA1-FA8.
The PF0 generator unit U1 is same as the PF0 generator unit U1 in the “h+1 bit mod p” circuit block shown in
The half adder HA1 has inputs A0 and B0, an output S0, and a carry output C0′. The full adder FA1 has inputs A1 and B1, a carry input C0′, an output S1, and a carry output C1′. The full adder FA2 has inputs A2 and B2, a carry input C1′, an output S2, and a carry output C2′. The full adder FA3 has inputs A3 and B3, a carry input C2′, an output S3, and a carry output C3′. The full adder FA4 has inputs A4 and B4, a carry input C3′, an output S4, and a carry output C4′. The full adder FA5 has inputs A5 and B5, a carry input C4′, an output S5, and a carry output C5′. The full adder FA6 has inputs A6 and B6, a carry input C5′, an output S6, and a carry output C6′. The half adder HA2 has inputs S0 and PF0, an output Q0, and a carry output C0. The half adder HA3 has inputs C0 and S1, an output Q1, and a carry output C1. The half adder HA4 has inputs C1 and S2, an output Q2, and a carry output C2. The half adder HA5 has inputs C2 and S3, an output Q3, and a carry output C3. The full adder FA7 has inputs S4 and PF0, a carry input C3, an output Q4, and a carry output C4. The full adder FA8 has inputs S5 and PF0, a carry input C4, an output Q5, and a carry output C5. The half adder HA6 has inputs C5 and S6, and an output Q6.
In accordance with the above configuration, the PF0 generator unit U1 determines if the sum of binaries A and B input to the “h bit AD mod p” circuit block is equal to or higher than p=79. If the sum of binaries A and B is equal to or higher than p=79, the half adders HA2-HA6 and the full adders FA7, FA8 are used to add 49, a complement of 79 in 8-bit binary, to the sum of A and B in order to subtract 79 from the sum of A and B.
The “X k-times” circuit block shown in
The “X k-times” circuit block is a circuit operative to compute a power (X)j of the input X, which is controlled by the clock clj (j=1 to p−1).
The “X k-times” circuit block includes an “X Zp” circuit block, and a “Rgstr” register <1> and a “Rgstr” register <2> operable in sync with the clock cl.
The “Rgstr” register <1> has an input connected to X, and an output connected to one output of the “X Zp” circuit block. The “Rgstr” register <2> has an input connected to the output of the “X k-times” circuit block, and an output connected to one input of the “X k-times” circuit block. The “Rgstr” register <2> holds ‘1’ in the initial state.
In accordance with this circuitry, the “X k-times” circuit block takes its own output with a 1-cycle delay to obtain the product of the input X and the output (X)j.
The output (X)j is multiplied cumulatively by the input X at every input of the clock cl. The data X is set in the “Rgstr” register <1> before the clock clj (j=1−k) rises, and the “Rgstr” register <2> having an initial state of ‘1’ is brought into sync therewith, thereby obtaining (X)j at the j-th clj.
The following description is given to a circuit block operative to compute the m-th power of the element j in Zp frequently used in later-described operation processing. Hereinafter, this circuit block is referred to as a “(j)i (j=1 to p−1)” circuit block.
The “(j)i (j=1 to p−1)” circuit block is controlled by the clocks cki (i=0 to p−2) and clj (j=1 to p−1), and provides (j)i in sync with the rise of the clock clj.
The “(j)i (j=1 to p−1)” circuit block is a circuit that computes the 0-th to (p−2)-th powers of all the elements 1 to p−1 in Zp other than zero in order, and holds them in registers.
The “(j)i (j=1 to p−1)” circuit block includes an “X Zp” circuit block, a “Counter (1 to p−1)” circuit block, and a “Ro (1 to p−1)” register unit as shown in
The index-decidable clock is cki, and an index i can be decided by the order of the clock cki. On the other hand, the elements in Zp are designated in order from 1 by the clock cl, and the order j of the clock clj indicates the number of elements.
The “Counter (1 to p−1)” circuit block is connected to one input of the “X Zp” circuit block. It uses cki as the start signal and counts up at the timing of the rise of clj within a range of 1 to p−1.
The “Ro (1 to p−1)” register unit includes (p−1) pieces of registers, and it stores inputs i1-ip-1 in Nos. 1 to p−1 registers in order at the rise of the clock/clj at in, and provides the contents ii to ip-1 of Nos. 1 to p−1 registers in order at the rise of the clock clj at out.
As shown in
The following description is given to an operating circuit operative to seek component elements of the syndrome mS in batch. Hereinafter, this operating circuit is referred to as the “syndrome component element generating circuit”.
Scanning m within a range of 0 to p−2 requires ε pieces of S0 to Sp-2+ε as the components of the syndrome mS. An operation processing equation required for creation of the components of the syndrome mS is shown in Expression 55.
The syndrome component element generating circuit includes, as shown in
Data Y read out of the p-adic cell array is stored in the “Ro (1 to p−1)” register as the initial setting. The “(j)i (j=1 to p−1)” circuit block generates (j)i. These “Ro (1 to p−1)” register and “(j)i (j=1 to p−1)” circuit block are synchronized with each other by the clock cli and controlled such that (j)i is provided at the same time as the output of the component yj of Y. The “X Zp” circuit block yields the product thereof, (j)iyj, which is summed, in sync with the clock clj (j=1 to p−1), through the loop including the “h bit AD mod p” circuit block and the “Rgstr” register, to create a syndrome component Si. The resultant Si is stored in the i-th register in the Ri (0 to p−2+ε) register at the clock cki+1. This process is treated at the clock cki for i=0 to p−2+ε to obtain all syndrome components, which are then stored in the “Ri (0 to p−2+ε)” register unit.
The following description is given to an operating circuit for seeking a solution searching polynomial Ψ(x). This operating circuit is referred to as the “solution searching polynomial generating circuit”.
A processing equation is shown in Expression 56, which is required in operational processing for deriving a coefficient φj at each degree j of x in the solution searching polynomial Ψ(x).
The solution searching polynomial generating circuit is a circuit for use in the step of error searching with the use of a syndrome uS=(uSm, uSm+1, . . . , uSm+ε).
The solution searching polynomial generating circuit allows a simple circulation circuit to generate the solution searching polynomial Ψ(x) without using a complicated Euclidean method.
The solution searching polynomial generating circuit comprises a first part circuit U1 for deriving Σφj−1Sm+i on the right side of the 2nd equation shown in Expression 56, and a second part circuit U2 for deriving −u(j)−1 on the right side of the 2nd equation shown in Expression 56 as well.
The first part circuit U1 includes (ε−1) pieces of serially connected “Rgstr” registers <1>-<ε>, and (ε−1) pieces of “X Zp” circuit blocks <1>-<ε> connected to the nodes between the “Rgstr” registers, respectively.
The “Rgstr” register <1> has an initial value of ‘1’ and other “Rgstr” registers <2>-<ε> have an initial value of ‘0’.
The first part circuit U1 is controlled by the clock ck fed to the “Rgstr” registers, and provides the coefficients φj−1, φj−2, . . . , φj−(ε-1), φj−ε at the respective degrees from the nodes between the “Rgstr” registers at the rise of the j-th clock ckj. A node with no coefficient present is at ‘0’ and accordingly cannot contribute to the product operation with the syndrome components, Sm+1 to Sm+ε, executed by the “X Zp” circuit blocks <1>-<ε>. The outputs from the X Zp” circuit blocks <1>-<ε> are summed 2 by 2 at the “h bit AD mod p” circuit blocks, and a ladder of these “h bit AD mod p” circuit blocks is applied to finally obtain Σφj−1Sm+i.
The second part circuit U2 comprises a “Counter (1 to ε)” circuit block, “X Zp” circuit blocks <a>, <b>, and a “j−1 dec” circuit block.
The second part circuit U2 generates (jSm)−1 from j generated at the “Counter (1 to ε)” circuit block and the syndrome component Sm, in accordance with the clock ckj, at the “X Zp” circuit block <a> and the “j−1 dec” circuit block. Then, the “X Zp” circuit block <b> derives u(j)−1 from the generated (jSm)−1 and the established η.
An “X Zp” circuit block <c> is used to multiply Σφj−1Sm+i, generated at the first part circuit U1, by u(j)−1, generated at the second part circuit U2, to yield the coefficient φj.
The coefficient φj is an h-bit binary, which is represented in complement to represent a negative number. Therefore, the output from the “X Zp” circuit block <c> is inverted through the inverter IV1, and ‘1’ is added thereto at the “h bit AD mod p” circuit block, thereby obtaining an h-bit binary complement representation.
The “j−1 dec” circuit block shown in
The solution searching polynomial generating circuit described above is possible to provide the coefficients φj−φj−ε where j=ε on the respective nodes on receipt of ε-times inputs of the clock ck.
When used in an actual p-adic cell memory, 5 or 6 is selected as ε. Therefore, the number of circuit blocks required in the solution searching polynomial generating circuit is small and the circuit scale is sufficiently small in practice as can be considered.
If the degree of Ψ(x) is coincident with η, it is required to derive the root of this Ψ(x) and the associated multiplicity. Therefore, the following description is given to an operating circuit operative to compute a coefficient of the Hasse differential polynomial required in deriving the multiplicity of the root. Hereinafter, this operating circuit is referred to as the “Hasse differential polynomial coefficient generating circuit”.
A relation between the coefficient of the Hasse differential polynomial, the coefficient, and the coefficient of Ψ(x) is as shown in Expression 57.
In a word, as can be found from Expression 57, the Hasse differential polynomial coefficient generating circuit multiplies the coefficient of Ψ(x) by the binomial coefficient, generates the coefficient at each degree at every differential stage using the clocks ck and cl, and stores all the coefficients in the registers.
The Hasse differential polynomial coefficient generating circuit includes a “i!” table having a record of the factorial i! of each element i in Zp, a “(i!)−1” table having a record of the inverse element, and a “φi” table having a record of the coefficient φi of the solution searching polynomial Ψ(x). As for the i!” table and “(i!)−1” table, they can be suppressed to sufficiently small scales in practice, for example, in the case of p=17.
As for the “φi” table, it is created in the Hasse differential polynomial coefficient generating circuit shown in
The Hasse differential polynomial coefficient generating circuit includes, as shown in
The number of clocks of the clock ck corresponds to the number of differential stages, and i in cki takes a value of 1−ε. On the other hand, the clock cl corresponds to the degree, and a growth in number of differential stages increases undesired degrees. Therefore, it is not required to generate the clock cl every time by the same number as the clock ck though the circuit of
For the purpose of storing the coefficients of Ψ(x), that is, the coefficients corresponding to Ψ[0], previously in the registers, ck0 is provided as a matter of convenience.
The following description is given to an operating circuit operative to compute the root and the associated multiplicity of the solution searching polynomial Ψ(x). Hereinafter, this operating circuit is referred to as the “solution searching polynomial root/multiplicity operating circuit”.
The solution searching polynomial root/multiplicity operating circuit regards the 0-th stage differential for the Hasse differential polynomial as Ψ(x). Unless the Hasse differential polynomial is zero for each element in Zp, the circuit shifts the computation to the next element. The circuit increases the number of differential stages while the Hasse differential polynomial keeps zero. When registers are used to hold the number of the first Hasse differential stages where the Hasse differential polynomial is not zero, for each element in Zp, the element with the number of stages being not zero indicates the root, and the number of the remaining stages indicates the multiplicity of the root. In a word, when those with non-‘0’ contents are selected from the registers, the held value indicates the multiplicity of the root.
Specifically, when the root of the solution searching polynomial Ψ(x) is denoted with α, and a Hasse differential polynomial of Ψ(x) in the i-th stage with [Ψ(x)][i], a relational equation is given as in Expression 58 where the multiplicity of α is denoted with n.
The solution searching polynomial root/multiplicity operating circuit seeks n as in Expression 58 for each element α in Zp regardless of whether it is the root of Ψ(x) or not. In the case of n=0, it means that α is not a root.
The solution searching polynomial root/multiplicity operating circuit scans the elements 1 to p−1 in Zp at the clock ck to seek the number of stages of the Hasse differential at the clock cl, and the value of the Hasse differential polynomial in that number of stages at the clock clk. The clock ck is generated when the computed value of the Hasse differential polynomial becomes non-zero such that the process enters the cycle for the next element in Zp.
The solution searching polynomial root/multiplicity operating circuit includes, as shown in
The “(j)i (j=1 to p−1)” circuit block selects an element a on receipt of the clock ck α-times, and provides the j-th power of α on receipt of the clock clk (j+1)-times.
The “Ro i(0−ε)/j(0−ε)” register unit is a register operative to provide a coefficient φ[i]j of the Hasse differential polynomial on receipt of the clocks cli and clkj. It corresponds to the “R i(0−ε)/j(0 to ε−1)” register unit shown in
The “X Zp” circuit block multiplies the output αj from the “(j)i (j=1 to p−1)” circuit block by the output φ[i]j from the “Ro i (0−ε)/j(0−ε)” register unit, and provides αjφ[i]j.
Thus, when the clock clk is applied (ε+1)-times to the “(j)i (j=1 to p−1)” circuit block, the “Ro i(0−ε)/j(0−ε)” register unit and the “X Zp” circuit block, the value of the Hasse differential polynomial can be obtained. For the purpose of simplifying the control of the clocks ck, cl and clk, the sum of the terms of the value 0 not present in this computation is computed as well. Therefore, the total sum of the clocks clk originally required is almost halved.
The value [Ψ(x)][i] of the differential polynomial is taken in the “Rgstr” register <1> as ‘0’ in the case of zero and ‘1’ in other cases.
The value held in the “Rgstr” register <1> is output at the timing of the clock clk0 as the clock ckα (α=1 to p−1). The clock ckα is held until it is reset by the clock clkε.
The “Rgstr” register <1> has an initial value of 0 and accordingly the clock ck1 rises at the first clk0. The clock ck2 and so forth rise at clk0 in any cycle of clk in accordance with the computation result.
The “clock cl gen.” circuit block generates the clock cli in sync with the clock clko and resets it to the clock cl0 at every rise of the clock ckα.
The “Counter (0 to ε)” circuit block is reset to 0 by the clock ckα, and counts up at every input of the clock cl and outputs the order of the clock cl minus 1. This output is stored in the “Li (1 to p−1)” register unit.
The “Li (1 to p−1)” register unit has the inputs, which are switched by the clock ckα, and thus can store the associated multiplicity in the α-th register.
By the way, in the case of small p, the elements in Zp for use in computations may be prepared previously in part if they can be contained in tables, thereby omitting the computations and reducing the circuit scale. For example, an actual p is equal to around 19 at most, and accordingly the inverse elements and factorials of the elements are contained in tables. These tables are used in a binary decoder.
In particular, the inverse elements of the elements in Zp are immediately required for variable input elements in many cases. Accordingly, it is desired to configure them as a decoder circuit.
The inverse elements j−1 of the elements j can be obtained by deriving a relation of j×j−1≡1 (mod p), then configuring h-bit binary representations of j and j−1 as shown in Expression 59, and forming an associated conversion decoder.
Input:Ii=(j)i
j=(j)0+(j)12+(j)222+ . . . +(j)h−22h−2+(j)h−12h−1
Output:Ii=(j−1)i
jj−1≡1(mod p)
j−1=(j−1)0+(j−1)12+(j−1)222+ . . . +(j−1)h−22h−2+(j−1)h−12h−1 [Expression 59]
A specific configuration of the conversion decoder is described later.
The factorials j! of the elements j are required in computations of the coefficients of the Hasse differential polynomial and accordingly they may be previously derived for use in turn.
The computation of the factorial j! requires the value of the element in Zp. In this case, p is a prime and also a coprime with the numeral of each element contained in the factorial. Therefore, a recurrence formula shown in Expression 60 can be used to derive the factorial without dealing a large number.
Input:Ii=(j)i
j=(j)0+(j)12+(j)222+ . . . +(j)h−22h−2+(j)h−12h−1
Output:Ii=(j!)i
j!(mod p)≡[(j−1)!(mod p)]×j(mod p)
j!=(j!)0+(j!)12+(j!)222+ . . . +(j!)h−22h−2+(j!)h−12h−1 [Expression 60]
The following description is given to specific circuitry of the conversion decoder, that is, a “j−1 dec” circuit block.
The present decoder circuit has general circuitry operative to decode 7-bit binary data I into another 7-bit binary data O.
It can be used as the “j−1 dec” circuit block in consideration of substitutions of j into I and of j−1 into O. The present decoder circuit is used in conversion between the elements in Zp and is operable in accordance with 2 clocks τ0 and τ1.
The decoder circuit decodes bits I0-I5 2-bit by 2-bit partly to create signals /A0-/A3, /B0-/B3, /C0-/C3, and uses a NOR gate to create AiBk from /Ai and /Bk.
The decoder circuit includes a NOR connection having 16 discharge paths to Vss at every output bit Om, thereby inverting the NOR-node-latched level to Om. The latch circuit can be reset using the clock τ0 just 1 clock.
The 16 discharge paths are gated by the signals AiBk (i=0-3, k=0-3) and branched by the input bits I6 and /I6. Arranged beneath the branches is an OR connection of NMOS transistors controlled by Cmi (mi=0-3) in accordance with the association of conversion. These branches are connected to Vss by the clock τ1.
The transistors controlled by Cm1 are arranged in such the manner that the bits of an input I corresponding to the bit Om are classified by AiBk in the conversion, and then classified by ‘1’, ‘0’ of I6 to select one among C0-C3.
The error E derived in operational processing is corrected after it is confirmed that the Lee metric thereof is equal to or below ε and thus no failed correction occurs.
Therefore, the following description is given to an operating circuit element operative to compute the Lee metrics of the elements in Zp. Hereinafter, this operating circuit element is referred to as an “h bit LMp” circuit block.
With respect to an h-bit binary-represented element a in Zp, the Lee metric thereof Q=|a| can be represented by Q=/PF0×a+PF0×(p−a) where PF0 is ‘1’ if a≧(p+1)/2 and ‘0” if a<(p+1)/2. Therefore, the Lee metric of a can be obtained by subtracting a from p, that is, adding the complement of a to p if a≧(p+1)/2.
A specific example is described here in the case of h=7, p=79.
In the case of h=7, p=79, A and Q have a relation therebetween as in Expression 61.
a=A0+A12+A222+A323+A424+A525+A626
Q=|a| (Q=/PF0×a+PF0×(p−a))
Q=Q0+Q12+Q222+Q323+Q424+Q525+Q626 [Expression 61]
The “h bit LMp” circuit block receives an h-bit binary A0-Ah−1 and provides an h-bit binary Q0-Qh−1.
The “h bit LM p” circuit block comprises a PF0 generator unit U1, an XOR gate G1, 2 half adders HA1, HA2, and 5 full adders FA1-FA5.
The PF0 generator unit U1 includes serially connected PMOS transistors QP1, QP2 and NMOS transistors QN1, QN2 between the Vcc terminal and the Vss terminal. These transistors QP1, QP2, QN1 and QN2 are controlled by A5, A6, A3 and A5, respectively.
The PF0 generator unit U1 also includes 2 PMOS transistors QP3, QP4, 2 NMOS transistors QN3, QN4, and an inverter IV1.
The transistors QP3, QP4 are serially connected and both ends thereof are connected to the source and drain of the transistor QP1. The transistor QN1 is connected between the source and drain of the transistor QN1. The transistor QN4 is connected between the source of the transistor QN1 and the drain of the transistor QN2 (Vss terminal). The transistors QP3, QP4, QN3 and QN4 are controlled by A2, A4, A4 and A6, respectively. The inverter IV1 has an input connected to the node of the transistors QP2 and QN1. The output from the inverter IV1 provides the carry PF0.
The XOR gate G1 receives Aj (j=0-7) and PF0, and provides Bj.
The full adder FA1 has inputs B0 and PF0, a carry input PF0, an output Q0, and a carry output C0. The full adder FA2 has inputs B1 and PF0, a carry input C0, an output Q1, and a carry output C1. The full adder FA3 has inputs B2 and PF0, a carry input C1, an output Q2, and a carry output C2. The full adder FA4 has inputs B3 and PF0, a carry input C2, an output Q3, and a carry output C3. The half adder HA1 has inputs C3 and B4, an output Q4, and a carry output C4. The half adder HA2 has inputs C4 and B5, an output Q5, and a carry output C5.
In this specific example, when the input reaches 40 or above, the complement of a is added to p. The complement of a can be created by inverting each bit representation Aj of a into Bj through the XOR gate and adding 1 thereto in the case of PF0=1.
As p=79 is 79=(1001111)2, the process represents it by PF0, and uses PF0 as 1, then adds 79, of which PF0 is represented as 1, to the inverse of Ai, or Bi itself.
The “h bit LM p” circuit block operates not in sync with clocks and provides computed Lee metrics on receipt of inputs.
The following description is given to an operating circuit for computing a Lee metric w(E)=Σ|ej| (j=1 to p−1) of an error code word E. Hereinafter, this operating circuit is referred to as the “Lee metric operating circuit”.
The Lee metric operating circuit includes a “Ro (0 to p−1)” register unit, an “h bit LMp” circuit block, an “h bit AD mod p” circuit block, and a “Rgstr” register.
The error code word E derived from the polynomial Ψ(x) is stored as the initial value in the “Ro (0 to p−1)” register unit. From the “Ro (0 to p−1)” register unit, the components ej of E are taken out in order by the clock ckj.
The “h bit LMp” circuit block computes the associated Lee metrics |ej| from the taken-out components ej. The “h bit LMp” circuit block provides the Lee metrics of the components, computed at every clock ckj, to the “h bit AD mod p” circuit block.
The “Rgstr” register and the “h bit AD mod p” circuit block form a loop, which is used to sum up these |ej|. The output from the “h bit AD mod p” circuit block when the (p−1)-th clock ck rises provides w(E)=Σ|ej|.
As for E, on the basis of α and [n] obtained as a set of the root and multiplicity of Ψ(x) through the above-described operation, a conversion, t=α−1, et=(utm)−1n, is applied to derive the components et. If w(E)≦ε, the flow terminates a series of error searching and executes correction by E.
If the Lee metric code corrected by the error code E can be obtained after completion of error searching, it is required to restore the code to the data code A in Zp. This operation corresponds to the inverse operation of C=AG with the generator matrix G. The inversion of the matrix is a large scale operation. Therefore, the elements of A are sequentially derived from the elements of C. The process of computation is shown in Expression 62. In Expression 62, note that j=1 to p−1, n=p−1, p−ε−3=n−γ−1=k−1.
As shown in Expression 62, the relation, cj=Σ(j)i+1ai, is modified in turn to derive a1 from ao, subsequently a2 from a1, . . . , then am sequentially. This is the principle of computation.
Both sides are multiplied by the inverse elements of the powers of j to yield the terms of j on all elements in Zp, which are then summed. The fact that the sum of all elements in Zp becomes zero is utilized for the modification.
Expression 63 is a relational equation between the A components and the C components.
The following description is given to an operating circuit for realizing the relational equation in Expression 63.
At the time of deriving am+1 after am is obtained, the sum on j at am+1 is computed in turn while obtaining c(m)j. At this time, the powers required for j include the (m+1)-th power for c(m)j, and (m+2)-th power for am+1. Therefore, the present operating circuit uses the slightly-modified circuit block for computing the powers of the elements in Zp.
The inverse converting circuit includes a 1st part circuit U1 operative to derive the elements of A one by one through operations, and a 2nd part circuit U2 operative to every time convert the components of the Lee metric code C required in the operations.
The part circuits U1 and U2 include a “(j)i (j=1 to p−1) 2” circuit block operative to generate the (m+1)-th and m-th powers of the element j in Zp. The “(j)i (j=1 to p−1) 2” circuit block provides the part circuit U1 with a power of the element j having an index i equal to the number of cycles of the clock cki if the number of cycles of the clock cl is equal to j. On the other hand, it provides the part circuit U2 with a power of the element j having an index i smaller by 1 than the number of cycles of the clock cki if the number of cycles of the clock cl is equal to j.
The “(j)i (j=1 top−1) 2” circuit block is anew symbolized by turning the “(j)i (j=1 to p−1)” circuit block to a circuit capable of providing signals from internal nodes. The details are described later.
The “(j)i (j=1 to p−1) 2” circuit block provides the element in Zp itself to the part unit U1 and ‘1’ to the part unit U2 in the 1st cycle of the clock cl. The ‘1’ fed to the part unit U2 is not a value found in the original operation. Accordingly, a thought is required to eliminate the influence exerted on the operation result. Therefore, for the purpose of eliminating the influence from the ‘1’, the product operation at the part unit U2 turns the other input to ‘0’ in the first cycle of the clock ck so that the result from the product operation becomes zero.
At the start, the 1st part unit U1 is described.
The 1st part unit U1 includes, in addition to the “(j)i (j=1 to p−1) 2” circuit block, a “(j)i dec” circuit block, 2 “X Zp” circuit blocks <1>, <2>, an “h bit AD mod p” circuit block <1>, a “Rgstr” register <1>, and a “Li (0 to k−1)” register unit.
The output (j)m+1 from the “(j)i (j=1 to p−1) 2” circuit block is fed to the “(j)i dec” circuit block.
The “(j)i dec” circuit block converts (j)m+1 to the inverse element (j)−(m+1), and provides it to the “X Zp” circuit block <1>.
The “X Zp” circuit block <1> computes the product of (j)−(m+1) fed from the “(j)i dec” circuit block and cj (=c(m-1)j) fed from the 2nd part unit U1 in sync with (p−1) pieces of the clocks cl between the clocks ck, and provides the product to the “h bit AD mod p” circuit block <1>.
The product output from the “h bit AD mod p” circuit block <1> is summed up through the loop including the “Rgstr” register <1> having an initial value of ‘0’ and the “h bit AD mod p” circuit block <1>. The result is fed from the “h bit AD mod p” circuit block <1> to the “X Zp” circuit block <2>.
The “X Zp” circuit block <2> computes the product of the sum output from the “h bit AD mod p” circuit block <1> and (p−1)−1 to obtain am in accordance with the computation formulae shown in Expression 62. This am is held in the m-th register in the “Li (0 to k−1)” register unit by the clock ckm+1 at the beginning in the next cycle.
Next, the 2nd part unit U2 is described.
The 2nd part unit U2 includes, in addition to the “(j)i (j=1 to p−1) 2” circuit block, a “Rgstr” register <2>, an “X Zp” circuit block <3>, 2 “h bit AD mod p” circuit blocks <2>, <3>, and a “R (1 to p−1)” register unit.
The “Rgstr” register <2> provides the established am in the cycle after cki. Namely, the output am-1 is provided at the clock ckm. In the first cycle ck0 of the clock ck, the initial value of the output node on the “Rgstr” register <2> is set at ‘0’. This is aimed to bring the result of the product operation at the time of the clock cl1 to zero as described above.
The “X Zp” circuit block <3> computes the product of (j)m fed from the “(j)i (j=1 to p−1) 2” circuit block generated in the cycle ckm of the clock ck and the output am-1 from the “Rgstr” register <2>, and provides the product to the “h bit AD mod p” circuit block <2> via an inverter IV1.
The “h bit AD mod p” circuit block <2> computes the complement of the output am-1 fed from the “Rgstr” register <2> via the inverter IV1 to create −jmam-1, and provides it to the “h bit AD mod p” circuit block <3>.
The “h bit AD mod p” circuit block <3> computes the sum of −jmam-1 output from the “h bit AD mod p” circuit block <2> and cj (=c(m-2)j) fed from the “Rgstr” register <2> in sync with the clock cl, and provides it as c(m-1)j. The c(m-1)j output from the “h bit AD mod p” circuit block <3> is recorded in the j-th register in the “R (1 to p−1)” register unit in sync with the fall of the clock cl. The setting in the “Rgstr” register <2> causes the “R (1 to p−1)” register unit to have an initial value of c(m-2)j=c(m-1)j=C.
Next, the “(j)i (j=1 to p−1) 2” circuit block shown in
The “(j)i (j=1 to p−1) 2” circuit block is a modified circuit of the “(j)i (j=1 to p−1)” circuit block, that is, the circuit operative to derive the 0-th to (p−2)-th powers of all the elements 1 to p−1 in Zp except zero and hold them in the registers.
The “(j)i (j=1 to p−1) 2” circuit block provides (j)1+1 and (j)i in sync with the input clocks cki (i=0 to p−2) and clj (j=1 to p−1) as shown in
The “(j)i (j=1 to p−1) 2” circuit block includes a “Counter (1 to p−1)” circuit block, an “X Zp” circuit block, and a “R (1 to p−1)” register unit.
The “R (1 to p−1)” register unit includes (p−1) pieces of registers, and it stores inputs in Nos. 1 to p−1 registers in turn at the rise of the clock /cl at in, and provides the contents of Nos. 1 to p−1 registers in order at the rise of the clock /cl at out.
The “X Zp” circuit block computes the sum of the output from the “Counter (1 to p−1)” circuit block operative to count up in sync with the input clock cl and the output from the “R (1 to p−1)” register unit.
With the above configuration, the “R (1 top−1)” register unit provides (j)i at every rise of clj in each cycle of clj after the rise of cki. At the same time, the “X Zp” circuit block provides (j)i+1 having an index different by 1 from (j)i.
[Syndrome Converting Method]
The next study is given to what the error correction through the syndrome converting method executes when viewed in the space of the codes representing the Lee metric code, and to the condition under which this method can be used effectively.
When a point in a true error code word actually indistinct is represented by E=(e1, e2, . . . , ej, . . . , en), in the syndrome converting method the process converts it to a point mE=(u(1)me1, u(2)me2, . . . , u(j)mej, . . . , u(n)men) in a virtual error code word. Note that the component coordinates themselves are unchanged. In this case, the syndrome is represented as in Expression 64.
These conversions result in mE≠m′E in the case of m≠m′ and η≠η′. Namely, if η is different from each other, they cannot be the same point. This is because u(i)mei=u′ (i)mei, that is, Expression 65 should establish over all i in the case of mE≠m′E though Expression 65 cannot establish other than E=0.
Therefore, the process scans over m=0 to p−2 because of (j)p-1=1, and uses both γ−1 and γ−2 as η effective on the syndrome converting method to simplify the configuration of the solution searching polynomial. Thus, the process can obtain 2 (p−1) points containing the true error code word point. If these points contain all of the error code word points that are considered to suffer the restriction of the Lee metric similar to the true error, it is possible to search errors without misses and correct them, if correctable, by deriving a solution searching polynomial to obtain a solution.
Unless they contain all the error code word points, error correction may cause a miss because there can be a point corresponding to the error other than the point converted from the true error and accordingly it is hard to say positively that the error cannot be specified even if solution searching is impossible.
Then, the condition on the error quantity and the correctable condition are described next.
In the syndrome converting method the process uses (p−1) conversions that use syndromes cyclically and the values of η to use 2 (p−1) conversions at the maximum. Then, it is studied next to find if these conversions can cover all causable errors.
As described above, when the point in the true error code word is given by E=(e1, e2, . . . , ej, . . . , en), in the syndrome converting method the point in the virtual error code word is given by mE=(u(1)me1, u(2)me2, . . . , u(j)mej, . . . , u(n)men).
There are ξ error component positions, which are represented by ji (i=1−ξ). In this case, and the syndrome conversion can make the sum equal to η as in Expression 66.
In Expression 66, εi is considered a variable. As for the variables εi, 1 to p−1, and the sum of pieces is fixed to η, the selections of the value of each variable become (p−1)ξ-1. The final selection contains 0 as they remain same and accordingly this case is excluded.
If n(ξ) indicates the number when the sum of ξ pieces of free variables εi is congruent with q, it is required to exclude the case where the sum reaches q before the final selection. Therefore, n(ξ)=(p−1)ξ-1−n(ξ−1) establishes and thus yields n(ξ) as in Expression 67.
ξ:even n(ξ)={(p−1)ξ−1}/p
ξ:odd n(ξ)={(p−1)ξ+1)}/p [Expression 67]
In this case, there is one that has components all falling within a range of 0 to p/2, that is, components belonging only to J+. Accordingly, if the number of conversions is equal to or higher than the number in the case, different conversions can cover different cases. Therefore, it is possible to create a virtual error in J+ for the solution through the syndrome converting method.
When viewed from the syndrome converting method, this condition is in the case of ξ=2, which is in the case of 2 roots as in the above-described study. In the case of 3 or more roots (ξ≧3), however, it is not possible to exclude the case of solution-unobtainable errors.
In a word, this indicates that the syndrome converting method is simple in processing but causes error correction misses. If there is the possibility of causing various patterns of errors, it is preferable to increase the range of conversions through the syndrome converting method, the number of conversions, using another converting method than that of converting the syndrome components cyclically. It is also preferable to configure a solution searching polynomial using the Euclidean iterative method, which is though not suitable for on-chip use because of complicated processing as can be found.
Next, in relation to the condition, w(E)≦ε, on the error correctable by the Lee metric code and the condition on searching without misses through the syndrome converting method, the relations between the error quantity obtained in the operational processing result and the failed correction are grouped.
(1) In the case of the number of distributions of ε≦the number of searching
If the solution E obtained through the syndrome converting method contains one that is found to satisfy the Lee metric W(E)≦ε, it is the true error reliably and accordingly the flow terminates solution searching then.
This is because the key to solution closes in the self-mapping between ε or below error words so that the true error corresponds to the key-to-solution-applicable error.
If the solution E obtained through the syndrome converting method contains one that is found to satisfy the Lee metric W(E)≦ε, it is a failed error to an adjacent code. In this case, it is not possible to distinguish such the error from the true error on the Lee metric code.
This is the case of failed correction that cannot be excluded by any ECC.
This is the case that an error code point drops in a gap between code words such that the true error can be searched through the syndrome converting method possibly.
The error locates at the shortest distance to the true code and uniquely belongs to that code as can be considered. Of the errors E obtained through the syndrome converting method, one having the minimum Lee metric, w(E)>ε, is denoted with Emin. If Emin is satisfied by only 1 component configuration, Emin is adopted as the true error. This is because all virtual errors obtained from the true error through conversions completely include the cases of all occurrence patters of the true error so that the error can be determined. It cannot be determined in the presence of plural Emin and accordingly no solution can be obtained.
(2) In the case of the number of ε distributions>the number of searching
The process causes a careless defeat through the syndrome converting method in addition to the failed correction to the true error.
In the procedure of searching, if the number of distributions of ε≦the number of searching, “w(E) is computed at every solution E found. If w(E)≦ε, the flow terminates processing as the true error is found, and if w(E)>ε, the flow continues the scan to find a smaller w(E). If the minimum w(E) at the last of all processing satisfies w(E)>ε, it is the case that the key to solution is not applicable”.
[Method of Verifying in p-adic Memory System]
Finally, a simple method of verifying the operation of the circuits for operational processing in the “p-adic world” is described.
The circuits for conversions at the entrance to the “binary world” and to the “p-adic Zp world” and the circuit for conversions of the Lee metric code to the p-adic memory system are so complicated that it is difficult to verify and specify the operations.
Therefore, it is effective if the circuit operations can be determined by observing the states of the input data and the data held in the cell array. It is possible to execute the verify using the fact that the state of the p-adic cell corresponding to a special data pattern becomes special. This verifying method is a method in which the process uses ‘0’ and ‘1’ as batch-processed data and monitors and determines the states of the memory cells in the cell array at that time.
The input data can be represented as in Expression 68.
D(h)=d0(2h)0+d1(2h)1+ . . . +dδ−3(2h)δ−3+dδ−2(2h)δ−2+dδ−1(2h)δ−1
D(h)=a0(p)0+a1(p)1+ . . . +aδ−2(p)δ−2+aδ−1(p)δ−1+aδ(p)δ [Expression 68]
The input data targeted to ECC batch processing is assumed 1 in binary. In this case, the binary and p-adic representations of the input data are as in Expression 69.
D=(d0,d1, . . . ,dδ−3,dδ−2,dδ−1)=(1,0, . . . ,0,0,0)
D=(a0,a1, . . . ,aδ−2,aδ−1,aδ)=(1,0, . . . ,0,0,0) [Expression 69]
When the input data is 1 in binary, and if Zp and the cell levels have the same correspondence in every memory cell, the multi-levels of a memory cell group operative to store the data are all set different.
There is no memory cell with the same level setting in the case where 0 is substituted for the numeral in binary data and in the case where 1 is substituted for the same. This is the necessary and sufficient condition on determination from the relations in Expression 70 because the Lee metric code turns 0 to a code word of (0, 0, . . . , 0, 0, 0), and 1 to a code word of (1, 2, . . . , p−3, p−2, p−1).
Which bit position is turned to ‘1’ to determine ‘1’ in the binary data depends on the setting of the circuit. Accordingly, if this conversion is made as an inherent correspondence, the data cannot be decoded easily.
As can be found from the condition on decision of the circuit operations, the correspondence between the cell levels and the numerals in Zp can be changed at every memory cell. The input binary and the stored data, that is, p-adic number, has no linear relation therebetween, and accordingly the converting circuit can set the correspondence between the binary and the p-adic number freely. Therefore, this circuit can be locked to make it difficult to conversely read the input data from the stored data directly. Thus, it is easily applied to the security of data as can be found.
In summary, the code conversion in the p-adic memory system according to the present embodiment provides the following correspondence between the code input to the memory system and the level recorded in the memory cell as a result.
(1) If a certain number of p-adic cells are treated as a processing unit, and when the input binary data is 0, a cell level corresponding to 0 in Zp is written in all p-adic cells contained in the processing unit.
(2) If (p−1) p-adic cells are treated as a processing unit, and when the input binary data contains ‘1’ only in 1 bit, all cell levels corresponding to 1 to p−1 in Zp are written in p-adic cells belonging to the processing unit.
(3) In the case of the above (2), and if the correspondence relations between the elements in Zp on all memory cells belonging to the processing unit and the cell levels are identical, the cell levels written in the memory cells belonging to the processing unit are all different from each other.
(4) From the above (1) and (2), if (p−1) p-adic cells are treated as the processing unit, in each memory cell belonging to the processing unit, the cell level written when the input binary data is 0 is different from the cell level written when the input binary data contains ‘1’ only in 1 bit.
Thus, multi-leveling of memory cells requires stable accurate operations in the prior art though the memory system according to the present embodiment applies high-efficiency error correction to make it possible to provide larger operational margins than the conventional system and accordingly provide further multi-leveling of memory cells.
[Others]
While certain embodiments have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of the inventions. Indeed, the novel methods and systems described herein may be embodied in a variety of other forms: furthermore, various omissions, substitutions and changes in the form of the methods and systems described herein may be made without departing from the spirit of the inventions. The accompanying claims and their equivalents are intended to cover such forms or modifications as would fall within the scope and spirit of the inventions.
The embodiments of the present invention are applicable to such memory systems that use cells having 3 or more levels. For example, they can be applied to memory systems using flash memories, DRAMs, PRAMs, and ReRAMs.
Number | Date | Country | Kind |
---|---|---|---|
2010-213215 | Sep 2010 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5500811 | Corry | Mar 1996 | A |
5790545 | Holt et al. | Aug 1998 | A |
20090198881 | Toda | Aug 2009 | A1 |
20100107039 | Toda | Apr 2010 | A1 |
Entry |
---|
U.S. Appl. No. 13/237,418, filed Sep. 20, 2011, Toda. |
U.S. Appl. No. 13/011,318, filed Jan. 21, 2011, Haruki Toda. |
Ron M. Roth, et al., “Lee-Metric BCH Codes and their Application to Constrained and Partial-Response Channels”, IEEE Transactions on Information Theory, vol. 40, No. 4, Jul. 1994, 14 Pages. |
Number | Date | Country | |
---|---|---|---|
20120079331 A1 | Mar 2012 | US |