This application is based upon and claims the benefit of priority from Japanese Patent Application No. 2015-018840, filed on Feb. 2, 2015; the entire contents of which are incorporated herein by reference.
Embodiments described herein relate generally to a decoding device and a decoding method.
An LDPC code (LDPC stands for Low-Density Parity-Check) is known as an encoding method that has a strong error correction/encoding capacity and that is used in communication systems and memory devices. An LDPC code uses a parity check matrix and repeatedly performs message value calculation called row processing and column processing; and performs decoding by obtaining the posterior probability of received-word data. From among the existing types of error correction codes, an LDPC code has the error correction capacity close to the theoretical limit. For that reason, the LDPC code is widely used in communication systems and storage devices.
Meanwhile, regarding the flash memory that, in recent years, has become mainstream as far as nonvolatile semiconductor memory devices are concerned, miniaturization of memory cells and multi-bit per cell architecture have escalated the errors occurring during reading. For that reason, the error correction capacity of the conventional BCH code (BCH stands for Bose, Chandhuri, Hocquenghem) has become insufficient. Thus, in recent years, a lot of attention is being focused on the LDPC codes having a higher error correction capacity. Besides, in order to retain the intergenerational compatibility among the error correction methods, there has been a demand for a technology providing an on-chip decoding circuit for decoding the LDPC codes. As a result of providing an on-chip decoding technology, the LDPC code decoding operation can be performed using a circuit arranged on the chip on which the semiconductor memory device is formed. As a result, the apparent error occurrence rate of the semiconductor memory device can be held down to a certain level or lower.
Meanwhile, since an LDPC code performs probability-based error correction, it becomes necessary to perform complex real number calculation. Particularly, in the check node processing performed during the calculations for decoding an LDPC code, it is necessary to perform product-sum operations of probability values, thereby requiring a large amount of calculation resources. Hence, in order to implement the decoding operation for an LDPC code using hardware, a large-scale digital semiconductor circuit is required. That makes on-chip implementation a difficult task.
In that regard, in order to downscale the semiconductor circuit that performs decoding of an LDPC code, a method has been proposed in which the real numbers are expressed as electrical current and the real number calculation is performed using analog circuitry. However, in the case of expressing data values as electrical current, electrical current must continuously flow during the data processing. That leads to consumption of an enormous amount of electrical power.
In this way, in order to achieve a sufficient error correction capacity in an LDPC code using the conventional technology, it is necessary to perform the decoding operation using real number calculation. Unfortunately, this enlarges implementation of an error correction device using a semiconductor integrated circuit.
According to an embodiment, a decoding device includes a variable node processor, a check node processor, a storage, a first forwarder, and a second forwarder. The variable node processor is configured to perform variable node processing on variable nodes defined by a code and output first messages. The check node processor is configured to perform check node processing on check nodes defined by the code based on the first messages and output second messages. The storage is configured to store one or more of the second messages. The first forwarder is configured to forward one or more first messages remaining after excluding messages to be forwarded to one or more check nodes corresponding to the one or more of the second messages having been stored in the storage, to the check nodes. The second forwarder is configured to forward the second messages to the variable nodes and forward the one or more of the second messages to the storage.
Configurations Shared Between Embodiments
A decoding device according to embodiments will now be explained. The decoding device according to the embodiments decodes LDPC codes.
With reference to
The memory unit 2, the encoder 3, and the decoder 4 may be integrated into one semiconductor chip, but without limitation. The memory unit 2, the encoder 3, and the decoder 4 may also be implemented as separate pieces of hardware. Alternatively, the encoder 3 and the decoder 4 may be configured as a computer program operating on a central processing unit (CPU).
Meanwhile, for example, when the memory unit 2 receives a read request from outside, the controller reads the LDPC code from the memory medium and sends it to the decoder 4. Then, the decoder 4 decodes the LDPC code; restores the original input data 5; and outputs the restored input data 5 as output data 6 from the memory system 1.
When a flash memory is used as the memory medium, reading of information is done depending on whether the threshold voltage is high or low.
Given below is the explanation about LDPC codes. An LDPC code is characterized by a low-density matrix called a check matrix in which majority of the components are equal to 0 and only a small number of components are equal to 1. Depending on the code length, a large check matrix is required. However, for the sake of illustration, the following explanation is given about an 8×4 check matrix. An example of a check matrix H is given below in Equation (1).
In the check matrix H, the count of 1 present in each row and each column is called weight, and the check matrix is created in such a way that the weights in all columns and all rows are greater than zero. When the column weight and the row weight are constant values, the check matrix is called a regular matrix. In the check matrix H given in Equation (1), all column weights are equal to four and all row weights are equal to two. Hence, the check matrix H is a regular matrix.
In the LDPC method, a data string x that is to be sent through a communication path or that is to be stored in a memory is converted into a data string c that satisfies HcT=0. This data string c is called a code. Thus, in the LDPC method, the data used in information processing is not the original data string x but is the code c obtained by conversion. The encoder 3 performs a conversion operation with respect to the data string containing the input data 5. The memory unit 2 writes the code c, which is obtained by conversion of the input data 5, in the flash memory.
Generally, the code c represents a data string having a greater data length than the data string x and contains, in addition to the information included in the data string x, information required in performing error correction. Meanwhile, encoding itself represents mapping with one-to-one correspondence. Thus, if the data string x is provided, the code c gets uniquely determined. Conversely, if the code c is provided, the original data string x gets uniquely determined. Moreover, (the length of the data string x)/(the length of the code c) is called a code rate. Herein, it can be said that, higher the code rate, the higher is the efficiency of the error correction.
The check matrix H can be expressed using a Tanner graph illustrated in
Equation (2) presents an example of variable nodes {ci} and check nodes {fj} when the check matrix H provided in Equation (1) is used.
A basic operation of LDPC code decoding will now be explained. It is assumed herein that the decoding operation explained below is performed by, for example, the decoder 4. In such a configuration, the decoder 4 reads a code stored in the memory unit 2, and decodes the code to recover the original data. Generally known as an error correction method used for LDPC codes is a method using belief propagation (BP). The BP will now be explained.
To begin with, for a string “y”={yi} of some physical quantities, each of the variable nodes ci receives a probability Q0i at which the digital value corresponding to each of the values yi is “0”. Each of the variable nodes ci then sends the probabilities Q0i to the check nodes {fj, fh, . . . } to which that variable node ci is connected, as messages {qij, qih, . . . } (see (a) in
An example of the string “y” of physical quantities is a bit string read from the memory unit 2. When a flash memory is used as a memory medium, the memory unit 2 reads the threshold voltages of the time when the bit string is read from the memory medium, and converts the threshold voltages into probability values by calculating probabilities indicating likelihood for respective bits of the bit string. Each of the variable nodes ci then receives the probability values of the respective bits as probabilities Q0i.
The check node fj then calculates, taking the parity condition into account, probabilities {rji, rjk, . . . } at which the respective variable nodes {ci, ck . . . } is a digital data value of “1”, based on messages q={qij, qkj, . . . } received from the respective variable nodes {ci, ck, . . . } connected to that check node fj. The check node fj then sends back the probabilities {rji, rjk, . . . } to the corresponding variable nodes {ci, ck, . . . } as messages rij (see (b) in
When a check node fj calculates a message rji to be sent back to a variable node ci, the check node fj does not include the message qij received from that variable node ci. In other words, the variable node ci receives the messages rji corresponding to the variable nodes other than that corresponding to that variable node ci. More particularly, the check node fj performs the check node processing following Equation (3) below to calculate the messages rji. In Equation (3), the value A(j) represents a set of subscripts {i, k, . . . } given to the variable nodes that are connected to that check node fj.
A variable node ci performs variable node processing based on the messages (probabilities) {rji, rki, . . . } received from the respective check nodes {fj, fk, . . . } that are connected to that variable node ci.
In other words, the variable node ci calculates a probability Q′i at which the received data is originally “0”, using the messages {rji, rki, . . . } and the probability Q0i retained by that variable node ci. As a result of calculation, if the probability Q′i is equal to or greater than ½, the variable node ci presumes that the value of the received data is “1”. If the probability Q′i is smaller than ½, then the variable node ci presumes that the value of the received data is “0”.
During the error correction according to the LDPC method, the parity check is performed using the presumed value. More particularly, with respect to a presumed-value string ctemp={c0temp, c1temp, . . . }, it is determined whether HctempT=0 holds true. If HctempT=0 holds true, calculations are ended under the estimation that the presumed-value string is a digital data string in which the presumed value ctemp was stored. However, if HctempT=0 does not hold true, then the variable node ci recalculates the message q={qij, qkj, . . . } and sends the calculation result to the check nodes {fj, fk, . . . } (see (b) in
The specific calculation performed by the variable node ci is as Equation (4) below.
Where the value B(i) in Equation (4) represents a set of subscripts {j, k, . . . } given to the check nodes f connected to the variable node ci, and the value K is a normalization constant determined to satisfy Equation (5) below.
Herein, the message qij that is sent from the variable node ci to the check node fj represents “the probability at which the value of digital data of the variable node ci is equal to 1” calculated based on probability Q01 and probability {rki, rli, . . . }. That message is not included in the message rji received from the check node fj. That is, as a result of receiving the message qij, the check node fj receives message on the check nodes except for itself.
Upon receiving the message q, the check node calculates the message (probability) r based on the received message q, and returns a variable node. This abovementioned algorithm is repeatedly implemented until the parity condition is satisfied. That is, the presumed-value string ctemp is updated using the calculated message r; and, until HctempT=0 holds true with respect to the updated presumed-value string ctemp, the algorithm is repeatedly implemented.
In the embodiments, the process from when each of the variable nodes calculates and transmits the messages q to the corresponding check nodes, and to when the variable node receives the messages r from the corresponding check nodes is used as a unit of the error correction, and this unit is herein referred to as an “iteration”.
At Step S1 in
The check nodes fj then perform the check node processing, following Equation (3), based on the received messages qij (Step S3), and send back the results to the corresponding variable nodes ci, as the messages rji based on the check matrix H (Step S4). The messages rji are then received by the corresponding variable nodes ci (Step S5).
Each of the variable nodes ci then performs the variable node processing based on the received messages rji. The variable node ci recalculates the messages qij if the variable node ci determines that HcT=0 is not established with the presumed value string ctemp, as a result of the variable node processing.
The variable node ci then transmits the recalculated messages qij to the corresponding check nodes fj (Step S6). Each of the check nodes fj performs the check node processing based on the received messages qij (Step S7), and transmits the resultant messages rji to the corresponding variable nodes ci (Step S8). The messages rji are then received by the variable nodes ci (Step S9). The variable nodes ci then update the presumed value string ctemp based on the received messages rji.
The process from when the variable nodes ci calculates the messages qij at Step S5 to when the check node fj receives the messages rji at Step S9 is repeated, as a unit of repetitive process until the parity condition is satisfied. This unit of repetitive process corresponds to the iteration mentioned above.
The process from when the presumed value string ctemp is updated based on the received probabilities Q0i and the probabilities Q0i are transmitted to the corresponding check nodes fj to when the messages rji are received at Step S5 is also considered as equivalent to the unit of the repetitive process.
Details of Error Correction According to Embodiments
In the error correction using the BP, probabilities Q′ for estimating the original data in the respective variable nodes are calculated by exchanging the probability values between the variable nodes and the check nodes. Information eventually required in this series of processes is information of whether the probability Q′ is higher than ½, and details of the specific values are less important. Therefore, the probability calculations in the variable node processing and the check node processing do not need to be very exact. A message received from one of the check nodes, in particular, has a limited impact on the final result because the probabilities are calculated in the variable node processing by multiplying the messages received from the check nodes.
Therefore, while the messages transmitted from the check nodes to the variable nodes are updated once in every iteration, the final results are not affected very much even if one or more of the check nodes are kept unupdated.
In the embodiments, considering this point, one or more of the check nodes {f0, f1, . . . } are temporarily kept unupdated so that the check node processing is temporarily kept resting in each iteration. The check nodes to be temporarily kept unupdated are changed between successive iterations. In replacement of the message to be transmitted from the temporarily resting check nodes to the variable nodes, the message calculated by that check node and stored in a memory in the previous iteration is transmitted, for example.
In the manner described above, by keeping one or more of the check nodes {f0, f1, . . . } temporarily unupdated in each iteration, resources required for the check node processing can be reduced. Furthermore, the check node processing can be executed at a higher speed depending on the configuration required for the check node processing.
The variable nodes and the check nodes are implemented using memory medium such as memories or registers.
In the kth iteration, the check node f0 is kept unupdated. In other words, in the kth iteration, the check node f0 does not receive the messages qij from the variable nodes ci, and does not update the values that are the probabilities r0i. As the message r0i sent back from the check node f0 to the variable nodes ci, the message r0i resulting from the (k−1)th iteration and stored separately is used instead.
In the kth iteration, the other check nodes f1 to f3 update their values as usual, and sends back their messages to the variable nodes ci. The message r1i from the check node f1 in which the value is not updated in the subsequent (k+1)th iteration is stored separately in the memory.
In the same manner, the check nodes f1, f2, and f3 are kept temporarily unupdated in the (k+1)th, the (k+2)th, and the (k+3)th iterations, respectively. Therefore in the (k+1)th, the (k+2)th, and the (k+3)th iterations, the check nodes f1, f2, and f3 neither receive the messages qij from the variable nodes ci, nor their values are updated. The check nodes f1, f2, and f3 use the values stored in the previous iterations as the messages sent back to the variable nodes ci, and the message from the check node that is to be kept temporarily unupdated in the subsequent iteration is also stored in the memory.
In the manner described above, by keeping one or more of the check nodes f0 to f3 temporarily unupdated in each iteration, the check node processing can be executed in a smaller number of check nodes, being smaller than the number of check nodes defined by the check matrix H. In this manner, the amount of computations (the degree of concurrency) required in check node processing can be reduced, so that the circuit can be downscaled.
In the example in
At this time, if the messages qij are transmitted to all of the check nodes f0 to f3, to cause the check nodes f0 to f3 to perform the check node processing, the reduction effect of check node processing might not be achieved sufficiently.
To address this issue, therefore, in the first iteration, the messages qij are not transmitted to a check node (for example, the check node f3) that is not to be kept temporarily unupdated in the subsequent iteration (the kth iteration in the example illustrated in
Explained now with reference to
In
When the check nodes temporarily kept unupdated occupies a ratio of equal to or lower than 3/10, the average error bit count declines as the iteration is repeated. By contrast, when the check nodes temporarily kept unupdated occupies a ratio of equal to or higher than 4/10, the average error bit count does not decline as the iteration is repeated, and the error floor appears.
It is preferable to change the check node temporarily kept unupdated in each of the iterations. It is also preferable to keep each of the check nodes temporarily unupdated at a fair ratio. If each of the check nodes is kept temporarily unupdated at an unfair ratio, some of the variable nodes may fall incapable of correcting errors appropriately.
Used in the error correction illustrated in
When the number of check nodes kept temporarily unupdated occupies one third of the entire check nodes, one of the two check node remain temporarily unupdated. When the number of check nodes kept temporarily unupdated occupies more than one third of the entire check nodes, both of these two check nodes may stay temporarily unupdated. In such a case, because the messages returned from the variable nodes to the check nodes remain unupdated as well, the error correction cannot be performed appropriately. This is the reason why the error floor appears when the ratio of the check nodes temporarily kept resting is 4/10 or 5/10 in
Let us now discuss the ratio of check nodes that are kept temporarily unupdated with respect to the entire check nodes in each iteration. It is assumed therein that average number of check nodes connected to each of the variable nodes is N (where N>2). As described earlier, when the ratio between the check nodes temporarily kept unupdated and the entire check nodes with respect to a variable node exceeds (N−2)/N, the messages to be returned from the variable node to the check nodes may not be updated, so that the error correction may not be performed appropriately. Therefore, it is preferable for the ratio between the check nodes kept temporarily unupdated and the entire check nodes with respect to a variable node to be equal to or lower than (N−2)/N.
First Embodiment
The decoder 4 is implemented as hardware, and the units included in the decoder 4 are integrated into one semiconductor chip, for example, but without limitation. The units included in the decoder 4 may be partly or entirely implemented as separate respective pieces of hardware. The message storage 45 includes a rewritable non-volatile memory and a structure for reading and writing data from and to the non-volatile memory, for example. The units included in the memory unit 2 are also integrated into one semiconductor chip, for example. The units included in the memory unit 2 may be partly or entirely implemented as separate respective pieces of hardware.
The decoder 4 and the memory unit 2 operate under the control of a higher-level structure above the memory system 1 in which the decoder 4 and the memory unit 2 are included, for example, but without limitation. Alternatively, the memory system 1 may be provided with a controller, and the controller may control the operations of the decoder 4 and the memory unit 2. In the explanation hereunder, it is assumed that the number of check nodes determined by the check matrix H is six, for the purpose of explanation.
In the memory unit 2, the memory 20 is a memory medium, and an example of the memory 20 is a flash memory. The threshold reader 21 reads the threshold voltage when a bit string is read from the memory 20. The threshold-to-probability converter 22 converts the threshold voltage into a probability value by calculating a probability indicating likelihood for each bit of the bit string, based on the threshold voltage acquired by the threshold reader 21. The probability values of the respective bits acquired by the threshold-to-probability converter 22 are stored in the initial probability storage 23.
In the decoder 4, the variable node processor 40 performs the variable node processing and calculates the probabilities Q0i based on the probability values stored in the initial probability storage 23 or the messages (probability values) rji received from the second forwarder 43 described later. The variable node processor 40 transmits the calculated probabilities Q0i to the first forwarder 41 as the messages qij.
Upon receiving the messages qij from the variable node processor 40, the first forwarder 41 notifies the distribution controller 44 of the reception. The first forwarder 41 also selects the messages to be applied with the check node processing by the check node processor 42 from the messages qij, and forwards the selected messages to the check node processor 42, under the control of the distribution controller 44.
The check node processor 42 performs the check node processing to the check nodes in a number less than a predefined number of check nodes, being predefined by the check matrix H, and calculates the probabilities rij. For example, the check node processor 42 performs the check node processing to four out of the six check nodes, the six being the number of check nodes defined by the check matrix H. The check node processor 42 then updates the check nodes with respective probabilities rji calculated in the check node processing, and transmits the probabilities rji to the second forwarder 43 as the messages rji.
The second forwarder 43 stores designated one or more messages from the messages rji received from the check node processor 42 in the message storage 45, under the control of the distribution controller 44. In this example, because the check node processing is performed to the four check nodes out of six, which is the number predefined by the check matrix H, the second forwarder 43 stores the messages corresponding to at least two check nodes, representing the difference between four and six, in the message storage 45.
The second forwarder 43 transmits the messages rji received from the check node processor 42 and the messages resulting from the previous iteration and stored in the message storage 45 to the variable node processor 40 so that such messages are supplied to the appropriate variable nodes, under the control of the distribution controller 44. The variable node processor 40 calculates the probabilities Q0i′ for the respective variable nodes, and acquires a presumed value string ctemp.
A determiner 46 determines whether Hctemp=0 is established with the presumed value string ctemp acquired by the variable node processor 40. If the determiner 46 determines that Hctemp=0 is established, the determiner 46 converts the probabilities Q0i, which are calculated for the respective variable nodes, into respective bits values, and outputs the bit values to a higher-level structure above the memory system 1, for example. If the determiner 46 determines that Hctemp=0 is not established, the determiner 46 notifies the higher-level structure of Hctemp=0 not being established.
A process of the kth iteration performed in the distribution controller 44 will now be explained more in detail. Upon being notified that the messages qij are received from the first forwarder 41, the distribution controller 44 determines the check nodes to which the received message qij are to be forwarded, and forwards the messages qij to the determined check nodes in the check node processor 42.
At this time, the distribution controller 44 controls the first forwarder 41 so as not to forward messages qiA to be addressed to a check node fA belonging to a subset A, including one or more of the check nodes fj, to the check node processor 42. In other words, the distribution controller 44 forwards the messages resulting from excluding the message qiA to be sent to the check node fA, included in the subset A, from the messages qij to be sent to the entire check nodes fj (referred to as messages qi(j-A)) to the check node processor 42. In this manner, the check node processing for the check node fA is temporarily kept resting, and the check node fA is left unupdated.
Under such control, the first forwarder 41 forwards the message qi(j-A) to the check node processor 42.
The check node processor 42 performs the check node processing corresponding to the respective check nodes. Because the first forwarder 41 does not forward the message qiA to be sent to a check node fA belonging to the subset A to the check node processor 42, the check node processor 42 does not perform the process corresponding to the check node fA belonging to the subset A. The check node processor 42 transmits messages r(j-A)i generated in the check node processing to the second forwarder 43. These messages r(j-A)i are messages generated by applying check node processing to the remaining check nodes after excluding the check node fA from the entire check nodes fj.
The distribution controller 44 then controls the second forwarder 43 to read a message rAi′ from the message storage 45. The message rAi′ is a message resulting from the subset A and is stored in the previous iteration (in this example, in the (k−1)th iteration). The messages rAi′ read from the message storage 45 are used as replacement of the messages rAi excluded by the check node processor 42 and left out without being forwarded in the kth iteration.
Before executing the process of the iteration for the first time (first iteration), messages serving as initial values are stored in the message storage 45. These messages serving as the initial values may be any value that can be used as probability values, without limitation. For example, ½ may be stored as an initial value in the message storage 45.
The distribution controller 44 controls to cause the second forwarder 43 to forward the messages rAi′ read from the message storage 45, and the messages r(j-A)i received from the check node processor 42 to the variable node processor 40. At this time, the distribution controller 44 determines the variable nodes to which these messages rAi′ and messages r(j-a)i are to be transmitted, and controls the second forwarder 43 to forward the messages to the determined variable nodes in the variable node processor 40.
The distribution controller 44 also controls to cause the second forwarder 43 to store the messages (referred to as messages rBi) received from a check node fB belonging to a subset B in the message storage 45. The check node fB is a check node for which the check node processing is to be temporarily kept resting in the subsequent (k+1)th iteration, among the entire check nodes fj.
As an example, the distribution controller 44 may select the check node for which the check node processing is to be temporarily kept resting in the kth iteration, the (k+1)th iteration, . . . , and so on, sequentially from the check nodes f0 to f3, e.g., the check node f0, the check node f1, . . . , as illustrated in
Under such control, the second forwarder 43 forwards the messages rAi′ and messages r(j-A)i to the variable nodes determined by the variable node processor 40, and stores the messages rBi in the message storage 45.
Using the messages rAi′ and messages r(j-A)i received from the second forwarder 43, the variable node processor 40 calculates probabilities Q0i′ at which the bits in the respective variable nodes are 0 (or 1). The variable node processor 40 then transmits the calculated probabilities Q0i′ to the determiner 46. The process up to when the variable node processor 40 transmits the probabilities Q0i′ to the determiner 46 is the process within the scope of the kth iteration.
The determiner 46 then determines whether the calculations have been converged, based on the probabilities Q0i′. In other words, the determiner 46 determines, for the presumed value string ctemp, whether the values in HctempT have converged, based on the probabilities Q0i′. If the determiner 46 determines that the calculations have been converged, the determiner 46 outputs the probabilities Q0i′, or bit values resultant of converting the probabilities Q0i′ to the higher-level structure.
If the determiner 46 determines that the calculations have not been converged yet, the determiner 46 transmits the notification to the higher-level structure, for example. In this case, the process of the following (k+1)th iteration is started under the control of the higher-level structure.
In the (k+1)th iteration, when the first forwarder 41 receives the message qij from the variable node processor 40, the distribution controller 44 determines the check nodes to which the received messages qij are to be forwarded. The distribution controller 44 then controls to cause the first forwarder 41 to forward the messages (referred to as messages qi(j-b)) excluding the messages qiB that are to be forwarded to the check node fB to the appropriate check nodes in the check node processor 42. The check node fB belongs to the subset B that includes some of the entire check nodes fj, and is different from the subset A.
As described above, the decoder 4 according to the first embodiment excludes the message to be transmitted to one or more of the check nodes from the messages qij to be forwarded from the variable node processor 40 to the check node processor 42, and sends the remaining messages to the check node processor 42. The decoder 4 allows the variable node processor 40 to use a past message stored in the message storage 45, in replacement of the excluded message. In this manner, with the decoder 4 according to the first embodiment, the amount of computations required in the check node processing can be reduced, and the circuit of the check node processor 42 can be downscaled compared with existing structures.
In the configuration described above, it is preferable to change the subset of the check nodes excluded from those to which the first forwarder 41 forwards the messages, in every iteration. Preferably, a subset of check nodes excluded from those to which the first forwarder 41 forwards the message does not share any common check nodes with other subsets in successive iterations.
This exclusion will now be explained more specifically with reference to
In the example illustrated in
In replacement of the messages for the subset 20213 in the kth iteration, the subset 20213 being a subset without its check nodes updated in the kth iteration, a message 2011 generated and stored as a result of the check node processing executed to the subset 20213 in the previous (k−1)th iteration is forwarded to the variable node processing 2002.
The message 2012 generated as a result of the check node processing performed to the subset 20213 is also stored in the kth iteration, for the subset 20213 that will not be updated in the following (k+1)th iteration.
In the (k+1)th iteration, the variable node processing 2002 is executed using the messages from the subsets 20210 to 20212 generated as a result of the check node processing 2021, and using the stored message 2011. The messages generated as a result of the variable node processing 2002 are then forwarded to check node processing 2022.
In the check node processing 2022, the check node processing of the subset 20212 is temporarily kept resting, so that the check nodes included in the subset 20212 remain unupdated. The subset 20212 is different from the subset 20213 for which the check node processing is temporarily kept resting in the kth iteration. In the remaining subsets 20210, 20211, and 20213, the check node processing is executed and the check nodes are updated. The messages generated as a result of performing the check node processing to the subset 20210, 20211, and 20213 including the updated check nodes are forwarded to variable node processing 2003 for the subsequent (k+2)th iteration.
In replacement of the message from the subset 20212 including the check nodes that are not updated in the (k+1)th iteration, the message 2012 generated and stored as a result of the check node processing in the previous kth iteration is forwarded to the variable node processing 2003, as a message corresponding to the subset 20212 in the kth iteration. A message 2013 generated as a result of performing the check node processing to the subset 20211 is stored in the (k+1)th iteration, because the subset 20211 will not be updated in the following (k+2)th iteration.
In the manner described above, in the decoding process according to the first embodiment, when the messages are forwarded from variable node processing 200x (where the subscript x is 1, 2, . . . ) to the check node processing 202x, the messages are not forwarded to one or more of the check nodes. Therefore, those check nodes remain unupdated, and the messages stored in the previous iteration are forwarded to the variable node processing 200x as a replacement.
In the example illustrated in
Therefore, it is preferable for a set Ck of the check node unupdated in the kth iteration to be different from the set Ck+1 of the check node unupdated in the (k+1)th iteration. If the set Ck and the set Ck+1 share some check nodes, such common check nodes are updated less frequently, so that the calculation may not readily converge. Therefore, it is preferable that the set Ck and the set Ck+1 do not share any check nodes.
Furthermore, to prevent the check nodes from being updated unfairly, it is preferable for the message from every check node to be replaced with a message stored in the past iteration at an equal frequency. For example, the check nodes for which the check node processing is temporarily kept resting may be distributed among the iterations so that the message from every check node is replaced at an equal frequency when an increase in the number of iterations reaches its limit. The check node for which the check node processing is to be temporarily kept resting may be selected sequentially in the respective successive iterations, or selected randomly using a random number, for example. The check node for which the check node processing is to be temporarily kept resting may also be selected based on a table prepared in advance.
Second Embodiment
A second embodiment will now be explained. The second embodiment describes an example in which a plurality of check node calculators, each of which performs the check node processing presented in Equation (3), are provided in parallel to the check node processor 42 according to the first embodiment explained with reference to
In the example illustrated in
When reception of the messages qij is notified from the first forwarder 41, the distribution controller 44 determines the check nodes to which the received messages qij are to be forwarded. The distribution controller 44 then controls to cause the first forwarder 41 to forward the messages qij to the corresponding check node calculators 4201, 4202, 4203, and 4204 based on the result of check node determination. At this time, among the messages qij, the distribution controller 44 controls to cause the first forwarder 41 not to forward messages qi2 that are to be forwarded to the two remaining check nodes to the check node processor 42′.
Under such control, the first forwarder 41 forwards the messages qi(j-2), which are resultant of excluding the messages q12 from the messages qij, to the check node processor 42′. The message qi(j-2) are then forwarded to the corresponding check node calculators 4201, 4202, 4203, and 4204.
The check node calculators 4201, 4202, 4203, and 4204 in the check node processor 42′ perform their check node processing based on the received messages qi(j-2). The check node processor 42′ then forwards the messages r(j-2)i calculated by the check node calculators 4201, 4202, 4203, and 4204 to the second forwarder 43.
The distribution controller 44 controls to cause the second forwarder 43 to read messages rji′, acquired from the two check node and stored in the previous iteration, from the message storage 45. The messages rji′ read from the message storage 45 are used as replacement for the messages excluded by the check node processor 42 as not to be forwarded in the this iteration.
The distribution controller 44 controls to cause the second forwarder 43 to forward the messages rji′ read from the message storage 45 and the messages r(j-2)i received from the check node processor 42 to the variable node processor 40. At this time, the distribution controller 44 determines the variable nodes to which these message rAi′ and the messages r(j-A)i are to be forwarded, and controls to cause the second forwarder 43 to forward the messages to the determined variable nodes in the variable node processor 40.
The distribution controller 44 also controls to cause the second forwarder 43 to store the message received from the two out of the entire check nodes fj in the message storage 45. These two being the check nodes for which the check node processing is temporarily kept resting in the subsequent iteration.
Under such control, the second forwarder 43 forwards the message rji′ and the messages r(j-2)i to the determined variable nodes in the variable node processor 40, and stores the message received from the two check nodes for which the check node processing is to be temporarily kept resting in the subsequent iteration in the message storage 45.
The check node calculators 4201 to 4204 illustrated in
In the second embodiment, because the check node processing can be performed with check node calculators in the number smaller than the number of check nodes predefined by the check matrix H, the circuit for the check node processor can be downscaled, compared with the configuration using the existing technology. More specifically, assuming that the number of entire check nodes is C, and the average number of times the check node calculators perform the check node calculation based on Equation (3) in each iteration is L (where L<2×C), the configuration according to the second embodiment can reduce the number of check node calculators to a number smaller than C/L. Therefore, the configuration according to the second embodiment can downsize the circuit of the check node processor, compared with the existing configuration.
Third Embodiment
A third embodiment will now be explained. In the explanation above, the embodiments is used in the decoder 4 provided to the memory system 1 illustrated in
In the manner described above, in the communication system that transmits and receives information over the communication path 8, the circuit of the check node processor that performs the check node processing in the LDPC decoding can be downscaled, compared with the existing configuration.
While certain embodiments have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of the inventions. Indeed, the novel embodiments described herein may be embodied in a variety of other forms; furthermore, various omissions, substitutions and changes in the form of the embodiments described herein may be made without departing from the spirit of the inventions. The accompanying claims and their equivalents are intended to cover such forms or modifications as would fall within the scope and spirit of the inventions.
Number | Date | Country | Kind |
---|---|---|---|
2015-018840 | Feb 2015 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
7805654 | Seki | Sep 2010 | B2 |
20050229087 | Kim | Oct 2005 | A1 |
20050262420 | Park | Nov 2005 | A1 |
20060274772 | Kim | Dec 2006 | A1 |
20070094568 | Choi | Apr 2007 | A1 |
20110087946 | Planjery | Apr 2011 | A1 |
20110246850 | Rault | Oct 2011 | A1 |
20120036410 | Rault | Feb 2012 | A1 |
20140032996 | Maeto | Jan 2014 | A1 |
20150178151 | Li | Jun 2015 | A1 |
Number | Date | Country |
---|---|---|
2007-13519 | Jan 2007 | JP |
2008-219528 | Sep 2008 | JP |
2012-124888 | Jun 2012 | JP |
2013-207358 | Oct 2013 | JP |
2014-27432 | Feb 2014 | JP |
Entry |
---|
Gu, M. et al., “A 100 pJ/bit, (32,8) CMOS Anaiog Low-Density Parity-Check Decoder Based on Margin Propagation” IEEE Journal of Soild-State Circuits. vol. 46, No. 6. (Jun. 2011) pp. 1433-1442. |
Number | Date | Country | |
---|---|---|---|
20160226523 A1 | Aug 2016 | US |