The present disclosure relates to an apparatus and a method for improving data storage by data inversion.
It would be highly beneficial if improved concepts for multi-bit correction would be provided.
It becomes increasingly important to increase the reliability of memories and also to reduce power consumption in the new arising types memories.
A lot of types of memories, for example MRAM (Magnetoresistive Random Access Memory), R-RAM (Resistive Random Access Memory), exhibit an asymmetrical behavior with respect to permanent faults and errors. For example, a lot of memories exhibit in general more stuck-at-0 memory faults than stuck-at-1 memory faults. Other memories exhibit in general more stuck-at-1 memory faults than stuck-at-0 memory faults.
For example, flash-memories are asymmetrical with respect to power consumption for writing 1 or 0. In other words, power consumption differs, when a 1 is written into memory compared to when a 0 is written into memory. In R-RAMs errors are unidirectional, mainly, stuck-at-zero errors occur, but not stuck-at-one errors. Also, regarding MRAMs, mainly stuck-at-0 faults occur, but not stuck-at-1 faults.
It would be highly appreciated, if improved concepts for data storage would be provided.
An apparatus comprising a processing unit and a memory is provided. The processing unit is configured to encode a plurality of bits to obtain a plurality of encoded bits, and the processing unit is further configured to determine an inversion decision. When the inversion decision indicates that the subset of the encoded bits shall not be inverted, the processing unit is configured to store, as a stored word, bits of the first codeword into the memory. When the inversion decision indicates that the subset of the encoded bits shall be inverted, the processing unit is configured to invert each encoded bit of a subset of the encoded bits to obtain a second codeword and to store the second codeword into the memory.
An apparatus is provided. The apparatus comprises a processing unit, and a memory. The processing unit is configured to encode a plurality of bits to obtain a plurality of encoded bits by employing a linear error correcting code, wherein each of the plurality of encoded bits has a bit value, wherein the error correcting code has a code distance which is at least 3, and wherein the plurality of encoded bits forms a first codeword of the linear error correcting code. Moreover, the processing unit is configured to determine an inversion decision indicating whether a subset of the encoded bits shall be inverted or not depending on the subset of the encoded bits, wherein the subset of the encoded bits is determined such that the first codeword of the error correcting code is transformed into a second codeword of that code if all bits of the subset are inverted and wherein the subset comprises all encoded bits of the plurality of encoded bits or comprises at least three of the encoded bits of the plurality of encoded bits, and wherein an encoded bit of the subset of the encoded bits is an indication bit, wherein the bit value of the indication bit is equal to a first predefined bit value. When the inversion decision indicates that the subset of the encoded bits shall not be inverted, the processing unit is configured to store, as a stored word, bits of the first codeword into the memory, wherein the bits of the first codeword stored in the memory comprise the indication bit having the first predefined bit value. When the inversion decision indicates that the subset of the encoded bits shall be inverted, the processing unit is configured to modify the first codeword of the linear error correcting code to obtain the second codeword of the linear error correcting code by inverting each encoded bit of the subset of the encoded bits by changing its bit value, and is configured to store as the stored word the second codeword into the memory, wherein the second codeword comprises the indication bit being inverted so that the bit value of the indication bit is equal to a second predefined bit value being different from the first predefined bit value.
Moreover, another embodiment is provided. The apparatus comprises a processing unit, and a memory. In such another embodiment the processing unit is configured to supplement payload data bits x1, . . . , xn to be stored at an address a in an addressable memory by l bits bf1, . . . , bfl with constant values, wherein l≧1.
The processing unit is configured to encode the bits with constant values bf1, . . . , bfl and the payload data bits x1, . . . , xn with a linear code C correcting at least 1-bit errors into a codeword c1, . . . , cm, bf1, . . . , bfl, x1, . . . , xn, wherein c1, . . . , cm are check bits determined from bf1, . . . , bfl, x1, . . . , xn when bits derived from the address bits are not involved in forming a codeword, and coding of bits bf1, . . . , bfl, x1, . . . , xn, A1, . . . , Ak With a linear code C correcting at least 1-bit errors into a codeword c1, . . . , cm, bf1, . . . , bfl, x1, . . . , xn, A1, . . . , Ak, wherein c1, . . . , cm are check bits determined from bf1, . . . , bfl, x1, . . . , xn, A1, . . . , Ak, when bits A1, . . . , Ak derived from the address bits a1, . . . , ar are involved in encoding, and A1, . . . , Ak=f(a1, . . . , ar) are determined by a function f: 0,1r→{0,1}k from the address bits.
Moreover, the processing unit is configured to define K groups Y1, . . . , Yk Of bits of the bits c1, . . . , cm, bf1, . . . , bfl, x1, . . . , xn to be stored directly or invertedly so that a subset of defined bits bf1, . . . , bfl is uniquely allocated to each of these groups, wherein K≧1.
Furthermore, the processing unit is configured to select which group of bits of groups Y1, . . . , Yk is stored into the memory in an inverted or non-inverter manner.
The processing unit is configured to write the bits c1, . . . , cm, bf1, . . . , bfl, x1 . . . , xn into the memory at an address a, wherein bits belonging to a group of bits written into the memory invertedly are inverted prior to writing, and the bits not belonging to a group whose bits are inverted are written into the memory in a non-inverted manner,
Moreover, the processing unit is configured to read out the bits stored in the memory at an address a.
If the bits derived from the address bits are not involved in forming the codeword, the processing unit is configured to correct, based on the error correcting code C, bits read out from the memory possibly differing from values written to the same address due to an error, at least at the bit positions at which the constant values bf1, . . . , bfl have been stored directly or invertedly.
If the bits derived from the address bits are involved in forming the codeword, the processing unit is configured to correct, based on the error correcting code C, possibly erroneous values read out from the memory and by using possibly also erroneous bits A1′, . . . , Ak′ derived from the possibly erroneous address bits at least at the bit positions at which the constant values bf1, . . . , bfl have been stored directly or invertedly.
The processing unit is configured to determine from the read-out constant values corrected by using the code C and uniquely allocated to the respective bit groups, whether and which bit group has been written into the memory directly or invertedly.
The processing unit is configured to invert the read-out and corrected bits of the bit group that has been determined in the previous step as the bit groups whose bits have been inverted during writing.
In an embodiment, k=r and (A1, . . . , Ak)=(a1, . . . , ar) apply.
According to an embodiment, k=1, A1=f(a1, . . . , ar)=a1+a2+ . . . +ar applies, and A1 is the parity of the address bits a1, . . . , ar.
Moreover, a further embodiment is provided for directly or invertedly writing a subset of bits forming a codeword of a linear code C correcting at least 1-bit errors into a memory of memory cells directly or invertedly, and for reading and recovering the bits written into the memory from the bits read out possibly erroneously from the memory that were stored directly or invertedly. The apparatus comprises a processing unit, and a memory.
In such a further embodiment, the processing unit is configured to define the number K of subsets of the bits encoded with a linear code C correcting at least 1-bit errors that can be written into the memory directly or invertedly, wherein K≧1.
The processing unit is configured to provide n payload data bits x1, . . . , xn that are to be stored as a subword of a codeword of a linear systematic code correcting at least 1-bit errors at an address a=a1, . . . , ar with r≧2,
The processing unit is configured to form the information bits u1, . . . , uN of the code C, wherein then, if the address a is not involved in forming the codewords of the code C, the databits x1, . . . , xn are supplemented by l defined binary values bf1, . . . , bfl, so that
u
1
, . . . , u
N
=bf
1
, . . . , bf
l
,x
1
, . . . , x
n
with N=l+n applies, and if the address a is involved in forming the codewords of the code C, the data bits x1, . . . , xn and bits A1, . . . , Ak derived from address bits a1, . . . , ar are supplemented by l defined binary values bf1, . . . , bfl, so that
u
1
, . . . , u
N
=bf
1
, . . . , bf
l
,x
1
, . . . , x
n
,A
1
, . . . , A
k,
with N=l+n+k applies, wherein
A
1
, . . . , A
k
=f(a1, . . . , ar)
are binary values uniquely determined by a function f from the values of the r address bits a1, . . . , ar, l≧1 and 1≦k≦r,
wherein, if the address bits are not involved in error detection or error correction, the processing unit is configured to form a codeword y, . . . , yP of the code C, wherein C is a linear systematic code with a generator matrix G in systematic form and an H-matrix H, wherein
y=y
1
, . . . , y
P=(u1, . . . , uN)G·=c1, . . . , cm,bf1, . . . , bfl,x1, . . . , xn,
applies and c1, . . . , cm m are check bits, the generator matrix G is an (N,P)-matrix and the H-matrix H=(h1, . . . , hP) is an ([P−N],P)-matrix, so that all columns of the H-matrix are pairwise distinct and unequal to 0 and m=P−N and N=n+l applies,
wherein the processing unit is configured to determine K subsets Y1={y1,1, . . . , y1,q1}, . . . , YK={yK,1, . . . , yK,qK} of bits
y
1
, . . . , y
P
=c
1
, . . . , c
m
,bf
1
, . . . , bf
l
,x
1
, . . . , x
n,
so that a subset of bits bf1, . . . , bfl is uniquely allocated to each subset Y1, . . . , Yk,
so that if y1b, . . . , yPb are binary values of the bits y1, . . . , yP, then y1b, . . . , yPb is the codeword of the code C when for k=1, . . . , K and for j=1, . . . , P, if yj is an element of the subset Yk, then y1b=1 and if yj is no element of subset Yk, then y1b=0, so that
H·(y1b, y2b, . . . , yPb)=0
applies and H is the H-matrix of the code C,
wherein the processing unit is configured to define which group of groups of bits Y1, . . . , Yk is written into the memory directly or invertedly,
wherein the processing unit is configured to form the P bits d1, . . . , dP to be written into the memory, wherein for 1, . . . P, di=
wherein the processing unit is configured to write the bits d1, . . . , dP into the memory at an address a,
wherein the processing unit is configured to create an address a and to read out the possibly erroneous values d1′, . . . , dP′, stored at the address a, which have originated from the values d1, . . . , dP written at the address a by possible errors,
wherein the processing unit is configured to define L bit positions k1, . . . , kL to be corrected by code C with l≦P and {k1, . . . , kL}⊂{1, . . . , P}, that are to be corrected by using the code C in the case of an erroneous value, wherein the bit positions at which bf1, . . . , bfl have been stored directly or invertedly belong to the bit positions to be corrected,
wherein the processing unit is configured to determine binary correction values ek
wherein the processing unit is configured to form corrected bits
d
k
cor
=d′
k
ope
k
at least at the bit positions at which values bf1, . . . , bfl have been stored directly or invertedly, wherein op is a uniquely invertible Boolean operation,
wherein the processing unit is configured to determine, based on the known inserted values bf1, . . . , bfl and the respective read-out values corrected by using the code C, for which group Y1, . . . , Yk the bits have been stored directly or invertedly,
wherein the processing unit is configured to output the bits
y
k
cor
=d′
k
ope
k
if yk
y
k
cor=
if yk
wherein, if the address bits are involved in error detection and error correction, the processing unit is configured to form a codeword y=y1, . . . , yP of the code C, wherein C is a linear systematic code with a generator matrix G in systematic form and an H-matrix H, wherein
applies, the generator matrix G is an (N,P)-matrix and the H-matrix H=(h1, . . . , hP) is an ([P−N],P)-matrix, so that all columns of the H-matrix are pairwise distinct and unequal to 0 and P=n+l+m+k and c1, . . . , cm are check bits, (N durch P ersetzt)
wherein the processing unit is configured to determine K subsets Y1={y1,1, . . . , y1,q1}, . . . , YK={yK,1, . . . , yK,qK} of the bits
y
1
, . . . , y
n+l
, y
n+l+k+1
, . . . , y
P
=c
1
, . . . , c
m
,bf
1
, . . . , bf
l
,x
1
, . . . , x
n,
so that each bit of the bits bf1, . . . , bfl, belongs to only one of the subsets Y1, . . . , YK, and so that If y1b, . . . , yPb are binary values of the bits y1, . . . , yP, then y1b, . . . , yPb is a codeword of the code C if for k=1, . . . , K and for j=1, . . . , P, it applies that
if yj is an element of the subset Yk, then yjb=1 and if yj is no element of the subset Yk, then yjb=0, so that
H·(y1b, y2b, . . . , yPb)=0
applies and H is the H-matrix of code C,
wherein the processing unit is configured to define which group of bits Y1, . . . , Yk are written into the memory directly or invertedly,
wherein the processing unit is configured to form the P−k bits d1, . . . , dm+l+n, to be written into the memory, wherein for i=1, . . . , m+n+l,
di=yi when yi belongs to a group whose bits are written into the memory directly, and
di=
wherein the processing unit is configured to write the bits d1, . . . , dm+n+l at an address a into the memory,
wherein the processing unit is configured to create an address a and reading out possibly erroneous values d1′, . . . , dm+n+l′ stored at the address a, which have originated from values d1, . . . , dn+l+dn+k+1, . . . , dP written at the address a by possible errors,
wherein the processing unit is configured to define L bit positions k1, . . . , kL to be corrected by code C with L≦P−k and {k1, . . . , kL}⊂{1, . . . , n+l,n+l+k+1,P}, that are corrected by using the code C in the case of an erroneous value, wherein the bit positions at which bf1, . . . , bfl have been stored directly or invertedly belong to the bit positions to be corrected,
wherein the processing unit is configured to determine binary correction values ek
wherein the processing unit is configured to form corrected bits
d
k
cor
=d′
ki
ope
k
at least at the bit positions at which the values bf1, . . . , bfl have been stored directly or invertedly, wherein “op” is a binary clearly reversible operation,
wherein the processing unit is configured to determine, based on the known inserted values bf1, . . . , bfl and the corresponding correct values read out and corrected by using the code C, for which group of the bits Y1, . . . , Yk the bits have been stored directly or invertedly, and
wherein the processing unit is configured to output the bits
y
k
cor
=d′
k
ope
k
if yk
y
k
cor=
if yk
According to another embodiment, an apparatus for storing bits in a memory is provided, wherein the bits are encoded with a linear error correcting code C, the linear error correcting code C having a code distance which is at least 3, wherein it is determined whether a subset of the bits encoded with the linear error correcting code C is written into the memory directly or in a bit-by-bit inverted manner, and wherein the code C comprises an H-matrix H, wherein the apparatus comprises a processing unit, and a memory. A subset of bits written into the memory either directly or invertedly comprises at least one binary constant value, which is together with payload data bits used for coding for forming a codeword of the linear code C. The processing unit is configured to write the binary constant value as a binary value bf into the memory when the bits of the respective subset of bits are directly written into the memory. The processing unit is configured to write the binary constant value into the memory as an inverted value
The processing unit is configured to convert a codeword of the code C to a codeword of the same code when the subset of bits written into the memory either directly or invertedly is inverted and the H-matrix of the code is formed such that the number of ones of each component of the columns of the H-matrix corresponding to the subset of bits written into the memory either directly or invertedly, is even.
Moreover, the processing unit is configured to correct, when reading out from the memory, possibly erroneous bits read out from the memory by using the linear error correcting code C, wherein at least that bit at the bit position at which the constant binary value bf has been written is corrected when the respective subset of bits has been written into the memory directly, or at the bit position at which the constant binary value
Furthermore, the processing unit is configured to invert bits of the subset of bits that have been written into the memory directly or invertedly after reading out when the corrected value that has been read out at the bit position at which the constant value bf or the inverted constant value
According to another embodiment, a method is provided. The method comprises:
Embodiments are based on the finding that data inversion may be employed for data storage. According to embodiments, data inversion allows to mask permanent faults. This is especially useful when the error rate is relatively high when a memory is relatively new.
If a stuck-at-0 fault occurs at a data location, no error occurs if the bit to be stored at this location is 0. But an error occurs if the bit to be stored is 1. If the bit to be stored is 1, for the inverted data the bit to be stored at this location is 0 and no error occurs, if the bit is stored invertedly.
According to embodiments, if there are several stuck-at faults, it is very useful to invert or not to invert different groups of data in a dataword separately. By this, the stored data can be adapted to the occurring faults by inverting groups of data.
Moreover, data inversion allows to reduce power consumption, for example, if storing a 1 requires more energy than storing a zero, or vice versa.
For example, if an erased state is denoted by 1, for writing a 0 much more energy may be needed than for writing a 1. Or, for example, if the number of 0th in a data word is greater than the number of 1th it is useful to invert the data before storing.
According to embodiments, a better adaption can be achieved if the data is inverted in a groupwise way.
According to embodiments, data inversion is employed to reduce the error rate. If errors occur unidirectionally, for example, a 1 to be stored is changed to 0, e.g., by a stuck-at-0 fault, the bits which are equal to 0 will not be changed to an error state.
If the number of 1s in a data word is greater than the number of 0s, it is useful to invert the data before storing, when more stuck-at-0 faults are present than stuck-at-1 faults. Then, after inversion, the number of 0s is greater than the number of 1s and the number of possible errors is reduced.
A better adaption can be achieved if the data are inverted in a groupwise way.
According to embodiments, a “fixbit” is added to the data bits. The data bits and the fixbit are jointly used as information bits of an error correcting linear code C, and the check bits are determined from the information bits, i.e. the data bits and the fixbit.
According to embodiments, the code C is chosen such that if a word w is a codeword, the inverted codeword
According to embodiments, if an erroneous bit occurred, also the fix-bit is corrected using the error correcting code C. After correction, the corrected fixbit indicates whether or not the data stored in the memory are to be inverted. According to embodiments, the fix-bit is corrected by the same linear code C, by which the data bits and the check bits are also corrected.
In embodiments, groups or subsets of bits of a codeword are inverted. Fixbits, indicating a group is inverted or not, are assigned to every subgroup. All these fixbits are part of the information bits for determining the check-bits.
According to embodiments, the subgroups are selected such that the inversion of the bits of a subgroup transforms a codeword of the code C into a codeword of C.
In some embodiments, address bits are part of the codeword but are not stored, and address bits are not inverted.
According to embodiments, fix-bits (inversion-flag-bits) are part of the error correction by the linear code.
In some embodiments, subgroups of bits are inverted.
According to embodiments, the code is selected such that the inversion of the bits of a subgroup transforms a codeword into a codeword.
In some embodiments, addresses are included in the determination of the checkbits, but are not inverted.
Before embodiments are described in detail using the accompanying figures, it is to be pointed out that the same or functionally equal elements are given the same reference numbers in the figures and that a repeated description for elements provided with the same reference numbers is omitted. Hence, descriptions provided for elements having the same reference numbers are mutually exchangeable.
An apparatus comprising a processing unit and a memory is provided. The processing unit is configured to encode a plurality of bits to obtain a plurality of encoded bits, the processing unit is configured to determine an inversion decision. When the inversion decision indicates that the subset of the encoded bits shall not be inverted, the processing unit is configured to store, as a stored word, bits of the first codeword into the memory. When the inversion decision indicates that the subset of the encoded bits shall be inverted, the processing unit is configured to invert each encoded bit of a subset of the encoded bits of the first codeword to obtain a second codeword and to store the second codeword into the memory.
As stated above, the plurality of encoded bits forms a first codeword of the linear error correcting code. This means that the encoded bits of the plurality of all the encoded bits form a first codeword of the error correcting code.
In an embodiment, the processing unit may, for example, be configured to generate a decision signal as the inversion decision, wherein the decision signal may, e.g., indicate whether a subset of the encoded bits shall be inverted or not.
According to an embodiment, the apparatus may be a circuitry.
In an embodiment, the subset of the encoded bits comprises all encoded bits of the plurality of encoded bits.
According to an embodiment, the subset of the encoded bits does not comprise all encoded bits of the plurality of encoded bits.
In an embodiment, the error correcting code is a linear error correcting code C, wherein the first predefined value is a first constant binary value bf, wherein the second predefined value is a second constant binary value
According to an embodiment, the error correcting code is a linear error correcting code C, wherein the first predefined value is a first constant binary value bf, wherein the second predefined value is a second constant binary value
In an embodiment, the linear error correcting code C comprises a parity check matrix H, wherein the number of ones of each component of the columns of the parity check matrix H is even.
According to an embodiment, the memory 110 is a register, or a register array, or an addressable memory 110.
In an embodiment, the memory is an addressable memory and the processing unit 120 is configured to encode the plurality of bits to obtain the plurality of encoded bits by employing the linear error correcting code, and by using address bits.
According to an embodiment, the processing unit 120 is configured to determine the inversion decision depending on the number of zeros of the subset of the encoded bits or the number of ones of the subset of the encoded bits.
In an embodiment, when after writing write values into the memory, after subsequently reading out the write values from the memory to obtain read values, and after comparing the write values and read values, no error has occurred, the processing unit is configured to determine the inversion decision so that the inversion decision indicates that the subset of encoded bits shall not be inverted.
In an embodiment, when after writing write values into the memory, after subsequently reading out the write values from the memory to obtain read values, and after comparing the write values and read values, a number of T errors have occurred at the most wherein T is smaller than or equal to the number of errors that can be corrected by the linear error correcting code, the processing unit is configured to determine the inversion decision so that the inversion decision indicates that the subset of encoded bits shall not be inverted.
In an embodiment, when, after writing inverted write values of a subset of bits into the memory 110, after subsequently reading out the written inverted write values from the memory 110 to obtain read values, and after comparing the written inverted write values and the read values, so many errors have occurred at the most as have occurred after direct writing and comparison of the read-out values and the written values, the processing unit 120 is configured to determine the inversion decision so that the inversion decision indicates that the subset of the encoded bits shall be inverted.
According to an embodiment, when, after writing inverted write values of a subset of bits into the memory 110, after subsequently reading out the written inverted write values from the memory 110 to obtain read values, and after comparing the written inverted write values and the read values, T errors have occurred at the most, wherein T is smaller than the number of errors that can be corrected by the code C, the processing unit 120 is configured to determine the inversion decision so that the inversion decision indicates that the subset of the encoded bits shall be inverted.
In an embodiment, the memory 110 is a Flash memory 110.
According to another embodiment, the memory 110 is an M-RAM or wherein the memory 110 is an R-RAM.
In an embodiment, the error correcting code comprises a generator matrix, wherein the processing unit 120 is configured to encode the plurality of bits by using the generator matrix in its systematic form for encoding.
According to another embodiment, the code C is a Hamming code or a shortened Hamming code.
In an embodiment, the error correcting code is a Hsiao code or a shortened Hsiao code.
According to another embodiment, the code C is a BCH code or a shortened BCH code.
Moreover, another embodiment is provided. In such another embodiment, the processing unit 120 is configured to supplement payload-data bits x1, . . . , xn to be stored at an address a in an addressable memory 110 by l bits bf1, . . . , bfl with constant values, wherein l≧1.
The processing unit 120 is configured to encode the bits with constant values bf1, . . . , bfl and the payload data bits x1, . . . , xn with a linear code C correcting at least 1-bit errors into a codeword c1, . . . , cm, bf1, . . . , bfl, x1, . . . , xn, wherein c1, . . . , cm are check bits determined from bf1, . . . , bfl, x1, . . . , xn when bits derived from the address bits are not included in forming a codeword, and coding of bits bf1, . . . , bfl, x1, . . . , xn, A1, . . . , Ak with a linear code C correcting at least 1-bit errors into a codeword c1, . . . , cm, bf1, . . . , bfl, x1, . . . , xn, A1, . . . , Ak, wherein c1, . . . , cm are check bits determined from bf1, . . . , bfl, x1, . . . , xn, A1, . . . , Ak, when bits A1, . . . , Ak derived from the address bits a1, . . . , ar are involved in encoding, and A1, . . . , Ak=f(a1, . . . , ar) are uniquely determined by a function f: {0,1}r→{0,1}k from the address bits.
Moreover, the processing unit 120 is configured to define K groups Y1, . . . , Yk of bits of the bits c1, . . . , cm, bf1, . . . , bfl, x1, . . . , xn to be stored directly or invertedly so that a subset of defined bits bf1, . . . , bfl is uniquely assigned to each of these groups, wherein K≧1.
The processing unit 120 is configured to determine the groups of bits Y1, . . . , YK such that a first codeword of the linear Code C is transformed into a second codeword of the code C if all the bits of a group Yj, j=1, . . . , K, are inverted and wherein the processing unit is configured to select which group of bits of groups Y1, . . . , YK is stored into the memory in an inverted or non-inverter manner.
The processing unit 120 is configured to write the bits c1, . . . , cm, bf1, . . . , bfl, x1, . . . , xn into the memory at an address a, wherein bits belonging to a group of bits written into the memory 110 invertedly are inverted prior to writing, and the bits not belonging to a group whose bits are inverted are written into the memory 110 in a non-inverted manner.
Moreover, the processing unit 120 is configured to read out the bits stored in the memory 110 at an address a.
If the bits derived from the address bits are not involved in forming the codeword, the processing unit 120 is configured to correct, based on the error correcting code C, bits read out from the memory 110 possibly differing from values written to the same address due to an error, at least at the bit positions at which the constant values bf1, . . . , bfl have been stored directly or invertedly.
If the bits derived from the address bits are involved in forming the codeword, the processing unit 120 is configured to correct, based on the error correcting code C, possibly erroneous values read out from the memory 110 and by using possibly also erroneous bits A′1, . . . , A′k derived from the possibly erroneous address bits at least at the bit positions at which the constant values bf1, . . . , bfl have been stored directly or invertedly.
The processing unit 120 is configured to determine from the read-out constant values corrected by using the code C uniquely assigned to the respective bit groups, whether and which bit group has been written into the memory directly or invertedly.
The processing unit 120 is configured to invert the read-out and corrected bits of the bit group that has been determined in the previous step as the bit groups whose bits have been inverted during writing.
In an embodiment, k=r and (A1, . . . , Ak)=(a1, . . . , ar) apply.
According to an embodiment, k=1, A1=f(a1, . . . , ar)=a1+a2+ . . . +ar applies, and A is the parity of the address bits a1, . . . , ar.
Moreover, a further embodiment is provided for directly or invertedly writing a subset of bits forming a codeword of a linear code C correcting at least 1-bit errors into a memory 110 of memory cells directly or invertedly, and for reading and recovering the bits written into the memory 110 from the bits read out possibly erroneously from the memory 110 that were stored directly or invertedly. In such a further embodiment, the processing unit 120 is configured to define the number K of subsets of the bits encoded with a linear code C correcting at least 1-bit errors that can be written into the memory 110 directly or invertedly, wherein K≧1.
The processing unit 120 is configured to provide n payload data bits x1, . . . , xn that are to be stored as a subword of a codeword of a linear systematic code correcting at least 1-bit errors at an address a=a1, . . . , ar with r≧2,
The processing unit 120 is configured to form the information bits u1, . . . , uN of the code C, wherein then, if the address a is not involved in forming the codewords of the code C, the databits x1, . . . , xn are supplemented by l defined binary values bf1, . . . , bfl, so that
u
1
, . . . , u
N
=bf
1
, . . . , bf
l
,x
1
, . . . , x
n
with N=l+n applies, and if the address a is involved in forming the codewords of the code C, the data bits x1, . . . , xn and bits A1, . . . , Ak derived from address bits a1, . . . , ar are supplemented by l defined binary values bf1, . . . , bfl, so that
u
1
, . . . , u
N
=bf
1
, . . . , bf
l
,x
1
, . . . , x
n
,A
1
, . . . , A
k,
with N=l+n+k applies, wherein
A
1
, . . . , A
k
=f(a1, . . . , ar)
are binary values uniquely determined by a function f from the values of the r address bits a1, . . . , ar, l≧1 and 1≦k≧r,
wherein, If the address bits are not involved in error detection or error correction. the processing unit 120 is configured to form a codeword y, . . . , yP of the code C, wherein C is a linear systematic code with a generator matrix G in systematic form and an H-matrix H, wherein
y=y
1
, . . . , y
P=(u1, . . . , uN)G·=c1, . . . , cm,bf1, . . . , bfl,x1, . . . , xn,
applies and c1, . . . , cm m are check bits, the generator matrix G is an (N,P)-matrix and the H-matrix H=(h1, . . . , hP) is an ([P−N],P)-matrix, so that all columns of the H-matrix are pairwise distinct and unequal to 0 and m=P−N and N=n+l and P=n+m+l applies,
wherein the processing unit 120 is configured to determine K subsets
Y
1
={y
1,1
, . . . , y
1,q1
}, . . . , Y
K
={y
K,1
, . . . , y
K,qK} of bits
y
1
, . . . , y
N
=c
1
, . . . , c
m
,bf
1
, . . . , bf
l
,x
1
, . . . , x
n,
so that a subset of bits bf1, . . . , bfl is clearly allocated to each subset Y1, . . . , Yk,
so that if y1b, . . . , yPb are binary values of the bits y1, . . . , yP, then y1b, . . . , yPb is the codeword of the code C when for k=1, . . . , K and for j=1, . . . , P, if yj is an element of the subset Yk, then y1b=1 and if yj is no element of subset Yk, then y1b=0, so that
H·(y1b,y2b, . . . , yPb)=0
applies and H is the H-matrix of the code C,
wherein the processing unit 120 is configured to define which group of groups of bits Y1, . . . , Yk is written into the memory 110 directly or invertedly,
wherein the processing unit 120 is configured to form the P bits d1, . . . , dP to be written into the memory 110, wherein for 1, . . . P, di=
wherein the processing unit 120 is configured to write the bits d1, . . . , dP into the memory 110 at an address a,
wherein the processing unit 120 is configured to create an address a and to read out the possibly erroneous values d1′, . . . , dP′ stored at the address a, which have originated from the values d1, . . . , dP written at the address a by possible errors,
wherein the processing unit 120 is configured to define L bit positions k1, . . . , kL to be corrected by code C with l≦P and {k1, . . . , kL}⊂{1, . . . , P}, that are to be corrected by using the code C in the case of an erroneous value, wherein the bit positions at which bf1, . . . , bfl have been stored directly or invertedly belong to the bit positions to be corrected,
wherein the processing unit 120 is configured to determine binary correction values ek
wherein the processing unit 120 is configured to form corrected bits
d
k
cor
=d′
ki
ope
k
at least at the bit positions at which values bf1, . . . , bfl have been stored directly or invertedly, wherein op is a uniquely invertible Boolean operation,
wherein the processing unit 120 is configured to determine, based on the known inserted values bf1, . . . , bfl and the respective read-out values corrected by using the code C, for which group Y1, . . . , Yk the bits have been stored directly or invertedly,
wherein the processing unit 120 is configured to output the bits
y
k
cor
=d′
ki
ope
k
if Yk
y
k
cor=
if yk belongs to a group of bits that have been written into the memory 110 invertedly during writing into the memory 110, wherein “op” is a two-ary uniquely invertible Boolean operation,
wherein, if the address bits are involved in error detection and error correction, the processing unit 120 is configured to form a codeword y=y1, . . . , yP of the code C, wherein C is a linear systematic code with a generator matrix G in systematic form and an H-matrix H, wherein
applies, the generator matrix G is an (N,P)-matrix and the H-matrix H=(h1, . . . , hP) is an ([P−N],P)-matrix, so that all columns of the H-matrix are pairwise distinct and unequal to 0 and P=n+l+m+k, N=n+l+k holds and c1, . . . , cm are check bits,
wherein the processing unit 120 is configured to determine K subsets Y1={y1,1, . . . , y1,q1}, . . . , YK={yK,1, . . . , yK,qK} of the bits
y
1
, . . . , y
n+l
, y
n+l+k+1, . . . ,
y
P
=c
1
, . . . , c
m
,bf
1
, . . . , bf
l
,x
1
, . . . , x
n,
so that each bit of the bits bf1, . . . , bfl, belongs to only one of the subsets Y1, . . . , YK, and so that If y1b, . . . , yPb are binary values of the bits y1, . . . , yP, then y1b, . . . , yPb is a codeword of the code C if for k=1, . . . , K and for j=1, . . . , P, it applies that
if yj is an element of the subset Yk, then yjb=1 and if yj is no element of the subset Yk, then yjb=0, so that
H·(y1b,y2b, . . . , yPb)=0
applies and H is the H-matrix of code C,
wherein the processing unit 120 is configured to define which group of bits Y1, . . . , Yk are written into the memory 110 directly or invertedly,
wherein the processing unit 120 is configured to form the P−k bits d1, . . . , dm+l+n, to be written into the memory 110, wherein for i=1, . . . , m+n+l,
di=yi when yi belongs to a group whose bits are written into the memory 110 directly, and
di=
wherein the processing unit 120 is configured to write the bits d1, . . . , dm+n+l at an address a into the memory 110,
wherein the processing unit 120 is configured to create an address a and reading out possibly erroneous values d1′, . . . , dm+n+l′ stored at the address a, which have originated from values d1, . . . , dn+l,dn+k+1, . . . , dP written at the address a by possible errors,
wherein the processing unit 120 is configured to define L bit positions k1, . . . , kL with L≦P−k that are corrected by using the code C in the case of an erroneous value, wherein the bit positions at which bf1, . . . , bfl have been stored directly or invertedly belong to the bit positions to be corrected,
wherein the processing unit 120 is configured to determine binary correction values ek
wherein the processing unit 120 is configured to form corrected bits
d
k
cor
=d′
ki
ope
k
at least at the bit positions at which the values bf1, . . . , bfl have been stored directly or invertedly, wherein “op” is a binary uniquely invertible operation,
wherein the processing unit 120 is configured to determine, based on the known inserted values bf1, . . . , bfl and the corresponding correct values read out and corrected by using the code C, for which group of the bits Y1, . . . , Yk the bits have been stored directly or invertedly, and
wherein the processing unit 120 is configured to output the bits
y
k
cor
=d′
k
ope
k
if yk
y
k
cor=
if yk
According to another embodiment, an apparatus for storing bits in a memory 110 is provided, wherein the bits are encoded with a linear error correcting code C, the linear error correcting code C having a code distance which is at least 3, wherein it is determined whether a subset of the bits encoded with the linear error correcting code C is written into the memory 110 directly or in a bit-by-bit inverted manner, and wherein the code C comprises an H-matrix H, wherein the apparatus comprises a processing unit 120, and a memory 110. A subset of bits written into the memory 110 either directly or invertedly comprises at least one binary constant value, which is together with payload data bits used for coding for forming a codeword of the linear code C. The processing unit 120 is configured to write the binary constant value as a binary value bf into the memory 110 when the bits of the respective subset of bits are directly written into the memory 110. The processing unit 120 is configured to write the binary constant value into the memory 110 as an inverted value
The processing unit 120 is configured to convert a codeword of the code C to a codeword of the same code when the subset of bits written into the memory 110 either directly or invertedly is inverted and the H-matrix of the code is formed such that the number of ones of each component of the columns of the H-matrix corresponding to the subset of bits written into the memory 110 either directly or invertedly, is even.
Moreover, the processing unit 120 is configured to correct, when reading out from the memory 110, possibly erroneous bits read out from the memory 110 by using the linear error correcting code C, wherein at least that bit at the bit position at which the constant binary value bf has been written is corrected when the respective subset of bits has been written into the memory 110 directly, or at the bit position at which the constant binary value
Furthermore, the processing unit 120 is configured to invert bits of the subset of bits that have been written into the memory 110 directly or invertedly after reading out when the corrected value that has been read out at the bit position at which the constant value bf or the inverted constant value
According to another embodiment, a method is provided. The method comprises:
In the following, basic principles of embodiments are described.
Embodiments relate to writing data into memories and reading the data from the memories. Embodiments allow to directly or invertedly write subsets or groups of bits, which shall be stored, into a memory in an effective manner, and further allows to restore them in their original form when reading them from the memory.
Whether a subset or a group of bits is written into a memory directly or invertedly may, for example, be determined by the values of the bits of the subset, or may, e.g., be determined by the characteristics of the memory with respect to errors or energy consumption, or may, for example, be determined by other characteristics.
For example, for a memory which exhibits permanent memory errors with value 0 more often than memory errors with value 1, it can be advantageous to write the bits to be stored into the memory directly (as they have more zeros than ones), since then the probability that a value 0 will be written into a memory cell, which exhibits a permanent memory error wherein the bit is stuck-at 0, is higher compared to the probability that a value 1 is written into such a memory cell. Thereby, the probability that a permanent memory error results in erroneous behaviour can be reduced.
It is also possible to write bits tentatively into the memory directly and then invertedly and to decide then the variant where less errors have occurred.
Many non-volatile memory concepts, such as the classic floating gate memory (e.g., EEPROM=electrically erasable programmable read-only memory, Flash) or charge trapping memory (e.g., MONOS, Nanodot), but also novel memory concepts such as MRAM=Magnetoresistive Random Access Memory, R-RAM, PCRAM or CBRAM (Conductive Bridging Random Access Memory), have intrinsically given preferred values for the reliability of the cells, or for the current consumption during writing. For example, the classical floating gate exhibits an erratic bit, well-known by a person skilled in the art, wherein the erratic bit indicates data corruption when programming a state with a low cut-off voltage. The current consumption during reading or writing depends significantly on the data pattern to be programmed/to be read. The reading of cells with low cut-off voltage inherently requires significantly more current compared to reading with a high cut-off voltage. When programming, the situation might possibly be opposite. For example, when hot-carrier programming, only the cell that has to be brought into the state with high cut-off voltage needs programming current. The situation is similar for the charge trapping concept. Likewise, for novel memories, e.g., MRAM, exhibiting energetic asymmetry of the magnetic anisotropic energy, the higher energetic state is more at danger in data storage than the state having lower energy. Embodiments, however, may not only be employed for non-volatile memories, but can also be used, for example, for permanent errors or for errors occurring more frequently for a particular state within an SRAM or DRAM.
If the energy consumption during writing a first binary value b1 is higher than during writing a second binary value b2=
Based on the number of values b1 or based on the number of bits b2 of a subset of bits of a group of bits, it can be decided, whether the bits of the group are to be written into the memory invertedly or directly. By this, the effort for determining, whether a subset of bits is written into the memory directly or invertedly, can be reduced.
In embodiments, the bits to be stored shall, e.g., be encoded by using a linear error correcting code C having a generator matrix G and an H-matrix or parity check matrix H, wherein address bits, indicating where the bits are to be stored, may, but need not be involved in the encoding. For example, it may be advantageous to perform encoding with a generator matrix G, being in a systematic form, wherein the G-matrix comprises a unit matrix as a sub-matrix, wherein the H-matrix in some embodiments may exhibit a systematic form and in other embodiments may exhibit a non-systematic form. In order to check, when reading out bits from the memory, whether bits of a subset of bits have been written into the memory directly or invertedly, the bits (which may, for example, later again be stored) are supplemented by constant binary values. Here, the supplemented constant binary values are involved in forming the respective codewords of the linear code.
The subsets of the bits that are directly or invertedly written into the memory are formed such that a codeword of the code C, which has been formed from non-inverted bits, is transferred into another codeword of the code C, when the bits of a subset of bits, that can be written into the memory invertedly or directly, are inverted.
This characteristic advantageously allows performing correction of bits being read out from the memory and possibly of erroneous bits on the basis of the error correcting code C without having to know, for the correction of the bits read out from the memory, whether the bits from the read-out subset of bits have been written into the memory directly or invertedly.
When reading out the data from the memory, then, after correcting the data by using the corrected bits in the bit positions at which the bits with the constant values have been written directly or invertedly, it can be found out whether the bits of a subset or group of bits has been written into the memory directly or invertedly.
Linear error correcting codes, known to the skilled person, are used as error correcting codes. Examples for such codes are Hamming codes, Hsiao codes, BCH codes, etc. Frequently, shortened codes are used, such as shortened Hamming codes, shortened Hsiao codes or shortened BCH codes, to adapt the codes to the necessary bit width of the data to be stored. Shortened codes can be obtained from unshortened codes by deleting columns of the respective H-matrix not corresponding to the check bits.
For better understanding of used terms and the description of embodiments, several basic terms of codes will briefly be described in the following.
A linear code C comprises a generator matrix or G-matrix G and an H-matrix H. If C is a (Q,N)-code, then a codeword comprises Q bits, wherein a codeword is designated by y=y1, . . . , yQ, and N information bits exist, referred to as u=u1, . . . , uN, wherein Q>N applies.
The G-matrix is an (N,Q)-matrix having N rows and Q columns, the H-matrix is an (m,Q)-matrix, wherein m=Q−N applies. From the information bits u, a codeword y is determined according to the relationship
y=u·G
If the code C is a systematic code, then the generator matrix G has the form
G=(PN,m,IN) with m=Q−N,
wherein IN is the N-dimensional unit matrix and PN,m is the parity matrix.
An assigned H-matrix may be defined as
H=(Im,Pm,NT),
wherein Im is the m-dimensional unit matrix and Pm,NT is the transpose of the parity matrix PN,m, where rows and columns are exchanged. If the values of N, Q, m are not to be referred to specifically, or if these values are known from the context, then simply G=(P,I) and H=(I,PT) is written.
It is known that the G-matrix and the H-matrix in systematic form are also used as G=(I,P) and H=(PT,I), what has the effect, that the check bits are arranged at the left of the information bits within a codeword, or that the check bits are arranged at the right of the information bits within a codeword.
The N rows of the G-matrix are codewords of the code C.
In a systematic code C
y=y
1
, . . . , y
Q=(u1, . . . , uN)·G·=c1, . . . , cm,u1, . . . , un,
applies, wherein c1, . . . , cm, u1, . . . , uN·P are check bits of the codeword y1, . . . , yQ. The information bits u1, . . . , uN are an unamended part of the codeword, wherein the check bits are added to the information bits. Due to errors, a codeword y=y1, . . . , yQ can be corrupted to a different word y′=y′1, . . . , y′Q, wherein e with
e=e
1
, . . . , e
Q
=y
1
+y′
1
, . . . , y
Q
+y′
Q
=y+y′
is referred to as error vector, and wherein “+” designates the component-wise addition modulo 2 or the XOR operation.
The error syndrome s of a word y′ is
s=H·y′,
wherein s=s1, . . . , sm comprises m components. The error syndrome of a word y* is exactly equal to 0, if y* is a codeword of the code C.
If y is a codeword and if y′ is an erroneous word resulting from errors, wherein y+y′=e, then the following applies
H·(y′)=H·(0+y′)=H·(y+y′)=H·e
and the error syndrome of the word y′ only depends on the error vector, e by which y′ differs from the codeword y.
If an i-bit error exists, exactly i bits of the error vector e are equal to 1, and all other components are equal to 0. If, for example, exactly one component of the error vector e is equal to 1, then a 1-bit error exists in the bit where the component of e is equal to 1.
If the code C is a 1-bit error correcting code, then the error syndromes of all 1-bit errors are pairwise distinct and are different from 0, and to each of these error syndromes, a particular 1-bit error is then uniquely allocated. A decoder implemented as a decoder circuit then determines from the error syndrome applied to its input, which bit position is to be inverted/corrected.
If the code C is a 2-bit error correcting code, then the error syndromes of all 2-bit errors and all 1-bit errors are pairwise different and are also different from 0, and to each of these error syndromes, a determined 2-bit error or 1-bit error is uniquely allocated. A decoder realized as a decoder circuit then determines from the error syndrome applied to its input, which bit position is inverted/corrected. Respective statements apply for 3-bit error correcting codes, 4-bit error correcting codes, . . . , etc.
The error syndrome may, e.g, be determined by a syndrome generator implementing for a word w=w1, . . . , wQ the relation
s(w)=H·w
for example by using XOR gates.
If y=y1, . . . , yQ and v=v1, . . . , vQ are codewords of the code C, then y+v is also a codeword of the code C.
Furthermore, the following applies:
If y=y1, . . . , yQ is a codeword of the code C, and w=w1, . . . , wQ is a word having the error syndrome s(w)=H·w, then the error syndrome of the word w+y is equal to the error syndrome s(w) of the word w, since
H·(y+w)=H·y·H·w=s(w)
applies, and since the error syndrome of a word does not change when a codeword is added modulo 2 by a component-wise addition to the word. Adding a codeword y=y1, . . . , yQ to a word w=w1, . . . , wQ means that those components of w are inverted, where the components of y are equal to 1.
If specifically
is a codeword of the code C, then, with y=y1, . . . , yQ,
If M is a subset of bits of a codeword y=y1, . . . , yQ of the error correcting code C whose bits are written into the memory directly or invertedly, it is advantageous when the word
y
M
=y
1
M
, . . . , y
Q
M with yiM=1, for yiεM and yiM=0 for yiεM
is a codeword of the code C.
If the bits of a codeword y1, . . . , yQ that belong to the set Mare inverted, then the resulting word y1+y1M, y2+Y2M, . . . , yQ+yQM is again a codeword. Independent of whether the original codeword y1, . . . , yQ or the codeword inverted in the bits, which belong to the set M, is written into the memory, in both cases a codeword of the code C is written into the memory. When reading out the stored, possibly erroneous codeword y′=y′1, . . . , y′Q or (y+yM)′, the correction of read-out bits with the code C can be performed based on the error syndrome formed of y′ or (y+y)′, without having to know whether y or the codeword y+yM, which is inverted in the bits belonging to the set M, has been written into the memory, since the error syndrome depends only on the occurred errors, e.g., only on the occurred error vector e, and not on which codeword has been written into the memory. It may, for example, be advantageous that the values read out at the bit positions, at which the constant binary values bf1, . . . , bf1 have been written, can be corrected after reading out, and that after the correction with the code C, it can then be determined based on these already corrected values, whether the codeword y has been stored directly or in the bits belonging to M.
It is moreover advantageous that the constant binary values are corrected with the same code C, such as the stored payload data bits, wherein the number of check bits normally does not increase by this correction. If
is a codeword of the code C, a subset M of bits can consist of all bits of a codeword y=y1, . . . , yQ when the address bits are not involved in the encoding.
Groups of bits Mi with i=1, 2, . . . , , where a codeword can be inverted, wherein the codeword inverted in the bits of Mi is again a codeword of the code C, can easily be determined.
Groups or subsets of bits wherein a codeword of the code C inverted in the bits of the subset is again a codeword of the code C, can be easily determined, since the subset of bits of an arbitrary codeword of the code C which are equal to 1 form such a subset.
Since such a subset of bits can be determined for each codeword, there is a plurality of suitable subsets of bits.
Particular embodiments will now be described.
In a first embodiment, as an example of an error correcting code C, a 1-bit error correcting (15, 11)-Hamming code of the length Q=15 with N=11 information bits will be considered.
The H-matrix of the considered code C is
The variables c1,c2,c3,c4,bf1,x1,x2,x3,x4,x5,x6,x7,x8,x9,x10 correspond, from left to right, to the columns of the H-matrix of Formula (1).
Since each of the four rows of the H-matrix comprises 8 ones and 8 is an even number,
is a codeword of the code C, and a codeword inverted in a component-wise way in all its 15 bits is again a codeword of code C.
K=1 and a subset M1=M={y1, . . . , Y15}comprising all bits of a codeword are selected.
10 payload data bits x1, . . . , x10 are provided which are supplemented by a constant binary value bf1 to 11 information bits
u=u
1
, . . . , u
11
=bf
1
,x
1
, . . . , x
10
In an embodiment, the constant binary value is defined as bf1=0. The code C comprises four check bits c1, . . . , c4. The encoded bits y1, . . . , y15 are determined as
y
1
, . . . , y
15
=c
1
, . . . , c
4
,bf
1
,x
1
, . . . , x
10=(bf1,x1, . . . , x10)·G
by using a G-matrix G of the code C. Thereby, the G-matrix is the matrix G=(I11,P11,5), wherein I11 is the 11-dimensional unit matrix, for P11,5.
applies, and for
c
1
=bf
1
+x
1
+x
3
+x
5
+x
7
+x
8
+x
9
c
2
=bf
1
+x
1
+x
4
+x
6
+x
7
+x
8
+x
10
c
3
=bf
1
+x
2
+x
3
+x
6
+x
7
+x
9
+x
10
c
4
=bf
1
+x
2
+x
4
+x
5
+x
8
+x
9
+x
10 (3)
applies.
The coder forms according to the relations defined in Formulae (3) the check bits c1, . . . , c4 from the information bits bf1, x1, . . . , x10. For example, the coder may be implemented with XOR gates or by using a common synthesis tool. K=1 applies and there is only one subset Y1={y1, . . . , y15} of bits to be inverted.
Since
is a codeword of the code C, with y=y1, . . . , y15, consequently,
As a specific codeword, the codeword formed of the data bits x1, x2, . . . , x10=1,0,1,1,0,1,1,1,1,1 and the constant binary value bf1=0 will now be considered. According to Formula (3), c1=1, c2=0, c3=1 and c4=0, so that the respective codeword is
y
1
, . . . , y
15=1,0,1,0,0,1,0,1,1,0,1,1,1,1,1
The codeword has 10 ones and 5 zeros. An example is considered, where it is advantageous to write as many zeros as possible into the memory. It is possible for a stored value 0 to be less frequently corrupted to a stored value 1, than vice versa, as can be the case in an MRAM. It is also possible that writing a value 0 requires less energy than writing a value 1, as can be the case in a Flash memory. It is also possible that permanent errors exist at one or several positions in the memory. Thus, it is possible that a stuck-at-0 error exists at the position of the bit yQ=y15. If the word 1,0,1,0,0,1,0,1,1,0,1,1,1,1,1 is written exemplarily into the memory, as can be the case when writing into a Flash memory, and if the written values are compared with the read-out values, it can be seen that at the position of y15 a stuck-at-0 error exists, since a value 0 is read out instead of the written value 1, as y15=1 has been written into the memory. If, however, it is decided that the bits of Y1, e.g., in this case all bits, are invertedly written into the memory, then
d
1
, . . . , d
15
=
1
, . . . ,
15=1,0,1,1,1,0,0,1,0,0,0,0,0
is written into the memory at an address a, and a possible stuck-at-0 error in the 15th bit has no effect. If no further errors exist and if read out is conducted at the address a
d
1
′, . . . , d
15′=1,0,1,1,1,0,1,0,1,0,0,0
it can be seen, for example by determining the error syndrome of the read-out word
s=H·(1,0,1,1,1,0,0,1,0,0,0,0,0)=0,
that a codeword of the code C has been read out, and that no error correction is necessary.
It can be concluded from the value d5′=1, that the word has been invertedly written into the memory. In order to restore the original word, all read-out bits d1′, . . . , d15′ are to be inverted, so that
y
1
, . . . , y
15
=
1
, . . . ,
15
applies.
If, for example, an error exists, which corrupts the read-out value d5′ from 1 to 0, this error is then corrected to 1 by the same code C, which also corrects errors in other bits as will be described below in more detail.
Advantageously, the effort for error correction is low. Only one additional bit having a constant value is required to indicate, whether the bits of the codeword have been written into the memory directly or indirectly (invertedly).
Thereby, the memory can, for example, be a register, a register array, an RAM, an M-RAM or a Flash memory.
Writing into the memory will now be discussed with reference to
In
y=y
1
, . . . , y
15
=c
1
, . . . , c
4
,bf
1
,x
1
, . . . , x
10=(bf1,x1, . . . , x10)·G
which is output at a 15 bit-wide output of the coder Cod 11.
Here, it is assumed that the code C is given in its systematic form. The output of the coder 11 is fed into an XOR circuit 12 having a first 15 bit-wide input. Moreover, the XOR circuit 12 comprises a second 1 bit-wide input to which a binary inversion signal Inv is applied. Furthermore, the XOR circuit 12 comprises a 15 bit-wide output which carries the values d1, . . . , d15, and which is connected to a 15 bit-wide data input of a memory Mem 13.
In
If Inv=0 then d1, . . . , d15=y1, . . . , y15 applies, while if Inv=1 then d1, . . . , d5=
When writing data, the memory Mem 13 is provided with a write address a, and the data applied to the data inputs of the memory Mem 13 are stored at the address a.
When a read address a′ is applied, and when reading data, the data being stored at a read address a′ are read. If the write address a is equal to the read address a′, i.e. when a=a′, then the values d1′, . . . , d15′ will be output at data outputs. It is possible that the data d1, . . . , d15, written at an address a, and the data d1′, . . . , d15′ read out from the same address a, differ due to errors.
From the values read out from the memory Mem 13, the error syndrome
S=H·(d1′, . . . , d15′)
with s=(s1,s2,s3,s4) and
s
1
=d
1
′+d
5
′+d
6
′+d
3
′+d
10
′+d
12
′+d
13
′+d
14′
s
2
=d
2
′+d
5
′+d
6
′+d
9
′+d
11
′+d
12
′+d
13
′+d
15′
s
3
=d
3
′+d
5
′+d
7
′+d
8
′+d
11
′+d
12
′+d
14
′+d
15′
s
4
=d
4
′+d
5
′+d
7
′+d
9
′+d
10
′+d
13
′+d
14
′+d
15′ (4)
applies. The error syndrome s=(s1,s2,s3,s4) is determined by a syndrome generator Syn (not shown in
If the codeword y1, . . . , y15=1,0,1,0,0,1,0,1,1,0,1,1,1,1,1 with y5=bf1=0 inverted as d1, . . . , d15=0,1,0,1,1,0,1,0,0,1,0,0,0,0,0 has been written into the memory Mem 13, and if the read-out bits d1′, . . . , d15′ are d1′, . . . , d15′=0,1,0,1,1,0,1,0,0,1,0,0,0,0,0, then, according to Formulae (4), s=0, s2=0, s3=0 and s4=0 applies, and the read-out values are not corrected. Since d5′=1 and the constant value bf1=0 has been stored in the fifth bit directly or invertedly, the read-out word will be inverted component wise so that
y
1
cor
, . . . , y
15
cor
=
1
, . . . ,
15
=y
1
, . . . , y
16
applies.
If the bit d5′ is erroneously corrupted to 0, d1, . . . , d15′=0,1,0,1,0,0,1,0,0,1,0,0,0,0,0 is read out from the memory Mem 13 and the syndrome generator determines, according to equations (4), the error syndrome s=(1,1,1,1). According to the last row in Table 1, the value d5′=bf′1=0 is corrected to d5cor=d5′+1=
y
1
cor
, . . . , y
15
cor=1,0,1,0,0,1,1,0,1,1,0,1,1,1,1,1
is output by the circuit.
In the following, an error in the data bits will be considered. If, for example, the value d15′ is erroneously equal to 1, the word d1′, . . . , d15′=0,1,0,1,1,0,1,0,0,1,0,0,0,0,1 will be read out from the memory Mem 13. The syndrome generator forms, according to Formulae (4) the error syndrome s=(0,1,1,1), to which the bit d15′ to be corrected is allocated by the decoder, so that the corrected word d1cor, . . . , d15cor is formed according to
d
1
cor
=d
1
′, . . . , d
14
cor
=d
14
′,d
15
cor
=
15
and so that the corrected word is
d
1
cor
, . . . , d
15
cor=0,1,0,1,1,0,1,0,0,0,1,0,0,0,0,0.
Since d5cor=1 applies, the word is to be inverted, so that
y
1
cor
, . . . , y
15
cor
=
1
cor
, . . . ,
15
cor=101001011011111
applies, and the properly corrected word is output by the circuit.
As in
In
In some embodiments, the memory Mem 13 may be a register which may, e.g., comprise 15 memory elements. Memory elements may, e.g., be, flip-flops or latches.
When creating read address a′, the possibly erroneous bits d′=d1′, . . . , d15′ are output at the 15 data outputs of the memory Mem 13. It may be assumed that a′=a applies and that the data written at the write address a into the memory Mem 13 are read out from the same read address a. The read-out bits d1′, . . . , d15′ may, e.g., differ from the written bits d1, . . . , d15, since the read-out bits can be erroneous due to memory errors or due to errors on the data lines.
The bits d1′, . . . , d15′, being read out onto the data outputs of the memory Mem 13, are fed into a 15 bit-wide input of a syndrome generator Synd 21 and also into a 15 bit-wide first input of an XOR circuit 23. The syndrome generator Synd 21 is implemented such that said syndrome generator Synd 21 forms an error syndrome s=s1,s2,s3,s4 according to Formulae (4). Said error syndrome is provided at a 4 bit-wide output of the syndrome generator Synd 21, wherein said output is connected to a 4 bit-wide input of a decoder Dec 22. The decoder Dec 22 outputs a correction signal e=e1, . . . , e15 at its 15 bit-wide output. The decoder Dec 22 is configured such that it forms the correction signal according to table 1. The XOR circuit 23 e.g., comprises 15 XOR gates XOR1, . . . , XOR5, wherein each of the 15 XOR gates has two inputs and one output.
For i=1, . . . , 15, the value di′ is fed into the first input of the XOR gate XORi of the XOR-circuit 23 and the value ei is fed into the second input of the XOR gate XORi, so that the value
d
i
cor
=d
i
′+e
i
is output at the output of the XOR gate XORi. The output of the XOR gate XOR5 of the XOR circuit 23, which carries the value d5cor=bf1cor, is fed, since bf1=0 has been selected, directly into a first 1 bit-wide input of an XOR circuit 26, which may, e.g., comprise 15 XOR gates XOR1′, . . . , XOR15′, wherein each of the 15 XOR gates has a binary output and two binary inputs.
The 15 bit-wide output of the XOR circuit 23 is connected to a second 15 bit-wide input of the XOR circuit 26.
For i=1, . . . , 15, the value dicor is fed into a first input of the XOR gate XORi′, while the output of the XOR gate XORi is connected to the second input of this gate, said output carrying the signal d5cor=bf1cor. Thus the corrected values d1cor, . . . , d15cor are inverted if d5cor=1 and not inverted if d5cor=0. The syndrome generator Synd 21, the decoder Dec 22 and the XOR circuit 23 form a corrector 24, as illustrated in
It is advantageous if the correction of the values d′=d1′, . . . , d15′ read out from the memory Mem 13 is performed by the corrector 24 independent from whether y=y1, . . . , y15 or y=
According to the embodiment of
However, according to some embodiments, only a part of the bits is corrected, for example, the bits corresponding to the data bits, and the bit d5′ which corresponds to the constant binary value bf1. In some embodiments, only a part of the values allocated to the data bits are corrected.
The circuit parts, which corresponds to the circuit parts of
In
It is possible that the error detector FE 31 is implemented such that the error detector FE 31 outputs a 1 bit-wide error signal E=1, if the syndrome s is s≠0, and so that the error detector FE 31 outputs E=0 if the syndrome s is s=0. Then the error detector FE 31 can be realized by an OR gate having 4 inputs and one output.
In an embodiment, q=2. In such an embodiment, E=(E1,E2)=0, 0 is output, when s=0; E=1, 0 is output, when s is equal to one of the columns of the H-matrix of the code C; and E=0, 1 is output when s≠0 and is not equal to one of the columns of the H-matrix.
If E=1, 0, then an error, which is correctable by the code C, is detected. If E=0, 1, then an error, which is not correctable by the code C is detected. If E=0, 0, this means that no detectable error exists.
According to some embodiments, the error detector FE 31 may be implemented such that q=2 applies and, for example, E=0, 0 and E=1, 1 indicates that no error exists, and E=0, 1 or E=1, 0 indicates that an error exists.
In the following, further embodiments will be explained, wherein a code C has 8 data bits x1, . . . , x8 and 6 check bits c1, . . . , c6.
It is defined that K=2 subsets Y1, Y2 of bits are formed that can be directly or invertedly written into the memory Mem 13. The 8 data bits x1, . . . , x8 are supplemented by two constant binary values bf1,bf2 to form 10 information bits u1, . . . , u10, so that
u
1
, . . . , u
10
=bf
1
,bf
2
,x
1
, . . . , x
8.
The H-matrix of the considered code C may, e.g., be defined as
Variables c1,c2,c3,c4,c5,c6, bf1,bf2, x1,x2,x3,x4,x5,x6,x7,x8, from left to right, correspond to the columns of the H-matrix (5) from left to right, respectively, so that c1 corresponds to the first column, c2 corresponds to the second column, etc.
The code C of this embodiment is a shortened Hsiao code. All columns of the H-matrix are pairwise distinct and each column has an odd number of ones, since each column has either one or three ones.
Since each row of the H-matrix comprises an even number of ones,
is a code vector of the code C, and therefore, if y=y1, . . . , y16 is a codeword of the code C,
As an example, the set Y1={c1,c2,c3,c4,c5,c6,bf1,x4} is selected as a first subset Y1 of bits that are directly or invertedly written into the memory, and the set Y2={bf2,x1,x2,x3,x5,x6,x7,x8} is selected as a second subset.
Correspondingly, the 1st to 7th and the 12th column of the H-matrix are allocated to the set Y1. In the components of each of these columns, 2 ones exist, so that the component-wise modulo 2 sum of these columns of the H-matrix is equal to 0, wherein
h
1
+h
2
+h
3
+h
4
+h
5
+h
6
+h
7
+h
12=0,
wherein
H·(1,1,1,1,1,1,1,0,0,0,0,1,0,0,0,0)T=0
applies, and wherein (1,1,1,1,1,1,1,0,0,0,0,1,0,0,0,0,) is codeword.
The 8th to 11th and the 13th to 16th columns of the H-matrix are allocated to the set Y2. In the components of each of these columns 4 ones exist, so that the component-wise modulo 2 sum of these columns of the H-matrix is equal to 0, wherein
h
8
+h
9
+h
10
+h
11
+h
13
+h
14
+h
15
+h
16=0,
wherein
H·(0,0,0,0,0,0,0,1,1,1,1,0,1,1,1,1)T=0
applies and wherein (0,0,0,0,0,0,0,1,1,1,1,0,1,1,1,1,) is also codeword of the considered code.
The sets Y1 and Y2 are disjunct and their union comprises all 16 components of a codeword.
Here, it is also possible to select a third set Y3 of bits that can be directly or invertedly written into the memory Mem 13. Such a set Y3 may comprise all bits of a codeword. The corrected values d7cor and d8cor, which have been read out from the memory, determine which subsets of bits have been invertedly written into the memory Mem 13 and which subsets of bits have been directly written into the memory Mem 13.
In such an embodiment, there are four different options of writing a codeword y1, . . . , y16 into a memory directly, in a partly inverted manner or in a completely inverted manner. It is assumed that y7 and y8 are set to the constant binary values y7=bf1=0,y8=bf2=0.
It is possible to write the words
d
1
, . . . , d
16
=c
1
,c
2
,c
3
,c
4
,c
5
,c
6,0,0,x1,x2,x3,x4,x5,x6,x7,x8,
d
1
, . . . , d
16
=
1
,
2
,
3
,
4
,
5
,
6,1,0,x1,x2,x3,
d
1
, . . . , d
16
=c
1
,c
2
,c
3
,c
4
,c
5
,c
6,0,1,
or
d
1
, . . . , d
16
=
1
,
2
,
3
,
4
,
5
,
6,1,1,
into the memory.
As, if c1,c2,c3,c4,c5,c6,0,0, x1,x2,x3,x4,x5,x6,x7,x8 is a codeword of the code C, then the values d1, . . . , d16 written into the memory are codewords of the code C, irrespective of which subsets of bits have been inverted, the possibly erroneous values d1′, . . . , d16′ read out from the memory can be corrected by using the code C, without knowing which bit groups have been directly and which bit groups have been invertedly written into the memory.
In particular, the read-out values d7′,d8′ can be corrected to d7cor,d8cor, wherein
d7cor,d8cor=0,0 indicates that the bits of none of the bit groups have been inverted,
d7cor,d8cor=1,0 indicates that the bits of the bit group Y1 have been inverted,
d7cor,d8cor=0,1 indicates that the bits of the bit group Y2 have been inverted,
d7cor,d8cor=1,1 indicates that the bits of the bit group Y3=Y1∪Y2 have been inverted.
An aspect will now be discussed with reference to the following embodiments. A 1-bit error-correcting code C having 4 check bits (c1 c2,c3,c4), 6 data bits (x1,x2,x3,x4,x5,x6) and two constant binary values (bf1,bf2) and one H-matrix H is considered, wherein
and wherein the variables c1,c2,c3,c4,bf1,bf2,x1,x2,x3,x4,x5, x6 correspond to the columns of the H-matrix (6) H.
The number of ones of the third column and fourth column of the H-matrix is odd and
is a code vector of the code C.
The subset Y1 may, e.g., be defined as
Y
1
={c
1
,c
2
,c
3
,c
4
,bf
1
,x
1}
and the subset Y2 may, e.g., be defined as
Y
2
={c
3
,c
4
,bf
2
,x
3
,x
4
,x
5
,x
6}.
The sets Y1 and Y2 are not disjunct, as they have the bits c3 and c4 in common.
The following applies: If y=y1, . . . , y12 is a codeword of the code C, the word obtained from y by inverting the bits, which belong to Y1, is also a codeword.
Likewise, the following applies: If y=y1, . . . , y12 is a codeword of the code C, the word obtained from y by inverting the bits, which belong to Y2, is also a codeword.
In the following, the case is considered that the codeword y*=1,0,1,1,1,1,1,1,0,1,0,1 is to be stored directly or invertedly in the memory, e.g. at an address a. It is assumed that in a test, it has, for example, been determined that the 12th bit y*12 has a stuck-at-0 error. Then, instead of the codeword
y*=1,0,1,1,1,1,1,1,0,1,0,1=c1,c2,c3,c4,bf1,bf2,x1,x2,x3,x4,x5,x6
the codeword
c
1
,c
2
,
3
,c
4
,bf
1
,
2
,x
1
,
2
,
3
,
4
,
5
,
6=1,0,0,1,0,1,0,1,0,1,0=d1, . . . , d12
can be stored into the memory, which is inverted in the bits of the subset Y2, and whose value in the 12th bit is equal to 0. By this, the stuck-at-0 error in this bit position has no effect.
If no further error occurs, the word d1′, . . . , d12′=100010101010 will be read out when reading at the address a. Since d1′, . . . , d12′ is a codeword of the code C, d1cor, . . . , d12cor=d1′, . . . , d12′ and the value of d5cor,d6cor=1,0 indicates that the bits of the subset Y2 have been inverted, so that
applies. By writing the bits, which are inverted in the bits of subset Y2, into the memory and by reversing the performed inversion based on the constant binary values, the (stuck-at-0) error can be tolerated without having an effect.
Here, it is possible that, as has already been mentioned, an error has been detected by a test.
According to an embodiment, a codeword y1, . . . , yQ is directly written into a memory, and subsequently, the respective value is readout and compared with the written value to determine whether and where which errors occurred.
If an error detector exists, one can proceed as follows:
If the error detector does not indicate an error after writing a codeword y1, . . . , yQ at an address a when reading out at the address a, no new word will be written at the address a. If the error detector indicates an error, then the word, being inverted in the bits of Y1 is written at the address a in the memory. If the error detector, when reading out at the address, does not indicate an error now, no further word is written into the memory. If the error detector indicates an error when reading out the word stored at the address a, the word, being inverted in the bits of Y2, is written into the memory. If the error detector does not indicate an error now when reading out at the address, no further word is written into the memory. This is continued until either no error is indicated during reading out or until no further subset YK Of inverted bits exists.
Furthermore, the following procedure is possible:
At the address a, a codeword y1, . . . , yQ or a codeword inverted in the bits of subset Yi is written into the memory, and this written word is maintained when the error detector indicates a number of errors when the number of errors is correctable by the code C.
It is also possible to maintain the bits written into the memory when the error detector indicates that a certain number of errors is not exceeded. If the code C is a 2-bit error correcting code, then the word written into the memory can be maintained when the error detector indicates a 1-bit error at the most, since then still a further, random error can be corrected.
For error treatment, it is advantageous when several different subsets Y1, . . . , Yk with k>1 exist, whose bits can each be written into the memory directly or invertedly, which allows good adaptation to different possible permanent errors.
In the following, further embodiments will be discussed.
A shortened Hamming code having 5 check bits c1, . . . , c5 and 8 payload data bits x1, . . . , x8 and a constant binary value bf1 directly or invertedly stored at an address a=a1, . . . , a5 in a memory will be considered as the code C. In such embodiments, address the bits a1, . . . , a5, as are involved in the encoding.
The H-matrix H of the code is
wherein the columns of the H-matrix are referred to as h1, . . . , h14. The variables c1,c2,c3,c4,c5,bf1,x1,x2,x3,x4,x5,x6,x7,x8,a1,a2,a3,a4,a5 correspond to the respective columns of the H-matrix (7), from left to right. The corresponding G-matrix G in its systematic form is
G=(P14,5I14),
wherein I14 is a 14-dimensional unit matrix and P14,5 has the form
When writing into the memory, by employing the address bits a1, . . . , as of the memory address at which data are written into the memory, a codeword of the code C is defined as
(bf1,x1, x2, . . . , x8,a1, . . . , a5)·G=c1, . . . , c5,x1, . . . , x8,a1, . . . , a5 (9)
wherein
c
1
=bf
1
+x
1
+x
2
+x
3
+x
5
+x
7
+a
1
+a
3
+a
5
c
2
=bf
1
+x
1
+x
2
+x
3
+x
4
+x
5
+x
8
+a
2
+a
4
+a
5
c
3
=bf
1
+x
1
+x
3
+x
4
+x
6
+x
7
+a
2
+a
4
+a
5
c
4
=bf
1
+x
2
+x
3
+x
4
+x
6
+x
8
+a
1
+a
4
+a
5
c
5
=x
1
+x
2
+x
3
+x
4
+x
6
+x
8
+a
2
+a
3
+a
5
applies and wherein a1, . . . , a5 is referred to as a write address.
Y
1
={c
1
,c
2
,c
3
,c
4
,c
5
,bf
1
,x
1
,x
2
,x
3
,x
4
,x
5
,x
6
,x
7
,x
8}
of bits is defined, so that the bits of this set can be written into the memory either directly or invertedly. bf1 is set to a constant value bf1=1.
If
v=c
1
,c
2
,c
3
,c
4
,c
5
,bf
1
,x
1
,x
2
,x
3
,x
4
,x
5
,x
6
,x
7
,x
8
,a
1
,a
2
,a
3
,a
4
,a
5
is a codeword of the code C, then
v=
1
,
2
,
3
,
4
,
5
,
1
,
1
,
2
,
3
,
4
,
5
,
6
,
7
,
8
,a
1
,a
2
,a
3
,a
4
,a
5
is also a codeword of the code C.
At the address a=a1, . . . , a5, the bits
d
1
=c
1
,d
2
=c
2
,d
3
=c
3
,d
4
=c
4
,d
5
=c
5
,d
6
=bf
1=1,d7=x1,d8=x2,d9=x3,d10=x4,d11=x5, d12=x6d13=x7,d14=x8
are written into the memory when the bits are stored directly,
or at the address a, the bits
d
1
=
1
,d
2
=
2
,d
3
=
3
,d
4
=
4
,d
5
=
5
,d
6
=
1=0,d7=
are written into the memory.
Then, when reading from the memory at the read address a′, when a=a′ and no error exists, the bits di′=di are read out for i=1, . . . , 14, and the bits d1′, . . . , d14′, a1, . . . , a5 form a codeword of the code C.
If an error exists in the bits d1′, . . . , d14′, which can be corrected by the code C, the error of the word d1′, . . . , d14′,a1, . . . , a5 is corrected to d1cor, . . . , . . . , d14cor,a1, . . . , a5, and it is determined based on the value d6cor whether the data have been written into the memory directly or invertedly. For example, if d6cor=1, then the data have been written into the memory directly, and if d6cor=0, then the data have been written into the memory invertedly. Errors in the address bits are not corrected. They are detected, when the errors are detectable by the code C.
If, for example, a 1-bit error exists in the address bit a1, the associated error syndrome is [1,0,0,1,0]T. Since none of the columns h1, . . . , h14 of the H-matrix is equal to [1,0,0,1,0]T, no correction of one of the bits d1′, . . . , d14′ is performed, and the error is indicated as a non-correctable error. By this, it can, for example, be detected that the read address and the write address do not match, and differ by an error detectable by the code C.
For example, 8 payload data bits x1, . . . , x8 are to be stored. The payload data bits are supplemented by a bit bf1 carrying the constant binary value, wherein, here, the constant value is, e.g., bf1=1.
The bits bf1,x1, . . . , x8 are applied to the 9 bit-wide first input of the coder Cod 41, while the bits a1, . . . , a5 of the write address are applied to the 5 bit-wide second input of the coder Cod 41.
The coder Cod 41 is configured such that the coder Cod 41 outputs the bits c1, . . . , c5,bf1=1,x1, . . . , x8 of the codeword c1, . . . , c5,bf1=1,x1, . . . , x8,a1, . . . , a5 at its 14 outputs, wherein the codeword is formed according to
(c1, . . . , c5,1,x1, . . . , x8,a1, . . . , a5)=(1,x1, . . . , x8,a1, . . . , a5)·G
where G is the generator matrix of the considered code.
It is assumed that the code C is provided in its systematic form.
The 14 bit-wide output of the coder Cod 41 is guided into the first 14 bit-wide input of the XOR circuit 42 to whose second 1 bit-wide input an inversion signal Inv is applied.
The 14 bit-wide output of the XOR circuit 12 carrying the values d1, . . . , d4 is connected to the 14 bit-wide data input of the memory Mem 43.
Here, the XOR circuit 42 comprises 14 XOR gates having two inputs and one output each, wherein a first input of these XOR gates is respectively connected to one of the 14 binary output lines of the coder Cod 41, while the second input of these XOR gates is respectively connected to the second input of the XOR circuit 42 carrying the inversion signal Inv.
For Inv=0, d1, . . . , d14=c1, . . . , c5,1,x1, . . . , x8 applies, while for Inv=1 d1, . . . , d15=
Here, according to embodiments, the coder is implemented such that, when
c
1
, . . . , c
5,1,x1, . . . x8,a1, . . . , a5
is a codeword of the code C, then
1
, . . . ,
5,0,
is also a codeword of the code C.
In an embodiment, when writing data, the memory Mem 43 is provided with a write address a, so that the data applied to its data inputs are stored at the address a=a1, . . . , a5. The bits a1, . . . , a5 of the write address are part of the information bits u1, . . . , u14=bf1,x1, . . . , x8,a1, . . . , a5 of the code.
When reading data, data that are stored at a read address a′=a1′, . . . , a5∝ are read from the memory when a read address a′ is applied.
If the write address a and the read address a′ match, i.e. when a=a′, the values d1′, . . . , d15′ will be output at data outputs. It is possible that the data d1, . . . , d15 written at an address a and the data d1′, . . . , d15′ read out from the same address a, are different due to errors. If no error occurs, the read out value d6′ indicates, whether the data have been written into the memory directly or invertedly. If an error correctable by the code occurs, then it can be detected depending on the data, being read out from the memory and corrected based on d6cor whether the data have been written into the memory invertedly or directly, when the error is correctable by the code C.
Supplementary to the apparatus of
A read address a′ is provided to the memory Mem 43, and the possibly erroneous bits d′=d1′, . . . , d14′ are read. The possibly erroneous bits d′=d1′, . . . , d14′ are output on 14 binary data outputs of the memory Mem 43. It may be assumed that a=a′ applies and the bits written at the write address a are read out from the same address a′=a. Since the read-out bits d′ can be erroneous, for example due to permanent or not permanent or transient memory errors, the read-out bits d1′, . . . , d14′ do not have to be equal to the written bits d1, . . . , d14.
If no error exists, then
(d′,a′)=d1′, . . . , d14′,a1′, . . . a5′
is a codeword of code C.
If (d′,a′) is no codeword of the code, then an error exists in the memory Mem 43 or an error has occurred when determining the address.
The bits d1′, . . . , d14′, being output on the data outputs of the memory 43, are simultaneously fed into a 14 bit-wide first input of a syndrome generator Synd 51 into whose 5 bit-wide second input, the bits a1′, . . . , a5′ of the read address a′ are fed. The syndrome generator Synd 51 outputs a 5 bit-wide error syndrome s=(s1, . . . , s5) at its 5 bit-wide output. Here, the syndrome generator Synd 51 is configured such that the syndrome generator Synd 51 forms the error syndrome s according to
s=H·(d1′, . . . , d14′,a1′, . . . , a5′),
wherein the H-matrix H of Formula (7) may, for example, be used. The read address a′ is involved in syndrome formation.
The 5 bit-wide output of the syndrome generator Synd 51 is connected to a 5 bit-wide input of a decoder Dec 52 which may, for example, be implemented such that the syndrome generator Synd 51 forms a correction vector e=(e6, e7, . . . , e14) comprising the correction bits e6, e7, . . . , e14, for the bits d6′, d7′, . . . , d14′ being read out from the memory.
It is possible that the corrector also additionally forms correction signals e1, . . . , e5, when the check bits are also to be corrected.
Furthermore, it is possible that the corrector also forms correction bits for the address bits a1′, . . . , a′5, wherein a correction signal different from 0 for the address bits indicates that an address error exists, and the bits read out at the erroneous address a′ are not to be used further.
In
d
i
cor
=d
i
′+e
i
is output at the output of the i-th XOR gate XORi. The syndrome generator Synd 51, decoder Dec 52 and XOR circuit 53 may be considered as circuit parts which together form the corrector 54. The corrector 54 may also comprise an error detector FE 57, as shown in
The least significant output of the XOR circuit 53, i.e. the output of the XOR gate XOR6 carrying the value d6cor is fed into the input of an inverter 55 that outputs the value
For i=7, . . . , 14 the value dicor is applied to the first input of the XOR gate XORi′, while the value
It is also possible that further bits, for example also the check bits, are corrected, or that only a subset of the payload data bits is corrected.
In the embodiment shown in
It has been shown that, for embodiments, the bits a1, . . . , ar of the write address a and the bits a1′, . . . , ar′ of the read address with r=5 are involved in the encoding and decoding, so that the check bits are determined from the information bits, e.g., according to
u
1
, . . . , u
14
=bf
1
,x
1
, . . . , x
8
,a
1
, . . . , a
5.
It is also possible that bits are derived from the address bits a1, . . . , ar by a function f: {0,1}r→{0,1}t with t<r, wherein said derived bits
A
1
, . . . , A
t
=f(a1, . . . , ar)
are determined so that
u
1
, . . . , u
k
=bf
1
, . . . , bf
1
,x
1
, . . . , x
n
,A
1
, . . . , A
t
form the information bits of the linear code C. Thus, it is, for example, possible that t=1, and A1, being defined according to
A
1
=a
1
+a
2
+ . . . +a
r
is the parity of the address bits.
A further aspect of embodiments will now be discussed with respect to a BCH code.
An H-matrix of a (15,7) BCH code C, which can correct 1-bit and 2-bit errors, is (see Lin, S. and Costello, D. Error Control Coding, Prentice Hall, 1983, page 149) the H-matrix H
The variables y1, . . . , y15 are allocated to the columns of the H-matrix from left to right.
Since each row of the H-matrix of this BCH code C comprises either 6, 8 or 12 ones, and hence, an even number of ones,
is a codeword of the code C, and it is possible to form a set Y1′={y1, . . . , y15} of all bits, that can either directly or invertedly be written into the memory as the bits d1, . . . , d15. Since the H-matrix of Formula (10) has 8 rows, the BCH code has 8 check bits and 7 information bits. If y15=bf1 is selected as a constant value, 6 payload data bits can be stored. After reading out the possibly erroneous bits d1′, . . . , d15′ from the memory, 1-bit and 2-bit errors can be corrected by the BCH code. If, for example, d15′ is erroneous, then d15′ will be corrected to the correct value d15cor, even if a further bit is erroneous.
Embodiments may implement a further aspect that for identifying a set Yi, of bits that are directly or invertedly written into the memory, t constant values bf1, . . . , bft with t>1 are used. After the values d1′, d2′, d3′, . . . , being read out from the memory, are corrected according to the error correcting code C, it can be decided from the corrected bits corresponding to the constant values bf1, . . . , bft, whether the bits of the bit group Yi are to be inverted or not. By this, the reliability of the statement, as to whether the bits of Yi are to be inverted or not, can be increased.
For example, t=3, and the code C may be a 2-bit error correcting code with a code distance 5. For the constant binary values bfi1,bfi2,bfi3 of the subset Yi it can apply that bfi1=bfi2=bi3=0. In the case of a 1-bit error or a 2-bit error, it cannot happen, that not all bits di1cor,di2cor, di3cor at the bit positions at which the constant binary values have been stored directly or invertedly are the same, since all 1-bit and all 2-bit errors are corrected by the code C. Thereby, advantageously, the decision whether the bits of Yi have been written into the memory directly or invertedly is particularly reliable.
In the following, subsequent method steps of an embodiment are described, wherein the address bits are not involved in encoding:
1. Providing the data bits to be stored and supplementing the data bits by constant binary values.
2. Encoding the data bits and the constant binary values with an error correcting code C.
3. Forming the bits to be stored by the steps of
In the following, subsequent method steps of a further embodiment are described, wherein the address bits are involved in encoding:
1. Providing the data bits to be stored and supplementing the data bits by constant binary values.
2. Encoding the data bits, the constant binary values and the address bits of the write address with an error correcting code C.
3. Forming the bits to be stored, wherein the address bits do not belong to the bits to be stored, by the steps of
In the following, embodiments are summarized:
According to an embodiment, a method for storing bits in a memory is provided, wherein the bits are encoded with a linear error correcting code C, the linear error correcting code C having a code distance which is at least 3, wherein it is determined whether a subset of the bits encoded with the linear error correcting code C is written into the memory directly or in a bit-by-bit inverted manner, and wherein the code C comprises an H-matrix H, wherein:
1. A subset of bits written into the memory either directly or invertedly comprises at least one binary constant value, which is together with payload data bits used for coding for forming a codeword of the linear code C, wherein the binary constant value is written as a binary value bf into the memory when the bits of the respective subset of bits are directly written into the memory, and wherein the binary value bf is written into the memory as inverted value
wherein a codeword of the code C is converted to a codeword of the same code when the subset of bits written into the memory either directly or invertedly is inverted and the H-matrix of the code is formed such that the number of ones of each component of the columns of the H-matrix corresponding to the subset of bits written into the memory either directly or invertedly, is even,
2. when reading out from the memory, possibly erroneous bits read out from the memory are corrected by using the linear error correcting code C, wherein at least that bit at the bit position at which the constant binary value bf has been written is corrected when the respective subset of bits has been written into the memory directly, or at the bit position at which the constant binary value
3. bits of the subset of bits that have been written into the memory directly or invertedly are inverted after reading out when the corrected value that has been read out at the bit position at which the constant value bf or the inverted constant value
According to an embodiment, the memory is a register.
According to another embodiment, the memory is a register array.
According to a further embodiment, the memory is an addressable memory.
In an embodiment, the bits encoded with an error correcting code C are encoded by using address bits.
According to an embodiment, the number of zeros or the number of ones in a subset of bits of the subset of bits that is written into the memory directly or invertedly determines whether the subset is written into the memory directly or invertedly.
In an embodiment, a subset of bits is written into the memory directly when, after direct writing, subsequent readout and comparison of the written values and the read-out values, no error has occurred.
According to an embodiment, a subset of bits is written into the memory directly when, after direct writing, subsequent readout and comparison of the written values and the read-out values, T errors have occurred at the most, wherein T is smaller than the number of errors that can be corrected by the code C.
In an embodiment, a subset of bits is written into the memory invertedly when, after inverted writing, subsequent readout and comparison of the written values and the read-out values, so many errors have occurred at the most as have occurred after direct writing and comparison of the read-out values and the written values.
According to an embodiment, a subset of bits is written into the memory invertedly when, after inverted writing, subsequent readout and comparison of the written values and the read-out values, T errors have occurred at the most, wherein T is smaller than the number of errors that can be corrected by the code C.
Moreover, according to another embodiment, a further method is provided. The method comprises:
1. Supplementing payload data bits x1, . . . , xn to be stored at an address a in an addressable memory by l bits bf1, . . . , bfl with constant values, wherein l≧1.
2. Encoding the bits with constant values bf1, . . . , bfl and the payload data bits x1, . . . , xn with a linear code C correcting at least 1-bit errors into a codeword c1, . . . , cm, bf1, . . . , bfl, x1, . . . , xn, wherein c1, . . . , cm are check bits determined from bf1, . . . , bfl, x1, . . . , xn when bits derived from the address bits are not involved in forming a codeword, and coding of bits bf1, . . . , bfl, x1, . . . , xn, A1, . . . , Ak with a linear code C correcting at least 1-bit errors into a codeword c1, . . . , cm, bf1, . . . , bfl, x1, . . . , xn, A1, . . . , Ak, wherein c1, . . . , cm are check bits determined from bf1, . . . , . . . bfl, x1, . . . , xn, A1, . . . , Ak, when bits A1, . . . , Ak derived from the address bits a1, . . . , ar are involved in encoding, and A1, . . . , Ak=f(a1, . . . , ar) are uniquely determined by a function f: {0,1}r→{0,1}k from the address bits.
3. Defining K groups Y1, . . . , Yk Of bits of the bits c1, . . . , cm, bf1, . . . , bfl, x1, . . . , xn to be stored directly or invertedly so that a subset of defined bits bf1, . . . , bfl is uniquely allocated to each of these groups, wherein K≧1,
4. Selecting which group of bits of groups Y1, . . . , Yk is stored into the memory in an inverted or non-inverter manner.
5. Writing the bits c1, . . . , cm, bf1, . . . , bfl, x1, . . . , xn into the memory at an address a, wherein bits belonging to a group of bits written into the memory invertedly are inverted prior to writing, and the bits not belonging to a group whose bits are inverted are written into the memory directly, i.e. in a non-inverted manner.
6. Reading out the bits stored in the memory at an address a.
7. Continuing at 8. if the bits derived from the address bits are not involved in forming the codeword and continuing at 10, if the bits derived from the address bits are involved in forming the codeword.
8. Correcting, based on the error correcting code C, bits read out from the memory possibly differing from values written to the same address due to an error, at least at the bit positions at which the constant values bf1, . . . , bfl have been stored directly or invertedly.
10. Correcting, based on the error correcting code C, possibly erroneous values read out from the memory and by using possibly also erroneous bits A1′, . . . , Ak′ derived from the possibly erroneous address bits at least at the bit positions at which the constant values bf1, . . . , bfl have been stored directly or invertedly.
11. Determining, from the read-out constant values corrected by using the code C uniquely allocated to the respective bit groups, whether and which bit group has been written into the memory directly or invertedly.
12. Inverting the read-out and corrected bits of the bit groups that have been determined in the previous step as the bit groups whose bits have been inverted during writing.
13. End of the method
Furthermore, according to another embodiment, a method for directly or invertedly writing a subset of bits forming a codeword of a linear code C correcting at least 1-bit errors into a memory of memory cells directly or invertedly, and for reading and recovering the bits written into the memory from the bits read out possibly erroneously from the memory that were stored directly or invertedly, is provided, wherein the method comprises the steps:
1. Defining the number K of subsets of the bits encoded with a linear code C correcting at least 1-bit errors that can be written into the memory directly or invertedly, wherein K≧1.
2. Providing n payload data bits x1, . . . , xn that are to be stored as a subword of a codeword of a linear systematic code correcting at least 1-bit errors at an address a=a1, . . . , ar with r≧2.
3. Forming the information bits u1, . . . , uN of the code C, wherein then, if the address a is not involved in forming the codewords of the code C, the databits x1, . . . , xn are supplemented by l defined binary values bf1, . . . , bfl, so that
u
1
, . . . , u
N
=bf
1
, . . . , bf
l
,x
1
, . . . , x
n
with N=l+n applies, and if the address a is involved in forming the codewords of the code C, the data bits x1, . . . , xn and bits A1, . . . , Ak derived from address bits a1, . . . , ar are supplemented by l defined binary values bf1, . . . , bfl, so that
u
1
, . . . , u
N
=bf
1
, . . . , bf
l
,x
1
, . . . , x
n
,A
1
, . . . , A
k,
with N=l+n+k applies, wherein
A
1
, . . . , A
k
=f(a1, . . . , ar)
are binary values uniquely determined by a function f from the values of the r address bits a1, . . . , ar, l≧1 and 1≦k≦r.
4. Continuing the method with step 5 if the address a is not involved in error detection or error correction and continuing the method with step 16 if the address is involved in error detection or error correction.
5. Forming a codeword y1, . . . , yP of the code C, wherein C is a linear systematic code with a generator matrix G in systematic form and an H-matrix H, wherein
y=y
1
, . . . , y
P=(u1, . . . , uN)G·=c1, . . . , cm,bf1, . . . , bfl,x1, . . . , xn,
applies and c1, . . . , cm are m are check bits, the generator matrix G is an (N,P)-matrix and the H-matrix H=(h1, . . . , hP) is an ([P−N],P)-matrix, so that all columns of the H-matrix are pairwise distinct and unequal to 0 and P=n+m+l, m=P−N, N=n+l and m=P−N applies.
6. Determining K subsets Y1={y1,1, . . . , y1,q1}, . . . , YK={yK,1, . . . , yK,qK} of bits
y
1
, . . . , y
P
=c
1
, . . . , c
m
,bf
1
, . . . , bf
l
,x
1
, . . . , x
n,
so that the following applies
10. Creating an address a and reading out the possibly erroneous values d1′, . . . , dP′ stored at the address a, which have originated from the values d1, . . . , dP written at the address a by possible errors.
11. Defining L bit positions k1, . . . , kL to be corrected by code C with L≦P and {k1, . . . , kL}∪{1, . . . , P}, that are to be corrected by using the code C in the case of an erroneous value, wherein the bit positions at which bf1, . . . , bfl have been stored directly or invertedly belong to the bit positions to be corrected.
12. Determining binary correction values ek
13. Forming corrected bits
d
k
cor
=d′
ki
ope
k
at least at the bit positions at which values bf1, . . . , bfl have been stored directly or invertedly, wherein op is a uniquely invertible Boolean operation.
14. Determining, based on the known inserted values bf1, . . . , bfl and the respective read-out values corrected by using the code C, for which group Y1, . . . , Yk the bits have been stored directly or invertedly.
15. Outputting the bits
y
k
cor
=d′
ki
ope
k
if Yk
y
k
cor=
if yk
16. Forming a codeword y=y1, . . . , yP of the code C, wherein C is a linear systematic code with a generator matrix G in systematic form and an H-matrix H, wherein
applies, the generator matrix G is an (N,P)-matrix and the H-matrix H=(h1, . . . , hP) is an ([P−N],P)-matrix, so that all columns of the H-matrix are pairwise distinct and unequal to 0 and P=n+l+m+k, N=n+l+k and c1, . . . , cm are m=P−N check bits.
17. Determining K subsets Y1={y1,1, . . . , y1,q1}, . . . , YK={yK,1, . . . , yK,qK} of the bits
y
1
, . . . , y
n+l+m
=c
1
, . . . , c
m
,bf
1
, . . . , bf
l
,x
1
, . . . , x
n,
so that the following applies
21. Creating an address a and reading out possibly erroneous values d1′, . . . , dm+n+l′ stored at the address a, which have originated from values d1, . . . , dn+m+l written at the address a by possible errors.
22. Defining L bit positions k1, . . . , kL to be corrected by code C with L≦P−k and {k1, . . . , kL}⊂ {1, . . . , n+m+l}, that are corrected by using the code C in the case of an erroneous value, wherein the bit positions at which bf1, . . . , bfl have been stored directly or invertedly belong to the bit positions to be corrected.
23. Determining binary correction values ek
24. Forming corrected bits
d
k
cor
=d′
k
ope
k
at least at the bit positions at which the values bf1, . . . , bfl have been stored directly or invertedly, wherein “op” is a binary uniquely invertible operation.
25. Determining, based on the known values bf1, . . . , bfl and the corresponding values read out and corrected by using the code C, for which group of the bits Y1, . . . , Yk the bits have been stored directly or invertedly.
26. Outputting the bits
y
k
cor
=d′
k
ope
k
if yk
y
k
cor=
if yk
According to an embodiment, the memory is a Flash memory.
According to another embodiment, the memory is an M-RAM.
According to a further embodiment, the memory is an R-RAM.
In an embodiment, the generator matrix of the code C in its systematic form serves for encoding.
According to another embodiment, the code C is a Hamming code or a shortened Hamming code.
In another embodiment, the code C is a Hsiao code or a shortened Hsiao code.
According to a further embodiment, the code C is a BCH code or a shortened BCH code.
In another embodiment, k=r and (A1, . . . , Ak)=(a1, . . . , ar) apply.
According to another embodiment, k=1 and A1=f(a1, . . . , ar)=a1+a2+ . . . +ar applies and A1 is the parity of the address bits a1, . . . , ar.
Although some aspects have been described in the context of an apparatus, it is clear that these aspects also represent a description of the corresponding method, where a block or device corresponds to a method step or a feature of a method step. Analogously, aspects described in the context of a method step also represent a description of a corresponding unit or item or feature of a corresponding apparatus.
The inventive decomposed signal can be stored on a digital storage medium or can be transmitted on a transmission medium such as a wireless transmission medium or a wired transmission medium such as the Internet.
Depending on certain implementation requirements, embodiments of embodiments can be implemented in hardware or in software. The implementation can be performed using a digital storage medium, for example a floppy disk, a DVD, a CD, a ROM, a PROM, an EPROM, an EEPROM or a FLASH memory, having electronically readable control signals stored thereon, which cooperate (or are capable of cooperating) with a programmable computer system such that the respective method is performed.
Some embodiments according to embodiments comprise a non-transitory data carrier having electronically readable control signals, which are capable of cooperating with a programmable computer system, such that one of the methods described herein is performed.
Generally, embodiments of the present invention can be implemented as a computer program product with a program code, the program code being operative for performing one of the methods when the computer program product runs on a computer. The program code may for example be stored on a machine readable carrier.
Other embodiments comprise the computer program for performing one of the methods described herein, stored on a machine readable carrier.
In other words, an embodiment of the inventive method is, therefore, a computer program having a program code for performing one of the methods described herein, when the computer program runs on a computer.
A further embodiment of the inventive methods is, therefore, a data carrier (or a digital storage medium, or a computer-readable medium) comprising, recorded thereon, the computer program for performing one of the methods described herein.
A further embodiment of the inventive method is, therefore, a data stream or a sequence of signals representing the computer program for performing one of the methods described herein. The data stream or the sequence of signals may for example be configured to be transferred via a data communication connection, for example via the Internet.
A further embodiment comprises a processing means, for example a computer, or a programmable logic device, configured to or adapted to perform one of the methods described herein.
A further embodiment comprises a computer having installed thereon the computer program for performing one of the methods described herein.
In some embodiments, a programmable logic device (for example a field programmable gate array) may be used to perform some or all of the functionalities of the methods described herein. In some embodiments, a field programmable gate array may cooperate with a microprocessor in order to perform one of the methods described herein. Generally, the methods are performed by any hardware apparatus.
While this disclosure has been described in terms of several advantageous embodiments, there are alterations, permutations, and equivalents which fall within the scope of this disclosure. It should also be noted that there are many alternative ways of implementing the methods and compositions of the present invention. It is therefore intended that the following appended claims be interpreted as including all such alterations, permutations, and equivalents as fall within the true spirit and scope of the present invention.
The above described embodiments are merely illustrative for the principles of the present invention. It is understood that modifications and variations of the arrangements and the details described herein will be apparent to others skilled in the art. It is the intent, therefore, to be limited only by the scope of the impending patent claims and not by the specific details presented by way of description and explanation of the embodiments herein.
Although each claim only refers back to one single claim, the disclosure also covers any conceivable combination of claims.