TECHNIQUES FOR MULTIPLE-SUBCARRIER JOINT PRECODING

Information

  • Patent Application
  • 20110007828
  • Publication Number
    20110007828
  • Date Filed
    March 09, 2009
    15 years ago
  • Date Published
    January 13, 2011
    14 years ago
Abstract
A method (400) for performing a multiple-sub-carrier-joint-modulation (MSJM) precoding. The method includes grouping input information bits into bit blocks (S410); converting the bit blocks into bit vectors (S420); mapping each of the bit vectors into a symbol vector (S430); and modulating symbol vectors into data subcarriers (S440).
Description

The invention relates generally to orthogonal frequency division multiplexing (OFDM) communication systems and, more particularly, to precoding techniques performed by such systems.


The WiMedia standard defines the specifications of a media access control (MAC) layer and a physical (PHY) layer based on orthogonal frequency division multiplexing (OFDM) transmissions. The WiMedia standard enables short-range multimedia file transfers at rates up to 480 Mbps with low power consumption. The standard operates in a frequency band between 3.1 GHz and 10.6 GHz in the UWB spectrum. However, the highest data rate of the WiMedia standard rate cannot meet future wireless multimedia applications, such as HDTV wireless connectivity. An effort is being made to increase the data rates to 1 Gpbs and above.


To this end, weak (or non-channel) channel coding and higher order symbol constellation techniques have been envisioned to be used in future high data rate wireless systems. For example, the WiMedia PHY transfer rate can be increased to 960 Mbps if a ¾ convolutional code together with 16QAM modulation are used. However, precoding of the transmitted OFDM symbols is required to ensure good performance.


The precoding technique is needed to avoid loss of frequency diversity gain results from the characteristics of the OFDM transmission. Specifically, with a weak channel code, the OFDM cannot exploit the frequency diversity effectively. Therefore the channel performance is almost determined by the worst subcarrier, which has the lowest signal-to-noise-ratio (SNR). This limits the number of high data rate applications that be carried by a conventional OFDM wireless system.


To overcome this problem, a few precoding techniques have been discussed in the related art. Generally, the precoding techniques are based on jointly modulating transmit symbols onto multiple subcarriers. This allows a receiver to recover transmit symbols even when some of these subcarriers are in deep fading. Examples for precoding techniques can be found in “OFDM or single-carrier block transmissions?,” by Z. Wang, X. Ma and G. B. Giannakis published in IEEE Transactions on Communications, vol. 52, pp. 380-394 March 2004 and in “Linearly Precoded or Coded OFDM against Wireless Channel Fades,” by Z. Wang, and G. B. Giannakis published in Third IEEE Signal Processing Workshop on Signal Processing Advances in Wireless Communications, Taoyuan, Taiwan, Mar. 20-23, 2001.


The precoding is typically performed by a precoder circuit coupled to an input of an IFFT OFDM modulator of a transmitter and by a pre-decoder circuit coupled to the output of a FFT OFDM demodulator of a receiver. A well-designed complex precoder can effectively exploit the frequency diversity provided by multi-path channels. However, implementing a complex precoder increases the complexity of the transmitter and receiver as it requires more sophisticated decoding and symbol mapping techniques. For example, the use of dual carrier modulation (DCM) as a precoder requires replacing the QPSK symbol constellation to 16QAM symbol constellation.


Furthermore, to guarantee full frequency diversity (i.e., diversity order of 2) in high data rate modes, a higher constellation (e.g., 256QAM) is required. For example, if a DCM is used to jointly modulate two information symbols s(i) and s(i+50) formed using 16QAM constellation, a frequency diversity order of two is achieved as follows:






R
=




1

17




[



4


1




1



-
4




]






[




x


(
i
)







x


(

i
+
50

)





]

=


R
*

[




s


(
i
)







s


(

i
+
50

)





]


=



1

17




[



4


1




1



-
4




]


*


[




s


(
i
)







s


(

i
+
50

)





]

.








The information symbols s(i) and s(i+50) are formed using a 16QAM constellation. However, the precoding operation expands the symbol constellation to 256QAM, i.e. the constellation of the precoded symbols x(i) and x(i+50) is 256QAM.


Implementing and designing receivers and transmitters with such a high constellation without affecting the diversity gain and the overall performance of the channel is not feasible. The high constellation is a by-product of the conventional precoding techniques which jointly precode only two symbols to achieve diversity of order two.


It would be therefore advantageous to provide an efficient precoding technique for achieving a frequency diversity order of two while minimizing the size of the constellation.


