37     .SetGroupName (
"Wifi")
 
   51   double z = std::sqrt (snr);
 
   52   double ber = 0.5 * erfc (z);
 
   61   double z = std::sqrt (snr / 2.0);
 
   62   double ber = 0.5 * erfc (z);
 
   71   double z = std::sqrt (snr / (5.0 * 2.0));
 
   72   double ber = 0.75 * 0.5 * erfc (z);
 
   73   NS_LOG_INFO (
"16-Qam" << 
" snr=" << snr << 
" ber=" << ber);
 
   81   double z = std::sqrt (snr / (21.0 * 2.0));
 
   82   double ber = 7.0 / 12.0 * 0.5 * erfc (z);
 
   83   NS_LOG_INFO (
"64-Qam" << 
" snr=" << snr << 
" ber=" << ber);
 
   91   double z = std::sqrt (snr / (85.0 * 2.0));
 
   92   double ber = 15.0 / 32.0 * 0.5 * erfc (z);
 
   93   NS_LOG_INFO (
"256-Qam" << 
" snr=" << snr << 
" ber=" << ber);
 
  101   double z = std::sqrt (snr / (341.0 * 2.0));
 
  102   double ber = 31.0 / 160.0 * 0.5 * erfc (z);
 
  103   NS_LOG_INFO (
"1024-Qam" << 
" snr=" << snr << 
" ber=" << ber);
 
  109                                    uint32_t bValue)
 const 
  119   double pms = std::pow (1 - pe, nbits);
 
  125                                    uint32_t bValue)
 const 
  135   double pms = std::pow (1 - pe, nbits);
 
  143   double D = std::sqrt (4.0 * p * (1.0 - p));
 
  148       pe = 0.5 * (36.0 * std::pow (D, 10)
 
  149                   + 211.0 * std::pow (D, 12)
 
  150                   + 1404.0 * std::pow (D, 14)
 
  151                   + 11633.0 * std::pow (D, 16)
 
  152                   + 77433.0 * std::pow (D, 18)
 
  153                   + 502690.0 * std::pow (D, 20)
 
  154                   + 3322763.0 * std::pow (D, 22)
 
  155                   + 21292910.0 * std::pow (D, 24)
 
  156                   + 134365911.0 * std::pow (D, 26));
 
  158   else if (bValue == 2)
 
  161       pe = 1.0 / (2.0 * bValue) *
 
  162         (3.0 * std::pow (D, 6)
 
  163          + 70.0 * std::pow (D, 7)
 
  164          + 285.0 * std::pow (D, 8)
 
  165          + 1276.0 * std::pow (D, 9)
 
  166          + 6160.0 * std::pow (D, 10)
 
  167          + 27128.0 * std::pow (D, 11)
 
  168          + 117019.0 * std::pow (D, 12)
 
  169          + 498860.0 * std::pow (D, 13)
 
  170          + 2103891.0 * std::pow (D, 14)
 
  171          + 8784123.0 * std::pow (D, 15));
 
  173   else if (bValue == 3)
 
  176       pe = 1.0 / (2.0 * bValue) *
 
  177         (42.0 * std::pow (D, 5)
 
  178          + 201.0 * std::pow (D, 6)
 
  179          + 1492.0 * std::pow (D, 7)
 
  180          + 10469.0 * std::pow (D, 8)
 
  181          + 62935.0 * std::pow (D, 9)
 
  182          + 379644.0 * std::pow (D, 10)
 
  183          + 2253373.0 * std::pow (D, 11)
 
  184          + 13073811.0 * std::pow (D, 12)
 
  185          + 75152755.0 * std::pow (D, 13)
 
  186          + 428005675.0 * std::pow (D, 14));
 
  188   else if (bValue == 5)
 
  192       pe = 1.0 / (2.0 * bValue) *
 
  193         (92.0 * std::pow (D, 4.0)
 
  194          + 528.0 * std::pow (D, 5.0)
 
  195          + 8694.0 * std::pow (D, 6.0)
 
  196          + 79453.0 * std::pow (D, 7.0)
 
  197          + 792114.0 * std::pow (D, 8.0)
 
  198          + 7375573.0 * std::pow (D, 9.0)
 
  199          + 67884974.0 * std::pow (D, 10.0)
 
  200          + 610875423.0 * std::pow (D, 11.0)
 
  201          + 5427275376.0 * std::pow (D, 12.0)
 
  202          + 47664215639.0 * std::pow (D, 13.0));
 
  213                                     uint32_t bValue)
 const 
  223   double pms = std::pow (1 - pe, nbits);
 
  229                                     uint32_t bValue)
 const 
  239   double pms = std::pow (1 - pe, nbits);
 
  245                                      uint32_t bValue)
 const 
  255   double pms = std::pow (1 - pe, nbits);
 
  261                                       uint32_t bValue)
 const 
  271   double pms = std::pow (1 - pe, nbits);
 
  399           NS_ASSERT (
"undefined DSSS/HR-DSSS datarate");
 
