mac,stdout: add PUSCH and PUCCH SINR to stdout

This commit implements the PUCCH and PUSCH metrics in the MAC,
to be displayed in the eNB console.

Signed-off-by: Carlo Galiotto <carlo@srs.io>
master
Carlo Galiotto 3 years ago committed by Andre Puschmann
parent ebaa71d190
commit 4e3564a8a2

@ -62,6 +62,8 @@ public:
void metrics_dl_cqi(const srsran_uci_cfg_nr_t& cfg_, uint32_t dl_cqi); void metrics_dl_cqi(const srsran_uci_cfg_nr_t& cfg_, uint32_t dl_cqi);
void metrics_dl_mcs(uint32_t mcs); void metrics_dl_mcs(uint32_t mcs);
void metrics_ul_mcs(uint32_t mcs); void metrics_ul_mcs(uint32_t mcs);
void metrics_pucch_sinr(float sinr);
void metrics_pusch_sinr(float sinr);
void metrics_cnt(); void metrics_cnt();
uint32_t read_pdu(uint32_t lcid, uint8_t* payload, uint32_t requested_bytes) final; uint32_t read_pdu(uint32_t lcid, uint8_t* payload, uint32_t requested_bytes) final;
@ -83,10 +85,14 @@ private:
std::atomic<bool> active_state{true}; std::atomic<bool> active_state{true};
// TO DO: some counters are kept as members of class ue_nr, while some others (i.e., mcs) are kept in the ue_metrics
// We should make these counters more uniform
uint32_t phr_counter = 0; uint32_t phr_counter = 0;
uint32_t dl_cqi_valid_counter = 0; uint32_t dl_cqi_valid_counter = 0;
uint32_t dl_ri_counter = 0; uint32_t dl_ri_counter = 0;
uint32_t dl_pmi_counter = 0; uint32_t dl_pmi_counter = 0;
uint32_t pucch_sinr_counter = 0;
uint32_t pusch_sinr_counter = 0;
mac_ue_metrics_t ue_metrics = {}; mac_ue_metrics_t ue_metrics = {};
// UE-specific buffer for MAC PDU packing, unpacking and handling // UE-specific buffer for MAC PDU packing, unpacking and handling

@ -145,6 +145,12 @@ void metrics_stdout::set_metrics_helper(uint32_t num_ue
} else { } else {
fmt::print(" {:>2}", 0); fmt::print(" {:>2}", 0);
} }
float ul_mcs = (is_nr) ? mac.ues[i].ul_mcs : phy[i].ul.mcs;
if (not isnan(ul_mcs)) {
fmt::print(" {:>2}", int(ul_mcs));
} else {
fmt::print(" {:>2}", 0);
}
if (mac.ues[i].rx_brate > 0) { if (mac.ues[i].rx_brate > 0) {
fmt::print(" {:>6.6}", float_to_eng_string((float)mac.ues[i].rx_brate / (mac.ues[i].nof_tti * 1e-3), 1)); fmt::print(" {:>6.6}", float_to_eng_string((float)mac.ues[i].rx_brate / (mac.ues[i].nof_tti * 1e-3), 1));
} else { } else {

@ -81,6 +81,8 @@ void mac_nr::stop()
/// However, get_metrics is called infrequently enough to cause major halts in the L1/L2 /// However, get_metrics is called infrequently enough to cause major halts in the L1/L2
void mac_nr::get_metrics(srsenb::mac_metrics_t& metrics) void mac_nr::get_metrics(srsenb::mac_metrics_t& metrics)
{ {
// TO DO: We should comment on the logic we follow to get the metrics. Some of them are retrieved from MAC, some
// others from the scheduler.
get_metrics_nolock(metrics); get_metrics_nolock(metrics);
sched.get_metrics(metrics); sched.get_metrics(metrics);
} }
@ -357,6 +359,14 @@ int mac_nr::pucch_info(const srsran_slot_cfg_t& slot_cfg, const mac_interface_ph
logger.error("Error handling UCI data from PUCCH reception"); logger.error("Error handling UCI data from PUCCH reception");
return SRSRAN_ERROR; return SRSRAN_ERROR;
} }
// process PUCCH SNR
uint16_t rnti = pucch_info.uci_data.cfg.pucch.rnti;
srsran::rwlock_read_guard rw_lock(rwmutex);
if (ue_db.contains(rnti)) {
ue_db[rnti]->metrics_pucch_sinr(pucch_info.csi.snr_dB);
}
return SRSRAN_SUCCESS; return SRSRAN_SUCCESS;
} }
@ -419,6 +429,7 @@ int mac_nr::pusch_info(const srsran_slot_cfg_t& slot_cfg, mac_interface_phy_nr::
srsran::rwlock_read_guard rw_lock(rwmutex); srsran::rwlock_read_guard rw_lock(rwmutex);
if (ue_db.contains(rnti)) { if (ue_db.contains(rnti)) {
ue_db[rnti]->metrics_rx(pusch_info.pusch_data.tb[0].crc, nof_bytes); ue_db[rnti]->metrics_rx(pusch_info.pusch_data.tb[0].crc, nof_bytes);
ue_db[rnti]->metrics_pusch_sinr(pusch_info.csi.snr_dB);
} }
return SRSRAN_SUCCESS; return SRSRAN_SUCCESS;
} }

