Commit e90603fe authored by Florian Kaltenberger's avatar Florian Kaltenberger

making first_carrier_offset flexible for all prossible N_RB_DL

parent 4e62f468
...@@ -128,12 +128,14 @@ int nr_init_frame_parms0(NR_DL_FRAME_PARMS *fp, ...@@ -128,12 +128,14 @@ 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];
fp->slots_per_subframe = nr_slots_per_subframe[NR_MU_1]; fp->slots_per_subframe = nr_slots_per_subframe[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,9 +222,10 @@ int nr_init_frame_parms0(NR_DL_FRAME_PARMS *fp, ...@@ -242,9 +222,10 @@ 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);
} }
fp->slots_per_frame = 10* fp->slots_per_subframe; fp->slots_per_frame = 10* fp->slots_per_subframe;
......
...@@ -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 > 106 && N_RB_DL <= 273) {
if (N_RB_DL == 217) { fs = 122.88e6;
fs = 122.88e6; bw = 80e6;
bw = 80e6; }
else if (N_RB_DL > 0 && N_RB_DL <= 106) {
} fs = 61.44e6;
else if (N_RB_DL == 245) { bw = 40e6;
fs = 122.88e6; }
bw = 90e6; else
} AssertFatal(1==0,"Unsupported numerology for mu %d, N_RB %d\n",mu, N_RB_DL);
else if (N_RB_DL == 273) {
fs = 122.88e6;
bw = 100e6;
}
else if (N_RB_DL == 106) {
fs = 61.44e6;
bw = 40e6;
}
else AssertFatal(1==0,"Unsupported numerology for mu %d, N_RB %d\n",mu, N_RB_DL);
break;
} }
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;
......
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