20#include "ns3/command-line.h"
21#include "ns3/config.h"
22#include "ns3/double.h"
23#include "ns3/gnuplot.h"
24#include "ns3/internet-stack-helper.h"
25#include "ns3/ipv4-address-helper.h"
27#include "ns3/mobility-helper.h"
28#include "ns3/mobility-model.h"
29#include "ns3/string.h"
30#include "ns3/yans-wifi-channel.h"
31#include "ns3/yans-wifi-helper.h"
129 while ((packet = socket->Recv()))
154 socket->Send(Create<Packet>(
pktSize));
184 phy.SetChannel(wifiChannel.
Create());
191 positionAlloc->Add(Vector(0.0, 0.0, 0.0));
192 positionAlloc->Add(Vector(5.0, 0.0, 0.0));
193 mobility.SetPositionAllocator(positionAlloc);
194 mobility.SetMobilityModel(
"ns3::ConstantPositionMobilityModel");
199 ipv4.
SetBase(
"10.1.1.0",
"255.255.255.0");
207 source->SetAllowBroadcast(
true);
208 source->Connect(remote);
218 interPacketInterval);
227main(
int argc,
char* argv[])
229 std::ofstream outfile(
"clear-channel.plt");
231 const std::vector<std::string> modes{
239 cmd.Parse(argc, argv);
243 for (
uint32_t i = 0; i < modes.size(); i++)
245 std::cout << modes[i] << std::endl;
248 for (
double rss = -102.0; rss <= -80.0; rss += 0.5)
258 wifi.SetRemoteStationManager(
"ns3::ConstantRateWifiManager",
263 wifiMac.
SetType(
"ns3::AdhocWifiMac");
277 dataset.Add(rss, pktsRecvd);
282 gnuplot.
SetTerminal(
"postscript eps color enh \"Times-BoldItalic\"");
283 gnuplot.
SetLegend(
"RSS(dBm)",
"Number of packets received");
284 gnuplot.
SetExtra(
"set xrange [-102:-83]");
WiFi adhoc experiment class.
uint32_t Run(const WifiHelper &wifi, const YansWifiPhyHelper &wifiPhy, const WifiMacHelper &wifiMac, const YansWifiChannelHelper &wifiChannel)
Run an experiment.
void GenerateTraffic(Ptr< Socket > socket, uint32_t pktSize, uint32_t pktCount, Time pktInterval)
Generate the traffic.
void ReceivePacket(Ptr< Socket > socket)
Receive a packet.
void SetPosition(Ptr< Node > node, Vector position)
Set the position of a node.
Gnuplot2dDataset m_output
The output dataset.
Ptr< Socket > SetupPacketReceive(Ptr< Node > node)
Setup the receiving socket.
uint32_t m_pktsTotal
Total number of received packets.
Experiment(std::string name)
Constructor.
Vector GetPosition(Ptr< Node > node)
Get the position of a node.
Parse command-line arguments.
This class can be used to hold variables of floating point type such as 'double' or 'float'.
Class to represent a 2D points plot.
void SetStyle(Style style)
a simple class to generate gnuplot-ready plotting commands from a set of datasets.
void AddDataset(const GnuplotDataset &dataset)
void SetLegend(const std::string &xLegend, const std::string &yLegend)
void SetTerminal(const std::string &terminal)
void GenerateOutput(std::ostream &os)
Writes gnuplot commands and data values to a single output stream.
void SetExtra(const std::string &extra)
aggregate IP/TCP/UDP functionality to existing Nodes.
void Install(std::string nodeName) const
Aggregate implementations of the ns3::Ipv4, ns3::Ipv6, ns3::Udp, and ns3::Tcp classes onto the provid...
A helper class to make life easier while doing simple IPv4 address assignment in scripts.
void SetBase(Ipv4Address network, Ipv4Mask mask, Ipv4Address base="0.0.0.1")
Set the base network number, network mask and base address.
Ipv4InterfaceContainer Assign(const NetDeviceContainer &c)
Assign IP addresses to the net devices specified in the container based on the current network prefix...
Ipv4 addresses are stored in host order in this class.
static Ipv4Address GetAny()
holds a vector of std::pair of Ptr<Ipv4> and interface index.
Helper class used to assign positions and mobility models to nodes.
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.
Smart pointer class similar to boost::intrusive_ptr.
static EventId Schedule(const Time &delay, FUNC f, Ts &&... args)
Schedule an event to expire after delay.
static void Destroy()
Execute the events scheduled with ScheduleDestroy().
static void Run()
Run the simulation.
static Ptr< Socket > CreateSocket(Ptr< Node > node, TypeId tid)
This method wraps the creation of sockets that is performed on a given node by a SocketFactory specif...
Hold variables of type string.
Simulation virtual time values and global simulation resolution.
a unique identifier for an interface.
static TypeId LookupByName(std::string name)
Get a TypeId by name.
helps to create WifiNetDevice objects
create MAC layers for a ns3::WifiNetDevice.
void SetType(std::string type, Args &&... args)
void Set(std::string name, const AttributeValue &v)
manage and create wifi channel objects for the YANS model.
void SetPropagationDelay(std::string name, Ts &&... args)
void AddPropagationLoss(std::string name, Ts &&... args)
Ptr< YansWifiChannel > Create() const
Make it easy to create and manage PHY objects for the YANS model.
void experiment(std::string queue_disc_type)
void SetDefault(std::string name, const AttributeValue &value)
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
#define NS_LOG_DEBUG(msg)
Use NS_LOG to output a message of level LOG_DEBUG.
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
Time Seconds(double value)
Construct a Time in the indicated unit.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
Callback< R, Args... > MakeCallback(R(T::*memPtr)(Args...), OBJ objPtr)
Build Callbacks for class method members which take varying numbers of arguments and potentially retu...
uint32_t pktSize
packet size used for the simulation (in bytes)
static const uint32_t packetSize
Packet size generated at the AP.
Ptr< PacketSink > sink
Pointer to the packet sink application.