@ -220,9 +220,12 @@ void ue_nr::metrics_read(mac_ue_metrics_t* metrics_)
auto it = std::find(cc_list.begin(), cc_list.end(), 0); auto it = std::find(cc_list.begin(), cc_list.end(), 0);
ue_metrics.cc_idx = std::distance(cc_list.begin(), it); ue_metrics.cc_idx = std::distance(cc_list.begin(), it);
// printf("RNTI %u: reading and resetting metrics: \n", rnti);
*metrics_ = ue_metrics; *metrics_ = ue_metrics;
phr_counter = 0; phr_counter = 0;
dl_cqi_valid_counter = 0; dl_cqi_valid_counter = 0;
pucch_sinr_counter = 0;
pusch_sinr_counter = 0;
ue_metrics = {}; ue_metrics = {};
} }
@ -286,6 +289,26 @@ void ue_nr::metrics_cnt()
ue_metrics.nof_tti++; ue_metrics.nof_tti++;
} }
void ue_nr::metrics_pucch_sinr(float sinr)
{
std::lock_guard<std::mutex> lock(metrics_mutex);
// discard nan or inf values for average SINR
if (!std::isinf(sinr) && !std::isnan(sinr)) {
ue_metrics.pucch_sinr = SRSRAN_VEC_SAFE_CMA((float)sinr, ue_metrics.pucch_sinr, pucch_sinr_counter);
pucch_sinr_counter++;
}
}
void ue_nr::metrics_pusch_sinr(float sinr)
{
std::lock_guard<std::mutex> lock(metrics_mutex);
// discard nan or inf values for average SINR
if (!std::isinf(sinr) && !std::isnan(sinr)) {
ue_metrics.pusch_sinr = SRSRAN_VEC_SAFE_CMA((float)sinr, ue_metrics.pusch_sinr, pusch_sinr_counter);
pusch_sinr_counter++;
}
}
/** Converts the buffer size field of a BSR (5 or 8-bit Buffer Size field) into Bytes /** Converts the buffer size field of a BSR (5 or 8-bit Buffer Size field) into Bytes
* @param buff_size_field The buffer size field contained in the MAC PDU * @param buff_size_field The buffer size field contained in the MAC PDU
* @param format The BSR format that determines the buffer size field length * @param format The BSR format that determines the buffer size field length

@ -79,7 +79,10 @@ struct ch_metrics_t {
{ {
count++; count++;
PHY_METRICS_SET(n); PHY_METRICS_SET(n);
// We exclude inf and nan from the average SINR
if (!std::isnan(other.sinr) || !std::isinf(other.sinr)) {
PHY_METRICS_SET(sinr); PHY_METRICS_SET(sinr);
}
PHY_METRICS_SET(rsrp); PHY_METRICS_SET(rsrp);
PHY_METRICS_SET(rsrq); PHY_METRICS_SET(rsrq);
PHY_METRICS_SET(rssi); PHY_METRICS_SET(rssi);

Loading…
Cancel
Save