A Discrete-Event Network Simulator
API
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
ns3::AarfcdWifiManager Class Reference

an implementation of the AARF-CD algorithmThis algorithm was first described in "Efficient Collision Detection for Auto Rate Fallback Algorithm". The implementation available here was done by Federico Maguolo for a very early development version of ns-3. Federico died before merging this work in ns-3 itself so his code was ported to ns-3 later without his supervision. More...

#include <aarfcd-wifi-manager.h>

+ Inheritance diagram for ns3::AarfcdWifiManager:
+ Collaboration diagram for ns3::AarfcdWifiManager:

Public Member Functions

 AarfcdWifiManager ()
virtual ~AarfcdWifiManager ()
- Public Member Functions inherited from ns3::WifiRemoteStationManager
 WifiRemoteStationManager ()
virtual ~WifiRemoteStationManager ()
void AddBasicMode (WifiMode mode)
void AddSupportedMode (Mac48Address address, WifiMode mode)
WifiMode GetAckMode (Mac48Address address, WifiMode dataMode)
WifiMode GetBasicMode (uint32_t i) const
WifiMode GetCtsMode (Mac48Address address, WifiMode rtsMode)
WifiMode GetDataMode (Mac48Address address, const WifiMacHeader *header, Ptr< const Packet > packet, uint32_t fullPacketSize)
WifiMode GetDefaultMode (void) const
uint32_t GetFragmentationThreshold (void) const
uint32_t GetFragmentOffset (Mac48Address address, const WifiMacHeader *header, Ptr< const Packet > packet, uint32_t fragmentNumber)
uint32_t GetFragmentSize (Mac48Address address, const WifiMacHeader *header, Ptr< const Packet > packet, uint32_t fragmentNumber)
WifiRemoteStationInfo GetInfo (Mac48Address address)
uint32_t GetMaxSlrc (void) const
uint32_t GetMaxSsrc (void) const
uint32_t GetNBasicModes (void) const
WifiMode GetNonUnicastMode (void) const
uint32_t GetRtsCtsThreshold (void) const
WifiMode GetRtsMode (Mac48Address address, const WifiMacHeader *header, Ptr< const Packet > packet)
bool IsAssociated (Mac48Address address) const
bool IsBrandNew (Mac48Address address) const
bool IsLastFragment (Mac48Address address, const WifiMacHeader *header, Ptr< const Packet > packet, uint32_t fragmentNumber)
bool IsWaitAssocTxOk (Mac48Address address) const
bool NeedDataRetransmission (Mac48Address address, const WifiMacHeader *header, Ptr< const Packet > packet)
bool NeedFragmentation (Mac48Address address, const WifiMacHeader *header, Ptr< const Packet > packet)
bool NeedRts (Mac48Address address, const WifiMacHeader *header, Ptr< const Packet > packet)
bool NeedRtsRetransmission (Mac48Address address, const WifiMacHeader *header, Ptr< const Packet > packet)
void PrepareForQueue (Mac48Address address, const WifiMacHeader *header, Ptr< const Packet > packet, uint32_t fullPacketSize)
void RecordDisassociated (Mac48Address address)
void RecordGotAssocTxFailed (Mac48Address address)
void RecordGotAssocTxOk (Mac48Address address)
void RecordWaitAssocTxOk (Mac48Address address)
void ReportDataFailed (Mac48Address address, const WifiMacHeader *header)
void ReportDataOk (Mac48Address address, const WifiMacHeader *header, double ackSnr, WifiMode ackMode, double dataSnr)
void ReportFinalDataFailed (Mac48Address address, const WifiMacHeader *header)
void ReportFinalRtsFailed (Mac48Address address, const WifiMacHeader *header)
void ReportRtsFailed (Mac48Address address, const WifiMacHeader *header)
void ReportRtsOk (Mac48Address address, const WifiMacHeader *header, double ctsSnr, WifiMode ctsMode, double rtsSnr)
void ReportRxOk (Mac48Address address, const WifiMacHeader *header, double rxSnr, WifiMode txMode)
void Reset (void)
void Reset (Mac48Address address)
void SetFragmentationThreshold (uint32_t threshold)
void SetMaxSlrc (uint32_t maxSlrc)
void SetMaxSsrc (uint32_t maxSsrc)
void SetRtsCtsThreshold (uint32_t threshold)
virtual void SetupPhy (Ptr< WifiPhy > phy)
- Public Member Functions inherited from ns3::Object
 Object ()
