39 .SetGroupName (
"Wifi")
53 double EbNo = snr * signalSpread / phyRate;
54 double z = std::sqrt (EbNo);
55 double ber = 0.5 * erfc (z);
64 double EbNo = snr * signalSpread / phyRate;
65 double z = std::sqrt ((1.5 * log2 (m) * EbNo) / (m - 1.0));
66 double z1 = ((1.0 - 1.0 / std::sqrt (m)) * erfc (z));
67 double z2 = 1 - std::pow ((1 - z1), 2);
68 double ber = z2 / log2 (m);
69 NS_LOG_INFO (
"Qam m=" << m <<
" rate=" << phyRate <<
" snr=" << snr <<
" ber=" << ber);
88 double retval =
Factorial (n) / (
Factorial (
k) *
Factorial (n -
k)) * std::pow (p,
static_cast<double> (
k)) * std::pow (1 - p,
static_cast<double> (n -
k));
96 unsigned int dstart = (d + 1) / 2;
97 unsigned int dend = d;
100 for (
unsigned int i = dstart; i < dend; i++)
111 unsigned int dstart = d / 2 + 1;
112 unsigned int dend = d;
115 for (
unsigned int i = dstart; i < dend; i++)
119 pd += 0.5 *
Binomial (d / 2, ber, d);
142 uint32_t signalSpread, uint64_t phyRate,
143 uint32_t dFree, uint32_t adFree)
const
145 NS_LOG_FUNCTION (
this << snr << nbits << signalSpread << phyRate << dFree << adFree);
146 double ber =
GetBpskBer (snr, signalSpread, phyRate);
152 double pmu = adFree * pd;
154 double pms = std::pow (1 - pmu, nbits);
160 uint32_t signalSpread,
162 uint32_t m, uint32_t dFree,
163 uint32_t adFree, uint32_t adFreePlusOne)
const
165 NS_LOG_FUNCTION (
this << snr << nbits << signalSpread << phyRate << m << dFree << adFree << adFreePlusOne);
166 double ber =
GetQamBer (snr, m, signalSpread, phyRate);
173 double pmu = adFree * pd;
176 pmu += adFreePlusOne * pd;
178 double pms = std::pow (1 - pmu, nbits);
185 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(void) const
WifiModulationClass GetModulationClass() const
uint64_t GetPhyRate(uint16_t channelWidth, uint16_t guardInterval, uint8_t nss) const
WifiCodeRate GetCodeRate(void) 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.
bool IsMu(void) const
Return true if this TX vector is used for a multi-user transmission.
uint16_t GetChannelWidth(void) const
Model the error rate for different modulations.
double GetFecBpskBer(double snr, uint64_t nbits, uint32_t 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.
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
double GetQamBer(double snr, unsigned int m, uint32_t signalSpread, uint64_t phyRate) const
Return BER of QAM-m with the given parameters.
uint32_t Factorial(uint32_t k) const
Return k!
double CalculatePdOdd(double ber, unsigned int d) const
double GetFecQamBer(double snr, uint64_t nbits, uint32_t signalSpread, uint64_t phyRate, uint32_t m, uint32_t dfree, uint32_t adFree, uint32_t adFreePlusOne) const
double CalculatePd(double ber, unsigned int d) const
double GetBpskBer(double snr, uint32_t signalSpread, uint64_t phyRate) const
Return BER of BPSK with the given parameters.
static TypeId GetTypeId(void)
Get the type ID.
#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.
const uint16_t WIFI_CODE_RATE_1_2
1/2 coding rate
const uint16_t WIFI_CODE_RATE_2_3
2/3 coding rate
const uint16_t WIFI_CODE_RATE_5_6
5/6 coding rate