Improve PUSCH NR BLER test output

When full BLER is enabled, the code also outputs false alarm and missed
detection probabilities.
master
dvdgrgrtt 3 years ago committed by dvdgrgrtt
parent 6b0a3669cf
commit 63899ef4bc

@ -214,9 +214,11 @@ int main(int argc, char** argv)
goto clean_exit; goto clean_exit;
} }
uint32_t n_blocks = 0; uint32_t n_blocks = 0;
uint32_t n_errors = 0; uint32_t n_errors = 0;
float evm = 0; uint32_t crc_false_pos = 0;
uint32_t crc_false_neg = 0;
float evm = 0;
for (; n_blocks < 2000000 && n_errors < 100; n_blocks++) { for (; n_blocks < 2000000 && n_errors < 100; n_blocks++) {
// Generate SCH payload // Generate SCH payload
for (uint32_t tb = 0; tb < SRSRAN_MAX_TB; tb++) { for (uint32_t tb = 0; tb < SRSRAN_MAX_TB; tb++) {
@ -324,9 +326,15 @@ int main(int argc, char** argv)
if (full_check) { if (full_check) {
// Validate by comparing payload (recall, payload is represented in bytes) // Validate by comparing payload (recall, payload is represented in bytes)
if ((memcmp(data_rx.tb[0].payload, data_tx.payload[0], pusch_cfg.grant.tb[0].tbs * sizeof(uint8_t) / 8) == 0) != if ((memcmp(data_rx.tb[0].payload, data_tx.payload[0], pusch_cfg.grant.tb[0].tbs * sizeof(uint8_t) / 8) == 0) &&
data_rx.tb[0].crc) { !data_rx.tb[0].crc) {
printf("\nWarning! Bit comparison and CRC do not match!\n"); printf("\nWARNING! Codeword OK but CRC KO!\n");
crc_false_pos++;
} else if ((memcmp(data_rx.tb[0].payload, data_tx.payload[0], pusch_cfg.grant.tb[0].tbs * sizeof(uint8_t) / 8) !=
0) &&
data_rx.tb[0].crc) {
printf("\nWarning! Codeword KO but CRC OK!\n");
crc_false_neg++;
} }
} }
} }
@ -346,6 +354,19 @@ int main(int argc, char** argv)
(n_blocks - n_errors) / 1e3 * pusch_cfg.grant.tb[0].tbs / n_blocks, (n_blocks - n_errors) / 1e3 * pusch_cfg.grant.tb[0].tbs / n_blocks,
100.0F * (n_blocks - n_errors) / n_blocks); 100.0F * (n_blocks - n_errors) / n_blocks);
if (full_check) {
uint32_t true_errors = n_errors + crc_false_neg - crc_false_pos;
printf("CRC: missed detection/Type I err. %.2f%% (%d out of %d)",
100.0F * crc_false_neg / true_errors,
crc_false_neg,
true_errors);
printf(" -- false alarm %.2f%% (%d out of %d)", 100.0F * crc_false_pos / n_errors, crc_false_pos, n_errors);
printf(" -- Type II err. %.2f%% (%d out of %d)\n",
100.0F * crc_false_pos / (n_blocks - true_errors),
crc_false_pos,
n_blocks - true_errors);
}
ret = SRSRAN_SUCCESS; ret = SRSRAN_SUCCESS;
clean_exit: clean_exit:

Loading…
Cancel
Save