virtual ~Object ()
void AggregateObject (Ptr< Object > other)
void Dispose (void)
AggregateIterator GetAggregateIterator (void) const
virtual TypeId GetInstanceTypeId (void) const
template<typename T >
Ptr< T > GetObject (void) const
template<typename T >
Ptr< T > GetObject (TypeId tid) const
void Start (void)
- Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter >
 SimpleRefCount ()
 SimpleRefCount (const SimpleRefCount &o)
uint32_t GetReferenceCount (void) const
SimpleRefCountoperator= (const SimpleRefCount &o)
void Ref (void) const
void Unref (void) const
- Public Member Functions inherited from ns3::ObjectBase
virtual ~ObjectBase ()
void GetAttribute (std::string name, AttributeValue &value) const
bool GetAttributeFailSafe (std::string name, AttributeValue &attribute) const
void SetAttribute (std::string name, const AttributeValue &value)
bool SetAttributeFailSafe (std::string name, const AttributeValue &value)
bool TraceConnect (std::string name, std::string context, const CallbackBase &cb)
bool TraceConnectWithoutContext (std::string name, const CallbackBase &cb)
bool TraceDisconnect (std::string name, std::string context, const CallbackBase &cb)
bool TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb)

Static Public Member Functions

static TypeId GetTypeId (void)
 This method returns the TypeId associated to ns3::AarfcdWifiManager.

Private Member Functions

void CheckRts (AarfcdWifiRemoteStation *station)
virtual WifiRemoteStationDoCreateStation (void) const
virtual WifiMode DoGetDataMode (WifiRemoteStation *station, uint32_t size)
virtual WifiMode DoGetRtsMode (WifiRemoteStation *station)
virtual bool DoNeedRts (WifiRemoteStation *station, Ptr< const Packet > packet, bool normally)
virtual void DoReportDataFailed (WifiRemoteStation *station)
virtual void DoReportDataOk (WifiRemoteStation *station, double ackSnr, WifiMode ackMode, double dataSnr)
virtual void DoReportFinalDataFailed (WifiRemoteStation *station)
virtual void DoReportFinalRtsFailed (WifiRemoteStation *station)
virtual void DoReportRtsFailed (WifiRemoteStation *station)
virtual void DoReportRtsOk (WifiRemoteStation *station, double ctsSnr, WifiMode ctsMode, double rtsSnr)
virtual void DoReportRxOk (WifiRemoteStation *station, double rxSnr, WifiMode txMode)
void IncreaseRtsWnd (AarfcdWifiRemoteStation *station)
virtual bool IsLowLatency (void) const
void ResetRtsWnd (AarfcdWifiRemoteStation *station)
void TurnOffRts (AarfcdWifiRemoteStation *station)
void TurnOnRts (AarfcdWifiRemoteStation *station)

Private Attributes

uint32_t m_maxRtsWnd
uint32_t m_maxSuccessThreshold
uint32_t m_minRtsWnd
uint32_t m_minSuccessThreshold
uint32_t m_minTimerThreshold
bool m_rtsFailsAsDataFails
double m_successK
double m_timerK
bool m_turnOffRtsAfterRateDecrease
bool m_turnOnRtsAfterRateIncrease

Additional Inherited Members

- Protected Member Functions inherited from ns3::WifiRemoteStationManager
virtual void DoDispose (void)
uint32_t GetNSupported (const WifiRemoteStation *station) const
WifiMode GetSupported (const WifiRemoteStation *station, uint32_t i) const

Detailed Description

an implementation of the AARF-CD algorithm

