src/devices/wifi/wifi-phy.cc
author Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
Tue, 02 Sep 2008 15:17:43 -0700
changeset 3586 692e616413a3
parent 3212 0c00342d6a73
child 3906 01acc159ffb1
permissions -rw-r--r--
improve debugging output
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     1
/* -*-  Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     2
/*
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     3
 * Copyright (c) 2005,2006 INRIA
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     4
 *
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     6
 * it under the terms of the GNU General Public License version 2 as 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     7
 * published by the Free Software Foundation;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     8
 *
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    12
 * GNU General Public License for more details.
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    13
 *
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    14
 * You should have received a copy of the GNU General Public License
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    15
 * along with this program; if not, write to the Free Software
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    16
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    17
 *
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    18
 * Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    19
 */
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    20
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    21
#include "wifi-phy.h"
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
    22
#include "wifi-mode.h"
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
    23
#include "wifi-channel.h"
1920
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
    24
#include "wifi-preamble.h"
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    25
#include "ns3/simulator.h"
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    26
#include "ns3/packet.h"
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    27
#include "ns3/random-variable.h"
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
    28
#include "ns3/assert.h"
1979
d535a38b7fc4 convert TRACE to NS_LOG
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1978
diff changeset
    29
#include "ns3/log.h"
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
    30
#include "ns3/double.h"
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
    31
#include "ns3/uinteger.h"
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
    32
#include "ns3/enum.h"
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
    33
#include "ns3/trace-source-accessor.h"
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    34
#include <math.h>
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    35
1979
d535a38b7fc4 convert TRACE to NS_LOG
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1978
diff changeset
    36
