This documentation is not the Latest Release.
A Discrete-Event Network Simulator
API
tcp-variants-comparison.cc
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2013 ResiliNets, ITTC, University of Kansas
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License version 2 as
7  * published by the Free Software Foundation;
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17  *
18  * Authors: Justin P. Rohrer, Truc Anh N. Nguyen <annguyen@ittc.ku.edu>, Siddharth Gangadhar <siddharth@ittc.ku.edu>
19  *
20  * James P.G. Sterbenz <jpgs@ittc.ku.edu>, director
21  * ResiliNets Research Group http://wiki.ittc.ku.edu/resilinets
22  * Information and Telecommunication Technology Center (ITTC)
23  * and Department of Electrical Engineering and Computer Science
24  * The University of Kansas Lawrence, KS USA.
25  *
26  * Work supported in part by NSF FIND (Future Internet Design) Program
27  * under grant CNS-0626918 (Postmodern Internet Architecture),
28  * NSF grant CNS-1050226 (Multilayer Network Resilience Analysis and Experimentation on GENI),
29  * US Department of Defense (DoD), and ITTC at The University of Kansas.
30  *
31  * “TCP Westwood(+) Protocol Implementation in ns-3”
32  * Siddharth Gangadhar, Trúc Anh Ngọc Nguyễn , Greeshma Umapathi, and James P.G. Sterbenz,
33  * ICST SIMUTools Workshop on ns-3 (WNS3), Cannes, France, March 2013
34  */
35 
36 #include <iostream>
37 #include <fstream>
38 #include <string>
39 
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"
48 #include "ns3/enum.h"
49 #include "ns3/event-id.h"
50 #include "ns3/flow-monitor-helper.h"
51 #include "ns3/ipv4-global-routing-helper.h"
52 
53 using namespace ns3;
54 
55 NS_LOG_COMPONENT_DEFINE ("TcpVariantsComparison");
56 
57 bool firstCwnd = true;
58 bool firstSshThr = true;
59 bool firstRtt = true;
60 bool firstRto = true;
65 uint32_t cWndValue;
66 uint32_t ssThreshValue;
67 
68 
69 static void
70 CwndTracer (uint32_t oldval, uint32_t newval)
71 {
72  if (firstCwnd)
73  {
74  *cWndStream->GetStream () << "0.0 " << oldval << std::endl;
75  firstCwnd = false;
76  }
77  *cWndStream->GetStream () << Simulator::Now ().GetSeconds () << " " << newval << std::endl;
78  cWndValue = newval;
79 
80  if (!firstSshThr)
81  {
82  *ssThreshStream->GetStream () << Simulator::Now ().GetSeconds () << " " << ssThreshValue << std::endl;
83  }
84 }
85 
86 static void
87 SsThreshTracer (uint32_t oldval, uint32_t newval)
88 {
89  if (firstSshThr)
90  {
91  *ssThreshStream->GetStream () << "0.0 " << oldval << std::endl;
92  firstSshThr = false;
93  }
94  *ssThreshStream->GetStream () << Simulator::Now ().GetSeconds () << " " << newval << std::endl;
95  ssThreshValue = newval;
96 
97  if (!firstCwnd)
98  {
99  *cWndStream->GetStream () << Simulator::Now ().GetSeconds () << " " << cWndValue << std::endl;
100  }
101 }
102 
103 static void
104 RttTracer (Time oldval, Time newval)
105 {
106  if (firstRtt)
107  {
108  *rttStream->GetStream () << "0.0 " << oldval.GetSeconds () << std::endl;
109  firstRtt = false;
110  }
111  *rttStream->GetStream () << Simulator::Now ().GetSeconds () << " " << newval.GetSeconds () << std::endl;
112 }
113 
114 static void
115 RtoTracer (Time oldval, Time newval)
116 {
117  if (firstRto)
118  {
119  *rtoStream->GetStream () << "0.0 " << oldval.GetSeconds () << std::endl;
120  firstRto = false;
121  }
122  *rtoStream->GetStream () << Simulator::Now ().GetSeconds () << " " << newval.GetSeconds () << std::endl;
123 }
124 
125 
126 static void
127 TraceCwnd (std::string cwnd_tr_file_name)
128 {
129  AsciiTraceHelper ascii;
130  cWndStream = ascii.CreateFileStream (cwnd_tr_file_name.c_str ());
131  Config::ConnectWithoutContext ("/NodeList/1/$ns3::TcpL4Protocol/SocketList/0/CongestionWindow", MakeCallback (&CwndTracer));
132 }
133 
134 static void
135 TraceSsThresh (std::string ssthresh_tr_file_name)
136 {
137  AsciiTraceHelper ascii;
138  ssThreshStream = ascii.CreateFileStream (ssthresh_tr_file_name.c_str ());
139  Config::ConnectWithoutContext ("/NodeList/1/$ns3::TcpL4Protocol/SocketList/0/SlowStartThreshold", MakeCallback (&SsThreshTracer));
140 }
141 
142 static void
143 TraceRtt (std::string rtt_tr_file_name)
144 {
145  AsciiTraceHelper ascii;
146  rttStream = ascii.CreateFileStream (rtt_tr_file_name.c_str ());
147  Config::ConnectWithoutContext ("/NodeList/1/$ns3::TcpL4Protocol/SocketList/0/RTT", MakeCallback (&RttTracer));
148 }
149 
150 static void
151 TraceRto (std::string rto_tr_file_name)
152 {
153  AsciiTraceHelper ascii;
154  rtoStream = ascii.CreateFileStream (rto_tr_file_name.c_str ());
155  Config::ConnectWithoutContext ("/NodeList/1/$ns3::TcpL4Protocol/SocketList/0/RTO", MakeCallback (&RtoTracer));
156 }
157 
158 int main (int argc, char *argv[])
159 {
160  std::string transport_prot = "TcpWestwood";
161  double error_p = 0.0;
162  std::string bandwidth = "2Mbps";
163  std::string delay = "0.01ms";
164  std::string access_bandwidth = "10Mbps";
165  std::string access_delay = "45ms";
166  bool tracing = false;
167  std::string prefix_file_name = "TcpVariantsComparison";
168  double data_mbytes = 0;
169  uint32_t mtu_bytes = 400;
170  uint16_t num_flows = 1;
171  float duration = 100;
172  uint32_t run = 0;
173  bool flow_monitor = false;
174  bool pcap = false;
175  std::string queue_type = "ns3::DropTailQueue";
176 
177 
179  cmd.AddValue ("transport_prot", "Transport protocol to use: TcpNewReno, "
180  " TcpWestwood, TcpWestwoodPlus ", transport_prot);
181  cmd.AddValue ("error_p", "Packet error rate", error_p);
182  cmd.AddValue ("bandwidth", "Bottleneck bandwidth", bandwidth);
183  cmd.AddValue ("delay", "Bottleneck delay", delay);
184  cmd.AddValue ("access_bandwidth", "Access link bandwidth", access_bandwidth);
185  cmd.AddValue ("access_delay", "Access link delay", access_delay);
186  cmd.AddValue ("tracing", "Flag to enable/disable tracing", tracing);
187  cmd.AddValue ("prefix_name", "Prefix of output trace file", prefix_file_name);
188  cmd.AddValue ("data", "Number of Megabytes of data to transmit", data_mbytes);
189  cmd.AddValue ("mtu", "Size of IP packets to send in bytes", mtu_bytes);
190  cmd.AddValue ("num_flows", "Number of flows", num_flows);
191  cmd.AddValue ("duration", "Time to allow flows to run in seconds", duration);
192  cmd.AddValue ("run", "Run index (for setting repeatable seeds)", run);
193  cmd.AddValue ("flow_monitor", "Enable flow monitor", flow_monitor);
194  cmd.AddValue ("pcap_tracing", "Enable or disable PCAP tracing", pcap);
195  cmd.AddValue ("queue_type", "Queue type for gateway (e.g. ns3::CoDelQueue)", queue_type);
196  cmd.Parse (argc, argv);
197 
199  SeedManager::SetRun (run);
200 
201  // User may find it convenient to enable logging
202  //LogComponentEnable("TcpVariantsComparison", LOG_LEVEL_ALL);
203  //LogComponentEnable("BulkSendApplication", LOG_LEVEL_INFO);
204  //LogComponentEnable("DropTailQueue", LOG_LEVEL_ALL);
205 
206  // Calculate the ADU size
207  Header* temp_header = new Ipv4Header ();
208  uint32_t ip_header = temp_header->GetSerializedSize ();
209  NS_LOG_LOGIC ("IP Header size is: " << ip_header);
210  delete temp_header;
211  temp_header = new TcpHeader ();
212  uint32_t tcp_header = temp_header->GetSerializedSize ();
213  NS_LOG_LOGIC ("TCP Header size is: " << tcp_header);
214  delete temp_header;
215  uint32_t tcp_adu_size = mtu_bytes - 20 - (ip_header + tcp_header);
216  NS_LOG_LOGIC ("TCP ADU size is: " << tcp_adu_size);
217 
218  // Set the simulation start and stop time
219  float start_time = 0.1;
220  float stop_time = start_time + duration;
221 
222  // 4 MB of TCP buffer
223  Config::SetDefault ("ns3::TcpSocket::RcvBufSize", UintegerValue (1 << 21));
224  Config::SetDefault ("ns3::TcpSocket::SndBufSize", UintegerValue (1 << 21));
225 
226  // Select TCP variant
227  if (transport_prot.compare ("TcpNewReno") == 0)
228  {
229  Config::SetDefault ("ns3::TcpL4Protocol::SocketType", TypeIdValue (TcpNewReno::GetTypeId ()));
230  }
231  else if (transport_prot.compare ("TcpWestwood") == 0)
232  { // the default protocol type in ns3::TcpWestwood is WESTWOOD
233  Config::SetDefault ("ns3::TcpL4Protocol::SocketType", TypeIdValue (TcpWestwood::GetTypeId ()));
234  Config::SetDefault ("ns3::TcpWestwood::FilterType", EnumValue (TcpWestwood::TUSTIN));
235  }
236  else if (transport_prot.compare ("TcpWestwoodPlus") == 0)
237  {
238  Config::SetDefault ("ns3::TcpL4Protocol::SocketType", TypeIdValue (TcpWestwood::GetTypeId ()));
239  Config::SetDefault ("ns3::TcpWestwood::ProtocolType", EnumValue (TcpWestwood::WESTWOODPLUS));
240  Config::SetDefault ("ns3::TcpWestwood::FilterType", EnumValue (TcpWestwood::TUSTIN));
241  }
242  else
243  {
244  NS_LOG_DEBUG ("Invalid TCP version");
245  exit (1);
246  }
247 
248  // Create gateways, sources, and sinks
249  NodeContainer gateways;
250  gateways.Create (1);
251  NodeContainer sources;
252  sources.Create (num_flows);
253  NodeContainer sinks;
254  sinks.Create (num_flows);
255 
256  // Configure the error model
257  // Here we use RateErrorModel with packet error rate
258  Ptr<UniformRandomVariable> uv = CreateObject<UniformRandomVariable> ();
259  uv->SetStream (50);
260  RateErrorModel error_model;
261  error_model.SetRandomVariable (uv);
263  error_model.SetRate (error_p);
264 
265  PointToPointHelper UnReLink;
266  UnReLink.SetDeviceAttribute ("DataRate", StringValue (bandwidth));
267  UnReLink.SetChannelAttribute ("Delay", StringValue (delay));
268  UnReLink.SetDeviceAttribute ("ReceiveErrorModel", PointerValue (&error_model));
269 
270 
272  stack.InstallAll ();
273 
275  address.SetBase ("10.0.0.0", "255.255.255.0");
276 
277  // Configure the sources and sinks net devices
278  // and the channels between the sources/sinks and the gateways
279  PointToPointHelper LocalLink;
280  LocalLink.SetDeviceAttribute ("DataRate", StringValue (access_bandwidth));
281  LocalLink.SetChannelAttribute ("Delay", StringValue (access_delay));
282 
283  Ipv4InterfaceContainer sink_interfaces;
284 
285  DataRate access_b (access_bandwidth);
286  DataRate bottle_b (bandwidth);
287  Time access_d (access_delay);
288  Time bottle_d (delay);
289 
290  Config::SetDefault ("ns3::DropTailQueue::Mode", EnumValue (DropTailQueue::QUEUE_MODE_BYTES));
291  Config::SetDefault ("ns3::CoDelQueue::Mode", EnumValue (CoDelQueue::QUEUE_MODE_BYTES));
292 
293  uint32_t size = (std::min (access_b, bottle_b).GetBitRate () / 8) *
294  ((access_d + bottle_d) * 2).GetSeconds ();
295 
296  for (int i = 0; i < num_flows; i++)
297  {
299  devices = LocalLink.Install (sources.Get (i), gateways.Get (0));
300  address.NewNetwork ();
301  Ipv4InterfaceContainer interfaces = address.Assign (devices);
302 
303  for (uint32_t j = 0; j <= 1; ++j)
304  {
306 
307  link = DynamicCast<PointToPointNetDevice> (devices.Get (j));
308 
309  Ptr<DropTailQueue> q = CreateObject <DropTailQueue> ();
310  q->SetMode (DropTailQueue::QUEUE_MODE_BYTES);
311  q->SetAttribute ("MaxBytes", UintegerValue (size));
312  link->SetQueue (q);
313  }
314 
315  devices = UnReLink.Install (gateways.Get (0), sinks.Get (i));
316  address.NewNetwork ();
317  interfaces = address.Assign (devices);
318  sink_interfaces.Add (interfaces.Get (1));
319 
320  for (uint32_t j = 0; j <= 1; ++j)
321  {
323 
324  link = DynamicCast<PointToPointNetDevice> (devices.Get (j));
325 
326  if (queue_type.compare ("ns3::DropTailQueue") == 0)
327  {
328  Ptr<DropTailQueue> q = CreateObject <DropTailQueue> ();
330  q->SetAttribute ("MaxBytes", UintegerValue (size));
331  link->SetQueue (q);
332  }
333  else if (queue_type.compare ("ns3::CoDelQueue") == 0)
334  {
335  Ptr<CoDelQueue> q = CreateObject <CoDelQueue> ();
337  q->SetAttribute ("MaxBytes", UintegerValue (size));
338  link->SetQueue (q);
339  }
340  else
341  {
342  NS_FATAL_ERROR ("Queue not recognized. Allowed values are ns3::CoDelQueue or ns3::DropTailQueue");
343  }
344  }
345  }
346 
347  NS_LOG_INFO ("Initialize Global Routing.");
349 
350  uint16_t port = 50000;
351  Address sinkLocalAddress (InetSocketAddress (Ipv4Address::GetAny (), port));
352  PacketSinkHelper sinkHelper ("ns3::TcpSocketFactory", sinkLocalAddress);
353 
354  for (uint16_t i = 0; i < sources.GetN (); i++)
355  {
356  AddressValue remoteAddress (InetSocketAddress (sink_interfaces.GetAddress (i, 0), port));
357 
358  if (transport_prot.compare ("TcpNewReno") == 0
359  || transport_prot.compare ("TcpWestwood") == 0
360  || transport_prot.compare ("TcpWestwoodPlus") == 0
361  || transport_prot.compare ("TcpHybla") == 0
362  || transport_prot.compare ("TcpHighSpeed") == 0
363  || transport_prot.compare ("TcpBic") == 0
364  || transport_prot.compare ("TcpCubic") == 0)
365  {
366  Config::SetDefault ("ns3::TcpSocket::SegmentSize", UintegerValue (tcp_adu_size));
367  BulkSendHelper ftp ("ns3::TcpSocketFactory", Address ());
368  ftp.SetAttribute ("Remote", remoteAddress);
369  ftp.SetAttribute ("SendSize", UintegerValue (tcp_adu_size));
370  ftp.SetAttribute ("MaxBytes", UintegerValue (int(data_mbytes * 1000000)));
371 
372  ApplicationContainer sourceApp = ftp.Install (sources.Get (i));
373  sourceApp.Start (Seconds (start_time * i));
374  sourceApp.Stop (Seconds (stop_time - 3));
375 
376  sinkHelper.SetAttribute ("Protocol", TypeIdValue (TcpSocketFactory::GetTypeId ()));
377  ApplicationContainer sinkApp = sinkHelper.Install (sinks);
378  sinkApp.Start (Seconds (start_time * i));
379  sinkApp.Stop (Seconds (stop_time));
380  }
381  else
382  {
383  NS_LOG_DEBUG ("Invalid transport protocol " << transport_prot << " specified");
384  exit (1);
385  }
386  }
387 
388  // Set up tracing if enabled
389  if (tracing)
390  {
391  std::ofstream ascii;
392  Ptr<OutputStreamWrapper> ascii_wrap;
393  ascii.open ((prefix_file_name + "-ascii").c_str ());
394  ascii_wrap = new OutputStreamWrapper ((prefix_file_name + "-ascii").c_str (),
395  std::ios::out);
396  stack.EnableAsciiIpv4All (ascii_wrap);
397 
398  Simulator::Schedule (Seconds (0.00001), &TraceCwnd, prefix_file_name + "-cwnd.data");
399  Simulator::Schedule (Seconds (0.00001), &TraceSsThresh, prefix_file_name + "-ssth.data");
400  Simulator::Schedule (Seconds (0.00001), &TraceRtt, prefix_file_name + "-rtt.data");
401  Simulator::Schedule (Seconds (0.00001), &TraceRto, prefix_file_name + "-rto.data");
402  }
403 
404  if (pcap)
405  {
406  UnReLink.EnablePcapAll (prefix_file_name, true);
407  LocalLink.EnablePcapAll (prefix_file_name, true);
408  }
409 
410  // Flow monitor
411  FlowMonitorHelper flowHelper;
412  if (flow_monitor)
413  {
414  flowHelper.InstallAll ();
415  }
416 
417  Simulator::Stop (Seconds (stop_time));
418  Simulator::Run ();
419 
420  if (flow_monitor)
421  {
422  flowHelper.SerializeToXmlFile (prefix_file_name + ".flowmonitor", true, true);
423  }
424 
426  return 0;
427 }
Protocol header serialization and deserialization.
Definition: header.h:42
holds a vector of ns3::Application pointers.
Simulation virtual time values and global simulation resolution.
Definition: nstime.h:102
Manage ASCII trace files for device models.
Definition: trace-helper.h:155
an Inet address class
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...
tuple devices
Definition: first.py:32
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.
Definition: string.h:41
Ptr< NetDevice > Get(uint32_t i) const
Get the Ptr stored in this container at a given index.
NetDeviceContainer Install(NodeContainer c)
Use number of bytes for maximum queue size.
Definition: queue.h:129
void SetMode(DropTailQueue::QueueMode mode)
Set the operating mode of this device.
uint32_t ssThreshValue
uint32_t cWndValue
static void Run(void)
Run the simulation.
Definition: simulator.cc:200
Ptr< OutputStreamWrapper > cWndStream
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition: log.h:201
aggregate IP/TCP/UDP functionality to existing Nodes.
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
Definition: log.h:244
#define NS_FATAL_ERROR(msg)
Report a fatal error with a message and terminate.
Definition: fatal-error.h:145
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.
tuple cmd
Definition: second.py:35
static void SetRun(uint64_t run)
Set the run number of simulation.
uint16_t port
Definition: dsdv-manet.cc:44
a polymophic address class
Definition: address.h:90
uint32_t GetN(void) const
Get the number of Ptr stored in this container.
Class for representing data rates.
Definition: data-rate.h:88
Packet header for IPv4.
Definition: ipv4-header.h:31
double GetSeconds(void) const
Get an approximation of the time stored in this instance in the indicated unit.
Definition: nstime.h:341
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.
Definition: enum.h:54
static EventId Schedule(Time const &delay, MEM mem_ptr, OBJ obj)
Schedule an event to expire after delay.
Definition: simulator.h:1216
void InstallAll(void) const
Aggregate IPv4, IPv6, UDP, and TCP stacks to all nodes in the simulation.
Hold an unsigned integer type.
Definition: uinteger.h:44
void SetRate(double rate)
Definition: error-model.cc:208
tuple interfaces
Definition: first.py:41
holds a vector of ns3::NetDevice pointers
A class encapsulating an output stream.
AttributeValue implementation for TypeId.
Definition: type-id.h:548
Callback< R > MakeCallback(R(T::*memPtr)(void), OBJ objPtr)
Definition: callback.h:1480
void ConnectWithoutContext(std::string path, const CallbackBase &cb)
Definition: config.cc:824
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.
Definition: command-line.h:201
#define NS_LOG_LOGIC(msg)
Use NS_LOG to output a message of level LOG_LOGIC.
Definition: log.h:252
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().
Definition: simulator.cc:164
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.
Definition: pointer.h:36
static void TraceSsThresh(std::string ssthresh_tr_file_name)
virtual uint32_t GetSerializedSize(void) const =0
Header for the Transmission Control Protocol.
Definition: tcp-header.h:44
static TypeId GetTypeId(void)
Get the type ID.
Definition: tcp-westwood.cc:47
Ptr< OutputStreamWrapper > rtoStream
Helper to enable IP flow monitoring on a set of Nodes.
bool firstSshThr
static Time Now(void)
Return the current simulation virtual time.
Definition: simulator.cc:223
tuple stack
Definition: first.py:34
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)
Definition: error-model.cc:194
AttributeValue implementation for Address.
Definition: address.h:278
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 SetMode(CoDelQueue::QueueMode mode)
Set the operating mode of this device.
Definition: codel-queue.cc:265
void AddValue(const std::string &name, const std::string &help, T &value)
Add a program argument, assigning to POD.
Definition: command-line.h:491
static void Stop(void)
Tell the Simulator the calling event should be the last one executed.
Definition: simulator.cc:208
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.
Definition: log.h:236
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition: nstime.h:895
void SetDefault(std::string name, const AttributeValue &value)
Definition: config.cc:774
bool firstCwnd
void SetRandomVariable(Ptr< RandomVariableStream >)
Definition: error-model.cc:215
bool firstRtt
bool firstRto
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.
tuple address
Definition: first.py:37
Determine which packets are errored corresponding to an underlying distribution, rate, and unit.
Definition: error-model.h:182
void SetAttribute(std::string name, const AttributeValue &value)
Set a single attribute, raising fatal errors if unsuccessful.
Definition: object-base.cc:191
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.
void SetQueue(Ptr< Queue > queue)
Attach a queue to the PointToPointNetDevice.
Ipv4Address GetAddress(uint32_t i, uint32_t j=0) const
static void TraceRto(std::string rto_tr_file_name)