DESIGN OF THE ALAMOUTI SCHEME FOR A MIMO RECEIVER AND ITS IMPLEMENTATION ON AN FPGA DESIGN OF THE ALAMOUTI SCHEME FOR A MIMO RECEIVER AND ITS IMPLEMENTATION ON AN FPGA Jorge Silva Instituto Superior de Engenharia de Lisboa (ISEL), Área Departamental de Engenharia Electrónica e Telecomunicações e de Computadores (ADEETC), Lisboa, Portugal 29482@alunos.isel.pt Pedro Pinho Instituto Superior de Engenharia de Lisboa (ISEL), Área Departamental de Engenharia Electrónica e Telecomunicações e de Computadores (ADEETC), Lisboa, Portugal Instituto de Telecomunicações - Campus de Santiago, Aveiro, Portugal ppinho@deetc.isel.pt Mário Véstias Instituto Superior de Engenharia de Lisboa (ISEL), Área Departamental de Engenharia Electrónica e Telecomunicações e de Computadores (ADEETC), Lisboa, Portugal INESC-ID, Libsoa, Portugal mvestias@deetc.isel.pt Keywords: Alamouti, MIMO Receiver, FPGA. Abstract: This paper analyses the Alamouti scheme for different antenna configurations and different modulation types, namely BPSK, QPSK and QAM. All configurations were modeled and simulated in MATLAB. A MIMO receiver for a 2×1 antenna configuration and BPSK modulation was implemented in a FPGA. The FPGA results indicate that the Alamouti scheme is a good design option for hardware implementation of a MIMO receiver. The receiver uses only about 10% of the resources of a medium-sized FPGA and achieves almost 300 Msymbols per second. 1 Introduction Currently, there is an increasing offer of services based on wireless communications, which require high speeds to ensure the quality of service without compromising the transmission power of the system or the bandwidth. MIMO (Multiple Input Multiple Output) technology offers increased capacity to these systems without requiring an increase in bandwidth or transmitted power. This technology is based on the channel space exploration using multiple anten- nas at both ends of the communications system, offer- ing various gains: beam forming, array gain, spatial diversity gain, spatial multiplexing gain and interfer- ence reduction. The spatial diversity technique is the most effi- cient and effective to combat the effects of multi- path fading, achieving in this way an improved sys- tem reliability. Spatial diversity gain arises from the use of space-time coding of the transmitted/received signals, where time, which is the natural dimension of digital communication systems, is complemented with the spatial dimension, from the use of multiple antennas on the part of the system. There are sev- eral space-time encoding schemes [2], as for example: Space-Time Block Codes (STBC), Space-Time Trel- lis Codes (STTC), Space-Time Turbo Trellis Codes (STTTC) and Layered Space-Time Codes (LSTC). In STBC it is possible to reach a maximum order of spa- tial diversity (equals the number of transmit antennas, MT ) using a simple and linear processing on the de- coding. A well-known type of STBC scheme is the Alamouti Scheme [1]. The paper is organized as follows. In section 2, the Alamouti scheme is briefly described. In section 3, we describe the implementation of a MIMO receiver based on the Alamouti scheme on an FPGA. Section 4 reports the results of the implementation in terms of area and performance. Finally, section 5 concludes the paper and proposes some future improvements. i-ETC: ISEL Academic Journal of Electronics, Telecommunications and Computers CETC2011 Issue, Vol. 2, n. 1 (2013) ID-6 http://journals.isel.pt/index.php/IAJETC 2 Alamouti Scheme The original Alamouti scheme [1] is a transmit di- versity technique using two transmitting antennas and one receiving antenna, and can be divided into three parts: (1) the encoding and transmission sequence of information symbols at the transmitter, where the bits of information are encoded into symbols in the do- mains of space and time and then transmitted, one for each transmit antenna; (2) the scheme for combining the received signals at the receiver, which prepares the symbols for the maximum likelihood detector and (3) the decision rule for maximum likelihood detection for the sent symbols. Figure 1 shows the Alamouti scheme for the 2×1 antenna configuration. In this transmitting scheme, two signals are simul- taneously transmitted from both antennas (antenna one and two) in two steps. In the first step, sig- nals s1 and s2 are transmitted from antennas one and two, respectively. Then, in the second step antenna one transmits −s2∗ and antenna two transmits s∗1 (the mark * stands for the conjugate of the symbol) (see figure 1). At the receiver side, two signals are received, r0 and r1, from antenna one and antenna two, respectiv- elly. These signals are expressed as: r0 = h0S0 + h1S1 + n0 (1) r1 =−h0S∗1 + h1S ∗ 0 + n1 (2) where h0 and h1 are the channel responses between each of the transmiting antenna and the receiving an- tenna. n0 and n1 represent complex noise and inter- ference of the channel. Estimations of the sent signals, s̃0 and s̃1, are then determined from the received signals and also using the channel responses, h0 and h1, as follows: s̃0 = (|h0|2 +|h1|2)S0 + h∗0n0 + h ∗ 1n1 (3) s̃1 = (|h0|2 +|h1|2)S1 −h0n∗1 + h ∗ 1n0 (4) This operation is implemented at the receiver by a block designated combiner. Finally, the sent bits are obtained from the re- ceived symbols using a demodulator (the demodulator block in figure 1). The Alamouti scheme can be generalized to the case of two transmitting antennas and NR receiving antennas, achieving in this way a diversity gain of 2× NR. For example, in the 2×2 antenna configuration the received signals, r0, r1, r2 and r3, are expressed as: r0 = h0S0 + h1S1 + n0 (5) r1 =−h0S∗1 + h1S ∗ 0 + n1 (6) r2 = h2S0 + h3S1 + n2 (7) r3 =−h2S∗1 + h3S ∗ 0 + n3 (8) where h0, h1, h2 and h3 are the channel responses be- tween each of the transmiting antennas and receiving antennas. The combiner would then calculate an estimative of the sent symbols from these signals as follows: s̃0 = (|h0|2 +|h1|2 +|h2|2 +|h3|2)S0 +h∗0n0 + h1n ∗ 1 + h ∗ 2n2 + h3n ∗ 3 s̃1 = (|h0|2 +|h1|2 +|h2|2 +|h3|2)S1 −h0n∗1 + h ∗ 1n0 −h2n ∗ 3 + h ∗ 3n2 (9) The Alamouti scheme for different antenna con- figurations was implemented in MATLAB in order to validate their theoretical concepts. Figure 2 presents the Alamouti scheme for multiple antenna configura- tions for BPSK modulation.   Figure 2: Alamouti scheme for various antenna configura- tions using BPSK. An important aspect is the difference in power be- tween the configuration of one transmitting antenna and two receiving antennas (1×2) to two transmitting antennas and one receiving antenna (2×1). Consid- ering that the transmitted power is normalized to 1, the power transmitted by each transmit antenna in the case of the 2×1 is half the power transmitted by the antenna of the 1×2 case. This means that there is then a 3 dB difference between the 1×2 and 2×1 con- figurations. The increase in the number of receiving antennas also makes the order of diversity increases, 2×NR. The Alamouti scheme was also implemented with modulations QPSK and 16 QAM. In Figure 3 it can J. Silva et al. | i-ETC - CETC2011 Issue, Vol. 2, n. 1 (2013) ID-6 i-ETC: ISEL Academic Journal of Electronics, Telecommunications and Computers http://journals.isel.pt/index.php/IAJETC bits [ ]10 SS Space-Time Coder Modulator [ ]*10 SS − [ ]*01 SS + 1 0 n n Combiner r 0h 1 h ~ 0S ~ 1S Demodulator 0h 1h Alamouti transmitter bits Alamouti receiver Figure 1: Alamouti scheme. be seen that modulations with higher levels require a better SNR ratio, that is, for the same BER, a higher modulation has a higher SNR.  Figure 3: Alamouti scheme with BPSK, QPSK and QAM modulations. 3 FPGA receiver for a 2×1 antenna configuration with BPSK In this section we desribe the FPGA implemen- tation of the Alamouti receiver for a 2 × 1 antenna configuration and BPSK modulation (see figure 4). Rx 1 0 n n Combiner r 0h 1h ~ 0S ~ 1S Demodulator bits [ ]10 , rr [ ]10 , ss Figure 4: Alamouti receiver scheme. From section 2 we know that the received signals in figure 4 are given by r0 = h0S0 + h1S1 + n0 (10) r1 =−h0S∗1 + h1S ∗ 0 + n1 (11) and the estimated symbols at the receiver are given by s̃0 = (|h0|2 +|h1|2)S0 + h∗0n0 + h ∗ 1n1 (12) s̃1 = (|h0|2 +|h1|2)S1 −h0n∗1 + h ∗ 1n0 (13) From equations (3) and (4), we see that s̃0 and s̃1 are the result of mathematical operations between complex numbers. The complex multiplication be- tween two complex numbers, x and y, is given by: x×y = (a + bi)×(c + di) = (a×c−b×d)+(a×d + b×c)i Based on equation (5) the block diagram of the complex multiplier is given in figure 5. reala imga realb imgb realout imgout Figure 5: Block diagram of a complex multiplier. This complex multiplier will serve as the basis for the construction of the combiner block (see figure 6). To recover the original transmitted bits from s̃0 and s̃1 is then necessary to carry out the demodula- tion of the received symbols. For the demodulation method we have used hard decision. Using the hard decision process to perform the BPSK demodulation, it is enough to consider only the most significant bit (MSB) of the real part of the complex symbol, that is, the signal bit. If the real part of the estimated symbol is positive, then the most significant bit of the symbol is a ’0’. On the other side, if the real part of the es- timated symbol is negative, then the most significant J. Silva et al. | i-ETC - CETC2011 Issue, Vol. 2, n. 1 (2013) ID-6 i-ETC: ISEL Academic Journal of Electronics, Telecommunications and Computers http://journals.isel.pt/index.php/IAJETC Size LUT DSP Freq Throughput 16 bits 2058 (6%) 8 (4%) 29 MHz 29 Msymbols/s 23 bits 2986 (9%) 8 (4%) 24 MHz 24 Msymbols/s Table 1: FPGA results for a 2×1 antenna configuration with BPSK without pipeline. Size LUT DSP Latency Freq Throughput 16 bits 2268 (7%) 8(4%) 11 285 MHz 285 Msymbols/s 23 bits 3230 (10%) 8(4%) 17 263 MHz 263 Msymbols/s Table 2: FPGA results for a 2×1 antenna configuration with BPSK with pipeline. real r0 img r0 real r1 img r1 real h 0 img h0 real h1 img h1 complex multiplication complex multiplication complex multiplication complex multiplication realout realout realout realout realout realout 0 ~ S 1 ~ S 0 * 0 rh × 0 * 1 rh × * 11 rh × * 10 rh × Figure 6: Block diagram of the Alamouti receber using BPSK modulation. bit is a ’1’. Therefore, if the MSB is ’0’, then the recovered bit is ’0’, otherwise is ’1’. In this implementation, all numbers were repre- sented in two different custom floating-point formats: 16 bits (5 bits for the exponent and 11 bits for the mantissa) and 23 bits (6 bits for the exponent and 17 bits for the mantissa). 4 Results The system was implemented in a Virtex4-SX35 FPGA with speed grade -12. Two architectural im- plementatiosn were considered: with and without pipeline (see tables 1 and 2). The results show that the receiver uses less than 10% of the available resources of a medium sized FPGA. Wihout pipeline the receiver decodes upto 29 Msymbols per second. The pipelined version in- creases the decode ratio to about 10 times more with only a marginal increase in the utilized resources. 5 Conclusion In this work we have modulated and simulated in MATLAB the Alamouti scheme for various antenna configurations and different modulations. The results are as expected and show the advantages of using this STBC scheme. The good throughputs achieved when implemented in an FPGA even using floating point arithmetic and multiple antennas show that the method is a good design option for a MIMO imple- mentation using an STBC scheme. In the future, we will do a detailed study about the precision of the used arithmetic in order to improve the area and throughput of the hardware implementation. REFERENCES [1] S. M. Alamouti. A simple transmit diversity technique for wireless communications. IEEE Journal on Se- lected Areas in Communications, 16:1451–1458, 1998. [2] M. Jankiraman. Space-Time Codes and MIMO Systems. Artech House, Boston-London: UK, 2004. J. Silva et al. | i-ETC - CETC2011 Issue, Vol. 2, n. 1 (2013) ID-6 i-ETC: ISEL Academic Journal of Electronics, Telecommunications and Computers http://journals.isel.pt/index.php/IAJETC