helps to manage and create WimaxNetDevice objects More...
#include "wimax-helper.h"
Public Types | |
enum | NetDeviceType { DEVICE_TYPE_SUBSCRIBER_STATION , DEVICE_TYPE_BASE_STATION } |
Net Device Type Distinguish a subscriber station(SS) device from base station(BS) device. More... | |
enum | PhyType { SIMPLE_PHY_TYPE_OFDM } |
WiMAX Physical layer WiMAX Physical layers with different levels of detail. More... | |
enum | SchedulerType { SCHED_TYPE_SIMPLE , SCHED_TYPE_RTPS , SCHED_TYPE_MBQOS } |
Scheduler Type Different implementations of uplink/downlink scheduler. More... | |
Public Member Functions | |
WimaxHelper (void) | |
Create a Wimax helper in an empty state. More... | |
~WimaxHelper (void) | |
int64_t | AssignStreams (int64_t stream) |
Assign a fixed random variable stream number to the random variables used by this model. More... | |
int64_t | AssignStreams (NetDeviceContainer c, int64_t stream) |
Assign a fixed random variable stream number to the random variables used by this model. More... | |
Ptr< BSScheduler > | CreateBSScheduler (SchedulerType schedulerType) |
Ptr< WimaxPhy > | CreatePhy (PhyType phyType) |
Ptr< WimaxPhy > | CreatePhy (PhyType phyType, char *SNRTraceFilePath, bool activateLoss) |
Ptr< WimaxPhy > | CreatePhyWithoutChannel (PhyType phyType) |
Ptr< WimaxPhy > | CreatePhyWithoutChannel (PhyType phyType, char *SNRTraceFilePath, bool activateLoss) |
ServiceFlow | CreateServiceFlow (ServiceFlow::Direction direction, ServiceFlow::SchedulingType schedulinType, IpcsClassifierRecord classifier) |
Creates a transport service flow. More... | |
Ptr< UplinkScheduler > | CreateUplinkScheduler (SchedulerType schedulerType) |
NetDeviceContainer | Install (NodeContainer c, NetDeviceType deviceType, PhyType phyType, Ptr< WimaxChannel > channel, SchedulerType schedulerType) |
NetDeviceContainer | Install (NodeContainer c, NetDeviceType deviceType, PhyType phyType, SchedulerType schedulerType, double frameDuration) |
NetDeviceContainer | Install (NodeContainer c, NetDeviceType type, PhyType phyType, SchedulerType schedulerType) |
Ptr< WimaxNetDevice > | Install (Ptr< Node > node, NetDeviceType deviceType, PhyType phyType, Ptr< WimaxChannel > channel, SchedulerType schedulerType) |
void | SetPropagationLossModel (SimpleOfdmWimaxChannel::PropModel propagationModel) |
Set the propagation and loss model of the channel. More... | |
Public Member Functions inherited from ns3::PcapHelperForDevice | |
PcapHelperForDevice () | |
Construct a PcapHelperForDevice. More... | |
virtual | ~PcapHelperForDevice () |
Destroy a PcapHelperForDevice. More... | |
void | EnablePcap (std::string prefix, NetDeviceContainer d, bool promiscuous=false) |
Enable pcap output on each device in the container which is of the appropriate type. More... | |
void | EnablePcap (std::string prefix, NodeContainer n, bool promiscuous=false) |
Enable pcap output on each device (which is of the appropriate type) in the nodes provided in the container. More... | |
void | EnablePcap (std::string prefix, Ptr< NetDevice > nd, bool promiscuous=false, bool explicitFilename=false) |
Enable pcap output the indicated net device. More... | |
void | EnablePcap (std::string prefix, std::string ndName, bool promiscuous=false, bool explicitFilename=false) |
Enable pcap output the indicated net device using a device previously named using the ns-3 object name service. More... | |
void | EnablePcap (std::string prefix, uint32_t nodeid, uint32_t deviceid, bool promiscuous=false) |
Enable pcap output on the device specified by a global node-id (of a previously created node) and associated device-id. More... | |
void | EnablePcapAll (std::string prefix, bool promiscuous=false) |
Enable pcap output on each device (which is of the appropriate type) in the set of all nodes created in the simulation. More... | |
Public Member Functions inherited from ns3::AsciiTraceHelperForDevice | |
AsciiTraceHelperForDevice () | |
Construct an AsciiTraceHelperForDevice. More... | |
virtual | ~AsciiTraceHelperForDevice () |
Destroy an AsciiTraceHelperForDevice. More... | |
void | EnableAscii (Ptr< OutputStreamWrapper > stream, NetDeviceContainer d) |
Enable ascii trace output on each device in the container which is of the appropriate type. More... | |
void | EnableAscii (Ptr< OutputStreamWrapper > stream, NodeContainer n) |
Enable ascii trace output on each device (which is of the appropriate type) in the nodes provided in the container. More... | |
void | EnableAscii (Ptr< OutputStreamWrapper > stream, Ptr< NetDevice > nd) |
Enable ascii trace output on the indicated net device. More... | |
void | EnableAscii (Ptr< OutputStreamWrapper > stream, std::string ndName) |
Enable ascii trace output the indicated net device using a device previously named using the ns-3 object name service. More... | |
void | EnableAscii (Ptr< OutputStreamWrapper > stream, uint32_t nodeid, uint32_t deviceid) |
Enable ascii trace output on the device specified by a global node-id (of a previously created node) and associated device-id. More... | |
void | EnableAscii (std::string prefix, NetDeviceContainer d) |
Enable ascii trace output on each device in the container which is of the appropriate type. More... | |
void | EnableAscii (std::string prefix, NodeContainer n) |
Enable ascii trace output on each device (which is of the appropriate type) in the nodes provided in the container. More... | |
void | EnableAscii (std::string prefix, Ptr< NetDevice > nd, bool explicitFilename=false) |
Enable ascii trace output on the indicated net device. More... | |
void | EnableAscii (std::string prefix, std::string ndName, bool explicitFilename=false) |
Enable ascii trace output the indicated net device using a device previously named using the ns-3 object name service. More... | |
void | EnableAscii (std::string prefix, uint32_t nodeid, uint32_t deviceid, bool explicitFilename) |
Enable ascii trace output on the device specified by a global node-id (of a previously created node) and associated device-id. More... | |
void | EnableAsciiAll (Ptr< OutputStreamWrapper > stream) |
Enable ascii trace output on each device (which is of the appropriate type) in the set of all nodes created in the simulation. More... | |
void | EnableAsciiAll (std::string prefix) |
Enable ascii trace output on each device (which is of the appropriate type) in the set of all nodes created in the simulation. More... | |
Static Public Member Functions | |
static void | EnableAsciiForConnection (Ptr< OutputStreamWrapper > oss, uint32_t nodeid, uint32_t deviceid, char *netdevice, char *connection) |
Enable ascii trace output on the indicated net device for a given connection. More... | |
static void | EnableLogComponents (void) |
Helper to enable all WimaxNetDevice log components with one statement. More... | |
Private Member Functions | |
virtual void | EnableAsciiInternal (Ptr< OutputStreamWrapper > stream, std::string prefix, Ptr< NetDevice > nd, bool explicitFilename) |
Enable ascii trace output on the indicated net device. More... | |
virtual void | EnablePcapInternal (std::string prefix, Ptr< NetDevice > nd, bool explicitFilename, bool promiscuous) |
Enable pcap output on the indicated net device. More... | |
Static Private Member Functions | |
static void | AsciiRxEvent (Ptr< OutputStreamWrapper > stream, std::string path, Ptr< const Packet > packet, const Mac48Address &source) |
ASCII trace receive event. More... | |
static void | AsciiTxEvent (Ptr< OutputStreamWrapper > stream, std::string path, Ptr< const Packet > packet, const Mac48Address &dest) |
ASCII trace transmit event. More... | |
Private Attributes | |
Ptr< WimaxChannel > | m_channel |
wifi channel More... | |
helps to manage and create WimaxNetDevice objects
This class can help to create a large set of similar WimaxNetDevice objects and to configure their attributes during creation.
Definition at line 58 of file wimax-helper.h.
Net Device Type Distinguish a subscriber station(SS) device from base station(BS) device.
Enumerator | |
---|---|
DEVICE_TYPE_SUBSCRIBER_STATION | Subscriber station(SS) device. |
DEVICE_TYPE_BASE_STATION | Base station(BS) device. |
Definition at line 65 of file wimax-helper.h.
WiMAX Physical layer WiMAX Physical layers with different levels of detail.
Enumerator | |
---|---|
SIMPLE_PHY_TYPE_OFDM |
Definition at line 76 of file wimax-helper.h.
Scheduler Type Different implementations of uplink/downlink scheduler.
Enumerator | |
---|---|
SCHED_TYPE_SIMPLE | A simple priority-based FCFS scheduler. |
SCHED_TYPE_RTPS | A simple scheduler - rtPS based scheduler. |
SCHED_TYPE_MBQOS | An migration-based uplink scheduler. |
Definition at line 85 of file wimax-helper.h.
ns3::WimaxHelper::WimaxHelper | ( | void | ) |
Create a Wimax helper in an empty state.
Definition at line 43 of file wimax-helper.cc.
ns3::WimaxHelper::~WimaxHelper | ( | void | ) |
Definition at line 48 of file wimax-helper.cc.
|
staticprivate |
ASCII trace receive event.
stream | the output stream |
path | the path name |
packet | the packet |
source | the source MAC address |
Definition at line 407 of file wimax-helper.cc.
References ns3::Time::GetSeconds(), ns3::OutputStreamWrapper::GetStream(), and ns3::Simulator::Now().
Referenced by EnableAsciiInternal().
|
staticprivate |
ASCII trace transmit event.
stream | the output stream |
path | the path |
packet | the packet |
dest | the destination MAC address |
Definition at line 416 of file wimax-helper.cc.
References ns3::Time::GetSeconds(), ns3::OutputStreamWrapper::GetStream(), and ns3::Simulator::Now().
Referenced by EnableAsciiInternal().
int64_t ns3::WimaxHelper::AssignStreams | ( | int64_t | stream | ) |
Assign a fixed random variable stream number to the random variables used by this model.
Return the number of streams (possibly zero) that have been assigned.
stream | first stream index to use |
Definition at line 634 of file wimax-helper.cc.
References m_channel, and NS_LOG_FUNCTION.
int64_t ns3::WimaxHelper::AssignStreams | ( | NetDeviceContainer | c, |
int64_t | stream | ||
) |
Assign a fixed random variable stream number to the random variables used by this model.
Return the number of streams (possibly zero) that have been assigned. The Install() method should have previously been called by the user.
c | NetDeviceContainer of the set of net devices for which the WimaxNetDevice should be modified to use a fixed stream |
stream | first stream index to use |
Definition at line 641 of file wimax-helper.cc.
References ns3::NetDeviceContainer::Begin(), ns3::NetDeviceContainer::End(), and m_channel.
Ptr< BSScheduler > ns3::WimaxHelper::CreateBSScheduler | ( | SchedulerType | schedulerType | ) |
schedulerType | Scheduling mechanism |
Creates a downlink scheduler to be used by base station according to selected scheduling mechanism.
Definition at line 184 of file wimax-helper.cc.
References NS_FATAL_ERROR, SCHED_TYPE_MBQOS, SCHED_TYPE_RTPS, and SCHED_TYPE_SIMPLE.
Referenced by Install().
phyType | WiMAX Physical layer type |
Creates a physical layer object to be used in simulation.
Definition at line 74 of file wimax-helper.cc.
References ns3::SimpleOfdmWimaxChannel::COST231_PROPAGATION, m_channel, NS_FATAL_ERROR, third::phy, and SIMPLE_PHY_TYPE_OFDM.
Referenced by Install().
Ptr< WimaxPhy > ns3::WimaxHelper::CreatePhy | ( | PhyType | phyType, |
char * | SNRTraceFilePath, | ||
bool | activateLoss | ||
) |
phyType | WiMAX Physical layer type |
SNRTraceFilePath | the path to the repository containing the SNR traces files |
activateLoss | set to 1 if you want ton activate losses 0 otherwise |
Creates a physical layer
Definition at line 103 of file wimax-helper.cc.
References ns3::SimpleOfdmWimaxChannel::COST231_PROPAGATION, m_channel, NS_FATAL_ERROR, third::phy, and SIMPLE_PHY_TYPE_OFDM.
phyType | WiMAX Physical layer type |
Creates a physical layer without a channel
Definition at line 127 of file wimax-helper.cc.
References NS_FATAL_ERROR, third::phy, and SIMPLE_PHY_TYPE_OFDM.
Referenced by Install().
Ptr< WimaxPhy > ns3::WimaxHelper::CreatePhyWithoutChannel | ( | PhyType | phyType, |
char * | SNRTraceFilePath, | ||
bool | activateLoss | ||
) |
phyType | WiMAX Physical layer type |
SNRTraceFilePath | of the repository containing the SNR traces files |
activateLoss | set to 1 to activate losses 0 otherwise |
Creates a physical layer without creating a channel
Definition at line 143 of file wimax-helper.cc.
References NS_FATAL_ERROR, third::phy, and SIMPLE_PHY_TYPE_OFDM.
ServiceFlow ns3::WimaxHelper::CreateServiceFlow | ( | ServiceFlow::Direction | direction, |
ServiceFlow::SchedulingType | schedulinType, | ||
IpcsClassifierRecord | classifier | ||
) |
Creates a transport service flow.
direction | the direction of the service flow: UP or DOWN. |
schedulinType | The service scheduling type to be used: UGS, RTPS, NRTPS, BE |
classifier | The classifier to be used for this service flow |
Definition at line 422 of file wimax-helper.cc.
References ns3::CsParameters::ADD, ns3::ServiceFlow::IPV4, ns3::ServiceFlow::SetConvergenceSublayerParam(), ns3::ServiceFlow::SetCsSpecification(), ns3::ServiceFlow::SetMaximumLatency(), ns3::ServiceFlow::SetMaxSustainedTrafficRate(), ns3::ServiceFlow::SetMaxTrafficBurst(), ns3::ServiceFlow::SetMinReservedTrafficRate(), ns3::ServiceFlow::SetMinTolerableTrafficRate(), ns3::ServiceFlow::SetRequestTransmissionPolicy(), ns3::ServiceFlow::SetSduSize(), ns3::ServiceFlow::SetServiceSchedulingType(), ns3::ServiceFlow::SetToleratedJitter(), ns3::ServiceFlow::SetTrafficPriority(), and ns3::ServiceFlow::SetUnsolicitedGrantInterval().
Referenced by Ns3WimaxSFTypeTestCase::DoRunOnce(), and Ns3WimaxSchedulingTestCase::DoRunOnce().
Ptr< UplinkScheduler > ns3::WimaxHelper::CreateUplinkScheduler | ( | SchedulerType | schedulerType | ) |
schedulerType | Scheduling mechanism |
Creates a uplink scheduler to be used by base station according to selected scheduling mechanism.
Definition at line 163 of file wimax-helper.cc.
References NS_FATAL_ERROR, SCHED_TYPE_MBQOS, SCHED_TYPE_RTPS, SCHED_TYPE_SIMPLE, and ns3::Seconds().
Referenced by Install().
|
static |
Enable ascii trace output on the indicated net device for a given connection.
oss | The output stream object to use when logging ascii traces. |
nodeid | the id of the node for which you want to enable tracing. |
deviceid | the id of the net device for which you want to enable tracing. |
netdevice | the type of net device for which you want to enable tracing (SubscriberStationNetDevice, BaseStationNetDevice or WimaxNetDevice) |
connection | the connection for which you want to enable tracing (InitialRangingConnection, BroadcastConnection, BasicConnection, PrimaryConnection). |
Definition at line 52 of file wimax-helper.cc.
References ns3::Config::Connect(), ns3::AsciiTraceHelper::DefaultDequeueSinkWithContext(), ns3::AsciiTraceHelper::DefaultDropSinkWithContext(), ns3::AsciiTraceHelper::DefaultEnqueueSinkWithContext(), and ns3::MakeBoundCallback().
Referenced by EnableAsciiInternal().
|
privatevirtual |
Enable ascii trace output on the indicated net device.
NetDevice-specific implementation mechanism for hooking the trace and writing to the trace file.
stream | The output stream object to use when logging ascii traces. |
prefix | Filename prefix to use for ascii trace files. |
nd | Net device for which you want to enable tracing. |
explicitFilename | Treat the prefix as an explicit filename if true |
Implements ns3::AsciiTraceHelperForDevice.
Definition at line 446 of file wimax-helper.cc.
References AsciiRxEvent(), AsciiTxEvent(), ns3::Config::Connect(), ns3::AsciiTraceHelper::CreateFileStream(), ns3::AsciiTraceHelper::DefaultDequeueSinkWithContext(), ns3::AsciiTraceHelper::DefaultDropSinkWithContext(), ns3::AsciiTraceHelper::DefaultEnqueueSinkWithContext(), EnableAsciiForConnection(), ns3::Packet::EnablePrinting(), ns3::AsciiTraceHelper::GetFilenameFromDevice(), ns3::Node::GetId(), ns3::NetDevice::GetIfIndex(), ns3::NetDevice::GetNode(), ns3::Object::GetObject(), ns3::MakeBoundCallback(), and NS_LOG_INFO.
|
static |
Helper to enable all WimaxNetDevice log components with one statement.
Definition at line 363 of file wimax-helper.cc.
References ns3::LOG_LEVEL_ALL, and ns3::LogComponentEnable().
|
privatevirtual |
Enable pcap output on the indicated net device.
NetDevice-specific implementation mechanism for hooking the trace and writing to the trace file.
prefix | Filename prefix to use for pcap files. |
nd | Net device for which you want to enable tracing. |
explicitFilename | Treat the prefix as an explicit filename if true |
promiscuous | If true capture all possible packets available at the device. |
Implements ns3::PcapHelperForDevice.
Definition at line 601 of file wimax-helper.cc.
References ns3::PcapHelper::CreateFile(), ns3::PcapHelper::DLT_EN10MB, create-module::file, ns3::PcapHelper::GetFilenameFromDevice(), ns3::Object::GetObject(), ns3::MakeBoundCallback(), NS_LOG_INFO, ns3::PcapSniffTxRxEvent(), and third::phy.
NetDeviceContainer ns3::WimaxHelper::Install | ( | NodeContainer | c, |
NetDeviceType | deviceType, | ||
PhyType | phyType, | ||
Ptr< WimaxChannel > | channel, | ||
SchedulerType | schedulerType | ||
) |
c | A set of nodes. |
deviceType | Device type to create. |
phyType | PHY type to create. |
channel | A channel to use. |
schedulerType | The scheduling mechanism. |
For each of the input nodes, a new WiMAX net device (either ns3::SubscriberStationNetDevice or ns3::BaseStationNetDevice depending on the type parameter) is attached to the shared input channel.
Definition at line 288 of file wimax-helper.cc.
References ns3::Node::AddDevice(), ns3::Mac48Address::Allocate(), ns3::NodeContainer::Begin(), third::channel, CreateBSScheduler(), CreatePhyWithoutChannel(), CreateUplinkScheduler(), DEVICE_TYPE_BASE_STATION, first::devices, ns3::NodeContainer::End(), and third::phy.
NetDeviceContainer ns3::WimaxHelper::Install | ( | NodeContainer | c, |
NetDeviceType | deviceType, | ||
PhyType | phyType, | ||
SchedulerType | schedulerType, | ||
double | frameDuration | ||
) |
c | A set of nodes. |
deviceType | Device type to create. |
phyType | PHY type to create. |
schedulerType | The scheduling mechanism. |
frameDuration | the farme duration in seconds |
For each of the input nodes, a new WiMAX net device (either ns3::SubscriberStationNetDevice or ns3::BaseStationNetDevice depending on the type parameter) is attached to the shared input channel.
Definition at line 205 of file wimax-helper.cc.
References ns3::Node::AddDevice(), ns3::Mac48Address::Allocate(), ns3::NodeContainer::Begin(), CreateBSScheduler(), CreatePhy(), CreateUplinkScheduler(), DEVICE_TYPE_BASE_STATION, first::devices, ns3::NodeContainer::End(), m_channel, third::phy, and ns3::Seconds().
NetDeviceContainer ns3::WimaxHelper::Install | ( | NodeContainer | c, |
NetDeviceType | type, | ||
PhyType | phyType, | ||
SchedulerType | schedulerType | ||
) |
c | a set of nodes |
type | device type to create |
phyType | a phy to use |
schedulerType | the type of the scheduling algorithm to install |
For each of the input nodes, a new WiMAX net device (either ns3::SubscriberStationNetDevice or ns3::BaseStationNetDevice depending on the type parameter) is attached to the shared input channel.
Definition at line 249 of file wimax-helper.cc.
References ns3::Node::AddDevice(), ns3::Mac48Address::Allocate(), ns3::NodeContainer::Begin(), CreateBSScheduler(), CreatePhy(), CreateUplinkScheduler(), DEVICE_TYPE_BASE_STATION, first::devices, ns3::NodeContainer::End(), m_channel, and third::phy.
Referenced by Ns3WimaxNetworkEntryTestCase::DoRun(), Ns3WimaxManagementConnectionsTestCase::DoRun(), Ns3WimaxSfCreationTestCase::DoRun(), Ns3WimaxSimpleOFDMTestCase::DoRunOnce(), Ns3WimaxSFTypeTestCase::DoRunOnce(), and Ns3WimaxSchedulingTestCase::DoRunOnce().
Ptr< WimaxNetDevice > ns3::WimaxHelper::Install | ( | Ptr< Node > | node, |
NetDeviceType | deviceType, | ||
PhyType | phyType, | ||
Ptr< WimaxChannel > | channel, | ||
SchedulerType | schedulerType | ||
) |
node | Node to be installed. |
deviceType | Device type to create. |
phyType | PHY type to create. |
channel | A channel to use. |
schedulerType | The scheduling mechanism to install on the device. |
For each of the input nodes, a new WiMAX net device (either ns3::SubscriberStationNetDevice or ns3::BaseStationNetDevice depending on the type parameter) is attached to the shared input channel.
Definition at line 327 of file wimax-helper.cc.
References ns3::Node::AddDevice(), ns3::Mac48Address::Allocate(), third::channel, CreateBSScheduler(), CreatePhyWithoutChannel(), CreateUplinkScheduler(), DEVICE_TYPE_BASE_STATION, and third::phy.
void ns3::WimaxHelper::SetPropagationLossModel | ( | SimpleOfdmWimaxChannel::PropModel | propagationModel | ) |
Set the propagation and loss model of the channel.
By default the channel uses a COST231 propagation and loss model.
propagationModel | The propagation and loss model to set |
Definition at line 94 of file wimax-helper.cc.
References m_channel.
|
private |
wifi channel
Definition at line 326 of file wimax-helper.h.
Referenced by AssignStreams(), CreatePhy(), Install(), and SetPropagationLossModel().