Certain embodiments of the invention include a method for performing a multiple-subcarrier-joint-modulation (MSJM) precoding. The method comprises grouping input information bits into bit blocks; converting the bit blocks into bit vectors; mapping each of the bit vectors into a symbol vector; and modulating symbol vectors into data subcarriers.


Certain embodiments of the invention also include a computer-readable medium having stored thereon computer executable code for performing a multiple-subcarrier-joint-modulation (MSJM) precoding. The computer executable code causes a computer to execute the process of grouping input information bits into bit blocks; converting the bit blocks into bit vectors; mapping each of the bit vectors into a symbol vector; and modulating symbol vectors into data subcarriers.


Certain embodiments of the invention also include an orthogonal frequency division multiplexing (OFDM) transmitter for performing a multiple-subcarrier-joint-modulation (MSJM) precoding. The OFDM transmitter comprises a first serial-to-parallel (S/P) converter for converting bit blocks into bit vectors; a precoder for mapping each of the bit vectors to a symbol vector; and a second S/P converter for grouping symbol vectors and mapping the symbol vectors into data subcarriers.





The subject matter that is regarded as the invention is particularly pointed out and distinctly claimed in the claims at the conclusion of the specification. The foregoing and other features and advantages of the invention will be apparent from the following detailed description taken in conjunction with the accompanying drawings.



FIG. 1 is a block diagram of an OFDM communication system in accordance with one embodiment of the invention;



FIG. 2 is an exemplary lookup table showing the precoding of symbol vectors;



FIG. 3 is a graph showing simulation results of the multiple-subcarrier-joint-modulation (MSJM) precoding; and



FIG. 4 is a flowchart describing an exemplary method for performing the MSJM precoding implemented in accordance with an embodiment of the invention.





It is important to note that the embodiments disclosed by the invention are only examples of the many advantageous uses of the innovative teachings herein. In general, statements made in the specification of the present application do not necessarily limit any of the various claimed inventions. Moreover, some statements may apply to some inventive features but not to others. In general, unless otherwise indicated, singular elements may be in plural and vice versa with no loss of generality. In the drawings, like numerals refer to like parts through several views.



FIG. 1 shows a non-limiting and exemplary block diagram of an OFDM based wireless system 100 used to describe the principles of the invention. The system 100 jointly precodes a number of m (m>2) subcarriers to achieve a frequency diversity order of two, while maintaining a small constellation size. The system 100 may be any type of OFDM based wireless system operating according to wireless communication standards including, but not limited to, WiMedia UWB versions 1.0, 1.5 and 2.0, IEEE 802.11n, WiMax, and so on.


The system 100 comprises a transmitter 110 and a receiver 120 that communicate over a wireless medium. The transmitter 110 includes serial-to-parallel (S/P) converters 111 and 113, a precoder 112, and an OFDM modulator 114. The receiver 120 includes an OFDM demodulator 121, a parallel-to-serial (P/S) converter 122, and a pre-decoder 123. The system 100 also comprises a transmit antenna 130 and a receive antenna 140.


In accordance with principles of the invention, input information bits, preferably after being encoded and interleaved, are partitioned into bit blocks. Each bit block includes n*g bits, where ‘n’ is a number of available data subcarriers and ‘g’ is the number of bits to be transmitted per subcarrier. The S/P converter 111 converts each bit block to k bit vectors. For example, the i-th bit vector of the q-th bit block can be represented as follows:






{right arrow over (b)}
q,i
=[b
q,i(0),bq,i(1), . . . ,bq,i(m*g−1)]


The number ‘k’ is the number of data subcarriers divided by the number of jointly precoded subcarriers, i.e., n/m. Each bit vector includes a number of m*g bits.


In a preferred embodiment of the invention, the precoder 112 utilizes a lookup table to map each bit vector to a symbol vector. A symbol vector includes m symbols, and the symbol vector corresponding to the i-th bit vector of the q-th bit block may be represented as follows:






{right arrow over (s)}
q,i
=[s
q,i(i1),sq,i(i2), . . . ,sq,i(im)]


When utilizing a lookup table the values of the bit vectors {right arrow over (b)}q,i are used as table indexes to retrieve the values of the symbol vectors. The size of the lookup table is 2m*g by m. A number 2m*g is required in order to achieve a diversity order of two as for any two different bit vectors, their corresponding symbol vectors {right arrow over (s)}q,i have at least two symbols in difference. Various embodiments to generate the lookup table are described in detail below.