This algorithm was first described in "Efficient Collision Detection for Auto Rate Fallback Algorithm". The implementation available here was done by Federico Maguolo for a very early development version of ns-3. Federico died before merging this work in ns-3 itself so his code was ported to ns-3 later without his supervision.

Definition at line 38 of file aarfcd-wifi-manager.h.

Constructor & Destructor Documentation

ns3::AarfcdWifiManager::AarfcdWifiManager ( )

Definition at line 111 of file aarfcd-wifi-manager.cc.

ns3::AarfcdWifiManager::~AarfcdWifiManager ( )
virtual

Definition at line 115 of file aarfcd-wifi-manager.cc.

Member Function Documentation

void ns3::AarfcdWifiManager::CheckRts ( AarfcdWifiRemoteStation station)
private

Definition at line 320 of file aarfcd-wifi-manager.cc.

References ns3::AarfcdWifiRemoteStation::m_rtsCounter, ns3::AarfcdWifiRemoteStation::m_rtsOn, and TurnOffRts().

Referenced by DoReportDataFailed(), and DoReportDataOk().

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

WifiMode ns3::AarfcdWifiManager::DoGetDataMode ( WifiRemoteStation station,
uint32_t  size 
)
privatevirtual

Definition at line 289 of file aarfcd-wifi-manager.cc.

References ns3::WifiRemoteStationManager::GetSupported(), and ns3::AarfcdWifiRemoteStation::m_rate.

+ Here is the call graph for this function:

WifiMode ns3::AarfcdWifiManager::DoGetRtsMode ( WifiRemoteStation station)
privatevirtual

Definition at line 295 of file aarfcd-wifi-manager.cc.

References ns3::WifiRemoteStationManager::GetSupported().

+ Here is the call graph for this function:

bool ns3::AarfcdWifiManager::DoNeedRts ( WifiRemoteStation station,
Ptr< const Packet packet,
bool  normally 
)
privatevirtual
void ns3::AarfcdWifiManager::DoReportDataFailed ( WifiRemoteStation st)
privatevirtual

It is important to realize that "recovery" mode starts after failure of the first transmission after a rate increase and ends at the first successful transmission. Specifically, recovery mode transcends retransmissions boundaries. Fundamentally, ARF handles each data transmission independently, whether it is the initial transmission of a packet or the retransmission of a packet. The fundamental reason for this is that there is a backoff between each data transmission, be it an initial transmission or a retransmission.

Definition at line 157 of file aarfcd-wifi-manager.cc.

References CheckRts(), IncreaseRtsWnd(), ns3::AarfcdWifiRemoteStation::m_failed, ns3::AarfcdWifiRemoteStation::m_haveASuccess, ns3::AarfcdWifiRemoteStation::m_justModifyRate, m_maxSuccessThreshold, m_minSuccessThreshold, m_minTimerThreshold, ns3::AarfcdWifiRemoteStation::m_rate, ns3::AarfcdWifiRemoteStation::m_recovery, ns3::AarfcdWifiRemoteStation::m_retry, ns3::AarfcdWifiRemoteStation::m_rtsCounter, ns3::AarfcdWifiRemoteStation::m_rtsOn, ns3::AarfcdWifiRemoteStation::m_rtsWnd, ns3::AarfcdWifiRemoteStation::m_success, m_successK, ns3::AarfcdWifiRemoteStation::m_successThreshold, ns3::AarfcdWifiRemoteStation::m_timer, m_timerK, ns3::AarfcdWifiRemoteStation::m_timerTimeout, m_turnOffRtsAfterRateDecrease, ns3::Max(), ns3::Min(), NS_ASSERT, ResetRtsWnd(), TurnOffRts(), and TurnOnRts().

+ Here is the call graph for this function:

void ns3::AarfcdWifiManager::DoReportFinalDataFailed ( WifiRemoteStation station)
privatevirtual

Definition at line 284 of file aarfcd-wifi-manager.cc.

void ns3::AarfcdWifiManager::DoReportFinalRtsFailed ( WifiRemoteStation station)
privatevirtual

