diff --git a/targets/PROJECTS/CORRIDOR/OFDM_RX.m b/targets/PROJECTS/CORRIDOR/OFDM_RX.m
index 3198cdb33a9b286b134d51ffd78cfb67db8d8068..924e93ce803c9dce74f2fa1c2e942a296f5db1a6 100644
--- a/targets/PROJECTS/CORRIDOR/OFDM_RX.m
+++ b/targets/PROJECTS/CORRIDOR/OFDM_RX.m
@@ -5,6 +5,6 @@ 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);
+    fblock=fft(ifblock,[],1)/sqrt(num_carriers);
     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/emos_read_v2.m b/targets/PROJECTS/CORRIDOR/emos_read_v2.m
index 943c599663b41069b0a8f6ddddcd60b3dc5f6e3d..a16c2fa24588b7e39bac90baf326fdc6ce06c258 100644
--- a/targets/PROJECTS/CORRIDOR/emos_read_v2.m
+++ b/targets/PROJECTS/CORRIDOR/emos_read_v2.m
@@ -3,10 +3,13 @@ clear all
 
 global symbols_per_slot slots_per_frame;
 
+addpath('E:\Synchro\kaltenbe\My Documents\Matlab\dpss_chanest')
+addpath('../../../openair1/PHY/LTE_REFSIG');
+
 enable_plots=0; %enables figures
 record=0; %put 1 to enable the video record of the delay doppler profile
+
 %% preload and init data
-addpath('../../../openair1/PHY/LTE_REFSIG');
 primary_synch; %loads the primary sync signal
 
 %load('E:\EMOS\corridor\ofdm_pilots_sync_2048_v7.mat');
@@ -18,15 +21,19 @@ n_run=1;
 symbols_per_slot = 6;
 slots_per_frame = 20;
 
+sourcedir = 'F:\trials2 train extracted\';
+destdir = 'F:\trials2 train processed\';
+
+
 switch n_carriers
     case 1,
         p = init_params(25,3,4); %this can be 25, 50, or 100
         pss_t = upsample(primary_synch0_time,4);
         
         if n_trials==1
-            filename = sprintf('F:\\trials1 train extracted\\eNB_data_20140331_UHF_run%d.EMOS',n_run);
+            filename = sprintf('eNB_data_20140331_UHF_run%d',n_run);
         else
-            filename = sprintf('F:\\trials2 train extracted\\eNB_data_UHF_20140519_run%d.EMOS',n_run);
+            filename = sprintf('eNB_data_UHF_20140519_run%d',n_run);
         end
         
         nframes = 100; % frames in one block
@@ -37,22 +44,20 @@ switch n_carriers
         pss_t = upsample(primary_synch0_time,4*4); % this assumes we are doing the sync on the second carrier, which is 10MHz
         
         if (n_trials==1)
-            filename = sprintf('F:\\trials1 train extracted\\eNB_data_20140331_2.6GHz_run%d.EMOS',n_run);
+            filename = sprintf('eNB_data_20140331_2.6GHz_run%d',n_run);
         else
-            filename = sprintf('F:\\trials2 train extracted\\eNB_data_20140519_2.6GHz_run%d.EMOS',n_run);
+            filename = sprintf('eNB_data_20140519_2.6GHz_run%d',n_run);
         end
         
         nframes = 50; % frames in one block
         threshold = 3e+4 ; % maybe should change that !!!!
 end
 
-destdir = 'E:\EMOS\corridor\tmp';
-
 % derived parameters
 samples_slot_agg = sum([p.nant_rx].*[p.samples_slot]);
 num_symbols_frame = symbols_per_slot*slots_per_frame;
 
-d = dir(filename);
+d = dir(fullfile(sourcedir,[filename '.EMOS']));
 nblocks = floor(d.bytes/(samples_slot_agg*slots_per_frame*nframes*4));
 
 %frequency offset
@@ -172,11 +177,15 @@ end
 syncblock=0;%variable containing the number of the synchronization block
 
 
-
+%% init DPSS parameters
+max_tau = 1e-6;
+for carrier=1:n_carriers
+    p_dpss(carrier) = init_dpss(p(carrier),max_tau);
+end
 
 
 %% main loop
-fid = fopen(filename,'r');
+fid = fopen(fullfile(sourcedir,[filename '.EMOS']),'r');
 
 vStorage1 = [];
 vStorage2 = [];
@@ -361,6 +370,10 @@ while ~feof(fid)
             max1=0;%variable containing a maximum
         end
         
+        H_dpss1 = zeros(nframes*num_symbols_frame/2,p(1).useful_carriers,p(1).nant_tx,p(1).nant_rx);
+        if (n_carriers==2)
+            H_dpss2 = zeros(nframes*num_symbols_frame/2,p(2).useful_carriers,p(2).nant_tx,p(2).nant_rx);
+        end
         for i=start:nframes;
             
             fprintf(1,'.');
@@ -410,8 +423,9 @@ while ~feof(fid)
                     received_f = received_f2;
                 end
                 
-                
+                % standard channel estimation
                 H = zeros(num_symbols_frame/2,p(carrier).useful_carriers/4,p(carrier).nant_tx,p(carrier).nant_rx);
+                H_dpss = 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).
@@ -429,6 +443,26 @@ while ~feof(fid)
                     H_power2((block-1)*NFRAMES+i,:,:) = 10*log10(mean(mean(abs(H).^2,1),2));
                 end
                 