The symbol vectors are grouped together and mapped into ‘n’ data subcarriers by the S/P converter 113. The symbol sq,i(ie), e=1, . . . m is transmitted on the ie-th data subcarrier of the q-th OFDM symbol. The OFDM modulator 114 performs an IFFT operation to generate a time-domain transmit signal, which is then transmitted through the transmit antenna 130.


The time-domain transmit signal is received at the receiver 120 and converted to a frequency domain signal through an FFT operation performed by the OFDM demodulator 121. Then, a number of m-symbol vectors: {right arrow over (r)}q,i=[rq,i(i1), rq,i(i2), . . . , rq,i(im)]T are output by the P/S converter 122, where rq,i(ie) is the received signal of the ie-th data subcarrier of the q-th OFDM symbol and ‘T’ denotes the matrix transpose operation. The pre-decoder 123 generates information bits using the following equation:






{right arrow over (r)}
q,i=diag{{right arrow over (s)}q,i}*{right arrow over (h)}i+{right arrow over (N)}q,i  (1)


where diag{{right arrow over (s)}q,i} is a m by m diagonal matrix with the e-th diagonal element equals to sq,i(ie), e=1, . . . m, the vector {right arrow over (r)}q,i is a received symbol vector, {right arrow over (h)}i=[h(i1), h(i2), . . . h(im)]T is a channel parameter vector, where h(ie), e=1, . . . , m denotes the channel parameter of the ie-th data subcarrier, and {right arrow over (N)}q,i is an additive white Gaussian noise (AWGN) vector.


In accordance with a preferred embodiment of the invention, the pre-decoding can be simplified. In this embodiment, the receiver 120 selects at least m−1 subcarriers (from m subcarriers) having the highest signal-to-noise ratio. The symbol indices of the respective selected subcarriers are pre-decoded separately. Since the precoding technique has a diversity order of two, the pre-decoded m−1 indices are sufficient to recover the bit vector. This significantly reduces the complexity of the pre-decoding process.


Following are non-limiting examples describing the precoding techniques disclosed by the invention. In the following examples the number of jointly precoded subcarriers ‘m’ is 3, the number of available data subcarriers ‘n’ is 102, and the number of bits ‘g’ to be transmitted per subcarrier is 4. The input information bits are grouped into bit blocks, each block includes 102*4=408 bits. Then, 34 (102/3=34) bit vectors are generated, each vector includes 12 (4*3=12) bits. The bit vectors are: {right arrow over (b)}q,i=bq,i(0), bq,i(1), . . . , bq,i(11), i=0, 1, . . . , 33.


As the input bit vector {right arrow over (b)}q,i has 12 bits, the number of codewords required for the precoding is 212=642. Therefore, the minimum constellation size for symbols sq(i) to achieve diversity order of two is 64. Thus, the precoding technique according to the invention increases the constellation size by a power of 2 (e.g., 16QAM to 64QAM) in comparison to other conventional techniques, such as the DCM that increases the constellation size at least by a power of 4 (e.g., 16QAM to 256QAM).


The precoder 112 maps each bit vector {right arrow over (b)}q,i to a symbol vector {right arrow over (s)}q,i=[sq(i), sq(i+34), sq(i+68)], in which all three symbols are from a 64-QAM constellation. The symbols sq(i), sq(i+34), and sq(i+68) are transmitted on the i-th, (i+34)-th and (i+68)-th data subcarriers of the q-th OFDM symbol, respectively. As mentioned above, the mapping is performed using a lookup table. In this example, the table includes 212 (or 642) rows and 3 columns. FIG. 2 is an example of a lookup table generated in accordance with one embodiment of the invention. The values c1, c2, and c3 are the values of the symbols in sq(i), sq(i+34), and sq(i+68) in the symbol vector. To generate the lookup table, the values of c1 and c2 columns are computed using the value of







[



b

q
,
i




(
0
)


,


b

q
,
i




(
1
)


,





,


b

q
,
i




(
5
)



]



(




j
=
0

5





b

q
,
i




(
j
)




2
j



)





for c1 and the values of







[



b

q
,
i




(
6
)


,


b

q
,
i




(
7
)


,





,


b

q
,
i




(
11
)



]



(




j
=
0

5





b

q
,
j




(

j
+
6

)




2
j



)





for c2.