Definition at line 280 of file aarfcd-wifi-manager.cc.

void ns3::AarfcdWifiManager::DoReportRtsFailed ( WifiRemoteStation station)
privatevirtual

Definition at line 144 of file aarfcd-wifi-manager.cc.

void ns3::AarfcdWifiManager::DoReportRtsOk ( WifiRemoteStation station,
double  ctsSnr,
WifiMode  ctsMode,
double  rtsSnr 
)
privatevirtual
void ns3::AarfcdWifiManager::DoReportRxOk ( WifiRemoteStation station,
double  rxSnr,
WifiMode  txMode 
)
privatevirtual

Definition at line 235 of file aarfcd-wifi-manager.cc.

TypeId ns3::AarfcdWifiManager::GetTypeId ( void  )
static

This method returns the TypeId associated to ns3::AarfcdWifiManager.

This object is accessible through the following paths with Config::Set and Config::Connect:

  • /NodeList/[i]/DeviceList/[i]/$ns3::WifiNetDevice/RemoteStationManager/$ns3::AarfcdWifiManager

Attributes defined for this type:

  • SuccessK: Multiplication factor for the success threshold in the AARF algorithm.
    • Set with class: ns3::DoubleValue
    • Underlying type: double -1.79769e+308:1.79769e+308
    • Initial value: 2
    • Flags: construct write read
  • TimerK: Multiplication factor for the timer threshold in the AARF algorithm.
    • Set with class: ns3::DoubleValue
    • Underlying type: double -1.79769e+308:1.79769e+308
    • Initial value: 2
    • Flags: construct write read
  • MaxSuccessThreshold: Maximum value of the success threshold in the AARF algorithm.
  • MinTimerThreshold: The minimum value for the 'timer' threshold in the AARF algorithm.
  • MinSuccessThreshold: The minimum value for the success threshold in the AARF algorithm.
  • MinRtsWnd: Minimum value for Rts window of Aarf-CD
  • MaxRtsWnd: Maximum value for Rts window of Aarf-CD
  • TurnOffRtsAfterRateDecrease: If true the RTS mechanism will be turned off when the rate will be decreased
    • Set with class: BooleanValue
    • Underlying type: bool
    • Initial value: true
    • Flags: construct write read
  • TurnOnRtsAfterRateIncrease: If true the RTS mechanism will be turned on when the rate will be increased
    • Set with class: BooleanValue
    • Underlying type: bool
    • Initial value: true
    • Flags: construct write read

Attributes defined in parent class ns3::WifiRemoteStationManager:

  • IsLowLatency: 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.
  • MaxSsrc: The maximum number of retransmission attempts for an RTS. This value will not have any effect on some rate control algorithms.
  • MaxSlrc: The maximum number of retransmission attempts for a DATA packet. This value will not have any effect on some rate control algorithms.
  • RtsCtsThreshold: 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-2007, Section 9.2.6. This value will not have any effect on some rate control algorithms.
  • FragmentationThreshold: 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-2007, Section 9.4. This value will not have any effect on some rate control algorithms.
  • NonUnicastMode: Wifi mode used for non-unicast transmissions.
    • Set with class: WifiModeValue
    • Underlying type: WifiMode
    • Initial value: Invalid-WifiMode
    • Flags: construct write read

No TraceSources defined for this type.
TraceSources defined in parent class ns3::WifiRemoteStationManager:

  • MacTxRtsFailed: The transmission of a RTS by the MAC layer has failed
  • MacTxDataFailed: The transmission of a data packet by the MAC layer has failed
  • MacTxFinalRtsFailed: The transmission of a RTS has exceeded the maximum number of attempts
  • MacTxFinalDataFailed: The transmission of a data packet has exceeded the maximum number of attempts

Reimplemented from ns3::WifiRemoteStationManager.

Definition at line 59 of file aarfcd-wifi-manager.cc.

References m_maxRtsWnd, m_maxSuccessThreshold, m_minRtsWnd, m_minSuccessThreshold, m_minTimerThreshold, m_successK, m_timerK, m_turnOffRtsAfterRateDecrease, m_turnOnRtsAfterRateIncrease, and ns3::TypeId::SetParent().