+                %% dpss channel estimation
+                snr = zeros(size(H_power1));
+                for itx=1:p(carrier).nant_tx
+                    f_start = mod(itx-1,2)*2+1;
+                    for irx=1:p(carrier).nant_rx
+                        snr((block-1)*NFRAMES+i,itx,irx)=squeeze(H_power1((block-1)*NFRAMES+i,itx,irx))-noise1((block-1)*NFRAMES+i,irx);
+                        snr_rounded = min(max(round(snr((block-1)*NFRAMES+i,itx,irx)),0),30);
+                        for it=1:num_symbols_frame/2
+                            if (carrier==1)
+                                H_dpss1((i-1)*num_symbols_frame/2+it,:,itx,irx) = dpss_smooth(H(it,:,itx,irx),p_dpss(carrier).V,p_dpss(carrier).Dopt(snr_rounded+1),f_start);
+                            else
+                                H_dpss2((i-1)*num_symbols_frame/2+it,:,itx,irx) = dpss_smooth(H(it,:,itx,irx),p_dpss(carrier).V,p_dpss(carrier).Dopt(snr_rounded+1),f_start);
+                            end
+                        end
+                    end
+                end
+                
+               
+                
+                %% compute delay Doppler power profiles 
                 Ht = ifft(H,[],2)*sqrt(size(H,2)); %impulse response
                 PDP = mean(abs(Ht).^2,1);
                 PDP_all = squeeze(mean(mean(PDP,3),4));
@@ -443,7 +477,8 @@ while ~feof(fid)
                     PDP_totalb((block-1)*NFRAMES+i,:,:,:) = PDP;
                     Hb=H;
                 end
-                %
+                
+                %                 % frequency offset correction
                 %                 Hprime=H*exp(2*i*pi*167E-6*f_offset);
                 %                 Htprime = ifft(Hprime,[],2); %impulse response
                 %                 PDPprime = mean(abs(Htprime).^2,1);
@@ -554,7 +589,19 @@ while ~feof(fid)
             end
         end
         
-        %
+        %save postprocessed channels
+        for carrier=1:n_carriers
+                varname1 = sprintf('H_dpss%d',carrier);
+                varname2 = sprintf('H_dpss_block%d',block);
+                eval([varname2 '='  varname1 ';']);
+                filename_H = sprintf('_H_dpss_carrier%d.mat',carrier);
+                if exist(fullfile(destdir,[filename filename_H]),'file')
+                    save(fullfile(destdir,[filename filename_H]),varname2,'-append');
+                else
+                    save(fullfile(destdir,[filename filename_H]),varname2);
+                end
+                clear(varname2);
+        end
         
         Ht1a=ifft(H1a,[],2);
         
@@ -1006,12 +1053,11 @@ end
 fclose(fid);
 
 %% save processed data
-[path,name,ext]=fileparts(filename);
 if(n_carriers==1)
-    save([name '.mat'],'PDP_totala','PDD_totala','mean_delay_a','mean_doppler_shift_a','doppler_freq_of_max_a','delay_doppler_profile_beforea','delay_doppler_profile_duringa','delay_doppler_profile_aftera','noise1','H_power1');
+    save(fullfile(destdir,[filename '.mat']),'PDP_totala','PDD_totala','mean_delay_a','mean_doppler_shift_a','doppler_freq_of_max_a','delay_doppler_profile_beforea','delay_doppler_profile_duringa','delay_doppler_profile_aftera','noise1','H_power1');
     
 end
 if(n_carriers==2)
-    save([name '.mat'],'PDP_totala','PDD_totala','mean_delay_a','mean_doppler_shift_a','doppler_freq_of_max_a','delay_doppler_profile_beforea','delay_doppler_profile_duringa','delay_doppler_profile_aftera','PDP_totalb','PDD_totalb','mean_delay_b','mean_doppler_shift_b','doppler_freq_of_max_b','delay_doppler_profile_beforeb','delay_doppler_profile_duringb','delay_doppler_profile_afterb','noise1','H_power1','noise2','H_power2');
+    save(fullfile(destdir,[filename '.mat']),'PDP_totala','PDD_totala','mean_delay_a','mean_doppler_shift_a','doppler_freq_of_max_a','delay_doppler_profile_beforea','delay_doppler_profile_duringa','delay_doppler_profile_aftera','PDP_totalb','PDD_totalb','mean_delay_b','mean_doppler_shift_b','doppler_freq_of_max_b','delay_doppler_profile_beforeb','delay_doppler_profile_duringb','delay_doppler_profile_afterb','noise1','H_power1','noise2','H_power2');
     
 end
\ No newline at end of file
diff --git a/targets/PROJECTS/CORRIDOR/log_read.m b/targets/PROJECTS/CORRIDOR/log_read.m
index b786b9ffac7153bf9d0fe79d5d5b39d8c1cd55db..217168b061441993fd56682593f6c45ca8db04fa 100644
--- a/targets/PROJECTS/CORRIDOR/log_read.m
+++ b/targets/PROJECTS/CORRIDOR/log_read.m
@@ -99,7 +99,7 @@ for idx=1:length(d1)
     plot(rtime2,smooth(N2(:,3),100),'m')
     legend('UHF','2.6GHz card 1','2.6GHz card 2','2.6GHz card 3');
     xlabel('time [seconds]')
-    ylabel('NF [dB]')
+    ylabel('Noise [dB]')
     title(sprintf('Run %d',idx));
     saveas(h,sprintf('figures/nf_vs_time_run%d.eps',idx),'epsc2');