21 #include "ns3/core-module.h"
22 #include "ns3/applications-module.h"
23 #include "ns3/wifi-module.h"
24 #include "ns3/mobility-module.h"
25 #include "ns3/internet-module.h"
65 int main (
int argc,
char *argv[])
67 uint32_t payloadSize = 1472;
68 uint64_t simulationTime = 10;
72 bool verifyResults = 0;
75 cmd.
AddValue (
"payloadSize",
"Payload size in bytes", payloadSize);
76 cmd.
AddValue (
"enableRts",
"Enable or disable RTS/CTS", enableRts);
77 cmd.
AddValue (
"simulationTime",
"Simulation time in seconds", simulationTime);
78 cmd.
AddValue (
"distance",
"Distance in meters between the station and the access point", distance);
79 cmd.
AddValue (
"enablePcap",
"Enable/disable pcap file generation", enablePcap);
80 cmd.
AddValue (
"verifyResults",
"Enable/disable results verification at the end of the simulation", verifyResults);
81 cmd.
Parse (argc, argv);
100 NetDeviceContainer staDeviceA, staDeviceB, staDeviceC, staDeviceD, apDeviceA, apDeviceB, apDeviceC, apDeviceD;
104 ssid =
Ssid (
"network-A");
106 mac.
SetType (
"ns3::StaWifiMac",
108 staDeviceA = wifi.
Install (phy, mac, wifiStaNodes.
Get (0));
113 apDeviceA = wifi.
Install (phy, mac, wifiApNodes.
Get (0));
116 ssid =
Ssid (
"network-B");
118 mac.
SetType (
"ns3::StaWifiMac",
122 staDeviceB = wifi.
Install (phy, mac, wifiStaNodes.
Get (1));
127 apDeviceB = wifi.
Install (phy, mac, wifiApNodes.
Get (1));
130 ssid =
Ssid (
"network-C");
132 mac.
SetType (
"ns3::StaWifiMac",
137 staDeviceC = wifi.
Install (phy, mac, wifiStaNodes.
Get (2));
142 apDeviceC = wifi.
Install (phy, mac, wifiApNodes.
Get (2));
145 ssid =
Ssid (
"network-D");
147 mac.
SetType (
"ns3::StaWifiMac",
152 staDeviceD = wifi.
Install (phy, mac, wifiStaNodes.
Get (3));
157 apDeviceD = wifi.
Install (phy, mac, wifiApNodes.
Get (3));
165 positionAlloc->
Add (Vector (0.0, 0.0, 0.0));
166 positionAlloc->
Add (Vector (10.0, 0.0, 0.0));
167 positionAlloc->
Add (Vector (20.0, 0.0, 0.0));
168 positionAlloc->
Add (Vector (30.0, 0.0, 0.0));
170 positionAlloc->
Add (Vector (distance, 0.0, 0.0));
171 positionAlloc->
Add (Vector (10 + distance, 0.0, 0.0));
172 positionAlloc->
Add (Vector (20 + distance, 0.0, 0.0));
173 positionAlloc->
Add (Vector (30 + distance, 0.0, 0.0));
176 mobility.
Install (wifiApNodes);
177 mobility.
Install (wifiStaNodes);
185 address.
SetBase (
"192.168.1.0",
"255.255.255.0");
187 StaInterfaceA = address.
Assign (staDeviceA);
189 ApInterfaceA = address.
Assign (apDeviceA);
191 address.
SetBase (
"192.168.2.0",
"255.255.255.0");
193 StaInterfaceB = address.
Assign (staDeviceB);
195 ApInterfaceB = address.
Assign (apDeviceB);
197 address.
SetBase (
"192.168.3.0",
"255.255.255.0");
199 StaInterfaceC = address.
Assign (staDeviceC);
201 ApInterfaceC = address.
Assign (apDeviceC);
203 address.
SetBase (
"192.168.4.0",
"255.255.255.0");
205 StaInterfaceD = address.
Assign (staDeviceD);
207 ApInterfaceD = address.
Assign (apDeviceD);
218 clientA.SetAttribute (
"Interval",
TimeValue (
Time (
"0.00002")));
219 clientA.SetAttribute (
"PacketSize",
UintegerValue (payloadSize));
232 clientB.SetAttribute (
"Interval",
TimeValue (
Time (
"0.00002")));
233 clientB.SetAttribute (
"PacketSize",
UintegerValue (payloadSize));
246 clientC.SetAttribute (
"Interval",
TimeValue (
Time (
"0.00002")));
247 clientC.SetAttribute (
"PacketSize",
UintegerValue (payloadSize));
260 clientD.SetAttribute (
"Interval",
TimeValue (
Time (
"0.00002")));
261 clientD.SetAttribute (
"PacketSize",
UintegerValue (payloadSize));
284 uint64_t totalPacketsThrough = DynamicCast<UdpServer> (serverAppA.
Get (0))->GetReceived ();
285 double throughput = totalPacketsThrough * payloadSize * 8 / (simulationTime * 1000000.0);
286 std::cout <<
"Throughput with default configuration (A-MPDU aggregation enabled, 65kB): " << throughput <<
" Mbit/s" <<
'\n';
287 if (verifyResults && (throughput < 59 || throughput > 60))
289 NS_LOG_ERROR (
"Obtained throughput " << throughput <<
" is not in the expected boundaries!");
293 totalPacketsThrough = DynamicCast<UdpServer> (serverAppB.
Get (0))->GetReceived ();
294 throughput = totalPacketsThrough * payloadSize * 8 / (simulationTime * 1000000.0);
295 std::cout <<
"Throughput with aggregation disabled: " << throughput <<
" Mbit/s" <<
'\n';
296 if (verifyResults && (throughput < 30 || throughput > 30.5))
298 NS_LOG_ERROR (
"Obtained throughput " << throughput <<
" is not in the expected boundaries!");
302 totalPacketsThrough = DynamicCast<UdpServer> (serverAppC.
Get (0))->GetReceived ();
303 throughput = totalPacketsThrough * payloadSize * 8 / (simulationTime * 1000000.0);
304 std::cout <<
"Throughput with A-MPDU disabled and A-MSDU enabled (8kB): " << throughput <<
" Mbit/s" <<
'\n';
305 if (verifyResults && (throughput < 51 || throughput > 52))
307 NS_LOG_ERROR (
"Obtained throughput " << throughput <<
" is not in the expected boundaries!");
311 totalPacketsThrough = DynamicCast<UdpServer> (serverAppD.
Get (0))->GetReceived ();
312 throughput = totalPacketsThrough * payloadSize * 8 / (simulationTime * 1000000.0);
313 std::cout <<
"Throughput with A-MPDU enabled (32kB) and A-MSDU enabled (4kB): " << throughput <<
" Mbit/s" <<
'\n';
314 if (verifyResults && (throughput < 58 || throughput > 59))
316 NS_LOG_ERROR (
"Obtained throughput " << throughput <<
" is not in the expected boundaries!");
void Set(std::string name, const AttributeValue &v)
holds a vector of ns3::Application pointers.
Simulation virtual time values and global simulation resolution.
Smart pointer class similar to boost::intrusive_ptr.
AttributeValue implementation for Boolean.
HT PHY for the 5 GHz band (clause 20)
holds a vector of std::pair of Ptr and interface index.
Ptr< YansWifiChannel > Create(void) const
void SetRemoteStationManager(std::string type, std::string n0="", const AttributeValue &v0=EmptyAttributeValue(), std::string n1="", const AttributeValue &v1=EmptyAttributeValue(), std::string n2="", const AttributeValue &v2=EmptyAttributeValue(), std::string n3="", const AttributeValue &v3=EmptyAttributeValue(), std::string n4="", const AttributeValue &v4=EmptyAttributeValue(), std::string n5="", const AttributeValue &v5=EmptyAttributeValue(), std::string n6="", const AttributeValue &v6=EmptyAttributeValue(), std::string n7="", const AttributeValue &v7=EmptyAttributeValue())
Hold variables of type string.
Ptr< NetDevice > Get(uint32_t i) const
Get the Ptr stored in this container at a given index.
Make it easy to create and manage PHY objects for the yans model.
static YansWifiChannelHelper Default(void)
Create a channel helper in a default working state.
static void Run(void)
Run the simulation.
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
aggregate IP/TCP/UDP functionality to existing Nodes.
static YansWifiPhyHelper Default(void)
Create a phy helper in a default working state.
helps to create WifiNetDevice objects
virtual void SetStandard(WifiPhyStandard standard)
void SetChannel(Ptr< YansWifiChannel > channel)
void Install(Ptr< Node > node) const
"Layout" a single node according to the current position allocator type.
Create a client application which sends UDP packets carrying a 32bit sequence number and a 64 bit tim...
AttributeValue implementation for Time.
Hold an unsigned integer type.
holds a vector of ns3::NetDevice pointers
Create a server application which waits for input UDP packets and uses the information carried into t...
virtual NetDeviceContainer Install(const WifiPhyHelper &phy, const WifiMacHelper &mac, NodeContainer::Iterator first, NodeContainer::Iterator last) const
void Start(Time start)
Arrange for all of the Applications in this container to Start() at the Time given as a parameter...
Parse command-line arguments.
static void Destroy(void)
Execute the events scheduled with ScheduleDestroy().
void SetAttribute(std::string name, const AttributeValue &value)
Record an attribute to be set in each Application after it is is created.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
keep track of a set of node pointers.
Ptr< Application > Get(uint32_t i) const
Get the Ptr
stored in this container at a given index.
void SetMobilityModel(std::string type, std::string n1="", const AttributeValue &v1=EmptyAttributeValue(), std::string n2="", const AttributeValue &v2=EmptyAttributeValue(), std::string n3="", const AttributeValue &v3=EmptyAttributeValue(), std::string n4="", const AttributeValue &v4=EmptyAttributeValue(), std::string n5="", const AttributeValue &v5=EmptyAttributeValue(), std::string n6="", const AttributeValue &v6=EmptyAttributeValue(), std::string n7="", const AttributeValue &v7=EmptyAttributeValue(), std::string n8="", const AttributeValue &v8=EmptyAttributeValue(), std::string n9="", const AttributeValue &v9=EmptyAttributeValue())
void Install(std::string nodeName) const
Aggregate implementations of the ns3::Ipv4, ns3::Ipv6, ns3::Udp, and ns3::Tcp classes onto the provid...
manage and create wifi channel objects for the yans model.
create MAC layers for a ns3::WifiNetDevice.
void SetPcapDataLinkType(SupportedPcapDataLinkTypes dlt)
Set the data link type of PCAP traces to be used.
The IEEE 802.11 SSID Information Element.
virtual void SetType(std::string type, std::string n0="", const AttributeValue &v0=EmptyAttributeValue(), std::string n1="", const AttributeValue &v1=EmptyAttributeValue(), std::string n2="", const AttributeValue &v2=EmptyAttributeValue(), std::string n3="", const AttributeValue &v3=EmptyAttributeValue(), std::string n4="", const AttributeValue &v4=EmptyAttributeValue(), std::string n5="", const AttributeValue &v5=EmptyAttributeValue(), std::string n6="", const AttributeValue &v6=EmptyAttributeValue(), std::string n7="", const AttributeValue &v7=EmptyAttributeValue(), std::string n8="", const AttributeValue &v8=EmptyAttributeValue(), std::string n9="", const AttributeValue &v9=EmptyAttributeValue(), std::string n10="", const AttributeValue &v10=EmptyAttributeValue())
Helper class used to assign positions and mobility models to nodes.
void Stop(Time stop)
Arrange for all of the Applications in this container to Stop() at the Time given as a parameter...
Ipv4InterfaceContainer Assign(const NetDeviceContainer &c)
Assign IP addresses to the net devices specified in the container based on the current network prefix...
void AddValue(const std::string &name, const std::string &help, T &value)
Add a program argument, assigning to POD.
static void Stop(void)
Tell the Simulator the calling event should be the last one executed.
Ptr< Node > Get(uint32_t i) const
Get the Ptr stored in this container at a given index.
Time Seconds(double value)
Construct a Time in the indicated unit.
AttributeValue implementation for Ssid.
void SetDefault(std::string name, const AttributeValue &value)
void Add(Vector v)
Add a position to the list of positions.
void Parse(int argc, char *argv[])
Parse the program arguments.
A helper class to make life easier while doing simple IPv4 address assignment in scripts.
#define NS_LOG_ERROR(msg)
Use NS_LOG to output a message of level LOG_ERROR.
void Create(uint32_t n)
Create n nodes and append pointers to them to the end of this NodeContainer.
void EnablePcap(std::string prefix, Ptr< NetDevice > nd, bool promiscuous=false, bool explicitFilename=false)
Enable pcap output the indicated net device.
void SetPositionAllocator(Ptr< PositionAllocator > allocator)
Set the position allocator which will be used to allocate the initial position of every node initiali...
Include Radiotap link layer information.
void SetBase(Ipv4Address network, Ipv4Mask mask, Ipv4Address base="0.0.0.1")
Set the base network number, network mask and base address.
Ipv4Address GetAddress(uint32_t i, uint32_t j=0) const