Commit 044e70f6 authored by Florian Kaltenberger's avatar Florian Kaltenberger

git-svn-id: http://svn.eurecom.fr/openair4G/trunk@5204 818b1a75-f10b-46b9-bf7c-635c3b92a50f
parent 118466b5
close all close all
clear all clear all
nant1 = 1;
enable_plots=2; %enables figures
%% preload and init data
addpath('../../../openair1/PHY/LTE_REFSIG');
primary_synch; %loads the primary sync signal
pss1_t = upsample(primary_synch0_time,4*4);
pss2_t = upsample(primary_synch0_time,4*2);
%load('E:\EMOS\corridor\ofdm_pilots_sync_2048_v7.mat');
load('ofdm_pilots_sync_30MHz.mat');
filename = 'E:\EMOS\corridor\eNB_data_20140319_133327.EMOS';
nb_rb1 = 100; %this can be 25, 50, or 100
num_carriers1 = 2048/100*nb_rb1;
num_zeros1 = num_carriers1-(12*nb_rb1+1);
prefix_length1 = num_carriers1/4; %this is extended CP
ofdm_symbol_length1 = num_carriers1 + prefix_length1;
frame_length1 = ofdm_symbol_length1*num_symbols_frame;
useful_carriers1 = num_carriers1-num_zeros1-1;
nb_rb2 = 50; %this can be 25, 50, or 100
num_carriers2 = 2048/100*nb_rb2;
num_zeros2 = num_carriers2-(12*nb_rb2+1);
prefix_length2 = num_carriers2/4; %this is extended CP
ofdm_symbol_length2 = num_carriers2 + prefix_length2;
frame_length2 = ofdm_symbol_length2*num_symbols_frame;
useful_carriers2 = num_carriers2-num_zeros2-1;
nant1 = 2;
nant2 = 2; nant2 = 2;
samples_slot1 = 7680*2; samples_slot1 = 7680*2;
samples_slot2 = 7680; samples_slot2 = 7680;
samples_slot_agg = nant1*samples_slot1 + nant2*samples_slot2; samples_slot_agg = nant1*samples_slot1 + nant2*samples_slot2;
nframes = 10; nframes = 50;
slots_per_frame = 20; slots_per_frame = 20;
%% read data d = dir(filename);
fid = fopen('E:\EMOS\corridor\eNB_data_20140311_173205.EMOS','r'); nblocks = floor(d.bytes/(samples_slot_agg*slots_per_frame*nframes*4));
[v,c]=fread(fid, 2*samples_slot_agg*slots_per_frame*nframes, 'int16',0,'ieee-le'); PDP1_total = zeros(nblocks*nframes,useful_carriers1);
fclose(fid); PDP2_total = zeros(nblocks*nframes,useful_carriers2);
v0 = double(v(1:2:end,:))+1j*double(v(2:2:end,:));
%%
v1 = zeros(samples_slot1*slots_per_frame*nframes,nant1);
v2 = zeros(samples_slot1*slots_per_frame*nframes,nant2);
for slot=1:slots_per_frame*nframes
v1((slot-1)*samples_slot1+1:slot*samples_slot1,1) = v0((slot-1)*samples_slot_agg+1:slot*samples_slot_agg-samples_slot2*nant2,1);
v2((slot-1)*samples_slot2+1:slot*samples_slot2,1) = v0((slot-1)*samples_slot_agg+samples_slot1+1:slot*samples_slot_agg-samples_slot2,1);
v2((slot-1)*samples_slot2+1:slot*samples_slot2,2) = v0((slot-1)*samples_slot_agg+samples_slot1+samples_slot2+1:slot*samples_slot_agg,1);
end
%% %% main loop
figure(1) fid = fopen(filename,'r');
plot(20*log10(abs(fftshift(fft(v1))))) block = 1;
figure(2) while ~feof(fid)
plot(20*log10(abs(fftshift(fft(v2))))) fprintf(1,'Processing block %d of %d',block,nblocks);
%%
[v,c]=fread(fid, 2*samples_slot_agg*slots_per_frame*nframes, 'int16',0,'ieee-le');
if (c==0)
break
end
v0 = double(v(1:2:end,:))+1j*double(v(2:2:end,:));
%% sync v1 = zeros(samples_slot1*slots_per_frame*nframes,nant1);
addpath('../../../openair1/PHY/LTE_REFSIG'); v2 = zeros(samples_slot2*slots_per_frame*nframes,nant2);
primary_synch; %loads the primary sync signal for slot=1:slots_per_frame*nframes
for a1=1:nant1
v1((slot-1)*samples_slot1+1:slot*samples_slot1,a1) = ...
v0((slot-1)*samples_slot_agg+(a1-1)*samples_slot1+1:...
(slot-1)*samples_slot_agg+ a1 *samples_slot1,1);
end
for a2=1:nant2
v2((slot-1)*samples_slot2+1:slot*samples_slot2,a2) = ...
v0((slot-1)*samples_slot_agg+nant1*samples_slot1+(a2-1)*samples_slot2+1:...
(slot-1)*samples_slot_agg+nant1*samples_slot1+ a2 *samples_slot2,1);
end
end
pss_t = upsample(primary_synch0_time,4*2); if enable_plots>=2
[corr,lag] = xcorr(v2(:,1),pss_t); figure(1)
figure(3); plot(abs(fftshift(fft(v1))))
plot(lag,abs(corr));
figure(2)
%% frame start detection plot(abs(fftshift(fft(v2))))
load('E:\EMOS\corridor\ofdm_pilots_sync_30MHz.mat'); end
ofdm_symbol_length = num_carriers + prefix_length;
frame_length = ofdm_symbol_length*num_symbols_frame; %% frame start detection
useful_carriers = num_carriers-num_zeros-1; [corr,lag] = xcorr(v2(:,1),pss2_t);
%[m,idx]=max(abs(corr));
% TODO: do a proper peak detection. for now just take the max [m,idx]=peaksfinder(corr,frame_length2);
[m,i]=max(abs(corr));
frame_start = lag(i) - prefix_length; if (enable_plots>=2)
figure(20);
%% ofdm receiver hold off
received = v2(frame_start:frame_start+frame_length,1); plot(lag,abs(corr));
received_f = zeros(num_symbols_frame,useful_carriers); hold on
for i=0:num_symbols_frame-1; plot(lag(idx),m,'ro')
ifblock=received(i*ofdm_symbol_length+[1:ofdm_symbol_length]); end
ifblock(1:prefix_length)=[];
fblock=fft(ifblock);
received_f(i+1,:) = [fblock(2:useful_carriers/2+1); fblock(end-useful_carriers/2+1:end)];
end
%% channel estimation %%
H=conj(f2).*received_f; for i=1:size(idx,2)-1; % the last frame is not complite
Ht = ifft(H,[],2); fprintf(1,'.');
PDP = mean(abs(Ht(2:end,:).^2),1); %frame_start2 = lag(i) - prefix_length2;
figure(3) frame_start2 = lag(idx(i))-prefix_length2;
surf(20*log10(abs(Ht))) frame_start1 = frame_start2*2;
xlabel('time [OFDM symbol]')
ylabel('delay time [samples]')
zlabel('power [dB]')
shading interp
figure(4)
plot(10*log10(PDP))
xlabel('delay time [samples]')
ylabel('power [dB]')
% ofdm receiver
received_f1 = OFDM_RX(v1(frame_start1:frame_start1+frame_length1,:),num_carriers1,useful_carriers1,prefix_length1,num_symbols_frame);
received_f2 = OFDM_RX(v2(frame_start2:frame_start2+frame_length2,:),num_carriers2,useful_carriers2,prefix_length2,num_symbols_frame);
% channel estimation (SISO)
H1=conj(squeeze(f1(1,:,:))).*received_f1(:,:,1);
H2=conj(squeeze(f2(1,:,:))).*received_f2(:,:,1);
H1t = ifft(H1,[],2);
H2t = ifft(H2,[],2);
PDP1 = mean(abs(H1t(2:end,:).^2),1);
PDP2 = mean(abs(H2t(2:end,:).^2),1);
PDP1_total((block-1)*nframes+i+1,:) = PDP1;
PDP2_total((block-1)*nframes+i+1,:) = PDP2;
if enable_plots>=1
figure(3)
surf((abs(H1t)))
xlabel('time [OFDM symbol]')
ylabel('delay time [samples]')
zlabel('power [dB]')
title('H1t')
shading interp
figure(4)
plot(10*log10(PDP1))
xlabel('delay time [samples]')
ylabel('power [dB]')
title('PDP1')
figure(30)
surf((abs(H2t)))
xlabel('time [OFDM symbol]')
ylabel('delay time [samples]')
zlabel('power [dB]')
title('H2t')
shading interp
figure(40)
plot(10*log10(PDP2))
xlabel('delay time [samples]')
ylabel('power [dB]')
title('PDP2')
end
end
fprintf(1,'\n');
block = block+1;
end
fclose(fid);
...@@ -2,7 +2,7 @@ function [m,ind]=peaksfinder(corr,frame_length) ...@@ -2,7 +2,7 @@ function [m,ind]=peaksfinder(corr,frame_length)
threshold=45000; threshold=max(abs(corr))*0.75;
consecutivePos=[]; consecutivePos=[];
highCorrVal=find(abs(corr)>threshold); highCorrVal=find(abs(corr)>threshold);
num_peak=0; num_peak=0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment