21 #include "ns3/command-line.h" 22 #include "ns3/config.h" 23 #include "ns3/uinteger.h" 25 #include "ns3/yans-wifi-helper.h" 27 #include "ns3/mobility-helper.h" 28 #include "ns3/internet-stack-helper.h" 29 #include "ns3/ipv4-address-helper.h" 30 #include "ns3/udp-client-server-helper.h" 31 #include "ns3/packet-sink-helper.h" 32 #include "ns3/ipv4-global-routing-helper.h" 33 #include "ns3/yans-wifi-channel.h" 65 else if (
version ==
"80211_10MHZ")
69 else if (
version ==
"80211_5MHZ")
77 else if (
version ==
"80211n_2_4GHZ")
81 else if (
version ==
"80211n_5GHZ")
96 int main (
int argc,
char *argv[])
98 uint32_t payloadSize = 1472;
99 double simulationTime = 10;
100 std::string apVersion =
"80211a";
101 std::string staVersion =
"80211n_5GHZ";
102 std::string apRaa =
"Minstrel";
103 std::string staRaa =
"MinstrelHt";
104 bool apHasTraffic =
false;
105 bool staHasTraffic =
true;
108 cmd.AddValue (
"simulationTime",
"Simulation time in seconds", simulationTime);
109 cmd.AddValue (
"apVersion",
"The standard version used by the AP: 80211a, 80211b, 80211g, 80211_10MHZ, 80211_5MHZ, holland, 80211n_2_4GHZ, 80211n_5GHZ or 80211ac", apVersion);
110 cmd.AddValue (
"staVersion",
"The standard version used by the station: 80211a, 80211b, 80211g, 80211_10MHZ, 80211_5MHZ, holland, 80211n_2_4GHZ, 80211n_5GHZ or 80211ac", staVersion);
111 cmd.AddValue (
"apRaa",
"Rate adaptation algorithm used by the AP", apRaa);
112 cmd.AddValue (
"staRaa",
"Rate adaptation algorithm used by the station", staRaa);
113 cmd.AddValue (
"apHasTraffic",
"Enable/disable traffic on the AP", apHasTraffic);
114 cmd.AddValue (
"staHasTraffic",
"Enable/disable traffic on the station", staHasTraffic);
115 cmd.Parse (argc,argv);
131 wifi.SetRemoteStationManager (
"ns3::" + staRaa +
"WifiManager");
133 mac.SetType (
"ns3::StaWifiMac",
137 staDevice =
wifi.Install (
phy,
mac, wifiStaNode);
140 wifi.SetRemoteStationManager (
"ns3::" + apRaa +
"WifiManager");
142 mac.SetType (
"ns3::ApWifiMac",
149 if (staVersion ==
"80211ac")
154 if (apVersion ==
"80211ac")
162 positionAlloc->
Add (Vector (0.0, 0.0, 0.0));
163 positionAlloc->
Add (Vector (5.0, 0.0, 0.0));
164 mobility.SetPositionAllocator (positionAlloc);
165 mobility.SetMobilityModel (
"ns3::ConstantPositionMobilityModel");
171 stack.Install (wifiStaNode);
174 address.SetBase (
"192.168.1.0",
"255.255.255.0");
178 staNodeInterface =
address.Assign (staDevice);
179 apNodeInterface =
address.Assign (apDevice);
195 apClient.SetAttribute (
"Interval",
TimeValue (
Time (
"0.00001")));
196 apClient.SetAttribute (
"PacketSize",
UintegerValue (payloadSize));
206 staClient.SetAttribute (
"Interval",
TimeValue (
Time (
"0.00001")));
207 staClient.SetAttribute (
"PacketSize",
UintegerValue (payloadSize));
223 rxBytes = payloadSize * DynamicCast<UdpServer> (staServerApp.
Get (0))->GetReceived ();
224 throughput = (rxBytes * 8) / (simulationTime * 1000000.0);
225 std::cout <<
"AP Throughput: " << throughput <<
" Mbit/s" << std::endl;
233 rxBytes = payloadSize * DynamicCast<UdpServer> (apServerApp.
Get (0))->GetReceived ();
234 throughput = (rxBytes * 8) / (simulationTime * 1000000.0);
235 std::cout <<
"STA Throughput: " << throughput <<
" Mbit/s" << std::endl;
ERP-OFDM PHY (Clause 19, Section 19.5)
holds a vector of ns3::Application pointers.
Simulation virtual time values and global simulation resolution.
Smart pointer class similar to boost::intrusive_ptr.
OFDM PHY for the 5 GHz band (Clause 17 with 5 MHz channel bandwidth)
HT PHY for the 5 GHz band (clause 20)
holds a vector of std::pair of Ptr<Ipv4> and interface index.
static void PopulateRoutingTables(void)
Build a routing database and initialize the routing tables of the nodes in the simulation.
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.
void Set(std::string path, const AttributeValue &value)
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.
OFDM PHY for the 5 GHz band (Clause 17 with 10 MHz channel bandwidth)
HT PHY for the 2.4 GHz band (clause 20)
static YansWifiPhyHelper Default(void)
Create a phy helper in a default working state.
helps to create WifiNetDevice objects
WifiPhyStandard
Identifies the PHY specification that a Wifi device is configured to use.
Create a client application which sends UDP packets carrying a 32bit sequence number and a 64 bit tim...
AttributeValue implementation for Time.
Ipv4Address GetAddress(uint32_t i, uint32_t j=0) const
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...
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().
This is intended to be the configuration used in this paper: Gavin Holland, Nitin Vaidya and Paramvir...
void SetAttribute(std::string name, const AttributeValue &value)
Record an attribute to be set in each Application after it is is created.
OFDM PHY for the 5 GHz band (Clause 17)
Every class exported by the ns3 library is enclosed in the ns3 namespace.
keep track of a set of node pointers.
DSSS PHY (Clause 15) and HR/DSSS PHY (Clause 18)
manage and create wifi channel objects for the yans model.
create MAC layers for a ns3::WifiNetDevice.
The IEEE 802.11 SSID Information Element.
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...
static void Stop(void)
Tell the Simulator the calling event should be the last one executed.
Time Seconds(double value)
Construct a Time in the indicated unit.
AttributeValue implementation for Ssid.
void Add(Vector v)
Add a position to the list of positions.
Ptr< Node > Get(uint32_t i) const
Get the Ptr<Node> stored in this container at a given index.
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.
Ptr< Application > Get(uint32_t i) const
Get the Ptr<Application> stored in this container at a given index.
WifiPhyStandard ConvertStringToStandard(std::string version)