-
Notifications
You must be signed in to change notification settings - Fork 37
/
Copy pathMainSystem.m
74 lines (51 loc) · 2.18 KB
/
MainSystem.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
function MainSystem()
sysPower = 1;
addpath(genpath('Blocks'));
%% System Initialisation
% Random seed set to 2020
rng(280);
% Initialising System Parameters
txParams = txConfig();
txParams.sysPower = sysPower;
%% Uplink Channel Estimation
% Simulate UE Uplink Tx
N = txParams.OFDM.N;
cp = txParams.OFDM.cp;
ULTx_Stream = UplinkTx(txParams);
% Adding a Single Tap Rayleigh fading channel and AWGN Noise
txParams.CSI = (1 / sqrt(2)) * (randn(1, txParams.numUsers) + 1i * randn(1, txParams.numUsers));
UL_Noise = (1 / sqrt(2 * txParams.SNR * N)) * (randn((N + cp), txParams.numUsers) + 1i * randn((N + cp), txParams.numUsers));
ULRx_Stream = ULTx_Stream .* txParams.CSI + UL_Noise;
% Estimating CSI
txParams.est_CSI = UplinkRx(ULRx_Stream, txParams);
[~, txParams.sorted_CSI_Idx] = sort(txParams.est_CSI, 'descend');
%% Generating Data
% Generating random data
txBitStreamMat = randi([0, 1], txParams.dataLength - txParams.coding.cc.tbl, txParams.numUsers);
txBitStreamMat = [txBitStreamMat; zeros(txParams.coding.cc.tbl, txParams.numUsers)];
%% Data Processing at Tx
% Passing the data for transmission
[txOut, txParams] = Transmitter(txBitStreamMat, txParams);
%% Channel Model
% For Simulation purposes, the flat fading channel will added at the receiver
% Noise
SNR = txParams.SNR;
noiseMat = (sqrt(sysPower) / sqrt(2 * SNR)) .* (randn(size(txOut)) + (1i) * randn(size(txOut)));
signalPower = norm(txOut) .^ 2;
noisePower = norm(noiseMat) .^ 2;
empSNR = signalPower / noisePower;
empSNRdb = 10 * log10(empSNR);
rxDataStream = txOut + noiseMat;
%% Receiver
% Detecting the information from received signal
rxBitStreamMat = Receiver(rxDataStream, txParams);
% Error in received bitstream
errBits = sum(bitxor(txBitStreamMat, rxBitStreamMat));
if (~errBits)
disp('Successful Transmission');
else
disp(['Err Bits: ', num2str(errBits)]);
end
disp(txParams.CSI);
disp(txParams.CSI(txParams.sorted_CSI_Idx));
end