2 # NEPI, a framework to manage network experiments
3 # Copyright (C) 2014 INRIA
5 # This program is free software: you can redistribute it and/or modify
6 # it under the terms of the GNU General Public License as published by
7 # the Free Software Foundation, either version 3 of the License, or
8 # (at your option) any later version.
10 # This program is distributed in the hope that it will be useful,
11 # but WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU General Public License for more details.
15 # You should have received a copy of the GNU General Public License
16 # along with this program. If not, see <http://www.gnu.org/licenses/>.
19 from nepi.execution.attribute import Attribute, Flags, Types
20 from nepi.execution.trace import Trace, TraceAttr
21 from nepi.execution.resource import ResourceManager, clsinit_copy, \
22 ResourceState, reschedule_delay
23 from nepi.resources.ns3.ns3wifiremotestationmanager import NS3BaseWifiRemoteStationManager
26 class NS3AarfcdWifiManager(NS3BaseWifiRemoteStationManager):
27 _rtype = "ns3::AarfcdWifiManager"
30 def _register_attributes(cls):
32 attr_successk = Attribute("SuccessK",
33 "Multiplication factor for the success threshold in the AARF algorithm.",
38 flags = Flags.Reserved | Flags.Construct)
40 cls._register_attribute(attr_successk)
42 attr_timerk = Attribute("TimerK",
43 "Multiplication factor for the timer threshold in the AARF algorithm.",
48 flags = Flags.Reserved | Flags.Construct)
50 cls._register_attribute(attr_timerk)
52 attr_maxsuccessthreshold = Attribute("MaxSuccessThreshold",
53 "Maximum value of the success threshold in the AARF algorithm.",
58 flags = Flags.Reserved | Flags.Construct)
60 cls._register_attribute(attr_maxsuccessthreshold)
62 attr_mintimerthreshold = Attribute("MinTimerThreshold",
63 "The minimum value for the \'timer\' threshold in the AARF algorithm.",
68 flags = Flags.Reserved | Flags.Construct)
70 cls._register_attribute(attr_mintimerthreshold)
72 attr_minsuccessthreshold = Attribute("MinSuccessThreshold",
73 "The minimum value for the success threshold in the AARF algorithm.",
78 flags = Flags.Reserved | Flags.Construct)
80 cls._register_attribute(attr_minsuccessthreshold)
82 attr_minrtswnd = Attribute("MinRtsWnd",
83 "Minimum value for Rts window of Aarf-CD",
88 flags = Flags.Reserved | Flags.Construct)
90 cls._register_attribute(attr_minrtswnd)
92 attr_maxrtswnd = Attribute("MaxRtsWnd",
93 "Maximum value for Rts window of Aarf-CD",
98 flags = Flags.Reserved | Flags.Construct)
100 cls._register_attribute(attr_maxrtswnd)
102 attr_turnoffrtsafterratedecrease = Attribute("TurnOffRtsAfterRateDecrease",
103 "If true the RTS mechanism will be turned off when the rate will be decreased",
108 flags = Flags.Reserved | Flags.Construct)
110 cls._register_attribute(attr_turnoffrtsafterratedecrease)
112 attr_turnonrtsafterrateincrease = Attribute("TurnOnRtsAfterRateIncrease",
113 "If true the RTS mechanism will be turned on when the rate will be increased",
118 flags = Flags.Reserved | Flags.Construct)
120 cls._register_attribute(attr_turnonrtsafterrateincrease)
122 attr_islowlatency = Attribute("IsLowLatency",
123 "If true, we attempt to modelize a so-called low-latency device: a device where decisions about tx parameters can be made on a per-packet basis and feedback about the transmission of each packet is obtained before sending the next. Otherwise, we modelize a high-latency device, that is a device where we cannot update our decision about tx parameters after every packet transmission.",
128 flags = Flags.Reserved | Flags.Construct)
130 cls._register_attribute(attr_islowlatency)
132 attr_maxssrc = Attribute("MaxSsrc",
133 "The maximum number of retransmission attempts for an RTS. This value will not have any effect on some rate control algorithms.",
134 type = Types.Integer,
138 flags = Flags.Reserved | Flags.Construct)
140 cls._register_attribute(attr_maxssrc)
142 attr_maxslrc = Attribute("MaxSlrc",
143 "The maximum number of retransmission attempts for a DATA packet. This value will not have any effect on some rate control algorithms.",
144 type = Types.Integer,
148 flags = Flags.Reserved | Flags.Construct)
150 cls._register_attribute(attr_maxslrc)
152 attr_rtsctsthreshold = Attribute("RtsCtsThreshold",
153 "If the size of the data packet + LLC header + MAC header + FCS trailer is bigger than this value, we use an RTS/CTS handshake before sending the data, as per IEEE Std. 802.11-2012, Section 9.3.5. This value will not have any effect on some rate control algorithms.",
154 type = Types.Integer,
158 flags = Flags.Reserved | Flags.Construct)
160 cls._register_attribute(attr_rtsctsthreshold)
162 attr_fragmentationthreshold = Attribute("FragmentationThreshold",
163 "If the size of the data packet + LLC header + MAC header + FCS trailer is biggerthan this value, we fragment it such that the size of the fragments are equal or smaller than this value, as per IEEE Std. 802.11-2012, Section 9.5. This value will not have any effect on some rate control algorithms.",
164 type = Types.Integer,
168 flags = Flags.Reserved | Flags.Construct)
170 cls._register_attribute(attr_fragmentationthreshold)
172 attr_nonunicastmode = Attribute("NonUnicastMode",
173 "Wifi mode used for non-unicast transmissions.",
175 default = "Invalid-WifiMode",
178 flags = Flags.Reserved | Flags.Construct)
180 cls._register_attribute(attr_nonunicastmode)
182 attr_defaulttxpowerlevel = Attribute("DefaultTxPowerLevel",
183 "Default power level to be used for transmissions. This is the power level that is used by all those WifiManagers that do notimplement TX power control.",
184 type = Types.Integer,
188 flags = Flags.Reserved | Flags.Construct)
190 cls._register_attribute(attr_defaulttxpowerlevel)
195 def _register_traces(cls):
197 mactxrtsfailed = Trace("MacTxRtsFailed", "The transmission of a RTS by the MAC layer has failed")
199 cls._register_trace(mactxrtsfailed)
201 mactxdatafailed = Trace("MacTxDataFailed", "The transmission of a data packet by the MAC layer has failed")
203 cls._register_trace(mactxdatafailed)
205 mactxfinalrtsfailed = Trace("MacTxFinalRtsFailed", "The transmission of a RTS has exceeded the maximum number of attempts")
207 cls._register_trace(mactxfinalrtsfailed)
209 mactxfinaldatafailed = Trace("MacTxFinalDataFailed", "The transmission of a data packet has exceeded the maximum number of attempts")
211 cls._register_trace(mactxfinaldatafailed)
215 def __init__(self, ec, guid):
216 super(NS3AarfcdWifiManager, self).__init__(ec, guid)
217 self._home = "ns3-aarfcd-wifi-manager-%s" % self.guid