EP0498501B1 - Encoding/decoding circuit, and digital video system comprising the circuit - Google Patents
Encoding/decoding circuit, and digital video system comprising the circuit Download PDFInfo
- Publication number
- EP0498501B1 EP0498501B1 EP92200268A EP92200268A EP0498501B1 EP 0498501 B1 EP0498501 B1 EP 0498501B1 EP 92200268 A EP92200268 A EP 92200268A EP 92200268 A EP92200268 A EP 92200268A EP 0498501 B1 EP0498501 B1 EP 0498501B1
- Authority
- EP
- European Patent Office
- Prior art keywords
- circuit
- data
- sub
- decoding
- symbols
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Lifetime
Links
- 230000015654 memory Effects 0.000 claims abstract description 53
- 238000012937 correction Methods 0.000 claims abstract description 45
- 230000002457 bidirectional effect Effects 0.000 claims description 2
- 238000001514 detection method Methods 0.000 description 3
- 230000009466 transformation Effects 0.000 description 2
- 239000000470 constituent Substances 0.000 description 1
- 125000004122 cyclic group Chemical group 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 238000000034 method Methods 0.000 description 1
- 238000012545 processing Methods 0.000 description 1
- 238000011084 recovery Methods 0.000 description 1
- 230000033764 rhythmic process Effects 0.000 description 1
- 230000005236 sound signal Effects 0.000 description 1
- 230000001502 supplementing effect Effects 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N9/00—Details of colour television systems
- H04N9/79—Processing of colour television signals in connection with recording
- H04N9/87—Regeneration of colour television signals
- H04N9/88—Signal drop-out compensation
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N9/00—Details of colour television systems
- H04N9/79—Processing of colour television signals in connection with recording
- H04N9/80—Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback
- H04N9/804—Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback involving pulse code modulation of the colour picture signal components
- H04N9/806—Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback involving pulse code modulation of the colour picture signal components with processing of the sound signal
- H04N9/8063—Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback involving pulse code modulation of the colour picture signal components with processing of the sound signal using time division multiplex of the PCM audio and PCM video signals
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11B—INFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
- G11B20/00—Signal processing not specific to the method of recording or reproducing; Circuits therefor
- G11B20/10—Digital recording or reproducing
- G11B20/18—Error detection or correction; Testing, e.g. of drop-outs
- G11B20/1806—Pulse code modulation systems for audio signals
- G11B20/1813—Pulse code modulation systems for audio signals by adding special bits or symbols to the coded information
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11B—INFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
- G11B20/00—Signal processing not specific to the method of recording or reproducing; Circuits therefor
- G11B20/10—Digital recording or reproducing
- G11B20/18—Error detection or correction; Testing, e.g. of drop-outs
- G11B20/1833—Error detection or correction; Testing, e.g. of drop-outs by adding special lists or symbols to the coded information
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11B—INFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
- G11B27/00—Editing; Indexing; Addressing; Timing or synchronising; Monitoring; Measuring tape travel
- G11B27/36—Monitoring, i.e. supervising the progress of recording or reproducing
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/03—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
- H03M13/05—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
- H03M13/13—Linear codes
- H03M13/15—Cyclic codes, i.e. cyclic shifts of codewords produce other codewords, e.g. codes defined by a generator polynomial, Bose-Chaudhuri-Hocquenghem [BCH] codes
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N5/00—Details of television systems
- H04N5/76—Television signal recording
- H04N5/91—Television signal processing therefor
- H04N5/92—Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback
- H04N5/926—Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback by pulse code modulation
- H04N5/9261—Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback by pulse code modulation involving data reduction
- H04N5/9264—Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback by pulse code modulation involving data reduction using transform coding
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N5/00—Details of television systems
- H04N5/76—Television signal recording
- H04N5/91—Television signal processing therefor
- H04N5/93—Regeneration of the television signal or of selected parts thereof
- H04N5/94—Signal drop-out compensation
- H04N5/945—Signal drop-out compensation for signals recorded by pulse code modulation
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N9/00—Details of colour television systems
- H04N9/79—Processing of colour television signals in connection with recording
- H04N9/80—Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback
- H04N9/804—Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback involving pulse code modulation of the colour picture signal components
- H04N9/8042—Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback involving pulse code modulation of the colour picture signal components involving data reduction
- H04N9/8047—Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback involving pulse code modulation of the colour picture signal components involving data reduction using transform coding
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N5/00—Details of television systems
- H04N5/76—Television signal recording
- H04N5/78—Television signal recording using magnetic recording
- H04N5/782—Television signal recording using magnetic recording on tape
- H04N5/783—Adaptations for reproducing at a rate different from the recording rate
Definitions
- the invention relates to a circuit for the encoding and decoding of digital data with an error correction code.
- digital data words are formed in a stream of digital data, each data word being encoded according to a given error correction code (i.e. provided with so-called parity symbols) after which they are stored as code words on a storage medium (upon recording).
- a given error correction code i.e. provided with so-called parity symbols
- the redundant information in the parity symbols enables error correction upon decoding. It is often advantageous to use a combination of two error correction codes.
- the digital data symbols (such as bytes) can be arranged, for example, in rectangular blocks, so that data words are formed in the horizontal and the vertical direction.
- the horizontal data words on the one side and the vertical data words on the other side can then be protected by way of two (possibly different) codes.
- the codes together are also referred to as a product code.
- For encoding and decoding it is necessary to store the digital data temporarily block-wise in an external frame memory. In order to enable simple and fast reading and writing in such an external frame memory, accompanied by a low power dissipation and limited use of wiring, it is advantageous when one (standard) memory suffices.
- the invention inter alia has for its object to provide an encoding/decoding circuit which requires a small external frame memory.
- the invention as defined in claim 1 provides an encoding/decoding circuit which comprises a first sub-circuit for encoding data in the recording mode and decoding data in the reproduction mode according to a first error correction code, a second sub-circuit for encoding data in the recording mode and decoding data in the reproduction mode according to a second error correction code, a third sub-circuit for the supply of non-encoded data in the recording mode and the output of decoded data in the reproduction mode, the first sub-circuit being suitable to output encoded data in the recording mode and to supply encoded data in the reproduction mode, each sub-circuit being suitable to receive clock signals from its own system clock having a frequency, the circuit also comprising switching means which are connected to said sub-circuits and which are controlled by a control circuit for cyclically connecting the sub-circuits, via the switching means, to a terminal for data transfer from and to an external frame
- Fig. 1 shows a digital video system suitable for use of a circuit in accordance with the invention.
- a digital image pick up unit 1.1 for example a CCD camera generating 25 frames (50 fields) per second, each with approximately 420.000 pixels, applies digital video data to a video processor 1.5.
- the video processor each time two fields applied are combined so as to form one frame which is stored in a memory 1.7, for example a 5-Mbit DRAM.
- the video data contains 8 bits of luminance information (enabling representation of 256 grey values) and chrominance information.
- the raster of the chrominance information is coarser than that the luminance information, for example one chrominance value, determined by two 8-bit values, per block of 2x2 pixels.
- DCT blocks which can be distinguished as luminance DCT blocks and chrominance DCT blocks.
- Four luminance DCT blocks in conjunction with their two corresponding chrominance DCT blocks form a so-called DCT unit.
- Shuffle (mixing) has an averageing effect, which is advantageous for the data reduction to be subsequently executed.
- Each DCT block is transformed in a known Discrete Cosine Transformation (and inverse DCT) circuit 1.9.
- a data reduction is performed in a known variable-length encoding/decoding circuit 1.10.
- Quantisation can be performed, if desired, in various ways in parallel, each time the most suitable way being chosen.
- one or more microphones 1.3 apply digital audio data to the audio data processor 1.6 which is connected to a memory 1.8, for example a 256-Kbit SRAM.
- a memory 1.8 for example a 256-Kbit SRAM.
- the audio data of the processor 1.6 (in which the blocks are also formed) and the reduced video data of the circuit 1.10 are applied to an error correction encoding/decoding circuit 1.11 in which the data is provided with a known error correction code, for example a Reed-Solomon product code.
- a known error correction code for example a Reed-Solomon product code.
- a code of this kind is described in United States Patent Specification 4,802,173.
- a number of bytes (or other data symbols) to be protected by the error correction code is arranged in a rectangular array, after which so-called parity symbols are added to each horizontal row and each vertical column (i.e. to each horizontal and vertical data word) in accordance with the rules of the relevant code.
- the data words with the added parity symbols are referred to as code words.
- These parity symbols enable, utilising the redundant information they represent, the correction of errors in the array of bytes which occur during the transport of the data or due to the damaging of the storage medium.
- Richard E. Blahut "Theory and practice of error control codes", 1983, Addison-Wesley Publ. Comp. Inc., or N. Glover & T. Dudley: "Practical error correction design for engineers", 1982, Data System Technology Corp., Broomfield Colorado.
- Each segment of 3072 bits forms 3 lines of 128 bytes in an RS video block.
- An RS video block thus comprises 81 lines of 128 bytes which form 81 horizontal data words and 128 vertical data words.
- the parity symbols associated with the constituent data symbols are determined for each RS video block in accordance with a Reed-Solomom product code and are added. For example, first an outer code can be applied to the vertical data words and subsequently an inner code to the horizontal data words.
- the standard notation for such a Reed Solomon code is RS(k+p,k,p+1), where k is the number of data symbols of the code to be protected and p is the number of parity symbols.
- RS(88,81,8) code over GF(256) and derived from the primitive polynomial x 8 +x 4 +x 3 +x 2 +1.
- RS(136,128,9) code over GF(256) and derived from the primitive polynomial x 8 +x 4 +x 3 +x 2 +1.
- the circuit 1.11 is connected to a memory 1.12, for example a 1 Mbit SRAM.
- the data (code words) thus encoded in the recording mode is applied to a known modulator/demodulator circuit 1.13 which modulates the data for supply to two read/write heads 1.14 and 1.15 for recording the data on, for example a magnetic tape.
- the two read/write heads 1.14 and 1.15 read the code words stored on the magnetic tape and apply these words to a modulator/demodulator circuit 1.13 after which the demodulated data is corrected in the circuit 1.11 by means of the parity symbols added on the basis of the Reed-Solomon product code.
- the inner code (applied to the horizontal video and audio code words) is then decoded, after which the corrected data is separated into audio data, applied to the audio processor 1.6, and video data which is subsequently decoded according to the outer code, after which it is applied to the variable length encoding/decoding circuit 1.10.
- the audio processor 1.6 applies an audio data, via a digital-to-analog converter 1.17, to the audio output 1.4.
- variable length decoding/encoding circuit 1.10 then decodes the variable length code, thus supplementing the amount of data bits obtained to 15,360. Subsequently, this data is applied to the DCT circuit 1.9 in which the inverse Discrete Cosine Transformation is performed. The data thus produced is applied to the video processor 1.5 which renders the data suitable for and applies it to the video output 1.2.
- Fig. 2 is a detailed representation of the error correction encoding/decoding circuit 1.11 in accordance with the invention. It comprises a first subcircuit 2.1 with a first encoding circuit 2.2 for encoding data, in the recording mode, according to a first error correction code, a first decoding circuit 2.3 for decoding, in the reproduction mode, data encoded according to the first error correction code, and a first address counter 2.4; a second sub-circuit 2.5 which comprises a second encoding circuit 2.6 for encoding, in the recording mode, data according to a second error correction code, a second decoding circuit 2.7 for decoding, in the reproduction mode, data encoded according to the second error correction code, and a second address counter 2.8; a third sub-circuit 2.9 which comprises an interface circuit 2.10 for the supply of non-encoded data in the recording mode and the output of decoded data in the reproduction mode, and a third address counter 2.11.
- the structure of the circuit 1.11 is such that the external memory 1.12 can be as small as possible and the necessary access to this memory is minimised.
- the circuit furthermore comprises switching means 2.12 and 2.13 which connect the sub-circuits to the external memory 1.12 under the control of a control circuit 2.15.
- the switching means 2.12 connect the address counters 2.4, 2.8 and 2.11 to the address input and output AD of the memory 1.12 and the switching means 2.13 connect the encoding circuit 2.2, the decoding circuit 2.3, the encoding circuit 2.6, the decoding circuit 2.7 and the interface circuit 2.10 to the data input and output I/O of the memory 1.12.
- Each sub-circuit is controlled by its own system clock.
- the system clocks are derived, for example from an external clock signal of 13.5 MHz, each system clock amounting to 4.5 MHz and being phase-shifted with respect to one another, for example through 0, 120 and 240 degrees. Thus, together they determine the frequency of 13.5 MHz used to control the switching means and the external memory by the control circuit 2.15 which receives the external clock signal, generates the system clock and the data stream and also ensures correct addressing in the circuit 1.11 and in the external memory 1.12 by means of the address counters 2.4, 2.8 and 2.11.
- variable-length encoding/decoding circuit 1.10 applies non-encoded (as regards the error correction code to be added) data to the interface circuit 2.10 , which data is row-wise written into the external SRAM 1.12, under the control of the 4.5 MHz system clock of the third sub-circuit, via the switching means.
- the address counter 2.11 Under the control of the control circuit 2.15, the address counter 2.11 then acts as a pointer in the external memory. Any auxiliary data AUX can also be applied to the external memory via the interface circuit 2.10.
- the data symbols are arranged in 81 rows and 128 columns of bytes per RS video block, so that 81 horizontal data words of 128 bytes and 128 vertical data words of 81 bytes are formed per RS video block 81.
- a vertical data word is read from the external SRAM, after which this data word is encoded in the second encoding circuit 2.6 according to the second (outer) error correction code (i.e. the associated parity symbols are determined), after which the calculated (vertical) parity symbols associated with the second error correction code are written into the external SRAM, so that the entire code word associated with the relevant data word is stored in the SRAM.
- the address counter 2.8 acts as a further pointer in the external memory.
- a horizontal data word is read from the external SRAM, after which this data word is encoded according to the first (inner) error correction code in the first encoding circuit 2.2, after which the data word, together with the calculated (horizontal) parity symbols associated with the first error corection code (i.e. the horizontal code word), is not stored but applied directly to the modulator/demodulator circuit 1.13.
- the address counter 2.4 then acts as a further pointer in the external memory.
- the previously determined vertical parity symbols of the second (outer) error correction code also form horizontal data words which are thus processed in the first encoding circuit 2.2.
- audio data is also processed (for example in a multiplex fashion): the audio processor 1.6 applies audio data to the circuit 2.2 which provides this data with parity symbols associated with the first error correction code, after which the data is applied, together with the associated, calculated parity symbols, to the modulator/demodulator circuit 1.13.
- the modulator/demodulator circuit 1.13 applies data to the first decoding circuit 2.3 which determines, on the basis of the identification information generated in and despatched by the circuit 1.13, whether the encoded horizontal data word (i.e. horizontal code word) concerns audio data or video data.
- Audio data is decoded according to the first (inner) error correction code and is applied to the audio processor 1.6;
- video data is decoded according to the first (inner) error correction code and, if correctable, it is written into the external memory 1.12 under the control of the 4.5 MHz system clock of the first sub-circuit.
- the address counter 2.4 Under the control of the control circuit 2.15, the address counter 2.4 then acts as a pointer in the external memory.
- the addresses at which the data is stored in the memory are contained in the identification information generated in the circuit 1.13.
- the second decoding circuit 2.7 reads vertical encoded data words (i.e. vertical video code words) from the external SRAM, decodes these words according to the second error correction code, and writes only those data symbols of each relevant data word into the external memory 1.12 that have been corrected by decoding.
- the address counter 2.8 then acts as a further pointer in the external memory.
- the decoded data is read from the external memory 1.12 and applied to the variable-length encoding/decoding circuit 1.10 or is output as auxiliary data AUX.
- the address counter 2.11 then acts as a further pointer in the external memory under the control of the control circuit 2.15.
- a 1-Mbit SRAM can be used as a standard memory; this is approximately 1049 Kbits. The remaining 53 Kbit is used for the storage of the further parity symbols of 6 RS video blocks of the relevant frame, see Fig. 3.
- the address counters or pointers A1, A2 and A3 (associated with the respective sub-circuits) cyclically and simultaneously scan the external memory, the control circuit 2.15 ensuring that the pointers do not overtake one another and hence can proceed in the rhythm of their system clock.
- the simultaneous cyclic scanning of the external memory under the control of the control circuit 2.15 takes place in the reverse order during the recording mode and the reproduction mode.
- the vertical parity symbols of 6 RS video blocks are cyclically stored in the appropriate storage spaces VP1/7 to VP6/12.
- the storage space VP1/7 for example contains the parity symbols of the RS video block 1 or of the RS video block 7, depending on the phase in the cycle of the address counters.
- the control circuit 2.15 ensures that in the recording mode the address counter A2 erases the relevant vertical parity symbols only after they have been read by the address counter A1, and that in the reproduction mode the address counter A1 erases the relevant vertical parity symbols only after they have been read by the address counter A2.
- the specification of the 1 Mbit SRAM to be used is: 128 Kbit * 8, frequency 13.5 MHz, bidirectional 8-bit data bus.
- the Reed-Solomon product code used employs an outer code which operates on the vertical data words and an inner code which operates on the horizontal data words.
- the inner code has 8 parity symbols and the outer code has 7 parity symbols.
- the error correction strategy is as follows.
- the inner code serves to correct single bit errors (incidental errors) and to detect burst errors (string of bit errors).
- the outer code serves to correct horizontal detected errors (erasures) and to correct any miscorrections by the horizontal decoder.
- 6 of the 8 parity symbols of the inner code can be used to correct at the most 3 errors.
- the remaining 2 parity symbols then serve as an additional detection margin.
- the entire data word is not written into the SRAM, but is made an erasure in its entirety by means of a correction bit as will be described hereinafter.
- the corresponding preceding data word from the previous frame then remains in the memory.
- 4 of the 8 parity symbols of the inner code can be used for the correction of at the most 2 errors.In that case the remaining 4 parity symbols are used as an additional detection margin.
- the 7 parity symbols of the outer code can all be used for the correction of at the most 7 detected erasures.
- An other possibility consists in that 2 parity symbols are used for the correction of 1 error and the remaining 5 parity symbols are used for the correction of detected erasures. Any miscorrection occurring can thus also be corrected. 1 parity symbol can also be used as an additional detection margin.
- the circuit 1.11 comprises an embedded SRAM 2.14 (see Fig. 2), connected to the address counters 2.4 and 2.8, the encoding circuits 2.2 and 2.6, and the decoding circuits 2.3 and 2.7 of the first and the second sub-circuit.
- a so-called correction bit is stored in the memory 2.14 for each horizontal data word.
- This correction bit indicates whether or not the relevant data word was correctable by means of the inner code (corrected or errorless and hence now correct). Any miscorrections, for which the probability of occurrence is very small, are ignored in this respect.
- the correction bit has the logic value 1 and otherwise the logic value 0. Each correction bit having the value 0 is thus associated with a horizontal data word consisting of erasures.
- the second decoding circuit 2.7 When the second decoding circuit 2.7 reads the vertical code words from the external memory in the reproduction mode, the correction bits associated with the horizontal data words are also read from the memory 2.14.
- the outer decoding circuit thus knows where the erasures to be corrected are located. In the memory 2.14 it is also memorised for the vertical data words whether they are correct. When the data word is correct the correction bit has the logic value 1 and otherwise the logic value 0.
- the control circuit can thus provide a reliability indication for each byte: if the horizontal data word or the vertical data word containing the relevant byte is correct (i.e. if at least one of the two correction bits of relevance to the byte has the logic value 1), the byte is reliable.
- This reliability information can be applied, via the circuit 2.10, to the variable length encoding/decoding circuit 1.10. Moreover, when a given threshold value concerning the number of unreliable bytes is exceeded, an indication signal can be generated to indicate that the quality of the tape or the heads is insufficient.
- time can be saved as follows during the decoding of the vertical code words by the second (outer) decoding circuit 2.7.
- the Reed-Solomon decoder circuit used generates the difference value between the correct value and the incorrect value during the correction of an erasure (i.e. the calculation of the correct value of an incorrect byte whose location is known), it is advantageous to enter the value "O" into the decoding circuit. This is because the circuit then generates directly the correct value which need merely be written into the external memory.
Landscapes
- Engineering & Computer Science (AREA)
- Signal Processing (AREA)
- Multimedia (AREA)
- Physics & Mathematics (AREA)
- Mathematical Physics (AREA)
- General Physics & Mathematics (AREA)
- Algebra (AREA)
- Pure & Applied Mathematics (AREA)
- Probability & Statistics with Applications (AREA)
- Theoretical Computer Science (AREA)
- Error Detection And Correction (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
- Color Television Systems (AREA)
- Reduction Or Emphasis Of Bandwidth Of Signals (AREA)
- Television Signal Processing For Recording (AREA)
Abstract
Description
- The invention relates to a circuit for the encoding and decoding of digital data with an error correction code.
- In a circuit of this kind, digital data words are formed in a stream of digital data, each data word being encoded according to a given error correction code (i.e. provided with so-called parity symbols) after which they are stored as code words on a storage medium (upon recording). Should the code words no longer correspond completely to the original code words, due to disturbances or damaging of any kind after recovery from the storage medium (upon reproduction), the redundant information in the parity symbols enables error correction upon decoding. It is often advantageous to use a combination of two error correction codes. To this end, the digital data symbols (such as bytes) can be arranged, for example, in rectangular blocks, so that data words are formed in the horizontal and the vertical direction. The horizontal data words on the one side and the vertical data words on the other side can then be protected by way of two (possibly different) codes. The codes together are also referred to as a product code. For encoding and decoding it is necessary to store the digital data temporarily block-wise in an external frame memory. In order to enable simple and fast reading and writing in such an external frame memory, accompanied by a low power dissipation and limited use of wiring, it is advantageous when one (standard) memory suffices.
- The invention inter alia has for its object to provide an encoding/decoding circuit which requires a small external frame memory. To achieve this, the invention as defined in
claim 1 provides an encoding/decoding circuit which comprises a first sub-circuit for encoding data in the recording mode and decoding data in the reproduction mode according to a first error correction code, a second sub-circuit for encoding data in the recording mode and decoding data in the reproduction mode according to a second error correction code, a third sub-circuit for the supply of non-encoded data in the recording mode and the output of decoded data in the reproduction mode, the first sub-circuit being suitable to output encoded data in the recording mode and to supply encoded data in the reproduction mode, each sub-circuit being suitable to receive clock signals from its own system clock having a frequency, the circuit also comprising switching means which are connected to said sub-circuits and which are controlled by a control circuit for cyclically connecting the sub-circuits, via the switching means, to a terminal for data transfer from and to an external frame memory at a frequency which is at least equal to the sum of the frequencies of the system clocks of the sub-circuits. As a result of the use of fast switching means, for example multiplexers which are controlled at a frequency which is at least equal to the sum of the frequencies of the system clocks of the sub-circuits, it is achieved that all three sub-circuits can communiate as if it were parallel with a single external memory. The control circuit cyclically connects each time one sub-circuit to the external memory, but at such a high frequency that all sub-circuits can access to the memory for a sufficiently long period of time. A cycle is then determined by the frequencies of the system clocks. Therefore, the sub-circuits are not necessarily alternately connected to the memory. - Fig. 1 shows a digital video system suitable for use of a circuit in accordance with the invention;
- Fig. 2 shows the encoding/decoding circuit in accordance with the invention;
- Fig. 3 illustrates the use of the external frame memory.
- Fig. 1 shows a digital video system suitable for use of a circuit in accordance with the invention. A digital image pick up unit 1.1, for example a CCD camera generating 25 frames (50 fields) per second, each with approximately 420.000 pixels, applies digital video data to a video processor 1.5. In the video processor each time two fields applied are combined so as to form one frame which is stored in a memory 1.7, for example a 5-Mbit DRAM. Per pixel the video data contains 8 bits of luminance information (enabling representation of 256 grey values) and chrominance information. Generally, the raster of the chrominance information is coarser than that the luminance information, for example one chrominance value, determined by two 8-bit values, per block of 2x2 pixels. In the video processor 1.5 there are also formed blocks of 8x8 pixels, so called DCT blocks, which can be distinguished as luminance DCT blocks and chrominance DCT blocks. Four luminance DCT blocks in conjunction with their two corresponding chrominance DCT blocks form a so-called DCT unit. Each time five DCT units, obtained in the video processor 1.5 by shuffle, constitute a so-called segment. Shuffle (mixing) has an averageing effect, which is advantageous for the data reduction to be subsequently executed. Each DCT block is transformed in a known Discrete Cosine Transformation (and inverse DCT) circuit 1.9. Subsequently, per segment (i.e. 30 DCT blocks) a data reduction is performed in a known variable-length encoding/decoding circuit 1.10. Therein, 30*64*8=15,360 bits are reduced to 3072 bits, using known techniques such as quantisation and variable-length encoding. Quantisation can be performed, if desired, in various ways in parallel, each time the most suitable way being chosen.
- Via an analog-to-digital converter 1.16 one or more microphones 1.3 apply digital audio data to the audio data processor 1.6 which is connected to a memory 1.8, for example a 256-Kbit SRAM. Generally speaking, the amount of audio data is much smaller than the amount of video data, so that the audio data need not be reduced. The audio data of the processor 1.6 (in which the blocks are also formed) and the reduced video data of the circuit 1.10 are applied to an error correction encoding/decoding circuit 1.11 in which the data is provided with a known error correction code, for example a Reed-Solomon product code. A code of this kind is described in United States Patent Specification 4,802,173. A number of bytes (or other data symbols) to be protected by the error correction code is arranged in a rectangular array, after which so-called parity symbols are added to each horizontal row and each vertical column (i.e. to each horizontal and vertical data word) in accordance with the rules of the relevant code. The data words with the added parity symbols are referred to as code words. These parity symbols enable, utilising the redundant information they represent, the correction of errors in the array of bytes which occur during the transport of the data or due to the damaging of the storage medium. In this respect reference is also made to Richard E. Blahut: "Theory and practice of error control codes", 1983, Addison-Wesley Publ. Comp. Inc., or N. Glover & T. Dudley: "Practical error correction design for engineers", 1982, Data System Technology Corp., Broomfield Colorado.
- The number of luminance DCT blocks per frame amounts to 720/8*576/8 = 90*72 = 6480. Per frame there are 360/8*288/8*2 = 3240 chrominance DCT blocks. Thus, there are 1620 DCT units per frame, or 324 segments per frame. In the case of a field frequency of 50 Hz, a frame is divided into 12 so-called tracks (in the case of a field frequency of 60 Hz, a frame is divided into 10 tracks). Such a track contains, in addition to the data symbols and the parity symbols, inter alia identification and synchronisation information. The data symbols and the parity symbols of a track are referred to hereinafter as a RS video block. Per video block, therefore, there are 27 segments. Each segment of 3072 bits (= 384 bytes) forms 3 lines of 128 bytes in an RS video block. This includes 1 byte of auxiliary data AUX per line, for example, data concerning the elapsed time or the frame number. An RS video block thus comprises 81 lines of 128 bytes which form 81 horizontal data words and 128 vertical data words. Subsequently, in the circuit 1.11 the parity symbols associated with the constituent data symbols are determined for each RS video block in accordance with a Reed-Solomom product code and are added. For example, first an outer code can be applied to the vertical data words and subsequently an inner code to the horizontal data words. The standard notation for such a Reed Solomon code is RS(k+p,k,p+1), where k is the number of data symbols of the code to be protected and p is the number of parity symbols. For the outer code use can be made of RS(88,81,8), code over GF(256) and derived from the primitive polynomial x8+x4+x3+x2+1. For the inner code use can be made of: RS(136,128,9), code over GF(256) and derived from the primitive polynomial x8+x4+x3+x2+1.
- To this end, the circuit 1.11 is connected to a memory 1.12, for example a 1 Mbit SRAM. The data (code words) thus encoded in the recording mode is applied to a known modulator/demodulator circuit 1.13 which modulates the data for supply to two read/write heads 1.14 and 1.15 for recording the data on, for example a magnetic tape.
- For the reconstruction of the video and audio signals, the two read/write heads 1.14 and 1.15 read the code words stored on the magnetic tape and apply these words to a modulator/demodulator circuit 1.13 after which the demodulated data is corrected in the circuit 1.11 by means of the parity symbols added on the basis of the Reed-Solomon product code. First the inner code (applied to the horizontal video and audio code words) is then decoded, after which the corrected data is separated into audio data, applied to the audio processor 1.6, and video data which is subsequently decoded according to the outer code, after which it is applied to the variable length encoding/decoding circuit 1.10. The audio processor 1.6 applies an audio data, via a digital-to-analog converter 1.17, to the audio output 1.4. The variable length decoding/encoding circuit 1.10 then decodes the variable length code, thus supplementing the amount of data bits obtained to 15,360. Subsequently, this data is applied to the DCT circuit 1.9 in which the inverse Discrete Cosine Transformation is performed. The data thus produced is applied to the video processor 1.5 which renders the data suitable for and applies it to the video output 1.2.
- Fig. 2 is a detailed representation of the error correction encoding/decoding circuit 1.11 in accordance with the invention. It comprises a first subcircuit 2.1 with a first encoding circuit 2.2 for encoding data, in the recording mode, according to a first error correction code, a first decoding circuit 2.3 for decoding, in the reproduction mode, data encoded according to the first error correction code, and a first address counter 2.4; a second sub-circuit 2.5 which comprises a second encoding circuit 2.6 for encoding, in the recording mode, data according to a second error correction code, a second decoding circuit 2.7 for decoding, in the reproduction mode, data encoded according to the second error correction code, and a second address counter 2.8; a third sub-circuit 2.9 which comprises an interface circuit 2.10 for the supply of non-encoded data in the recording mode and the output of decoded data in the reproduction mode, and a third address counter 2.11. The structure of the circuit 1.11 is such that the external memory 1.12 can be as small as possible and the necessary access to this memory is minimised. To achieve this, the circuit furthermore comprises switching means 2.12 and 2.13 which connect the sub-circuits to the external memory 1.12 under the control of a control circuit 2.15. The switching means 2.12 connect the address counters 2.4, 2.8 and 2.11 to the address input and output AD of the memory 1.12 and the switching means 2.13 connect the encoding circuit 2.2, the decoding circuit 2.3, the encoding circuit 2.6, the decoding circuit 2.7 and the interface circuit 2.10 to the data input and output I/O of the memory 1.12. Each sub-circuit is controlled by its own system clock. The system clocks are derived, for example from an external clock signal of 13.5 MHz, each system clock amounting to 4.5 MHz and being phase-shifted with respect to one another, for example through 0, 120 and 240 degrees. Thus, together they determine the frequency of 13.5 MHz used to control the switching means and the external memory by the control circuit 2.15 which receives the external clock signal, generates the system clock and the data stream and also ensures correct addressing in the circuit 1.11 and in the external memory 1.12 by means of the address counters 2.4, 2.8 and 2.11.
- In the recording mode the data stream is controlled by the control circuit 2.15 as follows. The variable-length encoding/decoding circuit 1.10 applies non-encoded (as regards the error correction code to be added) data to the interface circuit 2.10 , which data is row-wise written into the external SRAM 1.12, under the control of the 4.5 MHz system clock of the third sub-circuit, via the switching means. Under the control of the control circuit 2.15, the address counter 2.11 then acts as a pointer in the external memory. Any auxiliary data AUX can also be applied to the external memory via the interface circuit 2.10. As described above, the data symbols are arranged in 81 rows and 128 columns of bytes per RS video block, so that 81 horizontal data words of 128 bytes and 128 vertical data words of 81 bytes are formed per
RS video block 81. Under the control of the 4.5 MHz system clock of the second sub-circuit, a vertical data word is read from the external SRAM, after which this data word is encoded in the second encoding circuit 2.6 according to the second (outer) error correction code (i.e. the associated parity symbols are determined), after which the calculated (vertical) parity symbols associated with the second error correction code are written into the external SRAM, so that the entire code word associated with the relevant data word is stored in the SRAM. Under the control of the control circuit 2.15, the address counter 2.8 then acts as a further pointer in the external memory. Under the control of the 4.5 MHz system clock of the first sub-circuit, a horizontal data word is read from the external SRAM, after which this data word is encoded according to the first (inner) error correction code in the first encoding circuit 2.2, after which the data word, together with the calculated (horizontal) parity symbols associated with the first error corection code (i.e. the horizontal code word), is not stored but applied directly to the modulator/demodulator circuit 1.13. Under the control of the control circuit 2.15 the address counter 2.4 then acts as a further pointer in the external memory. The previously determined vertical parity symbols of the second (outer) error correction code also form horizontal data words which are thus processed in the first encoding circuit 2.2. In alternation with this processing of video data in the circuit 2.2, audio data is also processed (for example in a multiplex fashion): the audio processor 1.6 applies audio data to the circuit 2.2 which provides this data with parity symbols associated with the first error correction code, after which the data is applied, together with the associated, calculated parity symbols, to the modulator/demodulator circuit 1.13. - In the reproduction mode the data stream is as follows. The modulator/demodulator circuit 1.13 applies data to the first decoding circuit 2.3 which determines, on the basis of the identification information generated in and despatched by the circuit 1.13, whether the encoded horizontal data word (i.e. horizontal code word) concerns audio data or video data. Audio data is decoded according to the first (inner) error correction code and is applied to the audio processor 1.6; video data is decoded according to the first (inner) error correction code and, if correctable, it is written into the external memory 1.12 under the control of the 4.5 MHz system clock of the first sub-circuit. Under the control of the control circuit 2.15, the address counter 2.4 then acts as a pointer in the external memory. The addresses at which the data is stored in the memory are contained in the identification information generated in the circuit 1.13. Under the control of the 4.5 MHz system clock of the second sub-circuit, the second decoding circuit 2.7 reads vertical encoded data words (i.e. vertical video code words) from the external SRAM, decodes these words according to the second error correction code, and writes only those data symbols of each relevant data word into the external memory 1.12 that have been corrected by decoding. Under the control of the control circuit 2.15, the address counter 2.8 then acts as a further pointer in the external memory. Under the control of the 4.5 MHz system clock of the third sub-circuit, the decoded data is read from the external memory 1.12 and applied to the variable-length encoding/decoding circuit 1.10 or is output as auxiliary data AUX. The address counter 2.11 then acts as a further pointer in the external memory under the control of the control circuit 2.15.
- A storage capacity of 128*81*12*8=995328 bits (# bytes per line times # lines per RS video block times # RS video blocks per frame # bits per byte) is required for the storage of a complete frame in the external memory. A 1-Mbit SRAM can be used as a standard memory; this is approximately 1049 Kbits. The remaining 53 Kbit is used for the storage of the further parity symbols of 6 RS video blocks of the relevant frame, see Fig. 3. The address counters or pointers A1, A2 and A3 (associated with the respective sub-circuits) cyclically and simultaneously scan the external memory, the control circuit 2.15 ensuring that the pointers do not overtake one another and hence can proceed in the rhythm of their system clock. The simultaneous cyclic scanning of the external memory under the control of the control circuit 2.15 takes place in the reverse order during the recording mode and the reproduction mode. Moreover, the vertical parity symbols of 6 RS video blocks are cyclically stored in the appropriate storage spaces VP1/7 to VP6/12. The storage space VP1/7, for example contains the parity symbols of the
RS video block 1 or of theRS video block 7, depending on the phase in the cycle of the address counters. The control circuit 2.15 ensures that in the recording mode the address counter A2 erases the relevant vertical parity symbols only after they have been read by the address counter A1, and that in the reproduction mode the address counter A1 erases the relevant vertical parity symbols only after they have been read by the address counter A2. The specification of the 1 Mbit SRAM to be used is: 128 Kbit * 8, frequency 13.5 MHz, bidirectional 8-bit data bus. - As has already been described, the Reed-Solomon product code used employs an outer code which operates on the vertical data words and an inner code which operates on the horizontal data words. The inner code has 8 parity symbols and the outer code has 7 parity symbols. The error correction strategy is as follows. The inner code serves to correct single bit errors (incidental errors) and to detect burst errors (string of bit errors). The outer code serves to correct horizontal detected errors (erasures) and to correct any miscorrections by the horizontal decoder. To this end, 6 of the 8 parity symbols of the inner code can be used to correct at the most 3 errors. The remaining 2 parity symbols then serve as an additional detection margin. Thus, the results of the correction calculation (6 equations with 6 unknowns) are inserted in the remaining seventh and eighth equation for checking purposes, so that additional certainty is obtained as regards the correctness of the calculated corrections. The probability of a miscorrection then amounts to approximately 3*10-7 for the horizontal decoder (see, for example R.J. McEliece & L.Swanson: "On the decoder error probability for Reed-Solomon codes", IEEE Transactions on Inform. Th., IT-32,5, 1986, pp. 701-703). When more than 3 errors are detected in a horizontal data word, evidently a burst error is concerned. In that case the entire data word is not written into the SRAM, but is made an erasure in its entirety by means of a correction bit as will be described hereinafter. The corresponding preceding data word from the previous frame then remains in the memory. Alternatively, 4 of the 8 parity symbols of the inner code can be used for the correction of at the most 2 errors.In that case the remaining 4 parity symbols are used as an additional detection margin. The 7 parity symbols of the outer code can all be used for the correction of at the most 7 detected erasures. An other possibility consists in that 2 parity symbols are used for the correction of 1 error and the remaining 5 parity symbols are used for the correction of detected erasures. Any miscorrection occurring can thus also be corrected. 1 parity symbol can also be used as an additional detection margin.
- The inner code and the outer code thus cooperate: the inner code corrects small random errors and detects burst errors so that the outer code already knows about the location of the erasures corrected. In order to enable such cooperation between the inner and the outer decoder, the circuit 1.11 comprises an embedded SRAM 2.14 (see Fig. 2), connected to the address counters 2.4 and 2.8, the encoding circuits 2.2 and 2.6, and the decoding circuits 2.3 and 2.7 of the first and the second sub-circuit. In the reproduction mode, after the decoding of the video data according to the first (inner) error correction code in the circuit 2.3 and the writing of only the correctable (corrected or errorless) horizontal data words into the memory 1.12, a so-called correction bit is stored in the memory 2.14 for each horizontal data word. This correction bit indicates whether or not the relevant data word was correctable by means of the inner code (corrected or errorless and hence now correct). Any miscorrections, for which the probability of occurrence is very small, are ignored in this respect. When the data word is correct, the correction bit has the
logic value 1 and otherwise the logic value 0. Each correction bit having the value 0 is thus associated with a horizontal data word consisting of erasures. When the second decoding circuit 2.7 reads the vertical code words from the external memory in the reproduction mode, the correction bits associated with the horizontal data words are also read from the memory 2.14. The outer decoding circuit thus knows where the erasures to be corrected are located. In the memory 2.14 it is also memorised for the vertical data words whether they are correct. When the data word is correct the correction bit has thelogic value 1 and otherwise the logic value 0. The control circuit can thus provide a reliability indication for each byte: if the horizontal data word or the vertical data word containing the relevant byte is correct (i.e. if at least one of the two correction bits of relevance to the byte has the logic value 1), the byte is reliable. This reliability information can be applied, via the circuit 2.10, to the variable length encoding/decoding circuit 1.10. Moreover, when a given threshold value concerning the number of unreliable bytes is exceeded, an indication signal can be generated to indicate that the quality of the tape or the heads is insufficient. - In the reproduction mode, time can be saved as follows during the decoding of the vertical code words by the second (outer) decoding circuit 2.7. When the Reed-Solomon decoder circuit used generates the difference value between the correct value and the incorrect value during the correction of an erasure (i.e. the calculation of the correct value of an incorrect byte whose location is known), it is advantageous to enter the value "O" into the decoding circuit. This is because the circuit then generates directly the correct value which need merely be written into the external memory.
- It is to be noted that when use is made of an external SRAM 1.12 which cannot be operated at a clock frequency as high as 13.5 MHz, it is possible to use a 16-bit data bus structure instead of an 8-bit data bus structure, so that the frequency can be halved. In that case, for example, two standard 1-Mbit memories can be used in parallel using the same addressing, the 8 bits presented by the sub-circuits then being buffered as 16 bits which are each time split into 8-bit portions by the switching means 2.13, said portions being applied to the respective data inputs and outputs I/O of the two memories at half the frequency. Conversely, the 8-bit portions supplied at half the frequency by the two memories are then combined to 16 bits by the switching means, each
time 8 bits thereof being applied to the sub-circuits at the original frequency.
Claims (4)
- A circuit being arranged for bidirectional attachment between a user channel (1.10) and a system channel (1.13), for encoding user data symbols by means of a product code to error protected system data symbols, as well as for decoding such error protected system data symbols to user data symbols while executing an error correction operation,said circuit having a first subcircuit (2.1) attached to said system channel (1.13) for decoding first layer words of said product code for presentation to a local read-write memory (1.12) whilst producing intermediate error protectivity data, a second subcircuit (2.5) for decoding second layer code words of said product code accessed in said read write-memory (1.12) and on the basis of said intermediate error protectivity data, and a third subcircuit (2.9) for accessing decoded user symbols for presentation onto said user channel,said third sub-circuit (2.9) being arranged for receiving user symbols from said user channel for presentation to said local read-write memory (1.12), said second sub-circuit (2.5) being arranged for accessing said user symbols in said local read-write memory (1.12) for therefrom constituting second layer code words by means of added redundancy symbols for presentation to said read-write memory (1.12), said first sub-circuit (2.1) being arranged for accessing said second layer code words in said local read-write memory (1.12) for therefrom constituting first layer code words by means of further added redundancy symbols for presentation to said system channel (1.13),said circuit furthermore comprising control means (2.15) for controlling mutually exclusive access cycles to said local read-write memory (1.12) among said first, second and third sub-circuits at a uniform control frequency that is at least equal to the sum of the maximum access frequencies of said first, second and third sub-circuits.
- A circuit as claimed in Claim 1, wherein said maximum access frequencies are equal among said first, second, and third sub-circuits.
- A circuit as claimed in Claim 2, wherein said access cycles are cyclically assigned to said first, second and third subcircuits in a first order at encoding, and in a second order opposed thereto at decoding.
- A circuit as claimed in Claims 1, 2 or 3, wherein said first sub-circuit (2.1) is arranged for presenting said intermediate error protectivity data to an embedded memory (2.14) for subsequent accessing by said second sub-circuit (2.5).
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
NL9100218 | 1991-02-07 | ||
NL9100218A NL9100218A (en) | 1991-02-07 | 1991-02-07 | ENCODE / DECODE SWITCH AND DIGITAL VIDEO SYSTEM FITTED WITH THE SWITCH. |
Publications (2)
Publication Number | Publication Date |
---|---|
EP0498501A1 EP0498501A1 (en) | 1992-08-12 |
EP0498501B1 true EP0498501B1 (en) | 1997-04-02 |
Family
ID=19858846
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP92200268A Expired - Lifetime EP0498501B1 (en) | 1991-02-07 | 1992-01-31 | Encoding/decoding circuit, and digital video system comprising the circuit |
Country Status (7)
Country | Link |
---|---|
US (1) | US5469448A (en) |
EP (1) | EP0498501B1 (en) |
JP (1) | JP3255681B2 (en) |
KR (1) | KR100250590B1 (en) |
AT (1) | ATE151191T1 (en) |
DE (1) | DE69218648T2 (en) |
NL (1) | NL9100218A (en) |
Families Citing this family (24)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR100269748B1 (en) * | 1993-01-30 | 2000-10-16 | 윤종용 | Video data processing method and apparatus of digital vtr |
KR100285109B1 (en) * | 1993-04-27 | 2001-03-15 | 윤종용 | Digital video data processing method |
KR100319990B1 (en) * | 1993-09-29 | 2002-04-22 | 이데이 노부유끼 | Data playback method and data playback device |
US5583562A (en) * | 1993-12-03 | 1996-12-10 | Scientific-Atlanta, Inc. | System and method for transmitting a plurality of digital services including imaging services |
DE69430293D1 (en) * | 1993-12-16 | 2002-05-08 | Koninkl Philips Electronics Nv | Device for coding and decoding with a memory organized in pages (paged memory) |
US5638227A (en) * | 1993-12-17 | 1997-06-10 | Matsushita Electric Industrial Co., Ltd. | Digital data recording and reproducing apparatus |
US6330644B1 (en) | 1994-10-27 | 2001-12-11 | Canon Kabushiki Kaisha | Signal processor with a plurality of kinds of processors and a shared memory accessed through a versatile control means |
EP0791249B1 (en) * | 1995-09-08 | 2002-07-03 | Koninklijke Philips Electronics N.V. | Transmitter and receiver apparatus, method for transmitting and method for receiving and record carrier obtained by the method or the transmitter apparatus |
DE69619359T2 (en) * | 1995-11-10 | 2002-10-24 | Koninklijke Philips Electronics N.V., Eindhoven | FAULT PROTECTION METHOD AND DEVICE FOR PROGRAMMABLE STORAGE |
US6052415A (en) * | 1997-08-26 | 2000-04-18 | International Business Machines Corporation | Early error detection within an MPEG decoder |
JP3256517B2 (en) * | 1999-04-06 | 2002-02-12 | インターナショナル・ビジネス・マシーンズ・コーポレーション | Encoding circuit, circuit, parity generation method, and storage medium |
US6651214B1 (en) * | 2000-01-06 | 2003-11-18 | Maxtor Corporation | Bi-directional decodable Reed-Solomon codes |
KR100566911B1 (en) * | 2001-06-25 | 2006-04-03 | 주식회사 삼양사 | Negatively charged amphiphilic block copolymer as drug carrier and complex thereof with positively charged drug |
US8055979B2 (en) * | 2006-01-20 | 2011-11-08 | Marvell World Trade Ltd. | Flash memory with coding and signal processing |
US7844879B2 (en) * | 2006-01-20 | 2010-11-30 | Marvell World Trade Ltd. | Method and system for error correction in flash memory |
US7962827B2 (en) * | 2006-03-08 | 2011-06-14 | Marvell World Trade Ltd. | Systems and methods for achieving higher coding rate using parity interleaving |
US8583981B2 (en) * | 2006-12-29 | 2013-11-12 | Marvell World Trade Ltd. | Concatenated codes for holographic storage |
WO2009051693A2 (en) | 2007-10-15 | 2009-04-23 | Thomson Licensing | Preamble for a digital television system |
JP2009100222A (en) * | 2007-10-16 | 2009-05-07 | Toshiba Corp | Device and method for decoding low density parity check code |
US9195675B2 (en) * | 2011-02-24 | 2015-11-24 | A9.Com, Inc. | Decoding of variable-length data with group formats |
US8615698B1 (en) * | 2011-09-28 | 2013-12-24 | Google Inc. | Skewed orthogonal coding techniques |
CN104919433B (en) | 2013-01-11 | 2017-10-31 | 英派尔科技开发有限公司 | The page for flash memory is distributed |
US8891296B2 (en) | 2013-02-27 | 2014-11-18 | Empire Technology Development Llc | Linear Programming based decoding for memory devices |
WO2015088552A1 (en) * | 2013-12-13 | 2015-06-18 | Empire Technology Development Llc | Low-complexity flash memory data-encoding techniques using simplified belief propagation |
Family Cites Families (16)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3831143A (en) * | 1971-11-26 | 1974-08-20 | Computer Science Corp | Concatenated burst-trapping codes |
US4276646A (en) * | 1979-11-05 | 1981-06-30 | Texas Instruments Incorporated | Method and apparatus for detecting errors in a data set |
HU193077B (en) * | 1983-12-16 | 1987-08-28 | Sony Corp | Record player apparatus |
CA1310112C (en) * | 1985-05-21 | 1992-11-10 | Takao Abe | Apparatus for decoding error correcting code |
NL8601446A (en) * | 1986-06-05 | 1988-01-04 | Philips Nv | METHOD AND DEVICE FOR DECODING A BLOCK OF CODE SYMBOLS DIVIDED IN TWO WAYS OF CODEWORDS EACH PROTECTED BY A MINIMUM REMOTE SAVABLE CODE. |
JPS63274222A (en) * | 1987-05-01 | 1988-11-11 | Matsushita Electric Ind Co Ltd | Interleaving method |
US4998252A (en) * | 1987-08-06 | 1991-03-05 | Sony Corporation | Method and apparatus for transmitting digital data |
US4943964A (en) * | 1987-08-12 | 1990-07-24 | Hitachi, Ltd. | PCM signal reproducing device |
JPS6462027A (en) * | 1987-09-01 | 1989-03-08 | Nippon Conlux Co Ltd | Error correcting circuit |
JP2692096B2 (en) * | 1987-12-24 | 1997-12-17 | 日本電気株式会社 | Code error correction circuit |
US5220568A (en) * | 1988-05-31 | 1993-06-15 | Eastman Kodak Company | Shift correcting code for channel encoded data |
DE3838234A1 (en) * | 1988-11-11 | 1990-05-17 | Broadcast Television Syst | METHOD AND CIRCUIT FOR DETECTING AND CORRECTING ERRORS IN DATA WORDS |
SG45361A1 (en) * | 1989-05-16 | 1998-01-16 | Canon Kk | Device for processing transmitted digital video signal |
US5247523A (en) * | 1989-07-12 | 1993-09-21 | Hitachi, Ltd. | Code error correction apparatus |
JP2870843B2 (en) * | 1989-08-31 | 1999-03-17 | ソニー株式会社 | Information transmission equipment |
US5140596A (en) * | 1990-02-20 | 1992-08-18 | Eastman Kodak Company | High speed encoder for non-systematic codes |
-
1991
- 1991-02-07 NL NL9100218A patent/NL9100218A/en not_active Application Discontinuation
-
1992
- 1992-01-31 AT AT92200268T patent/ATE151191T1/en not_active IP Right Cessation
- 1992-01-31 EP EP92200268A patent/EP0498501B1/en not_active Expired - Lifetime
- 1992-01-31 DE DE69218648T patent/DE69218648T2/en not_active Expired - Fee Related
- 1992-02-01 KR KR1019920001583A patent/KR100250590B1/en not_active IP Right Cessation
- 1992-02-07 JP JP02294592A patent/JP3255681B2/en not_active Expired - Fee Related
-
1994
- 1994-02-08 US US08/193,613 patent/US5469448A/en not_active Expired - Fee Related
Also Published As
Publication number | Publication date |
---|---|
US5469448A (en) | 1995-11-21 |
KR100250590B1 (en) | 2000-04-01 |
ATE151191T1 (en) | 1997-04-15 |
DE69218648D1 (en) | 1997-05-07 |
JP3255681B2 (en) | 2002-02-12 |
DE69218648T2 (en) | 1997-10-02 |
KR920017378A (en) | 1992-09-26 |
NL9100218A (en) | 1992-09-01 |
JPH04320114A (en) | 1992-11-10 |
EP0498501A1 (en) | 1992-08-12 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP0498501B1 (en) | Encoding/decoding circuit, and digital video system comprising the circuit | |
US5757824A (en) | Code error correction apparatus | |
EP1125294B1 (en) | Multi-level error detection and correction technique for data storage recording device | |
US6378103B1 (en) | Apparatus and method for error correction in optical disk system | |
KR100200801B1 (en) | Error correction device | |
JPH0264970A (en) | Reproducing device | |
EP0553515B1 (en) | Device for processing digital data, and digital video system comprising the device | |
JPH0520105A (en) | Error correction device of degital data | |
KR100539261B1 (en) | Digital Data Coding and Recording Device for DVD and Method thereof | |
US4912695A (en) | Method for recording information including error information on a disk | |
US6047398A (en) | Reproducing method, reproducing apparatus and recording and reproducing apparatus using the same reproducing method, and recording medium having the same method recorded therein | |
JP3869598B2 (en) | Digital data encoding processing circuit, encoding processing method, and digital data recording apparatus including encoding processing circuit | |
US5805618A (en) | Reproducing apparatus for reproducing video information recorded together with error correction codes | |
JPH0448473A (en) | Digital video signal reproducing device | |
KR100223821B1 (en) | The circuit and method for error correction in a dvd | |
JP3768640B2 (en) | Playback device | |
KR0144975B1 (en) | Sink code interleave method and apparatus thereof | |
JPH1186465A (en) | Signal processor | |
JP3082458B2 (en) | Image modification device | |
JPH043525A (en) | Code error correcting device | |
KR100207617B1 (en) | Address generation circuit for de-shuffling | |
KR930009533B1 (en) | Video signal shuffling apparatus and method | |
JP2002185335A (en) | Data processing method using error correction code and device using the same | |
JPH09246996A (en) | Error correction device | |
JPH0729314A (en) | Digital magnetic recording device and digital magnetic reproducing device |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PUAI | Public reference made under article 153(3) epc to a published international application that has entered the european phase |
Free format text: ORIGINAL CODE: 0009012 |
|
AK | Designated contracting states |
Kind code of ref document: A1 Designated state(s): AT DE FR GB |
|
17P | Request for examination filed |
Effective date: 19930210 |
|
17Q | First examination report despatched |
Effective date: 19950807 |
|
GRAG | Despatch of communication of intention to grant |
Free format text: ORIGINAL CODE: EPIDOS AGRA |
|
GRAH | Despatch of communication of intention to grant a patent |
Free format text: ORIGINAL CODE: EPIDOS IGRA |
|
GRAH | Despatch of communication of intention to grant a patent |
Free format text: ORIGINAL CODE: EPIDOS IGRA |
|
GRAA | (expected) grant |
Free format text: ORIGINAL CODE: 0009210 |
|
AK | Designated contracting states |
Kind code of ref document: B1 Designated state(s): AT DE FR GB |
|
REF | Corresponds to: |
Ref document number: 151191 Country of ref document: AT Date of ref document: 19970415 Kind code of ref document: T |
|
REF | Corresponds to: |
Ref document number: 69218648 Country of ref document: DE Date of ref document: 19970507 |
|
ET | Fr: translation filed | ||
PLBE | No opposition filed within time limit |
Free format text: ORIGINAL CODE: 0009261 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT |
|
26N | No opposition filed | ||
REG | Reference to a national code |
Ref country code: FR Ref legal event code: CD |
|
REG | Reference to a national code |
Ref country code: GB Ref legal event code: IF02 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: DE Payment date: 20050315 Year of fee payment: 14 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: AT Payment date: 20060127 Year of fee payment: 15 Ref country code: GB Payment date: 20060127 Year of fee payment: 15 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: FR Payment date: 20060130 Year of fee payment: 15 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: DE Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20060801 |
|
GBPC | Gb: european patent ceased through non-payment of renewal fee |
Effective date: 20070131 |
|
REG | Reference to a national code |
Ref country code: FR Ref legal event code: ST Effective date: 20070930 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: AT Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20070131 Ref country code: GB Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20070131 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: FR Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20070131 |