A Discrete-Event Network Simulator
QKDNetSim v2.0 (NS-3 v3.41) @ (+)
API
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
yans-error-rate-model.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2005,2006 INRIA
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License version 2 as
6  * published by the Free Software Foundation;
7  *
8  * This program is distributed in the hope that it will be useful,
9  * but WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11  * GNU General Public License for more details.
12  *
13  * You should have received a copy of the GNU General Public License
14  * along with this program; if not, write to the Free Software
15  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16  *
17  * Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
18  */
19 
20 #ifndef YANS_ERROR_RATE_MODEL_H
21 #define YANS_ERROR_RATE_MODEL_H
22 
23 #include "error-rate-model.h"
24 
25 namespace ns3
26 {
27 
54 {
55  public:
60  static TypeId GetTypeId();
61 
63 
64  private:
65  double DoGetChunkSuccessRate(WifiMode mode,
66  const WifiTxVector& txVector,
67  double snr,
68  uint64_t nbits,
69  uint8_t numRxAntennas,
70  WifiPpduField field,
71  uint16_t staId) const override;
81  double GetBpskBer(double snr, uint32_t signalSpread, uint64_t phyRate) const;
92  double GetQamBer(double snr, unsigned int m, uint32_t signalSpread, uint64_t phyRate) const;
100  uint32_t Factorial(uint32_t k) const;
110  double Binomial(uint32_t k, double p, uint32_t n) const;
117  double CalculatePdOdd(double ber, unsigned int d) const;
124  double CalculatePdEven(double ber, unsigned int d) const;
131  double CalculatePd(double ber, unsigned int d) const;
142  double GetFecBpskBer(double snr,
143  uint64_t nbits,
144  uint32_t signalSpread,
145  uint64_t phyRate,
146  uint32_t dFree,
147  uint32_t adFree) const;
160  double GetFecQamBer(double snr,
161  uint64_t nbits,
162  uint32_t signalSpread,
163  uint64_t phyRate,
164  uint32_t m,
165  uint32_t dfree,
166  uint32_t adFree,
167  uint32_t adFreePlusOne) const;
168 };
169 
170 } // namespace ns3
171 
172 #endif /* YANS_ERROR_RATE_MODEL_H */
the interface for Wifi's error models
a unique identifier for an interface.
Definition: type-id.h:59
represent a single transmission mode
Definition: wifi-mode.h:51
This class mimics the TXVECTOR which is to be passed to the PHY in order to define the parameters whi...
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.
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
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.
WifiPpduField
The type of PPDU field (grouped for convenience)
Every class exported by the ns3 library is enclosed in the ns3 namespace.