The present invention relates to an encoding apparatus, and more specifically to an error-correcting encoding apparatus.
Encoding technology is widely utilized in various fields. For example, in transmitting data, a source apparatus encodes data to be transmitted and sends the encoded data through a communications path so that a destination apparatus receives and decodes the encoded data. When data is stored in a storage device, it is encoded and written to a disk, etc. The encoded data is then decoded after being read from the disk. Encoding normally refers to converting a data sequence from an information source into a different data sequence, and thus the new data sequence obtained by the conversion is referred to as a code.
When encoded data is transmitted, an error may occur in the transmission path. An error may also occur when the encoded data is read for reproduction from a storage device that stores the encoded data. To detect an occurrence of such an error, or to correct such an error, an error-correcting code is frequently used.
A convolutional code is known as one type of error-correcting code. Each time n-bits of data is input for processing a convolutional code. Data of m (m>n) bits is then determined depending on the n-bit data and s-bit data, which is input immediately before the n-bit data is output. Thus, in processing the convolutional code, data of (m−n) bits is added for error correction to the data to be transmitted. As a result, the redundancy of the data is increased, thereby reducing the decoding error rate when the data is decoded.
The ratio of the amount of data to be transmitted (number of bits of source data) to the amount of data obtained by the encoding process (number of bits of output data) is commonly referred to as an encoding rate (or an information rate) R, and is represented by the following equation.
R=n/m
The encoding rate R is always lower than 1 in an error-correcting code. Generally, the encoding rate R is one of the parameters for determining the error correction capability. For example, the lower the encoding rate R is, the higher the error correction capability becomes.
The error-correcting encoding apparatus 500 generates, for source data d, a data sequence x and parity data sequences y1,y2 for correcting the data sequence x. The data sequence x and the parity data sequences y1,y2 are then multiplexed and output. This output is the encoded data of the source data d. Described below is the operation performed when N-bits of source data d is encoded.
The source data d is output as the data sequence x as is, and is also transmitted to the convolution unit 501 and an interleaver 503. The convolution unit 501 performs a convolutional encoding process on the source data d and outputs the parity data sequence y1. The interleaver 503 temporarily stores the source data d and, then reads and outputs the stored source data in an order different from the input order. Thus, the source data d is randomized. The output from the interleaver 503 is then provided to the convolution unit 502. The convolution unit 502 also performs a convolutional encoding process on the output from the interleaver 503, and outputs the parity data sequence y2.
In the above described operations, the error-correcting encoding apparatus 500 generates an N-bit data sequence x, an N-bit parity data sequence y1, and an n-bit parity data sequence y2 for N-bits of source data d. The data sequence x and parity data sequences y1,y2 are, for example, multiplexed for each bit and output as the encoded data. Therefore, in this case, the error-correcting encoding apparatus 500 outputs 3×N bits of data for every N-bits input. As a result, the encoding rate R is ⅓.
The selection unit 511 alternately selects one bit from the outputs of the convolution units 501, 502. Table 1 shows the output sequence Z produced by the selection unit 511. In Table 1, y1(i) indicates the output from the convolutional unit 501 corresponding to the i-th data element of the source data d, and y2 (i) indicates the output from the convolution unit 502 corresponding to the i-th data element of the source data d When N-bits of source data d is input to the error-correcting encoding apparatus 510, the selection unit 511 outputs a N-bit output sequence Z (y1(1), y2(2), y1(3), y2(4), . . . , y1(N−1), y2(N)).
The puncturing operation performed by the selection unit 511 is represented by the following equation.
The output sequence Z is obtained by multiplying the data matrix D by the puncturing matrix P. For example, for the i-th data element of the source data d, y1(i) is obtained by multiplying the first row of the data matrix D by the first column of the puncturing matrix P. For the (i+1) the data element of the source data d, y1(i+1) is obtained by multiplying the second row of the data matrix D by the second column of the puncturing matrix P. Therefore, the operation of the selection unit 511 for alternately selecting the outputs of the convolution units 501, 502 bit by bit is represented as an operation of repeatedly performing the above described arithmetic operations.
With the above described configuration, the error-correcting encoding apparatus 510 generates an N-bit data sequence x and an N-bit parity data sequence Z for N-bits of source data d. The data sequence x and the parity data sequence Z are multiplexed bit by bit, and then output as encoded data. Since the error-correcting, encoding apparatus 510 outputs 2N bits of data for every N-bits input, the encoding rate R is ½.
U.S. Pat. No. 5,446,747 discloses in detail the above described error-correcting encoding apparatus shown in
In mobile terminal communications systems, it is required to optionally set the data length M of an output sequence from an encoding apparatus in relation to the data length N (number of bits) of source data d. For example, voice data, etc. is normally divided into data having a predetermined data length, and is then transmitted after being stored in a frame having a predetermined data length. Thus, when encoded data is processed in a mobile terminal communications system, voice data, etc. is divided into data having a predetermined data length, encoded and then stored in a frame.
However, the encoding rate R of the conventional error-correcting encoding apparatus shown in
Thus, the encoding rate of the conventional error-correcting encoding apparatus having a plurality of convolution units provided in parallel with each other cannot be set to a desired value. Therefore, the source data is encoded and stored in a predetermined frame with poor efficiency.
An object of the present invention is to obtain a desired encoding rate in an error-correcting encoding apparatus provided with a plurality of convolution units mounted in parallel with each other.
These and other objects are met by an error-correcting encoding apparatus according to the present invention that includes a plurality of convolution units mounted in parallel with each other. A randomization unit is also included for randomizing the source data so that different data sequences are provided for the plurality of convolution units. A selection unit that selects a data element in the output from a corresponding convolution unit according to selection information. The selection information indicates whether or not a data element in each output of the plurality of convolution units is to be selected, and has a data length equal to the data length of each output from the plurality of convolution units. Further, an output unit is included that outputs the source data and a data element selected by the selection unit.
In this configuration, each convolution unit generates a data element for correction of the source data. The selection unit outputs a data element according to the selection information from the data elements generated by the plurality of convolution units. As a result, the number of bits of the encoded data output of the output unit depends on the above described selection information. Therefore, a desired encoding rate can be obtained according to the selection information.
The error-correcting encoding apparatus according to another embodiment of the present invention includes a duplication unit that duplicates a predetermined number of data elements in the source data according to a requested encoding rate. Further, an encoding circuit is provided with a plurality of convolution units connected in parallel with each other, for encoding the source data.
In the above described configuration, the ratio of the data length of the source data to the data length of the output data from the encoding circuit is altered by changing the time the data elements are duplicated. Thus, the encoding rate is changed. If the data elements are duplicated, the decoding characteristic is improved.
Another error-correcting encoding apparatus according to the present invention includes an insertion unit for inserting a predetermined number of dummy bits into the source data according to the requested encoding rate. Further, an encoding circuit is provided with a plurality of convolution circuits mounted in parallel with each other, for encoding the source data into which the dummy bits are inserted by the insertion unit.
In the above described configuration, the ratio of the data length of the source data to the data length of the output data from the encoding circuit is altered. When a predetermined dummy bit (for example, 1) is inserted, a decoding characteristic is improved.
The error-correcting encoding apparatus according to the present invention is applicable to various fields, for example, a communication system and a data storage device.
A wireless signal transmitted from the base station 10 is received by a receiver 21 of the mobile station 20, demodulated by a demodulator 22, and decoded by a decoder 23. The base station 10 includes a receiver 14 for receiving a signal transmitted from the mobile station 20, a demodulator 15 for demodulating the received signal and a decoder 16 for decoding the demodulated data. The mobile station 20 encodes data (data B) to be transmitted to the base station 10 using an encoder 24, modulates the encoded data using a modulator 25, and transmits the modulated data through a transmitter 26.
In the above described communication system, the error-correcting encoding apparatus according to the present invention corresponds to the encoder 11 in the base station 10 or the encoder 24 in the mobile station 20.
In the above described storage medium, the error-correcting encoding apparatus according to the present embodiment corresponds to the encoder 31.
The error-correcting encoding apparatus 40 according to the present invention encodes source data u using a systematic code. In a systematic code, data to be transmitted is separated from the data for correcting errors (hereinafter referred to as “parity data”) when it is generated during the transmission of the data. Thus, when the error-correcting encoding apparatus 40 receives source data u, it adds parity data Zk to the source data u and then transmits the encoded data. The error-correcting encoding apparatus 40 encodes N-bits of source data u. The error-correcting encoding apparatus 40 outputs the source data u as a data sequence Xk and the parity data as a parity data sequence Zk.
An input I/F unit 41 provides the received source data u to a multiplexing unit 47, a first convolution unit 43, and an interleaver 42. The source data u provided from the input I/F unit 41 to the multiplexing unit 47 is referred to as data sequence Xk.
The interleaver 42 randomizes the input source data u. The interleaver 42 contains memory for temporarily storing N-bits of source data u. The N-bits of source data u is written bit by bit to the memory. The data written to the memory is read out bit by bit in an order different from the order in which the data is written to the memory, thereby randomizing the source data u.
The interleaver 42 provides different and independent data sequences for the convolution units 43 and 44. Thus, although an interleaver is provided only before a second convolution unit 44 in
The first convolution unit 43 performs a convoluting process on the input source data u. The second convolution unit 44 performs a convoluting process on the source data u randomized by the interleaver 42. The first convolution unit 43 and the second convolution unit 44 may have the same or different configurations. In the following explanation, it is assumed that the two convolution units 43 and 44 have the same configuration.
The first convolution unit 43 contains a plurality of memory units M connected in series with each other and one or more adders. Each memory unit M is, for example, a flip-flop, and stores 1-bit of data. The memory units M being serially connected to each other form part of a shift register. An adder can be, for example, an exclusive OR operation unit, a mod 2 adder, etc. With the configuration shown in
Each time the first convolution unit 43 receives a data element of the source data u, it outputs a data element of the parity data sequence Y1k corresponding to the received data element. The data element of the parity data sequence Y1k is obtained as the sum of the data element newly input to the first convolution unit 43 and the data element stored in the memory M when the data element is input. Therefore, in this convoluting process, the data element corresponding to the newly input data element is generated and then output based on one or more previously input data elements and the newly input data element.
An initial value of “0” is set in each memory unit M of the first convolution unit 43. When a N-bit data sequence is input, the first convolution unit 43 outputs an N-bit parity data sequence, and then outputs a tail bit. The data length of the tail bit is, for example, equal to the number of the memory units M. In this example, it is 2.
The configuration and operation of the second convolution unit 44 are basically the same as those of the above-described first convolution unit 43. However, the second convolution unit 44 performs a convoluting process on the source data u randomized by the interleaver 42 to generate a parity data sequence Y2k. Since a convoluting process is conventional technology, and is well known to one of ordinary skill of the art, the detailed explanation is omitted here.
A first puncturing unit 45 selects each data elements of the parity data sequence Y1k generated by the first convolution unit 43 according to a predetermined pattern, and outputs a parity data sequence Z1k. Similarly, a second puncturing unit 46 selects data elements of the parity data sequence Y2k generated by the second convolution unit 44 according to a predetermined pattern, and outputs a parity data sequence Z2k. The feature of the error-correcting encoding apparatus 40 shown in
The multiplexing unit 47 multiplexes the data sequence Xk received from the input I/F unit 41, the parity data sequence Z1k received from the first puncturing unit 45, and the parity data sequence Z2k received from the second puncturing unit 46 to output the output sequence C. The output sequence C from the multiplexing unit 47 includes encoded data for the source data u. The multiplexing unit 47 has the function of adjusting the timing of the three input data sequences. Thus, when each data element of the source data u (data sequence Xk) is output, each data element of the parity data sequence Z1k and Z2k that corresponds to the data element of the source data u is output related to the data element of the source data.
Thus, when the source data u is input, the error-correcting encoding apparatus 40 adds the parity data sequences Z1k and Z2k for error correction to the data sequence Xk, which is the same data sequence as the source data u, and outputs the result.
Described below are the operations and the configurations of the first puncturing unit 45 and the second puncturing unit 46. In this case, it is assumed that the data length of the source data u is N bits and the data length of the output sequence C is M bits. Thus, the error-correcting encoding apparatus 40 has an encoding rate=N/M. The data lengths of the source data u and the output sequence C are, for example, determined by the specification of a communication. Especially, the data length of the output sequence C is determined by the format of the frame transmitted in the communication system.
When the first convolution unit 43 receives the source data u, it outputs the parity data sequence Y1k, and then outputs a tail bit. However, the puncturing process is not performed on the tail bit. That is, the tail bit is transmitted to the multiplexing unit 47 without being input to the puncturing unit.
In
The second puncturing unit 46 is basically the same as the first puncturing unit 45. The puncturing table provided in the second puncturing unit 46 is basically the same puncturing table provided in the second puncturing unit 46. However, the selection information included in these two tables may be the same or different.
The CPU 52 and the memory 53 shown in
Further, the puncturing table is stored in the RAM area of the memory 53. Thus, selection information can be altered as necessary, enabling a desired encoding rate to be obtained. Furthermore, the data length of the selection information can be altered depending on the data length of source data or the data length of an output sequence from a convolution unit.
Described below is a method of generating a puncturing table (that is, the method of venerating selection information). It is assumed in the following description, that the data length of the source data u is N bits and the data length of the output sequence C is M bits. In this case, the encoding rate of R=N/M is requested. Since the data lengths of the tail bits respectively generated by the first convolution unit 43 and the second convolution unit 44 are much shorter than the data length of the source data u, such bits are ignored in the following description.
When the data length of the source data u is N-bits, the data lengths of the data sequence Xk, the parity data sequence Y1k generated by the first convolution unit 43 and the parity data sequence Y2k generated by the second convolution unit 44 are also N-bits. Therefore, to set the data length of the output sequence C to M bits, the following equation is true when the data lengths of the parity data sequence Z1k and Z2k respectively are K1 and K2.
N+K1+K2=M
The following equation is obtained if K1=K2=K.
K=(M−N)/2
(where M>N, N>K)
In this case, the first puncturing unit 45 selects K data elements from the parity data sequence Y1k comprising N data elements and outputs the selected bits as the parity data sequence Z1k. Similarly, the second puncturing unit 46 selects K data elements from the parity data sequence Y2k comprising N data elements, and outputs the selected bits as the parity data sequence Z2k.
The puncturing table is used when K data elements are selected from N data elements. The selection information stored in the puncturing table indicates whether or not each data element of an input sequence is selected, as described above. Therefore, to select K data elements, K bits in the N-bit selection information is assigned 1 (select), and the other bits are assigned 0 (not select). Described below is a practical example of the method of assigning “1” to K bits of the N bits.
A plurality of seed sequences k/n are generated. The k/n is an n-bit sequence to which k 1's are equally assigned (k=1, 2, 3, . . . ; n=1, 2, 3, . . . ; and n>k). For example, a seed sequence is generated with 10 defined as the maximum value of n, and 9 defined as the maximum value of k. A part of a seed sequence is shown below, where “0” is assigned to the leading bit of each seed sequence.
The optimum seed sequence is selected. Practically, k/n is determined in a way that the minimum value of r can be obtained by the following equation under the condition of K/N≧k/n.
For example, when the data length N of the source data u is 300 elements, and 155 data elements are selected from 300 data elements in the puncturing process, ½ is obtained as k/n by substituting 155/300 for K/N. In this case, r=0.01666 is also obtained.
A base pattern of selection information to be written to the puncturing table is generated used the seed sequence selected above. Practically, a base pattern having the data length of N is generated by repeating the selected seed sequence. For example, when a seed sequence of k/n=½ is selected, a 300-bit base pattern is obtained by repeating the seed sequence (01) as described in the example above.
Selection information is obtained by amending a base pattern. Practically, A=r N is first computed. Then, in the base pattern described above, the number of “0” corresponding to A are evenly selected and replaced with 1's. The leading bit of the base pattern is not replaced. For example, since A=0.166×300=5 is obtained in the example above, five 0's are replaced with 1's in the base pattern (01010101 . . . 0101).
The pattern obtained in the above-described process is stored in the puncturing table as selection information (puncturing pattern information).
The puncturing tables provided in the first puncturing unit 45 and the second puncturing unit 46 are the same as each other in one embodiment of the present invention. However, the two tables do not have to be always the same as each other. However, it is preferred that the numbers of 1's contained in the selection information stored in the two tables are equal or very close to each other. When the numbers of 1's contained in the selection information are quite different from each other, a poor decoding characteristic may be obtained.
The leading bit of the selection information is set to 0 for the following reason. That is, the leading bit of the selection information indicates whether or not the leading data element of the parity data sequence Y1k generated by the first convolution unit 43 (or the parity data sequence Y2k generated by the second convolution unit 44) is to be selected. The leading data element of the parity data sequence Y1k is generated in the first convolution unit 43 by adding the leading data element of the source data u to the initial value stored in the memory M shown in
Therefore, according to the present invention, the error correcting capability is improved in the decoding process by assigning 1 to the selection information to select a data element other than the leading data element.
Described below is the puncturing process performed using a puncturing table. The first puncturing unit 45 refers to a puncturing table each time it receives a data element of the parity data sequence Y1k, and determines whether or not the data element is to be selected. The selected data element is transmitted to the multiplexing unit 47 as a parity data sequence Z1k. On the other hand, when a data element is not selected, it is discarded without being transmitted to the multiplexing unit 47. This process is the same as the process in the second puncturing unit 46.
In step S1, a data element is obtained from the latch circuit 51. In step S2, the counter for counting the order, in the parity data sequence Yk, of the data element written to the latch circuit 51 is incremented. The count value k corresponds to the position information about the data element or its sequence number. The counter is reset each time a process is completed on a set of source data.
In step S3, the puncturing table shown in
In step S7, it is checked whether or not the count value k has reached N. If the count value K has reached N, then it is assumed that the process on a set of source data has been completed, and the counter is reset in step S8.
Thus, the first puncturing unit 45 and the second puncturing unit 46 selects K bits from the input N-bit parity data sequence Yk and outputs the selected bits. This selecting process is realized by the CPU 52 executing the program describing the steps S1 through S8.
Table 2 shows an example of the output from the first puncturing unit 45 and the second puncturing unit 46.
The output is obtained when the input source data u is 9-bit data, and both puncturing patterns P in the first puncturing unit 45 and the second puncturing unit 46 are (0 0 1 1 0 1 0 0 1).
The data elements of the data sequence Xk are sequentially written to the buffer 61. The parity data sequence Z1k are the data elements selected by the first puncturing unit 45. These data elements are written to the memory 62 corresponding to the sequence numbers. The sequence number corresponding to each data element is, for example, indicated by the count value k of the counter described by referring to
The read control unit 64 reads a data element from the buffer 61, the memory 62, or the other memory 63 at predetermined intervals, and outputs the selected data elements. Practically, the data element is read by repeatedly performing the following steps (1) through (4).
(1) Reading the data element having the sequence number specified by the buffer 61.
(2) Reading the data element having the specified sequence number if it is stored in the memory 62.
(3) Reading the data element having the specified sequence number if it is stored in the memory 63.
(4) Specifying the next sequence number.
When the buffer 61, memories 62,63 are in the state shown in
Thus, the error-correcting encoding apparatus 40 shown in
Briefly described below is the decoding device for decoding a data sequence encoded by the error-correcting encoding apparatus 40. Various methods have been developed as decoding processes. However, this device basically decode data sequences by performing an encoding process in the inverse order.
A serial/parallel converter 71 separates the received parity data sequence Z into a parity data sequence Z1k and a parity data sequence Z2k. The parity data sequences Z1k and Z2k are sequences generated by the first puncturing unit 45 and the second puncturing unit 46 contained in the error-correcting encoding apparatus 40.
A first depuncturing unit (p-1) 72 and a second depuncturing unit (p-1) 73 contain the same puncturing tables as the error-correcting encoding apparatus 40, and perform the depuncturing process on the parity data sequences Z1k and Z2k.
When the first depuncturing unit 72 receives the parity data sequence Z1k, it first checks the selection information corresponding to the sequence number=1 in the puncturing table. Since the selection information=0 in this example, the first depuncturing unit 72 outputs a “0”. It then checks the selection information corresponding to the sequence number=2 of the puncturing table. In this case, since the selection information=1, the first depuncturing unit 72 outputs Z11, that is, the leading data element of the parity data sequence Z1k. Similarly, the first depuncturing unit 72 outputs a “0” when the selection information=0, and sequentially outputs one by one the data element of the parity data sequence Z1k, when the selection information=1. As a result, the first depuncturing unit 72 outputs the following data sequences.
Output sequences: (0, Z11, 0, Z12, 0, Z13, 0, Z14, Z15).
Referring back to
In step S11, the puncturing table is searched using k to obtain corresponding selection information. In particular, selection information of the kth position is obtained. In step S12, it is checked whether the selection information obtained in step S11 is “1” or “0”. If the obtained selection information is a “1”, one of the data elements of the data sequence Zi is output as a data element of the data sequence Yk in step S13. Then, in step S14, I is incremented. On the other hand, if the obtained selection information is a “0”, then “0” is output as a data element of the data sequence Yk in step S15.
In step S16, k is then incremented. In step S17, it is checked whether or not k has reached N, where N indicates the data length of the source data. Unless k has reached N, control is returned to step S11. If k has reached N, then k and I are reset.
Referring again to
The output from the second decoder 75 is compared with a predetermined threshold by a determination unit 76. A deinterleaver 77 then performs a deinterleaving process (a process for performing the randomizing process by the error-correcting encoding apparatus 40 in the inverse order) on the comparison result, and the result is output as decoded data.
The decoding process excluding the process of generating a parity data sequence can be realized using conventional technology. For example, it is described in the U.S. Pat. No. 5,446,747. Therefore, the detailed explanation about the decoding process is omitted here.
To improve the decoding precision, the decoding device with the above described configuration can be serially connected as shown in
With the above-described configuration, the decoding precision can be improved by increasing the number of serially connected decoding modules. For example, the decoding precision of the decoded data S output from a decoding module 70-4 is higher than that of the decoded data S output from the decoding module 70-1. The operation with the configuration is described in the U.S. Pat. No. 5,446,747.
With the configuration shown in
Described below is the error-correcting encoding apparatus according to another embodiment of the present invention. The conventional error-correcting encoding apparatus is normally assigned a fixed encoding rate. For example, with the configuration shown in
In contrast, when the error-correcting encoding apparatus 40 is used, 417-bit parity data sequences Z1k,Z2k are generated respectively from the 666-bit parity data sequences Y1k,Y2k as shown in
The error-correcting encoding apparatus 80 according to the embodiment includes a bit duplication unit 81. The bit duplication unit 81 duplicates a predetermined number of data elements in the source data u to obtain a desired encoding rate.
The operation of the bit duplication unit 81 is described below. In the following descriptions, it is assumed that the data length of the source data u is N bits, and the data length of the output data sequence C is M bits. It is also assumed that M>3N. In other words, it is assumed that an encoding rate lower than ⅓ is requested.
Assuming that the data sequence Xk is obtained by duplicating r-bits of data in the source data u the bit duplication unit 81, each data length of the data sequence Xk, the parity data sequence Y1k, and the parity data sequence Y2k is “N+r”. Therefore, to set the data length of an output data sequence to M bits, the number of bits to be duplicated by the bit duplication unit 81 is obtained by the following equation.
(N+r)×3=M
∴r=M/3−N
For example, assuming that the data length of the source data u is 250 bits and the data length of a desired output sequence is 900 bits, R=50 is obtained by substituting N=250 and M=900 in the equation above.
It is desired that the bit duplication unit 81 duplicates the data elements of the source data u for every “constraint length+1”. The constraint length refers to the number of bits of data stored in the memory for a convoluting process. For example, with the configuration shown in
Thus, when a data sequence whose predetermined number of data elements are duplicated is encoded and transmitted, the precision of a decoding process for the subsequent data elements after the duplication of the data elements can be improved.
In step S21, the data element ui of the source data u is obtained. In the following descriptions, “1” is referred to as a sequence number. In step S22, it is checked whether or not the frequency j of the bit duplication has reached “r”, that is, the number of data elements to be duplicated. The frequency j of the bit duplication indicates the number of times the bit duplication has been performed on the source data u. If j>r, then it is assumed that the required frequency of the bit duplication has been performed, and the obtained data element ui is output as is in step S23. On the other hand, if j≦r, it is assumed that the bit duplication should be furthermore repeated, and control is passed to step S24.
In step S24, it is checked whether or not the sequence number i is a multiple of x. Unless the sequence number i is a multiple of x, no bit duplication is performed and control is then passed to step S2′. On the other hand, if the sequence number i is a multiple of x, then the source data ui is output in steps S25 and S26. Thus, the source data ui is duplicated. In step S27, the frequency j of the bit duplication is then incremented.
In step S28, it is checked whether or not the sequence number i has reached N. If the sequence number i has not reached N, the sequence number i is incremented in step S29, and then control is passed back to step S21 to obtain the next data element. On the other hand, if the sequence number i has reached N, this it is assumed that all data elements of the source data has been processed in steps S21 through S29. Then, i and j are reset in step S30, thereby terminating the process.
Referring back to
The decoding device for decoding a data sequence of the data encoded by the error-correcting encoding apparatus 80 only has to perform the process performed the bit duplication unit 81 in the inverse order after performing a normal decoding process.
The error-correcting encoding apparatus 90 further includes a dummy bit insertion unit 91. The dummy bit insertion unit 91 inserts a predetermined number of dummy bits into the source data u to obtain a desired encoding rate.
Described below is the operation of the dummy bit insertion unit 91. In the following description, it is assumed that the data length of the source data u is N bits, and the data length of an output data sequence is M bits. For example, M is larger than 3N, then a value smaller than ⅓ is desired as an encoding rate.
When the dummy bit insertion unit 91 obtains a data sequence Xk by inserting r dummy bits into the source data u, the data length of the data sequence Xk, the parity data sequence Y1k, and the parity data sequence Y2k is “N+r”. Therefore, to set the data length of the output data sequence to M bits, the number of bits to be inserted by the dummy bit insertion unit 91 can be obtained by the following equation.
(N+r)×=M
∴r=M/3−N
It is desired that the dummy bit insertion unit 91 inserts dummy bits having the same length as the constraint length. The constraint length refers to the number of bits of the data stored in the memory in the convoluting process as described above. Therefore, with the configuration shown in
The dummy bits can be either 1 or 0. If 1 is used as a dummy bit, and the constraint length is 2, then 11 is inserted as dummy data. For example, if the data length of the source data u is 250 bits, and the data length of a requested output sequence is 900 bits, then r=50. Thus, it is requested that 50 dummy bits are inserted into the source data u. If the constraint length is 2, ‘11’ is inserted into the source data u at 25 points. It is also desired that the dummy data is inserted as evenly distributed.
When a data sequence with a dummy bit of “1” is inserted, encoded and transmitted, the precision of the decoding process on the subsequent data elements after the dummy data is improved.
As described above by referring to
Thus, the error-correcting encoding apparatus 90 shown in
The decoding device for decoding a data sequence encoded by the error-correcting is encoding apparatus 90 only has to have the function of removing dummy bits after performing a normal decoding process.
The error-correcting encoding apparatuses shown in
A puncturing unit 102 selects a predetermined number of data elements from the parity data sequences Y1k through Ymk output respectively from the convolution units 101-1 through 101-m, and output the selected elements. For example, when the data length of the source data u is N bits and the data length of the output sequence C is M bits, that is, the encoding rate=N/M, the puncturing unit 102 selects the data elements as follows. Each of the convolution units 101-1 through 101-m outputs N-bit parity data when it is assigned an N-bit sequence.
If the puncturing unit 102 selects K1 through Km data elements respectively from the parity data sequences Y1k through Ymk, the following equation is obtained.
N+K1+K2+K3+ . . . +Km=M
If K1=K2=K3= . . . =Km=K, then the following equation is obtained.
K=(M−N)/m
∴encoding rate R=N/M=(M−m·K)/M
(where M>N, N>K)
Thus, the encoding rate R of the error-correcting encoding apparatus can be determined depending on the number of convolution units provided in parallel with each other, and the number of data elements to be selected from an N-bit sequence.
According to the above-described embodiments, the error-correcting encoding apparatuses shown in
The error-correcting encoding apparatus according to the above described embodiments use systematic codes, and the configuration in which a convoluting process is performed. However, the present invention is not limited to this configuration. That is, the error-correcting encoding apparatus according to the present invention is not necessarily limited by systematic codes, nor limited to the configuration including a convolution unit.
A desired encoding rate (information rate) is obtained in an error-correcting encoding apparatus for encoding source data. Therefore, it is not necessary to transmit insignificant data by using this apparatus in a communications system. As a result, the transmission efficiency is improved and the decoding characteristic also can be improved.
Number | Date | Country | Kind |
---|---|---|---|
10-232580 | Aug 1998 | JP | national |
This is a continuation of U.S. patent application Ser. No. 10/309,441, filed Dec. 4, 2002, which is a divisional of U.S. patent application Ser. No. 09/377,393, filed Aug. 19, 1999, now U.S. Pat. No. 6,519,732, which claims priority under 35 U.S.C. §119 from Japanese Application 10-232580, filed Aug. 19, 1998, the contents of each of the above referenced applications being incorporated by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
5406570 | Berrou et al. | Apr 1995 | A |
5436918 | Kato et al. | Jul 1995 | A |
5446747 | Berrou | Aug 1995 | A |
5721745 | Haladik et al. | Feb 1998 | A |
5729560 | Hagenauer et al. | Mar 1998 | A |
5734962 | Hladik et al. | Mar 1998 | A |
5751739 | Seshadri et al. | May 1998 | A |
5812601 | Schramm | Sep 1998 | A |
5907583 | Sakoda et al. | May 1999 | A |
5933462 | Viterbi et al. | Aug 1999 | A |
5978365 | Yi | Nov 1999 | A |
6000054 | Bahr et al. | Dec 1999 | A |
6023783 | Divsalar et al. | Feb 2000 | A |
6131180 | Ramesh | Oct 2000 | A |
6138260 | Ketseoglou | Oct 2000 | A |
6272183 | Berens et al. | Aug 2001 | B1 |
6289486 | Lee et al. | Sep 2001 | B1 |
6298463 | Bingemann et al. | Oct 2001 | B1 |
6430722 | Eroz et al. | Aug 2002 | B1 |
6519732 | Li | Feb 2003 | B1 |
Number | Date | Country |
---|---|---|
9740582 | Oct 1997 | WO |
Entry |
---|
Podemski, et al., “Distance Spectrum of the Turbo-codes”, 1995 IEE International Symposium on Information Theory, Sep. 1995, p. 34. |
Berrou et al., “Near Shannon Limit Error-Correcting Coding and Decoding: Turbo Codes (1)”, 1993 IEEE International Conference on Communications, May 1993, pp. 1064-1070. |
U.S. Appl. No. 60/096,807, filed Aug. 17, 1998, sheets 2-19. |
Barbulescu, et al, “Rate compatible turbo codes”, Electronics Letters, Mar. 1995, vol. 31, No. 7. |
Japanese Patent Office, Notice of Rejection Ground (corresponding Japanese Patent Application No. 2006-168226), mailed Jan. 27, 2009, with English translation. |
European Search Report for corresponding European Patent Application No. 04013773.9 issued Oct. 26, 2010. |
Toskala Antti. et al.; “Frames FMA2 Wideband-CDMA for UMTS”; European Transactions on Telecommunications, Wiley & Sons., Chichester, GB.; vol. 9, No. 4, Jul. 1, 1998, pp. 325-335, XP000778096; ISSN: 1124-318X; Sections 4.1 and 4.3, Figure 6; [Ref.: European Search Report issued Oct. 26, 2010]. |
Wang, “Asymptotic Performances of Non-Repetitive and Repetitive Turbo Codes”, MILCOM 97 Proceedings, Nov. 1997, vol. 1, pp. 48-53. |
Holma et al., “Performances of Frames Non-Spread Mode 1 (WB-TDMA) with Turbo Codes”, VTC 98, 840-844. |
Fei et al., “The Effects of Time Delay Spread on Turbo-TCM in a Wireless Communication Channel”, IEEE 47th Vehicular Technology Conference, 1997, pp. 334-338. |
Narayanan et al., “List Decoding of Turbo Codes”, IEEE Transactions on Communications, vol. 46, No. 6, Jun. 1998, pp. 754-762. |
Barbulescu et al., “Rate Compatible Turbo Codes”, Electronic Letters, Mar. 1995, vol. 31, No. 7, pp. 535-536. |
Kallel, “Complementary Punctured Convolutional (CPC) Codes and Their Applications”, IEEE Transactions on Communications, vol. 43, No. 6, Jun. 1995, pp. 2005-2009. |
Hindelang, T., et al., “Using Powerful “Turbo” Codes for 14.4 KBIT/S Data Service in GSM or PCS Systems”, IEEE Global Telecommunications Conference, 1997 GLOBECOM '97, vol. 2, pp. 649-653. |
Acikel, O.F., et al., “High Rate Turbo Codes for BPSK/QPSK Channels” IEEE International Conference on Communications, 1998 ICC'98 Conference Record, vol. 1, pp. 422-427. |
Berrou, et al., “Near Optimum Error Correcting Coding and Decoding: Turbo-Codes” Oct. 1996, IEEE Transactions on Communications, vol. 44, No. 10, pp. 1261-1271. |
Caire, et al., “Parallel Concatenated Codes with Unequal Error Protection”, May 1998, IEEE Transactions on Communication, vol. 46, No. 5, pp. 565-567. |
Benedetto, et al., “Unveiling Turbo Codes: Some Results on Parallel Concatenated Coding Schemes”, Mar. 1996, IEEE Transactions on Information Theory, vol. 42, No. 2, pp. 409-428. |
Benedetto, et al., “Design of Parallel Concatenated Convolutional Codes”, May 1996, IEEE Transactions on Communications, vol. 44, No. 5, pp. 591-600. |
Barbulescu et al., “Interleaver Design for Three Dimensional Turbo Codes”, IEEE International Symposium on Information Theory, 1995, p. 37. |
Rowitch et al., “Rate Compatible Punctured Turbo (RCPT) Codes in a Hybrid FEC/ARQ System”, IEEE Global Telecommunications Mini-Conference, 1997, pp. 55-59. |
Oberg, et al., “Application of Distant Spectrum Analysis to Turbo Code Performance Improvement”, International Symposium on Turbo Codes & Related Topics, Sep. 1997. |
Notice of Rejection Grounds, Jul. 27, 2004, partial translation of corresponding Japanese application. |
Summons to attend oral proceedings pursuant to Rule 71(1) EPC in EP Application 99115151.5-2415 dated Jul. 3, 2006. |
Extended European Search Report issued for corresponding European Patent Application No. 10180888.9, mailed Nov. 18, 2010. |
Extended European Search Report issued for corresponding European Patent Application No. 10180889.7, mailed Nov. 18, 2010. |
Keihou Ri—Sailing Toward Shannon Capacity' Data to Be Used for Discussion of Theses of the Graduate School of Tokyo University, Nov. 22, 1996. |
Office Action issued for corresponding European Patent Application No. 10180889.7, dated Aug. 30, 2012. |
Number | Date | Country | |
---|---|---|---|
20070300123 A1 | Dec 2007 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 09377393 | Aug 1999 | US |
Child | 10309441 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10309441 | Dec 2002 | US |
Child | 11847814 | US |