VHT configuration. More...
#include "vht-configuration.h"
Public Types | |
using | SecondaryCcaSensitivityThresholds |
Tuple identifying CCA sensitivity thresholds for secondary channels. | |
Public Member Functions | |
VhtConfiguration () | |
~VhtConfiguration () override | |
bool | Get160MHzOperationSupported () const |
SecondaryCcaSensitivityThresholds | GetSecondaryCcaSensitivityThresholds () const |
const std::map< MHz_u, dBm_u > & | GetSecondaryCcaSensitivityThresholdsPerBw () const |
void | Set160MHzOperationSupported (bool enable) |
Enable or disable 160 MHz operation support. | |
void | SetSecondaryCcaSensitivityThresholds (const SecondaryCcaSensitivityThresholds &thresholds) |
Sets the CCA sensitivity thresholds for PPDUs that do not occupy the primary channel. | |
Public Member Functions inherited from ns3::Object | |
Object () | |
Constructor. | |
~Object () override | |
Destructor. | |
void | AggregateObject (Ptr< Object > other) |
Aggregate two Objects together. | |
void | Dispose () |
Dispose of this Object. | |
AggregateIterator | GetAggregateIterator () const |
Get an iterator to the Objects aggregated to this one. | |
TypeId | GetInstanceTypeId () const override |
Get the most derived TypeId for this Object. | |
template<typename T > | |
Ptr< T > | GetObject () const |
Get a pointer to the requested aggregated Object. | |
template<> | |
Ptr< Object > | GetObject () const |
Specialization of () for objects of type ns3::Object. | |
template<typename T > | |
Ptr< T > | GetObject (TypeId tid) const |
Get a pointer to the requested aggregated Object by TypeId. | |
template<> | |
Ptr< Object > | GetObject (TypeId tid) const |
Specialization of (TypeId tid) for objects of type ns3::Object. | |
void | Initialize () |
Invoke DoInitialize on all Objects aggregated to this one. | |
bool | IsInitialized () const |
Check if the object has been initialized. | |
void | UnidirectionalAggregateObject (Ptr< Object > other) |
Aggregate an Object to another Object. | |
Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter > | |
SimpleRefCount () | |
Default constructor. | |
SimpleRefCount (const SimpleRefCount &o) | |
Copy constructor. | |
uint32_t | GetReferenceCount () const |
Get the reference count of the object. | |
SimpleRefCount & | operator= (const SimpleRefCount &o) |
Assignment operator. | |
void | Ref () const |
Increment the reference count. | |
void | Unref () const |
Decrement the reference count. | |
Public Member Functions inherited from ns3::ObjectBase | |
virtual | ~ObjectBase () |
Virtual destructor. | |
void | GetAttribute (std::string name, AttributeValue &value, bool permissive=false) const |
Get the value of an attribute, raising fatal errors if unsuccessful. | |
bool | GetAttributeFailSafe (std::string name, AttributeValue &value) const |
Get the value of an attribute without raising errors. | |
void | SetAttribute (std::string name, const AttributeValue &value) |
Set a single attribute, raising fatal errors if unsuccessful. | |
bool | SetAttributeFailSafe (std::string name, const AttributeValue &value) |
Set a single attribute without raising errors. | |
bool | TraceConnect (std::string name, std::string context, const CallbackBase &cb) |
Connect a TraceSource to a Callback with a context. | |
bool | TraceConnectWithoutContext (std::string name, const CallbackBase &cb) |
Connect a TraceSource to a Callback without a context. | |
bool | TraceDisconnect (std::string name, std::string context, const CallbackBase &cb) |
Disconnect from a TraceSource a Callback previously connected with a context. | |
bool | TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb) |
Disconnect from a TraceSource a Callback previously connected without a context. | |
Static Public Member Functions | |
static TypeId | GetTypeId () |
Get the type ID. | |
Static Public Member Functions inherited from ns3::Object | |
static TypeId | GetTypeId () |
Register this type. | |
Static Public Member Functions inherited from ns3::ObjectBase | |
static TypeId | GetTypeId () |
Get the type ID. | |
Private Attributes | |
bool | m_160MHzSupported |
whether 160 MHz operation is supported | |
std::map< MHz_u, dBm_u > | m_secondaryCcaSensitivityThresholds |
CCA sensitivity thresholds for signals that do not occupy the primary channel, indexed by signal bandwidth. | |
Additional Inherited Members | |
Protected Member Functions inherited from ns3::Object | |
Object (const Object &o) | |
Copy an Object. | |
virtual void | DoDispose () |
Destructor implementation. | |
virtual void | DoInitialize () |
Initialize() implementation. | |
virtual void | NotifyNewAggregate () |
Notify all Objects aggregated to this one of a new Object being aggregated. | |
Protected Member Functions inherited from ns3::ObjectBase | |
void | ConstructSelf (const AttributeConstructionList &attributes) |
Complete construction of ObjectBase; invoked by derived classes. | |
virtual void | NotifyConstructionCompleted () |
Notifier called once the ObjectBase is fully constructed. | |
Related Symbols inherited from ns3::ObjectBase | |
static TypeId | GetObjectIid () |
Ensure the TypeId for ObjectBase gets fully configured to anchor the inheritance tree properly. | |
VHT configuration.
This object stores VHT configuration information, for use in modifying AP or STA behavior and for constructing VHT-related information elements.
Definition at line 29 of file vht-configuration.h.
Tuple identifying CCA sensitivity thresholds for secondary channels.
Definition at line 54 of file vht-configuration.h.
ns3::VhtConfiguration::VhtConfiguration | ( | ) |
Definition at line 24 of file vht-configuration.cc.
References NS_LOG_FUNCTION.
|
override |
Definition at line 29 of file vht-configuration.cc.
References NS_LOG_FUNCTION.
bool ns3::VhtConfiguration::Get160MHzOperationSupported | ( | ) | const |
Definition at line 76 of file vht-configuration.cc.
References m_160MHzSupported.
Referenced by GetTypeId().
VhtConfiguration::SecondaryCcaSensitivityThresholds ns3::VhtConfiguration::GetSecondaryCcaSensitivityThresholds | ( | ) | const |
Definition at line 92 of file vht-configuration.cc.
References m_secondaryCcaSensitivityThresholds.
Referenced by GetTypeId().
const std::map< MHz_u, dBm_u > & ns3::VhtConfiguration::GetSecondaryCcaSensitivityThresholdsPerBw | ( | ) | const |
Definition at line 100 of file vht-configuration.cc.
References m_secondaryCcaSensitivityThresholds.
|
static |
Get the type ID.
Definition at line 35 of file vht-configuration.cc.
References Get160MHzOperationSupported(), GetSecondaryCcaSensitivityThresholds(), ns3::MakeBooleanAccessor(), ns3::MakeBooleanChecker(), ns3::MakeDoubleChecker(), ns3::MakeTupleAccessor(), ns3::MakeTupleChecker(), Set160MHzOperationSupported(), ns3::TypeId::SetParent(), and SetSecondaryCcaSensitivityThresholds().
void ns3::VhtConfiguration::Set160MHzOperationSupported | ( | bool | enable | ) |
Enable or disable 160 MHz operation support.
enable | true if 20 MHz, 40 MHz, 80 MHz and 160 MHz operation is to be supported, false if 20 MHz, 40 MHz and 80 MHz operation is to be supported |
Definition at line 69 of file vht-configuration.cc.
References m_160MHzSupported, and NS_LOG_FUNCTION.
Referenced by GetTypeId().
void ns3::VhtConfiguration::SetSecondaryCcaSensitivityThresholds | ( | const SecondaryCcaSensitivityThresholds & | thresholds | ) |
Sets the CCA sensitivity thresholds for PPDUs that do not occupy the primary channel.
The thresholds are defined as a tuple {threshold for 20MHz PPDUs, threshold for 40MHz PPDUs, threshold for 80MHz PPDUs}.
thresholds | the CCA sensitivity thresholds |
Definition at line 82 of file vht-configuration.cc.
References m_secondaryCcaSensitivityThresholds, and NS_LOG_FUNCTION.
Referenced by GetTypeId().
|
private |
whether 160 MHz operation is supported
Definition at line 78 of file vht-configuration.h.
Referenced by Get160MHzOperationSupported(), and Set160MHzOperationSupported().
CCA sensitivity thresholds for signals that do not occupy the primary channel, indexed by signal bandwidth.
Definition at line 80 of file vht-configuration.h.
Referenced by GetSecondaryCcaSensitivityThresholds(), GetSecondaryCcaSensitivityThresholdsPerBw(), and SetSecondaryCcaSensitivityThresholds().