NS_LOG_COMPONENT_DEFINE ("WifiPhy");
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
    37
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    38
namespace ns3 {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    39
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
    40
  // Define all the WifiMode needed for 802.11a
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
    41
static WifiMode g_6mba = WifiModeFactory::CreateBpsk ("wifia-6mbs",
1909
4d1214bb8bc0 add WifiMode mandatory flag
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1892
diff changeset
    42
                                                      true,
2164
6e347fdbfa4a avoid confusion between code and uncoded rates.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2159
diff changeset
    43
                                                      20000000, 6000000, 12000000);
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
    44
static WifiMode g_9mba = WifiModeFactory::CreateBpsk ("wifia-9mbs",
1909
4d1214bb8bc0 add WifiMode mandatory flag
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1892
diff changeset
    45
                                                      false,
2164
6e347fdbfa4a avoid confusion between code and uncoded rates.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2159
diff changeset
    46
                                                      20000000, 9000000, 12000000);
6e347fdbfa4a avoid confusion between code and uncoded rates.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2159
diff changeset
    47
// XXX explain why Bpsk rather than Qpsk
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
    48
static WifiMode g_12mba = WifiModeFactory::CreateBpsk ("wifia-12mbs",
1909
4d1214bb8bc0 add WifiMode mandatory flag
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1892
diff changeset
    49
                                                       true,
2164
6e347fdbfa4a avoid confusion between code and uncoded rates.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2159
diff changeset
    50
                                                       20000000, 12000000, 24000000);
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
    51
static WifiMode g_18mba = WifiModeFactory::CreateBpsk ("wifia-18mbs",
1909
4d1214bb8bc0 add WifiMode mandatory flag
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1892
diff changeset
    52
                                                       false,
2164
6e347fdbfa4a avoid confusion between code and uncoded rates.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2159
diff changeset
    53
                                                       20000000, 18000000, 24000000);
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
    54
static WifiMode g_24mba = WifiModeFactory::CreateBpsk ("wifia-24mbs",
1909
4d1214bb8bc0 add WifiMode mandatory flag
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1892
diff changeset
    55
                                                       true,
2164
6e347fdbfa4a avoid confusion between code and uncoded rates.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2159
diff changeset
    56
                                                       20000000, 24000000, 48000000);
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
    57
static WifiMode g_36mba = WifiModeFactory::CreateBpsk ("wifia-36mbs",
1909
4d1214bb8bc0 add WifiMode mandatory flag
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1892
diff changeset
    58
                                                       false,
2164
6e347fdbfa4a avoid confusion between code and uncoded rates.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2159
diff changeset
    59
                                                       20000000, 36000000, 48000000);
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
    60
static WifiMode g_48mba = WifiModeFactory::CreateBpsk ("wifia-48mbs",
1909
4d1214bb8bc0 add WifiMode mandatory flag
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1892
diff changeset
    61
                                                       false,
2164
6e347fdbfa4a avoid confusion between code and uncoded rates.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2159
diff changeset
    62
                                                       20000000, 48000000, 72000000);
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
    63
static WifiMode g_54mba = WifiModeFactory::CreateBpsk ("wifia-54mbs",
1909
4d1214bb8bc0 add WifiMode mandatory flag
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1892
diff changeset
    64
                                                       false,
2164
6e347fdbfa4a avoid confusion between code and uncoded rates.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2159
diff changeset
    65
                                                       20000000, 54000000, 72000000);
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
    66
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
    67
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    68
/****************************************************************
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    69
 *       This destructor is needed.
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    70
 ****************************************************************/
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    71
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
    72
WifiPhyListener::~WifiPhyListener ()
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    73
{}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    74
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    75
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    76
/****************************************************************
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    77
 *       Phy event class
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    78
 ****************************************************************/
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    79
2630
17b545238ab3 do not use ObjectBase as a base class.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2602
diff changeset
    80
class RxEvent
2370
5f7ad186b798 introduce ObjectBase
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2173
diff changeset
    81
{
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    82
public:
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
    83
  RxEvent (uint32_t size, WifiMode payloadMode, 
1920
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
    84
           enum WifiPreamble preamble,
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    85
           Time duration, double rxPower)
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    86
    : m_size (size),
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    87
      m_payloadMode (payloadMode),
1920
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
    88
      m_preamble (preamble),
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    89
      m_startTime (Simulator::Now ()),
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    90
      m_endTime (m_startTime + duration),
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    91
      m_rxPowerW (rxPower),
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    92
      m_refCount (1)
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    93
  {}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    94
  ~RxEvent ()
1992
5ff1101cb843 do not call Unref directly anymore.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1988
diff changeset
    95
  {
5ff1101cb843 do not call Unref directly anymore.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1988
diff changeset
    96
    NS_ASSERT (m_refCount == 0);
5ff1101cb843 do not call Unref directly anymore.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1988
diff changeset
    97
  }
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    98
  
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    99
  void Ref (void) const {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   100
    m_refCount++;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   101
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   102
  void Unref (void) const {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   103
    m_refCount--;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   104
    if (m_refCount == 0) {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   105
      delete this;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   106
    }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   107
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   108
  Time GetDuration (void) const {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   109
    return m_endTime - m_startTime;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   110
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   111
  Time GetStartTime (void) const {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   112
    return m_startTime;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   113
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   114
  Time GetEndTime (void) const {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   115
    return m_endTime;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   116
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   117
  bool Overlaps (Time time) const {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   118
    if (m_startTime <= time &&
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   119
        m_endTime >= time) {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   120
      return true;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   121
    } else {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   122
      return false;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   123
    }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   124
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   125
  double GetRxPowerW (void) const {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   126
    return m_rxPowerW;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   127
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   128
  uint32_t GetSize (void) const {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   129
    return m_size;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   130
  }
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
   131
  WifiMode GetPayloadMode (void) const {
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   132
    return m_payloadMode;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   133
  }
1920
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
   134
  enum WifiPreamble GetPreambleType (void) const {
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
   135
    return m_preamble;
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   136
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   137
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   138
private:
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   139
  uint32_t m_size;
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
   140
  WifiMode m_payloadMode;
1920
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
   141
  enum WifiPreamble m_preamble;
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   142
  Time m_startTime;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   143
  Time m_endTime;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   144
  double m_rxPowerW;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   145
  mutable int m_refCount;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   146
};
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   147
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   148
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   149
/****************************************************************
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   150
 *       Class which records SNIR change events for a 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   151
 *       short period of time.
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   152
 ****************************************************************/
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   153
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   154
WifiPhy::NiChange::NiChange (Time time, double delta)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   155
  : m_time (time), m_delta (delta) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   156
{}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   157
Time
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   158
WifiPhy::NiChange::GetTime (void) const
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   159
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   160
  return m_time;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   161
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   162
double 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   163
WifiPhy::NiChange::GetDelta (void) const
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   164
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   165
  return m_delta;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   166
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   167
bool 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   168
WifiPhy::NiChange::operator < (WifiPhy::NiChange const &o) const
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   169
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   170
  return (m_time < o.m_time)?true:false;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   171
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   172
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   173
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   174
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   175
/****************************************************************
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   176
 *       The actual WifiPhy class
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   177
 ****************************************************************/
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   178
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   179
NS_OBJECT_ENSURE_REGISTERED (WifiPhy);
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   180
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   181
TypeId 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   182
WifiPhy::GetTypeId (void)
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   183
{
2602
d9262bff6df2 add back support for introspected doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2530
diff changeset
   184
  static TypeId tid = TypeId ("ns3::WifiPhy")
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   185
    .SetParent<Object> ()
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   186
    .AddConstructor<WifiPhy> ()
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   187
    .AddAttribute ("EnergyDetectionThreshold",
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   188
                   "The energy of a received signal should be higher than "
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   189
                   "this threshold (dbm) to allow the PHY layer to detect the signal.",
2965
4b28e9740e3b get rid of Attribute class. Use AttributeValue subclasses directly.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   190
                   DoubleValue (-140.0),
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   191
                   MakeDoubleAccessor (&WifiPhy::SetEdThreshold,
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   192
                                       &WifiPhy::GetEdThreshold),
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   193
                   MakeDoubleChecker<double> ())
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   194
    .AddAttribute ("TxGain",
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   195
                   "Transmission gain (dB).",
2965
4b28e9740e3b get rid of Attribute class. Use AttributeValue subclasses directly.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   196
                   DoubleValue (1.0),
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   197
                   MakeDoubleAccessor (&WifiPhy::SetTxGain,
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   198
                                       &WifiPhy::GetTxGain),
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   199
                   MakeDoubleChecker<double> ())
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   200
    .AddAttribute ("RxGain",
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   201
                   "Reception gain (dB).",
2965
4b28e9740e3b get rid of Attribute class. Use AttributeValue subclasses directly.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   202
                   DoubleValue (1.0),
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   203
                   MakeDoubleAccessor (&WifiPhy::SetRxGain,
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   204
                                       &WifiPhy::GetRxGain),
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   205
                   MakeDoubleChecker<double> ())
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   206
    .AddAttribute ("TxPowerLevels",
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   207
                   "Number of transmission power levels available between "
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   208
                   "TxPowerBase and TxPowerEnd included.",
2965
4b28e9740e3b get rid of Attribute class. Use AttributeValue subclasses directly.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   209
                   UintegerValue (1),
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   210
                   MakeUintegerAccessor (&WifiPhy::m_nTxPower),
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   211
                   MakeUintegerChecker<uint32_t> ())
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   212
    .AddAttribute ("TxPowerEnd",
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   213
                   "Maximum available transmission level (dbm).",
2965
4b28e9740e3b get rid of Attribute class. Use AttributeValue subclasses directly.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   214
                   DoubleValue (16.0206),
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   215
                   MakeDoubleAccessor (&WifiPhy::SetTxPowerEnd, 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   216
                                       &WifiPhy::GetTxPowerEnd),
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   217
                   MakeDoubleChecker<double> ())
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   218
    .AddAttribute ("TxPowerStart",
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   219
                   "Minimum available transmission level (dbm).",
2965
4b28e9740e3b get rid of Attribute class. Use AttributeValue subclasses directly.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   220
                   DoubleValue (16.0206),
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   221
                   MakeDoubleAccessor (&WifiPhy::SetTxPowerStart, 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   222
                                       &WifiPhy::GetTxPowerStart),
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   223
                   MakeDoubleChecker<double> ())
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   224
    .AddAttribute ("RxNoise",
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   225
                   "Ratio of energy lost by receiver (dB).",
2965
4b28e9740e3b get rid of Attribute class. Use AttributeValue subclasses directly.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   226
                   DoubleValue (7),
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   227
                   MakeDoubleAccessor (&WifiPhy::SetRxNoise,
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   228
                                       &WifiPhy::GetRxNoise),
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   229
                   MakeDoubleChecker<double> ())
3212
0c00342d6a73 improve attribute documentation
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2989
diff changeset
   230
    .AddAttribute ("Standard", "The standard chosen configures a set of transmission modes"
0c00342d6a73 improve attribute documentation
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2989
diff changeset
   231
                   " and some PHY-specific constants.",
2965
4b28e9740e3b get rid of Attribute class. Use AttributeValue subclasses directly.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   232
                   EnumValue (WIFI_PHY_STANDARD_80211a),
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   233
                   MakeEnumAccessor (&WifiPhy::SetStandard),
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   234
                   MakeEnumChecker (WIFI_PHY_STANDARD_80211a, "802.11a",
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   235
                                    WIFI_PHY_STANDARD_holland, "holland"))
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   236
    .AddTraceSource ("State",
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   237
                     "The WifiPhy state",
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   238
                     MakeTraceSourceAccessor (&WifiPhy::m_stateLogger))
2652
f42cc6deb42b add extra trace sources
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2632
diff changeset
   239
    .AddTraceSource ("RxOk",
f42cc6deb42b add extra trace sources
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2632
diff changeset
   240
                     "A packet has been received successfully.",
2659
38f50c9d55f4 make sure the trace hooks get a full packet as input.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2652
diff changeset
   241
                     MakeTraceSourceAccessor (&WifiPhy::m_rxOkTrace))
2652
f42cc6deb42b add extra trace sources
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2632
diff changeset
   242
    .AddTraceSource ("RxError",
f42cc6deb42b add extra trace sources
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2632
diff changeset
   243
                     "A packet has been received unsuccessfully.",
2659
38f50c9d55f4 make sure the trace hooks get a full packet as input.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2652
diff changeset
   244
                     MakeTraceSourceAccessor (&WifiPhy::m_rxErrorTrace))
2652
f42cc6deb42b add extra trace sources
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2632
diff changeset
   245
    .AddTraceSource ("Tx", "Packet transmission is starting.",
2659
38f50c9d55f4 make sure the trace hooks get a full packet as input.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2652
diff changeset
   246
                     MakeTraceSourceAccessor (&WifiPhy::m_txTrace))
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   247
    ;
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   248
  return tid;
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   249
}
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   250
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   251
WifiPhy::WifiPhy ()
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   252
  : m_syncing (false),
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   253
    m_endTx (Seconds (0)),
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   254
    m_endSync (Seconds (0)),
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   255
    m_endCcaBusy (Seconds (0)),
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   256
    m_startTx (Seconds (0)),
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   257
    m_startSync (Seconds (0)),
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   258
    m_startCcaBusy (Seconds (0)),
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   259
    m_previousStateChangeTime (Seconds (0)),
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   260
    m_endSyncEvent (),
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   261
    m_random (0.0, 1.0)
2985
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   262
{
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   263
  NS_LOG_FUNCTION (this);
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   264
}
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   265
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   266
WifiPhy::~WifiPhy ()
2985
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   267
{
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   268
  NS_LOG_FUNCTION (this);
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   269
}
2530
05f9cec44621 avoid memory leaks
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2524
diff changeset
   270
05f9cec44621 avoid memory leaks
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2524
diff changeset
   271
void
05f9cec44621 avoid memory leaks
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2524
diff changeset
   272
WifiPhy::DoDispose (void)
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1920
diff changeset
   273
{
2985
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   274
  NS_LOG_FUNCTION (this);
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   275
  m_channel = 0;
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   276
  m_events.clear ();
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   277
  m_modes.clear ();
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   278
}
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   279
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   280
void
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   281
WifiPhy::SetStandard (enum WifiPhyStandard standard)
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   282
{
2985
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   283
  NS_LOG_FUNCTION (this << standard);
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   284
  m_standard = standard;
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   285
  switch (standard) {
2166
00b5eb43dba2 Improve the accuracy of 802.11a tx duration calculations.
Federico Maguolo <federico.maguolo@dei.unipd.it>
parents: 2164
diff changeset
   286
  case WIFI_PHY_STANDARD_80211a:
2083
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   287
    Configure80211a ();
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   288
    break;
2166
00b5eb43dba2 Improve the accuracy of 802.11a tx duration calculations.
Federico Maguolo <federico.maguolo@dei.unipd.it>
parents: 2164
diff changeset
   289
  case WIFI_PHY_STANDARD_holland:
2083
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   290
    ConfigureHolland ();
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   291
    break;
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   292
  default:
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   293
    NS_ASSERT (false);
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   294
    break;
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   295
  }
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1920
diff changeset
   296
}
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   297
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   298
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   299
void 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   300
WifiPhy::SetRxNoise (double db)
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   301
{
2985
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   302
  NS_LOG_FUNCTION (this << db);
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   303
  m_rxNoiseRatio = DbToRatio (db);
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   304
}
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   305
void 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   306
WifiPhy::SetTxPowerStart (double start)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   307
{
2985
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   308
  NS_LOG_FUNCTION (this << start);
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   309
  m_txPowerBaseDbm = start;
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   310
}
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   311
void 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   312
WifiPhy::SetTxPowerEnd (double end)
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   313
{
2985
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   314
  NS_LOG_FUNCTION (this << end);
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   315
  m_txPowerEndDbm = end;
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   316
}
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   317
void 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   318
WifiPhy::SetNTxPower (uint32_t n)
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   319
{
2985
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   320
  NS_LOG_FUNCTION (this << n);
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   321
  m_nTxPower = n;
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   322
}
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   323
void 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   324
WifiPhy::SetTxGain (double gain)
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   325
{
2985
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   326
  NS_LOG_FUNCTION (this << gain);
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   327
  m_txGainDb = gain;
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   328
}
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   329
void 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   330
WifiPhy::SetRxGain (double gain)
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   331
{
2985
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   332
  NS_LOG_FUNCTION (this << gain);
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   333
  m_rxGainDb = gain;
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   334
}
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   335
void 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   336
WifiPhy::SetEdThreshold (double threshold)
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   337
{
2985
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   338
  NS_LOG_FUNCTION (this << threshold);
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   339
  m_edThresholdW = DbmToW (threshold);
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   340
}
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   341
double 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   342
WifiPhy::GetRxNoise (void) const
2155
194dd8bdcf56 add WifiPhy::GetDevice
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2150
diff changeset
   343
{
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   344
  return RatioToDb (m_rxNoiseRatio);
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   345
}
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   346
double 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   347
WifiPhy::GetTxPowerStart (void) const
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   348
{
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   349
  return m_txPowerBaseDbm;
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   350
}
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   351
double 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   352
WifiPhy::GetTxPowerEnd (void) const
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   353
{
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   354
  return m_txPowerEndDbm;
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   355
}
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   356
double 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   357
WifiPhy::GetTxGain (void) const
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   358
{
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   359
  return m_txGainDb;
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   360
}
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   361
double 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   362
WifiPhy::GetRxGain (void) const
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   363
{
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   364
  return m_rxGainDb;
2155
194dd8bdcf56 add WifiPhy::GetDevice
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2150
diff changeset
   365
}
194dd8bdcf56 add WifiPhy::GetDevice
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2150
diff changeset
   366
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   367
double 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   368
WifiPhy::GetEdThreshold (void) const
2055
8899d6ef5d52 phy state logger
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1999
diff changeset
   369
{
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   370
  return WToDbm (m_edThresholdW);
2055
8899d6ef5d52 phy state logger
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1999
diff changeset
   371
}
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   372
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   373
Ptr<WifiChannel> 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   374
WifiPhy::GetChannel (void) const
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   375
{
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   376
  return m_channel;
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   377
}
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
   378
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   379
void 
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
   380
WifiPhy::SetChannel (Ptr<WifiChannel> channel)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   381
{
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
   382
  m_channel = channel;
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   383
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   384
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   385
void 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   386
WifiPhy::SetReceiveOkCallback (SyncOkCallback callback)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   387
{
2659
38f50c9d55f4 make sure the trace hooks get a full packet as input.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2652
diff changeset
   388
  m_syncOkCallback = callback;
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   389
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   390
void 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   391
WifiPhy::SetReceiveErrorCallback (SyncErrorCallback callback)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   392
{
2659
38f50c9d55f4 make sure the trace hooks get a full packet as input.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2652
diff changeset
   393
  m_syncErrorCallback = callback;
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   394
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   395
void 
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   396
WifiPhy::StartReceivePacket (Ptr<Packet> packet, 
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   397
                             double rxPowerDbm,
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   398
                             WifiMode txMode,
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   399
                             enum WifiPreamble preamble)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   400
{
2985
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   401
  NS_LOG_FUNCTION (this << packet << rxPowerDbm << txMode << preamble);
2071
122c95ffccdd use dB instead of dbm where appropriate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2056
diff changeset
   402
  rxPowerDbm += m_rxGainDb;
1988
210701141b08 convert to and from dbms when needed
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1979
diff changeset
   403
  double rxPowerW = DbmToW (rxPowerDbm);
2159
20f882e85b4a port to Ptr<Packet> branch
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2155
diff changeset
   404
  Time rxDuration = CalculateTxDuration (packet->GetSize (), txMode, preamble);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   405
  Time endRx = Simulator::Now () + rxDuration;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   406
2159
20f882e85b4a port to Ptr<Packet> branch
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2155
diff changeset
   407
  Ptr<RxEvent> event = Create<RxEvent> (packet->GetSize (), 
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   408
                                        txMode,
1920
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
   409
                                        preamble,
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   410
                                        rxDuration,
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   411
                                        rxPowerW);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   412
  AppendEvent (event);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   413
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   414
  switch (GetState ()) {
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   415
  case WifiPhy::SYNC:
1979
d535a38b7fc4 convert TRACE to NS_LOG
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1978
diff changeset
   416
    NS_LOG_DEBUG ("drop packet because already in Sync (power="<<
d535a38b7fc4 convert TRACE to NS_LOG
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1978
diff changeset
   417
                  rxPowerW<<"W)");
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   418
    if (endRx > m_endSync) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   419
      {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   420
        goto maybeCcaBusy;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   421
      }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   422
    break;
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   423
  case WifiPhy::TX:
1979
d535a38b7fc4 convert TRACE to NS_LOG
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1978
diff changeset
   424
    NS_LOG_DEBUG ("drop packet because already in Tx (power="<<
d535a38b7fc4 convert TRACE to NS_LOG
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1978
diff changeset
   425
                  rxPowerW<<"W)");
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   426
    if (endRx > m_endTx) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   427
      {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   428
        goto maybeCcaBusy;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   429
      }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   430
    break;
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   431
  case WifiPhy::CCA_BUSY:
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   432
  case WifiPhy::IDLE:
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   433
    if (rxPowerW > m_edThresholdW) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   434
      {
2150
e4aff46fe6c5 add some info logs, improve snr vs ber curve output, linearize the ber calculations.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2139
diff changeset
   435
        NS_LOG_DEBUG ("sync (power="<<rxPowerW<<"W)");
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   436
        // sync to signal
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   437
        NotifySyncStart (rxDuration);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   438
        SwitchToSync (rxDuration);
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   439
        NS_ASSERT (m_endSyncEvent.IsExpired ());
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   440
        m_endSyncEvent = Simulator::Schedule (rxDuration, &WifiPhy::EndSync, this, 
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   441
                                              packet,
1919
46ed9ed9dac0 remove extra WifiPhy::SendPacket argument. Add header mode support
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1909
diff changeset
   442
                                              event);
2071
122c95ffccdd use dB instead of dbm where appropriate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2056
diff changeset
   443
      }
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   444
    else 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   445
      {
1979
d535a38b7fc4 convert TRACE to NS_LOG
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1978
diff changeset
   446
        NS_LOG_DEBUG ("drop packet because signal power too Small ("<<
d535a38b7fc4 convert TRACE to NS_LOG
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1978
diff changeset
   447
                      rxPowerW<<"<"<<m_edThresholdW<<")");
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   448
        goto maybeCcaBusy;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   449
      }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   450
    break;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   451
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   452
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   453
  return;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   454
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   455
 maybeCcaBusy:
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   456
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   457
  if (rxPowerW > m_edThresholdW) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   458
    {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   459
      SwitchMaybeToCcaBusy (rxDuration);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   460
      NotifyCcaBusyStart (rxDuration);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   461
    } 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   462
  else 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   463
    {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   464
      double threshold = m_edThresholdW - rxPowerW;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   465
      NiChanges ni;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   466
      CalculateNoiseInterferenceW (event, &ni);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   467
      double noiseInterferenceW = 0.0;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   468
      Time end = Simulator::Now ();
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
   469
      for (NiChanges::const_iterator i = ni.begin (); i != ni.end (); i++) 
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   470
        {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   471
          noiseInterferenceW += i->GetDelta ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   472
          if (noiseInterferenceW < threshold) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   473
            {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   474
              break;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   475
            }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   476
          end = i->GetTime ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   477
        }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   478
      if (end > Simulator::Now ()) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   479
        {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   480
          Time delta = end - Simulator::Now ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   481
          SwitchMaybeToCcaBusy (delta);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   482
          NotifyCcaBusyStart (delta);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   483
        }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   484
    }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   485
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   486
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   487
void 
2159
20f882e85b4a port to Ptr<Packet> branch
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2155
diff changeset
   488
WifiPhy::SendPacket (Ptr<const Packet> packet, WifiMode txMode, WifiPreamble preamble, uint8_t txPower)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   489
{
3586
692e616413a3 improve debugging output
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3212
diff changeset
   490
  NS_LOG_FUNCTION (this << packet << txMode << preamble << (uint32_t)txPower);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   491
  /* Transmission can happen if:
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   492
   *  - we are syncing on a packet. It is the responsability of the
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   493
   *    MAC layer to avoid doing this but the PHY does nothing to 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   494
   *    prevent it.
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   495
   *  - we are idle
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   496
   */
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   497
  NS_ASSERT (!IsStateTx ());
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   498
2659
38f50c9d55f4 make sure the trace hooks get a full packet as input.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2652
diff changeset
   499
  m_txTrace (packet, txMode, preamble, txPower);
2159
20f882e85b4a port to Ptr<Packet> branch
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2155
diff changeset
   500
  Time txDuration = CalculateTxDuration (packet->GetSize (), txMode, preamble);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   501
  NotifyTxStart (txDuration);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   502
  SwitchToTx (txDuration);
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   503
  m_channel->Send (this, packet, GetPowerDbm (txPower) + m_txGainDb, txMode, preamble);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   504
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   505
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   506
uint32_t 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   507
WifiPhy::GetNModes (void) const
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   508
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   509
  return m_modes.size ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   510
}
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
   511
WifiMode 
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
   512
WifiPhy::GetMode (uint32_t mode) const
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   513
{
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
   514
  return m_modes[mode];
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   515
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   516
uint32_t 
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   517
WifiPhy::GetNTxPower (void) const
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   518
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   519
  return m_nTxPower;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   520
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   521
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   522
double 
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
   523
WifiPhy::CalculateSnr (WifiMode txMode, double ber) const
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   524
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   525
  double low, high, precision;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   526
  low = 1e-25;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   527
  high = 1e25;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   528
  precision = 1e-12;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   529
  while (high - low > precision) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   530
    {
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   531
      NS_ASSERT (high >= low);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   532
      double middle = low + (high - low) / 2;
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
   533
      if ((1 - GetChunkSuccessRate (txMode, middle, 1)) > ber) 
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   534
        {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   535
          low = middle;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   536
        } 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   537
      else 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   538
        {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   539
          high = middle;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   540
        }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   541
    }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   542
  return low;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   543
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   544
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   545
void
2083
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   546
WifiPhy::Configure80211aParameters (void)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   547
{
2985
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   548
  NS_LOG_FUNCTION (this);
2166
00b5eb43dba2 Improve the accuracy of 802.11a tx duration calculations.
Federico Maguolo <federico.maguolo@dei.unipd.it>
parents: 2164
diff changeset
   549
  m_plcpLongPreambleDelayUs = 16;
00b5eb43dba2 Improve the accuracy of 802.11a tx duration calculations.
Federico Maguolo <federico.maguolo@dei.unipd.it>
parents: 2164
diff changeset
   550
  m_plcpShortPreambleDelayUs = 16;
1920
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
   551
  m_longPlcpHeaderMode = g_6mba;
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
   552
  m_shortPlcpHeaderMode = g_6mba;
2166
00b5eb43dba2 Improve the accuracy of 802.11a tx duration calculations.
Federico Maguolo <federico.maguolo@dei.unipd.it>
parents: 2164
diff changeset
   553
  m_plcpHeaderLength = 4 + 1 + 12 + 1 + 6;
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   554
  /* 4095 bytes at a 6Mb/s rate with a 1/2 coding rate. */
2167
3b0f18764163 re-use the CaculateTxDuration method where it is needed.
Federico Maguolo <federico.maguolo@dei.unipd.it>
parents: 2166
diff changeset
   555
  m_maxPacketDuration = CalculateTxDuration (4095, g_6mba, WIFI_PREAMBLE_LONG);
2083
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   556
}
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   557
2083
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   558
void
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   559
WifiPhy::PrintModes (void) const
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   560
{
2150
e4aff46fe6c5 add some info logs, improve snr vs ber curve output, linearize the ber calculations.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2139
diff changeset
   561
#if 0
e4aff46fe6c5 add some info logs, improve snr vs ber curve output, linearize the ber calculations.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2139
diff changeset
   562
  for (double db = -10; db < 30; db+= 0.5) {
e4aff46fe6c5 add some info logs, improve snr vs ber curve output, linearize the ber calculations.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2139
diff changeset
   563
    double snr = DbToRatio (db);
e4aff46fe6c5 add some info logs, improve snr vs ber curve output, linearize the ber calculations.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2139
diff changeset
   564
    std::cout <<snr<<" ";
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   565
    for (uint8_t i = 0; i < GetNModes (); i++) {
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
   566
      WifiMode mode = GetMode (i);
2150
e4aff46fe6c5 add some info logs, improve snr vs ber curve output, linearize the ber calculations.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2139
diff changeset
   567
      double ber = 1-GetChunkSuccessRate (mode,snr, 2000*8);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   568
      std::cout <<ber<< " ";
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   569
    }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   570
    std::cout << std::endl;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   571
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   572
#endif
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   573
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   574
2083
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   575
void
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   576
WifiPhy::Configure80211a (void)
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   577
{
2985
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   578
  NS_LOG_FUNCTION (this);
2083
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   579
  Configure80211aParameters ();
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   580
  m_modes.push_back (g_6mba);
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   581
  m_modes.push_back (g_9mba);
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   582
  m_modes.push_back (g_12mba);
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   583
  m_modes.push_back (g_18mba);
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   584
  m_modes.push_back (g_24mba);
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   585
  m_modes.push_back (g_36mba);
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   586
  m_modes.push_back (g_48mba);
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   587
  m_modes.push_back (g_54mba);
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   588
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   589
  PrintModes ();
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   590
}
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   591
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   592
void
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   593
WifiPhy::ConfigureHolland (void)
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   594
{
2985
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
   595
  NS_LOG_FUNCTION (this);
2083
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   596
  Configure80211aParameters ();
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   597
  m_modes.push_back (g_6mba);
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   598
  m_modes.push_back (g_12mba);
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   599
  m_modes.push_back (g_18mba);
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   600
  m_modes.push_back (g_36mba);
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   601
  m_modes.push_back (g_54mba);
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   602
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   603
  PrintModes ();
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   604
}
c7541b84285e add the holland 802.11a set of modes.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2077
diff changeset
   605
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   606
void 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   607
WifiPhy::RegisterListener (WifiPhyListener *listener)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   608
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   609
  m_listeners.push_back (listener);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   610
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   611
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   612
bool 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   613
WifiPhy::IsStateCcaBusy (void)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   614
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   615
  return GetState () == CCA_BUSY;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   616
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   617
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   618
bool 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   619
WifiPhy::IsStateIdle (void)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   620
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   621
  return (GetState () == IDLE)?true:false;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   622
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   623
bool 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   624
WifiPhy::IsStateBusy (void)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   625
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   626
  return (GetState () != IDLE)?true:false;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   627
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   628
bool 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   629
WifiPhy::IsStateSync (void)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   630
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   631
  return (GetState () == SYNC)?true:false;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   632
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   633
bool 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   634
WifiPhy::IsStateTx (void)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   635
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   636
  return (GetState () == TX)?true:false;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   637
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   638
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   639
Time
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   640
WifiPhy::GetStateDuration (void)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   641
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   642
  return Simulator::Now () - m_previousStateChangeTime;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   643
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   644
Time
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   645
WifiPhy::GetDelayUntilIdle (void)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   646
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   647
  Time retval;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   648
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   649
  switch (GetState ()) {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   650
  case SYNC:
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   651
    retval = m_endSync - Simulator::Now ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   652
    break;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   653
  case TX:
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   654
    retval = m_endTx - Simulator::Now ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   655
    break;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   656
  case CCA_BUSY:
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   657
    retval = m_endCcaBusy - Simulator::Now ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   658
    break;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   659
  case IDLE:
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   660
    retval = Seconds (0);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   661
    break;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   662
  default:
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   663
    NS_ASSERT (false);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   664
    // NOTREACHED
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   665
    retval = Seconds (0);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   666
    break;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   667
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   668
  retval = Max (retval, Seconds (0));
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   669
  return retval;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   670
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   671
2139
a2cf93c741c3 add WifiPhy::GetLastRxStart
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2083
diff changeset
   672
Time 
a2cf93c741c3 add WifiPhy::GetLastRxStart
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2083
diff changeset
   673
WifiPhy::GetLastRxStartTime (void) const
a2cf93c741c3 add WifiPhy::GetLastRxStart
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2083
diff changeset
   674
{
a2cf93c741c3 add WifiPhy::GetLastRxStart
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2083
diff changeset
   675
  return m_startSync;
a2cf93c741c3 add WifiPhy::GetLastRxStart
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2083
diff changeset
   676
}
a2cf93c741c3 add WifiPhy::GetLastRxStart
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2083
diff changeset
   677
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   678
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   679
Time
1920
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
   680
WifiPhy::CalculateTxDuration (uint32_t size, WifiMode payloadMode, WifiPreamble preamble) const
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   681
{
1920
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
   682
  uint64_t delay = 0;
2166
00b5eb43dba2 Improve the accuracy of 802.11a tx duration calculations.
Federico Maguolo <federico.maguolo@dei.unipd.it>
parents: 2164
diff changeset
   683
  switch (m_standard) {
00b5eb43dba2 Improve the accuracy of 802.11a tx duration calculations.
Federico Maguolo <federico.maguolo@dei.unipd.it>
parents: 2164
diff changeset
   684
  case WIFI_PHY_STANDARD_80211a:
00b5eb43dba2 Improve the accuracy of 802.11a tx duration calculations.
Federico Maguolo <federico.maguolo@dei.unipd.it>
parents: 2164
diff changeset
   685
  case WIFI_PHY_STANDARD_holland: {
1920
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
   686
    delay += m_plcpLongPreambleDelayUs;
2166
00b5eb43dba2 Improve the accuracy of 802.11a tx duration calculations.
Federico Maguolo <federico.maguolo@dei.unipd.it>
parents: 2164
diff changeset
   687
    // symbol duration is 4us
00b5eb43dba2 Improve the accuracy of 802.11a tx duration calculations.
Federico Maguolo <federico.maguolo@dei.unipd.it>
parents: 2164
diff changeset
   688
    delay += 4;
2173
7437d8a72987 Avoid integer division
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2167
diff changeset
   689
    delay += lrint (ceil ((size * 8.0 + 16.0 + 6.0) / payloadMode.GetDataRate () / 4e-6) * 4);
2166
00b5eb43dba2 Improve the accuracy of 802.11a tx duration calculations.
Federico Maguolo <federico.maguolo@dei.unipd.it>
parents: 2164
diff changeset
   690
  } break;
00b5eb43dba2 Improve the accuracy of 802.11a tx duration calculations.
Federico Maguolo <federico.maguolo@dei.unipd.it>
parents: 2164
diff changeset
   691
  default:
00b5eb43dba2 Improve the accuracy of 802.11a tx duration calculations.
Federico Maguolo <federico.maguolo@dei.unipd.it>
parents: 2164
diff changeset
   692
    // quiet compiler.
00b5eb43dba2 Improve the accuracy of 802.11a tx duration calculations.
Federico Maguolo <federico.maguolo@dei.unipd.it>
parents: 2164
diff changeset
   693
    NS_ASSERT (false);
1920
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
   694
    break;
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
   695
  }
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   696
  return MicroSeconds (delay);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   697
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   698
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   699
char const *
2055
8899d6ef5d52 phy state logger
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1999
diff changeset
   700
WifiPhy::StateToString (enum State state)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   701
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   702
  switch (state) {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   703
  case TX:
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   704
    return "TX";
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   705
    break;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   706
  case CCA_BUSY:
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   707
    return "CCA_BUSY";
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   708
    break;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   709
  case IDLE:
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   710
    return "IDLE";
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   711
    break;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   712
  case SYNC:
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   713
    return "SYNC";
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   714
    break;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   715
  default:
3212
0c00342d6a73 improve attribute documentation
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2989
diff changeset
   716
    NS_ASSERT (false);
0c00342d6a73 improve attribute documentation
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2989
diff changeset
   717
    // quiet compiler
0c00342d6a73 improve attribute documentation
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2989
diff changeset
   718
    return "INVALID";
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   719
    break;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   720
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   721
}
2055
8899d6ef5d52 phy state logger
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1999
diff changeset
   722
enum WifiPhy::State 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   723
WifiPhy::GetState (void)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   724
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   725
  if (m_endTx > Simulator::Now ()) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   726
    {
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   727
      return WifiPhy::TX;
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   728
    } 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   729
  else if (m_syncing) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   730
    {
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   731
      return WifiPhy::SYNC;
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   732
    } 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   733
  else if (m_endCcaBusy > Simulator::Now ()) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   734
    {
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   735
      return WifiPhy::CCA_BUSY;
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   736
    } 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   737
  else 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   738
    {
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   739
      return WifiPhy::IDLE;
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   740
    }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   741
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   742
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   743
double 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   744
WifiPhy::DbToRatio (double dB) const
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   745
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   746
  double ratio = pow(10.0,dB/10.0);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   747
  return ratio;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   748
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   749
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   750
double 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   751
WifiPhy::DbmToW (double dBm) const
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   752
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   753
  double mW = pow(10.0,dBm/10.0);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   754
  return mW / 1000.0;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   755
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   756
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   757
double
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   758
WifiPhy::WToDbm (double w) const
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   759
{
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   760
  return 10.0 * log10(w * 1000.0);
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   761
}
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   762
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   763
double
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   764
WifiPhy::RatioToDb (double ratio) const
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   765
{
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   766
  return 10.0 * log10(ratio);
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   767
}
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   768
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
   769
double
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   770
WifiPhy::GetEdThresholdW (void) const
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   771
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   772
  return m_edThresholdW;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   773
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   774
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   775
Time
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   776
WifiPhy::GetMaxPacketDuration (void) const
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   777
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   778
  return m_maxPacketDuration;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   779
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   780
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   781
double 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   782
WifiPhy::GetPowerDbm (uint8_t power) const
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   783
{
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   784
  NS_ASSERT (m_txPowerBaseDbm <= m_txPowerEndDbm);
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   785
  NS_ASSERT (m_nTxPower > 0);
2782
4c813b3ea1c3 tx power shoudl reflect the user-selected power level, not be always the power level zero.
Providence SALUMU MUNGA <Providence.Salumu_Munga@it-sudparis.eu>
parents: 2659
diff changeset
   786
  double dbm = m_txPowerBaseDbm + power * (m_txPowerEndDbm - m_txPowerBaseDbm) / m_nTxPower;
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   787
  return dbm;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   788
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   789
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   790
void 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   791
WifiPhy::NotifyTxStart (Time duration)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   792
{
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
   793
  for (Listeners::const_iterator i = m_listeners.begin (); i != m_listeners.end (); i++) {
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   794
    (*i)->NotifyTxStart (duration);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   795
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   796
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   797
void 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   798
WifiPhy::NotifySyncStart (Time duration)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   799
{
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
   800
  for (Listeners::const_iterator i = m_listeners.begin (); i != m_listeners.end (); i++) {
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   801
    (*i)->NotifyRxStart (duration);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   802
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   803
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   804
void 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   805
WifiPhy::NotifySyncEndOk (void)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   806
{
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
   807
  for (Listeners::const_iterator i = m_listeners.begin (); i != m_listeners.end (); i++) {
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   808
    (*i)->NotifyRxEndOk ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   809
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   810
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   811
void 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   812
WifiPhy::NotifySyncEndError (void)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   813
{
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
   814
  for (Listeners::const_iterator i = m_listeners.begin (); i != m_listeners.end (); i++) {
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   815
    (*i)->NotifyRxEndError ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   816
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   817
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   818
void 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   819
WifiPhy::NotifyCcaBusyStart (Time duration)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   820
{
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
   821
  for (Listeners::const_iterator i = m_listeners.begin (); i != m_listeners.end (); i++) {
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   822
    (*i)->NotifyCcaBusyStart (duration);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   823
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   824
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   825
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   826
void
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   827
WifiPhy::LogPreviousIdleAndCcaBusyStates (void)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   828
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   829
  Time now = Simulator::Now ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   830
  Time idleStart = Max (m_endCcaBusy, m_endSync);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   831
  idleStart = Max (idleStart, m_endTx);
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   832
  NS_ASSERT (idleStart <= now);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   833
  if (m_endCcaBusy > m_endSync && 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   834
      m_endCcaBusy > m_endTx) {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   835
    Time ccaBusyStart = Max (m_endTx, m_endSync);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   836
    ccaBusyStart = Max (ccaBusyStart, m_startCcaBusy);
2055
8899d6ef5d52 phy state logger
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1999
diff changeset
   837
    m_stateLogger (ccaBusyStart, idleStart - ccaBusyStart, WifiPhy::CCA_BUSY);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   838
  }
2055
8899d6ef5d52 phy state logger
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1999
diff changeset
   839
  m_stateLogger (idleStart, now - idleStart, WifiPhy::IDLE);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   840
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   841
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   842
void
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   843
WifiPhy::SwitchToTx (Time txDuration)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   844
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   845
  Time now = Simulator::Now ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   846
  switch (GetState ()) {
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   847
  case WifiPhy::SYNC:
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   848
    /* The packet which is being received as well
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   849
     * as its endSync event are cancelled by the caller.
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   850
     */
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   851
    m_syncing = false;
2055
8899d6ef5d52 phy state logger
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1999
diff changeset
   852
    m_stateLogger (m_startSync, now - m_startSync, WifiPhy::SYNC);
2356
d43d9f5a22f8 Sync event must be properly canceled upon tx during sync.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2355
diff changeset
   853
    m_endSyncEvent.Cancel ();
d43d9f5a22f8 Sync event must be properly canceled upon tx during sync.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2355
diff changeset
   854
    m_endSync = now;
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   855
    break;
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   856
  case WifiPhy::CCA_BUSY: {
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   857
    Time ccaStart = Max (m_endSync, m_endTx);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   858
    ccaStart = Max (ccaStart, m_startCcaBusy);
2055
8899d6ef5d52 phy state logger
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1999
diff changeset
   859
    m_stateLogger (ccaStart, now - ccaStart, WifiPhy::CCA_BUSY);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   860
  } break;
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   861
  case WifiPhy::IDLE:
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   862
    LogPreviousIdleAndCcaBusyStates ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   863
    break;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   864
  default:
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   865
    NS_ASSERT (false);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   866
    break;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   867
  }
2055
8899d6ef5d52 phy state logger
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1999
diff changeset
   868
  m_stateLogger (now, txDuration, WifiPhy::TX);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   869
  m_previousStateChangeTime = now;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   870
  m_endTx = now + txDuration;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   871
  m_startTx = now;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   872
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   873
void
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   874
WifiPhy::SwitchToSync (Time rxDuration)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   875
{
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   876
  NS_ASSERT (IsStateIdle () || IsStateCcaBusy ());
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   877
  NS_ASSERT (!m_syncing);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   878
  Time now = Simulator::Now ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   879
  switch (GetState ()) {
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   880
  case WifiPhy::IDLE:
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   881
    LogPreviousIdleAndCcaBusyStates ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   882
    break;
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   883
  case WifiPhy::CCA_BUSY: {
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   884
    Time ccaStart = Max (m_endSync, m_endTx);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   885
    ccaStart = Max (ccaStart, m_startCcaBusy);
2055
8899d6ef5d52 phy state logger
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1999
diff changeset
   886
    m_stateLogger (ccaStart, now - ccaStart, WifiPhy::CCA_BUSY);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   887
  } break;
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   888
  case WifiPhy::SYNC:
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   889
  case WifiPhy::TX:
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   890
    NS_ASSERT (false);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   891
    break;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   892
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   893
  m_previousStateChangeTime = now;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   894
  m_syncing = true;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   895
  m_startSync = now;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   896
  m_endSync = now + rxDuration;
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   897
  NS_ASSERT (IsStateSync ());
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   898
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   899
void
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   900
WifiPhy::SwitchFromSync (void)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   901
{
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   902
  NS_ASSERT (IsStateSync ());
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   903
  NS_ASSERT (m_syncing);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   904
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   905
  Time now = Simulator::Now ();
2055
8899d6ef5d52 phy state logger
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1999
diff changeset
   906
  m_stateLogger (m_startSync, now - m_startSync, WifiPhy::SYNC);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   907
  m_previousStateChangeTime = now;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   908
  m_syncing = false;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   909
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   910
  NS_ASSERT (IsStateIdle () || IsStateCcaBusy ());
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   911
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   912
void
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   913
WifiPhy::SwitchMaybeToCcaBusy (Time duration)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   914
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   915
  Time now = Simulator::Now ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   916
  switch (GetState ()) {
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   917
  case WifiPhy::IDLE:
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   918
    LogPreviousIdleAndCcaBusyStates ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   919
  break;
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   920
  case WifiPhy::CCA_BUSY:
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   921
    break;
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   922
  case WifiPhy::SYNC:
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   923
    break;
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   924
  case WifiPhy::TX:
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   925
    break;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   926
  }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   927
  m_startCcaBusy = now;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   928
  m_endCcaBusy = Max (m_endCcaBusy, now + duration);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   929
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   930
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   931
void 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
   932
WifiPhy::AppendEvent (Ptr<RxEvent> event)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   933
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   934
  /* attempt to remove the events which are 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   935
   * not useful anymore. 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   936
   * i.e.: all events which end _before_
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   937
   *       now - m_maxPacketDuration
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   938
   */
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   939
  
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   940
  if (Simulator::Now () > GetMaxPacketDuration ())
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   941
    {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   942
      Time end = Simulator::Now () - GetMaxPacketDuration ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   943
      Events::iterator i = m_events.begin ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   944
      while (i != m_events.end () &&
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   945
             (*i)->GetEndTime () <= end) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   946
        {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   947
          i++;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   948
        }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   949
      m_events.erase (m_events.begin (), i);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   950
    } 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   951
  m_events.push_back (event);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   952
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   953
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   954
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   955
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   956
/**
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   957
 * Stuff specific to the BER model here.
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   958
 */
1892
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   959
double 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   960
WifiPhy::Log2 (double val) const
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   961
{
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   962
  return log(val) / log(2.0);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   963
}
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   964
double 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   965
WifiPhy::GetBpskBer (double snr, uint32_t signalSpread, uint32_t phyRate) const
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   966
{
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   967
  double EbNo = snr * signalSpread / phyRate;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   968
  double z = sqrt(EbNo);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   969
  double ber = 0.5 * erfc(z);
2150
e4aff46fe6c5 add some info logs, improve snr vs ber curve output, linearize the ber calculations.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2139
diff changeset
   970
  NS_LOG_INFO ("bpsk snr="<<snr<<" ber="<<ber);
1892
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   971
  return ber;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   972
}
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   973
double 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   974
WifiPhy::GetQamBer (double snr, unsigned int m, uint32_t signalSpread, uint32_t phyRate) const
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   975
{
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   976
  double EbNo = snr * signalSpread / phyRate;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   977
  double z = sqrt ((1.5 * Log2 (m) * EbNo) / (m - 1.0));
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   978
  double z1 = ((1.0 - 1.0 / sqrt (m)) * erfc (z)) ;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   979
  double z2 = 1 - pow ((1-z1), 2.0);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   980
  double ber = z2 / Log2 (m);
2150
e4aff46fe6c5 add some info logs, improve snr vs ber curve output, linearize the ber calculations.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2139
diff changeset
   981
  NS_LOG_INFO ("Qam m="<<m<<" rate=" << phyRate << " snr="<<snr<<" ber="<<ber);
1892
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   982
  return ber;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   983
}
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   984
uint32_t
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   985
WifiPhy::Factorial (uint32_t k) const
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   986
{
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   987
  uint32_t fact = 1;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   988
  while (k > 0) 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   989
    {
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   990
      fact *= k;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   991
      k--;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   992
    }
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   993
  return fact;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   994
}
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   995
double 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   996
WifiPhy::Binomial (uint32_t k, double p, uint32_t n) const
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   997
{
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   998
  double retval = Factorial (n) / (Factorial (k) * Factorial (n-k)) * pow (p, k) * pow (1-p, n-k);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
   999
  return retval;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1000
}
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1001
double 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1002
WifiPhy::CalculatePdOdd (double ber, unsigned int d) const
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1003
{
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1004
  NS_ASSERT ((d % 2) == 1);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1005
  unsigned int dstart = (d + 1) / 2;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1006
  unsigned int dend = d;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1007
  double pd = 0;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1008
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1009
  for (unsigned int i = dstart; i < dend; i++) 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1010
    {
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1011
      pd += Binomial (i, ber, d);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1012
    }
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1013
  return pd;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1014
}
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1015
double 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1016
WifiPhy::CalculatePdEven (double ber, unsigned int d) const
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1017
{
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1018
  NS_ASSERT ((d % 2) == 0);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1019
  unsigned int dstart = d / 2 + 1;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1020
  unsigned int dend = d;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1021
  double pd = 0;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1022
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1023
  for (unsigned int i = dstart; i < dend; i++)
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1024
    {
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1025
      pd +=  Binomial (i, ber, d);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1026
    }
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1027
  pd += 0.5 * Binomial (d / 2, ber, d);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1028
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1029
  return pd;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1030
}
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1031
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1032
double 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1033
WifiPhy::CalculatePd (double ber, unsigned int d) const
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1034
{
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1035
  double pd;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1036
  if ((d % 2) == 0) 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1037
    {
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1038
      pd = CalculatePdEven (ber, d);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1039
    } 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1040
  else 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1041
    {
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1042
      pd = CalculatePdOdd (ber, d);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1043
    }
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1044
  return pd;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1045
}
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1046
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1047
double
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1048
WifiPhy::GetFecBpskBer (double snr, double nbits, 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1049
                         uint32_t signalSpread, uint32_t phyRate,
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1050
                         uint32_t dFree, uint32_t adFree) const
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1051
{
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1052
  double ber = GetBpskBer (snr, signalSpread, phyRate);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1053
  if (ber == 0.0) 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1054
    {
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1055
      return 1.0;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1056
    }
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1057
  double pd = CalculatePd (ber, dFree);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1058
  double pmu = adFree * pd;
2150
e4aff46fe6c5 add some info logs, improve snr vs ber curve output, linearize the ber calculations.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2139
diff changeset
  1059
  pmu = std::min (pmu, 1.0);
1892
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1060
  double pms = pow (1 - pmu, nbits);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1061
  return pms;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1062
}
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1063
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1064
double
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1065
WifiPhy::GetFecQamBer (double snr, uint32_t nbits, 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1066
                       uint32_t signalSpread,
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1067
                       uint32_t phyRate,
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1068
                       uint32_t m, uint32_t dFree,
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1069
                       uint32_t adFree, uint32_t adFreePlusOne) const
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1070
{
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1071
  double ber = GetQamBer (snr, m, signalSpread, phyRate);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1072
  if (ber == 0.0) 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1073
    {
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1074
      return 1.0;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1075
    }
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1076
  /* first term */
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1077
  double pd = CalculatePd (ber, dFree);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1078
  double pmu = adFree * pd;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1079
  /* second term */
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1080
  pd = CalculatePd (ber, dFree + 1);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1081
  pmu += adFreePlusOne * pd;
2150
e4aff46fe6c5 add some info logs, improve snr vs ber curve output, linearize the ber calculations.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2139
diff changeset
  1082
  pmu = std::min (pmu, 1.0);
1892
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1083
  double pms = pow (1 - pmu, nbits);
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1084
  return pms;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1085
}
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1086
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1087
double 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1088
WifiPhy::GetChunkSuccessRate (WifiMode mode, double snr, uint32_t nbits) const
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1089
{
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1090
  if (mode.GetUid () == g_6mba.GetUid ())
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1091
    {
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1092
      return GetFecBpskBer (snr, 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1093
                            nbits,
2355
79b65c32b16f Use the physical rate where needed.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2173
diff changeset
  1094
                            mode.GetBandwidth (), // signal spread
79b65c32b16f Use the physical rate where needed.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2173
diff changeset
  1095
                            mode.GetPhyRate (), // phy rate
1892
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1096
                            10, // dFree
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1097
                            11 // adFree
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1098
                            );      
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1099
    }
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1100
  else if (mode.GetUid () == g_9mba.GetUid ())
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1101
    {
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1102
      return GetFecBpskBer (snr, 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1103
                            nbits,
2355
79b65c32b16f Use the physical rate where needed.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2173
diff changeset
  1104
                            mode.GetBandwidth (), // signal spread
79b65c32b16f Use the physical rate where needed.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2173
diff changeset
  1105
                            mode.GetPhyRate (), // phy rate
1892
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1106
                            5, // dFree
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1107
                            8 // adFree
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1108
                            );
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1109
    }
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1110
  else if (mode.GetUid () == g_12mba.GetUid ())
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1111
    {
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1112
      return GetFecQamBer (snr, 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1113
                           nbits,
2355
79b65c32b16f Use the physical rate where needed.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2173
diff changeset
  1114
                           mode.GetBandwidth (), // signal spread
79b65c32b16f Use the physical rate where needed.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2173
diff changeset
  1115
                           mode.GetPhyRate (), // phy rate
1892
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1116
                           4,  // m 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1117
                           10, // dFree
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1118
                           11, // adFree
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1119
                           0   // adFreePlusOne
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1120
                           );
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1121
    }
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1122
  else if (mode.GetUid () == g_18mba.GetUid ())
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1123
    {
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1124
      return GetFecQamBer (snr, 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1125
                           nbits,
2355
79b65c32b16f Use the physical rate where needed.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2173
diff changeset
  1126
                           mode.GetBandwidth (), // signal spread
79b65c32b16f Use the physical rate where needed.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2173
diff changeset
  1127
                           mode.GetPhyRate (), // phy rate
1892
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1128
                           4, // m
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1129
                           5, // dFree
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1130
                           8, // adFree
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1131
                           31 // adFreePlusOne
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1132
                           );
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1133
    }
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1134
  else if (mode.GetUid () == g_24mba.GetUid ())
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1135
    {
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1136
      return GetFecQamBer (snr, 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1137
                           nbits,
2355
79b65c32b16f Use the physical rate where needed.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2173
diff changeset
  1138
                           mode.GetBandwidth (), // signal spread
79b65c32b16f Use the physical rate where needed.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2173
diff changeset
  1139
                           mode.GetPhyRate (), // phy rate
1892
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1140
                           16, // m
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1141
                           10, // dFree
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1142
                           11, // adFree
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1143
                           0   // adFreePlusOne
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1144
                           );
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1145
    }
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1146
  else if (mode.GetUid () == g_36mba.GetUid ())
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1147
    {
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1148
      return GetFecQamBer (snr, 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1149
                           nbits,
2355
79b65c32b16f Use the physical rate where needed.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2173
diff changeset
  1150
                           mode.GetBandwidth (), // signal spread
79b65c32b16f Use the physical rate where needed.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2173
diff changeset
  1151
                           mode.GetPhyRate (), // phy rate
1892
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1152
                           16, // m
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1153
                           5,  // dFree
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1154
                           8,  // adFree
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1155
                           31  // adFreePlusOne
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1156
                           );
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1157
    }
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1158
  else if (mode.GetUid () == g_48mba.GetUid ())
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1159
    {
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1160
      return GetFecQamBer (snr, 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1161
                           nbits,
2355
79b65c32b16f Use the physical rate where needed.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2173
diff changeset
  1162
                           mode.GetBandwidth (), // signal spread
79b65c32b16f Use the physical rate where needed.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2173
diff changeset
  1163
                           mode.GetPhyRate (), // phy rate
1892
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1164
                           64, // m
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1165
                           6,  // dFree
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1166
                           1,  // adFree
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1167
                           16  // adFreePlusOne
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1168
                           );
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1169
    }
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1170
  else if (mode.GetUid () == g_54mba.GetUid ())
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1171
    {
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1172
      return GetFecQamBer (snr, 
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1173
                           nbits,
2355
79b65c32b16f Use the physical rate where needed.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2173
diff changeset
  1174
                           mode.GetBandwidth (), // signal spread
79b65c32b16f Use the physical rate where needed.
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2173
diff changeset
  1175
                           mode.GetPhyRate (), // phy rate
1892
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1176
                           64, // m
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1177
                           5,  // dFree
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1178
                           8,  // adFree
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1179
                           31  // adFreePlusOne
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1180
                           );
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1181
    }
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1182
  return 0;
7833628614bf implement WifiPhy::GetChunkSuccessRate
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1891
diff changeset
  1183
}
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1184
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1185
double
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
  1186
WifiPhy::CalculateSnr (double signal, double noiseInterference, WifiMode mode) const
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1187
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1188
  // thermal noise at 290K in J/s = W
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1189
  static const double BOLTZMANN = 1.3803e-23;
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
  1190
  double Nt = BOLTZMANN * 290.0 * mode.GetBandwidth ();
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1191
  // receiver noise Floor (W)
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1192
  double noiseFloor = m_rxNoiseRatio * Nt;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1193
  double noise = noiseFloor + noiseInterference;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1194
  double snr = signal / noise;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1195
  return snr;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1196
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1197
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1198
double
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
  1199
WifiPhy::CalculateNoiseInterferenceW (Ptr<RxEvent> event, NiChanges *ni) const
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1200
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1201
  Events::const_iterator i = m_events.begin ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1202
  double noiseInterference = 0.0;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1203
  while (i != m_events.end ()) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1204
    {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1205
      if (event == (*i)) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1206
        {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1207
          i++;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1208
          continue;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1209
        }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1210
      if (event->Overlaps ((*i)->GetStartTime ())) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1211
        {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1212
          ni->push_back (NiChange ((*i)->GetStartTime (), (*i)->GetRxPowerW ()));
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1213
        }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1214
      if (event->Overlaps ((*i)->GetEndTime ())) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1215
        {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1216
          ni->push_back (NiChange ((*i)->GetEndTime (), -(*i)->GetRxPowerW ()));
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1217
        }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1218
      if ((*i)->Overlaps (event->GetStartTime ())) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1219
        {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1220
          noiseInterference += (*i)->GetRxPowerW ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1221
        }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1222
      i++;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1223
    }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1224
  ni->push_back (NiChange (event->GetStartTime (), noiseInterference));
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1225
  ni->push_back (NiChange (event->GetEndTime (), 0));
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1226
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1227
  /* quicksort vector of NI changes by time. */
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1228
  std::sort (ni->begin (), ni->end (), std::less<NiChange> ());
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1229
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1230
  return noiseInterference;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1231
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1232
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1233
double
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
  1234
WifiPhy::CalculateChunkSuccessRate (double snir, Time duration, WifiMode mode) const
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1235
{
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1236
  if (duration == NanoSeconds (0)) {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1237
    return 1.0;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1238
  }
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
  1239
  uint32_t rate = mode.GetPhyRate ();
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1240
  uint64_t nbits = (uint64_t)(rate * duration.GetSeconds ());
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
  1241
  double csr = GetChunkSuccessRate (mode, snir, (uint32_t)nbits);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1242
  return csr;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1243
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1244
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1245
double 
1890
a2b30c6456c9 Phy80211 -> WifiPhy
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1889
diff changeset
  1246
WifiPhy::CalculatePer (Ptr<const RxEvent> event, NiChanges *ni) const
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1247
{  
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1248
  double psr = 1.0; /* Packet Success Rate */
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
  1249
  NiChanges::iterator j = ni->begin ();
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1250
  Time previous = (*j).GetTime ();
1920
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
  1251
  uint64_t plcpPreambleDelayUs;
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
  1252
  WifiMode payloadMode = event->GetPayloadMode ();
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
  1253
  WifiMode headerMode;
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
  1254
  switch (event->GetPreambleType ()) {
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
  1255
  case WIFI_PREAMBLE_LONG:
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
  1256
    plcpPreambleDelayUs = m_plcpLongPreambleDelayUs;
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
  1257
    headerMode = m_longPlcpHeaderMode;
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
  1258
    break;
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
  1259
  case WIFI_PREAMBLE_SHORT:
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
  1260
    plcpPreambleDelayUs = m_plcpShortPreambleDelayUs;
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
  1261
    headerMode = m_shortPlcpHeaderMode;
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
  1262
    break;
2077
8ff95ff1ed2e fix optimized builds
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2071
diff changeset
  1263
  default:
8ff95ff1ed2e fix optimized builds
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2071
diff changeset
  1264
    NS_ASSERT (false);
8ff95ff1ed2e fix optimized builds
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2071
diff changeset
  1265
    // only to quiet compiler. Really stupid.
8ff95ff1ed2e fix optimized builds
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2071
diff changeset
  1266
    plcpPreambleDelayUs = 0;
8ff95ff1ed2e fix optimized builds
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2071
diff changeset
  1267
    headerMode = m_shortPlcpHeaderMode;
8ff95ff1ed2e fix optimized builds
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2071
diff changeset
  1268
    break;
1920
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
  1269
  }
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
  1270
  Time plcpHeaderStart = (*j).GetTime () + MicroSeconds (plcpPreambleDelayUs);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1271
  Time plcpPayloadStart = plcpHeaderStart + 
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2503
diff changeset
  1272
    Seconds ((m_plcpHeaderLength + 0.0) / headerMode.GetDataRate ());
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1273
  double noiseInterferenceW = (*j).GetDelta ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1274
  double powerW = event->GetRxPowerW ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1275
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1276
  j++;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1277
  while (ni->end () != j) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1278
    {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1279
      Time current = (*j).GetTime ();
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
  1280
      NS_ASSERT (current >= previous);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1281
    
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1282
      if (previous >= plcpPayloadStart) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1283
        {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1284
          psr *= CalculateChunkSuccessRate (CalculateSnr (powerW, 
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
  1285
                                                          noiseInterferenceW, 
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
  1286
                                                          payloadMode), 
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1287
                                            current - previous,
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1288
                                            payloadMode);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1289
        } 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1290
      else if (previous >= plcpHeaderStart) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1291
        {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1292
          if (current >= plcpPayloadStart) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1293
            {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1294
              psr *= CalculateChunkSuccessRate (CalculateSnr (powerW, 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1295
                                                              noiseInterferenceW, 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1296
                                                              headerMode), 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1297
                                                plcpPayloadStart - previous,
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1298
                                                headerMode);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1299
              psr *= CalculateChunkSuccessRate (CalculateSnr (powerW, 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1300
                                                              noiseInterferenceW, 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1301
                                                              payloadMode),
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1302
                                                current - plcpPayloadStart,
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1303
                                                payloadMode);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1304
            } 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1305
          else 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1306
            {
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
  1307
              NS_ASSERT (current >= plcpHeaderStart);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1308
              psr *= CalculateChunkSuccessRate (CalculateSnr (powerW, 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1309
                                                              noiseInterferenceW, 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1310
                                                              headerMode), 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1311
                                                current - previous,
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1312
                                                headerMode);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1313
            }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1314
        } 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1315
      else 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1316
        {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1317
          if (current >= plcpPayloadStart) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1318
            {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1319
              psr *= CalculateChunkSuccessRate (CalculateSnr (powerW, 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1320
                                                              noiseInterferenceW, 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1321
                                                              headerMode), 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1322
                                                plcpPayloadStart - plcpHeaderStart,
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1323
                                                headerMode);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1324
              psr *= CalculateChunkSuccessRate (CalculateSnr (powerW, 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1325
                                                              noiseInterferenceW, 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1326
                                                              payloadMode), 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1327
                                                current - plcpPayloadStart,
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1328
                                                payloadMode);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1329
            } 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1330
          else if (current >= plcpHeaderStart) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1331
            {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1332
              psr *= CalculateChunkSuccessRate (CalculateSnr (powerW, 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1333
                                                              noiseInterferenceW, 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1334
                                                              headerMode), 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1335
                                                current - plcpHeaderStart,
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1336
                                                headerMode);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1337
            }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1338
        }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1339
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1340
      noiseInterferenceW += (*j).GetDelta ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1341
      previous = (*j).GetTime ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1342
      j++;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1343
    }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1344
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1345
  double per = 1 - psr;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1346
  return per;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1347
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1348
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1349
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1350
void
2159
20f882e85b4a port to Ptr<Packet> branch
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2155
diff changeset
  1351
WifiPhy::EndSync (Ptr<Packet> packet, Ptr<RxEvent> event)
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1352
{
2985
fa0747c4ad5e use function logging macros
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2782
diff changeset
  1353
  NS_LOG_FUNCTION (this << packet << event);
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
  1354
  NS_ASSERT (IsStateSync ());
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
  1355
  NS_ASSERT (event->GetEndTime () == Simulator::Now ());
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1356
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1357
  NiChanges ni;
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1358
  double noiseInterferenceW = CalculateNoiseInterferenceW (event, &ni);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1359
  double snr = CalculateSnr (event->GetRxPowerW (),
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1360
                             noiseInterferenceW,
1891
add6fb8761f3 use WifiMode rather than TransmissionMode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1890
diff changeset
  1361
                             event->GetPayloadMode ());
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1362
  
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1363
  /* calculate the SNIR at the start of the packet and accumulate
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1364
   * all SNIR changes in the snir vector.
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1365
   */
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1366
  double per = CalculatePer (event, &ni);
2164
6e347fdbfa4a avoid confusion between code and uncoded rates.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2159
diff changeset
  1367
  NS_LOG_DEBUG ("mode="<<(event->GetPayloadMode ().GetDataRate ())<<
1979
d535a38b7fc4 convert TRACE to NS_LOG
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1978
diff changeset
  1368
                ", ber="<<(1-GetChunkSuccessRate (event->GetPayloadMode (), snr, 1))<<
2159
20f882e85b4a port to Ptr<Packet> branch
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2155
diff changeset
  1369
                ", snr="<<snr<<", per="<<per<<", size="<<packet->GetSize ());
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1370
  
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1371
  if (m_random.GetValue () > per) 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1372
    {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1373
      NotifySyncEndOk ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1374
      SwitchFromSync ();
2659
38f50c9d55f4 make sure the trace hooks get a full packet as input.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2652
diff changeset
  1375
      m_rxOkTrace (packet, snr, event->GetPayloadMode (), event->GetPreambleType ());
1920
1d4864775cf8 replace header mode with preamble mode
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1919
diff changeset
  1376
      m_syncOkCallback (packet, snr, event->GetPayloadMode (), event->GetPreambleType ());
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1377
    } 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1378
  else 
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1379
    {
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1380
      /* failure. */
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1381
      NotifySyncEndError ();
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1382
      SwitchFromSync ();
2659
38f50c9d55f4 make sure the trace hooks get a full packet as input.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2652
diff changeset
  1383
      m_rxErrorTrace (packet, snr);
1889
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1384
      m_syncErrorCallback (packet, snr);
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1385
    }
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1386
}
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1387
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1388
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1389
41589561e4a7 WifiPhy class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
  1390
1977
4303409f3d8e remove uneeded trailing ';'
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1974
diff changeset
  1391
} // namespace ns3