From 0862a82b4ca2a9128b93fb1d21e85050e4bda2ba Mon Sep 17 00:00:00 2001
From: Florian Kaltenberger <florian.kaltenberger@eurecom.fr>
Date: Fri, 21 Mar 2014 18:00:49 +0000
Subject: [PATCH] updated emos_read scripts and signal generation script

git-svn-id: http://svn.eurecom.fr/openair4G/trunk@5207 818b1a75-f10b-46b9-bf7c-635c3b92a50f
---
 targets/PROJECTS/CORRIDOR/OFDM_RX.m           | 10 +++
 .../PROJECTS/CORRIDOR/OFDM_TX_FRAME_MIMO.m    |  4 +-
 targets/PROJECTS/CORRIDOR/emos_read.m         | 63 +++++++++++--------
 targets/PROJECTS/CORRIDOR/emos_read_ca.m      | 12 ++--
 targets/PROJECTS/CORRIDOR/generation_ca.m     |  5 ++
 5 files changed, 61 insertions(+), 33 deletions(-)
 create mode 100644 targets/PROJECTS/CORRIDOR/OFDM_RX.m

diff --git a/targets/PROJECTS/CORRIDOR/OFDM_RX.m b/targets/PROJECTS/CORRIDOR/OFDM_RX.m
new file mode 100644
index 0000000000..3198cdb33a
--- /dev/null
+++ b/targets/PROJECTS/CORRIDOR/OFDM_RX.m
@@ -0,0 +1,10 @@
+function received_f = OFDM_RX(received,num_carriers,useful_carriers,prefix_length,num_symbols_frame)
+nant = size(received,2);
+ofdm_symbol_length = num_carriers + prefix_length;
+received_f = zeros(num_symbols_frame,useful_carriers,nant);
+for j=0:num_symbols_frame-1;
+    ifblock=received(j*ofdm_symbol_length+(1:ofdm_symbol_length),:);
+    ifblock(1:prefix_length,:)=[];
+    fblock=fft(ifblock,[],1);
+    received_f(j+1,:,:) = [fblock(2:useful_carriers/2+1,:); fblock(end-useful_carriers/2+1:end,:)];
+end
\ No newline at end of file
diff --git a/targets/PROJECTS/CORRIDOR/OFDM_TX_FRAME_MIMO.m b/targets/PROJECTS/CORRIDOR/OFDM_TX_FRAME_MIMO.m
index 39dfaca692..6abb88a47d 100644
--- a/targets/PROJECTS/CORRIDOR/OFDM_TX_FRAME_MIMO.m
+++ b/targets/PROJECTS/CORRIDOR/OFDM_TX_FRAME_MIMO.m
@@ -18,7 +18,7 @@ elseif (num_ant ==2)
     f_dec = 2;
 elseif (num_ant == 4)
     t_dec = 2;
-    f_dec = 2;
+    f_dec = 4;
 else
     error('Only 1, 2 or 4 antennas supported');
 end
@@ -29,7 +29,7 @@ sig_f = zeros(num_ant,num_symbols_frame,num_useful_carriers);
 for a=1:num_ant
 for k=(floor((a-1)/2)+1):t_dec:preamble_length
     QAM4_preamble = zeros(1,num_useful_carriers);
-    QAM4_preamble((mod(a-1,2)+1):f_dec:num_useful_carriers) = QAM_MOD(4,floor(4*abs(rand(1,num_useful_carriers/f_dec))));
+    QAM4_preamble(2*mod(a-1,2)+1:f_dec:num_useful_carriers) = QAM_MOD(4,floor(4*abs(rand(1,num_useful_carriers/f_dec))));
     sig(a,(k-1)*(num_carriers+prefix_length)+1:k*(num_carriers+prefix_length)) = OFDM_TX(num_carriers,num_zeros,prefix_length,QAM4_preamble);
     sig_f(a,k,:) = QAM4_preamble;
 end
diff --git a/targets/PROJECTS/CORRIDOR/emos_read.m b/targets/PROJECTS/CORRIDOR/emos_read.m
index 6642d60bf5..fd9f5449ac 100644
--- a/targets/PROJECTS/CORRIDOR/emos_read.m
+++ b/targets/PROJECTS/CORRIDOR/emos_read.m
@@ -1,27 +1,29 @@
 close all
 clear all
 
-enable_plots=1; %eanbles figures
+enable_plots=2; %eanbles figures
 
 %% preload and init data
 addpath('../../../openair1/PHY/LTE_REFSIG');
 primary_synch; %loads the primary sync signal
-pss_t = upsample(primary_synch0_time,4*4);
+pss_t = upsample(primary_synch0_time,4);
+
+%load('E:\EMOS\corridor\ofdm_pilots_sync_2048_v7.mat');
+load('ofdm_pilots_sync_30MHz.mat');
 
-%load('../LOCALIZATION/ofdm_pilots_sync_2048.mat');
-load('E:\EMOS\corridor\ofdm_pilots_sync_2048_v7.mat');
 ofdm_symbol_length = num_carriers + prefix_length;
 frame_length = ofdm_symbol_length*num_symbols_frame;
 useful_carriers = num_carriers-num_zeros-1;
 
-filename = 'E:\EMOS\corridor\eNB_data_20140108_185919.EMOS';
-samples_slot = 7680*2;
+filename = 'E:\EMOS\corridor2\eNB_data_20140321_184441.EMOS';
+samples_slot = 7680/2;
 slots_per_frame = 20;
 nframes = 100;
+nant=3;
 
 d = dir(filename);
-nblocks = floor(d.bytes/(samples_slot*slots_per_frame*nframes*4));
-PDP_total = zeros(nblocks*nframes,useful_carriers);
+nblocks = floor(d.bytes/(samples_slot*slots_per_frame*nframes*nant*4));
+PDP_total = zeros(nblocks*nframes,useful_carriers/4);
 
 %% main loop
 fid = fopen(filename,'r');
