The present invention concerns the communication systems in which, in order to improve the fidelity of the transmission, the data to be transmitted are subjected to a channel coding. It concerns more particularly a “turbocoding” method, as well as the devices and apparatus intended to implement this method.
It will be recalled that so-called “channel” coding consists, when the “code words” sent to the receiver are formed, of introducing a certain degree of redundancy in the data to be transmitted. At the receiver, the associated decoding method then judiciously uses this redundancy to detect any transmission errors and if possible to correct them. More precisely, the “Hamming distance” between two binary sequences of the same length is defined as the number of locations where the two sequences have a different binary element. The code words obey certain rules defined by the coding method in question, which enables the receiver to replace the word received with the “legal” code word situated at the shortest Hamming distance from this received word.
It is clear that this error correction procedure is more reliable, the greater the minimum Hamming distance between the various code words. It will be noted that the distance between a given code word and the “null” code word (the one where all the binary elements are zero) is equal to the number of binary elements equal to 1, called the “binary weight”, of this given code word. It is deduced from this that, all other things being equal, the higher the minimum value of the binary weight of the code words (excluding the null word), the better the coding method. For more details, reference should be made for example to the book “Computer Networks” by A. Tannenbaum, 3rd edition, Prentice-Hall International, New Jersey, 1996, page 184.
In particular, the coding methods known as “cyclic redundancy codes” are known. In each of them, the choice has been made of a polynomial g(x), referred to as the “generator polynomial”, with binary coefficients, of degree d and with a constant term equal to 1. Each sequence of information to be transmitted is, possibly by extending it with zero elements, put in the form of a binary sequence u having a fixed length k. Then a sequence a is formed by extending the sequence u by means of a number of bits equal to d, these so-called padding bits being chosen so that the polynomial
associated with a is divisible by g(x) (modulo 2). It is the sequences a (of length p=k+d) which are sent to the receiver. The transmission errors are then detected by examining the remainder of the division of the code word received by the generator polynomial (see for example A. Tannenbaum, op. cit., pages 187–188).
Recently very effective coding methods have been proposed, known as “turbocodes”, in which the redundancy is increased by transmitting, for each sequence u of initial data, not just one but three binary sequences a, b and c, obtained as explained below. The turbocodes form part of so-called “convolutional” codes, that is to say codes in which each bit entering a coder is combined with other bits temporarily recorded in this coder, these temporarily recorded bits having been produced by the processing, in the coder, of the previous incoming bits; because of this, the result of the coding of a sequence entering a convolutional coder depends in general on the sequences previously processed.
The sequence b which has just been mentioned is obtained by means of a device which will be referred to as the “first coder”, normally on the basis of the polynomial representation
b(x)=a(x)·f1(x)/g(x),
where a(x) is the polynomial associated with the sequence a, g(x) a first predetermined polynomial with binary coefficients of degree d and with a constant term equal to 1, and f1(x) a second predetermined polynomial with binary coefficients without a common divisor with g(x). The polynomial g(x) is called the “recursion polynomial” because of its appearance at the denominator of the above expression.
As for the sequence a, it can be taken to be identical to u, but is often obtained, as in the “cyclic redundancy codes”, by extending the sequence u by means of padding bits chosen so that a(x) is divisible by g(x). This is because, as is known to experts, this divisibility is a necessary condition for guaranteeing the same quality of decoding for the last bits in each sequence as for the other bits.
The sequence c, finally, is obtained by means of a device which will be called the “second coder”, normally on the basis of the polynomial representation
c(x)=a*(x)·f2(x)/g*(x),
where g*(x) is a third predetermined polynomial with binary coefficients of degree d and with a constant term equal to 1, where f2(x) is a fourth predetermined polynomial with binary coefficients, without a common divisor with g*(x), and where the polynomial a*(x) represents a binary sequence a* which results in a predetermined manner from a permutation of the binary elements of u or a (an operation known as “interleaving”).
The “turbodecoding” of the message transmitted functions in the following manner: the decoder receives three sequences of numbers, denoted a′, b′ and c′, which have been produced by the action of the noise of the transmission channel on the transmitted sequences a, b and c. The turbodecoder then uses an iterative process (using b′ and c′ in alternation) intended to calculate an estimated value â of a with a reliability which increases with the number of iterations chosen. If padding bits have been chosen, it is obviously sufficient, once the final value of â has been obtained, to eliminate the last d bits therefrom in order to obtain the estimated value û of u.
The comments given above concerning the utility of the divisibility of the polynomials a(x) by the polynomial g(x) at the first coder also apply to the second coder, for which there is posed the problem of the divisibility of the polynomials a*(x) by the recursion polynomial g*(x), this problem having to be resolved in the context where each of these polynomials a*(x) comes from a polynomial a(x) divisible by g(x). A known solution consists, firstly, of permuting in a predetermined manner the binary elements of u in order to obtain a sequence u*, and, secondly, forming a* by extending u* by means of d padding bits so that a*(x) is divisible by g*(x) (then g*(x) will preferably be chosen so as to be identical to g(x) for reasons of simplicity); however, such a turbocoding method has the drawback that the efficacy of the turbodecoding is not ideal because of the fact that a and a* contain sets of padding bits chosen independently of each other; the result is a certain loss of reliability (measured in terms of error rates) in the transmission.
The patent application EP 0 928 071, in the name of Canon, resolves this tricky problem by means of interleavers in which the sequence a* is obtained directly by permutation of the binary elements of a. More precisely, a* has been represented by the polynomial
where π(i) belongs to a certain class of permutations of the integers i lying between 0 and (p−1); for each of these interleavers, it is always possible to find a polynomial g*(x) such that, whatever the polynomial a(x) divisible by g(x), the polynomial a*(x) is also divisible by g*(x). Thus, once the sequence a has been formed, additional padding bits do not have to be added to obtain a*.
In addition to a high minimum distance, a second quality sought for a coding method is obviously its simplicity of implementation, that is to say the simplicity of the algorithm employed, with regard to both the coding and the associated decoding.
To this end, the document EP 0 928 071 mentioned above presents a particular example of permutation belonging to said class of permutations preserving divisibility: there the residue modulo p of the product (i·e), where e is a predetermined strictly positive integer number, relatively prime with p and congruent with a power of 2 modulo p, is taken for π(i); as a result g*(x) is simply equal to g(x).
This interleaver, which has the merit of simplicity, does however have the drawback of requiring that the length p of the sequences a and a* be an odd multiple of the period of the recursion polynomial (the period of a polynomial g(x) is defined as being the smallest positive integer N such that said polynomial g(x) divides (xN+1) modulo 2; for other properties already known of the said period, it is possible to consult the classic work by F. J. McWilliams and N. J. A. Sloane entitled “The Theory of Error-Correcting Codes”, published by North-Holland in 1977, the seventh edition of which appeared in 1992).
To allow a greater choice in the length of said sequences whilst preserving the advantages offered by the interleavers according to EP 0 928 071, the invention proposes a turbocoding method for the transmission of information in which, a first polynomial with binary coefficients g(x) of degree d and with a constant term equal to 1 having been predetermined, first of all said information is presented in the form of binary sequences u of length
k=p−d,
where p is a predetermined multiple of the period N of the polynomial g(x), and then, for each of said sequences u, there is produced a triplet v of binary sequences (a, b, c) intended to be transmitted and obtained as follows:
Correlatively, the invention concerns a turbodecoding method, said method being remarkable in that it makes it possible to decode received sequences which have been transmitted after having been coded by means of a turbocoding method according to the invention.
Thus the turbocoding methods according to the invention, although not requiring any additional padding bits for obtaining the “interleaved” sequence a*, are applicable to a wide range of lengths p of transmitted sequences (since M=p/N can be even or odd), whilst remaining relatively simple to implement.
In addition, the turbocoding methods according to the present invention, whilst fitting within the general context of permutations disclosed by EP 0 928 071, enable an expert to have access, where he chooses M odd, to a greater reservoir of values of the number e amongst which it is possible to choose an optimum value e*, by comparison with the particular example of permutation disclosed by EP 0 928 071 and mentioned above.
This is because this particular example of permutation already offers a fairly wide set of possible values for e, defined (amongst other criteria) by the fact that each number e in this set is congruent with a power of 2 modulo p. However, subsequent researches have enabled the inventor to have access to an additional reservoir of values of e defining, here too, permutations preserving divisibility: it is a case (amongst other criteria) of the integers congruent with a power of 2 modulo N which are not congruent with a power of 2 modulo p. Not only the new values of e thus revealed allow a practical implementation of a turbocoding with the same advantages as a turbocoding according to the example disclosed by EP 0 928 071, but also an expert will be able, according to the concrete conditions of implementation, to seek said optimum value e* both in the values of the known set and in the values of the additional reservoir supplied by the present invention.
It is notably desirable to use a code with a large minimum distance (as explained in the introduction, the minimum distance of the code fulfils an important role in the suitability of the code for detecting and correcting transmission errors). For this purpose, the same procedure will be followed for determining an optimum value e* of e:
a) a certain number of different sequences u are chosen to form what will be referred to as the “representative set”,
b) for each strictly positive integer number e less than p, congruent with a power of 2 modulo N and relatively prime with p:
c) in order to implement the coding, the value e* of e which is associated with the largest value of this minimum weight w is chosen.
By virtue of these provisions, the codes according to the invention benefit from a relatively high minimum weight, whatever said predetermined polynomials chosen.
According to another of its aspects, the invention concerns various devices.
It thus concerns a device for coding sequences of data intended to be transmitted by means of a turbocoding method according to the invention, said device being remarkable in that it has:
Correlatively, the invention concerns a decoding device intended to implement a turbodecoding method according to the invention, said device being remarkable in that it has:
The present invention also relates to:
The advantages offered by these devices, digital signal processing apparatus, telecommunications network, data storage means and computer programs are essentially the same as those offered by the methods according to the invention.
Other aspects and advantages of the invention will emerge from a reading of the detailed description, which will be found below, of a preferred embodiment given by way of non-limitative example. This description refers to the accompanying drawings, in which:
a depicts schematically the conventional functioning of the first coder,
b depicts schematically the conventional functioning of the second coder,
To commence, an explanation will be given, by means of numerical examples, of the mathematical principles on which the invention is based.
Take for example the polynomial
g(x)=1+x+x3,
of degree d=3, as the recursion polynomial. It divides (x7+1) (the quotient being (1+x+x2+x4)), but does not divide (xN+1) for N between 1 and 6: the period of this polynomial g(x) is therefore equal to 7.
Take now for example a length of transmitted sequences equal to
p=14, i.e.: M=p/N=2.
To find the possible values of e, there are sought first of all the integers congruent with a power of 2 modulo 7 (N being equal to 7), that is to say congruent with 1, 2 or 4, being limited to the values below 14. (p being equal to 14), which are the only useful values since the different permutations are distinguished by the residues of (i·e) modulo 14; the corresponding values are: 1, 2, 4, 8, 9, and 11. Finally, by eliminating the values 2, 4 and 8, which each have a common divisor with 14 (and which would not give rise, consequently, to a permutation of the 14 indices concerned), it is found that, for this example, the “useful” values of e are 1, 9 and 11.
The example which we have just studied includes a length of sequences which is an even multiple of N, a length incompatible with the methods according to EP 0 928 071. It will now be shown, on the basis of a second example, that the present invention is advantageous compared with this prior art, even in the case where M is odd. Consider therefore, with the same g(x) as above, the case p=63 (i.e.: M=9). It is easily found that the integers e congruent with a power of 2 modulo 63 (and therefore also congruent with a power of 2 modulo 7) which are “useful”, are:
e=1, 2, 4, 8, 16, 32.
However, the present invention makes it possible to choose e also from amongst the values:
e=11, 22, 23, 25, 29, 37, 43, 44, 46, 50, 53, 58
corresponding to the integers congruent with a power of 2 modulo 7, but not congruent with a power of 2 modulo 63.
Construct now a permutation according to the invention, for example in the case, studied above, where p=14 and e=9. Taking the residues of (9i) modulo 14 for i between 0 and 13, the following are easily found:
a*0=a0, a*1=a11, a*2=a8, a*3=a5, a*4=a2, a*5=a13, a*6=a10, a*7=a7, a*8=a4, a*9=a1, a*10=a12, a*11=a9, a*12=a6, et a*13=a3. (1)
Examine the effect of this permutation on any sequence of data, for example:
u=(1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0).
By extending u with the 3 (d being equal to 3) bits (1, 0, 1), there is obtained
a=(1, 0, 0,1, 0, 0, 0, 1, 0, 0, 0,1, 0, 1), that is to say
a(x)=1+x3+x7+x11+x13,
which is indeed divisible by g(x) (the quotient being equal to (1+x+x2+x3+x5+x7+x10)). Using equation (1), there is then obtained the sequence a* represented by the polynomial
a*(x)=1+x+x5+x7+x13,
which is indeed divisible by g(x) (the quotient being equal to (1+x3+x4+x6+x7+x8+x10)), in accordance with the aim sought by the invention.
It can be shown that, whatever the permutation according to the invention, the appropriate polynomial g*(x) is none other than g(x).
It can thus be seen that the choice first of all of g(x), and then of p, leads, by applying the above rules, to a set “E” of “useful” values of e. All that remains then is to choose the polynomials f1(x) and f2(x), and to fix a value of e which is as effective as possible in terms of residual error rate after decoding, in order to obtain a particular turbocoding method according to the invention.
In general terms, the procedure leading to the selection of a method according to an embodiment of the invention will preferably comprise the following steps, described with reference to
It will be recalled that a conventional turbocoder consists of two recursive systematic convolutional (RSC) coders, and an interleaver, disposed as shown in
In the preferred embodiment, the signal transporting the sequence of data u supplies a padding module 30. This module 30 is responsible for extending the sequence u by means of padding bits, as explained below, so as to obtain a sequence a whose length p is a multiple of the period N of the polynomial g(x), and where the associated polynomial a(x) is divisible by g(x). The resulting signal then supplies the turbocoder 40. The latter has an interleaver π1 according to the invention, that is to say one producing, from the sequence a, a permutation a* divisible by g(x).
The consequence of the methods according to this embodiment of the invention is thus that the final state of each coder (that is to say at the end of the coding of any sequence) is identical to its initial state (at the start of the coding of said sequence), which guarantees a uniform decoding quality for all the bits in the same sequence. The said states of the coders are depicted in
a is an operating diagram of the first RSC coder (the one producing a sequence b from a sequence a), in the case where, for example,
f1(x)=1+x2+x3, and
g(x)=1+x+x3
are taken.
This coder carries three bits s1, s2, and s3 in memory.
b is an operating diagram of the second RSC coder (the one producing a sequence c from a sequence a* ), in the case where, for example,
f2(x)=1+x+x2+x3, and
g*(x)=1+x+x3
are taken.
This coder carries three bits s*1, s*2, and s*3 in memory.
These two RSC coders are illustrated in
Finally, the turbocoder 40 sends the three data sequences a, b, and c thus obtained to the transmitter 906 (see
For more details on turbocodes, reference can usefully be made to:
The coding device 901 has, connected together by an address and data bus 902:
Each of the elements illustrated in
The random access memory 904 stores data, variables and intermediate processing results, in memory registers bearing, in the description, the same names as the data whose values they store. It should be noted, in passing, that the word “register” designates, throughout the present description, both a memory area of low capacity (a few binary data) and a memory area of large capacity (making it possible to store an entire program) within a random access or read only memory.
The random access memory 904 contains notably the following registers:
The read only memory 905 is adapted to store, in registers which, for convenience, have the same names as the data which they store:
A conventional turbodecoder also requires a looping back of the output of the deinterleaver π2 onto the input of the first decoder in order to transmit to the first decoder the so-called “extrinsic” information produced by the second decoder.
The turbodecoder 300 receives the coded sequences a′, b′ and c′ coming from a receiver 1106 (see
The block diagram in
The decoding device 1101 has, connected together by an address and data bus 1102:
Each of the elements illustrated in
The random access memory 1104 stores data, variables and intermediate processing results, in memory registers bearing, in the description, the same names as the data whose values they store. The random access memory 1104 contains notably the following registers:
The read only memory 1105 is adapted to store, in registers which, for convenience, have the same names as the data which they store:
It should be noted that, in certain applications, it will be convenient to use the same computer device (functioning in multi-task mode) for the transmission and reception of signals according to the invention; in this case, the units 901 and 1101 will be physically identical.
The methods according to the invention can be implemented within a telecommunications network, as shown in
The base station SB and each peripheral station SPi can comprise a coding device 901 as described with reference to
The base station SB and each peripheral station SPi according to the invention can also comprise a decoding device 1101 as described with reference to
The base station SB and the peripheral stations SPi can comprise in addition, according to requirements, a digital camera, a computer, a printer, a server, a facsimile machine, a scanner or a digital photographic apparatus.
To end, the results of a coding and decoding simulation according to the invention are presented below. It was first of all sought to obtain the value of e offering to the associated code the greatest minimum distance possible, in this case, which may be useful in practice, where
g(x)=1+x2+x3, f1(x)=1+x+x3, f2(x)=1+x+x2+x3, and p=224 (M=32).
wr (e) designates the minimum weight for all the coded sequences v=(a, b, c) associated with the sequences a of weight r and such that a(x) is divisible by g(x). The values of wr (e) for r=2 and for r=3 have been calculated for each “useful” value of e. These results are given in Table 1.
It can be considered that the value e=71, for which w2=38 and w3=28, is optimum.
The performance of this turbocode on a white Gaussian noise channel was then simulated, for the optimum value of e. The results have been expressed in terms of residual error probability, per frame (Frame Error Ratio FER) on the one hand, and per bit (Bit Error Ratio BER) on the other hand, according to the signal to noise ratio (SNR) per information bit on the channel. They are depicted in
To implement this simulation, several values of SNR between 0.8 and 2.8 dB were studied. For each of these values of SNR, a certain number of sequences u were generated randomly and, for each of these sequences, the corresponding coded sequence v=(a, b, c) according to the present invention was calculated. On each “noisy” sequence (a′, b′, c′) resulting therefrom, double decoding iterations were performed, 8 in number at least and 50 at most. After the 8 first iterations, the simulation was interrupted as soon as two consecutive (double) iterations gave the same result.
In order to “experimentally” derive the probable value of the minimum distance of the code, the following procedure was carried out. When the decoding was interrupted before the 50th iteration, and when the “estimated” sequence â was not identical to the sequence a from which it came, their binary difference, or “error sequence” d=a+â, was calculated; then the corresponding coded sequence v=(d, b(d), c(d)) was calculated according to the present invention; finally, the binary weight PB of this coded sequence v was calculated and this value of PB associated with an erroneous estimation was recorded. This procedure was repeated with as many sequences u as proved necessary to obtain 25 erroneous sequences â for each studied value of the signal to noise ratio SNR.
Once the simulation was complete, it was found that none of these sequences v associated with an erroneous estimation had a weight PB less than 28. As is known to experts, this result, combined with the relatively high value of SNR achieved (as can be seen according to the shape of the graphs illustrated in
Number | Date | Country | Kind |
---|---|---|---|
00 12939 | Oct 2000 | FR | national |
Number | Name | Date | Kind |
---|---|---|---|
5905739 | Piret et al. | May 1999 | A |
6370670 | Le Dantec et al. | Apr 2002 | B1 |
6543021 | Piret | Apr 2003 | B1 |
6560362 | Piret et al. | May 2003 | B1 |
6578170 | Piret et al. | Jun 2003 | B1 |
6578171 | Braneci et al. | Jun 2003 | B1 |
6625762 | Le Dantec | Sep 2003 | B1 |
6638318 | Piret et al. | Oct 2003 | B1 |
6766489 | Piret et al. | Jul 2004 | B1 |
20040117719 | Piret | Jun 2004 | A1 |
Number | Date | Country |
---|---|---|
0928071 | Jul 1999 | EP |
Number | Date | Country | |
---|---|---|---|
20020099997 A1 | Jul 2002 | US |