40 #include "ns3/core-module.h" 
   41 #include "ns3/network-module.h" 
   42 #include "ns3/internet-module.h" 
   43 #include "ns3/point-to-point-module.h" 
   44 #include "ns3/applications-module.h" 
   45 #include "ns3/error-model.h" 
   46 #include "ns3/tcp-header.h" 
   47 #include "ns3/udp-header.h" 
   49 #include "ns3/event-id.h" 
   50 #include "ns3/flow-monitor-helper.h" 
   51 #include "ns3/ipv4-global-routing-helper.h" 
   74       *cWndStream->
GetStream () << 
"0.0 " << oldval << std::endl;
 
   91       *ssThreshStream->
GetStream () << 
"0.0 " << oldval << std::endl;
 
  158 int main (
int argc, 
char *argv[])
 
  160   std::string transport_prot = 
"TcpWestwood";
 
  161   double error_p = 0.0;
 
  162   std::string bandwidth = 
"2Mbps";
 
  163   std::string access_bandwidth = 
"10Mbps";
 
  164   std::string access_delay = 
"45ms";
 
  165   bool tracing = 
false;
 
  166   std::string tr_file_name = 
"";
 
  167   std::string cwnd_tr_file_name = 
"";
 
  168   std::string ssthresh_tr_file_name = 
"";
 
  169   std::string rtt_tr_file_name = 
"";
 
  170   std::string rto_tr_file_name = 
"";
 
  171   double data_mbytes = 0;
 
  172   uint32_t mtu_bytes = 400;
 
  173   uint16_t num_flows = 1;
 
  174   float duration = 100;
 
  176   bool flow_monitor = 
true;
 
  180   cmd.
AddValue (
"transport_prot", 
"Transport protocol to use: TcpTahoe, TcpReno, TcpNewReno, TcpWestwood, TcpWestwoodPlus ", transport_prot);
 
  181   cmd.
AddValue (
"error_p", 
"Packet error rate", error_p);
 
  182   cmd.
AddValue (
"bandwidth", 
"Bottleneck bandwidth", bandwidth);
 
  183   cmd.
AddValue (
"access_bandwidth", 
"Access link bandwidth", access_bandwidth);
 
  184   cmd.
AddValue (
"delay", 
"Access link delay", access_delay);
 
  185   cmd.
AddValue (
"tracing", 
"Flag to enable/disable tracing", tracing);
 
  186   cmd.
AddValue (
"tr_name", 
"Name of output trace file", tr_file_name);
 
  187   cmd.
AddValue (
"cwnd_tr_name", 
"Name of output trace file", cwnd_tr_file_name);
 
  188   cmd.
AddValue (
"ssthresh_tr_name", 
"Name of output trace file", ssthresh_tr_file_name);
 
  189   cmd.
AddValue (
"rtt_tr_name", 
"Name of output trace file", rtt_tr_file_name);
 
  190   cmd.
AddValue (
"rto_tr_name", 
"Name of output trace file", rto_tr_file_name);
 
  191   cmd.
AddValue (
"data", 
"Number of Megabytes of data to transmit", data_mbytes);
 
  192   cmd.
AddValue (
"mtu", 
"Size of IP packets to send in bytes", mtu_bytes);
 
  193   cmd.
AddValue (
"num_flows", 
"Number of flows", num_flows);
 
  194   cmd.
AddValue (
"duration", 
"Time to allow flows to run in seconds", duration);
 
  195   cmd.
AddValue (
"run", 
"Run index (for setting repeatable seeds)", run);
 
  196   cmd.
AddValue (
"flow_monitor", 
"Enable flow monitor", flow_monitor);
 
  197   cmd.
