src/devices/wifi/onoe-wifi-manager.cc
author Federico Maguolo <maguolof@dei.unipd.it>
Fri, 28 Mar 2008 12:14:02 -0700
changeset 2784 49006cbbfac7
parent 2624 17172ab64e3f
child 2965 4b28e9740e3b
permissions -rw-r--r--
GetMaxSsrc -> NeedRtsTransmission and GetMaxSlrc -> NeedDataRetransmission
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     1
/* -*-  Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     2
/*
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     3
 * Copyright (c) 2003,2007 INRIA
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     4
 *
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     6
 * it under the terms of the GNU General Public License version 2 as 
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     7
 * published by the Free Software Foundation;
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     8
 *
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    12
 * GNU General Public License for more details.
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    13
 *
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    14
 * You should have received a copy of the GNU General Public License
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    15
 * along with this program; if not, write to the Free Software
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    16
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    17
 *
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    18
 * Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    19
 */
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    20
2544
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    21
#include "onoe-wifi-manager.h"
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    22
#include "ns3/simulator.h"
2272
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
    23
#include "ns3/log.h"
2544
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    24
#include "ns3/uinteger.h"
2272
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
    25
2544
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    26
NS_LOG_COMPONENT_DEFINE ("OnoeWifiRemoteStation");
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    27
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    28
namespace ns3 {
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    29
2624
17172ab64e3f get the typename right. make sure the object is registered with our type system.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2544
diff changeset
    30
NS_OBJECT_ENSURE_REGISTERED (OnoeWifiManager);
17172ab64e3f get the typename right. make sure the object is registered with our type system.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2544
diff changeset
    31
2544
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    32
TypeId
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    33
OnoeWifiManager::GetTypeId (void)
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    34
{
2624
17172ab64e3f get the typename right. make sure the object is registered with our type system.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2544
diff changeset
    35
  static TypeId tid = TypeId ("ns3::OnoeWifiManager")
2544
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    36
    .SetParent<WifiRemoteStationManager> ()
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    37
    .AddConstructor<OnoeWifiManager> ()
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    38
    .AddAttribute ("UpdatePeriod",
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    39
                   "The interval between decisions about rate control changes",
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    40
                   Seconds (1.0),
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    41
                   MakeTimeAccessor (&OnoeWifiManager::m_updatePeriod),
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    42
                   MakeTimeChecker ())
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    43
    .AddAttribute ("RaiseThreshold", "XXX",
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    44
                   Uinteger (10),
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    45
                   MakeUintegerAccessor (&OnoeWifiManager::m_raiseThreshold),
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    46
                   MakeUintegerChecker<uint32_t> ())
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    47
    .AddAttribute ("AddCreditThreshold", "Add credit threshold",
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    48
                   Uinteger (10),
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    49
                   MakeUintegerAccessor (&OnoeWifiManager::m_addCreditThreshold),
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    50
                   MakeUintegerChecker<uint32_t> ())
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    51
    ;
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    52
  return tid;
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    53
}
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    54
2544
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    55
OnoeWifiManager::OnoeWifiManager ()
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    56
{}
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    57
WifiRemoteStation *
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    58
OnoeWifiManager::CreateStation (void)
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    59
{
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    60
  return new OnoeWifiRemoteStation (this);
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    61
}
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    62
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    63
OnoeWifiRemoteStation::OnoeWifiRemoteStation (Ptr<OnoeWifiManager> stations)
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    64
  : m_stations (stations),
2272
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
    65
    m_nextModeUpdate (Simulator::Now () + stations->m_updatePeriod),
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
    66
    m_shortRetry (0),
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
    67
    m_longRetry (0),
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
    68
    m_tx_ok (0),
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
    69
    m_tx_err (0),
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
    70
    m_tx_retr (0),
2277
51c66e7993c0 avoid uninitialized variables.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2272
diff changeset
    71
    m_tx_upper (0),
51c66e7993c0 avoid uninitialized variables.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2272
diff changeset
    72
    m_txrate (0)
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    73
{}
2544
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
    74
OnoeWifiRemoteStation::~OnoeWifiRemoteStation ()
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    75
{}
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    76
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    77
void 
2784
49006cbbfac7 GetMaxSsrc -> NeedRtsTransmission and GetMaxSlrc -> NeedDataRetransmission
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2624
diff changeset
    78
OnoeWifiRemoteStation::DoReportRxOk (double rxSnr, WifiMode txMode)
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    79
{}
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    80
void 
2784
49006cbbfac7 GetMaxSsrc -> NeedRtsTransmission and GetMaxSlrc -> NeedDataRetransmission
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2624
diff changeset
    81
OnoeWifiRemoteStation::DoReportRtsFailed (void)
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    82
{
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    83
  m_shortRetry++;
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    84
}
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    85
void 
2784
49006cbbfac7 GetMaxSsrc -> NeedRtsTransmission and GetMaxSlrc -> NeedDataRetransmission
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2624
diff changeset
    86
OnoeWifiRemoteStation::DoReportDataFailed (void)
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    87
{
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    88
  m_longRetry++;
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    89
}
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    90
void 
2784
49006cbbfac7 GetMaxSsrc -> NeedRtsTransmission and GetMaxSlrc -> NeedDataRetransmission
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2624
diff changeset
    91
OnoeWifiRemoteStation::DoReportRtsOk (double ctsSnr, WifiMode ctsMode, double rtsSnr)
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    92
{}
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    93
void 
2784
49006cbbfac7 GetMaxSsrc -> NeedRtsTransmission and GetMaxSlrc -> NeedDataRetransmission
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2624
diff changeset
    94
OnoeWifiRemoteStation::DoReportDataOk (double ackSnr, WifiMode ackMode, double dataSnr)
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    95
{
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    96
  UpdateRetry ();
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    97
  m_tx_ok++;
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    98
}
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    99
void 
2784
49006cbbfac7 GetMaxSsrc -> NeedRtsTransmission and GetMaxSlrc -> NeedDataRetransmission
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2624
diff changeset
   100
OnoeWifiRemoteStation::DoReportFinalRtsFailed (void)
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   101
{
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   102
  UpdateRetry ();
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   103
  m_tx_err++;
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   104
}
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   105
void 
2784
49006cbbfac7 GetMaxSsrc -> NeedRtsTransmission and GetMaxSlrc -> NeedDataRetransmission
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2624
diff changeset
   106
OnoeWifiRemoteStation::DoReportFinalDataFailed (void)
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   107
{
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   108
  UpdateRetry ();
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   109
  m_tx_err++;
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   110
}
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   111
void
2544
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
   112
OnoeWifiRemoteStation::UpdateRetry (void)
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   113
{
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   114
  m_tx_retr += m_shortRetry + m_longRetry;
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   115
  m_shortRetry = 0;
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   116
  m_longRetry = 0;
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   117
}
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   118
void
2544
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
   119
OnoeWifiRemoteStation::UpdateMode (void)
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   120
{
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   121
  if (Simulator::Now () < m_nextModeUpdate)
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   122
    {
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   123
      return;
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   124
    }
2277
51c66e7993c0 avoid uninitialized variables.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2272
diff changeset
   125
  m_nextModeUpdate = Simulator::Now () + m_stations->m_updatePeriod;
2272
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   126
  /**
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   127
   * The following 20 lines of code were copied from the Onoe
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   128
   * rate control kernel module used in the madwifi driver.
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   129
   */
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   130
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   131
  int dir = 0, enough;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   132
  uint32_t nrate;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   133
  enough = (m_tx_ok + m_tx_err >= 10);
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   134
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   135
  /* no packet reached -> down */
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   136
  if (m_tx_err > 0 && m_tx_ok == 0)
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   137
    dir = -1;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   138
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   139
  /* all packets needs retry in average -> down */
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   140
  if (enough && m_tx_ok < m_tx_retr)
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   141
    dir = -1;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   142
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   143
  /* no error and less than rate_raise% of packets need retry -> up */
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   144
  if (enough && m_tx_err == 0 &&
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   145
      m_tx_retr < (m_tx_ok * m_stations->m_addCreditThreshold) / 100)
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   146
    dir = 1;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   147
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   148
  NS_LOG_DEBUG (this << " ok " << m_tx_ok << " err " << m_tx_err << " retr " << m_tx_retr <<
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   149
                " upper " << m_tx_upper << " dir " << dir);
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   150
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   151
  nrate = m_txrate;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   152
  switch (dir) {
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   153
  case 0:
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   154
    if (enough && m_tx_upper > 0)
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   155
      m_tx_upper--;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   156
    break;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   157
  case -1:
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   158
    if (nrate > 0) {
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   159
      nrate--;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   160
    }
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   161
    m_tx_upper = 0;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   162
    break;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   163
  case 1:
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   164
    /* raise rate if we hit rate_raise_threshold */
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   165
    if (++m_tx_upper < m_stations->m_raiseThreshold)
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   166
      break;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   167
    m_tx_upper = 0;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   168
    if (nrate + 1 < GetNSupportedModes ()) {
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   169
      nrate++;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   170
    }
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   171
    break;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   172
  }
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   173
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   174
  if (nrate != m_txrate) {
2277
51c66e7993c0 avoid uninitialized variables.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2272
diff changeset
   175
    NS_ASSERT (nrate < GetNSupportedModes ());
2272
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   176
    m_txrate = nrate;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   177
    m_tx_ok = m_tx_err = m_tx_retr = m_tx_upper = 0;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   178
  } else if (enough)
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   179
    m_tx_ok = m_tx_err = m_tx_retr = 0;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   180
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   181
}
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   182
2544
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
   183
Ptr<WifiRemoteStationManager>
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
   184
OnoeWifiRemoteStation::GetManager (void) const
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   185
{
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   186
  return m_stations;
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   187
}
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   188
WifiMode 
2544
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
   189
OnoeWifiRemoteStation::DoGetDataMode (uint32_t size)
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   190
{
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   191
  UpdateMode ();
2272
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   192
  NS_ASSERT (m_txrate < GetNSupportedModes ());
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   193
  uint32_t rateIndex;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   194
  if (m_longRetry < 4)
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   195
    {
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   196
      rateIndex = m_txrate;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   197
    }
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   198
  else if (m_longRetry < 6)
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   199
    {
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   200
      if (m_txrate > 0)
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   201
        {
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   202
          rateIndex = m_txrate - 1;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   203
        }
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   204
      else
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   205
        {
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   206
          rateIndex = m_txrate;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   207
        }
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   208
    }
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   209
  else if (m_longRetry < 8)
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   210
    {
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   211
      if (m_txrate > 1)
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   212
        {
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   213
          rateIndex = m_txrate - 2;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   214
        }
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   215
      else
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   216
        {
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   217
          rateIndex = m_txrate;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   218
        }
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   219
    }
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   220
  else
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   221
    {
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   222
      if (m_txrate > 2)
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   223
        {
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   224
          rateIndex = m_txrate - 3;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   225
        }
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   226
      else
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   227
        {
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   228
          rateIndex = m_txrate;
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   229
        }
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   230
    }
ae2bbdbfc161 the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2271
diff changeset
   231
  return GetSupportedMode (rateIndex);
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   232
}
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   233
WifiMode 
2544
2e6e1a6e0d94 port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2277
diff changeset
   234
OnoeWifiRemoteStation::DoGetRtsMode (void)
2271
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   235
{
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   236
  UpdateMode ();
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   237
  // XXX: can we implement something smarter ?
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   238
  return GetSupportedMode (0);
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   239
}
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   240
85724b1cbb1a Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   241
} // namespace ns3