|
|
|
/**
|
|
|
|
* Copyright 2013-2022 Software Radio Systems Limited
|
|
|
|
*
|
|
|
|
* This file is part of srsRAN.
|
|
|
|
*
|
|
|
|
* srsRAN is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
* published by the Free Software Foundation, either version 3 of
|
|
|
|
* the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* srsRAN is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* A copy of the GNU Affero General Public License can be found in
|
|
|
|
* the LICENSE file in the top-level directory of this distribution
|
|
|
|
* and at http://www.gnu.org/licenses/.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SRSUE_PHY_METRICS_H
|
|
|
|
#define SRSUE_PHY_METRICS_H
|
|
|
|
|
|
|
|
#include "srsran/srsran.h"
|
|
|
|
#include <array>
|
|
|
|
|
|
|
|
namespace srsue {
|
|
|
|
|
|
|
|
struct info_metrics_t {
|
|
|
|
typedef std::array<info_metrics_t, SRSRAN_MAX_CARRIERS> array_t;
|
|
|
|
|
|
|
|
uint32_t pci;
|
|
|
|
uint32_t dl_earfcn;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define PHY_METRICS_SET(PARAM) \
|
|
|
|
do { \
|
|
|
|
PARAM = SRSRAN_VEC_SAFE_CMA(other.PARAM, PARAM, count); \
|
|
|
|
} while (false)
|
|
|
|
|
|
|
|
struct sync_metrics_t {
|
|
|
|
typedef std::array<sync_metrics_t, SRSRAN_MAX_CARRIERS> array_t;
|
|
|
|
|
|
|
|
float ta_us = 0.0;
|
|
|
|
float distance_km = 0.0;
|
|
|
|
float speed_kmph = 0.0;
|
|
|
|
float cfo = 0.0;
|
|
|
|
float sfo = 0.0;
|
|
|
|
|
|
|
|
void set(const sync_metrics_t& other)
|
|
|
|
{
|
|
|
|
ta_us = other.ta_us;
|
|
|
|
distance_km = other.distance_km;
|
|
|
|
speed_kmph = other.speed_kmph;
|
|
|
|
PHY_METRICS_SET(cfo);
|
|
|
|
PHY_METRICS_SET(sfo);
|
|
|
|
count++;
|
|
|
|
}
|
|
|
|
|
|
|
|
void reset()
|
|
|
|
{
|
|
|
|
count = 0;
|
|
|
|
ta_us = 0.0f;
|
|
|
|
distance_km = 0.0f;
|
|
|
|
speed_kmph = 0.0f;
|
|
|
|
cfo = 0.0f;
|
|
|
|
sfo = 0.0f;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
uint32_t count = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct ch_metrics_t {
|
|
|
|
typedef std::array<ch_metrics_t, SRSRAN_MAX_CARRIERS> array_t;
|
|
|
|
|
|
|
|
float n = 0.0;
|
|
|
|
float sinr = 0.0;
|
|
|
|
float rsrp = 0.0;
|
|
|
|
float rsrq = 0.0;
|
|
|
|
float rssi = 0.0;
|
|
|
|
float ri = 0.0;
|
|
|
|
float pathloss = 0.0;
|
|
|
|
float sync_err = 0.0;
|
|
|
|
|
|
|
|
void set(const ch_metrics_t& other)
|
|
|
|
{
|
|
|
|
count++;
|
|
|
|
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(rsrp);
|
|
|
|
PHY_METRICS_SET(rsrq);
|
|
|
|
PHY_METRICS_SET(rssi);
|
|
|
|
PHY_METRICS_SET(ri);
|
|
|
|
PHY_METRICS_SET(pathloss);
|
|
|
|
PHY_METRICS_SET(sync_err);
|
|
|
|
}
|
|
|
|
|
|
|
|
void reset()
|
|
|
|
{
|
|
|
|
count = 0;
|
|
|
|
n = 0.0;
|
|
|
|
sinr = 0.0;
|
|
|
|
rsrp = 0.0;
|
|
|
|
rsrq = 0.0;
|
|
|
|
rssi = 0.0;
|
|
|
|
ri = 0.0;
|
|
|
|
pathloss = 0.0;
|
|
|
|
sync_err = 0.0;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
uint32_t count = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct dl_metrics_t {
|
|
|
|
typedef std::array<dl_metrics_t, SRSRAN_MAX_CARRIERS> array_t;
|
|
|
|
|
|
|
|
float fec_iters = 0.0;
|
|
|
|
float mcs = 0.0;
|
|
|
|
float evm = 0.0;
|
|
|
|
|
|
|
|
void set(const dl_metrics_t& other)
|
|
|
|
{
|
|
|
|
count++;
|
|
|
|
PHY_METRICS_SET(fec_iters);
|
|
|
|
PHY_METRICS_SET(mcs);
|
|
|
|
PHY_METRICS_SET(evm);
|
|
|
|
}
|
|
|
|
|
|
|
|
void reset()
|
|
|
|
{
|
|
|
|
count = 0;
|
|
|
|
fec_iters = 0.0f;
|
|
|
|
mcs = 0.0f;
|
|
|
|
evm = 0.0f;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
uint32_t count = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct ul_metrics_t {
|
|
|
|
typedef std::array<ul_metrics_t, SRSRAN_MAX_CARRIERS> array_t;
|
|
|
|
|
|
|
|
float mcs;
|
|
|
|
float power;
|
|
|
|
|
|
|
|
void set(const ul_metrics_t& other)
|
|
|
|
{
|
|
|
|
count++;
|
|
|
|
PHY_METRICS_SET(mcs);
|
|
|
|
PHY_METRICS_SET(power);
|
|
|
|
}
|
|
|
|
|
|
|
|
void reset()
|
|
|
|
{
|
|
|
|
count = 0;
|
|
|
|
mcs = 0.0f;
|
|
|
|
power = 0.0f;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
uint32_t count = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
#undef PHY_METRICS_SET
|
|
|
|
|
|
|
|
struct phy_metrics_t {
|
|
|
|
info_metrics_t::array_t info = {};
|
|
|
|
sync_metrics_t::array_t sync = {};
|
|
|
|
ch_metrics_t::array_t ch = {};
|
|
|
|
dl_metrics_t::array_t dl = {};
|
|
|
|
ul_metrics_t::array_t ul = {};
|
|
|
|
uint32_t nof_active_cc = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace srsue
|
|
|
|
|
|
|
|
#endif // SRSUE_PHY_METRICS_H
|