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 #include "ns3/traffic-control-module.h"
53 
54 using namespace ns3;
55 
56 NS_LOG_COMPONENT_DEFINE ("TcpVariantsComparison");
57 
58 bool firstCwnd = true;
59 bool firstSshThr = true;
60 bool firstRtt = true;
61 bool firstRto = true;
69 uint32_t cWndValue;
70 uint32_t ssThreshValue;
71 
72 
73 static void
74 CwndTracer (uint32_t oldval, uint32_t newval)
75 {
76  if (firstCwnd)
77  {
78  *cWndStream->GetStream () << "0.0 " << oldval << std::endl;
79  firstCwnd = false;
80  }
81  *cWndStream->GetStream () << Simulator::Now ().GetSeconds () << " " << newval << std::endl;
82  cWndValue = newval;
83 
84  if (!firstSshThr)
85  {
86  *ssThreshStream->GetStream () << Simulator::Now ().GetSeconds () << " " << ssThreshValue << std::endl;
87  }
88 }
89 
90 static void
91 SsThreshTracer (uint32_t oldval, uint32_t newval)
92 {
93  if (firstSshThr)
94  {
95  *ssThreshStream->GetStream () << "0.0 " << oldval << std::endl;
96  firstSshThr = false;
97  }
98  *ssThreshStream->GetStream () << Simulator::Now ().GetSeconds () << " " << newval << std::endl;
99  ssThreshValue = newval;
100 
101  if (!firstCwnd)
102  {
103  *cWndStream->GetStream () << Simulator::Now ().GetSeconds () << " " << cWndValue << std::endl;
104  }
105 }
106 
107 static void
108 RttTracer (Time oldval, Time newval)
109 {
110  if (firstRtt)
111  {
112  *rttStream->GetStream () << "0.0 " << oldval.GetSeconds () << std::endl;
113  firstRtt = false;
114  }
115  *rttStream->GetStream () << Simulator::Now ().GetSeconds () << " " << newval.GetSeconds () << std::endl;
116 }
117 
118 static void
119 RtoTracer (Time oldval, Time newval)
120 {
121  if (firstRto)
122  {
123  *rtoStream->GetStream () << "0.0 " << oldval.GetSeconds () << std::endl;
124  firstRto = false;
125  }
126  *rtoStream->GetStream () << Simulator::Now ().GetSeconds () << " " << newval.GetSeconds () << std::endl;
127 }
128 
129 static void
131 {
132  *nextTxStream->GetStream () << Simulator::Now ().GetSeconds () << " " << nextTx << std::endl;
133 }
134 
135 static void
136 InFlightTracer (uint32_t old, uint32_t inFlight)
137 {
138  *inFlightStream->GetStream () << Simulator::Now ().GetSeconds () << " " << inFlight << std::endl;
139 }
140 
141 static void
143 {
144  *nextRxStream->GetStream () << Simulator::Now ().GetSeconds () << " " << nextRx << std::endl;
145 }
146 
147 static void
148 TraceCwnd (std::string cwnd_tr_file_name)
149 {
150  AsciiTraceHelper ascii;
151  cWndStream = ascii.CreateFileStream (cwnd_tr_file_name.c_str ());
152  Config::ConnectWithoutContext ("/NodeList/1/$ns3::TcpL4Protocol/SocketList/0/CongestionWindow", MakeCallback (&CwndTracer));
153 }
154 
155 static void
156 TraceSsThresh (std::string ssthresh_tr_file_name)
157 {
158  AsciiTraceHelper ascii;
159  ssThreshStream = ascii.CreateFileStream (ssthresh_tr_file_name.c_str ());
160  Config::ConnectWithoutContext ("/NodeList/1/$ns3::TcpL4Protocol/SocketList/0/SlowStartThreshold", MakeCallback (&SsThreshTracer));
161 }
162 
163 static void
164 TraceRtt (std::string rtt_tr_file_name)
165 {
166  AsciiTraceHelper ascii;
167  rttStream = ascii.CreateFileStream (rtt_tr_file_name.c_str ());
168  Config::ConnectWithoutContext ("/NodeList/1/$ns3::TcpL4Protocol/SocketList/0/RTT", MakeCallback (&RttTracer));
169 }
170 
171 static void
172 TraceRto (std::string rto_tr_file_name)
173 {
174  AsciiTraceHelper ascii;
175  rtoStream = ascii.CreateFileStream (rto_tr_file_name.c_str ());
176  Config::ConnectWithoutContext ("/NodeList/1/$ns3::TcpL4Protocol/SocketList/0/RTO", MakeCallback (&RtoTracer));
177 }
178 
179 static void
180 TraceNextTx (std::string &next_tx_seq_file_name)
181 {
182  AsciiTraceHelper ascii;
183  nextTxStream = ascii.CreateFileStream (next_tx_seq_file_name.c_str ());
184  Config::ConnectWithoutContext ("/NodeList/1/$ns3::TcpL4Protocol/SocketList/0/NextTxSequence", MakeCallback (&NextTxTracer));
185 }
186 
187 static void
188 TraceInFlight (std::string &in_flight_file_name)
189 {
190  AsciiTraceHelper ascii;
191  inFlightStream = ascii.CreateFileStream (in_flight_file_name.c_str ());
192  Config::ConnectWithoutContext ("/NodeList/1/$ns3::TcpL4Protocol/SocketList/0/BytesInFlight", MakeCallback (&InFlightTracer));
193 }
194 
195 
196 static void
197 TraceNextRx (std::string &next_rx_seq_file_name)
198 {
199  AsciiTraceHelper ascii;
200  nextRxStream = ascii.CreateFileStream (next_rx_seq_file_name.c_str ());
201  Config::ConnectWithoutContext ("/NodeList/2/$ns3::TcpL4Protocol/SocketList/1/RxBuffer/NextRxSequence", MakeCallback (&NextRxTracer));
202 }
203 
204 int main (int argc, char *argv[])
205 {
206  std::string transport_prot = "TcpWestwood";
207  double error_p = 0.0;
208  std::string bandwidth = "2Mbps";
209  std::string delay = "0.01ms";
210  std::string access_bandwidth = "10Mbps";
211  std::string access_delay = "45ms";
212  bool tracing = false;
213  std::string prefix_file_name = "TcpVariantsComparison";
214  double data_mbytes = 0;
215  uint32_t mtu_bytes = 400;
216  uint16_t num_flows = 1;
217  float duration = 100;
218  uint32_t run = 0;
219  bool flow_monitor = false;
220  bool pcap = false;
221  std::string queue_disc_type = "ns3::PfifoFastQueueDisc";
222 
223 
225  cmd.AddValue ("transport_prot", "Transport protocol to use: TcpNewReno, "
226  "TcpHybla, TcpHighSpeed, TcpHtcp, TcpVegas, TcpScalable, TcpVeno, "
227  "TcpBic, TcpYeah, TcpIllinois, TcpWestwood, TcpWestwoodPlus ", transport_prot);
228  cmd.AddValue ("error_p", "Packet error rate", error_p);
229  cmd.AddValue ("bandwidth", "Bottleneck bandwidth", bandwidth);
230  cmd.AddValue ("delay", "Bottleneck delay", delay);
231  cmd.AddValue ("access_bandwidth", "Access link bandwidth", access_bandwidth);
232  cmd.AddValue ("access_delay", "Access link delay", access_delay);
233  cmd.AddValue ("tracing", "Flag to enable/disable tracing", tracing);
234  cmd.AddValue ("prefix_name", "Prefix of output trace file", prefix_file_name);
235  cmd.AddValue ("data", "Number of Megabytes of data to transmit", data_mbytes);
236  cmd.AddValue ("mtu", "Size of IP packets to send in bytes", mtu_bytes);
237  cmd.AddValue ("num_flows", "Number of flows", num_flows);
238  cmd.AddValue ("duration", "Time to allow flows to run in seconds", duration);
239  cmd.AddValue ("run", "Run index (for setting repeatable seeds)", run);
240  cmd.AddValue ("flow_monitor", "Enable flow monitor", flow_monitor);
241  cmd.AddValue ("pcap_tracing", "Enable or disable PCAP tracing", pcap);
242  cmd.AddValue ("queue_disc_type", "Queue disc type for gateway (e.g. ns3::CoDelQueueDisc)", queue_disc_type);
243  cmd.Parse (argc, argv);
244 
246  SeedManager::SetRun (run);
247 
248  // User may find it convenient to enable logging
249  //LogComponentEnable("TcpVariantsComparison", LOG_LEVEL_ALL);
250  //LogComponentEnable("BulkSendApplication", LOG_LEVEL_INFO);
251  //LogComponentEnable("PfifoFastQueueDisc", LOG_LEVEL_ALL);
252 
253  // Calculate the ADU size
254  Header* temp_header = new Ipv4Header ();
255  uint32_t ip_header = temp_header->GetSerializedSize ();
256  NS_LOG_LOGIC ("IP Header size is: " << ip_header);
257  delete temp_header;
258  temp_header = new TcpHeader ();
259  uint32_t tcp_header = temp_header->GetSerializedSize ();
260  NS_LOG_LOGIC ("TCP Header size is: " << tcp_header);
261  delete temp_header;
262  uint32_t tcp_adu_size = mtu_bytes - 20 - (ip_header + tcp_header);
263  NS_LOG_LOGIC ("TCP ADU size is: " << tcp_adu_size);
264 
265  // Set the simulation start and stop time
266  float start_time = 0.1;
267  float stop_time = start_time + duration;
268 
269  // 4 MB of TCP buffer
270  Config::SetDefault ("ns3::TcpSocket::RcvBufSize", UintegerValue (1 << 21));
271  Config::SetDefault ("ns3::TcpSocket::SndBufSize", UintegerValue (1 << 21));
272 
273  // Select TCP variant
274  if (transport_prot.compare ("TcpNewReno") == 0)
275  {
276  Config::SetDefault ("ns3::TcpL4Protocol::SocketType", TypeIdValue (TcpNewReno::GetTypeId ()));
277  }
278  else if (transport_prot.compare ("TcpHybla") == 0)
279  {
280  Config::SetDefault ("ns3::TcpL4Protocol::SocketType", TypeIdValue (TcpHybla::GetTypeId ()));
281  }
282  else if (transport_prot.compare ("TcpHighSpeed") == 0)
283  {
284  Config::SetDefault ("ns3::TcpL4Protocol::SocketType", TypeIdValue (TcpHighSpeed::GetTypeId ()));
285  }
286  else if (transport_prot.compare ("TcpVegas") == 0)
287  {
288  Config::SetDefault ("ns3::TcpL4Protocol::SocketType", TypeIdValue (TcpVegas::GetTypeId ()));
289  }
290  else if (transport_prot.compare ("TcpScalable") == 0)
291  {
292  Config::SetDefault ("ns3::TcpL4Protocol::SocketType", TypeIdValue (TcpScalable::GetTypeId ()));
293  }
294  else if (transport_prot.compare ("TcpHtcp") == 0)
295  {
296  Config::SetDefault ("ns3::TcpL4Protocol::SocketType", TypeIdValue (TcpHtcp::GetTypeId ()));
297  }
298  else if (transport_prot.compare ("TcpVeno") == 0)
299  {
300  Config::SetDefault ("ns3::TcpL4Protocol::SocketType", TypeIdValue (TcpVeno::GetTypeId ()));
301  }
302  else if (transport_prot.compare ("TcpBic") == 0)
303  {
304  Config::SetDefault ("ns3::TcpL4Protocol::SocketType", TypeIdValue (TcpBic::GetTypeId ()));
305  }
306  else if (transport_prot.compare ("TcpYeah") == 0)
307  {
308  Config::SetDefault ("ns3::TcpL4Protocol::SocketType", TypeIdValue (TcpYeah::GetTypeId ()));
309  }
310  else if (transport_prot.compare ("TcpIllinois") == 0)
311  {
312  Config::SetDefault ("ns3::TcpL4Protocol::SocketType", TypeIdValue (TcpIllinois::GetTypeId ()));
313  }
314  else if (transport_prot.compare ("TcpWestwood") == 0)
315  { // the default protocol type in ns3::TcpWestwood is WESTWOOD
316  Config::SetDefault ("ns3::TcpL4Protocol::SocketType", TypeIdValue (TcpWestwood::GetTypeId ()));
317  Config::SetDefault ("ns3::TcpWestwood::FilterType", EnumValue (TcpWestwood::TUSTIN));
318  }
319  else if (transport_prot.compare ("TcpWestwoodPlus") == 0)
320  {
321  Config::SetDefault ("ns3::TcpL4Protocol::SocketType", TypeIdValue (TcpWestwood::GetTypeId ()));
322  Config::SetDefault ("ns3::TcpWestwood::ProtocolType", EnumValue (TcpWestwood::WESTWOODPLUS));
323  Config::SetDefault ("ns3::TcpWestwood::FilterType", EnumValue (TcpWestwood::TUSTIN));
324  }
325  else
326  {
327  NS_LOG_DEBUG ("Invalid TCP version");
328  exit (1);
329  }
330 
331  // Create gateways, sources, and sinks
332  NodeContainer gateways;
333  gateways.Create (1);
334  NodeContainer sources;
335  sources.Create (num_flows);
336  NodeContainer sinks;
337  sinks.Create (num_flows);
338 
339  // Configure the error model
340  // Here we use RateErrorModel with packet error rate
341  Ptr<UniformRandomVariable> uv = CreateObject<UniformRandomVariable> ();
342  uv->SetStream (50);
343  RateErrorModel error_model;
344  error_model.SetRandomVariable (uv);
346  error_model.SetRate (error_p);
347 
348  PointToPointHelper UnReLink;
349  UnReLink.SetDeviceAttribute ("DataRate", StringValue (bandwidth));
350  UnReLink.SetChannelAttribute ("Delay", StringValue (delay));
351  UnReLink.SetDeviceAttribute ("ReceiveErrorModel", PointerValue (&error_model));
352 
353 
355  stack.InstallAll ();
356 
357  TrafficControlHelper tchPfifo;
358  tchPfifo.SetRootQueueDisc ("ns3::PfifoFastQueueDisc");
359 
360  TrafficControlHelper tchCoDel;
361  tchCoDel.SetRootQueueDisc ("ns3::CoDelQueueDisc");
362 
364  address.SetBase ("10.0.0.0", "255.255.255.0");
365 
366  // Configure the sources and sinks net devices
367  // and the channels between the sources/sinks and the gateways
368  PointToPointHelper LocalLink;
369  LocalLink.SetDeviceAttribute ("DataRate", StringValue (access_bandwidth));
370  LocalLink.SetChannelAttribute ("Delay", StringValue (access_delay));
371 
372  Ipv4InterfaceContainer sink_interfaces;
373 
374  DataRate access_b (access_bandwidth);
375  DataRate bottle_b (bandwidth);
376  Time access_d (access_delay);
377  Time bottle_d (delay);
378 
379  Config::SetDefault ("ns3::CoDelQueueDisc::Mode", EnumValue (Queue::QUEUE_MODE_BYTES));
380 
381  uint32_t size = (std::min (access_b, bottle_b).GetBitRate () / 8) *
382  ((access_d + bottle_d) * 2).GetSeconds ();
383 
384  Config::SetDefault ("ns3::PfifoFastQueueDisc::Limit", UintegerValue (size / mtu_bytes));
385  Config::SetDefault ("ns3::CoDelQueueDisc::MaxBytes", UintegerValue (size));
386 
387  for (int i = 0; i < num_flows; i++)
388  {
390  devices = LocalLink.Install (sources.Get (i), gateways.Get (0));
391  tchPfifo.Install (devices);
392  address.NewNetwork ();
393  Ipv4InterfaceContainer interfaces = address.Assign (devices);
394 
395  devices = UnReLink.Install (gateways.Get (0), sinks.Get (i));
396  if (queue_disc_type.compare ("ns3::PfifoFastQueueDisc") == 0)
397  {
398  tchPfifo.Install (devices);
399  }
400  else if (queue_disc_type.compare ("ns3::CoDelQueueDisc") == 0)
401  {
402  tchCoDel.Install (devices);
403  }
404  else
405  {
406  NS_FATAL_ERROR ("Queue not recognized. Allowed values are ns3::CoDelQueueDisc or ns3::PfifoFastQueueDisc");
407  }
408  address.NewNetwork ();
409  interfaces = address.Assign (devices);
410  sink_interfaces.Add (interfaces.Get (1));
411  }
412 
413  NS_LOG_INFO ("Initialize Global Routing.");
415 
416  uint16_t port = 50000;
417  Address sinkLocalAddress (InetSocketAddress (Ipv4Address::GetAny (), port));
418  PacketSinkHelper sinkHelper ("ns3::TcpSocketFactory", sinkLocalAddress);
419 
420  for (uint16_t i = 0; i < sources.GetN (); i++)
421  {
422  AddressValue remoteAddress (InetSocketAddress (sink_interfaces.GetAddress (i, 0), port));
423 
424  if (transport_prot.compare ("TcpNewReno") == 0
425  || transport_prot.compare ("TcpWestwood") == 0
426  || transport_prot.compare ("TcpWestwoodPlus") == 0
427  || transport_prot.compare ("TcpHybla") == 0
428  || transport_prot.compare ("TcpHighSpeed") == 0
429  || transport_prot.compare ("TcpHtcp") == 0
430  || transport_prot.compare ("TcpVegas") == 0
431  || transport_prot.compare ("TcpVeno") == 0
432  || transport_prot.compare ("TcpBic") == 0
433  || transport_prot.compare ("TcpScalable") == 0
434  || transport_prot.compare ("TcpYeah") == 0
435  || transport_prot.compare ("TcpIllinois") == 0)
436  {
437  Config::SetDefault ("ns3::TcpSocket::SegmentSize", UintegerValue (tcp_adu_size));
438  BulkSendHelper ftp ("ns3::TcpSocketFactory", Address ());
439  ftp.SetAttribute ("Remote", remoteAddress);
440  ftp.SetAttribute ("SendSize", UintegerValue (tcp_adu_size));
441  ftp.SetAttribute ("MaxBytes", UintegerValue (int(data_mbytes * 1000000)));
442 
443  ApplicationContainer sourceApp = ftp.Install (sources.Get (i));
444  sourceApp.Start (Seconds (start_time * i));
445  sourceApp.Stop (Seconds (stop_time - 3));
446 
447  sinkHelper.SetAttribute ("Protocol", TypeIdValue (TcpSocketFactory::GetTypeId ()));
448  ApplicationContainer sinkApp = sinkHelper.Install (sinks);
449  sinkApp.Start (Seconds (start_time * i));
450  sinkApp.Stop (Seconds (stop_time));
451  }
452  else
453  {
454  NS_LOG_DEBUG ("Invalid transport protocol " << transport_prot << " specified");
455  exit (1);
456  }
457  }
458 
459  // Set up tracing if enabled
460  if (tracing)
461  {
462  std::ofstream ascii;
463  Ptr<OutputStreamWrapper> ascii_wrap;
464  ascii.open ((prefix_file_name + "-ascii").c_str ());
465  ascii_wrap = new OutputStreamWrapper ((prefix_file_name + "-ascii").c_str (),
466  std::ios::out);
467  stack.EnableAsciiIpv4All (ascii_wrap);
468 
469  Simulator::Schedule (Seconds (0.00001), &TraceCwnd, prefix_file_name + "-cwnd.data");
470  Simulator::Schedule (Seconds (0.00001), &TraceSsThresh, prefix_file_name + "-ssth.data");
471  Simulator::Schedule (Seconds (0.00001), &TraceRtt, prefix_file_name + "-rtt.data");
472  Simulator::Schedule (Seconds (0.00001), &TraceRto, prefix_file_name + "-rto.data");
473  Simulator::Schedule (Seconds (0.00001), &TraceNextTx, prefix_file_name + "-next-tx.data");
474  Simulator::Schedule (Seconds (0.00001), &TraceInFlight, prefix_file_name + "-inflight.data");
475  Simulator::Schedule (Seconds (0.1), &TraceNextRx, prefix_file_name + "-next-rx.data");
476  }
477 
478  if (pcap)
479  {
480  UnReLink.EnablePcapAll (prefix_file_name, true);
481  LocalLink.EnablePcapAll (prefix_file_name, true);
482  }
483 
484  // Flow monitor
485  FlowMonitorHelper flowHelper;
486  if (flow_monitor)
487  {
488  flowHelper.InstallAll ();
489  }
490 
491  Simulator::Stop (Seconds (stop_time));
492  Simulator::Run ();
493 
494  if (flow_monitor)
495  {
496  flowHelper.SerializeToXmlFile (prefix_file_name + ".flowmonitor", true, true);
497  }
498 
500  return 0;
501 }
Protocol header serialization and deserialization.
Definition: header.h:42
holds a vector of ns3::Application pointers.
Ptr< OutputStreamWrapper > nextTxStream
Simulation virtual time values and global simulation resolution.
Definition: nstime.h:102
Manage ASCII trace files for device models.
Definition: trace-helper.h:161
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...
QueueDiscContainer Install(NetDeviceContainer c)
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
#define min(a, b)
Definition: 80211b.c:44
Ptr< OutputStreamWrapper > nextRxStream
NetDeviceContainer Install(NodeContainer c)
static void TraceNextRx(std::string &next_rx_seq_file_name)
Use number of bytes for maximum queue size.
Definition: queue.h:133
void Add(const Ipv4InterfaceContainer &other)
Concatenate the entries in the other container with ours.
uint32_t ssThreshValue
uint32_t cWndValue
static void Run(void)
Run the simulation.
Definition: simulator.cc:201
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.
static TypeId GetTypeId(void)
Get the type ID.
Definition: tcp-scalable.cc:40
#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:162
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 TypeId GetTypeId(void)
Get the type ID.
Definition: tcp-bic.cc:29
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:33
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:1238
void InstallAll(void) const
Aggregate IPv4, IPv6, UDP, and TCP stacks to all nodes in the simulation.
static TypeId GetTypeId(void)
Get the type ID.
Definition: tcp-htcp.cc:46
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.
static void InFlightTracer(uint32_t old, uint32_t inFlight)
AttributeValue implementation for TypeId.
Definition: type-id.h:608
Callback< R > MakeCallback(R(T::*memPtr)(void), OBJ objPtr)
Definition: callback.h:1489
void ConnectWithoutContext(std::string path, const CallbackBase &cb)
Definition: config.cc:824
Build a set of QueueDisc objects.
static TypeId GetTypeId(void)
Get the type ID.
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:205
#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:165
static void CwndTracer(uint32_t oldval, uint32_t newval)
static TypeId GetTypeId(void)
Get the type ID.
static TypeId GetTypeId(void)
Get the type ID.
Definition: tcp-vegas.cc:37
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)
uint16_t SetRootQueueDisc(std::string type, std::string n01="", const AttributeValue &v01=EmptyAttributeValue(), std::string n02="", const AttributeValue &v02=EmptyAttributeValue(), std::string n03="", const AttributeValue &v03=EmptyAttributeValue(), std::string n04="", const AttributeValue &v04=EmptyAttributeValue(), std::string n05="", const AttributeValue &v05=EmptyAttributeValue(), std::string n06="", const AttributeValue &v06=EmptyAttributeValue(), std::string n07="", const AttributeValue &v07=EmptyAttributeValue(), std::string n08="", const AttributeValue &v08=EmptyAttributeValue(), std::string n09="", const AttributeValue &v09=EmptyAttributeValue(), std::string n10="", const AttributeValue &v10=EmptyAttributeValue(), std::string n11="", const AttributeValue &v11=EmptyAttributeValue(), std::string n12="", const AttributeValue &v12=EmptyAttributeValue(), std::string n13="", const AttributeValue &v13=EmptyAttributeValue(), std::string n14="", const AttributeValue &v14=EmptyAttributeValue(), std::string n15="", const AttributeValue &v15=EmptyAttributeValue())
Helper function used to set a root queue disc of the given type and with the given attributes...
virtual uint32_t GetSerializedSize(void) const =0
Header for the Transmission Control Protocol.
Definition: tcp-header.h:44
Ptr< OutputStreamWrapper > inFlightStream
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:224
static void NextRxTracer(SequenceNumber32 old, SequenceNumber32 nextRx)
tuple stack
Definition: first.py:34
static TypeId GetTypeId(void)
Get the type ID.
Definition: tcp-veno.cc:37
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.
static void TraceNextTx(std::string &next_tx_seq_file_name)
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...
static TypeId GetTypeId(void)
Get the type ID.
Definition: tcp-hybla.cc:30
void AddValue(const std::string &name, const std::string &help, T &value)
Add a program argument, assigning to POD.
Definition: command-line.h:495
static void Stop(void)
Tell the Simulator the calling event should be the last one executed.
Definition: simulator.cc:209
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
static void NextTxTracer(SequenceNumber32 old, SequenceNumber32 nextTx)
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)
static TypeId GetTypeId(void)
Get the type ID.
Definition: tcp-yeah.cc:38
static TypeId GetTypeId(void)
Get the type ID.
Definition: tcp-illinois.cc:39
void Create(uint32_t n)
Create n nodes and append pointers to them to the end of this NodeContainer.
tuple address
Definition: first.py:37
Determine which packets are errored corresponding to an underlying distribution, rate, and unit.
Definition: error-model.h:182
static void TraceInFlight(std::string &in_flight_file_name)
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)