30 #include "ns3/boolean.h"
31 #include "ns3/command-line.h"
32 #include "ns3/config.h"
33 #include "ns3/constant-position-mobility-model.h"
34 #include "ns3/flow-monitor-helper.h"
35 #include "ns3/internet-stack-helper.h"
36 #include "ns3/ipv4-address-helper.h"
37 #include "ns3/ipv4-flow-classifier.h"
38 #include "ns3/on-off-helper.h"
39 #include "ns3/propagation-delay-model.h"
40 #include "ns3/propagation-loss-model.h"
41 #include "ns3/string.h"
42 #include "ns3/udp-echo-helper.h"
43 #include "ns3/uinteger.h"
44 #include "ns3/yans-wifi-channel.h"
45 #include "ns3/yans-wifi-helper.h"
67 for (uint8_t i = 0; i < 3; ++i)
74 lossModel->SetDefaultLoss(200);
84 wifiChannel->SetPropagationLossModel(lossModel);
85 wifiChannel->SetPropagationDelayModel(CreateObject<ConstantSpeedPropagationDelayModel>());
90 wifi.SetRemoteStationManager(
"ns3::" + wifiManager +
"WifiManager");
94 wifiMac.
SetType(
"ns3::AdhocWifiMac");
110 ipv4.SetBase(
"10.0.0.0",
"255.0.0.0");
115 uint16_t cbrPort = 12345;
141 uint16_t echoPort = 9;
163 monitor->CheckForLostPackets();
166 for (
auto i = stats.begin(); i != stats.end(); ++i)
177 std::cout <<
"Flow " << i->first - 2 <<
" (" << t.
sourceAddress <<
" -> "
179 std::cout <<
" Tx Packets: " << i->second.txPackets <<
"\n";
180 std::cout <<
" Tx Bytes: " << i->second.txBytes <<
"\n";
181 std::cout <<
" TxOffered: " << i->second.txBytes * 8.0 / 9.0 / 1000 / 1000
183 std::cout <<
" Rx Packets: " << i->second.rxPackets <<
"\n";
184 std::cout <<
" Rx Bytes: " << i->second.rxBytes <<
"\n";
185 std::cout <<
" Throughput: " << i->second.rxBytes * 8.0 / 9.0 / 1000 / 1000
195 main(
int argc,
char** argv)
197 std::string wifiManager(
"Arf");
201 "Set wifi rate manager (Aarf, Aarfcd, Amrr, Arf, Cara, Ideal, Minstrel, Onoe, Rraa)",
203 cmd.Parse(argc, argv);
205 std::cout <<
"Hidden station experiment with RTS/CTS disabled:\n" << std::flush;
207 std::cout <<
"------------------------------------------------\n";
208 std::cout <<
"Hidden station experiment with RTS/CTS enabled:\n";
holds a vector of ns3::Application pointers.
void Add(ApplicationContainer other)
Append the contents of another ApplicationContainer to the end of this container.
Parse command-line arguments.
Helper to enable IP flow monitoring on a set of Nodes.
Ptr< FlowClassifier > GetClassifier()
Retrieve the FlowClassifier object for IPv4 created by the Install* methods.
Ptr< FlowMonitor > InstallAll()
Enable flow monitoring on all nodes.
std::map< FlowId, FlowStats > FlowStatsContainer
Container: FlowId, FlowStats.
aggregate IP/TCP/UDP functionality to existing Nodes.
A helper class to make life easier while doing simple IPv4 address assignment in scripts.
Ipv4 addresses are stored in host order in this class.
Keep track of the current position and velocity of an object.
holds a vector of ns3::NetDevice pointers
keep track of a set of node pointers.
void Create(uint32_t n)
Create n nodes and append pointers to them to the end of this NodeContainer.
Ptr< Node > Get(uint32_t i) const
Get the Ptr<Node> stored in this container at a given index.
Ptr< T > GetObject() const
Get a pointer to the requested aggregated Object.
void AggregateObject(Ptr< Object > other)
Aggregate two Objects together.
A helper to make it easier to instantiate an ns3::OnOffApplication on a set of nodes.
Smart pointer class similar to boost::intrusive_ptr.
static void Destroy()
Execute the events scheduled with ScheduleDestroy().
static void Run()
Run the simulation.
static void Stop()
Tell the Simulator the calling event should be the last one executed.
Hold variables of type string.
Create an application which sends a UDP packet and waits for an echo of this packet.
void SetAttribute(std::string name, const AttributeValue &value)
Record an attribute to be set in each Application after it is is created.
ApplicationContainer Install(Ptr< Node > node) const
Create a udp echo client application on the specified node.
Hold an unsigned integer type.
helps to create WifiNetDevice objects
create MAC layers for a ns3::WifiNetDevice.
void SetType(std::string type, Args &&... args)
Make it easy to create and manage PHY objects for the YANS model.
void SetChannel(Ptr< YansWifiChannel > channel)
void SetDefault(std::string name, const AttributeValue &value)
Time Seconds(double value)
Construct a Time in the indicated unit.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
Structure to classify a packet.
Ipv4Address sourceAddress
Source address.
Ipv4Address destinationAddress
Destination address.
void experiment(bool enableCtsRts, std::string wifiManager)
Run single 10 seconds experiment.