DE19960269A1 - Channel encoding transmission method with effective, modular nesting or interlacing for applying turbo codes, involves using coincidence algorithm. - Google Patents
Channel encoding transmission method with effective, modular nesting or interlacing for applying turbo codes, involves using coincidence algorithm.Info
- Publication number
- DE19960269A1 DE19960269A1 DE1999160269 DE19960269A DE19960269A1 DE 19960269 A1 DE19960269 A1 DE 19960269A1 DE 1999160269 DE1999160269 DE 1999160269 DE 19960269 A DE19960269 A DE 19960269A DE 19960269 A1 DE19960269 A1 DE 19960269A1
- Authority
- DE
- Germany
- Prior art keywords
- chain
- bit
- bits
- rank
- transmitted
- 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.)
- Withdrawn
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L1/00—Arrangements for detecting or preventing errors in the information received
- H04L1/004—Arrangements for detecting or preventing errors in the information received by using forward error control
- H04L1/0041—Arrangements at the transmitter end
-
- 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/27—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 using interleaving techniques
- H03M13/275—Interleaver wherein the permutation pattern is obtained using a congruential operation of the type y=ax+b modulo c
-
- 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/27—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 using interleaving techniques
- H03M13/2771—Internal interleaver for turbo codes
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L1/00—Arrangements for detecting or preventing errors in the information received
- H04L1/004—Arrangements for detecting or preventing errors in the information received by using forward error control
- H04L1/0056—Systems characterized by the type of code used
- H04L1/0071—Use of interleaving
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L1/00—Arrangements for detecting or preventing errors in the information received
- H04L1/004—Arrangements for detecting or preventing errors in the information received by using forward error control
- H04L1/0056—Systems characterized by the type of code used
- H04L1/0064—Concatenated codes
- H04L1/0066—Parallel concatenated codes
Landscapes
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- Probability & Statistics with Applications (AREA)
- Theoretical Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Error Detection And Correction (AREA)
- Detection And Prevention Of Errors In Transmission (AREA)
Abstract
Description
Die vorliegende Erfindung hat ein Übertragungsverfahren mit Kanalcodierung zum Gegenstand, d. h. mit einer Erzeugung von zu übertragenden Bits, die die Übertragungsleistungen eines Kanals derart berücksichtigt, daß die Übertragungsqualität so perfekt wie möglich ist, trotz der diesem Kanal innewoh nenden, unvermeidlichen physischen Fehlern. Ziel der Erfin dung ist es, ein Verfahren vorzuschlagen, bei dem eine praktische Anwendung einer theoretischen und erprobten Lö sung mit Signalverarbeitungseinrichtungen mit begrenzter Leistung einfach auszuführen ist. Diese Einrichtungen sind insbesondere Mobilfunktelefone. Das Hauptverwendungsgebiet der Erfindung ist also die Mobilfunktelefonie. Die Erfin dung könnte aber auch bei Satellitenverbindungen angewandt werden. Allgemein ist die Erfindung immer dann einsetzbar, wenn man einen Turbocode verwenden möchte, für den eine wirksame und modulare Verschachtelung gesucht wird.The present invention has a transmission method with Channel coding on the subject, d. H. with a generation of bits to be transmitted, which indicate the transmission powers of a Channel taken into account in such a way that the transmission quality is as perfect as possible, despite the intrinsic to this channel resulting inevitable physical errors. Aim of the Erfin It is an idea to propose a procedure in which a practical application of a theoretical and proven solution solution with signal processing equipment with limited Performance is easy to do. These facilities are especially mobile phones. The main area of use So the invention is mobile telephony. The Erfin could also be used for satellite connections become. In general, the invention can always be used if you want to use a turbo code for one effective and modular nesting is sought.
Bei der digitalen Informationsübertragung (Sprache, Bilder, Daten, usw.) unterscheidet man die Quellcodierung und die Kanalcodierung. Die Quellcodierung hat zum Ziel, die zu übertragenden digitalen Informationen zu komprimieren, so daß sie so wenig Platz wie möglich einnehmen, damit die Nutzdatenrate maximal ist. Dagegen besteht die Kanalcodie rung darin, der zu übertragenden Information eine Redundanz hinzuzufügen, damit die empfangene Information gegenüber den durch den Kanal verursachten Fehlern robuster ist. Hierbei verwandelt man eine unnütze Redundanz, die der ur sprünglichen Information, in eine nützliche Redundanz, die es ermöglicht, dem Übertragungsrauschen gegenüber wider standsfähig zu sein. Die Kanalcodierung hat also eine große Bedeutung. Eine große Anzahl von Kanalcodierungen steht seit den sechziger Jahren zur Verfügung. Man kennt unter anderen die Faltungs-Codierungen, die BCH-Codierungen, die Reed-Solomon-Codierungen usw. Die verwendeten Kanalcodie rungen unterscheiden sich je nach den ins Auge gefaßten An wendungen.With digital information transmission (voice, images, Data, etc.) one differentiates the source coding and the Channel coding. The aim of the source coding is to to compress transmitted digital information, so that they take up as little space as possible so that the User data rate is maximum. In contrast, the channel code exists redundancy in the information to be transmitted add to face the information received the errors caused by the channel is more robust. This turns an unnecessary redundancy that the original original information, in a useful redundancy that it allows to be reflected against the transmission noise to be stable. So the channel coding has a big one Importance. A large number of channel codes are available available since the 1960s. You know under others the convolutional codes, the BCH codes, the Reed-Solomon encodings, etc. The channel code used The requirements differ depending on the envisaged turns.
In der französischen Patentanmeldung 91 05280 mit dem Titel "Procédé de codage correcteur d'erreurs à au moins deux co dages convolutifs systématiques en parallèle, procédé de decodage itératif, module de décodage et décodeur corre spondant" (Fehlerkorrektur-Codierverfahren mit mindestens zwei parallelen, systematischen Faltungs-Codierungen, ite ratives Decodierverfahren, Decodiermodul und entsprechender Decodierer) sowie in der Druckschrift "Near Shannon limit error-correcting coding and decoding: Turbo Codes" Proc. In French patent application 91 05280 entitled "Procédé de codage correcteur d'erreurs à au moins deux co dages convolutifs systématiques en parallèle, procédé de decodage itératif, module de décodage et décodeur corre spondant "(error correction coding method with at least two parallel, systematic convolutional codes, ite ratative decoding method, decoding module and corresponding Decoder) and in the publication "Near Shannon limit error-correcting coding and decoding: Turbo Codes "Proc.
1993 International Conference an Communications, von C. Berrou, A. Glavieux und P. Thitimajshima, wurde ein neues, Turbocode genanntes Codierschema vorgeschlagen, dessen Lei stungen sich dem theoretischen Grenzwert der Kapazität ei nes Kanals annähern, wie es das Theorem von C. Shannon be schreibt.1993 International Conference an Communications, by C. Berrou, A. Glavieux and P. Thitimajshima, became a new, Turbocode called coding scheme proposed, the Lei the theoretical limit of the capacity approximate a channel, as is the theorem of C. Shannon writes.
In einem Beispiel, in dem der Codiersatz 1/3 entspricht, überträgt man mit einer solchen Codierung einen Datenfluß X von zu codierenden Daten in Form von drei Datenflüssen Y1, Y2 und Y3 von codierten Daten. In einem Beispiel ist der Datenfluß Y1 gleich dem Datenfluß X. Der Datenfluß Y2 re sultiert aus der Codierung des Datenflusses X durch einen ersten rekursiven Faltungscodierer. Der Datenfluß Y3 resul tiert aus der Codierung einer Permutation, ungenauerweise Verschachtelung genannt, der Bits des Datenflusses X durch einen zweiten rekursiven Faltungscodierer. Ein Turbo- Encoder verwendet so mindestens zwei vorzugsweise systema tische, rekursive Faltungscodierer, wobei dem zweiten ein zeitliches Verschachtelungsorgan vorgeschaltet ist, das auf Blöcken festgelegter Größe arbeitet.In an example in which the coding set corresponds to 1/3, one transmits a data flow X with such a coding of data to be encoded in the form of three data flows Y1, Y2 and Y3 of encoded data. In one example it is Data flow Y1 is equal to data flow X. Data flow Y2 right results from the coding of the data flow X by a first recursive convolutional encoder. The data flow Y3 results based on the coding of a permutation, inaccurately Called interleaving, the bits of the data flow X through a second recursive convolutional encoder. A turbo Encoder thus uses at least two, preferably systema table, recursive convolutional encoder, the second one temporal interleaving device that is upstream Blocks of fixed size works.
Der Permutationskreis bzw. das Verschachtelungsorgan ist eine wesentliche Komponente der Turbocodes. Eine konzeptmä ßige Interpretation ihrer Funktionsweise ist im Artikel von G. Battail "A conceptual framework for understanding Turbo Codes", IEEE Journal an Selected Areas in Communications, Vol. 16, Nr. 2, Februar 1998 angegeben. Sehr kurz kann dar an erinnert werden, daß eine Verschachtelung, wenn sie gut durchgeführt ist, es ermöglicht, eine Zufallscodierung zu imitieren. Es ist auch daran zu erinnern, daß die Zufalls codierung bei der Demonstration des Theorems der Kapazität von C. Shannon eine zentrale Rolle spielt. Es wird allge mein darin übereingestimmt zu sagen, daß es zwei sehr wich tige Faktoren für die Gestaltung eines solchen Verschachte lungsorgans gibt. Der erste Faktor ist die Tiefe dieses Verschachtelungsorgans. Die Tiefe ist die Größe des Ver schachtelungsorgans, d. h. die Anzahl n von Bits, die es permutieren kann. Je größer die Tiefe, desto besser, d. h. desto wirksamer ist der Zufallscharakter. Der zweite Faktor ist der Zufallsgrad, den das Verschachtelungsorgan bei ei nem gegebenen Block einführen kann. Ein ideales Verschach telungsorgan ist dann ein reines Zufalls-Verschachtelungs organ, aber das gibt es in der Praxis nicht.The permutation circle or the nesting element is an essential component of the turbo codes. A conceptual The interpretation of how it works is in the article by G. Battail "A conceptual framework for understanding Turbo Codes ", IEEE Journal on Selected Areas in Communications, Vol. 16, No. 2, February 1998. Can be very short to be reminded that nesting if good is carried out, it allows random coding imitate. It should also be remembered that random coding in demonstrating the capacity theorem by C. Shannon plays a central role. It is common my agreed to say that it very much gave way to two factors for the design of such a shaft governing body there. The first factor is the depth of this Nesting organ. The depth is the size of the ver nesting organ, d. H. the number n of bits it can permute. The greater the depth, the better. H. the more effective is the randomness. The second factor is the degree of randomness that the interleaving element at ei can introduce a given block. An ideal chess telungsorgan is then a pure random nesting organ, but that doesn't exist in practice.
Ein Verschachtelungsorgan hat nämlich zum Ziel, die Wörter von Codes geringer Gewichtung zu brechen, die am häufigsten zu übertragen sind. Es ist außerdem möglich, nichtzufäl lige Verschachtelungsorgane herzustellen, die wirksam die Wörter von Codes geringer Gewichtung bekämpfen. Unglückli cherweise haben diese letzteren Verschachtelungsorgane aber die Neigung, die Wirkungen der Codewörter hoher Gewichtung zu verstärken, was auch nicht wünschenswert ist. Das Krite rium, das es ermöglicht, ein optimales Verschachtelungsor gan herzustellen, muß die Codes aller Gewichtungen gleich zeitig berücksichtigen, und ein globales Optimum erreichen. Die Bestimmung dieses Kriteriums ist ein noch nicht gelö stes Problem.The goal of a nesting organ is the words break from low weight codes, the most common are to be transferred. It is also possible not to fail manufacture nesting organs that effectively the Combat words of low weight codes. Unfortunate However, the latter have nesting elements the tendency, the effects of high weight code words to reinforce, which is also undesirable. The Krite rium, which makes it possible to optimally nest gan, the codes of all weights must be the same take into account at an early stage and achieve a global optimum. The determination of this criterion has not yet been solved first problem.
Die bei den reellen Systemen gemäß dem Stand der Technik verwendeten Verschachtelungstechniken nutzen Matrizen. Die se Matrizen werden mit Hardwareschaltungen verwendet. Bei solchen Hardwareschaltungen werden die Daten oder Bits ei nes Blocks in Zeilen eingegeben, Matrixzeile für Matrixzei le. Sie werden anschließend in Spalten gelesen. Simulatio nen zeigen aber, daß die mit solchen Matrix-Verschachte lungsorganen erhaltenen Leistungen geringer sind als dieje nigen, die mit Verschachtelungsorganen erhalten werden, die durch Computerprogramme erzeugt werden, welche den Zufall imitieren. The real systems according to the state of the art The nesting techniques used use matrices. The These matrices are used with hardware circuits. At such hardware circuits will use the data or bits nes block entered in lines, matrix line for matrix line le. They are then read in columns. Simulation NEN show, however, that those with such matrix shafts benefits received are less than those nig that are obtained with nesting organs that are generated by computer programs which are random imitate.
Andererseits erfordern die beweglichen Funkverbindungszel len der dritten Generation, insbesondere im Rahmen der Emp fehlung IMT 2000, die Verwendung vieler verschiedener Dien ste, die unterschiedlichen Datenraten und zeitlichen Bedin gungen zugeordnet sind. Unter Berücksichtigung der Leistun gen der Turbocodes ist es wahrscheinlich, daß sie für die Dienste verwendet werden, die einen großen Schutz gegen Fehler erfordern, aber eine gewisse Verzögerung unterstüt zen (die des Verschachtelungsorgans). Das von den Matrixsy stemen nicht gelöste Problem ist dann der starre Charakter der Abmessung der Datenblöcke, die verarbeitet werden kön nen. Diese starren Abmessungen resultieren aus der Abmes sung der gewählten Matrizen und ihrem Schreib-Lese-System.On the other hand, the mobile radio connection cells require third generation, especially within the Emp recommendation IMT 2000, the use of many different dien different data rates and temporal conditions conditions are assigned. Taking into account the performance According to the turbo codes, it is likely that they will be used for the Services are used that offer great protection against Require mistakes, but support some delay zen (that of the nesting organ). The Matrixsy The problem that is not solved is the rigid character the dimension of the data blocks that can be processed nen. These rigid dimensions result from the dimension solution of the selected matrices and their read / write system.
Wenn man zum Beispiel annimmt, über k verschiedene Dienste zu verfügen, die je Zeitverzögerungen von r1, r2, . . . rk Bits unterstützen, ist es das Ziel, für jeden Dienst ein Verschachtelungsorgan maximaler Tiefe zu erzeugen, wobei bekannt ist, daß die Leistungen der Verschachtelung auf der Größe des Verschachtelungsorgans beruhen. Eine Schwierig keit bei der üblicherweise vorgeschlagenen Matrix-Anwendung besteht darin, die verschiedenen Verschachtelungsorgane für die verschieden Blockgrößen fest spezifizieren zu müssen.If you assume, for example, about k different services to have the time delays of r1, r2,. . . rk Support bits, the goal is for each service To produce nesting element of maximum depth, whereby it is known that the nesting services on the Size of the nesting organ. A difficult one speed in the usually proposed matrix application is the different nesting organs for to have to specify the different block sizes.
Die vorliegende Erfindung hat zum Ziel, diese Probleme zu lösen. Sie schlägt vor, ein softwaremäßig hergestelltes Verschachtelungsorgan auszubilden, das außerdem nur sehr wenige Parameter im Speicher benötigt. Für einen Block von n zu verschachtelnden Bits, mit Rängen k von 1 bis n in der Kette der zu übertragenden Bits, wird erfindungsgemäß durch Permutation ein weiterer Block von n Bits einer verschach telten Kette erzeugt. Die Ränge der Bits in der verschach telten Kette sind dann Ränge h, so daß h = f(k). Die Funk tion f muß eine Permutation von {1, . . ., n} sein, d. h. eine bijektive Anwendung von {1, . ., n} in sich selbst. Um die Funktion f zu realisieren, wendet man erfindungsgemäß eine Gleichung linearer Kongruenz an. Man kann dann zeigen, daß die Wahl einer solchen Lösung zur Wirkung hat, daß auf spe zifische Schaltungen verzichtet wird und außerdem nur ge ringe Ressourcen in Bezug auf die Software benötigt werden. Der Zufallscharakter ist somit theoretisch nicht perfekt, aber seine Annäherung durch einen einfachen Kongruenz- Algorithmus ist absolut wirksam in Bezug auf das Problem der Leistungsverbesserung der gesuchten Kanalcodierung.The present invention aims to address these problems to solve. She suggests a software-made one Training nesting organ, which is also only very few parameters needed in the memory. For a block of n bits to be nested, with ranks k from 1 to n in the Chain of bits to be transmitted is, according to the invention, by Permutation another block of n bits one chess generated chain. The ranks of the bits in the chess Then the chain is r, so that h = f (k). The funk tion f must have a permutation of {1,. . ., n}, d. H. a bijective application of {1,. ., n} in itself. To the To implement function f, according to the invention, one is used Equation of linear congruence. It can then be shown that the choice of such a solution has the effect that on spe specific circuits is dispensed with and also only ge ringe resources related to the software are needed. The random character is therefore theoretically not perfect, but its approximation through a simple congruence Algorithm is absolutely effective on the problem to improve the performance of the channel coding sought.
Die Erfindung hat also ein Übertragungsverfahren mit Ka
nalcodierung zwischen einem Sender und einem Empfänger zum
Gegenstand, bei dem
The invention thus relates to a transmission method with channel coding between a transmitter and a receiver, in which
- - eine Bitkette von n zu übertragenden Bits mit einem ersten Codierer codiert wird, um eine erste codierte Kette zu erhalten,- A bit string of n bits to be transmitted with one first encoder is encoded to a first encoded chain to obtain,
- - Bits der zu übertragenden Bitkette permutiert wer den, um eine weitere, sogenannte verschachtelte Bitkette zu erhalten,- Permutates bits of the bit string to be transmitted to add another so-called nested bit string receive,
- - die verschachtelte Kette mit einem zweiten Codierer codiert wird, um eine zweite codierte Kette zu erhalten,- The nested chain with a second encoder is encoded to obtain a second encoded chain
- - vom Sender zum Empfänger die zu übertragende Bitket te und/oder die erste und/oder die zweite codierte Kette übertragen werden,- from the sender to the receiver, the bitket to be transmitted te and / or the first and / or the second coded chain be transmitted,
- - und entsprechend die von der Senderseite übertrage nen Ketten empfangen und decodiert werden, um die zu über tragende Bitkette wiederherzustellen,- and accordingly the one transmitted by the transmitter NEN chains are received and decoded to over the to restore the carrying bit string,
dadurch gekennzeichnet, daß
characterized in that
-
- zur Permutation der Bits der Bitkette von n zu über
tragenden Bits einem Bit des Rangs k der zu übertragenden
Bitkette ein Rang hk in der verschachtelten Kette zugeordnet
wird, der von einem Rang hk-1 abhängt, der einem Bit des
Rangs k-1 der zu übertragenden Bitkette zugeordnet ist, so
daß der zugeordnete Rang hk von der Art ist:
hk = a.hk-1 + b, Modulo m, wobei a, b und m ganze Zahlen sind.For the permutation of the bits of the bit chain of n bits to be transmitted, a bit of the rank k of the bit chain to be transmitted is assigned a rank h k in the nested chain which depends on a rank h k-1 which corresponds to a bit of the rank k 1 is assigned to the bit string to be transmitted, so that the assigned rank h k is of the type:
h k = ah k-1 + b, modulo m, where a, b and m are integers.
Die Erfindung wird besser verstanden werden anhand der nachfolgenden Beschreibung und der Betrachtung der beilie genden Figuren. Diese sind nur darstellend und nicht die Erfindung einschränkend zu verstehen. Die Figuren zeigen:The invention will be better understood from the following description and the consideration of the enclosed figures. These are only illustrative and not that To understand the invention restrictively. The figures show:
Fig. 1 die funktionelle Darstellung einer Codier vorrichtung, die zur Anwendung des erfindungsgemäßen Ver fahrens genutzt werden kann; Figure 1 shows the functional representation of a coding device that can be used to apply the method according to the invention.
Fig. 2 ein Flußdiagramm der Verfahrensschritte des erfindungsgemäßen Verschachtelungsverfahrens; Fig. 2 is a flowchart of the method steps of the interleaving method according to the invention;
Tabelle 1, die ausdrücklich Teil der Beschrei bung ist, enthält bevorzugte Parameterwerte, die sich auf bevorzugte Ausführungsformen des erfindungsgemäßen Algo rithmus beziehen.Table 1, which is expressly part of the description Exercise contains preferred parameter values that relate to preferred embodiments of the algo according to the invention relate to the rhythm.
Fig. 1 zeigt eine funktionelle Darstellung von Einrichtun gen zur Anwendung eines erfindungsgemäßen Übertragungsver fahrens. Dieses Verfahren soll zwischen einem Sender 1 und einem Empfänger 2 angewendet werden. Der Sender 1 und der Empfänger 2 sind symbolisch dargestellt und miteinander über einen Kanal 3 verbunden. Das erfindungsgemäße Übertra gungsverfahren mit Kanalcodierung ist von der Art, die ei nen Datenfluß X, erzeugt vom Sender 1, in mehrere Daten flüsse Y1, Y2, Y3, Yi umwandelt, die vom Kanal 3 übertragen werden. Der Kanal 3 ist meist ein funkelektrischer Kanal, wobei eine Codierschaltung 4 das erfindungsgemäße Verfahren anwendet, der zwischen den Sender 1 und den Empfänger 2 ge schaltet ist und außerdem eine nicht dargestellte zugeord nete funkelektrische Sendeschaltung besitzt. Auf der Emp fangsseite sind Schaltungen geeignet, um entsprechend die Ketten Y1, Y2, Y3, Yi zu decodieren und zu empfangen und die übertragene Kette X wiederherzustellen. Fig. 1 shows a functional representation of Einrichtun conditions for using a transmission method according to the invention. This method is intended to be used between a transmitter 1 and a receiver 2 . The transmitter 1 and the receiver 2 are shown symbolically and connected to one another via a channel 3 . The transmission method according to the invention with channel coding is of the type which converts a data flow X, generated by the transmitter 1 , into a plurality of data flows Y1, Y2, Y3, Yi which are transmitted by the channel 3 . The channel 3 is usually a radio-electric channel, with a coding circuit 4 applying the method according to the invention, which is switched between the transmitter 1 and the receiver 2 and also has a not shown assigned radio-electric transmission circuit. On the receiving side, circuits are suitable for decoding and receiving the chains Y1, Y2, Y3, Yi and restoring the transmitted chain X accordingly.
Die Kanalcodierschaltung 4 besitzt einen ersten Faltungsco dierer 5, der eine Bitkette Y2 ausgehend von einer zu co dierenden Kette X erzeugt. In einem Beispiel ist dieser Faltungscodierer ein rekursiver Faltungscodierer. Er ent hält in seinem Prinzip eine bestimmte Anzahl von Verzöge rungsschaltungen 6 bis 9 in Kaskade, deren Ausgänge mit Ad dierern oder allgemeiner mit Operatoren 10 bis 13 verbunden sind. Die Operatoren 10 bis 13 haben zum Ziel, Bits der Kette X, die zu einem gegebenen Zeitpunkt zur Verfügung stehen, mit Bits dieser gleichen Kette, oder einer Umwand lung dieser Kette, zu kombinieren, die zu einem späteren Zeitpunkt zur Verfügung stehen. Der dargestellte Fal tungscodierer 5 wird rekursiver Codierer genannt, da die Faltungsprodukte, insbesondere diejenigen, die vom Operator 12 kommen, am Eingang des Systems in einem Operator 13 mit noch nicht verarbeiteten Bits der Kette X der zu codieren den Bits kombiniert werden. Wie oben erwähnt, wird die Her stellung eines rekursiven Faltungscodierers bevorzugt, da bei gleicher Codierkomplexität (und gleicher Schutzwirksam keit) ein solcher rekursiver Codierer weniger Operatoren und Verzögerungsschaltungen als ein nicht-rekursiver Codie rer erfordert, der die gleiche Umwandlung durchführt. Aus diesem Grund ist es erfindungsgemäß also a priori nicht notwendig, daß der Codierer 5 ein rekursiver Faltungscodie rer ist. Er könnte ein einfacher Faltungscodierer oder so gar ein anderes Codiersystem des Typs BCH oder Reed SOLOMON usw. sein, aber die Leistungen wären anders.The channel coding circuit 4 has a first convolutional encoder 5 which generates a bit chain Y2 starting from a chain X to be coded. In one example, this convolutional encoder is a recursive convolutional encoder. It contains in principle a certain number of delay circuits 6 to 9 in cascade, the outputs of which are connected to ad diers or more generally to operators 10 to 13 . The aim of the operators 10 to 13 is to combine bits of the chain X that are available at a given time with bits of this same chain, or a conversion of this chain, that are available at a later time. The illustrated folding encoder 5 is called a recursive encoder since the convolution products, in particular those coming from the operator 12, are combined at the input of the system in an operator 13 with not yet processed bits of the chain X of the bits to be encoded. As mentioned above, the manufacture of a recursive convolutional encoder is preferred because, with the same coding complexity (and the same protection efficiency), such a recursive encoder requires fewer operators and delay circuits than a non-recursive encoder that performs the same conversion. For this reason, according to the invention, it is therefore not a priori necessary for the encoder 5 to be a recursive convolutional encoder. It could be a simple convolutional encoder or some other BCH or Reed SOLOMON encoding system, etc., but the performance would be different.
Zusätzlich zu ihrer unveränderten Übertragung in der Kette Y1 oder in einer Faltungsform in der Kette Y2 wird erfin dungsgemäß die Kette X von zu verarbeitenden Bits in Form einer dritten codierten Kette Y3 von einem weiteren Codie rer 14 übertragen, der ebenfalls die Kette X von zu codie renden Bits empfängt. Die Besonderheit der Kette Y3 ist es, daß sie ausgehend von einer Permutation der Kette X der zu codierenden Bits erhalten wird. Diese Permutation wird von einem Permutationskreis durchgeführt, der auch Verschachte lungsorgan 15 genannt wird und zwischen den Eingang des Co dierers 14 und den Eingang der Codierschaltung 4 geschaltet ist.In addition to its unchanged transmission in the chain Y1 or in a convolution form in the chain Y2, the chain X of bits to be processed is inventively transferred in the form of a third coded chain Y3 by a further encoder 14 , which also encodes the chain X of code received bits. The peculiarity of the chain Y3 is that it is obtained on the basis of a permutation of the chain X of the bits to be coded. This permutation is carried out by a permutation circuit, which is also referred to as the manhole organ 15 and is connected between the input of the encoder 14 and the input of the coding circuit 4 .
Links in Fig. 1 ist in einem Beispiel bei einer Kette X
von 12 Bits die vom Verschachtelungsorgan 15 Bit für Bit
durchgeführte Verarbeitung, um die Kette X in eine permu
tierte Kette X' umzuwandeln, dargestellt. Das Verschachte
lungsorgan 15 ist vorzugsweise ein Software-Verschachte
lungsorgan und sein Umwandlungsalgorithmus ist in Fig. 2
dargestellt. Um die Bits der Bitkette von n zu übertragen
den Bits, in diesem Beispiel zwölf Bits, zu permutieren,
ordnet man gemäß den obigen Ausführungen einem Bit mit dem
Rang k der zu übertragenden Bitkette X einen Rang hk in der
verschachtelten Kette X' zu. Die Besonderheit der Erfindung
liegt darin, daß der Rang hk in der Kette X' vom Rang hk-1
abhängt, der einem Bit des Rangs k-1 der Bitkette X von zu
übertragenden Bits zugeordnet ist. Die Abhängigkeit ist
derart, daß
On the left in FIG. 1, in an example with a chain X of 12 bits, the processing carried out by the interleaver 15 bit by bit in order to convert the chain X into a permuted chain X 'is shown. The nesting element 15 is preferably a software nesting element and its conversion algorithm is shown in FIG. 2. In order to permute the bits of the bit chain from n to permute the bits, in this example twelve bits, a bit with the rank k of the bit string X to be transmitted is assigned a rank h k in the nested chain X 'according to the above statements. The special feature of the invention is that the rank h k in the chain X 'depends on the rank h k-1 , which is assigned to a bit of the rank k-1 of the bit string X of bits to be transmitted. The dependency is such that
hk = a. hk-1 + b Modulo mh k = a. h k-1 + b modulo m
In dieser Formel sind a, b und m ganze Zahlen, Parameter der Umwandlung. Zur Vervollständigung ist ein ergänzender Parameter und wesentlicher Bestandteil der Erfindung die Anzahl n von Bits der zu codierenden Kette X. Wie dies in der Einleitung bereits gesagt wurde, ermöglicht nämlich die Erfindung, die Codierung an die Länge der zu übertragenden Wörter anzupassen. Im Rahmen der GSM zum Beispiel ist be kannt, daß bei einem Nutzfenster von 156 Bits nur 142 Bits eine informative Bedeutung haben. Aus diesen 142 Bits wer den drei Gruppierungen gebildet. Eine erste und eine dritte Gruppierung stellen zu übertragende Informationen dar. Eine zweite, zwischen den beiden anderen liegende Gruppierung enthält Kohärenzinformationen, die es einer Kanaldecodier schaltung auf der Empfangsseite ermöglichen, die beiden er warteten Bitgruppierungen zu finden und die Übertragungs leistungen des Kanals zu verbessern. Es sind auch andere Normen möglich. Sogar bei der Norm GSM ist es möglich, die Übertragungsprotokolle hohen Datenraten anzupassen. In die sem Fall beträgt die Schlüssellänge der zu übertragenden Wörter nicht mehr 142 Bits, sondern kann sehr viel größer sein. Zum Beispiel kann sie 1024 Bits oder mehr betragen.In this formula, a, b and m are integers, parameters of conversion. To complete it is a supplement Parameters and an integral part of the invention Number n of bits of the chain X to be encoded the introduction has already been said, namely that Invention, the coding to the length of the transmitted Adapt words. In the context of GSM, for example, be knows that with a useful window of 156 bits only 142 bits have an informative meaning. Out of these 142 bits who the three groups. A first and a third Grouping represents information to be transmitted second grouping between the other two contains coherency information that it is a channel decoder enable circuit on the receiving side, the two he waited to find bit groups and the transmission improve channel performance. There are others too Standards possible. Even with the GSM standard, it is possible to Adapt transmission protocols to high data rates. In the In this case, the key length is the one to be transmitted Words no longer 142 bits, but can be much larger his. For example, it can be 1024 bits or more.
Während eines Schritts 16 definiert man im vom Verschachte lungsorgan 15 angewendeten Programm die Werte der Parameter n, a, b und m. In der Folge wird man sehen, welches die Be dingungen sind, die auf der sorgfältigen Auswahl dieser Pa rameter lasten, da die fehlende Berücksichtigung dieser Be dingungen zu einem verschlechterten, wenn auch möglicher weise noch vom erfindungsgemäßen Codierungsalgorithmus ak zeptierbaren Betrieb führt. Nach dem Schritt 16 beginnt man während eines Schritts 17, die Kette X von zu übertragenden Bits zu durchsuchen. Dies geschieht in Form von zwei Befeh len 18 und 19, d. h. einem Befehl 18 k = 1 und hk = 1 gefolgt von einem Befehl 19 k = k + I. Der Befehl 18 bedeutet tat sächlich, daß man dem Bit des Rangs 1 in der zu übertragen den Kette X einen Rang hk = 1 in der Kette X' vor ihrer Co dierung durch den Codierer 14 verleiht. Dies ist nicht zwingend notwendig. Insbesondere könnte man für k = 1 vor sehen, einen Ausgangsrang hk ungleich 1 zu wählen. Es würde einfach genügen, daß hk kleiner ist als n. Die Wahl von hk ungleich 1 kann wie oben erwähnt dazu führen, die Bits ge ringer oder hoher Gewichtungen weder außergewöhnlich zu be lasten noch außergewöhnlich zu begünstigen. Wenn nötig, kann man vorsehen, daß hk bei jeder neuen Kette X, die einer Permutation unterzogen wird, seinen Wert ändert. Der Schritt 17 wird von einem Test 20 gefolgt, während dem man prüft, ob das zu verarbeitende Bit mit dem Rang k zur Kette X von n Bits gehört, oder ob es zu einer anderen Kette ge hört, die auf die Kette X folgt und auch n Bits aufweist. Wenn dies nicht der Fall ist, und zu Anfang ist es nicht der Fall, kann man den Rang hk finden, indem man den Befehl 21 anwendet, wissend, daß a, b und m bekannt sind.During a step 16 , the values of the parameters n, a, b and m are defined in the program used by the nesting member 15 . In the following it will be seen what the conditions are that impose the careful selection of these parameters, since the failure to take these conditions into account leads to a deteriorated, even if possibly still acceptable, operation of the coding algorithm according to the invention. After step 16 , step 17 begins to search the chain X of bits to be transmitted. This is done in the form of two commands 18 and 19 , ie a command 18 k = 1 and h k = 1 followed by a command 19 k = k + I. Command 18 actually means that the bit of rank 1 in which gives the chain X a rank h k = 1 in the chain X 'before its coding by the encoder 14 . This is not absolutely necessary. In particular, for k = 1 one could envisage choosing an initial rank h k not equal to 1. It would simply suffice for h k to be smaller than n. As mentioned above, the selection of h k not equal to 1 can lead to the bits of low or high weights being neither extraordinarily loaded nor favored in an exceptional manner. If necessary, it can be provided that h k changes its value with each new chain X which is subjected to a permutation. Step 17 is followed by a test 20 , during which one checks whether the bit to be processed with the rank k belongs to the chain X of n bits, or whether it belongs to another chain that follows the chain X and also n bits. If this is not the case, and initially it is not, the rank h k can be found using command 21 , knowing that a, b and m are known.
Wenn sie derart erzeugt werden, sind die Ränge hk nicht un bedingt zufällig über die ganze Kette X von Bits verteilt. Es ist außerdem sogar in manchen Fällen möglich, daß die Umwandlung 21 keine Permutation von {1, 2, . . ., n} ist. Da mit diese letzteren Kriterien erhalten werden, müssen den Parametern a, b und m bestimmte Bedingungen auferlegt wer den. Tatsächlich hat die (unendliche) Folge, die von der linearen Kongruenz des Schritts 21 definiert wird, als Pe riode m, wenn, und nur wenn, b und m teilerfremd sind; falls für jede Primzahl p, die m teilt, a-1 ein Vielfaches von p ist und falls a-1 ein Vielfaches von 4 ist, wenn m ein Vielfaches von 4 ist. Ein Nachweis dieser Bedingungen findet sich im Artikel von HULL und DOBELL, SIAM REVIEW, 4 (1962), Seiten 230 bis 254. In der Praxis genügt es, m = n+1 anzunehmen, um eine Permutation zu erzeugen.If they are generated in this way, the ranks hk are not necessarily randomly distributed over the entire chain X of bits. It is also possible, in some cases, that the conversion 21 does not permutate {1, 2,. . ., n} is. Since these latter criteria are obtained, certain conditions must be imposed on parameters a, b and m. In fact, the (infinite) sequence defined by the linear congruence of step 21 has as period m if, and only if, b and m are prime factors; if for every prime p that divides m, a-1 is a multiple of p, and if a-1 is a multiple of 4, if m is a multiple of 4. Evidence of these conditions can be found in the article by HULL and DOBELL, SIAM REVIEW, 4 (1962), pages 230 to 254. In practice it is sufficient to assume m = n + 1 in order to generate a permutation.
Im in Fig. 1 dargestellten Beispiel will man zwölf Bits permutieren. Man kann dann m = 13 nehmen. Es ist nämlich wichtig, daß m größer ist als n. Nachfolgend wird klar, wie man m wesentlich größer als n nimmt, um bestimmte Schwie rigkeiten des Algorithmus zu lösen. Bleibt die Wahl von a und b. Die Wahl von b ungleich Null führt dazu, hk ungleich 1 für k = 1 zu wählen. Meist wählt man b = 0. Um mit einem einzigen gemäß dem Schritt 21 angewendeten Algorithmus von einer Permutation zur anderen zu gelangen, reicht es, b (Modulo m) zum Rang jedes Bits hinzuzufügen, das vom Ver schachtelungsorgan 15 erzeugt wurde, in dem b den Wert Null hat. In Fig. 1 kann also die Codierschaltung 4 andere Co dierer enthalten, um andere Ketten Yi codierter Bits zu er zeugen. Anstatt jedes mal von der Kette X auszugehen und ein weiteres komplexes Verschachtelungsorgan 15 vorzusehen, kann es in diesem Fall nützlicher sein, von der Kette X' auszugehen, den Wert von b zu ändern und so ein zusätzli ches Verschachtelungsorgan zu geringeren Kosten herzustel len durch eine Addition von b, Modulo m, um einen anderen Codierer anzutreiben.In the example shown in FIG. 1, one wants to permute twelve bits. You can then take m = 13. It is important that m is greater than n. The following explains how to take m significantly larger than n in order to solve certain difficulties of the algorithm. That leaves the choice of a and b. The choice of b not equal to zero leads to choosing h k not equal to 1 for k = 1. Usually one chooses b = 0. To move from one permutation to another with a single algorithm applied according to step 21 , it suffices to add b (modulo m) to the rank of each bit generated by the interleaving member 15 , in which b has the value zero. In Fig. 1, the coding circuit 4 may contain other encoders to generate other chains of Yi coded bits. In this case, instead of starting from the chain X and providing a further complex interleaving element 15 , it can be more useful in this case to start from the chain X ', to change the value of b and thus to produce an additional interleaving element at a lower cost by one Add b, modulo m to drive another encoder.
Es bleibt also die Wähl von a. In einem Beispiel kann man a
willkürlich in der Größenordnung der Hälfte von n oder der
Hälfte von n-1 wählen. Zum Beispiel wählt man hier a = 6.
Die Anwendung des Schritts 21 mit a = 6 und b = 0 für m =
13 gibt dann die folgenden Ergebnisse, wobei die erste Zei
le die Ränge k der Bits der Kette X und die zweite Zeile
die zugeordneten Ränge hk in der Kette X bedeuten:
So the choice of a remains. In one example, a can be chosen arbitrarily on the order of half of n or half of n-1. For example, here one chooses a = 6. The application of step 21 with a = 6 and b = 0 for m = 13 then gives the following results, the first line being the ranks k of the bits of the chain X and the second line being the assigned ranks h k in chain X mean:
Dieses Beispiel ist außerdem am linken Rand der Fig. 1 dargestellt. Die erste Zeile stellt die Ränge k der Bits der Kette X der zu verarbeitenden Bits und die zweite Zeile stellt die Ränge hk dar, die bei der Anwendung des Schritts 21 diesen Bits des Rangs k der Kette X zugeteilt wurden. Wie im Schritt 18 erwähnt, befindet sich das Bit des Rangs k = 1 auf dem Rang hk = 1 in der Kette X' der Codierbits. Für das Bit des Rangs k = 2 wendet man den Schritt 21 an. Dies ergibt einen Rang h2 = 6 × 1 + 0, Modulo 13, für b = 0. Die Operation 6 × 1 + 0 ergibt 6, Modulo 13, was das Ergebnis nicht verändert. Dies führt dazu, dem Bit des Rangs k = 2 einen Rang hk = 6 in der Kette X' zu verleihen. Für das Bit des Rangs k = 3 ergibt die Anwendung der Formel h3 = 6 × 6 + 0 Modulo 13. Dies ergibt 36, Modulo 13, d. h. 10. So werden nach und nach alle Ränge hk zugeteilt. Da vom Generator 1 nach und nach Bits der Kette X erzeugt werden können, ent hält das Verschachtelungsorgan 15 dann ein Register 22, in dem gemäß einem Schritt 23 nach und nach im Laufe ihrer Er zeugung durch den Generator 1 die Bits der Kette X' in Ab hängigkeit von dem Platz, der ihnen vom Schritt 21 zuge teilt wurde, eingeordnet werden. Die im Register 22 einge tragenen Pfeile beziehen sich auf diese Einordnung 23.This example is also shown on the left edge of FIG. 1. The first line represents the ranks k of the bits of the chain X of the bits to be processed and the second line represents the ranks h k that were assigned to these bits of the rank k of the chain X when step 21 was applied. As mentioned in step 18 , the bit of rank k = 1 is at rank h k = 1 in the chain X 'of the coding bits. Step 21 is used for the bit of rank k = 2. This gives a rank h 2 = 6 × 1 + 0, modulo 13 , for b = 0. The operation 6 × 1 + 0 results in 6, modulo 13 , which does not change the result. This results in giving the bit of rank k = 2 a rank h k = 6 in the chain X '. For the bit of rank k = 3, applying the formula h 3 = 6 × 6 + 0 modulo 13 . This gives 36, modulo 13 , ie 10. Gradually, all ranks h k are allocated. Since the generator 1 gradually bits of the chain X may be generated ent holds the interleaver 15 then a register 22 in which according to a step 23 gradually in the course of their He generation by the generator 1, the bits of the string X 'in Dependent on the space that was assigned to them by step 21 , can be classified. The arrows entered in register 22 relate to this classification 23 .
Wenn man eine festgelegte Anzahl n von Bits permutieren
will und wenn m = n + 1 die Bedingungen nicht überprüfen
kann (was selten der Fall ist), kann man ein m' größer als
m finden, die Permutation mit Hilfe einer linearen Kongru
enz in m' durchführen und anschließend die Zahlen größer
als m streichen. Wenn man zum Beispiel zehn Bits permutie
ren will, kann man wie oben m = 13, a = 6, b = 0 und h1 = 1
nehmen. Man erhält dann
If one wants to permute a fixed number n of bits and if m = n + 1 cannot check the conditions (which is rarely the case), one can find an m 'greater than m, the permutation with the help of a linear congruence in m '' and then cross out the numbers greater than m. For example, if you want to permute ten bits, you can take m = 13, a = 6, b = 0 and h 1 = 1 as above. You then get
Anschließend streicht man 12 und 11 und erhält eine zufäl
lig organisierte Folge.
Then you delete 12 and 11 and get a randomly organized sequence.
Wenn man so handelt, mit m unbedingt höher als n + 1, ord net man sehr wohl einen Rang hk+1 in der verschachtelten Kette einem Bit des Rangs k der zu übertragenden Bitkette zu, wenn der normalerweise in der verschachtelten Kette zu teilbare Rang hk höher ist als n, und dies für alle Bits ei nes Rangs höher als k der zu übertragenden Bitkette. Tat sächlich hat man einen Rang 7 in der verschachtelten Kette dem Bit des Rangs 7 in der zu übertragenden Bitkette zuge ordnet, während der Rang 12, der normalerweise in der ver schachtelten Kette zuteilbar wäre, höher als 10 war. Eine solche Verschiebung wurde für alle Bits eines Rangs von mehr als 7 durchgeführt, d. h. die Bits der Ränge 8, 9 und 10 der zu übertragenden Bitkette. Im gezeigten Beispiel hat natürlich die Unterdrückung des Rangs 11 keinen Einfluß, da dieser Rang der letzte zugeordnete Rang war. Trotzdem kann das beschriebene Verschiebungsprinzip mehrfach angewendet werden.If one acts in this way, with m necessarily higher than n + 1, one assigns a rank h k + 1 in the nested chain to a bit of the rank k of the bit chain to be transmitted, if the rank normally to be divided in the nested chain h k is higher than n, and this for all bits of a rank higher than k of the bit string to be transmitted. In fact, a rank 7 in the nested chain has been assigned to the rank 7 bit in the bit string to be transmitted, while rank 12 , which would normally be assignable in the nested chain, was higher than 10. Such a shift was carried out for all bits of a rank of more than 7, ie the bits of the ranks 8 , 9 and 10 of the bit string to be transmitted. In the example shown, the suppression of rank 11 has of course no influence, since this rank was the last assigned rank. Nevertheless, the displacement principle described can be used several times.
Der Schritt 23 wird von einer Iteration durch Verzweigung zwischen den Befehlen 18 und 19 gefolgt. Wenn beim Test 20 der Rang des vom Generator 1 erzeugten Bits größer als k wird, liest man in einem Schritt 24 das im Register 22 ent haltene Wort und läßt es vom Codierer 14 codieren. Die Ket te Y von verarbeiteten Bits wird danach in einem Schritt 25 von der Sendeschaltung ausgegeben und in den Kanal 3 gesen det. Um die Verarbeitung durch den Codierer 14 flüssiger zu machen, ist es möglich, ein zweites Register 26 vorzusehen. Das zweite Register 26 gehört auch zum Verschachtelungsor gan 15. Während des Lesens der Kette X', der Codierung und der Sendung der im Register 22 enthaltenen Bits übernimmt in diesem Fall das Verschachtelungsorgan 15 die Aufgabe, eine weitere Kette X' von permutierten Bits zu bilden. In diesem Fall enthält gleichzeitig mit dem Schritt 24 der Al gorithmus der Fig. 2 eine Verzweigung 27 mit einem folgen den Wort mit n Bits zu einer folgenden zu verarbeitenden Kette X.Step 23 is followed by an iteration by branching between instructions 18 and 19 . If in the test 20 the rank of the bit generated by the generator 1 is greater than k, one reads the word contained in the register 22 in a step 24 and has it encoded by the encoder 14 . The chain Y of processed bits is then output in a step 25 by the transmission circuit and sent into channel 3 . In order to make the processing by the encoder 14 more fluid, it is possible to provide a second register 26 . The second register 26 also belongs to the nesting gate 15 . In this case, during the reading of the chain X ', the coding and the transmission of the bits contained in the register 22 , the interleaver 15 takes over the task of forming a further chain X' of permuted bits. In this case, at the same time as step 24, the algorithm of FIG. 2 contains a branch 27 with a follow the word with n bits to a subsequent chain X to be processed.
Nachfolgend werden in der TABELLE 1 Wertebeispiele der Pa rameter a, b und m angegeben. Below are examples of values for Pa parameters a, b and m specified.
In der Praxis wird die Wahl der Parameter a, b und m durch eine pragmatische Annäherung durchgeführt, indem die globa len Leistungen der Codierung mit verschiedenen Permutatio nen verglichen werden. Es wäre aber auch möglich, einen au tomatischen Algorithmus vorzusehen, der diese Parameter ausgehend von einer gegebenen Zahl n berechnen würde.In practice, the choice of parameters a, b and m is made by a pragmatic approach was carried out by the globa len performance of coding with different permutatio be compared. But it would also be possible to get an au automatic algorithm to provide these parameters would calculate from a given number n.
Bei dieser Berechnung wählt man in einem ersten Schritt m = n + 1. Dann wählt man a in der Größenordnung der Hälfte von m oder n. Die Bedingung, daß b und m teilerfremd sind, wird dann auf natürliche Weise erhalten, indem b = 0 gewählt wird. Dann sucht man alle Primzahlen p, die m teilen. Und man sucht a so, daß a-1 ein Vielfaches von p ist, unab hängig vom Wert von p. Zum Beispiel versucht man in einer Kette X von n = 1024 Bits m = 1025, was keine Primzahl ist. Man reduziert dann m im Primfaktor. Dann kann man schreiben 1025 = 5 × 5 × 41. Dies führt dazu, für a den Wert 5 × 41 + 1 zu wählen, d. h. a = 206. Man prüft anschließend, ob m-a ein Vielfaches von 5 und von 41 ist. Dann kann man b in Ab hängigkeit vom Rang des Verschachtelungsorgans 15 in der Gesamtheit der in der Codierschaltung 4 verwendeten Ver schachtelungsorgane definieren. Wenn es nur eines gibt, hat b den Wert 0. Wenn es zwei gibt, gilt für das erste b = 0 und für das zweite hat b einen anderen Wert, zum Beispiel a/2. In this calculation, in a first step one chooses m = n + 1. Then one chooses a in the order of half of m or n. The condition that b and m are prime factors is then naturally obtained by b = 0 is chosen. Then you look for all prime numbers p that divide m. And you search for a so that a-1 is a multiple of p, regardless of the value of p. For example, you try m = 1025 in a chain X of n = 1024 bits, which is not a prime number. One then reduces m in the prime factor. Then you can write 1025 = 5 × 5 × 41. This leads to choosing 5 × 41 + 1 for a, ie a = 206. You then check whether ma is a multiple of 5 and 41. Then one can define b as a function of the rank of the nesting element 15 in the entirety of the nesting elements used in the coding circuit 4 . If there is only one, b has the value 0. If there are two, the first b = 0 and the second b has a different value, for example a / 2.
Die Verwendung des erfindungsgemäßen Algorithmus erfordert die Multiplikation der Ränge hk-1 mit a. Dies stellt auf grund der Geschwindigkeit der heute in Verarbeitungsschal tungen verfügbaren Operatoren keine Schwierigkeit dar. Die Addition von b ist eine Operation, die im allgemeinen nur eine Zykluszeit verwendet. Die Kongruenz, Modulo m, kann mit einer einfachen Verschiebung des Lesens des vom Addie rer erzeugten Ergebnisses hergestellt werden, der b hinzu fügt, oder des Multiplikator mit a. Wenn man b = 0 wählt, hat dies natürlich den Vorteil, eine Operation wegzulassen, wobei die Verschiebung in diesem Fall auf dem Ergebnis der Multiplikation erfolgt.The use of the algorithm according to the invention requires multiplying the ranks h k-1 by a. This is not a problem due to the speed of the operators available today in processing circuits. The addition of b is an operation that generally uses only one cycle time. The congruence, modulo m, can be established by simply shifting the reading of the result generated by the adder, which adds b, or the multiplier with a. Of course, choosing b = 0 has the advantage of omitting an operation, in which case the shift is based on the result of the multiplication.
Die Vorteile der erfindungsgemäßen Lösung in Bezug auf den
Stand der Technik sind:
The advantages of the solution according to the invention in relation to the prior art are:
- - eine sehr große Einfachheit der Herstellung des Ver schachtelungsorgans 15 (Konzept, Kosten usw.);- A very great simplicity of manufacture of the nesting member 15 (concept, cost, etc.);
- - bessere Leistungen in den Fällen, in denen Datenra ten und spezifische zeitliche Bedingungen berücksichtigt werden müssen;- better performance in cases where data and specific time conditions are taken into account Need to become;
- - eine rein softwaremäßige Verwaltung, die nur gerin gen Speicherplatz benötigt, nur die des Registers 22, das sehr selten über 10 Kbits liegt;- A purely software management, which requires only a small amount of storage space, only that of register 22 , which is very rarely more than 10 kbits;
- - eine Anpassungsfähigkeit an die verschiedenen bei einer ursprünglichen Anwendung vorhandenen Dienste, sowie eine Anpassungsfähigkeit an mögliche spätere Veränderungen. Es reicht nämlich, das in Fig. 2 dargestellte Programm zu ändern.- adaptability to the various services available in an original application, and adaptability to possible later changes. It is sufficient to change the program shown in FIG. 2.
Wenn der Zufallscharakter geändert werden soll, wie oben erklärt, kann man b den berechneten Rängen hk hinzufü gen. In einer Variante ist es möglich, eine Iteration des Verfahrens über die gefundenen Ränge hk durchzuführen. Bei dieser Iteration können a, b und m die gleichen oder andere sein. Man ordnet dann den vorhergehenden Rängen hk neue Rän ge h1 zu.If the random character is to be changed, as explained above, b can be added to the calculated ranks h k . In a variant, it is possible to iterate the method over the ranks h k found . In this iteration, a, b, and m can be the same or different. The previous ranks h k are then assigned new ranks ge h 1 .
Claims (8)
- - eine Bitkette (X) von n zu übertragenden Bits mit einem ersten Codierer codiert wird (5), um eine erste co dierte Kette (Y2) zu erhalten,
- - Bits der zu übertragenden Bitkette permutiert werden (15), um eine weitere, sogenannte verschachtelte Bitkette (X') zu erhalten,
- - die verschachtelte Kette mit einem zweiten Codierer codiert wird (14), um eine zweite codierte Kette (Y3) zu erhalten,
- - vom Sender zum Empfänger die zu übertragende Bitket te und/oder die erste und/oder die zweite codierte Kette übertragen werden (3),
- - und entsprechend die von der Senderseite übertrage nen Ketten empfangen und decodiert werden, um die zu über tragende Bitkette wiederherzustellen, dadurch gekennzeichnet, daß
- - zur Permutation der Bits der Bitkette von n zu über
tragenden Bits einem Bit des Rangs k der zu übertragenden
Bitkette ein Rang hk in der verschachtelten Kette zugeordnet
wird (21), der von einem Rang hk-1 abhängt, der einem Bit
des Rangs k-1 der zu übertragenden Bitkette zugeordnet ist,
so daß der zugeordnete Rang hk von der Art ist:
hk = a.hk-1 + b, Modulo m, wobei a, b und m ganze Zahlen sind.
- a bit chain (X) of n bits to be transmitted is coded ( 5 ) with a first encoder in order to obtain a first coded chain (Y2),
- Bits of the bit string to be transmitted are permuted ( 15 ) in order to obtain a further, so-called nested bit string (X '),
- the interleaved chain is encoded with a second encoder ( 14 ) in order to obtain a second encoded chain (Y3),
- - The bit chain to be transmitted and / or the first and / or the second coded chain are transmitted from the transmitter to the receiver ( 3 ),
- - And accordingly the chains transmitted by the transmitter side NEN are received and decoded to restore the bit chain to be transmitted, characterized in that
- - For permutation of the bits of the bit chain of n bits to be transmitted, a bit of the rank k of the bit chain to be transferred is assigned a rank h k in the nested chain ( 21 ), which depends on a rank h k-1 which corresponds to a bit of the Ranks k-1 is assigned to the bit string to be transmitted, so that the assigned rank h k is of the type:
h k = ah k-1 + b, modulo m, where a, b and m are integers.
7. The method according to any one of claims 1 to 5, characterized in that the parameters a, b and m are given values corresponding to one of the lines of the following table:
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
FR9815779A FR2787263B1 (en) | 1998-12-14 | 1998-12-14 | TRANSMISSION METHOD WITH EFFICIENT AND MODULAR INTERLOCKING CHANNEL CODING FOR TURBO CODES |
Publications (1)
Publication Number | Publication Date |
---|---|
DE19960269A1 true DE19960269A1 (en) | 2000-06-15 |
Family
ID=9533957
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
DE1999160269 Withdrawn DE19960269A1 (en) | 1998-12-14 | 1999-12-14 | Channel encoding transmission method with effective, modular nesting or interlacing for applying turbo codes, involves using coincidence algorithm. |
Country Status (3)
Country | Link |
---|---|
DE (1) | DE19960269A1 (en) |
FR (1) | FR2787263B1 (en) |
GB (1) | GB2346782B (en) |
Families Citing this family (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2001043310A2 (en) | 1999-12-03 | 2001-06-14 | Broadcom Corporation | Embedded training sequences for carrier acquisition and tracking |
WO2001043384A2 (en) | 1999-12-03 | 2001-06-14 | Broadcom Corporation | Viterbi slicer for turbo codes |
GB2361850B (en) | 2000-04-25 | 2003-12-24 | Ubinetics Ltd | Multiplexing and de-multiplexing |
DE60141982D1 (en) | 2000-09-01 | 2010-06-10 | Broadcom Corp | SATELLITE RECEIVER AND CORRESPONDING METHOD |
US7421044B2 (en) | 2000-09-05 | 2008-09-02 | Broadcom Corporation | Quasi error free (QEF) communication using turbo codes |
US7242726B2 (en) | 2000-09-12 | 2007-07-10 | Broadcom Corporation | Parallel concatenated code with soft-in soft-out interactive turbo decoder |
US6518892B2 (en) | 2000-11-06 | 2003-02-11 | Broadcom Corporation | Stopping criteria for iterative decoding |
JP4265345B2 (en) * | 2003-08-22 | 2009-05-20 | 日本電気株式会社 | Mobile phone, interleave parameter calculation device, method and program |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
FR2706054B1 (en) * | 1993-06-02 | 1995-07-13 | Alcatel Mobile Comm France | Method for interleaving a sequence of data elements, and corresponding interleaving device. |
FR2737363B1 (en) * | 1995-07-27 | 1997-09-05 | France Telecom | INTERLEAVING / DE-INTERLACING DATA ELEMENTS |
US5983384A (en) * | 1997-04-21 | 1999-11-09 | General Electric Company | Turbo-coding with staged data transmission and processing |
-
1998
- 1998-12-14 FR FR9815779A patent/FR2787263B1/en not_active Expired - Fee Related
-
1999
- 1999-12-14 DE DE1999160269 patent/DE19960269A1/en not_active Withdrawn
- 1999-12-14 GB GB9929541A patent/GB2346782B/en not_active Expired - Fee Related
Also Published As
Publication number | Publication date |
---|---|
GB9929541D0 (en) | 2000-02-09 |
FR2787263B1 (en) | 2002-10-25 |
GB2346782A (en) | 2000-08-16 |
GB2346782B (en) | 2004-01-14 |
FR2787263A1 (en) | 2000-06-16 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
DE69215743T2 (en) | Error correction coding method with at least two parallel, systematic convolutional encoders, iterative decoding method, decoding module and decoder therefor | |
DE69026916T2 (en) | Nesting in coded modulation for mobile radio | |
DE60009973T2 (en) | Nesting method, interleaver, turbo coding method and turbo encoder | |
DE3044208C2 (en) | Interpolator for increasing the word speed of a digital signal | |
DE69323020T2 (en) | Decoder for variable length codes | |
DE60020637T2 (en) | Rate adaptation and channel interleaving for a communication system | |
DE69936908T2 (en) | ITERATIVE DECODING OF PRODUCT CODES | |
DE60124488T2 (en) | Interleaver and interleaving method for a UMTS turbo encoder | |
DE69837077T2 (en) | Interleaver for turbo coder | |
DE69907705T2 (en) | NESTLER WITH APPLICATION OF SUB-GROUP DISTRIBUTION | |
DE69722571T2 (en) | System and method for digital transmission with a product code combined with multidimensional modulation | |
DE69905255T2 (en) | IMPROVED NESTLERS FOR TURBO CODES | |
DE3736193C2 (en) | ||
DE60002705T2 (en) | INNER ROW PERMUTATIONS FOR TURBOCODE | |
DE60016561T2 (en) | BLOCK QUARTERING FOR TURBO CODING | |
DE69418860T2 (en) | Method and device for block interleaving and deinterleaving | |
DE19960269A1 (en) | Channel encoding transmission method with effective, modular nesting or interlacing for applying turbo codes, involves using coincidence algorithm. | |
DE60104338T2 (en) | DEVICE AND METHOD FOR TURBO DECODING WITH SIGNATURE DATA COMPARISON AS ABORT CRITERION | |
DE1803222B2 (en) | PROCEDURE FOR SUMMARIZING PULSE-CODED MESSAGES | |
DE3810916C2 (en) | Delta pulse code modulation | |
DE69910965T2 (en) | PROCESS AND DEVICE FOR PROTECTION AGAINST ERRORS | |
DE60319557T2 (en) | Method for reducing the number of bits per soft bit | |
DE60311997T2 (en) | First interleaving method for a transmitter with two interleavers | |
EP1430614B1 (en) | Method and device for determining the initialization states in pseudo-noise sequences | |
DE60014395T2 (en) | PROCESS AND DEVICE FOR CODING WITH AT LEAST TWO PARALLEL CODERS |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
8110 | Request for examination paragraph 44 | ||
8139 | Disposal/non-payment of the annual fee |