This invention relates to bit interleaver and de-interleaver apparatus, methods and processor control code for use in MIMO (Multiple-input multiple-output) communications systems, in particular MIMO systems employing OFDM (orthogonal frequency division multiplexing).
A bit interleaver is a hardware structure commonly used with error correction codes such as convolutional codes to counteract the effect of burst errors. Burst errors occur on some physical channels such as fading channels which are typical for both indoor and outdoor wireless environments. In such channels, if the channel is in a deep fade, caused by multipath propagation and/or Doppler spread, a large number of bit errors at the receiver occur in sequence. A bit interleaver takes the bits to be transmitted as input and outputs the same bits in a different sequence. The inverse operation (de-interleaving) is performed at the receiver and re-arranges the bits to the correct order. The effect of interleaver is that the location of bit errors looks random and is distributed over the whole bitstream. In other words, it avoids a local concentration of many errors by dispersing the errors over the whole bitstream. This facilitates error correction and detection and is commonly used in communication systems such as 802.11a.
The 802.11a standard uses the OFDM technique, which transmits 52 equally spaced (over frequency) orthogonal subcarriers (48 with 4 pilot subcarriers, out of 64 possible subcarrier slots).
a shows a similar OFDM system 300 employing MIMO, in which like elements to those of
a and 3c show MIMO systems that map symbols to antennas in a “multiplexing” fashion. Thus referring to
As explained above, the performance of communication systems employing forward error correction (FEC) codes can be improved by bit interleaving, which involves creating a permutation of the coded bit stream so that bits that were adjacent to each other when leaving the encoder are separated during transmission over the channel. It is common to define such a permutation mathematically.
It is helpful for understanding the invention to review the interleaving and de-interleaving processes defined in the IEEE Standard 802.11a, Wireless LAN Medium Access Control (MAC) and Physical Layer (PHY) specifications High-speed Physical Layer in the 5 GHz Band, 1999 (hereby incorporated by reference). The interleaver can be summarised as a two stage interleaver designed to ensure that consecutive bits are mapped to every third OFDM subcarrier (first stage) and also mapped to different bit positions in the constellation (second stage). Other OFDM-based wireless standards such as IEEE802.11g and Hiperlan/2 (ETSI TS 101 475 (BRAN), HIPERLAN TYPE 2, Physical (PHY) Layer, 2001) use the same interleaving scheme.
The first 802.11a interleaver stage comprises a first permutation defined by the rule:
π(i)=(Ncbps/16)(i mod 16)+floor(i/16)
where i=0 . . . Ncbps−1 is the position of the input bit and π(i) is its position after the permutation, and floor(parameter) is the largest integer not exceeding the parameter.
This first stage of the 802.11a interleaver is the so-called classical “LR/TB” block interleaver described in, for example Section 3.2 of “Turbo Coding” by Chris Heegard and Stephen B. Wicker, Kluwer Academic Publishers, 1999. Here LR/TB stands for Left-Right/Top-Bottom, which describes the way the bits are written and read during the operation of the interleaver: bits are read-in as rows of a 2-D matrix and read-out as columns.
a shows the structure 400 of such a classical Left-Right/Top-Bottom block interleaver. This comprises a 2-D matrix with Ncbps/16 rows and 16 columns where Ncbps is the number of bits per OFDM symbol (equivalent to the value of 4*n in
This interleaver can be rewritten in mathematical terms:
π(i)=16·i mod (Ncbps−1), i=0 . . . Ncbps−1, π(Ncbps−1)=Ncbps−1
where i is the position of the input bit. This position is multiplied by 16, the result is then divided by (Ncbps−1), and the resulting remainder is the new bit position π(i). This is equivalent to taking every 16th bit and placing them to adjacent positions.
The second 802.11a interleaver stage comprises a second permutation defined by the rule:
π(i)=s*floor(i/s)+(i+Ncbps−floor(16*i/Ncbps)) mod s
where i=0 . . . Ncbps−1 is the position of the input bit and π(i) is its position after the permutation. Here s is dependent on the constellation size—it is 3 for 64-QAM, 2 for 16-QAM, and 1 for QPSK and for BPSK or, more generally, s=max (NBPSC/2; 1).
In this second stage, the bitstream is processed in groups of s bits and a cyclic bit shifting is performed (per group), having a shift step=t mod s bits (t=0 . . . 15, increasing by 1 in every Ncbps/16 bits). This maps bits to constellation bit positions of alternating reliability.
This can be understood by considering the example of
In the general case, for a constellation that conveys M bits per symbol, denoted as the vector [b0,b1, . . . ,bM-1], the reliability of a bit being successfully received can vary according to its position within the vector and the reliability of each bit position is dependent upon the exact bit-to-symbol mapping. Reliability depends on the Euclidean distance between symbols (as plotted on the graph of quadrature component against in-phase component of
In the allocation illustrated in
c shows a diagram illustrating bit allocations for an IEEE 802.11a interleaver for a single OFDM symbol with 48 subcarriers in a system using 16 QAM modulation.
It can be seen that adjacent bits are allocated to every third subcarrier and that they alternate between bit positions b0 and b1 or between b2 and b3. The 802.11a interleaver is designed for a block size equal to the number of coded bits that are conveyed in each OFDM symbol, which can vary since 802.11a systems allow for adaptive modulation and coding.
We next review the IEEE 802.11a de-interleaver.
In de-interleaving at the receiver, the inverse process interleaving is performed. This begins with:
π−1(i)=s*floor(i/s)+(i+floor(16*i/Ncbps)) mod s, i=0 . . . Ncbps−1
This stage is the inverse of the second interleaving stage. Then the inverse of the first interleaving stage is performed:
π−1(i)=16*i−(Ncbps−1)*floor(16*i/Ncbps), i=0 . . . Ncbps−1
This second step is equivalent to implementing a classical “TB/LR” block deinterleaver, where TB/LR stands for Top-Bottom/Left-Right, which describes the way the bits are written and read during the operation of the interleaver. Bits are read-in as columns of a 2-D matrix and read-out as rows (although it will be appreciated that the labelling of rows and columns for the 2D matrix is arbitrary).
The structure of this deinterleaver is the same as the one shown in
An architecture for a block interleaver in which data is written and read word-by-word rather than bit-by-bit is described in Eric Tell and Dake Liu, “A Hardware Architecture for a Multi Mode Block Interleaver”, Proc. of the International Conference on Circuits and Systems for Communications (ICCSC), Moscow, Russia, June 2004.
Interleaving design depends on the application and thus specific designs are desirable for MIMO systems, in particular MIMO OFDM systems employing convolutional coding.
All 802.11a systems are single antenna systems, and therefore the interleaver interleaves bits transmitted over the single antenna. In a case where multiple antennas are employed (MIMO), one can imagine extending the 802.11a interleaver by separating the input stream into a number of streams equal to the number of antennas and operating the 802.11a interleaver on each stream separately; this is illustrated diagrammatically in
De-interleaving (not shown in
However the inventor has simulated the performance of this method and it appears that it does not yield good results (as illustrated later). We have previously described a number of improved systems in the Applicant's earlier related UK patent application number no. 0413687.5 filed 18 Jun. 2004. However alternative improved interleaving methods and apparatus for MIMO systems, and corresponding de-interleaving methods and apparatus, would also be useful.
According to a first aspect of the present invention there is therefore provided an interleaver for a MIMO OFDM communications system having a plurality of transmit antennas said interleaver being configured to interleave a block of N data bits comprising data for a plurality of OFDM symbols, each OFDM symbol being defined by a block of Ncbps bits, by implementing first and second interleaving functions wherein at least one of said interleaving functions is configured to interleave data bits between said blocks of Ncbps bits.
In embodiments the effect of interleaving between blocks of data bits corresponding to OFDM symbols is to interleave across antennas. Thus preferably one or both of the interleaving functions interleave across space, that is between antennas.
Preferably the interleaver comprises two stages, a first stage to implement the first interleaving function followed by a second stage to implement the second interleaving function. However in embodiments these two stages may be combined and the first and second interleaving functions implemented together, for example by means of a single look-up table (LUT).
In one embodiment the first stage of interleaving is considered to interleave over a complete block of N data bits, both across antennas and across frequency (that is across subcarriers of the OFDM symbols). Preferably the second stage also interleaves over a complete block of N data bits, and may be configured to implement a cyclical bit shift to map adjacent bits alternately to more significant and less significant bits of the modulation constellation. The cyclical bit shift may, for example, comprise a shift step which varies from a minimum value to a maximum value over substantially the length of the whole block (that is the shift increasing by 1 for successive integer fractions of the block of N bits). In this way the second stage of the interleaver may conveniently be implemented using modified 802.11a hardware or program code.
Returning again to the first interleaving stage or, more particularly to the first interleaving function, this may be configured to interleave the block of N data bits such that pairs of bits c bits apart, where c is greater than 1 and preferably equal to 16, are mapped to adjacent bits. Thus in some embodiments an interleaving function similar to that of a first stage 802.11a interleaver may be implemented, but over the complete block of N data bits. This simplifies implementation of embodiments of an interleaver according to aspects of the invention whilst maintaining an interleaving across antennas.
In other embodiments, however, the first stage of the interleaver (or the first interleaving function) may implement a first stage 802.11a interleaver for each of block bits comprising an OFDM symbol (across frequency but not across antennas) and then the results of this may be concatenated, with additional interleaving, to perform across-antenna interleaving. In this way conventional 802.11a hardware or program code may be employed and the output streams combined to interleave across antennas, thus simplifying implementation of the first stage of an interleaver embodying aspects of the present invention.
Some preferred embodiments of the interleaver may be implemented using a matrix memory block configured to store an interleaving matrix with data being written to the matrix row-by-row and read from the matrix column-by-column (or vice versa). This is a conventional approach as previously described with reference to
Any of the above described alternatives first interleaving stages may be employed with any of the above-described second interleaving stages.
In another arrangement conventional first and second 802.11a interleaving stages are combined and implemented as the first interleaver stage (or first interleaving function) on a per antenna basis. The second interleaver stage (or second interleaving function) may then combine (and interleave) the result of the first interleaving stage from across-antenna interleaving. This configuration allows the use of a single look up table interleaver for each antenna separately followed by a step of interleaving the bits across space.
One or both stages of the interleaver may be implemented in either dedicated hardware or using a software controlled processor in conjunction with appropriate processor control code, or using a bit addressable memory and a look up table in ROM, for using any combination of these techniques. In preferred embodiments of the invention which employ a matrix memory block implementation using a processor is straightforward since, in essence, all that is required is a series of write and read instructions to appropriate addresses.
The invention further provides a MIMO transmitter including an interleaver as described above, for transmitting using the plurality of transmit antennas, the interleaver being configured to interleave the block of data for a plurality of OFDM symbols across space as well, preferably, across OFDM subcarriers. Preferably the transmitter comprises a convolutional coder and preferably the interleaver is configured to interleave convolutionally coded data for transmission.
The invention further provides a method of interleaving data for a MIMO OFDM communications system having a plurality of transmit antennas, the method comprising: inputting a block of N data bits comprising data for a plurality of OFDM symbols, each OFDM symbol being defined by a block of Ncbps bits; implementing a first interleaving function on said block of N data bits, implementing a second interleaving function on said block of N data bits; and outputting data interleaved by said first and second interleaving functions; wherein at least one of said interleaving functions is configured to interleave data bits between said blocks of Ncbps bits.
In one embodiment of the method the first interleaving function interleaves across frequency (for example conventionally) and across space, and preferably the second interleaving function then interleaves across the block on N data bits (interleaving between OFDM symbols). In another embodiment of the method the first interleaving function comprises two conventional interleaving stages and is implemented per antenna, and the second interleaving function interleaves across space. In this embodiment the two first stage interleaving functions may comprise a first permutation to modulate adjacent bits onto non-adjacent OFDM subcarriers and a second permutation to map adjacent bits onto constellation bits of different significance. In another arrangement the first interleaving function interleaves across frequency and space by implementing a single permutation across data bits for a plurality of OFDM symbols for transmission by a plurality of different transmit antennas.
The invention further provides an interleaver for a MIMO OFDM communications system having a plurality of transmit antennas, the interleaver comprising: means for inputting a block of N data bits comprising data for a plurality of OFDM symbols, each OFDM symbol being defined by a block of Ncbps bits; means for implementing a first interleaving function on said block of N data bits; means for implementing a second interleaving function on said block of N data bits; means for outputting data interleaved by said first and second interleaving functions; and wherein at least one of said interleaving functions is configured to interleave data bits between said blocks of Ncbps bits.
The further provides means for implementing a complementary de-interleaver to the above described interleavers, and complementary de-interleaving methods.
Broadly speaking each function is replaced by its inverse or complementary function or mapping to provide a complementary de-interleaver or de-interleaving method. Thus the invention contemplates making such substitutions in the above described interleavers and interleaving methods.
Thus in a complementary aspect the invention further provides a de-interleaver for a MIMO OFDM communications system having a plurality of transmit antennas, said de-interleaver being configured to de-interleave N interleaved data bits comprising data for a plurality of transmitted OFDM symbols, each OFDM symbol being defined by Ncbps interleaved bits, by implementing second and first de-interleaving functions, wherein at least one of said de-interleaving functions is configured to de-interleave data permuted across said N data bits to provide a plurality of blocks of Ncbps bits each corresponding to a said OFDM symbol.
Such a de-interleaver may be implemented using a matrix memory block, writing in the data to be de-interleaved column-by-column and reading the data from the matrix row-by-row. Complementary de-interleaving structures to those described above for across space interleaving may also be implemented if needed.
The invention further provides a complementary method of de-interleaving data in a MIMO OFDM communications system, the method comprising: inputting N interleaved data bits comprising data for a plurality of transmitted OFDM symbols, each OFDM symbol being defined by Ncbps interleaved bits; implementing a second de-interleaving function on said N data bits; implementing a first de-interleaving function on said N data bits; and outputting data de-interleaved by said first and second de-interleaving functions; wherein at least one of said de-interleaving functions is configured to de-interleave data permuted across said N data bits to provide a plurality of blocks of Ncbps bits each corresponding to a said OFDM symbol.
The invention further provides a de-interleaver for de-interleaving data in a MIMO OFDM communications system, the de-interleaver comprising: means for inputting N interleaved data bits comprising data for a plurality of transmitted OFDM symbols, each OFDM symbol being defined by Ncbps interleaved bits; means for implementing a second de-interleaving function on said N data bits; means for implementing a first de-interleaving function on said N data bits; and means for outputting data de-interleaved by said first and second de-interleaving functions; wherein at least one of said de-interleaving functions is configured to de-interleave data permuted across said N data bits to provide a plurality of blocks of Ncbps bits each corresponding to a said OFDM symbol.
The invention further provides a receiver including a de-interleaver as described above, and a receiver configured to operate in accordance wit a de-interleaving method as described above.
The invention further provides a MIMO OFDM signal comprising data interleaved by the method or apparatus described above.
The above-described interleavers and de-interleavers, and interleaving and de-interleaving methods may be implemented using processor control code. This code may be provided on a data carrier such as a disk, CD- or DVD-ROM, programmed memory such as read-only memory or EEPROM (Firmware), or on a data carrier such as optical or electrical signal carrier. For many applications embodiments of the above-described interleavers, de-interleavers will be implemented on a DSP (Digital Signal Processor), ASIC (Application Specific Integrated Circuit) or FPGA (Field Programmable Gate Array). Thus code (and data) to implement embodiments of the invention may comprise code in a conventional programming language such as C, or microcode. However code to implement embodiments of the invention may alternatively comprise code for setting up or controlling an ASIC or FPGA, or code for a hardware description language such as Verilog (Trade Mark), VHDL (Very high speed integrated circuit Hardware Description Language) or SystemC. As the skilled person will appreciate such code and/or data may be distributed between a plurality of coupled components in communication with one another, for example on a network.
A communications system may be provided comprising a transmitter apparatus in accordance with any aspect of the invention and an appropriately configured receiver.
These and other aspects, preferred features and advantages of the invention will now be further described, by way of example only, with reference to the accompanying drawings, in which:
a to 3c show, respectively, first multiplexing, block, and second multiplexing arrangements for the mapping of symbols to antennas in MIMO OFDM communications systems;
a to 4c show, respectively, a known Left-Right/Top-Bottom block interleaver, the 16 QAM constellation, and a diagram illustrating bit allocations for an IEEE 802.11a interleaver for a single OFDM symbol;
a and 6b show, respectively, structures for implementing a first interleaving stage of an interleaver and for implementing a de-interleaving stage of a de-interleaver according to embodiments of the present invention;
a to 7d show, respectively, first and second alternative first interleaving stage structures of interleaver and complementary de-interleaving structures according to embodiments of the present invention;
We will first describe preferred embodiments of an interleaver, and then describe corresponding de-interleavers. The interleaver embodiments we will describe first are implemented as two-stage methods/devices but, as we describe later, the interleaving performed by the two stages in combination may be implemented using a single, unified look-up table (LUT). Whether the stages are combined or not has implications for the hardware (or processor control code) employed—depending upon the interleaving performed by each stage it can be advantageous to implement the interleaving stages separately and, in particular, one advantage of embodiments of the inventions is that they permit re-use of existing 802.11a hardware/procedures will little modification.
We first describe the first interleaving stage of a two-stage interleaving method.
In one embodiment this is defined by the rule (permutation):
π(i)=(N/16)(i mod 16)+floor(i/16)
where i=0 . . . N−1 is the position of the input bit and π(i) is its position after the permutation and floor(parameter) is the largest integer not exceeding the parameter.
Here N is the number of length of the whole block—for example, for two transmit antennas and spatial-multiplexing (i.e. symbols are directly mapped to both antennas without any space-time symbol processing and/or adding new symbols) N is equal to 2*Ncbps.
This stage of the modified 802.11a interleaver is equivalent to a process operating on a 2-D interleaving matrix with N/16 rows and 16 columns and can be rewritten in mathematical terms:
π(i)=(16·i) mod (N−1), i=0 . . . N−1, π(N−1)=N−1
where i is the position of the input bit. This position is multiplied by 16. The result is then divided by (N−1) and the resulting remainder is the new bit position π(i). This is equivalent to taking every 16th bit and placing them to adjacent positions.
Referring to
b shows the structure of a de-interleaver 650 which, as can be seen, is similar to that of the interleaver, comprising a matrix memory storing a matrix of data bits 652, an input 654 to the matrix, an output 656 from the matrix and a controller 658, optionally under the control of stored code 660. The de-interleaver operates in a complementary manner to the interleaver and thus a de-interleaving procedure is followed to load-in the bits received from the Space-Time decoder and read-out the bits. More particularly, instead of a Left-Right/Top-Bottom write/read procedure the bits are written in from Top to Bottom, column after column and read-out from Left to Right, row after row. Thus, the de-interleaving matrix 652 has the same dimensions as the interleaving matrix 602 and only the loading/reading procedure need be different. For this reason a de-interleaver and an interleaver may conveniently be implemented together, using shared hardware resources, if desired.
Alternatively an interleaver (and de-interleaver) may be implemented using a look-up table, in effect hard-wired logic.
In an alternative, preferred embodiment the first interleaving stage is implemented using an 802.11a resource. In embodiments it is possible to use only one instance of an 802.11a first stage to implement the first stage of the present interleaver.
Referring to
The first stage of a conventional 802.11a interleaver is performed for each block of Ncbps bits by means of separate interleavers 702a,b, as described above with reference to
b again shows another structure of an interleaver 750 configured to implement a first interleaving stage using a plurality of 802.11a interleaver instances 752a,b. In
With the above described methods of implementing the first stage of the present interleaver it is possible to use an 802.11a resource only once for each antenna. This reduces hardware complexity, since it is only necessary to implement one 802.11a first interleaver stage and a concatenation function, and improved performance as compared with the technique described in
We next describe the second interleaving stage of the two-stage interleaving method.
In a preferred embodiment this is defined by the rule (permutation):
π(i)=s*floor(i/s)+(i+N−floor(16*i/N)) mod s
where i=0 . . . N−1 is the position of the input bit and π(i) is its position after the permutation. Here s is selected dependent upon the constellation size, preferably in the same way as in a conventional 802.11a interleaving scheme as described above (in particular, 3 for 64-QAM, 2 for 16-QAM, 1 for either QPSK or BPSK).
In this second interleaving stage, the bitstream is processed in groups of s bits and a cyclical bit shift is performed (per group), having a shift step=t mod s bits (t=0 . . . 15, increasing by 1 in every N/16 bits). This is similar to the second stage of a conventional 802.11a interleaver, except that the variability of t across the bit stream is different since N defines the length of a block of bits to be multiplexed across (preferably all) the antennas.
To implement a complete interleaver a first interleaving stage as described above (in either of the two basic versions) is followed by a second interleaving stage as described above.
In some implementations the two interleaving stages may be unified into a single Look-Up Table. Then the first described embodiment of the first interleaving stage may be employed in conjunction with the second interleaving stage as the second described embodiment of the first interleaving stage does not lend itself to LUT-based implementation (because the intention there is to reduce complexity by employing existing 802.11a hardware and/or code).
However a single look-up table interleaver may be used for each antenna separately, for example to implement both the first and second 802.11a interleaving stages for each antenna separately, and then the procedure/structure of
Where “multiplexed” mapping of ST-encoded symbols to antennas is employed (as shown in
We next describe corresponding de-interleaving methods and de-interleaver architectures. Broadly speaking these are complementary to those described above and will therefore be more briefly described. Again the de-interleavers operate upon a block of data bits N comprising data transmitted by all the transmit antennas, “multiplexed” mapping of ST-encoded symbols to antennas being assumed for the purposes of the discussion.
Thus in de-interleaving at the receiver, the inverse process of interleaving is performed, that is:
π−1(i)=s*floor(i/s)+(i+floor(16*i/N)) mod s, i=0 . . . N−1
This stage is the inverse of the second interleaving stage.
The inverse of the first interleaving stage is then performed. When the first described embodiment of the first interleaving stage has been employed a suitable de-interleaving operation is:
π−1(i)=16*i−(N−1)*floor(16*i/N), i=0 . . . N−1
This step corresponds to implementing a TB/LR (Top-Bottom/Left-Right) block de-interleaver, TB/LR describing the way the bits are written into and read from matrix during the operation of the interleaver. Thus, referring again to
When the second described embodiment (which concatenates 802.11a resources) of the first interleaving stage is employed, the de-interleaving inverse of this stage is complementary to that previously described, except that the bits are input from top to bottom (concatenating the several 802.11a resources vertically) and read-out from left to right, row after row. This is shown in
Thus, referring to
Transceiver 800 comprises a plurality of transceive antennas 802a,b (of which two are shown in the illustrated embodiment) each coupled to a respective transmit/receive RF stage 804a,b (duplexers not shown for clarity of illustration), and thence to respective analogue-to-digital/digital-to-analogue converters 806a,b and to a digital signal processor (DSP) 808. DSP 808 will typically include one or more processors 808a and some working memory 808b. The DSP 808 has a data input/output 810 and an address, data and control bus 812 to couple the DSP to permanent program memory 814 such as flash RAM or ROM. Permanent program memory 814 stores code and optionally data structures or data structure definitions for DSP 808.
As illustrated program memory 814 includes channel encoder and puncturing code 814a, interleaver code 814b, ST encoding and OFDM modulation code 814c, MIMO channel estimation code 814d, OFDM demodulation and ST decoding code 814e, deinterleaver code 814f, and channel decoder code 814g. Depending upon the implementation the interleaver (and de-interleaver) code may simply comprise an interface to an 802.11a hardware resource followed by concatenation code to perform concatenation as described above. Optionally the code in permanent program memory 814 may be provided on a carrier such as an optical or electrical signal carrier or, as illustrated in
The data input/output 810 of DSP 808 couples to further data processing elements of receiver 800 (not shown in
The transmitter rf output stage and receiver front-end will generally be implemented in hardware whilst the receiver processing will usually be implemented at least partially in software, although one or more ASICs and/or FPGAs may also be employed. The skilled person will recognise that all the functions of the receiver could be performed in hardware and that the exact point at which the signal is digitised in a software radio will generally depend upon a cost/complexity/power consumption trade-off.
The curves of
All interleavers assume the “multiplexing” mapping from ST-coded symbols to antennas shown in
A random interleaver is a structure which performs random permutations of the input bits. The permutations are different for every block transmitted, that is the permutations generated during each block of transmitted bits changes with every block and is pseudo-random (based on random numbers generated from a pseudo-random source such as a computer program). The random interleaver is not a realistic hardware resource but is a reference benchmark for research on interleavers, because of its performance: Interleavers that challenge the random interleaver in performance, deliver a performance that is close to optimal.
It can be seen that the interleaver of curve 908 has a performance close to that of a random interleaver (as does the interleaver of curve 902). It can also be seen that the interleaver of curve 908 (and of curve 902) outperforms the 802.11a interleaver by 1.5 to 2 dB, thereby demonstrating the improved performance of interleavers embodying aspects of the present invention.
The above described interleaving and de-interleaving systems can be incorporated into the transmitter 100a and receiver 100b of
It will be appreciated that a general purpose transmitter or general purpose receiver can be configured to implement an embodiment of the present invention by the introduction of suitable software to be executed by a computer apparatus. To that end, an aspect of the invention comprises a product, storing computer executable instructions in a computer readable form, which in use causes a computer with suitably configurable hardware components, to operate substantially in accordance with the invention as exemplified by the described embodiment. The product may comprise a storage medium such as an optical disk, a magnetic storage medium or a storage medium of any other technology, an active component such as a removable ROM unit or other memory device such as a memory card, or may comprise a signal such as could be received in a download, the signal bearing data defining such computer readable instructions as to establish a computer executable program product. The product may also comprise an application specific integrated circuit which, when installed in a suitably configured general purpose device, renders the resultant system operable in accordance with any of the aspects of the invention exemplified by the described embodiments.
Embodiments of the invention provide low complexity interleavers and have application in wireless local area network (WLAN) communications systems such as IEEE802.11n, and in other MIMO communications systems, in particular those using convolutional channel coding.
The scope of protection claimed in the appended claims is to be determined on the basis of the description, with reference to the accompanying drawings, but not to the extent that features of the specific embodiments of the invention are to be construed as limitations on the scope of features of the claims.
Number | Date | Country | Kind |
---|---|---|---|
0424116.2 | Nov 2004 | GB | national |