44    double EbNo = snr * signalSpread * 1e6 / phyRate;
 
   45    double z = std::sqrt(EbNo);
 
   46    double ber = 0.5 * erfc(z);
 
 
   55                              uint64_t phyRate)
 const 
   58    double EbNo = snr * signalSpread * 1e6 / phyRate;
 
   59    double z = std::sqrt((1.5 * log2(m) * EbNo) / (m - 1.0));
 
   60    double z1 = ((1.0 - 1.0 / std::sqrt(m)) * erfc(z));
 
   61    double z2 = 1 - std::pow((1 - z1), 2);
 
   62    double ber = z2 / log2(m);
 
   63    NS_LOG_INFO(
"Qam m=" << m << 
" rate=" << phyRate << 
" snr=" << snr << 
" ber=" << ber);
 
 
   83                    std::pow(p, 
static_cast<double>(k)) *
 
   84                    std::pow(1 - p, 
static_cast<double>(n - k));
 
 
   92    unsigned int dstart = (d + 1) / 2;
 
   93    unsigned int dend = d;
 
   96    for (
unsigned int i = dstart; i < dend; i++)
 
 
  107    unsigned int dstart = d / 2 + 1;
 
  108    unsigned int dend = d;
 
  111    for (
unsigned int i = dstart; i < dend; i++)
 
  115    pd += 0.5 * 
Binomial(d / 2, ber, d);
 
 
  144    NS_LOG_FUNCTION(
this << snr << nbits << signalSpread << phyRate << dFree << adFree);
 
  145    double ber = 
GetBpskBer(snr, signalSpread, phyRate);
 
  151    double pmu = adFree * pd;
 
  152    pmu = std::min(pmu, 1.0);
 
  153    double pms = std::pow(1 - pmu, nbits);
 
 
  167    NS_LOG_FUNCTION(
this << snr << nbits << signalSpread << phyRate << m << dFree << adFree
 
  169    double ber = 
GetQamBer(snr, m, signalSpread, phyRate);
 
  176    double pmu = adFree * pd;
 
  179    pmu += adFreePlusOne * pd;
 
  180    pmu = std::min(pmu, 1.0);
 
  181    double pms = std::pow(1 - pmu, nbits);
 
 
  190                                          uint8_t numRxAntennas,
 
  192                                          uint16_t staId)
 const 
  194    NS_LOG_FUNCTION(
this << mode << txVector << snr << nbits << +numRxAntennas << field << staId);
 
 
the interface for Wifi's error models
a unique identifier for an interface.
TypeId SetParent(TypeId tid)
Set the parent TypeId.
represent a single transmission mode
uint16_t GetConstellationSize() const
WifiModulationClass GetModulationClass() const
uint64_t GetPhyRate(MHz_u channelWidth, Time guardInterval, uint8_t nss) const
WifiCodeRate GetCodeRate() const
This class mimics the TXVECTOR which is to be passed to the PHY in order to define the parameters whi...
WifiMode GetMode(uint16_t staId=SU_STA_ID) const
If this TX vector is associated with an SU PPDU, return the selected payload transmission mode.
MHz_u GetChannelWidth() const
Model the error rate for different modulations.
double GetBpskBer(double snr, MHz_u signalSpread, uint64_t phyRate) const
Return BER of BPSK with the given parameters.
double GetFecBpskBer(double snr, uint64_t nbits, MHz_u signalSpread, uint64_t phyRate, uint32_t dFree, uint32_t adFree) const
double DoGetChunkSuccessRate(WifiMode mode, const WifiTxVector &txVector, double snr, uint64_t nbits, uint8_t numRxAntennas, WifiPpduField field, uint16_t staId) const override
A pure virtual method that must be implemented in the subclass.
static TypeId GetTypeId()
Get the type ID.
double Binomial(uint32_t k, double p, uint32_t n) const
Return Binomial distribution for a given k, p, and n.
double CalculatePdEven(double ber, unsigned int d) const
uint32_t Factorial(uint32_t k) const
Return k!
double CalculatePdOdd(double ber, unsigned int d) const
double CalculatePd(double ber, unsigned int d) const
double GetFecQamBer(double snr, uint64_t nbits, MHz_u signalSpread, uint64_t phyRate, uint32_t m, uint32_t dfree, uint32_t adFree, uint32_t adFreePlusOne) const
double GetQamBer(double snr, unsigned int m, MHz_u signalSpread, uint64_t phyRate) const
Return BER of QAM-m with the given parameters.
#define NS_ASSERT(condition)
At runtime, in debugging builds, if this condition is not true, the program prints the source file,...
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by ",...
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
#define NS_OBJECT_ENSURE_REGISTERED(type)
Register an Object subclass with the TypeId system.
WifiPpduField
The type of PPDU field (grouped for convenience)
@ WIFI_MOD_CLASS_ERP_OFDM
ERP-OFDM (18.4)
Every class exported by the ns3 library is enclosed in the ns3 namespace.
static constexpr uint16_t SU_STA_ID
STA_ID to identify a single user (SU)
@ WIFI_CODE_RATE_2_3
2/3 coding rate
@ WIFI_CODE_RATE_1_2
1/2 coding rate
@ WIFI_CODE_RATE_5_6
5/6 coding rate