Parse (argc, argv);
 
  216   uint32_t tcp_adu_size = mtu_bytes - (ip_header + tcp_header);
 
  220   float start_time = 0.1;
 
  221   float stop_time = start_time + duration;
 
  224   if (transport_prot.compare (
"TcpTahoe") == 0)
 
  228   else if (transport_prot.compare (
"TcpReno") == 0)
 
  232   else if (transport_prot.compare (
"TcpNewReno") == 0)
 
  236   else if (transport_prot.compare (
"TcpWestwood") == 0)
 
  241   else if (transport_prot.compare (
"TcpWestwoodPlus") == 0)
 
  257   sources.
Create (num_flows);
 
  280   address.
SetBase (
"10.0.0.0", 
"255.255.255.0");
 
  288   for (
int i = 0; i < num_flows; i++)
 
  291       devices = LocalLink.
Install (sources.
Get (i), gateways.
Get (0));
 
  294       devices = UnReLink.
Install (gateways.
Get (0), sinks.
Get (i));
 
  296       interfaces = address.
Assign (devices);
 
  297       sink_interfaces.
Add (interfaces.
Get (1));
 
  303   uint16_t 
port = 50000;
 
  307   for (uint16_t i = 0; i < sources.
GetN (); i++)
 
  311       if (transport_prot.compare (
"TcpTahoe") == 0
 
  312           || transport_prot.compare (
"TcpReno") == 0
 
  313           || transport_prot.compare (
"TcpNewReno") == 0
 
  314           || transport_prot.compare (
"TcpWestwood") == 0
 
  315           || transport_prot.compare (
"TcpWestwoodPlus") == 0)
 
  319           ftp.SetAttribute (
"Remote", remoteAddress);
 
  321           ftp.SetAttribute (
"MaxBytes", 
UintegerValue (
int(data_mbytes * 1000000)));
 
  334           NS_LOG_DEBUG (
"Invalid transport protocol " << transport_prot << 
" specified");
 
  342       if (tr_file_name.compare (
"") != 0)
 
  346           ascii.open (tr_file_name.c_str ());
 
  351       if (cwnd_tr_file_name.compare (
"") != 0)
 
  356       if (ssthresh_tr_file_name.compare (
"") != 0)
 
  361       if (rtt_tr_file_name.compare (
"") != 0)
 
  366       if (rto_tr_file_name.compare (
"") != 0)
 
holds a vector of ns3::Application pointers. 
 
Simulation virtual time values and global simulation resolution. 
 
Manage ASCII trace files for device models. 
 
static Ipv4Address GetAny(void)
 
void SetStream(int64_t stream)
Specifies the stream number for this RNG stream. 
 
std::pair< Ptr< Ipv4 >, uint32_t > Get(uint32_t i) const 
Get the std::pair of an Ptr and interface stored at the location specified by the index...
 
A helper to make it easier to instantiate an ns3::BulkSendApplication on a set of nodes...
 
holds a vector of std::pair of Ptr and interface index. 
 
static void PopulateRoutingTables(void)
Build a routing database and initialize the routing tables of the nodes in the simulation. 
 
Hold variables of type string. 
 
NetDeviceContainer Install(NodeContainer c)
 
static void Run(void)
Run the simulation. 
 
Ptr< OutputStreamWrapper > cWndStream
 
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name. 
 
aggregate IP/TCP/UDP functionality to existing Nodes. 
 
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO. 
 
A helper to make it easier to instantiate an ns3::PacketSinkApplication on a set of nodes...
 
Ptr< OutputStreamWrapper > CreateFileStream(std::string filename, std::ios::openmode filemode=std::ios::out)
Create and initialize an output stream object we'll use to write the traced bits. ...
 
Build a set of PointToPointNetDevice objects. 
 
void SetDeviceAttribute(std::string name, const AttributeValue &value)
Set an attribute value to be propagated to each NetDevice created by the helper. 
 
void SerializeToXmlFile(std::string fileName, bool enableHistograms, bool enableProbes)
Same as SerializeToXmlStream, but writes to a file instead. 
 
static void SetRun(uint64_t run)
Set the run number of simulation. 
 
a polymophic address class 
 
uint32_t GetN(void) const 
Get the number of Ptr stored in this container. 
 