double GetQpskBer(double snr) const 
Return BER of QPSK at the given SNR. 
static TypeId GetTypeId(void)
Get the type ID. 
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by "...
This class mimics the TXVECTOR which is to be passed to the PHY in order to define the parameters whi...
#define NS_OBJECT_ENSURE_REGISTERED(type)
Register an Object subclass with the TypeId system. 
#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. 
double GetChunkSuccessRate(WifiMode mode, WifiTxVector txVector, double snr, uint64_t nbits) const 
A pure virtual method that must be implemented in the subclass. 
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO. 
double GetFec16QamBer(double snr, uint64_t nbits, uint32_t bValue) const 
Return BER of QAM16 at the given SNR after applying FEC. 
double Get1024QamBer(double snr) const 
Return BER of QAM1024 at the given SNR. 
double GetFecQpskBer(double snr, uint64_t nbits, uint32_t bValue) const 
Return BER of QPSK at the given SNR after applying FEC. 
represent a single transmission modeA WifiMode is implemented by a single integer which is used to lo...
static double GetDsssDbpskSuccessRate(double sinr, uint64_t nbits)
Return the chunk success rate of the differential BPSK. 
the interface for Wifi's error models 
double CalculatePe(double p, uint32_t bValue) const 
Return the coded BER for the given p and b. 
uint16_t GetConstellationSize(void) const 
uint64_t GetDataRate(uint8_t channelWidth, uint16_t guardInterval, uint8_t nss) const 
double Get16QamBer(double snr) const 
Return BER of QAM16 at the given SNR. 
A model for the error rate for different modulations. 
Every class exported by the ns3 library is enclosed in the ns3 namespace. 
double GetFecBpskBer(double snr, uint64_t nbits, uint32_t bValue) const 
Return BER of BPSK at the given SNR after applying FEC. 
double Get64QamBer(double snr) const 
Return BER of QAM64 at the given SNR. 
double Get256QamBer(double snr) const 
Return BER of QAM256 at the given SNR. 
static double GetDsssDqpskCck5_5SuccessRate(double sinr, uint64_t nbits)
Return the chunk success rate of the differential encoded QPSK for 5.5Mbps data rate. 
double GetFec1024QamBer(double snr, uint64_t nbits, uint32_t bValue) const 
Return BER of QAM1024 at the given SNR after applying FEC. 
double GetFec64QamBer(double snr, uint64_t nbits, uint32_t bValue) const 
Return BER of QAM64 at the given SNR after applying FEC. 
double GetFec256QamBer(double snr, uint64_t nbits, uint32_t bValue) const 
Return BER of QAM256 at the given SNR after applying FEC. 
WifiModulationClass GetModulationClass() const 
static double GetDsssDqpskSuccessRate(double sinr, uint64_t nbits)
Return the chunk success rate of the differential encoded QPSK. 
WifiMode GetMode(void) const 
a unique identifier for an interface. 
WifiCodeRate GetCodeRate(void) const 
TypeId SetParent(TypeId tid)
Set the parent TypeId. 
double GetBpskBer(double snr) const 
Return BER of BPSK at the given SNR. 
static double GetDsssDqpskCck11SuccessRate(double sinr, uint64_t nbits)
Return the chunk success rate of the differential encoded QPSK for 11Mbps data rate.