The invention relates to a communication device, and in particular relates to a deinterleaver for a communication device.
Interleaving techniques are commonly used in communication systems to protect transmissions against burst errors. Burst errors result in a number of consecutive bits being received erroneously, with the rest of the transmission being received successfully.
Data correction bits are derived for the data prior to transmission, which are used by the receiver to detect whether the data has been received successfully, and whether erroneously received bits can be corrected. Only a certain number of erroneous bits can be corrected in each symbol to be transmitted. Therefore, interleaving is used to spread the bits for each symbol across the transmission. Thus, if a burst error occurs, only a small number of bits from each symbol are affected, so the receiver will be able to correct the received symbols using the data correction bits.
In many established standards, for example wireless communication standards, block interleaving is used, as it is easy and straightforward to implement. However, as data rates and distances between nodes increase, nested or concatenated interleaving schemes are becoming more important. The direct mapping of deinterleavers for such advanced interleaving schemes to hardware is usually suboptimal, so different optimization techniques can be used to save silicon area and reduce power consumption.
The “MultiBand OFDM Physical Layer Specification” Release 1.0 from the MultiBand OFDM Alliance proposes a three-stage interleaving scheme. In the first stage, symbol interleaving is used which permutes the bits across a number of consecutive OFDM symbols (usually six) to exploit frequency diversity within a band group. In the second stage, intra-tone interleaving is used which permutes the bits across the data sub-carriers (tones) within an OFDM symbol to exploit frequency diversity across sub-carriers. In the third stage, intra-symbol cyclic shifts are used which cyclically shift the bits in successive OFDM symbols by deterministic amounts.
The symbol interleaving operation performed by symbol interleaving unit 4 comprises dividing the coded bits into blocks of 6NCBPS coded bits, where NCBPS is the number of coded bits per symbol, and therefore 6NCBPS corresponds to six OFDM symbols. Each group of coded bits is then permuted using a block interleaver of size 6NCBPS by 6/NTDS, where NTDS is the time spreading factor. The sequences {U(i)} and {S(i)}, where i=0, . . . , NCBP6S−1 and NCBP6S is the number of coded bits in six symbols, represent the input and output bits of the symbol interleaving unit 4 respectively. The input-output relationship of this unit is given by the equation
where Floor(x) is a function which returns the largest integer value less than or equal to its argument value, and Mod(x,y) is the modulus operator which returns the non-negative integer remainder when x is divided by y.
The output bits of the symbol interleaving unit 4, which are grouped together into blocks of NCBP6S bits, are permuted together using a regular block interleaver of size NTint×10, where NTint=NCBPS/10. The sequences {S(i)} and {V(i)}, where i=0, . . . , NCBP6S−1, represent the input and output bits of the tone block interleaver unit 6 respectively. The input-output relationship of this unit is given by the equation
The output of the tone interleaving unit 6 is passed through intra-symbol cyclic shift unit 8. The sequences {V(i)} and {B(i)}, where i=0, . . . , NCBP6S−1, represent the input and output bits of the cyclic shift unit 8 respectively. The output of the cyclic shift unit 8 is given by the following equation
B(i)=V[m(i)×NCBPS+mod(i+m(i)×Ncyc,NCBPS)] (3)
where m(i)=Floor (i/NCBPS) and i=0, . . . , NCBP6S−1.
US 2005/0152327 discloses an interleaver for a multiband OFDM transceiver of an ultra wideband personal access network in accordance with the above three-stage interleaving scheme. This document also describes a deinterleaver which is a concatenation of three blocks, a cyclic de-shift unit, a tone-deinterleaving unit and a symbol deinterleaving unit, which is costly in terms of silicon area and is not scalable.
It is an object of the invention to provide a deinterleaver for a wireless communication device that is simple and inexpensive to implement.
In accordance with a first aspect of the invention, there is provided a deinterleaver for deinterleaving a stream of data bits representing a plurality of symbols that have been interleaved using a multi-stage interleaving scheme, the deinterleaver comprising preprocessing means for ordering the data bits in the stream into pairs, such that the data bits in the pair are consecutive data bits from a symbol; at least one memory for storing the paired bits, such that each pair of data bits is stored in a respective location in the memory; and a read and write address generator for the at least one memory, the generator being adapted to determine the addresses in the at least one memory that pairs of data bits are to be stored, and to determine the addresses in the at least one memory that pairs of data bits are to be read from.
In accordance with a second aspect of the invention, there is provided a device for use in an ultra-wideband system comprising a deinterleaver as described above.
In accordance with a third aspect of the invention, there is provided a communication device for use in receiving a stream of data bits representing a plurality of symbols, the device comprising a deinterleaver as described above.
These and other aspects of the invention will be apparent from and elucidated with reference to the embodiments described hereinafter.
The invention will now be described, by way of example only, with reference to the following drawings, in which:
a), 3(b) and 3(c) show initial output addresses at the deinterleaver for different values of deintv_type;
a), 4(b) and 4(c) show symbol bits in initial output addresses at the deinterleaver for different values of deintv_type.
a) to 7(g) illustrate the operation of the preprocessing unit when deintv_type=1;
a) to 8(f) illustrate the operation of the preprocessing unit when deintv_type=2;
a) to 9(g) illustrate the operation of the preprocessing unit when deintv_type=3;
a)-(d) illustrate the operation of the inter-symbol post-processing unit in accordance with the invention.
Although the invention will be described with reference to an ultra-wideband network in accordance with the “MultiBand OFDM Physical Layer Specification” Release 1.0 from the MultiBand OFDM Alliance mentioned above, it will be appreciated that the invention is applicable to other communication networks in which multi-level interleaving is used.
In the following description of the invention, it is assumed that data to be transmitted has been interleaved using the three-stage interleaving scheme described above with reference to
In the exemplary network, there are nine possible data rates that can be used: 39.4 Mb/s, 53.3 Mb/s, 80 Mb/s, 106.7 Mb/s, 160 Mb/s, 200 Mb/s, 320 Mb/s, 400 Mb/s and 480 Mb/s. The data rate 39.4 Mb/s is just used for the header. The parameters NTDS, NTint, Ncyc and NCBPS used in the interleaving scheme described above all depend on the data rate being used at that time.
It has been recognized that the order in which symbol data bits are output from an interleaver can be classified into three main types based on the data rate and other parameters used by the interleaver to interleave the data stream. Thus, in accordance with the invention, a new parameter deintv_type is defined, and its value is based on the data rate used to transmit the data stream. The parameter deintv_type has a value of 1 when the data rate is 39.4 Mb/s, 53.3 Mb/s and 80 Mb/s, a value of 2 when the data rate is 106.7 Mb/s, 160 Mb/s and 200 Mb/s, and a value of 3 when the data rate is 320 Mb/s, 400 Mb/s and 480 Mb/s. The values of deintv_type are shown in
The number of symbols used in the interleaving at the transmitter is denoted M and has the value M=0, . . . , 2 for data rates less than 320 Mb/s and M=0, . . . , 5 for data rates greater than 200 Mb/s (the range of values for M are also shown in the table of
a), 3(b), 3(c), 4(a), 4(b) and 4(c) show the natural order in which interleaved symbol bits are received at a deinterleaver for different values of deintv_type. Specifically,
In a preferred embodiment, two data bits can be stored in a single physical memory location, with the virtual address being mapped to a physical address by dividing by
It can be seen from
(i) The first pattern is that the data from each symbol is output in a round robin way. For example, the output will be sym0,m, sym1,m, sym2,m, sym0,m+1, sym1,m+1, sym2,m+1, etc. This is due to the symbol-interleaving unit 4 in the transmitter.
(ii) If two consecutive output addresses from the same symbol are grouped together starting from the first output address, it can be seen that for most of the groups, the address gap is 10 for data rates of 39.4 Mb/s, 53.3 Mb/s and 80 Mb/s and 20 for data rates greater than 80 Mb/s. For example, the address gap between sym0,0 and sym0,1 in
(iii) The pattern described in (ii) may occasionally be broken, but, in these cases, another pattern is available. Here, two consecutive samples have index of m, (m+gap)−M*N. This is shown in
As a result of the above observations, a deinterleaver 10 is presented in
The deinterleaver 10 preferably comprises control means that determines the value of deintv_type for the incoming transmission from the indication of the data rate in the header of the packet. In some embodiments, this header is a PLCP header.
At any time, one of the memories 16 or 18 is responsible for writing soft bits received in the incoming data stream, and the other is responsible for reading out soft bits stored therein. The memories 16, 18 switch responsibilities after 6 OFDM symbol periods. In a preferred embodiment where each memory location stores two data bits, the memories 16, 18 each have 3*NCBPS memory locations, one location for each pair of bits in six symbols.
The intra-symbol preprocessing unit 12 has three different operating modes, one for each of the possible values for deintv_type. Due to frequency domain de-spreading, two soft data bits will be input to the preprocessing unit 12 each clock cycle when deintv_type=1. As the deinterleaver is a parallel design, four soft bits will be input to the preprocessing unit 12 each clock cycle when deintv_type=2 or 3.
a) to 7(g) illustrate the operation of the preprocessing unit 12 when deintv_type=1. When deintv_type=1, only the first main register array 26 is used to process the incoming data stream. Thus the demultiplexer 32 is controlled to direct the incoming data stream to the first main register array 26, and the multiplexer 34 is controlled to select the first main register array 26 for the output of the preprocessing unit 12. The second main register array 28 and the special register array 30 are not used when deintv_type=1.
As mentioned above, the intra-symbol preprocessing unit 12 processes the incoming data stream and outputs the data bits in accordance with the pattern described in paragraph (ii) above. That is, the unit 12 groups the data stream into pairs of bits whose indices are 10 apart.
Each of
a) shows that the first ten data bits, denoted d0 to d9, have been stored in locations R0 to R9 respectively in the register 26. In the next clock cycle, data bits d10 and d11 will be received. It will be noted that register locations R10 to R19 are not used when deintv_type=1.
The operation of the register 26 follows a set pattern, with the pattern repeating every twenty data bits received, or, in other words, every ten clock cycles.
In each of the first five clock cycles of the pattern, when a new pair of data bits are received at the register 26, a first one of the pair of data bits is read straight out of the register along with a data bit previously stored in the register 26. This data bit will have an index that is ten less than the first data bit in the incoming pair. The other data bit in the pair is read into a vacant register location in the register 26.
So, as shown in
In
As shown in
In the last five clock cycles of the pattern, pairs of data bits stored in consecutive register locations are read out of the register 26, and both of the incoming data bits are stored in the vacated register locations.
Thus, in
After the tenth clock cycle of the pattern, the state of the register 26 will be as shown in
a) to 8(f) illustrate the operation of the preprocessing unit 12 when deintv_type=2. As when deintv_type=1, only the first main register array 26 is used to process the incoming data stream. The second main register array 28 and the special register array 30 are not used when deintv_type=2.
As mentioned above, the intra-symbol preprocessing unit 12 processes the incoming data stream and outputs the data bits in accordance with the pattern described in paragraph (ii) above. Thus, the unit 12 groups the data stream into pairs of bits whose indices are 20 apart.
In order to reduce the number of figures required to illustrate the operation of the preprocessing unit 12 when deintv_type=2, each of
a) shows that the first twenty data bits, denoted d0 to d19, have been stored in locations R0 to R19 respectively in the register 26. In the next clock cycle, data bits d20, d21, d22 and d23 will be received.
As when deintv_type=1, the operation of the register 26 follows a set pattern, with the pattern repeating every forty data bits received, or, in other words, every ten clock cycles.
In each of the first five clock cycles of the pattern, when a new quartet of data bits are received at the register 26, the first and third ones of the quartet of data bits are read straight out of the register along with two data bits previously stored in the register 26. These data bits will have an index that is twenty less than the first and third data bits in the incoming quartet respectively. The other data bits in the quartet are read into vacant register locations in the register 26.
As shown in
This process continues as shown in
In the last five clock cycles of the pattern, two pairs of data bits stored in consecutive register locations are read out of the register 26, and all four of the incoming data bits are stored in the vacated register locations.
Thus, in
After the tenth clock cycle of the pattern, consecutive data bits d40 to d59 have been stored in respective register locations R0 to R19, and each of data bits d0 to d19 have been read out of the register 26 with a corresponding data bit that has an index that is 20 higher. It can be seen that the state of the register 26 in
a) to 9(g) illustrate the operation of the preprocessing unit 12 when deintv_type=3.
According to the Wimedia PHY specification, when the data rate is higher than 200 Mb/s, i.e. when deintv_type=3, dual carrier modulation is used. In a dual carrier modulator, two hundred incoming bits are grouped into fifty groups of four bits, which are modulated on two sub-carriers. At the dual carrier demodulator (which is not shown in
As when deintv_type=1 or 2, the intra-symbol preprocessing unit 12 processes the incoming data stream and outputs the data bits in accordance with the pattern described in paragraph (ii) above. Thus, the unit 12 groups the data stream into pairs of bits whose indices are 20 apart.
However, as a result of the operation of the dual carrier demodulator when deintv_type=3, the processing required to group the data bits is more complicated than when deintv_type=1 or 2. Thus, the intra-symbol preprocessing unit 12 uses all three of the first main register array 26, the second main register array 28 and the special register array 30 to process the incoming data stream.
In order to reduce the number of figures required to illustrate the operation of the preprocessing unit 12 when deintv_type=3, each of
a) shows that the first forty data bits, denoted d0 to d19 and d50 to d69 have been received at the preprocessing unit 12 and have been directed by the demultiplexer 32 to appropriate locations in the first main register array 26, second main register array 28 and special register array 30. Data bits d0 to d19 have been stored in locations R0 to R19 respectively in the first main register array 26, data bits d50 to d59 have been stored in locations R0 to R9 respectively in the second main register array 28, and data bits d60 to d69 have been stored in locations R0 to R9 respectively in the special register array 30. In the next ten clock cycles, data bits d20 . . . d39 and d70 . . . d89 will be received.
As shown in
In addition to the above operation of the first main register array 26, incoming data bits d70, d72, . . . , d78 are read straight out of the second main register array 28 with respective data bits d50, d52, . . . , d58 which were stored in respective even-numbered register locations R0, R2, . . . , R8 in register 28. Data bits d51, d53, . . . , d59 in respective odd-numbered register locations R1, R3, . . . , R9 are moved to the newly vacated even-numbered register locations R0, R2, . . . , R8 in register 28, and incoming data bits d71, d73, . . . , d79 are stored in respective locations R1, R3, . . . , R9. The remaining incoming data bits, d80, . . . , d89 are stored in register locations R10, . . . , R19 in the second main register array 28.
The process continues as shown in
In an alternative embodiment, if there is a reordering block after or in the dual carrier demodulator, the data stream can be provided to the deinterleaver in a natural order, i.e. d0, d1, d2, d3, d4, . . . . Therefore, it is not necessary for the intra-symbol preprocessing unit 12 to use the second main register array 28 or the special register array 30. Instead, the operation of the preprocessing unit 12 will be as shown in
As described above, the output from the intra-symbol preprocessing unit 12 each clock cycle is a pair of data bits, whose indices differ by 10 when deintv_type=1, or by 20 when deintv_type=2 or 3. Due to the high throughput requirement of the deinterleaver 10, and the limited access speed of current memories (particularly CMOS memories), each pair of soft bits output by the preprocessing unit 12 are stored at a single memory address in one of the first or second memories 16, 18.
Also as described above, at any one time, one of the memories 16, 18 will be receiving and storing pairs of data bits from the preprocessing unit 12 for a current set of six symbols, while the other memory 16, 18 will be outputting pairs of data bits for a set of six symbols that have been previously stored in the memory 16, 18.
The read/write address generator 20 determines the locations in the first and second memories 16, 18 to which data is to be written to or read from. As described, the read/write generator controls the memory 16, 18 that are receiving pairs of data bits from the intra-symbol preprocessing unit 12 so that the bits for each OFDM symbol are stored at appropriate addresses in the memory 16, 18.
When deintv_type=1, the write address for the data bits dxdx+10 in the Mth symbol in the first or second memory 16, 18 is determined from the following equation:
where Mod(x,y) is the modulus operator which returns the non-negative integer remainder when x is divided by y, and Floor(z) is the floor function which returns the largest integer value less than or equal to its argument value.
When deintv_type=2 or 3, the write address for the data bits dxdx+20 in the Mth symbol in the first or second memory 16, 18 is determined from the following equation:
However, the read address generator that generates the addresses that data is to be read from is more complicated.
Essentially, the address generator 20 uses a pre-fetching mechanism to deal with the cyclic shift in the third stage of the interleaver. When pre-fetching is enabled for the current OFDM symbol, the corresponding memory location is first pre-fetched and it is combined with the following data in a normal way before being passed to the inter-symbol processing unit 24.
At the same time, different address counters (addr0, addr1, addr2, addr3, addr4, addr5) are used to facilitate the generation of the read addresses. Basically, each address counter is responsible for one OFDM symbol, which is located in one continuous section in the respective memory 16, 18, and each address counter is incremented by a certain value each clock cycle during normal operation. Once the address counter reaches the boundary value of that memory section (i.e. the section of the memory 16, 18 in which that OFDM symbol is stored), the address value will be wrapped around within the memory section. The read address generation is preferably controlled by a dual loop counter, which uses an inner loop and an outer loop. When the inner loop count, inner_cnt, reaches a certain threshold, it is reset to zero and the outer loop count, outer_cnt, is incremented by 1.
The operation of the address generator 20 will now be described in detail with reference to
In step 103, the first three of the address counters, addr0, addr1 and addr2, are set to the initial address values init_addr0, init_addr1 and init_addr2 respectively. If deintv_type=3, then the fourth, fifth and sixth address counters, addr3, addr4, addr5, are set to the initial address values init_addr3, init_addr4 and init_addr5 respectively.
In step 105, a pair of data bits in one memory location are pre-fetched for each OFDM symbol whose pref_en is high. These data bits are obtained from the address indicated by the appropriate init_addr.
In step 107, one memory location for symbols 0 and 1 are read in accordance with the values of addr0 and addr1 respectively.
In step 109, the value of addr0 is incremented by 20, and the value of addr1 is incremented by 20 if the current value of addr1 is less than 180. Otherwise, the value of addr1 is decremented by 80.
In step 111, it is determined whether deintv_type=3. If deintv_type=1 or 2, then the process moves to step 113 in which a memory location for symbol 2 is read in accordance with the value of addr2. In step 115, which follows step 113, the value of addr2 is incremented by 20 if the current value of addr2 is less than 280, otherwise, the value of addr2 is decremented by 80. The process then moves to step 117.
If, in step 111, it is determined that deintv_type=3, then the process moves to step 119 in which one memory location for symbols 2, 3, 4 and 5 are read in accordance with the values of addr2, addr3, addr4 and addr5 respectively. In step 121, which follows step 119, the value of addr2 is incremented by 20 if the current value of addr2 is less than 280, otherwise, the value of addr2 is decremented by 80. The value of addr3 is incremented by 20 if the current value of addr3 is less than 380, otherwise, the value of addr3 is decremented by 80. The value of addr4 is incremented by 20 if the current value of addr4 is less than 480, otherwise, the value of addr4 is decremented by 80. The value of addr5 is incremented by 20 if the current value of addr5 is less than 580, otherwise, the value of addr5 is decremented by 80. The process then moves to step 117.
In step 117, it is determined whether the value of inner_cnt is 4. If the value of inner_cnt is not 4, the process moves to step 123 in which the inner_cnt is incremented. After the inner_cnt is incremented, the process returns to step 107 and a memory location is read for symbols 0 and 1 in accordance with the current values for addr0 and addr1.
If the value of inner_cnt is not 4, the process moves to step 125 in which it is determined whether the outer_cnt is 19. If the value of the outer_cnt is 19, the process is complete for those six OFDM symbols, and the process returns to the initialization step 101, where to process repeats for subsequent symbols. If the value of the outer_cnt is not 19, the process moves to step 127.
In step 127, if deintv_type=1, the value of the outer_cnt is incremented by 1, and the values of init_addr0, init_addr1 and init_addr2 are incremented by 1.
If deintv_type=2, then the value of outer_cnt is incremented by 2, and the values of init_addr0, init_addr1 and init_addr2 are incremented by 2.
If deintv_type=3, then the value of the outer_cnt is incremented by 1, and the values of init_addr0, init_addr1, init_addr2, init_addr3, init_addr4 and init_addr5 are incremented by 1.
In all three situations, the inner_cnt is set to zero.
The process then passes to step 129 in which the value of pref_en is updated based on the current value of the outer_cnt for each OFDM symbol. The table in
After the pref_en value has been updated, the process returns to step 103, where the address counters are set to the value of the respective init_addr.
As mentioned above, the data bits output from the selected memory 16, 18 via the multiplexer 22, pass into an inter-symbol post-processing unit 24.
As mentioned, two data bits are stored at each memory address in the memories 16, 18, so two data bits are output from one of the memories 16, 18 to the post processing unit 24 each clock cycle. Due to the operation of the preprocessing unit 12, these data bits are consecutive data bits from the same symbol. However, only one soft data bit is stored in each register location of register array 36.
The post-processing unit 24 reorders these pairs of data bits so that the output of the post-processing block matches the expected deinterleaved pattern (i.e. 6/TSF symbols output their deinterleaved bits in a round robin way), which will be the pattern of data bits that were provided to the interleaver 2 in the transmitter.
a)-(d) illustrate the operation of the post-processing unit 24 in accordance with the invention. The shaded register locations indicate that valid data is stored there. The un-shaded register locations are available for receiving data. As shown in
Then, as shown in
Then, as shown in
Then, as shown in
Thus, as can be seen from the operation of the post-processing unit 24 described above, the pairs of consecutive data bits from the same symbol are separated for output from the deinterleaver 10.
Thus, as the deinterleaver structure according to the invention uses a combination of registers and memories, the deinterleaver is simple and inexpensive to design and implement. If the scheme used to interleave the data stream is modified in any way, or if an alternative interleaving scheme is used, it is easy to adapt the deinterleaver by changing the operation of the address generation part of the register arrays. Changes in the size of symbols can also be easily adapted to by modifying the size of the memories 16, 18 used in the deinterleaver 10.
As mentioned above, although the invention has been described with reference to an ultra-wideband network in accordance with the “MultiBand OFDM Physical Layer Specification” Release 1.0 from the MultiBand OFDM Alliance, the invention is applicable to any other system which uses multi-level interleaving to protect data communications between two devices. For example, the invention is also applicable to wireless, mobile and satellite communication systems, optical and magneto-optical storage systems and hard disk and digital tape storage systems.
While the invention has been illustrated and described in detail in the drawings and foregoing description, such illustration and description are to be considered illustrative or exemplary and not restrictive; the invention is not limited to the disclosed embodiments.
Other variations to the disclosed embodiments can be understood and effected by those skilled in the art in practicing the claimed invention, from a study of the drawings, the disclosure, and the appended claims. In the claims, the word “comprising” does not exclude other elements or steps, and the indefinite article “a” or “an” does not exclude a plurality. A single processor or other unit may fulfill the functions of several items recited in the claims. The mere fact that certain measures are recited in mutually different dependent claims does not indicate that a combination of these measured cannot be used to advantage. A computer program may be stored/distributed on a suitable medium, such as an optical storage medium or a solid-state medium supplied together with or as part of other hardware, but may also be distributed in other forms, such as via the Internet or other wired or wireless telecommunication systems. Any reference signs in the claims should not be construed as limiting the scope.
Number | Date | Country | Kind |
---|---|---|---|
06120514 | Sep 2006 | EP | regional |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/IB2007/053643 | 9/10/2007 | WO | 00 | 3/12/2009 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2008/032261 | 3/20/2008 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5627935 | Kim | May 1997 | A |
5946357 | Sandin et al. | Aug 1999 | A |
6363026 | Su et al. | Mar 2002 | B1 |
6732316 | Tong et al. | May 2004 | B1 |
7149207 | Okumura et al. | Dec 2006 | B2 |
7342915 | Okumura et al. | Mar 2008 | B2 |
7428667 | Kawahara et al. | Sep 2008 | B2 |
7469365 | Kawahara et al. | Dec 2008 | B2 |
7900097 | Wellig et al. | Mar 2011 | B2 |
8082483 | Nguyen | Dec 2011 | B2 |
20040178934 | Balakrishnan et al. | Sep 2004 | A1 |
20040268207 | Sharma | Dec 2004 | A1 |
20050034046 | Berkmann et al. | Feb 2005 | A1 |
20050152327 | Erlich et al. | Jul 2005 | A1 |
Number | Date | Country |
---|---|---|
2004015945 | Feb 2004 | WO |
Number | Date | Country | |
---|---|---|---|
20100042899 A1 | Feb 2010 | US |