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
canghaiwuhen
OpenXG-RAN
Commits
e90603fe
Commit
e90603fe
authored
Jan 31, 2019
by
Florian Kaltenberger
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
making first_carrier_offset flexible for all prossible N_RB_DL
parent
4e62f468
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
33 additions
and
59 deletions
+33
-59
openair1/PHY/INIT/nr_parms.c
openair1/PHY/INIT/nr_parms.c
+18
-37
openair1/SIMULATION/NR_PHY/pbchsim.c
openair1/SIMULATION/NR_PHY/pbchsim.c
+15
-22
No files found.
openair1/PHY/INIT/nr_parms.c
View file @
e90603fe
...
@@ -128,11 +128,13 @@ int nr_init_frame_parms0(NR_DL_FRAME_PARMS *fp,
...
@@ -128,11 +128,13 @@ int nr_init_frame_parms0(NR_DL_FRAME_PARMS *fp,
switch
(
mu
)
{
switch
(
mu
)
{
/*
case NR_MU_0: //15kHz scs
case NR_MU_0: //15kHz scs
fp->subcarrier_spacing = nr_subcarrier_spacing[NR_MU_0];
fp->subcarrier_spacing = nr_subcarrier_spacing[NR_MU_0];
fp->slots_per_subframe = nr_slots_per_subframe[NR_MU_0];
fp->slots_per_subframe = nr_slots_per_subframe[NR_MU_0];
fp->ssb_type = nr_ssb_type_A;
fp->ssb_type = nr_ssb_type_A;
break;
break;
*/
case
NR_MU_1
:
//30kHz scs
case
NR_MU_1
:
//30kHz scs
fp
->
subcarrier_spacing
=
nr_subcarrier_spacing
[
NR_MU_1
];
fp
->
subcarrier_spacing
=
nr_subcarrier_spacing
[
NR_MU_1
];
...
@@ -148,65 +150,42 @@ int nr_init_frame_parms0(NR_DL_FRAME_PARMS *fp,
...
@@ -148,65 +150,42 @@ int nr_init_frame_parms0(NR_DL_FRAME_PARMS *fp,
AssertFatal
(
1
==
0
,
"NR Operating Band n%d not available for SS block SCS with mu=%d
\n
"
,
fp
->
eutra_band
,
mu
);
AssertFatal
(
1
==
0
,
"NR Operating Band n%d not available for SS block SCS with mu=%d
\n
"
,
fp
->
eutra_band
,
mu
);
}
}
switch
(
N_RB_DL
){
if
(
N_RB_DL
>
0
&&
N_RB_DL
<=
106
)
{
case
11
:
case
24
:
case
38
:
case
78
:
case
51
:
case
65
:
case
106
:
//40 MHz
if
(
fp
->
threequarter_fs
)
{
if
(
fp
->
threequarter_fs
)
{
fp
->
ofdm_symbol_size
=
1536
;
fp
->
ofdm_symbol_size
=
1536
;
fp
->
first_carrier_offset
=
900
;
//1536 - ( (106*12) / 2 )
fp
->
nb_prefix_samples0
=
132
;
fp
->
nb_prefix_samples0
=
132
;
fp
->
nb_prefix_samples
=
108
;
fp
->
nb_prefix_samples
=
108
;
}
}
else
{
else
{
fp
->
ofdm_symbol_size
=
2048
;
fp
->
ofdm_symbol_size
=
2048
;
fp
->
first_carrier_offset
=
1412
;
//2048 - ( (106*12) / 2 )
fp
->
nb_prefix_samples0
=
176
;
fp
->
nb_prefix_samples0
=
176
;
fp
->
nb_prefix_samples
=
144
;
fp
->
nb_prefix_samples
=
144
;
}
}
break
;
}
else
if
(
N_RB_DL
>
106
&&
N_RB_DL
<=
217
)
{
case
133
:
case
162
:
case
189
:
case
217
:
//80 MHz
if
(
fp
->
threequarter_fs
)
{
if
(
fp
->
threequarter_fs
)
{
fp
->
ofdm_symbol_size
=
3072
;
fp
->
ofdm_symbol_size
=
3072
;
fp
->
first_carrier_offset
=
1770
;
//3072 - ( (217*12) / 2 )
fp
->
nb_prefix_samples0
=
264
;
fp
->
nb_prefix_samples0
=
264
;
fp
->
nb_prefix_samples
=
216
;
fp
->
nb_prefix_samples
=
216
;
}
}
else
{
else
{
fp
->
ofdm_symbol_size
=
4096
;
fp
->
ofdm_symbol_size
=
4096
;
fp
->
first_carrier_offset
=
2794
;
//4096 - ( (217*12) / 2 )
fp
->
nb_prefix_samples0
=
352
;
fp
->
nb_prefix_samples0
=
352
;
fp
->
nb_prefix_samples
=
288
;
fp
->
nb_prefix_samples
=
288
;
}
}
break
;
}
else
if
(
N_RB_DL
>
217
&&
N_RB_DL
<=
273
)
{
case
245
:
AssertFatal
(
fp
->
threequarter_fs
==
0
,
"3/4 sampling impossible for N_RB %d and MU %d
\n
"
,
N_RB_DL
,
mu
);
fp
->
ofdm_symbol_size
=
4096
;
fp
->
first_carrier_offset
=
2626
;
//4096 - ( (245*12) / 2 )
fp
->
nb_prefix_samples0
=
352
;
fp
->
nb_prefix_samples
=
288
;
break
;
case
273
:
AssertFatal
(
fp
->
threequarter_fs
==
0
,
"3/4 sampling impossible for N_RB %d and MU %d
\n
"
,
N_RB_DL
,
mu
);
AssertFatal
(
fp
->
threequarter_fs
==
0
,
"3/4 sampling impossible for N_RB %d and MU %d
\n
"
,
N_RB_DL
,
mu
);
fp
->
ofdm_symbol_size
=
4096
;
fp
->
ofdm_symbol_size
=
4096
;
fp
->
first_carrier_offset
=
2458
;
//4096 - ( (273*12) / 2 )
fp
->
nb_prefix_samples0
=
352
;
fp
->
nb_prefix_samples0
=
352
;
fp
->
nb_prefix_samples
=
288
;
fp
->
nb_prefix_samples
=
288
;
break
;
default:
AssertFatal
(
1
==
0
,
"Number of resource blocks %d undefined for mu %d, frame parms = %p
\n
"
,
N_RB_DL
,
mu
,
fp
);
}
}
else
{
AssertFatal
(
1
==
0
,
"Unsupported configuration N_RB %d and MU %d
\n
"
,
N_RB_DL
,
mu
);
}
fp
->
first_carrier_offset
=
fp
->
ofdm_symbol_size
-
N_RB_DL
*
6
;
break
;
break
;
case
NR_MU_2
:
//60kHz scs
case
NR_MU_2
:
//60kHz scs
...
@@ -231,6 +210,7 @@ int nr_init_frame_parms0(NR_DL_FRAME_PARMS *fp,
...
@@ -231,6 +210,7 @@ int nr_init_frame_parms0(NR_DL_FRAME_PARMS *fp,
}
}
break
;
break
;
/*
case NR_MU_3:
case NR_MU_3:
fp->subcarrier_spacing = nr_subcarrier_spacing[NR_MU_3];
fp->subcarrier_spacing = nr_subcarrier_spacing[NR_MU_3];
fp->slots_per_subframe = nr_slots_per_subframe[NR_MU_3];
fp->slots_per_subframe = nr_slots_per_subframe[NR_MU_3];
...
@@ -242,6 +222,7 @@ int nr_init_frame_parms0(NR_DL_FRAME_PARMS *fp,
...
@@ -242,6 +222,7 @@ int nr_init_frame_parms0(NR_DL_FRAME_PARMS *fp,
fp->slots_per_subframe = nr_slots_per_subframe[NR_MU_4];
fp->slots_per_subframe = nr_slots_per_subframe[NR_MU_4];
fp->ssb_type = nr_ssb_type_E;
fp->ssb_type = nr_ssb_type_E;
break;
break;
*/
default:
default:
AssertFatal
(
1
==
0
,
"Invalid numerology index %d"
,
mu
);
AssertFatal
(
1
==
0
,
"Invalid numerology index %d"
,
mu
);
...
...
openair1/SIMULATION/NR_PHY/pbchsim.c
View file @
e90603fe
...
@@ -364,29 +364,22 @@ int main(int argc, char **argv)
...
@@ -364,29 +364,22 @@ int main(int argc, char **argv)
double
fs
,
bw
,
scs
,
eps
;
double
fs
,
bw
,
scs
,
eps
;
switch
(
mu
)
{
if
(
mu
==
1
)
{
case
1
:
scs
=
30000
;
scs
=
30000
;
if
(
N_RB_DL
==
217
)
{
if
(
N_RB_DL
>
106
&&
N_RB_DL
<=
273
)
{
fs
=
122.88e6
;
fs
=
122.88e6
;
bw
=
80e6
;
bw
=
80e6
;
}
else
if
(
N_RB_DL
==
245
)
{
fs
=
122.88e6
;
bw
=
90e6
;
}
else
if
(
N_RB_DL
==
273
)
{
fs
=
122.88e6
;
bw
=
100e6
;
}
}
else
if
(
N_RB_DL
=
=
106
)
{
else
if
(
N_RB_DL
>
0
&&
N_RB_DL
<
=
106
)
{
fs
=
61.44e6
;
fs
=
61.44e6
;
bw
=
40e6
;
bw
=
40e6
;
}
}
else
AssertFatal
(
1
==
0
,
"Unsupported numerology for mu %d, N_RB %d
\n
"
,
mu
,
N_RB_DL
);
else
break
;
AssertFatal
(
1
==
0
,
"Unsupported numerology for mu %d, N_RB %d
\n
"
,
mu
,
N_RB_DL
)
;
}
}
else
AssertFatal
(
1
==
0
,
"Unsupported numerology for mu %d, N_RB %d
\n
"
,
mu
,
N_RB_DL
);
// cfo with respect to sub-carrier spacing
// cfo with respect to sub-carrier spacing
eps
=
cfo
/
scs
;
eps
=
cfo
/
scs
;
...
...
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