-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathQRD_based_BT_C_Method.m
120 lines (100 loc) · 3.46 KB
/
QRD_based_BT_C_Method.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
% Made by Woosung 2020.Jan.14th
function [F, index] = QRD_based_BT_C_Method(H, K, delta)
% < Input >
% K : The number of the bit streams
% H : Channel, the size of nR X nT
% delta : Orthogonality of the transformed channel matrix H_{LR}
% < Output >
% F : Selected Sub-optimal Precoder
% index : And its index
%% Default Value
if nargin < 1
disp('[Message] QRD_BT-C_Precoder_Selection : Default set H, K, delta');
nT = 2; nR = 4;
K = 2;
H = 1/sqrt(K)*sqrt(1/2)*(randn(nR,nR)+1i*randn(nR,nR));
delta = 0.99;
elseif nargin < 2
disp('[Message] QRD_BT-C_Precoder_Selection : Default set K, delta');
K = 4;
delta = 0.99;
elseif nargin < 3
disp('[Message] QRD_BT-C_Precoder_Selection : Default set delta only');
delta = 0.99;
end
%% Create Precoder based on the LTE-A Codebook
j = sqrt(-1);
u=[ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1;
-1, -j, 1, j, (-1-j)/sqrt(2), (1-j)/sqrt(2), (1+j)/sqrt(2), (-1+j)/sqrt(2), -1, -j, 1, j, -1, -1, 1, 1;
-1, 1, -1, 1, -j, j, -j, j, 1, -1, 1, -1, -1, 1, -1, 1;
-1, j, 1, -j, (1-j)/sqrt(2), (-1-j)/sqrt(2),(-1+j)/sqrt(2),(1+j)/sqrt(2), 1, -j, -1, j, 1, -1, -1, 1];
W=zeros(4,4,16);
for i=1:length(W)
a = u(:, i) * u(:, i)';
b = u(:, i)' * u(:, i);
W(:, :, i) = eye(4) - (2 * a) / b;
end
F4_matrix_order = ...
[[1 2 3 4];[1 2 3 4];[3 2 1 4];[3 2 1 4];
[1 2 3 4];[1 2 3 4];[1 3 2 4];[1 3 2 4];
[1 2 3 4];[1 2 3 4];[1 3 2 4];[1 3 2 4];
[1 2 3 4];[1 3 2 4];[3 2 1 4];[1 2 3 4]];
% Precoder Matrix 'F4' For QAM-16
F4=zeros(4,4,16);
for i=1:length(W)
F4(:, :, i) = W(:, F4_matrix_order(i,:), i) / 2 ;
end
F2_matrix_order = ...
[[1 4];[1 2];[1 2];[1 2];
[1 4];[1 4];[1 3];[1 3];
[1 2];[1 4];[1 3];[1 3];
[1 2];[1 3];[1 3];[1 2]];
% Precoder Matrix 'F2' For QAM-16
F2=zeros(4,2,16);
for i=1:length(W)
F2(:, :, i) = W(:, F2_matrix_order(i,:), i) / sqrt(2) ;
end
% In case of K == 4, note that we only consider 5 precoder
% because the rest of them are identical : F0, F1, F4, F5, F12
%% Basic Setup For searching the minimum distance
if K == 2
precoder_idx = 1:1:16;
elseif K == 4
precoder_idx = [1, 2, 5, 6, 13];
end
min_dist_per_precoder = zeros(length(precoder_idx), 1);
curr_precoder_idx = 1;
for i = precoder_idx
perms_array = perms(1:1:K).';
% curr_min = realmax;
if K == 2
Hp = H * F2(:, :, i);
elseif K == 4
Hp = H * F4(:, :, i);
end
% Complex_LLL function returns [Q, R, P]
[~, ~, P] = Complex_LLL(Hp, delta);
Hp_P = Hp * P;
% perms_matrix = eye(K); perms_matrix = perms_matrix(:, perms_idx);
% Utilize that -> 'Hp * perms_matrix == Hp(:, perms_idx);'
R_cas_min = realmin;
for perms_idx = perms_array
perm_Hp_P = Hp_P(:, perms_idx);
% As permutation matrices are orthogonal matrices,
% the inverse matrix exists and can be written as (perms_matrix * perms_matrix' = I).
% Perform the QR Decomposition
[~, R] = qr(perm_Hp_P);
R_cas_min = max(R_cas_min, min(diag(R).^2));
end
min_dist_per_precoder(curr_precoder_idx) = R_cas_min;
curr_precoder_idx = curr_precoder_idx + 1;
end
%% Find the precoder having mini-max distance from the candidate error vectors
[~, max_idx] = max(min_dist_per_precoder);
if K == 2
F = F2(:, :, precoder_idx(max_idx));
elseif K == 4
F = F4(:, :, precoder_idx(max_idx));
end
index = max_idx;
end