FR2906926A1 - Dispositif et procede iteratif de code de correction des erreurs (ecc), avec relecture et information d'erreur-effacement combines - Google Patents
Dispositif et procede iteratif de code de correction des erreurs (ecc), avec relecture et information d'erreur-effacement combines Download PDFInfo
- Publication number
- FR2906926A1 FR2906926A1 FR0707040A FR0707040A FR2906926A1 FR 2906926 A1 FR2906926 A1 FR 2906926A1 FR 0707040 A FR0707040 A FR 0707040A FR 0707040 A FR0707040 A FR 0707040A FR 2906926 A1 FR2906926 A1 FR 2906926A1
- Authority
- FR
- France
- Prior art keywords
- error
- data
- map
- errors
- memory structure
- 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.)
- Granted
Links
- 238000000034 method Methods 0.000 title claims abstract description 73
- 238000012937 correction Methods 0.000 title claims abstract description 65
- 238000013500 data storage Methods 0.000 claims description 16
- 230000000977 initiatory effect Effects 0.000 claims description 3
- 238000012545 processing Methods 0.000 claims description 2
- 238000011084 recovery Methods 0.000 abstract description 17
- 230000008569 process Effects 0.000 description 39
- 230000004044 response Effects 0.000 description 4
- 230000007547 defect Effects 0.000 description 3
- 230000002950 deficient Effects 0.000 description 3
- 238000001514 detection method Methods 0.000 description 3
- 238000011835 investigation Methods 0.000 description 3
- 208000011580 syndromic disease Diseases 0.000 description 3
- 230000008859 change Effects 0.000 description 2
- 238000004891 communication Methods 0.000 description 2
- 125000004122 cyclic group Chemical group 0.000 description 2
- 238000010586 diagram Methods 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 101000606504 Drosophila melanogaster Tyrosine-protein kinase-like otk Proteins 0.000 description 1
- 235000014676 Phragmites communis Nutrition 0.000 description 1
- 238000007796 conventional method Methods 0.000 description 1
- 238000012217 deletion Methods 0.000 description 1
- 230000037430 deletion Effects 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 230000010287 polarization Effects 0.000 description 1
- 230000001915 proofreading effect Effects 0.000 description 1
- 230000009467 reduction Effects 0.000 description 1
- 238000012360 testing method Methods 0.000 description 1
Classifications
-
- 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
-
- 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/1803—Error detection or correction; Testing, e.g. of drop-outs by redundancy in data representation
-
- 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/1879—Direct read-after-write methods
-
- 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/12—Formatting, e.g. arrangement of data block or words on the record carriers
- G11B20/1217—Formatting, e.g. arrangement of data block or words on the record carriers on discs
- G11B2020/1218—Formatting, e.g. arrangement of data block or words on the record carriers on discs wherein the formatting concerns a specific area of the disc
- G11B2020/1222—ECC block, i.e. a block of error correction encoded symbols which includes all parity data needed for decoding
-
- 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/1816—Testing
- G11B2020/1826—Testing wherein a defect list or error map is generated
-
- 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/1816—Testing
- G11B2020/183—Testing wherein at least one additional attempt is made to read or write the data when a first attempt is unsuccessful
-
- 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
- G11B2020/1843—Error detection or correction; Testing, e.g. of drop-outs by adding special lists or symbols to the coded information using a cyclic redundancy check [CRC]
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11B—INFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
- G11B2220/00—Record carriers by type
- G11B2220/90—Tape-like record carriers
Landscapes
- Engineering & Computer Science (AREA)
- Signal Processing (AREA)
- Detection And Correction Of Errors (AREA)
- Error Detection And Correction (AREA)
- Techniques For Improving Reliability Of Storages (AREA)
Abstract
Dans un procédé et un dispositif de correction itérative des erreurs destinés à corriger des erreurs dans des données numériques lues à partir d'un support de stockage, des relectures sont combinées avec la procédure de correction des erreurs en une procédure de reprise sur erreur unique. Les données lues à partir du support de stockage sont représentées sous la forme d'une structure de données multidimensionnelle, et la procédure de reprise sur erreur est exécutée pour chaque dimension de la structure de données. Dans chaque dimension, une carte d'effacement est générée qui contient des erreurs dans la lecture initiale des données pour cette dimension, et les erreurs dans la carte d'effacement sont déduites lorsqu'elles sont corrigées dans des relectures subséquentes. Après un nombre prédéterminé de relectures, ou lorsque aucune autre erreur n'est rencontrée, la procédure de reprise sur erreur est achevée.
Description
1 La présente invention concerne un procédé et un dispositif pour la
reprise d'une erreur de relance améliorée pour des disques de stockage à bande magnétique. Le procédé et le dispositif sont basés sur un motif de symboles à n dimensions (en règle générale des octets) qui sont codés par un code de correction des erreurs (ECC) avec un code de correction des symboles (en règle générale un code Reed-Solomon (RS)) dans chaque dimension (schéma de code de produit). Description de l'art antérieur Lorsqu'un système de stockage tel qu'un système de stockage à bande magnétique, lit des données à partir d'un support de stockage, tel qu'une mémoire à bande magnétique, des données erronées sont reçues occasionnellement en raison de défauts dans le support, de débris de bande magnétique, etc. Lorsque des données erronées sont détectées par un système de détection des erreurs, une tentative est faite en vue de corriger les données, ou de tester les données afin de déterminer si les données peuvent être corrigées. Lorsque le processus de correction n'est pas réussi, la bande magnétique doit être ré-enroulée, et des données doivent être lues à nouveau. Ceci est désigné par "relecture". Après que la relecture est exécutée, le processus de détection des erreurs et de correction des erreurs est répété. Le processus de relecture et le processus de code de correction des erreurs (ECC) sont exécutés un nombre de fois prédéterminé. Si l'erreur ne peut pas être corrigée après le nombre de tentatives prédéterminé, les données ne peuvent pas être reprises et l'erreur est désignée par "erreur fatale". Les processus de relecture et de code de correction des erreurs (ECC) ont été exécutés conventionnellement en tant que deux processus séparés pour des systèmes de stockage à bande magnétique. B0922FR 2906926 2 Le brevet US n 6 920 005, cependant, décrit la combinaison du processus de relecture, pour un dispositif de stockage, avec le processus de correction des erreurs. Dans la procédure décrite dans le brevet 5 US n 6 920 005, les performances d'une opération de reprise sur erreur en cours sont comparées aux performances d'une opération de reprise sur erreur précédente. Ceci est accompli en appliquant des paramètres au processus de reprise, et en comparant les 10 performances telles que par exemple, des statistiques de canal, de l'opération de reprise avec celles d'une opération de reprise précédente, et ensuite en ajoutant des paramètres. RÉSUMÉ DE L'INVENTION 15 Un objet de la présente invention est d'améliorer des processus combinés de relecture et de code de correction des erreurs (ECC) en introduisant plus d'une dimension pour un ensemble de données dans le processus de code de correction des erreurs (ECC). L'utilisation 20 de plus d'une dimension pour un ensemble de données dans le processus de code de correction des erreurs (ECC) offre la possibilité de procédures de décodage d'erreurs plus sophistiquées, comme, par exemple, le décodage par code de correction des erreurs (ECC) 25 itératif, dans lequel le décodage est exécuté dans chaque dimension itérativement jusqu'à ce qu'aucune nouvelle erreur ne puisse être reprise, ou jusqu'à ce qu'un autre critère d'arrêt soit satisfait ou atteint. L'introduction d'un agencement de code à n dimensions, 30 n étant un nombre entier supérieur à un, fournit également la possibilité de fusionner le processus de relecture et le processus de code de correction des erreurs (ECC) en un processus unique d'une façon plus B0922FR 2906926 3 sophistiquée avec une meilleure probabilité de reprise de données. Au lieu de comparer les performances d'une opération de reprise sur erreur en cours avec une 5 opération de reprise sur erreur précédente, le système et le procédé selon l'invention comparent le résultat du processus de correction, à savoir une carte des erreurs. Une carte des erreurs est une carte comportant des symboles erronés dans l'ensemble de données. Le 10 résultat pour le processus de correction en cours, à savoir la carte des erreurs, peut être différent du résultat d'un processus de correction précédent en raison d'erreurs distribuées de façon aléatoire ou de variations en termes de débris pour chaque relecture.
15 Les performances du processus lui-même ne sont pas mesurées, et les paramètres dans le processus ne sont ni modifiés ni ajoutés. Conformément au procédé et au dispositif de l'invention, des positions d'erreurs de symboles qu'il 20 est possible de corriger sont contrôlées lors de chaque passage de relecture. Dans chaque passage de relecture, le nombre d'erreurs de symboles et de positions d'erreurs de symboles peut changer selon le niveau du rapport signal / bruit (SNR) dans le canal, et la 25 quantité de débris sur la bande magnétique. Les paramètres dans les canaux, tels que les valeurs hors- piste, les valeurs de polarisation de résistance magnétique (MR), les paramètres de contrôle automatique de gain (AGC), etc., ne sont pas ajustés à chaque 30 passage de relecture. A l'inverse, le procédé et le dispositif de l'invention sont basés sur des variations naturelles dans les positions d'erreurs pour les B0922FR 2906926 4 symboles protégés par le code de correction des erreurs (ECC). La carte des erreurs susmentionnée avec des positions d'erreurs variables est construite, et le processus de correction itératif est exécuté. Dans le 5 procédé et le dispositif de l'invention, des paramètres ne sont ni appliqués ni ajoutés dans le processus de reprise. Au contraire, après chaque comparaison, la carte des erreurs est mise à jour en déduisant des erreurs de symboles de la carte des erreurs, et en 10 remplaçant les symboles de données erronés correspondants par des symboles de données corrects. DESCRIPTION DES DESSINS Les figures 1A, 1B, 1C, 1D, 2A et 2B illustrent des exemples de cartes des erreurs en vue d'expliquer le procédé selon la présente invention.
15 La figure 3 illustre un sous-ensemble de données C2 avec des mots codes C2 et Cl. Les figures 4A et 4B illustrent un sous-ensemble de données C3 avec le mot code C3. La figure 5 est un organigramme pour un mode de 20 réalisation du processus principal dans l'algorithme itératif selon la présente invention. La figure 6 est un organigramme d'un mode de réalisation du sous-processus de décodage d'erreurs dans l'algorithme itératif de l'invention.
25 La figure 7 est un organigramme d'un mode de réalisation du sous-processus de décodage à effacement dans l'algorithme itératif de l'invention. La figure 8 est un schéma de principe d'un dispositif selon l'invention, fonctionnant selon 30 l'algorithme itératif de l'invention. B0922FR 2906926 5 DESCRIPTION DES MODES DE RÉALISATION PRÉFÉRÉS Les erreurs reçues lors de la lecture de données à partir d'un support de stockage comprennent en règle générale deux types d'erreurs distincts, à savoir, des erreurs aléatoires associées au rapport signal / bruit 5 (SNR) dans le canal et aux débris de bande magnétique, et les erreurs de défaut sur le support. Le défaut sur le support est constant pour un ensemble de données déterminé, mais les erreurs aléatoires changent à chaque fois que l'ensemble de données est lu.
10 Étant donné que la largeur de piste et la longueur de bit diminuent, et qu'un nombre supérieur de canaux est introduit dans les produits de stockage à bande magnétique, la quantité d'erreurs liées au rapport SNR augmentera, par comparaison avec le nombre d'erreurs 15 occasionné par des défauts sur le support. Les erreurs liées au rapport SNR sont distribuées aléatoirement. Ceci signifie que le même ensemble de données est lu deux fois, la quantité d'erreurs occasionnées par le rapport SNR sera approximativement la même, mais on 20 peut s'attendre à ce qu'il y ait une variation des positions d'erreur. Les erreurs occasionnées par des défauts sur le support auront les mêmes positions d'erreurs d'une lecture à l'autre. La probabilité de relecture réussie d'un ensemble de données impossible à 25 corriger et d'obtention d'un meilleur échantillon de l'ensemble de données qui peut être corrigé, sera plus faible à mesure que le pourcentage des erreurs connexes au rapport SNR distribuées aléatoirement augmente dans le système.
30 Pour compenser ce problème et améliorer le succès de la reprise de données, les relectures peuvent être combinées avec le processus de code de correction des erreurs (ECC) en un processus de reprise sur erreur unique. En outre, en utilisant un code de produit itératif, tel qu'un code Reed-Solomon à n dimensions, B0922FR 2906926 6 pour la correction des erreurs en combinaison avec le processus de relecture, des capacités de correction améliorées peuvent être obtenues, par comparaison avec les procédés conventionnels utilisant un processus de 5 relecture et un processus de correction des erreurs séparés. Bien que des codes de Reed-Solomon (RS) soient utilisés comme exemple, l'amélioration réalisée par le procédé décrit ci-dessus peut être obtenue en utilisant d'autres codes produit de correction des symboles en 10 dehors des codes RS à n dimensions, comme, par exemple, des codes LPDC. Conformément à l'invention, un code à n dimensions, tel qu'un code de Reed-Solomon, est combiné à un algorithme de décodage itératif approprié à une 15 "recherche croisée" et à la correction des symboles erronés dans les n dimensions. Le procédé et le dis-positif selon l'invention sont basés sur le concept de réduction de symboles dans une carte d'effacement, ce qui signifie qu'une carte d'effacement conventionnelle 20 est générée initialement, et des symboles (OK) non erronés sont déduits de la carte lorsque les symboles sont corrigés par le système de code de correction des erreurs (ECC). Le procédé selon l'invention pour la correction 25 d'erreurs dans un ensemble de données lu à partir d'un support de stockage, comporte les étapes consistant à : (a) lire un ensemble de données qui contient des erreurs à partir d'un support de stockage ; (b) stocker l'ensemble de données dans une mémoire en 30 tant que première structure de mémoire multidimensionnelle ; (c) appliquer un algorithme de correction d'erreurs et de décodage itératif à ladite première structure de mémoire dans toutes les dimensions jusqu'à ce 35 qu'au moins un premier critère d'arrêt prédéterminé soit satisfait ; B0922FR 2906926 7 (d) construire une première carte des erreurs de toutes les erreurs restantes dans ladite première structure de mémoire ; (e) exécuter une relecture dudit ensemble de données à 5 partir dudit support et construire une seconde carte des erreurs représentant lesdites erreurs dans ledit ensemble de données, et stocker l'ensemble de données relu en tant que seconde structure de mémoire multidimensionnelle, avec 10 ladite seconde carte des erreurs ; (f) appliquer ledit algorithme de correction et de décodage itératif au niveau de ladite seconde structure de mémoire dans toutes les dimensions jusqu'à ce qu'au moins un second critère 15 prédéterminé soit satisfait ; (g) construire une nouvelle seconde carte des erreurs représentant les erreurs restantes dans ladite seconde structure de mémoire ; (h) comparer ladite nouvelle seconde carte des erreurs 20 et ladite première carte des erreurs en vue d'identifier les données transmissibles qui sont correctes dans ladite nouvelle seconde carte des erreurs, mais qui sont erronées dans ladite première carte des erreurs ; 25 (i) transférer, dans ladite première carte des erreurs, lesdites données transmissibles et mettre à jour la première carte des erreurs en vue d'obtenir une première carte des erreurs mise à jour, et mettre à jour ladite première structure 30 de données en en supprimant des erreurs indiquées par ladite première carte des erreurs mise à jour, en vue d'obtenir une première structure de données mise à jour ; (j) appliquer ledit algorithme de correction et de 35 décodage itératif dans toutes les dimensions au B0922FR 2906926 8 niveau de ladite première structure de données mise à jour ; et (k) répéter les étapes (e) à (j) jusqu'à ce qu'un troisième critère d'arrêt prédéterminé soit 5 satisfait. Le procédé peut être mis en œuvre avec un système de stockage de données avec correction des erreurs, qui interagit avec un support de stockage de données, comportant : une tête de lecture adaptée pour interagir 10 avec ledit support de stockage de données ; une unité de commande connectée à ladite tête de lecture qui actionne ladite tête de lecture en vue de lire des données à partir dudit support de stockage de données ; et une unité de correction des erreurs connectée à 15 ladite unité de commande qui est utilisée sur lesdites données lues par ladite tête de lecture en vue de corriger des erreurs de celle-ci. Une vue d'ensemble du procédé de l'invention est donnée ci-après.
20 Un ensemble de données impossibles à corriger est lu à partir d'un support de stockage. Facultativement, une carte des erreurs initiale est construite à partir d'un contrôle par redondance cyclique (CRC) ou d'un contrôle de syndrome rapide. L'ensemble de données et 25 la carte des erreurs initiale correspondante sont stockés dans une structure de mémoire S1. Un exemple d'une telle carte des erreurs initiale dans cette structure de mémoire S1 est montré sur la figure 1 A. L'algorithme de décodage et de correction itératif 30 est exécuté sur S1 dans toutes les dimensions, indiquées ci-dessous en tant que dimensions Cl, C2 et C3, jusqu'à ce qu'un critère d'arrêt prédéterminé soit satisfait. Une carte des erreurs des erreurs restantes dans la structure de mémoire S1 est construite. Un 35 exemple d'une telle carte des erreurs est montré sur la figure 1B. L'ensemble de données est relu à partir du B0922FR 2906926 9 support et stocké en tant que seconde structure de mémoire S2. Une carte des erreurs initiale dans la structure de mémoire S2 après la relecture est montrée sur la figure 1C. L'algorithme de décodage itératif est 5 exécuté sur la structure de mémoire S2, et une carte des erreurs des erreurs restantes dans la structure de mémoire S2 est construite. Une telle carte des erreurs dans la structure de mémoire S2 est montrée sur la figure 1D. Les cartes des erreurs dans les structures 10 de mémoire S1 et S2 sont comparées. Des données OK de S2 qui sont indiquées comme erronées dans la structure de mémoire S1, sont transférées de S2 à Si, et la carte des erreurs S1 est mise à jour en déduisant les erreurs corrigées de cette manière. Une telle carte des erreurs 15 mise à jour est montrée sur la figure 2A. L'algorithme de décodage itératif est de nouveau exécuté sur S1. S'il existe de nouvelles corrections réussies, la carte des erreurs S1 est de nouveau mise à jour. Une telle carte des erreurs mise à jour est 20 montrée sur la figure 2B. Le procédé retourne ensuite à une autre relecture et le processus est à nouveau répété un nombre de fois prédéterminé, ou bien le processus est arrêté si aucune erreur n'est rencontrée dans la structure de mémoire 25 S1. Le procédé de l'invention est expliqué en tant qu'un algorithme itératif à trois dimensions Cl, C2 et C3. L'algorithme peut cependant être étendu à plus de trois dimensions. L'ensemble de données tridimensionnel 30 utilisé dans l'exemple est formé pour des mots codes de code de correction des erreurs (ECC) dans chaque dimension, et forme ainsi un cube tridimensionnel avec des données codées. Ce cube est désigné ci-après sous le nom d'ensemble de données.
35 Un mot code est défini comme la plus petite quantité de données qui peut être codée ou décodée par B0922FR 2906926 10 le code de correction des erreurs (ECC) qui est destiné à être utilisé. Un mot code est composé de symboles de parité et de données. Un mot code Cl est formé par des symboles dans la 5 dimension des abscisses (x) dans le cube. Un mot code C2 est formé par des symboles dans la dimension des ordonnées (y) dans le cube, et un mot code C3 est formé par des symboles dans la dimension de cote (z) dans le cube.
10 Une tranche à travers le cube est montrée sur la figure 3, représentant un sous-ensemble de données C2. Le sous-ensemble de données C2 est défini comme un ensemble de données formé par des mots codes C2 et Cl et représente une zone carrée dans le plan x - y. Le 15 nombre d'ensembles de données C2 est égal au nombre de symboles dans un mot code C3. Un sous-ensemble de données C3 est défini en tant qu'un ensemble de données formé par des mots codes C3 et C2, et équivaut à une carré dans le plan y - z. Le 20 nombre de sous-ensembles de données C3 est égal au nombre de symboles dans un mot code Cl, tel qu'illustré sur les figures 4A et 4B. Un contrôle de syndrome (ou contrôle CRC supplé- mentaire) dans la dimension Cl pour les mots codes Cl 25 est utilisé en tant qu'information d'effacement pour la dimension C2. L'information est utilisée pour cons-truire la carte d'effacement initiale. Tel qu'utilisé ci-dessus, le terme effacement indique des erreurs de symboles dans un mot code, les 30 positions des symboles défectueux étant connues. Les positions défectueuses sont utilisées en tant que positions d'erreurs à partir de mots codes dans une autre dimension dans le cube. Le terme erreur de symboles tel qu'utilisé ci-dessus indique une erreur 35 dans un mot code qui exige de l'algorithme de décodage qu'il décode les positions défectueuses dans le mot B0922FR 2906926 11 code en utilisant l'information de symboles dans le mot code lui-même. L'algorithme commence par une carte d'effacement initiale. Les mots codes dans les différentes dimen- 5 sions sont alors décodés avec une détection et une correction d'erreur, et une carte des erreurs est produite en supprimant des positions d'erreurs de symboles de la carte d'effacement. La nouvelle carte des erreurs est utilisée en tant qu'entrée dans un 10 algorithme de décodage à effacement, et un processus de correction, dans les différentes dimensions. L'algorithme utilise une carte pour l'information d'effacement et d'erreur. C'est l'utilisation de la carte dans le procédé de décodage et le décodage 15 d'erreurs ou à effacement qui permet d'effectuer une détermination si l'information omise dans la carte est une information d'effacement ou une information d'erreur. La figure 5 montre des détails supplémentaires de 20 l'algorithme itératif principal. Après avoir lancé l'algorithme, une carte d'effacement est construite dans toutes les dimensions sur la base d'un contrôle par redondance cyclique (CRC) ou d'un contrôle de syndrome à partir des canaux lus. Dans l'étape suivante, 25 un décodage d'erreurs est exécuté et le processus de correction est mis en oeuvre pour tous les sous-ensembles de données C2. La carte d'effacement est mise à jour en déduisant des erreurs de la carte. Des détails du procédé de déduction sont montrés sur la figure 6.
30 Ensuite, le décodage et la correction d'erreurs sont exécutés pour tous les sous-ensembles de données C3, et la carte d'effacement est mise à jour en déduisant des erreurs de la carte. La correction et le décodage à effacement sont 35 exécutés pour tous les mots codes dans toutes les B0922FR 2906926 12 directions restantes, et la carte d'effacement est mise à jour. S'il existe des erreurs de symboles corrigées par le processus de décodage à effacement et d'erreur 5 susmentionné, un contrôle est exécuté en vue de rechercher si d'éventuelles erreurs de symboles sont encore présentes dans la carte d'effacement. Si la réponse à cette enquête est oui , alors l'algorithme retourne à la correction et au décodage d'erreurs pour 10 tous les sous-ensembles de données C2, et l'algorithme est réitéré. Facultativement, avant d'initier le processus de correction et de décodage d'erreurs pour tous les sous-ensembles de données C2 dans cette itération suivante, 15 la correction et le décodage d'erreurs peuvent être exécutés pour tous les mots codes Cl, et la carte d'effacement peut être mise à jour en déduisant des erreurs de cela. S'il n'y a aucune erreur de symboles présente dans 20 la carte d'effacement, l'algorithme itératif est arrêté, et le processus de reprise principal est poursuivi. Ce résultat est également le même lorsque la réponse à l'enquête précédente concernant des erreurs de symboles corrigées par les processus de décodage 25 d'erreurs ou à effacement est non . Un organigramme relatif au processus de décodage d'erreurs est montré sur la figure 6, qui s'applique à toutes les dimensions et est par conséquent décrit de manière générique pour des sous-ensembles de données 30 Cx. Un sous-ensemble de données Cx à traiter est sélectionné, et le mot code suivant dans le sous- ensemble de données choisi est sélectionné, et le nombre d'erreurs dans ce mot code est calculé. Une 35 enquête est exécutée en vue de savoir s'il y a des erreurs quelconques dans ce mot code. Si la réponse est B0922FR 2906926 13 oui , une autre enquête est exécutée en vue de savoir si le mot code peut être corrigé, si la réponse est non , alors une enquête est exécutée en vue de savoir s'il y a davantage de mots codes dans le sous- 5 ensemble de données à traiter. Si la réponse à l'enquête consistant à savoir s'il y a des erreurs dans le mot code est non , alors les erreurs de symboles sont déduites de la carte d'effacement lesquelles sont indiquées à ce moment en 10 tant que symboles erronés, et l'algorithme passe également à l'enquête susmentionnée consistant à savoir s'il reste des mots codes à traiter dans le sous-ensemble de données. Si la réponse à cette enquête est oui , l'algorithme retourne par une boucle au mot 15 code sélectionné suivant, et le procédé susmentionné est répété. Si la réponse à cette enquête est non , alors une enquête est exécutée en vue de savoir s'il reste des ensembles de données Cx à traiter. Si la réponse est oui l'algorithme retourne par une 20 boucle en vue d'exécuter une sélection du sous-ensemble de données suivant Cx à traiter. Si la réponse à cette enquête est non , alors le décodage d'erreurs est terminé pour tous les sous-ensembles de données Cx, et le processus principal est poursuivi.
25 Comme noté ci-dessus, dans l'itération susmentionnée, il y a une enquête consistant à savoir si le mot code peut être corrigé. Si la réponse à cette enquête est "oui", alors l'algorithme passe au calcul des positions d'erreurs de symboles et à la vérification con- 30 sistant à déterminer si les positions d'erreurs calculées sont des positions valides dans la carte d'effacement. Si les positions d'erreurs ne sont pas valides, une erreur de décodage a été occasionnée, et cette étape de décodage est ignorée, aucune correction n'est 35 exécutée et aucune déduction d'erreur de la carte d'effacement ne se produit. L'algorithme passe alors à B0922FR 2906926 14 l'enquête susmentionnée consistant à déterminer s'il reste des mots codes dans le sous-ensemble de données à traiter. Si la position d'erreur est valide, les erreurs 5 dans le mot code sont corrigées, et la carte d'effacement est mise à jour en déduisant les erreurs corrigées de la carte. L'algorithme passe ensuite une nouvelle fois à l'enquête consistant à déterminer s'il reste des mots codes dans le sous-ensemble de données à 10 traiter. L'algorithme de décodage à effacement est illustré dans un organigramme sur la figure 7. L'algorithme de décodage à effacement est initié par les mots codes dans la dimension Cl, et un mot code dans cette dimen- 15 sion est sélectionné pour le traitement. L'information d'erreur pour le mot code choisi est trouvée à partir de la carte d'effacement déduite, et cette information est utilisée en tant qu'information d'effacement étant donné que les positions erronées dans le mot code sont 20 connues. Une enquête est alors exécutée en vue de déterminer si le mot code peut être corrigé. Si le mot code peut être corrigé, les effacements dans le mot code sont corrigés, et la carte d'effacement est mise à 25 jour en déduisant les effacements corrigés de la carte d'effacement. L'algorithme enquête alors en vue de déterminer s'il reste des mots codes dans la dimension à traiter. Si le mot code ne peut pas être corrigé, 30 l'algorithme passe une nouvelle fois à cette même enquête consistant à savoir s'il reste des mots codes à traiter. Si la réponse est "oui", l'algorithme retourne par une boucle au mot code sélectionné suivant dans la dimension choisie et le processus susmentionné est 35 réitéré à nouveau. B0922FR 2906926 15 S'il n'y a plus de mots codes dans la dimension à traiter, une enquête est exécutée en vue de savoir s'il reste des dimensions à traiter. Le cas échéant, la dimension suivante à traiter est sélectionnée, et 5 l'algorithme revient pour sélectionner le premier mot code dans la dimension sélectionnée à traiter, et l'itération susmentionnée est de nouveau exécutée. S'il n'y a plus de dimensions à traiter, une enquête est exécutée en vue de déterminer si une 10 quelconque correction d'effacement subséquente a été occasionnée dans l'itération qui vient d'être exécutée. Si la réponse est non , le processus de décodage à effacement est arrêté, et le processus principal continue.
15 Si une correction d'effacement réussie dans l'itération se produit, alors une nouvelle itération est commencée. Si la carte d'effacement est vide, cette itération sera la dernière itération. L'algorithme de décodage de code de correction des erreurs (ECC) 20 fonctionne en mode de contrôle, plutôt qu'en mode de correction à effacement. La nouvelle itération commence avec les mots codes dans la dimension Cl au début de l'algorithme montré sur la figure 7. Un schéma de principe de base d'un dispositif pour 25 la mise en oeuvre de la procédure susmentionnée est montré sur la figure 8. Le dispositif comprend une tête de lecture - écriture 1 qui interagit avec un support de stockage de données 2 d'une façon connue pour écrire des données numériques sur, et pour lire des données 30 numériques à partir du, support de stockage de données 2. À cette fin, la tête de lecture - écriture 1 est en communication avec une unité de commande 3 par l'intermédiaire d'un amplificateur de lecture qui est opérationnel en mode écriture, et d'un amplificateur de 35 lecture 5 qui est opérationnel en mode lecture. L'unité de commande 3 est en communication avec une unité de B0922FR 2906926 16 code de correction des erreurs (ECC) 6, dans laquelle le procédé décrit ci-dessus est exécuté. Bien que des modifications et des changements puissent être suggérés par l'homme du métier, l'inten- 5 tion de l'inventeur est d'intégrer dans le brevet accordé pour la présente invention tous les changements et toutes les modifications qui sont, de façon claire et raisonnée, dans la portée de sa contribution à la technique. B0922FR
Claims (14)
1. Procédé pour la correction d'erreurs dans un ensemble de données lu à partir d'un support de stockage, comportant les étapes consistant à : (a) lire un ensemble de données qui contient des erreurs à partir d'un support de stockage ; (b) stocker l'ensemble de données dans une mémoire en tant que première structure de mémoire multidimensionnelle ; (c) appliquer un algorithme de correction d'erreurs et de décodage itératif à ladite première structure de mémoire dans toutes les dimensions jusqu'à ce qu'au moins un premier critère d'arrêt prédéterminé soit satisfait ; (d) construire une première carte des erreurs de toutes les erreurs restantes dans ladite première structure de mémoire ; (e) exécuter une relecture dudit ensemble de données à partir dudit support et construire une seconde carte des erreurs représentant lesdites erreurs dans ledit ensemble de données, et stocker l'ensemble de données relu en tant que seconde structure de mémoire multidimensionnelle, avec ladite seconde carte des erreurs ; (f) appliquer ledit algorithme de correction et de décodage itératif au niveau de ladite seconde structure de mémoire dans toutes les dimensions jusqu'à ce qu'au moins un second critère prédéterminé soit satisfait ; (g) construire une nouvelle seconde carte des erreurs représentant les erreurs restantes dans ladite seconde structure de mémoire ; (h) comparer ladite nouvelle seconde carte des erreurs et ladite première carte des erreurs en vue d'identifier les données transmissibles qui sont correctes dans ladite nouvelle seconde carte des B0922FR 2906926 18 erreurs, mais qui sont erronées dans ladite première carte des erreurs ; (i) transférer, dans ladite première carte des erreurs, lesdites données transmissibles et mettre 5 à jour la première carte des erreurs en vue d'obtenir une première carte des erreurs mise à jour, et mettre à jour ladite première structure de données en en supprimant des erreurs indiquées par ladite première carte des erreurs mise à jour, 10 en vue d'obtenir une première structure de données mise à jour ; (j) appliquer ledit algorithme de correction et de décodage itératif dans toutes les dimensions au niveau de ladite première structure de données 15 mise à jour ; et (k) répéter les étapes (e) à (j) jusqu'à ce qu'un troisième critère d'arrêt prédéterminé soit satisfait.
2. Procédé selon la revendication 1 comprenant 20 le stockage dudit ensemble de données à l'étape (b) en tant que première structure de mémoire tridimensionnelle, et le stockage de l'ensemble de données relu à l'étape (e) en tant que seconde structure de mémoire tridimensionnelle. 25
3. Procédé selon la revendication 1 comportant l'utilisation dudit au moins un critère d'arrêt, comme premier critère d'arrêt à l'étape (c) et comme second critère d'arrêt à l'étape (f).
4. Procédé selon la revendication 1 comprenant 30 l'utilisation d'un nombre prédéterminé de répétitions en tant que troisième critère d'arrêt à l'étape (k).
5. Procédé selon la revendication 1 comprenant l'utilisation d'un critère d'arrêt "aucune erreur restante laissée dans ladite première structure de 35 mémoire mise à jour" en tant que troisième critère d'arrêt à l'étape (k). B0922FR 2906926 19
6. Procédé selon la revendication 1 comprenant, après l'étape (a), l'étape consistant à générer une carte des erreurs initiale représentant lesdites erreurs dans la lecture de l'ensemble de données à 5 l'étape (a) et l'étape consistant à stocker ladite carte des erreurs initiale à l'étape (b), avec ladite première structure de mémoire, et générer ladite première carte des erreurs à l'étape (d) en éliminant les erreurs dans ladite carte des erreurs initiale qui 10 sont identifiées à l'étape (c).
7. Procédé selon la revendication 6 dans lequel chacune des première et seconde structures de mémoire comprend trois dimensions Cl, C2 et C3 comprenant chacune une pluralité de sous-ensembles de données, et 15 comportant l'application d'un algorithme de décodage et de correction itératif à chacune des étapes (c), (f) et (j) comprenant les étapes consistant à : (1) générer une carte d'effacement dans trois dimensions correspondant à Cl, C2, et C3 ; 20 initier ladite carte des erreurs en utilisant ladite carte d'effacement comme point de départ ; (2) pour tous les sous-ensembles de données C2, traiter chaque sous-ensemble de données d'un premier à un dernier nombre de mots codes qui s'y 25 trouvent et, pour chaque mot code, déterminer si ce mot code peut être corrigé et, le cas échéant, calculer des positions d'erreurs et contrôler lesdites positions d'erreurs en vue de déterminer la correspondance à ladite carte d'effacement et, 30 en cas de défaut de correspondance, indiquer l'occurrence d'une erreur de décodage et, en cas de correspondance avérée, supprimer les symboles non erronés de ladite carte d'effacement et, si ce mot code ne peut pas être corrigé, continuer 35 avec un mot code suivant dans les sous-ensembles de données C2 ; B0922FR 2906926 20 (3) pour tous les sous-ensembles de données C3, traiter chaque sous-ensemble de données d'un premier à un dernier nombre de mots codes qui s'y trou-vent et, pour chaque mot code, déterminer si ce 5 mot code peut être corrigé et, si oui, calculer des positions d'erreur qui s'y trouvent et contrôler lesdites positions d'erreurs en vue de déterminer la correspondance à ladite carte d'effacement et, en cas de défaut de corres- 10 pondance, indiquer l'occurrence d'une erreur de décodage et, en cas de correspondance, supprimer les symboles non erronés de ladite carte d'effacement et, si ce mot code ne peut pas être corrigé, continuer avec un mot code suivant dans 15 les sous-ensembles de données C3 ; (4) pour chaque mot code dans chacune desdites dimensions Cl, C2 et C3, récupérer des positions d'erreurs respectives pour ce mot code à partir de l'étape (2) et déterminer si ce mot code peut 20 être corrigé avec l'information d'effacement dans ladite carte d'effacement et, si oui, corriger ce mot code et, si non, continuer à un mot code suivant ; et répéter les étapes (1) à (4) tant que des mots 25 codes continuent à être corrigés.
8. Système de stockage de données avec correction des erreurs, qui interagit avec un support de stockage de données, comportant une tête de lecture adaptée pour interagir avec ledit support de 30 stockage de données ; une unité de commande connectée à ladite tête de lecture qui actionne ladite tête de lecture en vue de lire des données à partir dudit support de stockage de données ; et une unité de correction des erreurs connectée à ladite unité de 35 commande qui est utilisée sur lesdites données lues par B0922FR 2906926 21 ladite tête de lecture en vue de corriger des erreurs de celle-ci ; et comportant les étapes consistant à : (a) lire un ensemble de données qui contient des erreurs à partir d'un support de stockage ; 5 (b) stocker l'ensemble de données dans une mémoire en tant que première structure de mémoire multidimensionnelle ; (c) appliquer un algorithme de correction d'erreurs et de décodage itératif à ladite première structure 10 de mémoire dans toutes les dimensions jusqu'à ce qu'au moins un premier critère d'arrêt prédéterminé soit satisfait ; (d) construire une première carte des erreurs de toutes les erreurs restantes dans ladite première 15 structure de mémoire ; (e) exécuter une relecture dudit ensemble de données à partir dudit support et construire une seconde carte des erreurs représentant lesdites erreurs dans ledit ensemble de données, et stocker 20 l'ensemble de données relu en tant que seconde structure de mémoire multidimensionnelle, avec ladite seconde carte des erreurs ; (f) appliquer ledit algorithme de correction et de décodage itératif au niveau de ladite seconde 25 structure de mémoire dans toutes les dimensions jusqu'à ce qu'au moins un second critère prédéterminé soit satisfait ; (g) construire une nouvelle seconde carte des erreurs représentant les erreurs restantes dans ladite 30 seconde structure de mémoire ; (h) comparer ladite nouvelle seconde carte des erreurs et ladite première carte des erreurs en vue d'identifier les données transmissibles qui sont correctes dans ladite nouvelle seconde carte des 35 erreurs, mais qui sont erronées dans ladite première carte des erreurs ; B0922FR 2906926 22 (i) transférer, dans ladite première carte des erreurs, lesdites données transmissibles et mettre à jour la première carte des erreurs en vue d'obtenir une première carte des erreurs mise à 5 jour, et mettre à jour ladite première structure de données en en supprimant des erreurs indiquées par ladite première carte des erreurs mise à jour, en vue d'obtenir une première structure de données mise à jour ; 10 (j) appliquer ledit algorithme de correction et de décodage itératif dans toutes les dimensions au niveau de ladite première structure de données mise à jour ; et (k) répéter les étapes (e) à (j) jusqu'à ce qu'un 15 troisième critère d'arrêt prédéterminé soit satisfait.
9. Système de stockage de données selon la revendication 8, dans lequel ladite unité de correction des erreurs stocke ledit ensemble de données à l'étape 20 (b) en tant que première structure de mémoire tridimensionnelle, et stocke l'ensemble de données relu à l'étape (e) en tant que seconde structure de mémoire tridimensionnelle.
10. Système de stockage de données selon la 25 revendication 8, dans lequel ladite unité de correction des erreurs utilise ledit au moins un critère d'arrêt en tant que premier critère d'arrêt à l'étape (c) et en tant que deuxième critère d'arrêt à l'étape (f).
11. Système de stockage de données selon la 30 revendication 8, dans lequel ladite unité de correction des erreurs stocke un nombre prédéterminé de répétitions en tant que troisième critère d'arrêt à l'étape (k).
12. Système de stockage de données selon la 35 revendication 8, dans lequel ladite unité de correction des erreurs utilise un critère d'arrêt "aucune erreur B0922FR 2906926 23 restante laissée dans ladite première structure de mémoire mise à jour" en tant que troisième critère d'arrêt à l'étape (k).
13. Système de stockage de données selon la 5 revendication 8, dans lequel ladite unité de correction des erreurs, après l'étape (a), génère une carte des erreurs initiale représentant lesdites erreurs dans l'ensemble de données lu à l'étape (a) et stocke ladite carte des erreurs initiale à l'étape (b), avec ladite 10 première structure de mémoire, et génère ladite première carte des erreurs à l'étape (d) en supprimant des erreurs dans ladite carte des erreurs initiale qui sont identifiées à l'étape (c).
14. Système de stockage de données selon la 15 revendication 13, dans lequel chacune desdites première et seconde structure de mémoire comporte trois dimensions Cl, C2 et C3 comportant chacune une pluralité de sous-ensembles de données, dans lequel ladite unité de correction des erreurs applique un 20 algorithme de décodage et de correction itératif à chacune des étapes (c), (f) et (j) en effectuant les étapes consistant à (1) générer une carte d'effacement dans trois dimensions correspondant à Cl, C2, et C3 ; (2) initier ladite carte des erreurs en utilisant 25 ladite carte d'effacement comme point de départ ; (3) pour tous les sous-ensembles de données C2, traiter chaque sous-ensemble de données d'un premier à un dernier nombre de mots codes qui s'y trouvent et, pour chaque mot code, en déterminant si ce mot code peut 30 être corrigé et, le cas échéant, calculer des positions d'erreurs et contrôler lesdites positions d'erreurs en vue de déterminer la correspondance à ladite carte d'effacement et, en cas de défaut de correspondance, indiquer l'occurrence d'une erreur de décodage et, en 35 cas de correspondance avérée, supprimer les symboles non erronés de ladite carte d'effacement et, si ce mot B0922FR 2906926 24 code ne peut pas être corrigé, continuer avec un mot code suivant dans les sous-ensembles de données C2 ; pour tous les sous-ensembles de données C3, traiter chaque sous-ensemble de données d'un premier à un 5 dernier nombre de mots codes qui s'y trouvent et, pour chaque mot code, déterminer si ce mot code peut être corrigé et, si oui, calculer des positions d'erreur qui s'y trouvent et contrôler lesdites positions d'erreurs en vue de déterminer la correspondance à ladite carte 10 d'effacement et, en cas de défaut de correspondance, indiquer l'occurrence d'une erreur de décodage et, en cas de correspondance, supprimer les symboles non erronés de ladite carte d'effacement et, si ce mot code ne peut pas être corrigé, continuer avec un mot code 15 suivant dans les sous-ensembles de données C3 ; (4) pour chaque mot code dans chacune desdites dimensions Cl, C2 et C3, récupérer des positions d'erreurs respectives pour ce mot code à partir de l'étape (2) et déterminer si ce mot code peut être 20 corrigé avec l'information d'effacement dans ladite carte d'effacement et, si oui, corriger ce mot code et, si non, continuer à un mot code suivant ; et répéter les étapes (1) à (4) tant que des mots codes continuent à être corrigés. B0922FR
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/545,668 US7840872B2 (en) | 2006-10-10 | 2006-10-10 | N-dimensional iterative ECC method and apparatus with combined erasure—error information and re-read |
Publications (2)
Publication Number | Publication Date |
---|---|
FR2906926A1 true FR2906926A1 (fr) | 2008-04-11 |
FR2906926B1 FR2906926B1 (fr) | 2016-10-21 |
Family
ID=38787875
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
FR0707040A Active FR2906926B1 (fr) | 2006-10-10 | 2007-10-08 | Dispositif et procede iteratif de code de correction des erreurs (ecc), avec relecture et information d'erreur-effacement combines |
Country Status (4)
Country | Link |
---|---|
US (1) | US7840872B2 (fr) |
DE (1) | DE102007046789A1 (fr) |
FR (1) | FR2906926B1 (fr) |
GB (1) | GB2442863B (fr) |
Families Citing this family (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8832518B2 (en) * | 2008-02-21 | 2014-09-09 | Ramot At Tel Aviv University Ltd. | Method and device for multi phase error-correction |
WO2012158171A1 (fr) | 2011-05-19 | 2012-11-22 | Hewlett-Packard Development Company, L.P. | Codage de commande d'erreur |
US8793552B2 (en) | 2012-11-14 | 2014-07-29 | International Business Machines Corporation | Reconstructive error recovery procedure (ERP) for multiple data sets using reserved buffer |
US9053748B2 (en) | 2012-11-14 | 2015-06-09 | International Business Machines Corporation | Reconstructive error recovery procedure (ERP) using reserved buffer |
US8810944B1 (en) | 2013-07-16 | 2014-08-19 | International Business Machines Corporation | Dynamic buffer size switching for burst errors encountered while reading a magnetic tape |
US9166627B2 (en) * | 2013-08-07 | 2015-10-20 | International Business Machines Corporation | Combination error and erasure decoding for product codes |
US9582360B2 (en) | 2014-01-07 | 2017-02-28 | International Business Machines Corporation | Single and multi-cut and paste (C/P) reconstructive error recovery procedure (ERP) using history of error correction |
US9141478B2 (en) | 2014-01-07 | 2015-09-22 | International Business Machines Corporation | Reconstructive error recovery procedure (ERP) using reserved buffer |
CN106201333B (zh) * | 2015-06-01 | 2019-04-12 | 株式会社东芝 | 存储装置、控制器以及数据再读出方法 |
US10318381B2 (en) | 2017-03-29 | 2019-06-11 | Micron Technology, Inc. | Selective error rate information for multidimensional memory |
US11294763B2 (en) * | 2018-08-28 | 2022-04-05 | Hewlett Packard Enterprise Development Lp | Determining significance levels of error values in processes that include multiple layers |
US10984860B2 (en) | 2019-03-26 | 2021-04-20 | Hewlett Packard Enterprise Development Lp | Self-healing dot-product engine |
US11467760B1 (en) * | 2020-12-04 | 2022-10-11 | Amazon Technologies. Inc. | Selective erasure decoding for memory devices |
JP2023137091A (ja) * | 2022-03-17 | 2023-09-29 | キオクシア株式会社 | メモリシステムおよびメモリ制御方法 |
Family Cites Families (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH0447568A (ja) * | 1990-06-15 | 1992-02-17 | Teac Corp | 磁気テープ装置におけるデータ読み取り方法 |
JP2000057510A (ja) | 1998-08-10 | 2000-02-25 | Sony Corp | 再生装置および再生方法 |
EP1069569A3 (fr) | 1999-06-28 | 2005-06-01 | Hewlett-Packard Company, A Delaware Corporation | Recouvrement d'un paquet de données par superposition de mot de code |
KR100546314B1 (ko) | 2003-02-08 | 2006-01-26 | 삼성전자주식회사 | 저장 장치 및 저장 장치에서의 독출 에러 복구 방법 |
US20050149819A1 (en) * | 2003-12-15 | 2005-07-07 | Daewoo Electronics Corporation | Three-dimensional error correction method |
-
2006
- 2006-10-10 US US11/545,668 patent/US7840872B2/en not_active Expired - Fee Related
-
2007
- 2007-09-29 DE DE102007046789A patent/DE102007046789A1/de not_active Ceased
- 2007-10-08 FR FR0707040A patent/FR2906926B1/fr active Active
- 2007-10-09 GB GB0719724A patent/GB2442863B/en active Active
Also Published As
Publication number | Publication date |
---|---|
US20080098280A1 (en) | 2008-04-24 |
GB2442863B (en) | 2011-07-20 |
US7840872B2 (en) | 2010-11-23 |
FR2906926B1 (fr) | 2016-10-21 |
GB0719724D0 (en) | 2007-11-21 |
GB2442863A (en) | 2008-04-16 |
DE102007046789A1 (de) | 2008-04-17 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
FR2906926A1 (fr) | Dispositif et procede iteratif de code de correction des erreurs (ecc), avec relecture et information d'erreur-effacement combines | |
US11263076B2 (en) | Methods and devices for decoding quantum states | |
JP4939409B2 (ja) | 誤りを訂正するための装置、方法、及びプログラム | |
TW200302454A (en) | Decoding method and apparatus therefor | |
JP4946844B2 (ja) | 記録再生装置および記録再生方法 | |
US10152999B2 (en) | Systems and methods for correlation based data alignment | |
US20030095056A1 (en) | Enhanced coding for informed decoders | |
US8832521B2 (en) | Apparatus and method for processing optical information using low density parity check code | |
FR2831971A1 (fr) | Procede de memorisation de donnees avec correction d'erreur | |
EP0204635B1 (fr) | Procédé de transmission en blocs de mots d'information numérique | |
FR2845220A1 (fr) | Procedes et dispositifs pour le decodage des codes de geometrie algebrique a un point | |
JP4988418B2 (ja) | 回転する記憶媒体の複数の層にデータを読み書きする方法、プログラム及びデータ記憶装置 | |
US8130459B2 (en) | Converting timing errors into symbol errors to handle write mis-synchronization in bit-patterned media recording systems | |
TW201513102A (zh) | 用於多階編碼及解碼之系統及方法 | |
JP4191043B2 (ja) | 単純な復号化方法及び装置 | |
US20040078746A1 (en) | Error correction method and reproduction apparatus | |
FR3016453A1 (fr) | Procede et dispositif de stockage de donnees, procede et dispositif de decodage de donnees stockees, et programme d’ordinateur correspondants. | |
EP0769854B1 (fr) | Système permettant un décodage correct, sous forme d'un message binaire, d'un code magnétique enregistré sur une piste magnétique | |
CN100394506C (zh) | 纠错装置及方法 | |
EP2909725A1 (fr) | Procédé et dispositif pour améliorer la fiabilité de mémorisation de données dans un disque dur comprenant plusieurs plateaux | |
EP2786497A1 (fr) | Procédé de maximisation de la capacité de correction d'un code correcteur d'erreurs mettant en oeuvre des syndromes supplémentaires | |
FR3016454A1 (fr) | Procede et dispositif de stockage de donnees, procede et dispositif de decodage de donnees stokees et programme d'ordinateur correspondants | |
Yamamoto et al. | Error modeling and performance analysis of error-correcting codes for the digital video recording system | |
FR2762920A1 (fr) | Procede de transfert de donnees entre une memoire de masse a disque optique et un ordinateur | |
WO2006029960A1 (fr) | Procede et dispositif de mise a jour d'une graine etablie par une fonction deterministe dans un dispositif de communication a traitement numerique |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PLFP | Fee payment |
Year of fee payment: 9 |
|
PLFP | Fee payment |
Year of fee payment: 10 |
|
PLFP | Fee payment |
Year of fee payment: 11 |
|
PLFP | Fee payment |
Year of fee payment: 12 |
|
PLFP | Fee payment |
Year of fee payment: 13 |
|
PLFP | Fee payment |
Year of fee payment: 14 |
|
PLFP | Fee payment |
Year of fee payment: 15 |
|
PLFP | Fee payment |
Year of fee payment: 16 |
|
PLFP | Fee payment |
Year of fee payment: 17 |