-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmain_single_packet.m
137 lines (106 loc) · 6.44 KB
/
main_single_packet.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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
clear all;
close all;
% This script illustrates how to use this DECT-2020 New Radio link-level simulation environment.
% It defines a transmitter and a receiver handle class object.
% Also, it initiates the wireless channel model (this step can be skipped and replaced by a custom channel model).
% The transmitter generates a packet, sends it through the wireless channel and finally the receiver decodes it.
rng('shuffle');
%rng(1140598280);
warning('on');
% nice verbose plots
set(groot,'defaultAxesTickLabelInterpreter','latex');
set(groot,'defaultLegendInterpreter','latex');
set(groot,'defaultTextInterpreter','latex');
%profile on
%% these variables need to be set before creating tx
mac_meta_tx.u = 1; % mu = 1, 2, 4 or 8
mac_meta_tx.b = 1; % beta = 1, 2, 4, 8, 12 or 16
mac_meta_tx.PacketLengthType = 0; % 0 for subslots, 1 for slots
mac_meta_tx.PacketLength = 4; % min is 1, max is 16 according to Table 6.2.1-2a in part 4
mac_meta_tx.tm_mode_0_to_11 = 0; % Table 7.2-1, mode determines wether transmission is closed loop or not, values range from 0 to 11
mac_meta_tx.mcs_index = 5; % Table A-1 in part 3, values range from 0 to 11
mac_meta_tx.Z = 6144; % 5.3 -> so far only Z=6144 fully supported, 2048 only at TX, RX missing (Matlab has no option for Z=2048 in LTE toolbox)
mac_meta_tx.oversampling = 8; % By how much do we oversample our ofdm packet compared to critical sampling (insert zeros at specturm edges before IFFT)?
mac_meta_tx.codebook_index = 0; % 6.3.4, any value other than 0 makes packet beamformed, throws error if out of bound (depends on tm_mode_0_to_11)
mac_meta_tx.PLCF_type = 1; % Type 1 is 40 bits, Type 2 is 80 bits
mac_meta_tx.rv = 0; % HARQ version, values range from 0, 1, 2 to 3 (right HARQ retransmission order is 0 2 3 1)
mac_meta_tx.network_id = de2bi(1e6,32,'left-msb'); % 7.6.6 must be given as a 32 bit vector with network_id(1) being the MSB, network_id must be known for scrambler on PHY
% temporary restrictions
if mac_meta_tx.Z ~= 6144
error('Z must be 6144.');
end
%% create tx
verbose = 2; % show data during execution: 0 false, 1 only text, 2 text + plots
tx = dect_tx(verbose, mac_meta_tx);
%% generate tx signal
% generate random PCC bits
PCC_user_bits = [];
if mac_meta_tx.PLCF_type == 1
PCC_user_bits = randi([0 1], 40, 1);
elseif mac_meta_tx.PLCF_type == 2
PCC_user_bits = randi([0 1], 80, 1);
end
% how many PDC bits does tx need?
N_TB_bits = tx.phy_4_5.N_TB_bits;
% generate bits
PDC_user_bits = randi([0 1], N_TB_bits, 1);
% let tx create the packet
samples_antenna_tx = tx.generate_packet(PCC_user_bits, PDC_user_bits);
%% create rx
% assume the receiver has full knowledge of meta data at the transmitter (usually extracted from STF+PCC or blindly tested)
mac_meta_rx = mac_meta_tx;
% number of antennas at the receiver
mac_meta_rx.N_RX = 2;
% Synchronization before the FFT (i.e. in time domain) based on the STF:
%
% If synchronization before the FFT is turned on (i.e. mac_meta_rx.synchronization.pre_FFT.active = true), the receiver class
% dect_rx will try to synchronize a packet before decoding it. For that, the dect_rx method demod_decode_packet(samples_antenna_rx)
% must be called with samples_antenna_rx having more samples than samples_antenna_tx.
%
% If synchronization before the FFT is turned off (i.e. mac_meta_rx.synchronization.pre_FFT.active = false) the receiver class
% dect_rx will NOT try to synchronize a packet before decoding it. For that, the dect_rx method demod_decode_packet(samples_antenna_rx)
% must be called with samples_antenna_rx having the exact same number of samples as samples_antenna_tx.
%
mac_meta_rx.synchronization.pre_FFT.active = true;
if mac_meta_rx.synchronization.pre_FFT.active == true
% symbol time offset (STO), i.e. detection, coarse peak search, fine peak search
mac_meta_rx.synchronization.pre_FFT.sto_config = lib_rx.sync_STO_param(mac_meta_tx.u, mac_meta_tx.b, mac_meta_tx.oversampling);
% carrier frequency offset (CFO), i.e. fractional and integer CFO
mac_meta_rx.synchronization.pre_FFT.cfo_config = lib_rx.sync_CFO_param(mac_meta_tx.u);
mac_meta_rx.synchronization.pre_FFT.cfo_config.active_fractional = true;
mac_meta_rx.synchronization.pre_FFT.cfo_config.active_integer = true;
end
% synchronization in frequency domain based on STF and/or DRS
mac_meta_rx.synchronization.post_FFT.sto_fractional = true;
mac_meta_rx.synchronization.post_FFT.cfo_residual = true;
% create actual receiver
rx = dect_rx(verbose, mac_meta_rx);
%% create channel, can be replaced with a custom channel
% type can be awgn, rayleigh or rician
ch = lib_rf_channel.rf_channel_example_factory('rayleigh', verbose, tx, rx, size(samples_antenna_tx, 1));
%% give rx handles so it can debug, e.g. perfect channel knowledge
rx.tx_handle = tx;
rx.ch_handle = ch;
%% pass tx signal through channel and yield rx signal (this step can be skipped)
samples_antenna_rx = ch.pass_samples(samples_antenna_tx, 0);
%% The property snr_db of the RF channel refers to the inband noise. If oversampling is used, we have to remove out-of-band noise, otherwise synchronization in time domain is impaired.
if mac_meta_tx.oversampling > 1
% Kaiser LPF
lowpassfilter = designfilt( 'lowpassfir', ...
'PassbandFrequency', 0.6 / mac_meta_tx.oversampling, ...
'StopbandFrequency',0.8 / mac_meta_tx.oversampling, ...
'PassbandRipple', 10, ...
'StopbandAttenuation', 30, ...
'SampleRate', 1, ...
'DesignMethod', 'kaiserwin', ...
'MinOrder', 'even');
assert(mod(numel(lowpassfilter.Coefficients), 2) == 1, 'fractional LPF delay');
samples_antenna_rx = filter(lowpassfilter, samples_antenna_rx);
% compensate deterministic filter delay prior to synchronization
lowpassfilter_delay = (numel(lowpassfilter.Coefficients)-1)/2;
samples_antenna_rx(1:end-lowpassfilter_delay) = samples_antenna_rx(lowpassfilter_delay+1:end);
end
%% let rx decode the frame
[PCC_user_bits_recovered, PDC_user_bits_recovered] = rx.demod_decode_packet(samples_antenna_rx);
%profile viewer
%profile off