double GetSeconds(void) const 
Get an approximation of the time stored in this instance in the indicated unit. 
 
Ptr< OutputStreamWrapper > rttStream
 
static void RttTracer(Time oldval, Time newval)
 
static TypeId GetTypeId(void)
Get the type ID. 
 
void EnablePcapAll(std::string prefix, bool promiscuous=false)
Enable pcap output on each device (which is of the appropriate type) in the set of all nodes created ...
 
Hold variables of type enum. 
 
static EventId Schedule(Time const &delay, MEM mem_ptr, OBJ obj)
Schedule an event to expire after delay. 
 
void InstallAll(void) const 
Aggregate IPv4, IPv6, UDP, and TCP stacks to all nodes in the simulation. 
 
Hold an unsigned integer type. 
 
void SetRate(double rate)
 
holds a vector of ns3::NetDevice pointers 
 
static TypeId GetTypeId(void)
Get the type ID. 
 
A class encapsulating an output stream. 
 
AttributeValue implementation for TypeId. 
 
Callback< R > MakeCallback(R(T::*memPtr)(void), OBJ objPtr)
 
void ConnectWithoutContext(std::string path, const CallbackBase &cb)
 
Ptr< FlowMonitor > InstallAll()
Enable flow monitoring on all nodes. 
 
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. 
 
#define NS_LOG_LOGIC(msg)
Use NS_LOG to output a message of level LOG_LOGIC. 
 
void EnableAsciiIpv4All(std::string prefix)
Enable ascii trace output on all Ipv4 and interface pairs existing in the set of all nodes created in...
 
static void Destroy(void)
Execute the events scheduled with ScheduleDestroy(). 
 
static void CwndTracer(uint32_t oldval, uint32_t newval)
 
static TypeId GetTypeId(void)
Get the type ID. 
 
Every class exported by the ns3 library is enclosed in the ns3 namespace. 
 
keep track of a set of node pointers. 
 
Hold objects of type Ptr. 
 
static void TraceSsThresh(std::string ssthresh_tr_file_name)
 
static TypeId GetTypeId(void)
Get the type ID. 
 
static TypeId GetTypeId(void)
Get the type ID. 
 
Ptr< OutputStreamWrapper > rtoStream
 
Helper to enable IP flow monitoring on a set of Nodes. 
 
static Time Now(void)
Return the current simulation virtual time. 
 
void SetChannelAttribute(std::string name, const AttributeValue &value)
Set an attribute value to be propagated to each Channel created by the helper. 
 
static void SetSeed(uint32_t seed)
Set the seed. 
 
void SetUnit(enum ErrorUnit error_unit)
 
AttributeValue implementation for Address. 
 
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. 
 
#define NS_LOG_DEBUG(msg)
Use NS_LOG to output a message of level LOG_DEBUG. 
 
Time Seconds(double value)
Construct a Time in the indicated unit. 
 
void SetDefault(std::string name, const AttributeValue &value)
 
void SetRandomVariable(Ptr< RandomVariableStream >)
 
Ipv4Address NewNetwork(void)
Increment the network number and reset the IP address counter to the base value provided in the SetBa...
 
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. 
 
static void TraceRtt(std::string rtt_tr_file_name)
 
void Create(uint32_t n)
Create n nodes and append pointers to them to the end of this NodeContainer. 
 
void Add(Ipv4InterfaceContainer other)
Concatenate the entries in the other container with ours. 
 
Determine which packets are errored corresponding to an underlying distribution, rate, and unit. 
 
static void RtoTracer(Time oldval, Time newval)
 
static void TraceCwnd(std::string cwnd_tr_file_name)
 
static void SsThreshTracer(uint32_t oldval, uint32_t newval)
 
std::ostream * GetStream(void)
Return a pointer to an ostream previously set in the wrapper. 
 
Ptr< OutputStreamWrapper > ssThreshStream
 
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 
 
static void TraceRto(std::string rto_tr_file_name)