Commit 700986eb authored by Florian Kaltenberger's avatar Florian Kaltenberger

bugfixes - now works with dual carrier EMOS files


git-svn-id: http://svn.eurecom.fr/openair4G/trunk@5324 818b1a75-f10b-46b9-bf7c-635c3b92a50f
parent 92854bea
...@@ -13,7 +13,6 @@ primary_synch; %loads the primary sync signal ...@@ -13,7 +13,6 @@ primary_synch; %loads the primary sync signal
load('ofdm_pilots_sync_30MHz.mat'); load('ofdm_pilots_sync_30MHz.mat');
n_carriers = 2; % use 1 for UHF and 2 for 2.6GHz n_carriers = 2; % use 1 for UHF and 2 for 2.6GHz
nframes = 100; % frames in one block
symbols_per_slot = 6; symbols_per_slot = 6;
slots_per_frame = 20; slots_per_frame = 20;
...@@ -25,13 +24,18 @@ switch n_carriers ...@@ -25,13 +24,18 @@ switch n_carriers
%filename = 'E:\EMOS\corridor\trials1\eNB_data_20140331_UHF_run1.EMOS'; %filename = 'E:\EMOS\corridor\trials1\eNB_data_20140331_UHF_run1.EMOS';
filename = 'D:\trials1 train extracted\eNB_data_20140331_UHF_run1.EMOS'; filename = 'D:\trials1 train extracted\eNB_data_20140331_UHF_run1.EMOS';
nframes = 100; % frames in one block
threshold = 3e+4 ; % maybe should change that !!!!
case 2, case 2,
p(1) = init_params(50,2,4); p(1) = init_params(100,2,4);
p(2) = init_params(100,2,4); p(2) = init_params(50,2,4);
pss_t = upsample(primary_synch0_time,4*2); % this assumes we are doing the sync on the first carrier, which is 10MHz pss_t = upsample(primary_synch0_time,4*4); % this assumes we are doing the sync on the first carrier, which is 10MHz
%filename = 'E:\EMOS\corridor\trials1\eNB_data_20140331_UHF_run1.EMOS'; %filename = 'E:\EMOS\corridor\trials1\eNB_data_20140331_UHF_run1.EMOS';
filename = 'D:\trials1 train extracted\eNB_data_20140331_2.6GHz_run1.EMOS'; filename = 'D:\trials1 train extracted\eNB_data_20140331_2.6GHz_run1.EMOS';
nframes = 50; % frames in one block
threshold = 1e+4 ; % maybe should change that !!!!
end end
destdir = 'E:\EMOS\corridor\trials1 train'; destdir = 'E:\EMOS\corridor\trials1 train';
...@@ -54,9 +58,7 @@ block = 1; ...@@ -54,9 +58,7 @@ block = 1;
flag1 = 1; flag1 = 1;
start=2; start=2;
threshold = 3e+4 ; % maybe should change that !!!! %fseek(fid,samples_slot_agg*slots_per_frame*nframes*120*2,'bof'); %advance 30 sec
fseek(fid,samples_slot_agg*slots_per_frame*nframes*120*2,'bof'); %advance 30 sec
while ~feof(fid) while ~feof(fid)
fprintf(1,'Processing block %d of %d',block,nblocks); fprintf(1,'Processing block %d of %d',block,nblocks);
...@@ -68,21 +70,21 @@ while ~feof(fid) ...@@ -68,21 +70,21 @@ while ~feof(fid)
v0 = double(v(1:2:end))+1j*double(v(2:2:end)); v0 = double(v(1:2:end))+1j*double(v(2:2:end));
v1 = zeros(p(1).samples_slot*slots_per_frame*nframes,p(1).nant_rx); v1 = zeros(p(1).samples_slot*slots_per_frame*nframes,p(1).nant_rx);
if n_carriers==2
v2 = zeros(p(2).samples_slot*slots_per_frame*nframes,p(2).nant_rx);
end
for slot=1:slots_per_frame*nframes for slot=1:slots_per_frame*nframes
for a=1:p(1).nant_rx for a=1:p(1).nant_rx
v1((slot-1)*p(1).samples_slot+1:slot*p(1).samples_slot,a) = ... v1((slot-1)*p(1).samples_slot+1:slot*p(1).samples_slot,a) = ...
v0((slot-1)*samples_slot_agg+(a-1)*p(1).samples_slot+1:... v0((slot-1)*samples_slot_agg+(a-1)*p(1).samples_slot+1:...
(slot-1)*samples_slot_agg+ a *p(1).samples_slot,1); (slot-1)*samples_slot_agg+ a *p(1).samples_slot,1);
end end
end
if n_carriers==2
if n_carriers==2
v2 = zeros(p(2).samples_slot*slots_per_frame*nframes,p(2).nant_rx);
for slot=1:slots_per_frame*nframes
for a=1:p(2).nant_rx for a=1:p(2).nant_rx
v2((slot-1)*p(2).samples_slot+1:slot*p(2).samples_slot,a) = ... v2((slot-1)*p(2).samples_slot+1:slot*p(2).samples_slot,a) = ...
v0((slot-1)*samples_slot_agg+(a-1)*p(2).samples_slot+1:... v0((slot-1)*samples_slot_agg+p(1).nant_rx*p(1).samples_slot+(a-1)*p(2).samples_slot+1:...
(slot-1)*samples_slot_agg+ a *p(2).samples_slot,1); (slot-1)*samples_slot_agg+p(1).nant_rx*p(1).samples_slot+ a *p(2).samples_slot,1);
end end
end end
end end
...@@ -96,10 +98,10 @@ while ~feof(fid) ...@@ -96,10 +98,10 @@ while ~feof(fid)
end end
if n_carriers==2 if n_carriers==2
v2 = [vStorage1; v2] ; v2 = [vStorage2; v2] ;
if size(v2,1) > p(2).frame_length*nframes ; if size(v2,1) > p(2).frame_length*nframes ;
nframes = floor(size(v2,1) / p(2).frame_length) ; nframes = floor(size(v2,1) / p(2).frame_length) ;
vStorage1 = v2(p(2).frame_length*nframes+1:end,:) ; vStorage2 = v2(p(2).frame_length*nframes+1:end,:) ;
v2(p(2).frame_length*nframes + 1 : end,:) = [] ; v2(p(2).frame_length*nframes + 1 : end,:) = [] ;
start = 1 ; start = 1 ;
end end
...@@ -158,7 +160,7 @@ while ~feof(fid) ...@@ -158,7 +160,7 @@ while ~feof(fid)
fprintf(1,'.'); fprintf(1,'.');
frame_start1 = (slots_per_frame*p(1).samples_slot)*(i-1)+frame_offset+1; frame_start1 = (slots_per_frame*p(1).samples_slot)*(i-1)+frame_offset+1;
if n_carriers==2 if n_carriers==2
frame_start2 = (slots_per_frame*p(2).samples_slot)*(i-1)+frame_offset*2+1; frame_start2 = (slots_per_frame*p(2).samples_slot)*(i-1)+round(frame_offset/2)+1;
end end
if i<nframes if i<nframes
...@@ -172,78 +174,81 @@ while ~feof(fid) ...@@ -172,78 +174,81 @@ while ~feof(fid)
if n_carriers==2 if n_carriers==2
vStorage2 = [v2(frame_start2:end,:) ; vStorage2]; %% vStorage2 = [v2(frame_start2:end,:) ; vStorage2]; %%
end end
break
end end
%% MIMO channel estimation %% MIMO channel estimation
if (n_carriers==1) if (n_carriers==1)
transmit_f1 = f3; transmit_f1 = f3;
else else
transmit_f1 = f2; transmit_f1 = f1;
transmit_f2 = f1; transmit_f2 = f2;
end end
for carrier=1:n_carriers for carrier=1:n_carriers
if (carrier==1) if (carrier==1)
transmit_f = transmit_f1; transmit_f = transmit_f1;
received_f = received_f1; received_f = received_f1;
else else
transmit_f = transmit_f2; transmit_f = transmit_f2;
received_f = received_f2; received_f = received_f2;
end
H = zeros(num_symbols_frame/2,p(carrier).useful_carriers/4,p(carrier).nant_tx,p(carrier).nant_rx);
for itx=1:p(carrier).nant_tx
% f_start and t_start indicate the start of the pilots in time
% and frequency according to the specifications (see .doc file).
% t_start has to be >=2, since the first symbol is the PSS.
f_start = mod(itx-1,2)*2+1;
t_start = floor((itx-1)/2)+1;
for irx=1:p(carrier).nant_rx
H(:,:,itx,irx)=conj(squeeze(transmit_f(itx,t_start:2:end,f_start:4:end))).*received_f(t_start:2:end,f_start:4:end,irx);
end end
end
Ht = ifft(H,[],2);
PDP = mean(abs(Ht).^2,1); H = zeros(num_symbols_frame/2,p(carrier).useful_carriers/4,p(carrier).nant_tx,p(carrier).nant_rx);
PDP_all = squeeze(mean(mean(PDP,3),4));
%PDP_total((block-1)*nframes+i+1,:,:,:) = PDP;
if enable_plots>=1
figure(3+2*(carrier-1))
for itx=1:p(carrier).nant_tx for itx=1:p(carrier).nant_tx
for irx=1:p(1).nant_rx % f_start and t_start indicate the start of the pilots in time
subplot(p(1).nant_tx,p(1).nant_rx,(itx-1)*p(1).nant_rx + irx); % and frequency according to the specifications (see .doc file).
surf(20*log10(abs(Ht(:,:,itx,irx)))) % t_start has to be >=2, since the first symbol is the PSS.
%xlabel('time [OFDM symbol]') f_start = mod(itx-1,2)*2+1;
%ylabel('delay time [samples]') t_start = floor((itx-1)/2)+1;
%zlabel('power [dB]') for irx=1:p(carrier).nant_rx
shading interp H(:,:,itx,irx)=conj(squeeze(transmit_f(itx,t_start:2:end,f_start:4:end))).*received_f(t_start:2:end,f_start:4:end,irx);
end end
end end
figure(4+2*(carrier-1)) Ht = ifft(H,[],2);
for itx=1:p(1).nant_tx PDP = mean(abs(Ht).^2,1);
for irx=1:p(1).nant_rx PDP_all = squeeze(mean(mean(PDP,3),4));
subplot(p(1).nant_tx,p(1).nant_rx,(itx-1)*p(1).nant_rx + irx); %PDP_total((block-1)*nframes+i+1,:,:,:) = PDP;
plot(10*log10(PDP(:,:,itx,irx)))
ylim([50 80]) if enable_plots>=1
xlim([0 75]) figure(3+2*(carrier-1))
%xlabel('delay time [samples]') for itx=1:p(carrier).nant_tx
%ylabel('power [dB]') for irx=1:p(1).nant_rx
subplot(p(1).nant_tx,p(1).nant_rx,(itx-1)*p(1).nant_rx + irx);
surf(20*log10(abs(Ht(:,:,itx,irx))))
%xlabel('time [OFDM symbol]')
%ylabel('delay time [samples]')
%zlabel('power [dB]')
shading interp
end
end
figure(4+2*(carrier-1))
for itx=1:p(1).nant_tx
for irx=1:p(1).nant_rx
subplot(p(1).nant_tx,p(1).nant_rx,(itx-1)*p(1).nant_rx + irx);
plot(10*log10(PDP(:,:,itx,irx)))
ylim([50 80])
xlim([0 75])
%xlabel('delay time [samples]')
%ylabel('power [dB]')
end
end
drawnow
end
if carrier==1
% adjust frame offset base on channel estimate to compensate for
% timing drift. We try to keep the peak of the impulse response at
% sample prefix_length/8.
[m,idx] = max(fft(ifft(PDP_all),p(carrier).num_carriers));
offset = idx - p(carrier).prefix_length/8;
if offset > p(carrier).prefix_length
offset = offset - p(carrier).num_carriers;
end
if abs(offset) > 5
frame_offset = frame_offset + round(offset/4);
end end
end end
drawnow
end
end
% adjust frame offset base on channel estimate to compensate for
% timing drift. We try to keep the peak of the impulse response at
% sample prefix_length/8.
[m,idx] = max(fft(ifft(PDP_all),p(1).num_carriers));
offset = idx - p(1).prefix_length/8;
if offset > p(1).prefix_length
offset = offset - p(1).num_carriers;
end
if abs(offset) > 5
frame_offset = frame_offset + round(offset/4);
end end
end end
......
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