In accordance with one embodiment of the invention, the mapping values for c3 is determined using any Latin 2-hypercube of order 64, (or a 64 by 64 Latin square matrix). A Latin z-hypercube of order v is a z-dimensional array in which each row is a permutation of symbols 0, 1, . . . , v−1. A Latin matrix is an ‘I by I square matrix with cells containing ‘I’ different symbols (from 0 to (I−1)) where no symbol occurs more than once in any row or column. Specifically, the d-th element of c3 column, where d−1=x*64+y, 0≦x,y≦63, is the (x+1,y+1)-th element of a 64 by 64 Latin square matrix. As an example the following Latin matrix can be used for mapping the values of c3:






M
=

[



0


63


62





1




63


62


61





0




62


61


60





63





















1


0


63





2



]





This matrix allows to express the values of c3 using a non-binary operation, i.e., c3=mod(64−c2−c1, 64). The c3 values shown in FIG. 2 are computed using this modulo-64 operation. The precoding allows achieving diversity order of two as any two different rows of the lookup table include at least two symbols in difference.


It would be noted that any type (special or non-special) Latin matrices can be used to determine the values of the symbols. It should be further noted that different Latin matrices and different symbol constellation labelling (i.e., mapping between the symbol indices and the points on the symbol constellation) may result with different precoding techniques, which may have different performance. This allows selecting constellation labelling and a Latin square matrix to optimize the performance of the system.


In another embodiment the c3 values may be determined according to a binary operation defined as follows:





[pq,i(0),pq,i(1), . . . ,pq,i(5)]=[bq,i(0),bq,i(1), . . . ,bq,i(11)]*G,


Where G equals to:






G
=

(



1


1


0


1


0


0




1


0


1


0


1


0




1


1


0


1


1


1




0


1


1


0


0


1




1


1


0


0


0


1




1


0


0


1


0


1




0


0


1


0


1


1




0


1


0


1


0


1




1


1


1


0


1


1




1


0


0


1


1


0




1


0


0


0


1


1




1


0


1


0


0


1



)





and the values of c3 column can be computed using the value of [pq,i(0), pq,i(1), . . . , pq,i(5)] as







(




j
=
0

5





p

q
,
i




(
j
)




2
j



)

.




When the mapping of bit vectors to a symbol vectors is completed, all the 34 output symbol vectors {right arrow over (s)}q,i, i=0, 1, . . . , 33 are grouped together and mapped onto 102 data subcarriers.



FIG. 3 shows simulation results demonstrating the performance of the precoding technique implemented in accordance with one embodiment of the invention. In the simulations, 102 data subcarriers are used. The precoding (“MSJM precoding”) is done using a combination of a predefined Latin matrix and a Gray QAM labelling under the assumption that all data subcarriers channels are i.i.d. Rayleigh fading channels. As can be noticed, the gain (indicated by a curve 310) of the MSJM decoding (respective to the MSJM precoding) is better than the gain of the conventional DCM precoding with 16QAM (as indicated by a curve 320). Using the simplified precoding/pre-decoding technique results in gain performance (as indicated by a curve 330) which is lower than the MSJM precoding. However the pre-decoding is less complex. It will be appreciated that the inventive technique has a good performance-complexity trade-off.



FIG. 4 shows a non-limiting flowchart 400 describing the method for performing a multiple-subcarrier-joint-modulation (MSJM) precoding implemented in accordance with an embodiment of the invention. At S410, input information bits are grouped into bit blocks, each of which includes a number of n*g bits. The parameter ‘n’ is the number of available subcarriers, and ‘g’ is the number of bits to be transmitted per carrier. At S420, bit blocks are converted into bit vectors. The number of bit vectors is equal to the number of data subcarriers divided by the number of jointly precoded subcarriers, i.e., n/m. At S430, each bit vector is mapped into a symbol vector that includes a number of m symbols. In a preferred embodiment the mapping is performed using a lookup table having 2g*m rows and m columns.


To construct the lookup table, first a table that includes Qm−1 rows and m columns is generated. The parameter Q is the constellation size and is determined to be the minimum integer size that satisfies the equation:





log2 Q≦m*g/(m−1).


The values of the first ‘m−1’ columns are set using one of the techniques mentioned in detail above. Then a Latin (m−1)-hypercube of order Q is inserted (row-wise) to the last (m) column. The last step in constructing the lookup table includes selection from the Qm−1 by m table, 2g*m different rows.


At S440, the symbol vectors are modulated onto the ‘n’ data subcarriers and transmitted. It is appreciated that the MSJM precoding enables to increase the data rates of transmission with improved gain performance and minimum symbol constellation expansion.


The foregoing detailed description has set forth a few of the many forms that the invention can take. It is intended that the foregoing detailed description be understood as an illustration of selected forms that the invention can take and not as a limitation to the definition of the invention. It is only the claims, including all equivalents that are intended to define the scope of this invention.


