Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
O
OpenXG-RAN
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lizhongxiao
OpenXG-RAN
Commits
f01d4666
Commit
f01d4666
authored
Dec 16, 2014
by
Florian Kaltenberger
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
git-svn-id:
http://svn.eurecom.fr/openair4G/trunk@6269
818b1a75-f10b-46b9-bf7c-635c3b92a50f
parent
57dfae19
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
64 additions
and
18 deletions
+64
-18
targets/PROJECTS/CORRIDOR/OFDM_RX.m
targets/PROJECTS/CORRIDOR/OFDM_RX.m
+1
-1
targets/PROJECTS/CORRIDOR/emos_read_v2.m
targets/PROJECTS/CORRIDOR/emos_read_v2.m
+62
-16
targets/PROJECTS/CORRIDOR/log_read.m
targets/PROJECTS/CORRIDOR/log_read.m
+1
-1
No files found.
targets/PROJECTS/CORRIDOR/OFDM_RX.m
View file @
f01d4666
...
@@ -5,6 +5,6 @@ received_f = zeros(num_symbols_frame,useful_carriers,nant);
...
@@ -5,6 +5,6 @@ received_f = zeros(num_symbols_frame,useful_carriers,nant);
for j=0:num_symbols_frame-1;
for j=0:num_symbols_frame-1;
ifblock=received(j*ofdm_symbol_length+(1:ofdm_symbol_length),:);
ifblock=received(j*ofdm_symbol_length+(1:ofdm_symbol_length),:);
ifblock(1:prefix_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,:)];
received_f(j+1,:,:) = [fblock(2:useful_carriers/2+1,:); fblock(end-useful_carriers/2+1:end,:)];
end
end
\ No newline at end of file
targets/PROJECTS/CORRIDOR/emos_read_v2.m
View file @
f01d4666
...
@@ -3,10 +3,13 @@ clear all
...
@@ -3,10 +3,13 @@ clear all
global
symbols_per_slot
slots_per_frame
;
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
enable_plots
=
0
;
%enables figures
record
=
0
;
%put 1 to enable the video record of the delay doppler profile
record
=
0
;
%put 1 to enable the video record of the delay doppler profile
%% preload and init data
%% preload and init data
addpath
(
'../../../openair1/PHY/LTE_REFSIG'
);
primary_synch
;
%loads the primary sync signal
primary_synch
;
%loads the primary sync signal
%load('E:\EMOS\corridor\ofdm_pilots_sync_2048_v7.mat');
%load('E:\EMOS\corridor\ofdm_pilots_sync_2048_v7.mat');
...
@@ -18,15 +21,19 @@ n_run=1;
...
@@ -18,15 +21,19 @@ n_run=1;
symbols_per_slot
=
6
;
symbols_per_slot
=
6
;
slots_per_frame
=
20
;
slots_per_frame
=
20
;
sourcedir
=
'F:\trials2 train extracted\'
;
destdir
=
'F:\trials2 train processed\'
;
switch
n_carriers
switch
n_carriers
case
1
,
case
1
,
p
=
init_params
(
25
,
3
,
4
);
%this can be 25, 50, or 100
p
=
init_params
(
25
,
3
,
4
);
%this can be 25, 50, or 100
pss_t
=
upsample
(
primary_synch0_time
,
4
);
pss_t
=
upsample
(
primary_synch0_time
,
4
);
if
n_trials
==
1
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
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
end
nframes
=
100
;
% frames in one block
nframes
=
100
;
% frames in one block
...
@@ -37,22 +44,20 @@ switch n_carriers
...
@@ -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
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
)
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
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
end
nframes
=
50
;
% frames in one block
nframes
=
50
;
% frames in one block
threshold
=
3e+4
;
% maybe should change that !!!!
threshold
=
3e+4
;
% maybe should change that !!!!
end
end
destdir
=
'E:\EMOS\corridor\tmp'
;
% derived parameters
% derived parameters
samples_slot_agg
=
sum
([
p
.
nant_rx
]
.*
[
p
.
samples_slot
]);
samples_slot_agg
=
sum
([
p
.
nant_rx
]
.*
[
p
.
samples_slot
]);
num_symbols_frame
=
symbols_per_slot
*
slots_per_frame
;
num_symbols_frame
=
symbols_per_slot
*
slots_per_frame
;
d
=
dir
(
f
ilename
);
d
=
dir
(
f
ullfile
(
sourcedir
,[
filename
'.EMOS'
])
);
nblocks
=
floor
(
d
.
bytes
/(
samples_slot_agg
*
slots_per_frame
*
nframes
*
4
));
nblocks
=
floor
(
d
.
bytes
/(
samples_slot_agg
*
slots_per_frame
*
nframes
*
4
));
%frequency offset
%frequency offset
...
@@ -172,11 +177,15 @@ end
...
@@ -172,11 +177,15 @@ end
syncblock
=
0
;
%variable containing the number of the synchronization block
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
%% main loop
fid
=
fopen
(
f
ilename
,
'r'
);
fid
=
fopen
(
f
ullfile
(
sourcedir
,[
filename
'.EMOS'
])
,
'r'
);
vStorage1
=
[];
vStorage1
=
[];
vStorage2
=
[];
vStorage2
=
[];
...
@@ -361,6 +370,10 @@ while ~feof(fid)
...
@@ -361,6 +370,10 @@ while ~feof(fid)
max1
=
0
;
%variable containing a maximum
max1
=
0
;
%variable containing a maximum
end
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
;
for
i
=
start
:
nframes
;
fprintf
(
1
,
'.'
);
fprintf
(
1
,
'.'
);
...
@@ -410,8 +423,9 @@ while ~feof(fid)
...
@@ -410,8 +423,9 @@ while ~feof(fid)
received_f
=
received_f2
;
received_f
=
received_f2
;
end
end
% standard channel estimation
H
=
zeros
(
num_symbols_frame
/
2
,
p
(
carrier
)
.
useful_carriers
/
4
,
p
(
carrier
)
.
nant_tx
,
p
(
carrier
)
.
nant_rx
);
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
for
itx
=
1
:
p
(
carrier
)
.
nant_tx
% f_start and t_start indicate the start of the pilots in time
% f_start and t_start indicate the start of the pilots in time
% and frequency according to the specifications (see .doc file).
% and frequency according to the specifications (see .doc file).
...
@@ -429,6 +443,26 @@ while ~feof(fid)
...
@@ -429,6 +443,26 @@ while ~feof(fid)
H_power2
((
block
-
1
)
*
NFRAMES
+
i
,:,:)
=
10
*
log10
(
mean
(
mean
(
abs
(
H
)
.^
2
,
1
),
2
));
H_power2
((
block
-
1
)
*
NFRAMES
+
i
,:,:)
=
10
*
log10
(
mean
(
mean
(
abs
(
H
)
.^
2
,
1
),
2
));
end
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
Ht
=
ifft
(
H
,[],
2
)
*
sqrt
(
size
(
H
,
2
));
%impulse response
PDP
=
mean
(
abs
(
Ht
)
.^
2
,
1
);
PDP
=
mean
(
abs
(
Ht
)
.^
2
,
1
);
PDP_all
=
squeeze
(
mean
(
mean
(
PDP
,
3
),
4
));
PDP_all
=
squeeze
(
mean
(
mean
(
PDP
,
3
),
4
));
...
@@ -443,7 +477,8 @@ while ~feof(fid)
...
@@ -443,7 +477,8 @@ while ~feof(fid)
PDP_totalb
((
block
-
1
)
*
NFRAMES
+
i
,:,:,:)
=
PDP
;
PDP_totalb
((
block
-
1
)
*
NFRAMES
+
i
,:,:,:)
=
PDP
;
Hb
=
H
;
Hb
=
H
;
end
end
%
% % frequency offset correction
% Hprime=H*exp(2*i*pi*167E-6*f_offset);
% Hprime=H*exp(2*i*pi*167E-6*f_offset);
% Htprime = ifft(Hprime,[],2); %impulse response
% Htprime = ifft(Hprime,[],2); %impulse response
% PDPprime = mean(abs(Htprime).^2,1);
% PDPprime = mean(abs(Htprime).^2,1);
...
@@ -554,7 +589,19 @@ while ~feof(fid)
...
@@ -554,7 +589,19 @@ while ~feof(fid)
end
end
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
);
Ht1a
=
ifft
(
H1a
,[],
2
);
...
@@ -1006,12 +1053,11 @@ end
...
@@ -1006,12 +1053,11 @@ end
fclose
(
fid
);
fclose
(
fid
);
%% save processed data
%% save processed data
[
path
,
name
,
ext
]
=
fileparts
(
filename
);
if
(
n_carriers
==
1
)
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
end
if
(
n_carriers
==
2
)
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
end
\ No newline at end of file
targets/PROJECTS/CORRIDOR/log_read.m
View file @
f01d4666
...
@@ -99,7 +99,7 @@ for idx=1:length(d1)
...
@@ -99,7 +99,7 @@ for idx=1:length(d1)
plot
(
rtime2
,
smooth
(
N2
(:,
3
),
100
),
'm'
)
plot
(
rtime2
,
smooth
(
N2
(:,
3
),
100
),
'm'
)
legend
(
'UHF'
,
'2.6GHz card 1'
,
'2.6GHz card 2'
,
'2.6GHz card 3'
);
legend
(
'UHF'
,
'2.6GHz card 1'
,
'2.6GHz card 2'
,
'2.6GHz card 3'
);
xlabel
(
'time [seconds]'
)
xlabel
(
'time [seconds]'
)
ylabel
(
'N
F
[dB]'
)
ylabel
(
'N
oise
[dB]'
)
title
(
sprintf
(
'Run %d'
,
idx
));
title
(
sprintf
(
'Run %d'
,
idx
));
saveas
(
h
,
sprintf
(
'figures/nf_vs_time_run%d.eps'
,
idx
),
'epsc2'
);
saveas
(
h
,
sprintf
(
'figures/nf_vs_time_run%d.eps'
,
idx
),
'epsc2'
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment