This invention generally relates to systems and methods for designing error-correcting codes used to write and read data on data storage channels. In particular, embodiments of the invention pertain to systems and methods for constructing high-performance concatenated codes for holographic data storage channels.
As demand for digital data storage capacity increases, data storage systems must continue to store and retrieve data accurately, reliably, and quickly. The accuracy, reliability, and throughput of data storage may decrease due to any number of sources for error. For example, noise or interference present in the data storage channel, defects in a data storage medium, and intersymbol interference may result in data read or write errors. Some communication or data storage channels are also subject to errors which are dependent on the particular data symbols being written to or read from the data storage channel. In other words, the statistics, such as the mean and variance, of the noise corrupting the signals corresponding to the data symbols are different or asymmetric. Inevitably, the data stored in data storage systems using such channels is a distorted version of the written data.
Data storage systems often use error-correcting codes to increase data storage accuracy, reliability, and throughput. Error-correcting codes may achieve these improvements by encoding data at a transmitter, often during the data writing process, into a set of data symbols. This encoding process adds redundancy, so that the length of the block of data written to the data storage medium is often longer than the amount of originally transmitted data. Decoding may be performed by employing an efficient decoding algorithm after the data is read from the data storage medium. This decoding algorithm may be implemented on data processing circuitry, such as a field-programmable gate array (FPGA) or application specific integrated circuit (ASIC).
One error-prone data storage system is a holographic data storage system, which uses a holographic disk as its data storage medium and transmits data over a holographic data storage channel. In certain holographic data storage systems, data is arranged in an array, or page, of about a million (or more) bits. The pages may then be organized into chapters, and the chapters may be organized into books. High data storage densities of up to 320 pages per book have been achieved. These pages are stored within the same three-dimensional disk space, with each page offset from the next one by a very small angle (e.g., offset by 0.067 degrees). In addition, in order to achieve high storage densities, the spacing between the books may be minimized (e.g., book spacing of 700 micrometers has been achieved). Further, the holographic data storage channel is often an asymmetric channel.
Due to these and other characteristics of holographic data storage systems, powerful error-correction codes are needed to minimize the system's bit error rate (BER) and/or sector error rate (SER) and maximize the system's coding gain. The BER is the ratio of the number of incorrectly decoded data bits versus the total number of transmitted data bits. Similarly, the SER is the ratio of the number of incorrectly decoded sectors/blocks of data bits versus the total number of transmitted sectors/blocks. Finally, the signal to noise ratio is the ratio of signal power to noise power as data is transmitted on a channel, such as a holographic data storage channel. Because holographic storage channels have strict system requirements, very strong error correction codes are needed that achieve large SNR gains.
One method for achieving higher performance of forward error correction codes without the use of particularly long codes is to use a family of codes known as concatenated codes. For example,
System 100 includes concatenated encoders 102 and 104 where outer encoder 102 has a (n2, k2) code and is coupled to inner encoder 104 of a (n1, k1) code. The output of encoder 104 may be stored on or written to channel 106. The stored data may be received by a receiver comprising concatenated decoders 108 and 110. Inner decoder 108 may decode code (n1, k1), and outer decoder 110 may decode code (n2, k2).
The decoding process is also generally performed in two steps. Decoding is first performed for each C1 codeword as it arrives using a decoding algorithm for the inner code, and then the check digits (or parity bits) are removed. These bits are then decoded using a decoding algorithm for the C2 outer code, resulting in the final corrected user information. Although the example of system 100 shows one-level concatenation, multi-level concatenation may also be used. In multi-level concatenation, several codes are used to form multiple concatenated codes. These codes may then be combined to form an overall concatenated code.
Since the accuracy and reliability of a holographic data storage system suffers when the SNR is low, there is a continuing interest in constructing efficient concatenated codes that will provide significant improvements in SNR when implemented on particular data storage channels.
In accordance with the principles of the invention, systems and methods for constructing concatenated codes are provided. In general, the systems and methods realize this construction through a series of processing steps which take into account parameters related to the desired performance, throughput, and memory usage of the concatenated codes when implemented in an accompanying decoder. Generally, the decoder is implemented in part of the resources or memory of a field programmable gate array (FPGA) or an application specific integrated circuit (ASIC).
Specifically, an outer Bose, Chaudhuri, and Hocquenghem (BCH) encoder is configured to encode user information and output BCH codewords. An inner iterative encoder, such as a low-density parity check (LDPC) or turbo encoder, is responsive to the output of the BCH encoder and outputs resultant codewords that are then written to a channel, such as a holographic data storage channel. To decode the encoded information on the channel, the encoded information is received by an inner iterative decoder, such as an LDPC or turbo decoder. A BCH decoder is responsive to the output of the inner iterative decoder and outputs the decoded, corrected user information.
In some embodiments, the outer code (e.g., the BCH code) may be designed to remove up to T errors.
Thus, the correction power, TBCH, of the outer BCH code may be chosen according to the estimated or projected defect size. The outer BCH decoder may operate on the codeword level, where each codeword may typically include interleaved bits from one page of a holographic storage channel. In some embodiments, the outer BCH encoder may additionally or alternatively operate on the page level.
After the correction power for the outer BCH code is selected, the inner code rate may be selected based on the overall system code rate requirement. This overall system code rate requirement may be based, at least in part, on the required or desired SNR coding gain. For example, the inner code rate may be chosen in accordance with:
where Rinner is the code rate of the inner code, Rs is the overall system code rate, and RBCH is the code rate for the outer BCH code.
After the inner code rate has been selected based on the overall system code rate requirement, the inner, iteratively decodable code may be designed for the given inner code rate. Finally, the outer BCH code may be designed for the given outer code rate (i.e., the correction power, TBCH).
In some embodiments, one or more of the inner code and the outer code may be programmable in that the correction powers or code rates may be set according to required channel conditions (e.g., for a given defect condition). An ECC processor or software subroutine may set the correction power or code rate of the inner code, the outer code, or both the inner and outer codes. Programmable input signals may also be provided on a field programmable gate array (FPGA) or an application specific integrated circuit (ASIC). The programmable input signals may be used to program the desired correction power or code rate. The correction power or code rate of any of these codes may be dynamically set or adjusted to adapt to varying (e.g., time-varying) defect conditions, resulting in a more robust concatenated code implementation.
In some embodiments, a mother matrix representation of a quasi-cyclic parity check matrix may be constructed for a particular LDPC inner code. The number of rows, Mp, in the mother matrix may then be reduced by some number of rows, and the extra bits may be used for the outer code (e.g., the BCH code). This may allow for accordingly higher outer code (e.g., BCH code) correction power. Any remaining information bits for the inner LDPC code may be set to some known pattern (e.g., the remaining bits may be padded with zero bits). In some embodiments, to achieve even greater flexibility in the inner versus outer code rates, only a portion of a mother matrix row may be used. Using only a portion of a mother matrix row may increase implementation complexity, but allow for a wider spectrum of coding rates.
Another programmable code uses a set of stored inner codes (e.g., a set of stored LDPC codes), each code having a different value of Mp and the same circulant size Sc. Then, one of the inner codes in the code set may be programmably selected depending on the channel conditions, the channel detector performance, and/or the desired sector error rate (SER). Similar to the embodiment described above, the output of the outer encoder may be padded with a known value (e.g., zero padding may be used) before the inner encoding step.
The above and other advantages of the invention will be apparent upon consideration of the following detailed description, taken in conjunction with the accompanying drawings, in which like reference characters refer to like parts throughout, and in which:
The systems and methods of the invention generally relate to correcting and/or detecting errors associated with the communication and/or storage of data. In general, and as will be discussed in more detail below, such communication or data storage occurs on a channel, which refers to a medium on which a data-bearing signal is communicated and/or stored, as well as events that may physically affect the medium. Various aspects of a channel may corrupt data that is communicated or stored thereon, and the data recovered subsequent to communication or storage may be different from their intended values. Such differences are referred to as errors.
Some communication and/or data storage channels are subject to errors which are dependent on the data symbol being transmitted. In other words, the statistics, such as the mean and variance, of the noise corrupting the signals corresponding to the data symbols are different. An example of such a channel is the channel whose signal statistics are depicted in
In various embodiments, the asymmetric channel statistics depicted in graph 200 may include any number of probability density functions 210 and 220, including 1, 2, 3, 4, 5, 8, 10, 15, 20, 30, 40, 50, 75, 100, or more than 100 probability density functions corresponding to noise components of a similar number of data symbols. In addition, the probability density functions may depict the values of a uniform random variable, exponential random variable, geometric random variable, Poisson random variable, or any such suitable random variable that describes a random process.
The asymmetric signal statistics shown in graph 200 may be the signal statistics of a data communications channel, magnetic storage channel, holographic storage channel, or any suitable type of channel. The systems and methods described herein may be applied to asymmetric channels in general, and holographic storage channels in particular. In holographic storage systems, data may be arranged in an array or page of around a million (or more) bits. The pages may be organized into chapters, the chapters may be organized into books, and the books may be organized into volumes. To read the data that is written in a given volume from a holographic storage channel for a holographic storage system, a laser beam is deflected off of a hologram to produce a 3-D image which is a distorted version of the originally stored data. This 3-D image is then projected onto a detector that reads the data in parallel off of the holographic storage channel for the holographic storage system. This parallel read out of data provides the holographic storage channel with fast data transfer rates.
As previously mentioned, holographic storage systems typically store data in pages. As shown in system 300 of
As previously mentioned, there are several potential sources of errors in holographic storage systems. In addition to Gaussian noise and the issue of non-uniform SNR across a page, the holographic channel and/or channel detector occasionally may also introduce errors or defect bits. For example, an entire line or strip in a page may be read or written incorrectly. This entire strip or line may include defect bits. As shown in system 400 of
For example, as shown by the generic bi-partite graph representation of LDPC codes shown on the right in
Iterative algorithms (e.g., belief-propagation or generally soft-input/soft-output algorithms, such as BCJR or SOVA) may use soft information in making detection decisions. Therefore, these types of algorithms may be especially vulnerable to defect input log-likelihood ratios (input LLRs), particularly those defect input LLRs with large magnitudes. For example, the LLR for bit i may be given in accordance with:
where P(bi=0) is the probability of bit i being “0” and P(bi=1) is the probability of bit i being “1” given the detected signal, y. Assuming the maximum (or a large) LLR amplitude for the defect LLR values, the performance of an LDPC code (or other iterative code) on a holographic channel suffers greatly with a large number of defect LLRs.
However, using a concatenated code on these channels, and in particular on holographic storage channels, results in improved performance with a lower error rate at increased SNR ranges. As shown in system 500 of
BCH codewords 506 may then be encoded by iterative encoder 508. For example, iterative encoder 508 may include an LDPC encoder, a turbo encoder, or any other encoder for an iteratively decodable code. In some embodiments, iterative encoder 508 is configured to operate in a plurality of different modes where a different type of code is used for encoding in each mode. For example, programmable input 507 may select which type of code to use. As described in more detail below, programmable input 507 may also be used to select one specific LDPC code from a set of available LDPC codes with different rates and/or performance characteristics. In some embodiments, programmable input 507 is coupled to an ECC processor or software subroutine that dynamically selects the desired LDPC code in real-time based on varying channel error statistics. Resultant codewords 510 may then be stored on, or communicated across, channel 512. Channel 512 may include any data communications or storage channel, such as a magnetic storage channel, optical storage channel, holographic storage channel, or any other suitable type of channel. To decode the encoded information on channel 512, received waveform 514 is read from channel 512. Received waveform 514 may first be decoded by iterative decoder 516. BCH decoder 518 may then be responsive to the output of iterative decoder 516. Finally, BCH decoder 518 may output corrected and decoded user information 520.
The outer BCH code may be chosen so that it removes up to T errors. In other words, the correction power, TBCH, of the BCH code may be chosen to clean up all (or most of) the errors after the inner iterative decoder (i.e., iterative decoder 516). As previously described, iterative decoder 516, which uses soft information in the decoding process, often fails on some of the bits whose LLRs were in defect line 404 (
In some embodiments, the outer BCH code may operate on the codeword level (where each codeword typically includes interleaved bits from a single page). In other embodiments, the BCH encoding/decoding may be multiplexed to operate on the page level. In either implementation, the concatenated code may yield better performance (i.e., lower error rates) than using an iteratively decodable code alone.
At step 604, the inner code rate may be selected based on the overall system code rate requirement. The overall system code rate requirement may be based, at least in part, on the required or desired SNR coding gain. For example, the inner code rate may be computed in accordance with EQ 1 in some embodiments. After the outer BCH code correction power is selected at step 602 and the inner code rate is selected at step 604, the inner code and outer code may be designed at steps 606 and 608, respectively. In some embodiments, steps 606 and 608 may be combined into a single joint implementation step, taking into account the error statistics of both codes. The inner code that is designed at step 606 may be any iteratively decodable code, such as an LDPC or turbo code. For example, the inner code may be an LDPC code constructed or designed according to the methods and systems described in commonly-assigned U.S. patent application Ser. No. 11/893,936, filed Aug. 17, 2007, which is hereby incorporated by reference herein in its entirety.
In practice, one or more steps shown in process 600 may be combined with other steps, performed in any suitable order, performed in parallel (e.g., simultaneously or substantially simultaneously), or removed.
In some embodiments, the inner code, the outer code, or both the inner code and the outer code are at least partially user-programmable. For example, in some embodiments, a mother matrix representation of a quasi-cyclic parity check matrix may be constructed for a particular LDPC inner code. The number of rows, Mp, in the mother matrix may then be reduced by some number of rows, and the extra bits may be used for the outer code (e.g., the BCH code). This may allow for an accordingly higher outer code (e.g., BCH code) correction power. Any remaining information bits for the inner LDPC code may be set to some known pattern (e.g., the remaining bits may be padded with zero bits). In some embodiments, to achieve even greater flexibility in the inner versus outer code rates, only a portion of a mother matrix row may be used. Using only a portion of a mother matrix row may increase implementation complexity, but allow for a wider spectrum of coding rates.
The user may select the Mp parameter and/or the desired BCH correction power using one or more of programmable inputs 503 and 507 (
As an example, in one embodiment, a quasi-cyclic LDPC code with 32 rows and 64 columns in the mother matrix may be used. Reducing the number of rows, Mp, in the mother matrix achieves a higher code rate of the LDPC code and allows for an accordingly higher BCH correction power. As an example, with a circulant size Sc of 512, if the value of Mp is reduced from 32 to 31, 512 extra bits may be used by the outer BCH code. The correction power of the BCH code can then be set to, for example, TBCH=34 with a field size m=15. The remaining bits (e.g., 512−(34×15), or 2 bits, in the above example) may be set to any known pattern. For example, the remaining bits may be padded with zero bits. In more complex implementations, only a part of a row of the mother matrix may be used. This may allow for a wider range of coding rates and correction powers.
Another programmable approach uses a set of more than one inner (e.g., LDPC) code, each code having a different value of Mp and the same circulant size Sc.
Then, one of the inner codes in the code set may be programmably selected depending on the channel conditions, the channel detector performance, and/or the desired sector error rate (SER). Similar to the embodiment described above, the output of the outer encoder may be padded with a known value (e.g., zero padding may be used) before the inner decoding step. The user may select a desired LDPC code from the code set using one or more of programmable inputs 503 and 507 (
As an example, using a circulant size Sc of 256 and 128 columns in the mother matrix (Np=128), then the overall block length may be given by 128×256, or 32K bits. Now a set of LDPC codes may be designed with different rate assignments. Different BCH correction powers may then be supported while maintaining the overall system code rate requirement (e.g., RS=1/2). The exact code rate may be achieved by inserting one or more known bit patterns, such as zero bits. Table 1, below, shows some illustrative LDPC code rates, RLDPC, corresponding BCH correction powers, TBCH, and the number of bits to pad in order to achieve the overall system code rate requirement (RS=1/2 in the example shown in Table 1 below). An ECC processor or software routine may select the appropriate LDPC code based on, for example, channel conditions and/or the channel detector performance.
Referring now to
Referring now to
The HDD 700 may communicate with a host device (not shown) such as a computer, mobile computing devices such as personal digital assistants, cellular phones, media or MP3 players and the like, and/or other devices via one or more wired or wireless communication links 708. The HDD 700 may be connected to memory 709 such as random access memory (RAM), low latency nonvolatile memory such as flash memory, read only memory (ROM) and/or other suitable electronic data storage.
Referring now to
The DVD drive 710 may communicate with an output device (not shown) such as a computer, television or other device via one or more wired or wireless communication links 717. The DVD 710 may communicate with mass data storage 718 that stores data in a nonvolatile manner. The mass data storage 718 may include a hard disk drive (HDD). The HDD may have the configuration shown in
Referring now to
The HDTV 720 may communicate with mass data storage 727 that stores data in a nonvolatile manner such as optical and/or magnetic storage devices for example hard disk drives HDD and/or DVDs. At least one HDD may have the configuration shown in
The HDTV 720 also may support connections with a WLAN via a WLAN network interface 729.
Referring now to
The present invention may also be implemented in other control systems 740 of the vehicle 730. The control system 740 may likewise receive signals from input sensors 742 and/or output control signals to one or more output devices 744. In some implementations, the control system 740 may be part of an anti-lock braking system (ABS), a navigation system, a telematics system, a vehicle telematics system, a lane departure system, an adaptive cruise control system, a vehicle entertainment system such as a stereo, DVD, compact disc and the like. Still other implementations are contemplated.
The powertrain control system 732 may communicate with mass data storage 746 that stores data in a nonvolatile manner. The mass data storage 746 may include optical and/or magnetic storage devices for example hard disk drives HDD and/or DVDs. At least one HDD may have the configuration shown in
Referring now to
The cellular phone 750 may communicate with mass data storage 764 that stores data in a nonvolatile manner such as optical and/or magnetic storage devices for example hard disk drives HDD and/or DVDs. At least one HDD may have the configuration shown in
Referring now to
The set top box 780 may communicate with mass data storage 790 that stores data in a nonvolatile manner. The mass data storage 790 may include optical and/or magnetic storage devices for example hard disk drives HDD and/or DVDs. At least one HDD may have the configuration shown in
Referring now to
The media player 800 may communicate with mass data storage 810 that stores data such as compressed audio and/or video content in a nonvolatile manner. In some implementations, the compressed audio files include files that are compliant with MP3 format or other suitable compressed audio and/or video formats. The mass data storage may include optical and/or magnetic storage devices for example hard disk drives HDD and/or DVDs. At least one HDD may have the configuration shown in
The foregoing describes systems and methods for providing concatenated codes for holographic storage.
One skilled in the art will appreciate that the invention can be practiced by other than the described embodiments, which are presented for purposes of illustration and not of limitation, and the present invention is limited only by the claims that follow.
This claims the benefit of copending, commonly-assigned U.S. Provisional Patent Application No. 60/882,762 filed Dec. 29, 2006, which is hereby incorporated by reference herein in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
4610022 | Kitayama et al. | Sep 1986 | A |
5365530 | Yoshida | Nov 1994 | A |
5469448 | Denissen et al. | Nov 1995 | A |
6279133 | Vafai et al. | Aug 2001 | B1 |
6442726 | Knefel | Aug 2002 | B1 |
6715116 | Lester et al. | Mar 2004 | B2 |
6901011 | Micheloni et al. | May 2005 | B2 |
7043162 | Kubo et al. | May 2006 | B2 |
7142612 | Horowitz et al. | Nov 2006 | B2 |
7184486 | Wu et al. | Feb 2007 | B1 |
7246294 | Kauschke et al. | Jul 2007 | B2 |
7259997 | You | Aug 2007 | B2 |
7310768 | Eidson et al. | Dec 2007 | B2 |
7346829 | Riho et al. | Mar 2008 | B2 |
7379505 | Zaleski et al. | May 2008 | B2 |
7409622 | Lu et al. | Aug 2008 | B1 |
7516391 | Kyung et al. | Apr 2009 | B2 |
7668381 | Masumoto et al. | Feb 2010 | B2 |
7673226 | Eroz et al. | Mar 2010 | B2 |
7774681 | Earhart et al. | Aug 2010 | B2 |
7861131 | Xu et al. | Dec 2010 | B1 |
8055979 | Wu et al. | Nov 2011 | B2 |
20010025358 | Eidson et al. | Sep 2001 | A1 |
20020038440 | Barkan | Mar 2002 | A1 |
20040042294 | Guterman | Mar 2004 | A1 |
20040054960 | Eroz et al. | Mar 2004 | A1 |
20040062111 | Tanzawa et al. | Apr 2004 | A1 |
20040083334 | Chang et al. | Apr 2004 | A1 |
20040093549 | Song et al. | May 2004 | A1 |
20040261002 | Eidson et al. | Dec 2004 | A1 |
20050060635 | Eroz et al. | Mar 2005 | A1 |
20050074173 | Lee et al. | Apr 2005 | A1 |
20050091565 | Eroz et al. | Apr 2005 | A1 |
20050091570 | Eroz et al. | Apr 2005 | A1 |
20050180525 | Hansen et al. | Aug 2005 | A1 |
20050229076 | Riho et al. | Oct 2005 | A1 |
20070171730 | Ramamoorthy et al. | Jul 2007 | A1 |
20070204206 | Lee et al. | Aug 2007 | A1 |
20080198264 | Balram | Aug 2008 | A1 |
Number | Date | Country |
---|---|---|
09-251427 | Sep 1997 | JP |
2006-260619 | Sep 2006 | JP |
2007-299499 | Nov 2007 | JP |
246184 | Dec 1999 | KR |
575806 | Feb 2004 | TW |
WO 02086719 | Oct 2002 | WO |
WO 2005036401 | Apr 2005 | WO |
WO 2006020484 | Feb 2006 | WO |
Entry |
---|
Battail et al., “Pseudo-Random Recursive Convolutional Coding for Near-Capacity Performance”, Global Telecommunications Conference, IEEE vol. 4, pp. 23-27, 1993. |
Benedetto, “Design of Parallel Concatenated Convolutional Codes”, IEEE Transactions on Communications, vol. 44, No. 5, pp. 591-600, May 1996. |
Benedetto et al., “Serial Concatenated Trellis Coded Modualtion with Iterative Decoding”, Proceedings 1997 IEEE International Symposium on Information Theory, p. 8, Jun. 29-Jul. 4, 1997. |
Blaum, “A Family of Efficient Burst-Correcting Array Codes”, IEEE Transactions on Information Theory, vol. 36, No. 3, pp. 671-675, May 1990. |
Gallager, “Low-Density Parity-Check Codes”, IRE Transactions on Information Theory, pp. 21-28, Jan. 1962. |
Hewitt, “Turbo Product Codes for LMDS”, Radio and Wireless Conference, RAWCON 99, IEEE, pp. 107-111, Aug. 1-4, 1999. |
Imai and Hirakawa, “A New Multilevel Coding Method Using Error-Correcting Codes”, IEEE Transactions on Information Theory, vol. IT-23, No. 3, pp. 371-377, May 1977. |
Ungerboeck, “Channel Coding with Multilevel/Phase Signals”, IEEE Transactions on Information Theory, vol. IT-28, No. 1, pp. 55-67, Jan. 1982. |
Wei, “Trellis-Coded Modulation with Multidimensional Constellations”, IEEE Transactions on Information Theory, vol. IT-33, No. 4, pp. 483-501, Jul. 1987. |
Wicked, Ed., “Error Control Systems for Digital Communication and Storage” Prentice-Hall, Inc., Englewood Cliffs, NJ © 1995. The title page, copyright page and table of contents are enclosed herewith, 9 pages total. |
Number | Date | Country | |
---|---|---|---|
20080163026 A1 | Jul 2008 | US |
Number | Date | Country | |
---|---|---|---|
60882762 | Dec 2006 | US |