-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathOSIC_detector.m
74 lines (72 loc) · 2.71 KB
/
OSIC_detector.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 [X_hat]=OSIC_detector(y,H,sigma2,nT,OSIC_type)
% Input parameters
% y : Received signal,nRx1
% H : Channel matrix, nRxnT
% sigma2: Noise variance
% nT : Number of Tx antennas
% OSIC_type
% - 1 : Post_detection_SINR
% - 2 : Column_max
% - 3 : Post_detection_SNR
% Output parameter
% X_hat : Estimated signal,nTx1
%MIMO-OFDM Wireless Communications with MATLAB¢ç Yong Soo Cho, Jaekwon Kim, Won Young Yang and Chung G. Kang
%2010 John Wiley & Sons (Asia) Pte Ltd
if OSIC_type==1 % Post_detection_SINR
Order=[]; % detection order
index_array=[1:nT]; % yet to be detected signal index
% V-BLAST
for stage = 1:nT
Wmmse=inv(H'*H+sigma2*eye(nT+1-stage))*H'; % MMSE filter
WmmseH=Wmmse*H;
SINR=[];
for i =1:nT-(stage-1)
tmp= norm(WmmseH(i,[1:i-1 i+1:nT-(stage-1)]))^2 ...
+ sigma2*norm(Wmmse(i,:))^2;
SINR(i)=abs(WmmseH(i,i))^2/tmp; % SINR calculation
end
[val_max,index_temp] = max(SINR); % ordering using SINR
Order = [Order index_array(index_temp)];
index_array = index_array([1:index_temp-1 index_temp+1:end]);
x_temp(stage) = Wmmse(index_temp,:)*y; % MMSE filtering
X_hat(stage) = QAM16_slicer(x_temp(stage),1); % slicing
y_tilde = y - H(:,index_temp)*X_hat(stage); % interference subtraction
H_tilde = H(:,[1:index_temp-1 index_temp+1:nT-(stage-1)]); % new H
H = H_tilde; y = y_tilde;
end
X_hat(Order) = X_hat;
elseif OSIC_type==2 % column_norm ordering detection
%X_hat=zeros(nT,1);
G = inv(H); % inverse of H
for i=1:nT % column_norm calculation
norm_array(i) = norm(H(:,i));
end
[sorted_norm_array,Order_temp] = sort(norm_array);
Order = wrev(Order_temp);
% V-BLAST
for stage=1:nT
x_temp=G(Order(stage),:)*y; % Tx signal estimation
X_hat(Order(stage))=QAM16_slicer(x_temp,1); % slicing
y_tilde = y-H(:,Order(stage))*X_hat(Order(stage));
end
else % OSIC with Post_detection_SNR ordering
Order=[];
index_array=[1:nT]; % set of indices of signals to be detected
% V-BLAST
for stage=1:nT
G = inv(H'*H)*H';
norm_array=[];
for i=1:nT-(stage-1) % detection ordering
norm_array(i) = norm(G(i,:));
end
[val_min,index_min]=min(norm_array); % ordering in SNR
Order=[Order index_array(index_min)];
index_array = index_array([1:index_min-1 index_min+1:end]);
x_temp(stage) = G(index_min,:)*y; % Tx signal estimation
X_hat(stage) = QAM16_slicer(x_temp(stage),1); % slicing
y_tilde = y-H(:,index_min)*X_hat(stage); % interference subtraction
H_tilde = H(:,[1:index_min-1 index_min+1:nT-(stage-1)]); % new H
H = H_tilde; y = y_tilde;
end
X_hat(Order) = X_hat;
end