|
|
@ -1,12 +1,11 @@
|
|
|
|
clear
|
|
|
|
clear
|
|
|
|
enb = lteTestModel('1.1','1.4MHz');
|
|
|
|
enb = lteTestModel('1.1','1.4MHz');
|
|
|
|
Ntrials = 1;
|
|
|
|
Ntrials = 100;
|
|
|
|
SNR_values = 100;%linspace(0,10,6);
|
|
|
|
SNR_values = linspace(-8,0,6);
|
|
|
|
flen=1920;
|
|
|
|
flen=1920;
|
|
|
|
fft_size=128;
|
|
|
|
fft_size=128;
|
|
|
|
|
|
|
|
|
|
|
|
tx_offset = 0;%randi(50,1,Ntrials);
|
|
|
|
tx_offset = randi(50,1,Ntrials);
|
|
|
|
cfo_offset = 0;%2*rand(1,Ntrials)-1;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
tx_signal = lteTestModelTool(enb);
|
|
|
|
tx_signal = lteTestModelTool(enb);
|
|
|
|
pss_idx = flen/2-fft_size+1:flen/2;
|
|
|
|
pss_idx = flen/2-fft_size+1:flen/2;
|
|
|
@ -36,7 +35,7 @@ addpath('../sync/')
|
|
|
|
t = (0:length(tx_signal)-1).'/fft_size;
|
|
|
|
t = (0:length(tx_signal)-1).'/fft_size;
|
|
|
|
|
|
|
|
|
|
|
|
L=16;
|
|
|
|
L=16;
|
|
|
|
M=3;
|
|
|
|
M=4;
|
|
|
|
diff=zeros(length(SNR_values),M);
|
|
|
|
diff=zeros(length(SNR_values),M);
|
|
|
|
for snr_idx=1:length(SNR_values)
|
|
|
|
for snr_idx=1:length(SNR_values)
|
|
|
|
fprintf('SNR=%.1f dB\n', SNR_values(snr_idx));
|
|
|
|
fprintf('SNR=%.1f dB\n', SNR_values(snr_idx));
|
|
|
@ -44,7 +43,6 @@ for snr_idx=1:length(SNR_values)
|
|
|
|
rx_offset = zeros(M,length(tx_offset));
|
|
|
|
rx_offset = zeros(M,length(tx_offset));
|
|
|
|
for i=1:Ntrials
|
|
|
|
for i=1:Ntrials
|
|
|
|
[rx_signal, chinfo] = lteFadingChannel(cfg,tx_signal);
|
|
|
|
[rx_signal, chinfo] = lteFadingChannel(cfg,tx_signal);
|
|
|
|
% rx_signal = rx_signal.*exp(-1i*cfo_offset(i)*2*pi.*t);
|
|
|
|
|
|
|
|
%rx_signal = tx_signal;
|
|
|
|
%rx_signal = tx_signal;
|
|
|
|
SNR = 10^(SNRdB/10); % Linear SNR
|
|
|
|
SNR = 10^(SNRdB/10); % Linear SNR
|
|
|
|
rx = [zeros(tx_offset(i),1); rx_signal];
|
|
|
|
rx = [zeros(tx_offset(i),1); rx_signal];
|
|
|
@ -60,22 +58,27 @@ for snr_idx=1:length(SNR_values)
|
|
|
|
% srsLTE in tracking mode
|
|
|
|
% srsLTE in tracking mode
|
|
|
|
track_offset=2+rx_offset(2,i)+flen/2-fft_size-L/2;
|
|
|
|
track_offset=2+rx_offset(2,i)+flen/2-fft_size-L/2;
|
|
|
|
[rx_offset(3,i),corr_lt_track] = srslte_pss(enb,rx(track_offset:end),L);
|
|
|
|
[rx_offset(3,i),corr_lt_track] = srslte_pss(enb,rx(track_offset:end),L);
|
|
|
|
rx_offset(3,i) = rx_offset(2,i) + (rx_offset(3,i) - fft_size - L/2);
|
|
|
|
rx_offset(3,i) = rx_offset(2,i) + (rx_offset(3,i) - fft_size - L/2) + 1;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
% CP based
|
|
|
|
|
|
|
|
[rx_offset(4,i), corr_lt_cp] = srslte_cp_synch(enb, rx);
|
|
|
|
|
|
|
|
|
|
|
|
end
|
|
|
|
end
|
|
|
|
diff(snr_idx,:)=mean(abs(rx_offset-repmat(tx_offset,M,1)),2);
|
|
|
|
diff(snr_idx,:)=mean(abs(rx_offset-repmat(tx_offset,M,1) - chinfo.ChannelFilterDelay),2);
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
if (Ntrials == 1)
|
|
|
|
if (Ntrials == 1)
|
|
|
|
disp(diff)
|
|
|
|
disp(diff)
|
|
|
|
%plot(1:flen,abs(corr_res(1:flen)),1:flen,abs(corr_lt(1:flen)));
|
|
|
|
%plot(1:flen,abs(corr_res(1:flen)),1:flen,abs(corr_lt(1:flen)));
|
|
|
|
t=940:1000;
|
|
|
|
t=1:fft_size;
|
|
|
|
plot(t,abs(corr_lt(t)));
|
|
|
|
plot(t,abs(corr_lt_cp(t)));
|
|
|
|
|
|
|
|
%plot(lambda)
|
|
|
|
%plot(1:L,abs(corr_lt_track),[L/2, L/2], [0 max(abs(corr_lt_track))])
|
|
|
|
%plot(1:L,abs(corr_lt_track),[L/2, L/2], [0 max(abs(corr_lt_track))])
|
|
|
|
grid on
|
|
|
|
grid on
|
|
|
|
|
|
|
|
|
|
|
|
else
|
|
|
|
else
|
|
|
|
plot(SNR_values,diff);
|
|
|
|
plot(SNR_values,diff);
|
|
|
|
legend('Matlab','srs find','srs tracking 16','srs tracking 64')
|
|
|
|
legend('Matlab','srs find','srs tracking','srs cp')
|
|
|
|
grid on
|
|
|
|
grid on
|
|
|
|
xlabel('SNR (dB)')
|
|
|
|
xlabel('SNR (dB)')
|
|
|
|
ylabel('Avg time offset')
|
|
|
|
ylabel('Avg time offset')
|
|
|
|