 
    MATLAB课程:代码示例之Signal Processing and Communications(五)
Introduction to MIMO Systems
This example shows Multiple-Input-Multiple-Output (MIMO) systems, which use multiple antennas at the transmitter and receiver ends of a wireless communication system. MIMO systems are increasingly being adopted in communication systems for the potential gains in capacity they realize when using multiple antennas. Multiple antennas use the spatial dimension in addition to the time and frequency ones, without changing the bandwidth requirements of the system.
For a generic communications link, this example focuses on transmit diversity in lieu of traditional receive diversity. Using the flat-fading Rayleigh channel, it illustrates the concept of Orthogonal Space-Time Block Coding, which is employable when multiple transmitter antennas are used. It is assumed here that the channel undergoes independent fading between the multiple transmit-receive antenna pairs.
For a chosen system, it also provides a measure of the performance degradation when the channel is imperfectly estimated at the receiver, compared to the case of perfect channel knowledge at the receiver.
Using diversity reception is a well-known technique to mitigate the effects of fading over a communications link. However, it has mostly been relegated to the receiver end. In [ 1 ], Alamouti proposes a transmit diversity scheme that offers similar diversity gains, using multiple antennas at the transmitter. This was conceived to be more practical as, for example, it would only require multiple antennas at the base station in comparison to multiple antennas for every mobile in a cellular communications system.
This section highlights this comparison of transmit vs. receive diversity by simulating coherent binary phase-shift keying (BPSK) modulation over flat-fading Rayleigh channels. For transmit diversity, we use two transmit antennas and one receive antenna (2x1 notationally), while for receive diversity we employ one transmit antenna and two receive antennas (1x2 notationally).
The simulation covers an end-to-end system showing the encoded and/or transmitted signal, channel model, and reception and demodulation of the received signal. It also provides the no-diversity link (single transmit- receive antenna case) and theoretical performance of second-order diversity link for comparison. It is assumed here that the channel is known perfectly at the receiver for all systems. We run the simulation over a range of Eb/No points to generate BER results that allow us to compare the different systems.
We start by defining some common simulation parameters
frmLen = 100; % frame lengthnumPackets = 1000; % number of packetsEbNo = 0:2:20; % Eb/No varying to 20 dBN = 2; % maximum number of Tx antennasM = 2; % maximum number of Rx antennasand set up the simulation.
% Create comm.BPSKModulator and comm.BPSKDemodulator System objectsP = 2; % modulation orderhMod = comm.BPSKModulator;hDemod = comm.BPSKDemodulator('OutputDataType','double');% Create comm.OSTBCEncoder and comm.OSTBCCombiner System objectshAlamoutiEnc = comm.OSTBCEncoder;hAlamoutiDec = comm.OSTBCCombiner;% Create two comm.AWGNChannel System objects for one and two receive% antennas respectively. Set the NoiseMethod property of the channel to% 'Signal to noise ratio (Eb/No)' to specify the noise level using the% energy per bit to noise power spectral density ratio (Eb/No). The output% of the BPSK modulator generates unit power signals; set the SignalPower% property to 1 Watt.hAWGN1Rx = comm.AWGNChannel('NoiseMethod', 'Signal to noise ratio (Eb/No)',... 'SignalPower', 1);hAWGN2Rx = clone(hAWGN1Rx);% Create comm.ErrorRate calculator System objects to evaluate BER.hErrorCalc1 = comm.ErrorRate;hErrorCalc2 = comm.ErrorRate;hErrorCalc3 = comm.ErrorRate;% Since the comm.AWGNChannel System objects as well as the RANDI function% use the default random stream, the following commands are executed so% that the results will be repeatable, i.e., same results will be obtained% for every run of the example. The default stream will be restored at the% end of the example.s = RandStream.create('mt19937ar', 'seed',55408);prevStream = RandStream.setGlobalStream(s);% Pre-allocate variables for speedH = zeros(frmLen, N, M);ber_noDiver = zeros(3,length(EbNo));ber_Alamouti = zeros(3,length(EbNo));ber_MaxRatio = zeros(3,length(EbNo));ber_thy2 = zeros(1,length(EbNo));
The transmit diversity system has a computation complexity very similar to that of the receive diversity system.
The resulting simulation results show that using two transmit antennas and one receive antenna provides the same diversity order as the maximal-ratio combined (MRC) system of one transmit antenna and two receive antennas.
Also observe that transmit diversity has a 3 dB disadvantage when compared to MRC receive diversity. This is because we modelled the total transmitted power to be the same in both cases. If we calibrate the transmitted power such that the received power for these two cases is the same, then the performance would be identical. The theoretical performance of second-order diversity link matches the transmit diversity system as it normalizes the total power across all the diversity branches.
The accompanying functional scripts, MRC1M.m and OSTBC2M.m aid further exploration for the interested users.
PART 2: Space-Time Block Coding with Channel EstimationBuilding on the theory of orthogonal designs, Tarokh et al. [ 2 ] generalized Alamouti's transmit diversity scheme to an arbitrary number of transmitter antennas, leading to the concept of Space-Time Block Codes. For complex signal constellations, they showed that Alamouti's scheme is the only full-rate scheme for two transmit antennas.
In this section, we study the performance of such a scheme with two receive antennas (i.e., a 2x2 system) with and without channel estimation. In the realistic scenario where the channel state information is not known at the receiver, this has to be extracted from the received signal. We assume that the channel estimator performs this using orthogonal pilot signals that are prepended to every packet [ 3 ]. It is assumed that the channel remains unchanged for the length of the packet (i.e., it undergoes slow fading).
A simulation similar to the one described in the previous section is employed here, which leads us to estimate the BER performance for a space-time block coded system using two transmit and two receive antennas.
Again we start by defining the common simulation parameters
frmLen = 100; % frame lengthmaxNumErrs = 300; % maximum number of errorsmaxNumPackets = 3000; % maximum number of packetsEbNo = 0:2:12; % Eb/No varying to 12 dBN = 2; % number of Tx antennasM = 2; % number of Rx antennaspLen = 8; % number of pilot symbols per frameW = hadamard(pLen);pilots = W(:, 1:N); % orthogonal set per transmit antennaand set up the simulation.
% Create a comm.MIMOChannel System object to simulate the 2x2 spatially% independent flat-fading Rayleigh channelhChan = comm.MIMOChannel('MaximumDopplerShift', 0, ... 'SpatialCorrelation', false, ... 'NumTransmitAntennas', N, ... 'NumReceiveAntennas', M, ... 'PathGainsOutputPort', true);% Change the NumReceiveAntennas property value of the hAlamoutiDec System% object to M that is 2release(hAlamoutiDec);hAlamoutiDec.NumReceiveAntennas = M;% Release the hAWGN2Rx System objectrelease(hAWGN2Rx);% Set the global random stream for repeatabilitys = RandStream.create('mt19937ar', 'seed',55408);prevStream = RandStream.setGlobalStream(s);% Pre-allocate variables for speedHEst = zeros(frmLen, N, M);ber_Estimate = zeros(3,length(EbNo));ber_Known = zeros(3,length(EbNo));
For the 2x2 simulated system, the diversity order is different than that seen for either 1x2 or 2x1 systems in the previous section.
Note that with 8 pilot symbols for each 100 symbols of data, channel estimation causes about a 1 dB degradation in performance for the selected Eb/No range. This improves with an increase in the number of pilot symbols per frame but adds to the overhead of the link. In this comparison, we keep the transmitted SNR per symbol to be the same in both cases.
The accompanying functional script, OSTBC2M_E.m aids further experimentation for the interested users.
PART 3: Orthogonal Space-Time Block Coding and Further ExplorationsIn this final section, we present some performance results for orthogonal space-time block coding using four transmit antennas (4x1 system) using a half-rate code, G4, as per [ 4 ].
We expect the system to offer a diversity order of 4 and will compare it with 1x4 and 2x2 systems, which have the same diversity order also. To allow for a fair comparison, we use quaternary PSK with the half-rate G4 code to achieve the same transmission rate of 1 bit/sec/Hz.
These results take some time to generate on a single core. If you do not have Parallel Computing Toolbox™ (PCT) installed, we load the results from a prior simulation. The functional script ostbc4m.m is included, which, along with mrc1m.m and ostbc2m.m, was used to generate these results. If PCT is installed, these simulations are performed in parallel. In this case the functional scripts ostbc4m_pct.m, mrc1m_pct.m and ostbc2m_pct.m are used. The user is urged to use these scripts as a starting point to study other codes and systems.
[licensePCT,~] = license( 'checkout' , 'Distrib_Computing_Toolbox');if ( licensePCT && ~isempty(ver('distcomp'))) EbNo = 0:2:20; [ber11, ber14, ber22, ber41] = mimoOSTBCWithPCT(100,4e3,EbNo);else load ostbcRes.mat;end% Set up a figure for visualizing BER resultsclf(h);grid on;hold on;h.Renderer = 'zbuffer';ax = gca;ax.YScale = 'log';xlim([EbNo(1), EbNo(end)]);ylim([1e-5 1]);xlabel('Eb/No (dB)');ylabel('BER');h.NumberTitle = 'off';h.Name = 'Orthogonal Space-Time Block Coding(2)';title('G4-coded 4x1 System and Other Comparisons');% Theoretical performance of fourth-order diversity for QPSKBERthy4 = berfading(EbNo, 'psk', 4, 4);% Plot resultssemilogy(EbNo, ber11, 'r*', EbNo, ber41, 'ms', EbNo, ber22, 'c^', ... EbNo, ber14, 'ko', EbNo, BERthy4, 'g');legend('No Diversity (1Tx, 1Rx), BPSK', 'OSTBC (4Tx, 1Rx), QPSK', ... 'Alamouti (2Tx, 2Rx), BPSK', 'Maximal-Ratio Combining (1Tx, 4Rx), BPSK', ... 'Theoretical 4th-Order Diversity, QPSK');% Perform curve fittingfitBER11 = berfit(EbNo, ber11);fitBER41 = berfit(EbNo(1:9), ber41(1:9));fitBER22 = berfit(EbNo(1:8), ber22(1:8));fitBER14 = berfit(EbNo(1:7), ber14(1:7));semilogy(EbNo, fitBER11, 'r', EbNo(1:9), fitBER41, 'm', ... EbNo(1:8), fitBER22, 'c', EbNo(1:7), fitBER14, 'k');hold off;
As expected, the similar slopes of the BER curves for the 4x1, 2x2 and 1x4 systems indicate an identical diversity order for each system.
Also observe the 3 dB penalty for the 4x1 system that can be attributed to the same total transmitted power assumption made for each of the three systems. If we calibrate the transmitted power such that the received power for each of these systems is the same, then the three systems would perform identically. Again, the theoretical performance matches the simulation performance of the 4x1 system as the total power is normalized across the diversity branches.
AppendixThis example uses the following helper functions:
mrc1m.m
ostbc2m.m
ostbc4m.m
mimoOSTBCWithPCT.m
mrc1m_pct.m
ostbc2m_pct.m
ostbc4m_pct.m
S. M. Alamouti, "A simple transmit diversity technique for wireless communications", IEEE® Journal on Selected Areas in Communications, Vol. 16, No. 8, Oct. 1998, pp. 1451-1458.
V. Tarokh, H. Jafarkhami, and A.R. Calderbank, "Space-time block codes from orthogonal designs", IEEE Transactions on Information Theory, Vol. 45, No. 5, Jul. 1999, pp. 1456-1467.
A.F. Naguib, V. Tarokh, N. Seshadri, and A.R. Calderbank, "Space-time codes for high data rate wireless communication: Mismatch analysis", Proceedings of IEEE International Conf. on Communications, pp. 309-313, June 1997.
V. Tarokh, H. Jafarkhami, and A.R. Calderbank, "Space-time block codes for wireless communications: Performance results", IEEE Journal on Selected Areas in Communications, Vol. 17, No. 3, Mar. 1999, pp. 451-460.

 扫码加好友,拉您进群
扫码加好友,拉您进群 
    
 
    


 收藏
收藏













