A Discrete-Event Network Simulator
API
nist-error-rate-model.cc
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2010 The Boeing Company
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License version 2 as
7  * published by the Free Software Foundation;
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17  *
18  * Authors: Gary Pei <guangyu.pei@boeing.com>
19  * Sébastien Deronne <sebastien.deronne@gmail.com>
20  */
21 
22 #include <cmath>
23 #include "nist-error-rate-model.h"
24 #include "wifi-phy.h"
25 #include "ns3/log.h"
26 
27 namespace ns3 {
28 
29 NS_LOG_COMPONENT_DEFINE ("NistErrorRateModel");
30 
31 NS_OBJECT_ENSURE_REGISTERED (NistErrorRateModel);
32 
33 TypeId
35 {
36  static TypeId tid = TypeId ("ns3::NistErrorRateModel")
38  .AddConstructor<NistErrorRateModel> ()
39  ;
40  return tid;
41 }
42 
44 {
45 }
46 
47 double
49 {
50  double z = std::sqrt (snr);
51  double ber = 0.5 * erfc (z);
52  NS_LOG_INFO ("bpsk snr=" << snr << " ber=" << ber);
53  return ber;
54 }
55 double
57 {
58  double z = std::sqrt (snr / 2.0);
59  double ber = 0.5 * erfc (z);
60  NS_LOG_INFO ("qpsk snr=" << snr << " ber=" << ber);
61  return ber;
62 }
63 double
65 {
66  double z = std::sqrt (snr / (5.0 * 2.0));
67  double ber = 0.75 * 0.5 * erfc (z);
68  NS_LOG_INFO ("16-Qam" << " snr=" << snr << " ber=" << ber);
69  return ber;
70 }
71 double
73 {
74  double z = std::sqrt (snr / (21.0 * 2.0));
75  double ber = 7.0 / 12.0 * 0.5 * erfc (z);
76  NS_LOG_INFO ("64-Qam" << " snr=" << snr << " ber=" << ber);
77  return ber;
78 }
79 double
80 NistErrorRateModel::GetFecBpskBer (double snr, uint32_t nbits,
81  uint32_t bValue) const
82 {
83  double ber = GetBpskBer (snr);
84  if (ber == 0.0)
85  {
86  return 1.0;
87  }
88  double pe = CalculatePe (ber, bValue);
89  pe = std::min (pe, 1.0);
90  double pms = std::pow (1 - pe, (double)nbits);
91  return pms;
92 }
93 double
94 NistErrorRateModel::GetFecQpskBer (double snr, uint32_t nbits,
95  uint32_t bValue) const
96 {
97  double ber = GetQpskBer (snr);
98  if (ber == 0.0)
99  {
100  return 1.0;
101  }
102  double pe = CalculatePe (ber, bValue);
103  pe = std::min (pe, 1.0);
104  double pms = std::pow (1 - pe, (double)nbits);
105  return pms;
106 }
107 double
108 NistErrorRateModel::CalculatePe (double p, uint32_t bValue) const
109 {
110  double D = std::sqrt (4.0 * p * (1.0 - p));
111  double pe = 1.0;
112  if (bValue == 1)
113  {
114  // code rate 1/2, use table 3.1.1
115  pe = 0.5 * ( 36.0 * std::pow (D, 10)
116  + 211.0 * std::pow (D, 12)
117  + 1404.0 * std::pow (D, 14)
118  + 11633.0 * std::pow (D, 16)
119  + 77433.0 * std::pow (D, 18)
120  + 502690.0 * std::pow (D, 20)
121  + 3322763.0 * std::pow (D, 22)
122  + 21292910.0 * std::pow (D, 24)
123  + 134365911.0 * std::pow (D, 26)
124  );
125  }
126  else if (bValue == 2)
127  {
128  // code rate 2/3, use table 3.1.2
129  pe = 1.0 / (2.0 * bValue) *
130  ( 3.0 * std::pow (D, 6)
131  + 70.0 * std::pow (D, 7)
132  + 285.0 * std::pow (D, 8)
133  + 1276.0 * std::pow (D, 9)
134  + 6160.0 * std::pow (D, 10)
135  + 27128.0 * std::pow (D, 11)
136  + 117019.0 * std::pow (D, 12)
137  + 498860.0 * std::pow (D, 13)
138  + 2103891.0 * std::pow (D, 14)
139  + 8784123.0 * std::pow (D, 15)
140  );
141  }
142  else if (bValue == 3)
143  {
144  // code rate 3/4, use table 3.1.2
145  pe = 1.0 / (2.0 * bValue) *
146  ( 42.0 * std::pow (D, 5)
147  + 201.0 * std::pow (D, 6)
148  + 1492.0 * std::pow (D, 7)
149  + 10469.0 * std::pow (D, 8)
150  + 62935.0 * std::pow (D, 9)
151  + 379644.0 * std::pow (D, 10)
152  + 2253373.0 * std::pow (D, 11)
153  + 13073811.0 * std::pow (D, 12)
154  + 75152755.0 * std::pow (D, 13)
155  + 428005675.0 * std::pow (D, 14)
156  );
157  }
158  else if (bValue == 5)
159  {
160  // code rate 5/6, use table V from D. Haccoun and G. Begin, "High-Rate Punctured Convolutional Codes
161  // for Viterbi Sequential Decoding", IEEE Transactions on Communications, Vol. 32, Issue 3, pp.315-319.
162  pe = 1.0 / (2.0 * bValue) *
163  ( 92.0 * std::pow (D, 4.0)
164  + 528.0 * std::pow (D, 5.0)
165  + 8694.0 * std::pow (D, 6.0)
166  + 79453.0 * std::pow (D, 7.0)
167  + 792114.0 * std::pow (D, 8.0)
168  + 7375573.0 * std::pow (D, 9.0)
169  + 67884974.0 * std::pow (D, 10.0)
170  + 610875423.0 * std::pow (D, 11.0)
171  + 5427275376.0 * std::pow (D, 12.0)
172  + 47664215639.0 * std::pow (D, 13.0)
173  );
174  }
175  else
176  {
177  NS_ASSERT (false);
178  }
179  return pe;
180 }
181 
182 double
183 NistErrorRateModel::GetFec16QamBer (double snr, uint32_t nbits,
184  uint32_t bValue) const
185 {
186  double ber = Get16QamBer (snr);
187  if (ber == 0.0)
188  {
189  return 1.0;
190  }
191  double pe = CalculatePe (ber, bValue);
192  pe = std::min (pe, 1.0);
193  double pms = std::pow (1 - pe, static_cast<double> (nbits));
194  return pms;
195 }
196 double
197 NistErrorRateModel::GetFec64QamBer (double snr, uint32_t nbits,
198  uint32_t bValue) const
199 {
200  double ber = Get64QamBer (snr);
201  if (ber == 0.0)
202  {
203  return 1.0;
204  }
205  double pe = CalculatePe (ber, bValue);
206  pe = std::min (pe, 1.0);
207  double pms = std::pow (1 - pe, static_cast<double> (nbits));
208  return pms;
209 }
210 double
211 NistErrorRateModel::GetChunkSuccessRate (WifiMode mode, double snr, uint32_t nbits) const
212 {
215  {
216  if (mode.GetConstellationSize () == 2)
217  {
218  if (mode.GetCodeRate () == WIFI_CODE_RATE_1_2)
219  {
220  return GetFecBpskBer (snr,
221  nbits,
222  1 // b value
223  );
224  }
225  else
226  {
227  return GetFecBpskBer (snr,
228  nbits,
229  3 // b value
230  );
231  }
232  }
233  else if (mode.GetConstellationSize () == 4)
234  {
235  if (mode.GetCodeRate () == WIFI_CODE_RATE_1_2)
236  {
237  return GetFecQpskBer (snr,
238  nbits,
239  1 // b value
240  );
241  }
242  else
243  {
244  return GetFecQpskBer (snr,
245  nbits,
246  3 // b value
247  );
248  }
249  }
250  else if (mode.GetConstellationSize () == 16)
251  {
252  if (mode.GetCodeRate () == WIFI_CODE_RATE_1_2)
253  {
254  return GetFec16QamBer (snr,
255  nbits,
256  1 // b value
257  );
258  }
259  else
260  {
261  return GetFec16QamBer (snr,
262  nbits,
263  3 // b value
264  );
265  }
266  }
267  else if (mode.GetConstellationSize () == 64)
268  {
269  if (mode.GetCodeRate () == WIFI_CODE_RATE_2_3)
270  {
271  return GetFec64QamBer (snr,
272  nbits,
273  2 // b value
274  );
275  }
276  else if (mode.GetCodeRate () == WIFI_CODE_RATE_5_6)
277  {
278  return GetFec64QamBer (snr,
279  nbits,
280  5 // b value
281  );
282  }
283  else
284  {
285  return GetFec64QamBer (snr,
286  nbits,
287  3 // b value
288  );
289  }
290  }
291  }
292  else if (mode.GetModulationClass () == WIFI_MOD_CLASS_DSSS)
293  {
294  switch (mode.GetDataRate ())
295  {
296  case 1000000:
298  case 2000000:
300  case 5500000:
302  case 11000000:
304  }
305  }
306  return 0;
307 }
308 
309 } // namespace ns3
double GetQpskBer(double snr) const
Return BER of QPSK at the given SNR.
static double GetDsssDqpskCck11SuccessRate(double sinr, uint32_t nbits)
Return the chunk success rate of the differential encoded QPSK for 11Mbps data rate.
static TypeId GetTypeId(void)
ERP-OFDM PHY (19.5)
Definition: wifi-mode.h:52
#define NS_OBJECT_ENSURE_REGISTERED(type)
Register an Object subclass with the TypeId system.
Definition: object-base.h:44
enum WifiModulationClass GetModulationClass() const
Definition: wifi-mode.cc:115
#define NS_ASSERT(condition)
At runtime, in debugging builds, if this condition is not true, the program prints the source file...
Definition: assert.h:61
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition: log.h:201
static double GetDsssDqpskSuccessRate(double sinr, uint32_t nbits)
Return the chunk success rate of the differential encoded QPSK.
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
Definition: log.h:244
double GetFec64QamBer(double snr, uint32_t nbits, uint32_t bValue) const
Return BER of QAM64 at the given SNR after applying FEC.
double GetFec16QamBer(double snr, uint32_t nbits, uint32_t bValue) const
Return BER of QAM16 at the given SNR after applying FEC.
represent a single transmission modeA WifiMode is implemented by a single integer which is used to lo...
Definition: wifi-mode.h:93
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.
enum WifiCodeRate GetCodeRate(void) const
Definition: wifi-mode.cc:85
double Get16QamBer(double snr) const
Return BER of QAM16 at the given SNR.
HT PHY (Clause 20)
Definition: wifi-mode.h:56
Every class exported by the ns3 library is enclosed in the ns3 namespace.
uint8_t GetConstellationSize(void) const
Definition: wifi-mode.cc:91
double GetFecQpskBer(double snr, uint32_t nbits, uint32_t bValue) const
Return BER of QPSK at the given SNR after applying FEC.
double Get64QamBer(double snr) const
Return BER of QAM64 at the given SNR.
static double GetDsssDqpskCck5_5SuccessRate(double sinr, uint32_t nbits)
Return the chunk success rate of the differential encoded QPSK for 5.5Mbps data rate.
OFDM PHY (Clause 17)
Definition: wifi-mode.h:54
double GetFecBpskBer(double snr, uint32_t nbits, uint32_t bValue) const
Return BER of BPSK at the given SNR after applying FEC.
static double GetDsssDbpskSuccessRate(double sinr, uint32_t nbits)
Return the chunk success rate of the differential BPSK.
a unique identifier for an interface.
Definition: type-id.h:51
uint64_t GetDataRate(void) const
Definition: wifi-mode.cc:79
TypeId SetParent(TypeId tid)
Definition: type-id.cc:631
DSSS PHY (Clause 15) and HR/DSSS PHY (Clause 18)
Definition: wifi-mode.h:46
virtual double GetChunkSuccessRate(WifiMode mode, double snr, uint32_t nbits) const
A pure virtual method that must be implemented in the subclass.
double GetBpskBer(double snr) const
Return BER of BPSK at the given SNR.