Most preferably, the principles of the invention are implemented as a combination of hardware, firmware and software. Moreover, the software is preferably implemented as an application program tangibly embodied on a program storage unit or computer readable medium. The application program may be uploaded to, and executed by, a machine comprising any suitable architecture. Preferably, the machine is implemented on a computer platform having hardware such as one or more central processing units (“CPU”), a memory, and input/output interfaces. The computer platform may also include an operating system and microinstruction code. The various processes and functions described herein may be either part of the microinstruction code or part of the application program, or any combination thereof, which may be executed by a CPU, whether or not such computer or processor is explicitly shown. In addition, various other peripheral units may be connected to the computer platform such as an additional data storage unit and a printing unit.

Claims
  • 1. A method (400) for performing a multiple-subcarrier-joint-modulation (MSJM) precoding, comprising: grouping input information bits into bit blocks (S410);converting the bit blocks into bit vectors (S420);mapping each of the bit vectors into a symbol vector (S430); andmodulating symbol vectors into data subcarriers (S440).
  • 2. The method of claim 1, wherein each symbol vector includes a number of m symbols, wherein m equals to the number of jointly precoded subcarriers.
  • 3. The method of claim 2, wherein each bit vector includes a number of m*g bits, wherein g is the number of bits to be transmitted per subcarrier.
  • 4. The method of claim 3, wherein a minimum constellation size requires that modulating the symbols is a function of the number of bits within a bit vector.
  • 5. The method of claim 4, wherein the mapping of each of the bit vectors into the symbol vector is performed using a lookup table, wherein a number of rows in the lookup table equals to the constellation size to a power of (m−1) and a number of columns in the lookup table equals to the number of symbols in a symbol vectors.
  • 6. The method of claim 5, further comprising generating the lookup table by: generating a table, wherein a number of rows and columns of the table equal to the number of rows and columns of the lookup table;determining mapping values for first m−1 symbols in the symbol vector by setting values in first m−1 columns in the table;row-wise inserting a Latin (m−1)-hypercube in the last column of the table; andselecting rows having different values to construct the lookup table, wherein any two different rows in the lookup table include at least two symbols in difference.
  • 7. The method of claim 6, wherein the values of first m−1 columns are determined using at least one of: values of bits of a bit vector, binary operations, non-binary operations, and a constellation labelling.
  • 8. A computer-readable medium having stored thereon computer executable code for performing a multiple-subcarrier-joint-modulation (MSJM) precoding, comprising: grouping input information bits into bit blocks (S410);converting the bit blocks into bit vectors (S420);mapping each of the bit vectors into a symbol vector (S430); andmodulating symbol vectors into data subcarriers (S440).
  • 9. An orthogonal frequency division multiplexing (OFDM) transmitter (110) for performing a multiple-subcarrier-joint-modulation (MSJM) precoding, comprising: a first serial-to-parallel (S/P) converter (111) for converting bit blocks into bit vectors;a precoder (112) for mapping each of the bit vectors to a symbol vector; anda second S/P converter (113) for grouping symbol vectors and mapping the symbol vectors into data subcarriers.
  • 10. The OFDM transmitter of claim 9, further comprising an OFDM modulator (114) for generating a time-domain signal to be transmitted over a wireless medium.
  • 11. The OFDM transmitter of claim 9, wherein each symbol vector includes a number of m symbols, wherein m is equal to the number of jointly precoded subcarriers.
  • 12. The OFDM transmitter of claim 11, wherein each bit vector includes a number of m*g bits, wherein g is the number of bits to be transmitted per subcarrier.
  • 13. The OFDM transmitter of claim 12, wherein the mapping of each of the bit vectors into a symbol vector is performed using a lookup table.
  • 14. The OFDM transmitter of claim 13, wherein any two different rows of the lookup table include at least two symbols in difference.
  • 15. The OFDM transmitter of claim 14, wherein values of columns in the lookup table are determined using at least one of: a Latin hypercube, a Latin matrix, values of bits of a bit vector, binary operations, non-binary operations, and a constellation labelling.
Parent Case Info

This application claims the benefit from U.S. Provisional Application No. 61/035,142 filed on Mar. 10, 2008 and U.S. Provisional Application No. 61/157,230 filed on Mar. 4, 2009.

PCT Information
Filing Document Filing Date Country Kind 371c Date
PCT/IB09/50971 3/9/2009 WO 00 8/17/2010
Provisional Applications (2)
Number Date Country
61035142 Mar 2008 US
61157230 Mar 2009 US