27 #include "ns3/command-line.h" 28 #include "ns3/config.h" 29 #include "ns3/uinteger.h" 30 #include "ns3/boolean.h" 31 #include "ns3/double.h" 32 #include "ns3/string.h" 34 #include "ns3/yans-wifi-helper.h" 35 #include "ns3/spectrum-wifi-helper.h" 37 #include "ns3/mobility-helper.h" 38 #include "ns3/internet-stack-helper.h" 39 #include "ns3/ipv4-address-helper.h" 40 #include "ns3/udp-client-server-helper.h" 41 #include "ns3/yans-wifi-channel.h" 42 #include "ns3/multi-model-spectrum-channel.h" 43 #include "ns3/propagation-loss-model.h" 98 int main (
int argc,
char *argv[])
101 double simulationTime = 10;
102 uint16_t index = 256;
103 uint32_t channelWidth = 0;
104 std::string wifiType =
"ns3::SpectrumWifiPhy";
105 std::string errorModelType =
"ns3::NistErrorRateModel";
109 cmd.AddValue (
"simulationTime",
"Simulation time in seconds", simulationTime);
110 cmd.AddValue (
"distance",
"meters separation between nodes", distance);
111 cmd.AddValue (
"index",
"restrict index to single value between 0 and 63", index);
112 cmd.AddValue (
"wifiType",
"select ns3::SpectrumWifiPhy or ns3::YansWifiPhy", wifiType);
113 cmd.AddValue (
"errorModelType",
"select ns3::NistErrorRateModel or ns3::YansErrorRateModel", errorModelType);
114 cmd.AddValue (
"enablePcap",
"enable pcap output",
enablePcap);
115 cmd.Parse (argc,argv);
117 uint16_t startIndex = 0;
118 uint16_t stopIndex = 63;
125 std::cout <<
"wifiType: " << wifiType <<
" distance: " << distance <<
"m" << std::endl;
126 std::cout << std::setw (5) <<
"index" <<
127 std::setw (6) <<
"MCS" <<
128 std::setw (8) <<
"width" <<
129 std::setw (12) <<
"Rate (Mb/s)" <<
130 std::setw (12) <<
"Tput (Mb/s)" <<
131 std::setw (10) <<
"Received " <<
133 for (uint16_t i = startIndex; i <= stopIndex; i++)
135 uint32_t payloadSize;
145 if (wifiType ==
"ns3::YansWifiPhy")
148 channel.AddPropagationLoss (
"ns3::FriisPropagationLossModel");
149 channel.SetPropagationDelay (
"ns3::ConstantSpeedPropagationDelayModel");
159 else if (i > 7 && i <= 15)
164 else if (i > 15 && i <= 23)
169 else if (i > 23 && i <= 31)
174 else if (i > 31 && i <= 39)
182 else if (i > 39 && i <= 47)
190 else if (i > 47 && i <= 55)
198 else if (i > 55 && i <= 63)
207 else if (wifiType ==
"ns3::SpectrumWifiPhy")
213 = CreateObject<MultiModelSpectrumChannel> ();
215 = CreateObject<FriisPropagationLossModel> ();
219 = CreateObject<ConstantSpeedPropagationDelayModel> ();
233 else if (i > 7 && i <= 15)
238 else if (i > 15 && i <= 23)
243 else if (i > 23 && i <= 31)
248 else if (i > 31 && i <= 39)
256 else if (i > 39 && i <= 47)
264 else if (i > 47 && i <= 55)
272 else if (i > 55 && i <= 63)
619 wifi.SetRemoteStationManager (
"ns3::ConstantRateWifiManager",
"DataMode",
DataRate,
625 if (wifiType ==
"ns3::YansWifiPhy")
627 mac.SetType (
"ns3::StaWifiMac",
629 staDevice =
wifi.Install (
phy,
mac, wifiStaNode);
630 mac.SetType (
"ns3::ApWifiMac",
635 else if (wifiType ==
"ns3::SpectrumWifiPhy")
637 mac.SetType (
"ns3::StaWifiMac",
639 staDevice =
wifi.Install (spectrumPhy,
mac, wifiStaNode);
640 mac.SetType (
"ns3::ApWifiMac",
653 positionAlloc->
Add (Vector (0.0, 0.0, 0.0));
654 positionAlloc->
Add (Vector (distance, 0.0, 0.0));
655 mobility.SetPositionAllocator (positionAlloc);
657 mobility.SetMobilityModel (
"ns3::ConstantPositionMobilityModel");
665 stack.Install (wifiStaNode);
668 address.SetBase (
"192.168.1.0",
"255.255.255.0");
672 staNodeInterface =
address.Assign (staDevice);
673 apNodeInterface =
address.Assign (apDevice);
684 client.SetAttribute (
"Interval",
TimeValue (
Time (
"0.00002")));
685 client.SetAttribute (
"PacketSize",
UintegerValue (payloadSize));
692 std::stringstream ss;
693 ss <<
"wifi-spectrum-saturation-example-" << i;
694 phy.EnablePcap (ss.str (), apDevice);
701 uint64_t totalPacketsThrough;
702 totalPacketsThrough = DynamicCast<UdpServer> (serverApp.
Get (0))->GetReceived ();
703 throughput = totalPacketsThrough * payloadSize * 8 / (simulationTime * 1000000.0);
704 std::cout << std::setw (5) << i <<
705 std::setw (6) << (i % 8) + 8 * (i / 32) <<
706 std::setw (8) << channelWidth <<
707 std::setw (10) << datarate <<
708 std::setw (12) << throughput <<
709 std::setw (8) << totalPacketsThrough <<
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<Ipv4> and interface index.
Hold variables of type string.
Make it easy to create and manage PHY objects for the yans model.
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.
#define NS_FATAL_ERROR(msg)
Report a fatal error with a message and terminate.
static YansWifiPhyHelper Default(void)
Create a phy helper in a default working state.
void AddPropagationLossModel(Ptr< PropagationLossModel > loss)
Add the single-frequency propagation loss model to be used.
helps to create WifiNetDevice objects
Class for representing data rates.
Create a client application which sends UDP packets carrying a 32bit sequence number and a 64 bit tim...
static SpectrumWifiPhyHelper Default(void)
Create a phy helper in a default working state.
AttributeValue implementation for Time.
Ipv4Address GetAddress(uint32_t i, uint32_t j=0) const
void SetChannel(Ptr< SpectrumChannel > channel)
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().
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.
manage and create wifi channel objects for the yans model.
create MAC layers for a ns3::WifiNetDevice.
void SetErrorRateModel(std::string name, 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())
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.
void SetPropagationDelayModel(Ptr< PropagationDelayModel > delay)
Set the propagation delay model to be used.
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.
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.
void Create(uint32_t n)
Create n nodes and append pointers to them to the end of this NodeContainer.
This class can be used to hold variables of floating point type such as 'double' or 'float'...
Ptr< Application > Get(uint32_t i) const
Get the Ptr<Application> stored in this container at a given index.
Make it easy to create and manage PHY objects for the spectrum model.