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
76551239
Commit
76551239
authored
May 04, 2020
by
Sakthivel Velumani
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
included throughput print
parent
4eb78faa
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
11 additions
and
5 deletions
+11
-5
openair1/SIMULATION/NR_PHY/dlsim.c
openair1/SIMULATION/NR_PHY/dlsim.c
+11
-5
No files found.
openair1/SIMULATION/NR_PHY/dlsim.c
View file @
76551239
...
@@ -140,8 +140,10 @@ int main(int argc, char **argv)
...
@@ -140,8 +140,10 @@ int main(int argc, char **argv)
double
sigma2
,
sigma2_dB
=
10
,
SNR
,
snr0
=-
2
.
0
,
snr1
=
2
.
0
;
double
sigma2
,
sigma2_dB
=
10
,
SNR
,
snr0
=-
2
.
0
,
snr1
=
2
.
0
;
uint8_t
snr1set
=
0
;
uint8_t
snr1set
=
0
;
float
roundStats
[
50
];
float
roundStats
[
50
];
float
effRate
;
float
psnr
;
float
psnr
;
uint8_t
snrRun
;
uint8_t
snrRun
;
uint32_t
TBS
;
int
**
txdata
;
int
**
txdata
;
double
**
s_re
,
**
s_im
,
**
r_re
,
**
r_im
;
double
**
s_re
,
**
s_im
,
**
r_re
,
**
r_im
;
//double iqim = 0.0;
//double iqim = 0.0;
...
@@ -703,6 +705,7 @@ int main(int argc, char **argv)
...
@@ -703,6 +705,7 @@ int main(int argc, char **argv)
reset_meas
(
&
gNB
->
toutput
);
reset_meas
(
&
gNB
->
toutput
);
n_errors
=
0
;
n_errors
=
0
;
effRate
=
0
;
//n_errors2 = 0;
//n_errors2 = 0;
//n_alamouti = 0;
//n_alamouti = 0;
errors_scrambling
=
0
;
errors_scrambling
=
0
;
...
@@ -848,7 +851,7 @@ int main(int argc, char **argv)
...
@@ -848,7 +851,7 @@ int main(int argc, char **argv)
NR_UE_PDSCH
**
pdsch_vars
=
UE
->
pdsch_vars
[
UE
->
current_thread_id
[
UE_proc
.
nr_tti_rx
]];
NR_UE_PDSCH
**
pdsch_vars
=
UE
->
pdsch_vars
[
UE
->
current_thread_id
[
UE_proc
.
nr_tti_rx
]];
int16_t
*
UE_llr
=
pdsch_vars
[
0
]
->
llr
[
0
];
int16_t
*
UE_llr
=
pdsch_vars
[
0
]
->
llr
[
0
];
uint32_t
TBS
=
rel15
->
TBSize
[
0
];
TBS
=
rel15
->
TBSize
[
0
];
uint16_t
length_dmrs
=
1
;
uint16_t
length_dmrs
=
1
;
uint16_t
nb_rb
=
rel15
->
rbSize
;
uint16_t
nb_rb
=
rel15
->
rbSize
;
uint8_t
nb_re_dmrs
=
rel15
->
dmrsConfigType
==
NFAPI_NR_DMRS_TYPE1
?
6
:
4
;
uint8_t
nb_re_dmrs
=
rel15
->
dmrsConfigType
==
NFAPI_NR_DMRS_TYPE1
?
6
:
4
;
...
@@ -896,15 +899,17 @@ int main(int argc, char **argv)
...
@@ -896,15 +899,17 @@ int main(int argc, char **argv)
printf
(
"errors_bit = %u (trial %d)
\n
"
,
errors_bit
,
trial
);
printf
(
"errors_bit = %u (trial %d)
\n
"
,
errors_bit
,
trial
);
}
}
roundStats
[
snrRun
]
+=
((
float
)
round
);
roundStats
[
snrRun
]
+=
((
float
)
round
);
if
(
UE_harq_process
->
harq_ack
.
ack
==
1
)
effRate
+=
((
float
)
TBS
)
/
round
;
}
// noise trials
}
// noise trials
roundStats
[
snrRun
]
/=
((
float
)
n_trials
);
roundStats
[
snrRun
]
/=
((
float
)
n_trials
);
effRate
/=
n_trials
;
printf
(
"*****************************************
\n
"
);
printf
(
"*****************************************
\n
"
);
printf
(
"SNR %f, (false positive %f)
\n
"
,
SNR
,
printf
(
"SNR %f, (false positive %f)
\n
"
,
SNR
,
(
float
)
n_errors
/
(
float
)
n_trials
);
(
float
)
n_errors
/
(
float
)
n_trials
);
printf
(
"*****************************************
\n
"
);
printf
(
"*****************************************
\n
"
);
printf
(
"
\n
"
);
printf
(
"
\n
"
);
printf
(
"SNR %f : n_errors (negative CRC) = %d/%d, Avg round %.2f, Channel BER %e
\n
"
,
SNR
,
n_errors
,
n_trials
,
roundStats
[
snrRun
],(
double
)
errors_scrambling
/
available_bits
/
n_trials
);
printf
(
"SNR %f : n_errors (negative CRC) = %d/%d, Avg round %.2f, Channel BER %e
, Eff Rate %.4f bits/slot, Eff Throughput %.2f\%, TBS %d bits/slot
\n
"
,
SNR
,
n_errors
,
n_trials
,
roundStats
[
snrRun
],(
double
)
errors_scrambling
/
available_bits
/
n_trials
,
effRate
,
effRate
/
TBS
*
100
,
TBS
);
printf
(
"
\n
"
);
printf
(
"
\n
"
);
if
(
n_trials
==
1
)
{
if
(
n_trials
==
1
)
{
...
@@ -916,7 +921,8 @@ int main(int argc, char **argv)
...
@@ -916,7 +921,8 @@ int main(int argc, char **argv)
write_output
(
"rxF_comp.m"
,
"rxFc"
,
&
UE
->
pdsch_vars
[
0
][
0
]
->
rxdataF_comp0
[
0
][
0
],
N_RB_DL
*
12
*
14
,
1
,
1
);
write_output
(
"rxF_comp.m"
,
"rxFc"
,
&
UE
->
pdsch_vars
[
0
][
0
]
->
rxdataF_comp0
[
0
][
0
],
N_RB_DL
*
12
*
14
,
1
,
1
);
}
}
if
((
float
)
n_errors
/
(
float
)
n_trials
<=
target_error_rate
)
{
//if ((float)n_errors/(float)n_trials <= target_error_rate) {
if
(
effRate
>=
(
0
.
7
*
TBS
))
{
printf
(
"PDSCH test OK
\n
"
);
printf
(
"PDSCH test OK
\n
"
);
break
;
break
;
}
}
...
@@ -975,14 +981,14 @@ int main(int argc, char **argv)
...
@@ -975,14 +981,14 @@ int main(int argc, char **argv)
snrRun
++
;
snrRun
++
;
}
// NSR
}
// NSR
if
(
n_trials
>
1
)
{
/*
if (n_trials>1) {
printf("HARQ stats:\nSNR\tRounds\n");
printf("HARQ stats:\nSNR\tRounds\n");
psnr = snr0;
psnr = snr0;
for (uint8_t i=0; i<snrRun; i++) {
for (uint8_t i=0; i<snrRun; i++) {
printf("%.1f\t%.2f\n",psnr,roundStats[i]);
printf("%.1f\t%.2f\n",psnr,roundStats[i]);
psnr+=0.2;
psnr+=0.2;
}
}
}
}
*/
for
(
i
=
0
;
i
<
2
;
i
++
)
{
for
(
i
=
0
;
i
<
2
;
i
++
)
{
free
(
s_re
[
i
]);
free
(
s_re
[
i
]);
...
...
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