@@ -29,42 +31,53 @@ block = 1;
 while ~feof(fid)
     fprintf(1,'Processing block %d of %d',block,nblocks);
     
-    [v,c]=fread(fid, samples_slot*slots_per_frame*nframes*2, 'int16',0,'ieee-le');
-    v2 = double(v(1:2:end))+1j*double(v(2:2:end));
+    [v,c]=fread(fid, samples_slot*slots_per_frame*nframes*nant*2, 'int16',0,'ieee-le');
+    if (c==0)
+        break
+    end
+    v1 = double(v(1:2:end))+1j*double(v(2:2:end));
     
-    [corr,lag] = xcorr(v2,pss_t);
+    v2 = zeros(samples_slot*slots_per_frame*nframes,nant);
+    for slot=1:slots_per_frame*nframes
+        for a=1:nant
+            v2((slot-1)*samples_slot+1:slot*samples_slot,a) = ...
+                v1((slot-1)*samples_slot*nant+(a-1)*samples_slot+1:...
+                   (slot-1)*samples_slot*nant+ a   *samples_slot,1);
+        end
+    end
 
     if enable_plots>=2
         figure(1)
         plot(abs(fftshift(fft(v2))))
-
-        figure(2);
-        plot(lag,abs(corr));
     end
     
     %% frame start detection
-    %[m,i]=max(abs(corr));
+    [corr,lag] = xcorr(v2(:,1),pss_t);
+    %[m,idx]=max(abs(corr));
     [m,idx]=peaksfinder(corr,frame_length);
     
+    if enable_plots>=2
+        figure(2);
+        hold off
+        plot(lag,abs(corr));
+        hold on
+        plot(lag(idx),m,'ro')
+    end
+    
+    
+    %%
     for i=1:size(idx,2)-1; % the last frame is not complite
         fprintf(1,'.');
         frame_start = lag(idx(i))-prefix_length;
         % frame_start = lag(i) - prefix_length;
         
         %% ofdm receiver
-        received = v2(frame_start:frame_start+frame_length);
-        received_f = zeros(num_symbols_frame,useful_carriers);
-        for j=0:num_symbols_frame-1;
-            ifblock=received(j*ofdm_symbol_length+(1:ofdm_symbol_length));
-            ifblock(1:prefix_length)=[];
-            fblock=fft(ifblock);
-            received_f(j+1,:) = [fblock(2:useful_carriers/2+1); fblock(end-useful_carriers/2+1:end)];
-        end
+        received_f = OFDM_RX(v2(frame_start:frame_start+frame_length,:),num_carriers,useful_carriers,prefix_length,num_symbols_frame);
         
         %% channel estimation
-        H=conj(f).*received_f;
+        H=conj(squeeze(f3(1,3:2:end,1:4:end))).*received_f(3:2:end,1:4:end,1);
         Ht = ifft(H,[],2);
-        PDP = mean(abs(Ht(2:end,:).^2),1);
+        PDP = mean(abs(Ht).^2,1);
         PDP_total((block-1)*nframes+i+1,:) = PDP;
         
         if enable_plots>=1
diff --git a/targets/PROJECTS/CORRIDOR/emos_read_ca.m b/targets/PROJECTS/CORRIDOR/emos_read_ca.m
index d48e21a43a..53907e0e5d 100644
--- a/targets/PROJECTS/CORRIDOR/emos_read_ca.m
+++ b/targets/PROJECTS/CORRIDOR/emos_read_ca.m
@@ -40,8 +40,8 @@ slots_per_frame = 20;
 
 d = dir(filename);
 nblocks = floor(d.bytes/(samples_slot_agg*slots_per_frame*nframes*4));
-PDP1_total = zeros(nblocks*nframes,useful_carriers1);
-PDP2_total = zeros(nblocks*nframes,useful_carriers2);
+PDP1_total = zeros(nblocks*nframes,useful_carriers1/2);
+PDP2_total = zeros(nblocks*nframes,useful_carriers2/2);
 
 %% main loop
 fid = fopen(filename,'r');
@@ -104,12 +104,12 @@ while ~feof(fid)
         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);
+        H1=conj(squeeze(f1(1,3:2:end,1:2:end))).*received_f1(3:2:end,1:2:end,1);
+        H2=conj(squeeze(f2(1,3:2:end,1:2:end))).*received_f2(3:2:end,1:2:end,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 = mean(abs(H1t).^2,1);
+        PDP2 = mean(abs(H2t).^2,1);
         PDP1_total((block-1)*nframes+i+1,:) = PDP1;
         PDP2_total((block-1)*nframes+i+1,:) = PDP2;
         
diff --git a/targets/PROJECTS/CORRIDOR/generation_ca.m b/targets/PROJECTS/CORRIDOR/generation_ca.m
index 0ccd6c9b35..1bc98964a8 100644
--- a/targets/PROJECTS/CORRIDOR/generation_ca.m
+++ b/targets/PROJECTS/CORRIDOR/generation_ca.m
@@ -89,3 +89,8 @@ save('ofdm_pilots_sync_30MHz.mat','-v7','s1','s2','s3','f1','f2','f3','num_carri
 s_all = sum(s,1);
 s_all(1:5120) = s(1,1:5120);
 mat2wv(s_all, 'ofdm_pilots_sync_30MHz.wv', sample_rate, 1);
+
+s_all = sum(s3,1);
+s_all(1:640) = s3(1,1:640);
+mat2wv(s_all, 'ofdm_pilots_sync_5MHz.wv', 7.68e6, 1);
+
-- 
GitLab