A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
aarfcd-wifi-manager.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2005,2006 INRIA
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation;
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program; if not, write to the Free Software
15 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 *
17 * Author: Federico Maguolo <maguolof@dei.unipd.it>
18 */
19
20#ifndef AARFCD_WIFI_MANAGER_H
21#define AARFCD_WIFI_MANAGER_H
22
23#include "ns3/traced-value.h"
24#include "ns3/wifi-remote-station-manager.h"
25
26namespace ns3
27{
28
29struct AarfcdWifiRemoteStation;
30
31/**
32 * \brief an implementation of the AARF-CD algorithm
33 * \ingroup wifi
34 *
35 * This algorithm was first described in "Efficient Collision Detection for Auto Rate Fallback
36 * Algorithm". The implementation available here was done by Federico Maguolo for a very early
37 * development version of ns-3. Federico died before merging this work in ns-3 itself so his code
38 * was ported to ns-3 later without his supervision.
39 *
40 * This RAA does not support HT modes and will error
41 * exit if the user tries to configure this RAA with a Wi-Fi MAC
42 * that supports 802.11n or higher.
43 */
45{
46 public:
47 /**
48 * \brief Get the type ID.
49 * \return the object TypeId
50 */
51 static TypeId GetTypeId();
53 ~AarfcdWifiManager() override;
54
55 private:
56 void DoInitialize() override;
57 WifiRemoteStation* DoCreateStation() const override;
58 void DoReportRxOk(WifiRemoteStation* station, double rxSnr, WifiMode txMode) override;
59
60 void DoReportRtsFailed(WifiRemoteStation* station) override;
61 /**
62 * It is important to realize that "recovery" mode starts after failure of
63 * the first transmission after a rate increase and ends at the first successful
64 * transmission. Specifically, recovery mode transcends retransmissions boundaries.
65 * Fundamentally, ARF handles each data transmission independently, whether it
66 * is the initial transmission of a packet or the retransmission of a packet.
67 * The fundamental reason for this is that there is a backoff between each data
68 * transmission, be it an initial transmission or a retransmission.
69 *
70 * \param station the station that we failed to send Data
71 */
72 void DoReportDataFailed(WifiRemoteStation* station) override;
73 void DoReportRtsOk(WifiRemoteStation* station,
74 double ctsSnr,
75 WifiMode ctsMode,
76 double rtsSnr) override;
78 double ackSnr,
79 WifiMode ackMode,
80 double dataSnr,
81 uint16_t dataChannelWidth,
82 uint8_t dataNss) override;
83 void DoReportFinalRtsFailed(WifiRemoteStation* station) override;
84 void DoReportFinalDataFailed(WifiRemoteStation* station) override;
85 WifiTxVector DoGetDataTxVector(WifiRemoteStation* station, uint16_t allowedWidth) override;
87 bool DoNeedRts(WifiRemoteStation* station, uint32_t size, bool normally) override;
88
89 /**
90 * Check if the use of RTS for the given station can be turned off.
91 *
92 * \param station the station that we are checking
93 */
94 void CheckRts(AarfcdWifiRemoteStation* station);
95 /**
96 * Increase the RTS window size of the given station.
97 *
98 * \param station the station to increase RTS window
99 */
101 /**
102 * Reset the RTS window of the given station.
103 *
104 * \param station the station to reset RTS window
105 */
107 /**
108 * Turn off RTS for the given station.
109 *
110 * \param station the station to turn RTS off
111 */
112 void TurnOffRts(AarfcdWifiRemoteStation* station);
113 /**
114 * Turn on RTS for the given station.
115 *
116 * \param station the station to turn RTS on
117 */
118 void TurnOnRts(AarfcdWifiRemoteStation* station);
119
120 // AARF fields below
121 uint32_t m_minTimerThreshold; ///< minimum timer threshold
122 uint32_t m_minSuccessThreshold; ///< minimum success threshold
123 double m_successK; ///< Multiplication factor for the success threshold
124 uint32_t m_maxSuccessThreshold; ///< maximum success threshold
125 double m_timerK; ///< Multiplication factor for the timer threshold
126
127 // AARF-CD fields below
128 uint32_t m_minRtsWnd; ///< minimum RTS window
129 uint32_t m_maxRtsWnd; ///< maximum RTS window
130 bool m_turnOffRtsAfterRateDecrease; ///< turn off RTS after rate decrease
131 bool m_turnOnRtsAfterRateIncrease; ///< turn on RTS after rate increase
132
133 TracedValue<uint64_t> m_currentRate; //!< Trace rate changes
134};
135
136} // namespace ns3
137
138#endif /* AARFCD_WIFI_MANAGER_H */
an implementation of the AARF-CD algorithm
void ResetRtsWnd(AarfcdWifiRemoteStation *station)
Reset the RTS window of the given station.
bool m_turnOnRtsAfterRateIncrease
turn on RTS after rate increase
double m_timerK
Multiplication factor for the timer threshold.
TracedValue< uint64_t > m_currentRate
Trace rate changes.
uint32_t m_maxSuccessThreshold
maximum success threshold
bool DoNeedRts(WifiRemoteStation *station, uint32_t size, bool normally) override
WifiRemoteStation * DoCreateStation() const override
uint32_t m_minTimerThreshold
minimum timer threshold
uint32_t m_minSuccessThreshold
minimum success threshold
uint32_t m_minRtsWnd
minimum RTS window
bool m_turnOffRtsAfterRateDecrease
turn off RTS after rate decrease
uint32_t m_maxRtsWnd
maximum RTS window
void TurnOffRts(AarfcdWifiRemoteStation *station)
Turn off RTS for the given station.
double m_successK
Multiplication factor for the success threshold.
void DoInitialize() override
Initialize() implementation.
void TurnOnRts(AarfcdWifiRemoteStation *station)
Turn on RTS for the given station.
void DoReportFinalDataFailed(WifiRemoteStation *station) override
This method is a pure virtual method that must be implemented by the sub-class.
WifiTxVector DoGetRtsTxVector(WifiRemoteStation *station) override
void DoReportRxOk(WifiRemoteStation *station, double rxSnr, WifiMode txMode) override
This method is a pure virtual method that must be implemented by the sub-class.
void DoReportDataFailed(WifiRemoteStation *station) override
It is important to realize that "recovery" mode starts after failure of the first transmission after ...
WifiTxVector DoGetDataTxVector(WifiRemoteStation *station, uint16_t allowedWidth) override
static TypeId GetTypeId()
Get the type ID.
void DoReportRtsFailed(WifiRemoteStation *station) override
This method is a pure virtual method that must be implemented by the sub-class.
void DoReportRtsOk(WifiRemoteStation *station, double ctsSnr, WifiMode ctsMode, double rtsSnr) override
This method is a pure virtual method that must be implemented by the sub-class.
void CheckRts(AarfcdWifiRemoteStation *station)
Check if the use of RTS for the given station can be turned off.
void DoReportFinalRtsFailed(WifiRemoteStation *station) override
This method is a pure virtual method that must be implemented by the sub-class.
void DoReportDataOk(WifiRemoteStation *station, double ackSnr, WifiMode ackMode, double dataSnr, uint16_t dataChannelWidth, uint8_t dataNss) override
This method is a pure virtual method that must be implemented by the sub-class.
void IncreaseRtsWnd(AarfcdWifiRemoteStation *station)
Increase the RTS window size of the given station.
Trace classes with value semantics.
Definition: traced-value.h:116
a unique identifier for an interface.
Definition: type-id.h:59
represent a single transmission mode
Definition: wifi-mode.h:51
hold a list of per-remote-station state.
This class mimics the TXVECTOR which is to be passed to the PHY in order to define the parameters whi...
Every class exported by the ns3 library is enclosed in the ns3 namespace.
hold per-remote-station state for AARF-CD Wifi manager.
hold per-remote-station state.