+ Here is the call graph for this function:

void ns3::AarfcdWifiManager::IncreaseRtsWnd ( AarfcdWifiRemoteStation station)
private

Definition at line 342 of file aarfcd-wifi-manager.cc.

References m_maxRtsWnd, and ns3::AarfcdWifiRemoteStation::m_rtsWnd.

Referenced by DoReportDataFailed().

+ Here is the caller graph for this function:

bool ns3::AarfcdWifiManager::IsLowLatency ( void  ) const
privatevirtual

Definition at line 314 of file aarfcd-wifi-manager.cc.

void ns3::AarfcdWifiManager::ResetRtsWnd ( AarfcdWifiRemoteStation station)
private

Definition at line 357 of file aarfcd-wifi-manager.cc.

References m_minRtsWnd, and ns3::AarfcdWifiRemoteStation::m_rtsWnd.

Referenced by DoReportDataFailed(), and DoReportDataOk().

+ Here is the caller graph for this function:

void ns3::AarfcdWifiManager::TurnOffRts ( AarfcdWifiRemoteStation station)
private

Definition at line 329 of file aarfcd-wifi-manager.cc.

References ns3::AarfcdWifiRemoteStation::m_haveASuccess, and ns3::AarfcdWifiRemoteStation::m_rtsOn.

Referenced by CheckRts(), and DoReportDataFailed().

+ Here is the caller graph for this function:

void ns3::AarfcdWifiManager::TurnOnRts ( AarfcdWifiRemoteStation station)
private

Definition at line 336 of file aarfcd-wifi-manager.cc.

References ns3::AarfcdWifiRemoteStation::m_rtsOn.

Referenced by DoReportDataFailed(), and DoReportDataOk().

+ Here is the caller graph for this function:

Member Data Documentation

uint32_t ns3::AarfcdWifiManager::m_maxRtsWnd
private

Definition at line 79 of file aarfcd-wifi-manager.h.

Referenced by GetTypeId(), and IncreaseRtsWnd().

uint32_t ns3::AarfcdWifiManager::m_maxSuccessThreshold
private

Definition at line 74 of file aarfcd-wifi-manager.h.

Referenced by DoReportDataFailed(), and GetTypeId().

uint32_t ns3::AarfcdWifiManager::m_minRtsWnd
private

Definition at line 78 of file aarfcd-wifi-manager.h.

Referenced by DoCreateStation(), GetTypeId(), and ResetRtsWnd().

uint32_t ns3::AarfcdWifiManager::m_minSuccessThreshold
private

Definition at line 72 of file aarfcd-wifi-manager.h.

Referenced by DoCreateStation(), DoReportDataFailed(), and GetTypeId().

uint32_t ns3::AarfcdWifiManager::m_minTimerThreshold
private

Definition at line 71 of file aarfcd-wifi-manager.h.

Referenced by DoCreateStation(), DoReportDataFailed(), and GetTypeId().

bool ns3::AarfcdWifiManager::m_rtsFailsAsDataFails
private

Definition at line 80 of file aarfcd-wifi-manager.h.

double ns3::AarfcdWifiManager::m_successK
private

Definition at line 73 of file aarfcd-wifi-manager.h.

Referenced by DoReportDataFailed(), and GetTypeId().

double ns3::AarfcdWifiManager::m_timerK
private

Definition at line 75 of file aarfcd-wifi-manager.h.

Referenced by DoReportDataFailed(), and GetTypeId().

bool ns3::AarfcdWifiManager::m_turnOffRtsAfterRateDecrease
private

Definition at line 81 of file aarfcd-wifi-manager.h.

Referenced by DoReportDataFailed(), and GetTypeId().

bool ns3::AarfcdWifiManager::m_turnOnRtsAfterRateIncrease
private

Definition at line 82 of file aarfcd-wifi-manager.h.

Referenced by DoReportDataOk(), and GetTypeId().


The documentation for this class was generated from the following files: