Commit df29718a authored by Florian Kaltenberger's avatar Florian Kaltenberger

git-svn-id: http://svn.eurecom.fr/openair4G/trunk@5178 818b1a75-f10b-46b9-bf7c-635c3b92a50f
parent 35b66a85
close all
clear all
%% read data %% read data
fid = fopen('E:\EMOS\corridor\eNB_data_20140108_185919.EMOS','r'); fid = fopen('E:\EMOS\corridor\eNB_data_20140108_185919.EMOS','r');
[v,c]=fread(fid, 76800*4*100, 'int16',0,'ieee-le'); [v,c]=fread(fid, 76800*4*100, 'int16',0,'ieee-le');
...@@ -5,7 +8,7 @@ v2 = double(v(1:2:end))+1j*double(v(2:2:end)); ...@@ -5,7 +8,7 @@ v2 = double(v(1:2:end))+1j*double(v(2:2:end));
fclose(fid); fclose(fid);
figure(1) figure(1)
plot(abs(fft(v2))) plot(abs(fftshift(fft(v2))))
%% sync %% sync
addpath('../../../openair1/PHY/LTE_REFSIG'); addpath('../../../openair1/PHY/LTE_REFSIG');
...@@ -17,27 +20,39 @@ figure(2); ...@@ -17,27 +20,39 @@ figure(2);
plot(lag,abs(corr)); plot(lag,abs(corr));
%% frame start detection %% frame start detection
% TODO: do a proper peak detection. for now just take the max %load('../LOCALIZATION/ofdm_pilots_sync_2048.mat');
[m,i]=max(abs(corr)); load('E:\EMOS\corridor\ofdm_pilots_sync_2048_v7.mat');
frame_start = lag(i);
%% ofdm receiver
load('../LOCALIZATION/ofdm_pilots_sync_2048.mat');
ofdm_symbol_length = num_carriers + prefix_length; ofdm_symbol_length = num_carriers + prefix_length;
frame_length = ofdm_symbol_length*num_symbols_frame; frame_length = ofdm_symbol_length*num_symbols_frame;
useful_carriers = num_carriers-num_zeros-1; useful_carriers = num_carriers-num_zeros-1;
% TODO: do a proper peak detection. for now just take the max
[m,i]=max(abs(corr));
frame_start = lag(i) - prefix_length;
%% ofdm receiver
received = v2(frame_start:frame_start+frame_length); received = v2(frame_start:frame_start+frame_length);
received_f = zeros(num_symbols_frame,useful_carriers); received_f = zeros(num_symbols_frame,useful_carriers);
for i=0:num_symbols_frame-1; for i=0:num_symbols_frame-1;
ifblock=received(i*ofdm_symbol_length+[1:ofdm_symbol_length]); ifblock=received(i*ofdm_symbol_length+[1:ofdm_symbol_length]);
ifblock(1:prefix_length)=[]; ifblock(1:prefix_length)=[];
fblock=fft(ifblock); fblock=fft(ifblock);
received_f(i+1,:) = [fblock(end-useful_carriers/2+1:end); fblock(2:useful_carriers/2+1)]; received_f(i+1,:) = [fblock(2:useful_carriers/2+1); fblock(end-useful_carriers/2+1:end)];
end end
%% channel estimation %% channel estimation
H=conj(f).*received_f; H=conj(f).*received_f;
Ht = ifft(H,[],2);
PDP = mean(abs(Ht(2:end,:).^2),1);
figure(3)
surf(20*log10(abs(Ht)))
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]')
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