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"
52#include "ns3/traffic-control-module.h"
62static std::map<uint32_t, Ptr<OutputStreamWrapper>>
cWndStream;
64static std::map<uint32_t, Ptr<OutputStreamWrapper>>
rttStream;
65static std::map<uint32_t, Ptr<OutputStreamWrapper>>
rtoStream;
75 std::size_t
const n1 = context.find_first_of (
"/", 1);
76 std::size_t
const n2 = context.find_first_of (
"/", n1 + 1);
77 return std::stoul (context.substr (n1 + 1, n2 - n1 - 1));
87 *
cWndStream[nodeId]->GetStream () <<
"0.0 " << oldval << std::endl;
107 *
ssThreshStream[nodeId]->GetStream () <<
"0.0 " << oldval << std::endl;
174 Config::Connect (
"/NodeList/" + std::to_string (nodeId) +
"/$ns3::TcpL4Protocol/SocketList/0/CongestionWindow",
183 Config::Connect (
"/NodeList/" + std::to_string (nodeId) +
"/$ns3::TcpL4Protocol/SocketList/0/SlowStartThreshold",
192 Config::Connect (
"/NodeList/" + std::to_string (nodeId) +
"/$ns3::TcpL4Protocol/SocketList/0/RTT",
201 Config::Connect (
"/NodeList/" + std::to_string (nodeId) +
"/$ns3::TcpL4Protocol/SocketList/0/RTO",
210 Config::Connect (
"/NodeList/" + std::to_string (nodeId) +
"/$ns3::TcpL4Protocol/SocketList/0/NextTxSequence",
219 Config::Connect (
"/NodeList/" + std::to_string (nodeId) +
"/$ns3::TcpL4Protocol/SocketList/0/BytesInFlight",
229 "/$ns3::TcpL4Protocol/SocketList/1/RxBuffer/NextRxSequence",
233int main (
int argc,
char *argv[])
235 std::string transport_prot =
"TcpWestwood";
236 double error_p = 0.0;
237 std::string bandwidth =
"2Mbps";
238 std::string delay =
"0.01ms";
239 std::string access_bandwidth =
"10Mbps";
240 std::string access_delay =
"45ms";
242 std::string prefix_file_name =
"TcpVariantsComparison";
243 uint64_t data_mbytes = 0;
245 uint16_t num_flows = 1;
246 double duration = 100.0;
248 bool flow_monitor =
false;
251 std::string queue_disc_type =
"ns3::PfifoFastQueueDisc";
252 std::string recovery =
"ns3::TcpClassicRecovery";
256 cmd.AddValue (
"transport_prot",
"Transport protocol to use: TcpNewReno, TcpLinuxReno, "
257 "TcpHybla, TcpHighSpeed, TcpHtcp, TcpVegas, TcpScalable, TcpVeno, "
258 "TcpBic, TcpYeah, TcpIllinois, TcpWestwood, TcpWestwoodPlus, TcpLedbat, "
259 "TcpLp, TcpDctcp, TcpCubic, TcpBbr", transport_prot);
260 cmd.AddValue (
"error_p",
"Packet error rate", error_p);
261 cmd.AddValue (
"bandwidth",
"Bottleneck bandwidth", bandwidth);
262 cmd.AddValue (
"delay",
"Bottleneck delay", delay);
263 cmd.AddValue (
"access_bandwidth",
"Access link bandwidth", access_bandwidth);
264 cmd.AddValue (
"access_delay",
"Access link delay", access_delay);
265 cmd.AddValue (
"tracing",
"Flag to enable/disable tracing",
tracing);
266 cmd.AddValue (
"prefix_name",
"Prefix of output trace file", prefix_file_name);
267 cmd.AddValue (
"data",
"Number of Megabytes of data to transmit", data_mbytes);
268 cmd.AddValue (
"mtu",
"Size of IP packets to send in bytes", mtu_bytes);
269 cmd.AddValue (
"num_flows",
"Number of flows", num_flows);
270 cmd.AddValue (
"duration",
"Time to allow flows to run in seconds", duration);
271 cmd.AddValue (
"run",
"Run index (for setting repeatable seeds)", run);
272 cmd.AddValue (
"flow_monitor",
"Enable flow monitor", flow_monitor);
273 cmd.AddValue (
"pcap_tracing",
"Enable or disable PCAP tracing", pcap);
274 cmd.AddValue (
"queue_disc_type",
"Queue disc type for gateway (e.g. ns3::CoDelQueueDisc)", queue_disc_type);
275 cmd.AddValue (
"sack",
"Enable or disable SACK option", sack);
276 cmd.AddValue (
"recovery",
"Recovery algorithm type to use (e.g., ns3::TcpPrrRecovery", recovery);
277 cmd.Parse (argc, argv);
279 transport_prot = std::string (
"ns3::") + transport_prot;
281 SeedManager::SetSeed (1);
282 SeedManager::SetRun (run);
298 uint32_t tcp_adu_size = mtu_bytes - 20 - (ip_header + tcp_header);
302 double start_time = 0.1;
303 double stop_time = start_time + duration;
313 if (transport_prot.compare (
"ns3::TcpWestwoodPlus") == 0)
323 NS_ABORT_MSG_UNLESS (TypeId::LookupByNameFailSafe (transport_prot, &tcpTid),
"TypeId " << transport_prot <<
" not found");
331 sources.
Create (num_flows);
341 error_model.
SetUnit (RateErrorModel::ERROR_UNIT_PACKET);
360 address.SetBase (
"10.0.0.0",
"255.255.255.0");
370 DataRate access_b (access_bandwidth);
372 Time access_d (access_delay);
373 Time bottle_d (delay);
376 ((access_d + bottle_d) * 2).GetSeconds ());
383 for (
uint32_t i = 0; i < num_flows; i++)
392 if (queue_disc_type.compare (
"ns3::PfifoFastQueueDisc") == 0)
396 else if (queue_disc_type.compare (
"ns3::CoDelQueueDisc") == 0)
402 NS_FATAL_ERROR (
"Queue not recognized. Allowed values are ns3::CoDelQueueDisc or ns3::PfifoFastQueueDisc");
410 Ipv4GlobalRoutingHelper::PopulateRoutingTables ();
412 uint16_t
port = 50000;
416 for (uint16_t i = 0; i < sources.
GetN (); i++)
421 ftp.SetAttribute (
"Remote", remoteAddress);
423 ftp.SetAttribute (
"MaxBytes",
UintegerValue (data_mbytes * 1000000));
429 sinkHelper.SetAttribute (
"Protocol",
TypeIdValue (TcpSocketFactory::GetTypeId ()));
440 ascii.open ((prefix_file_name +
"-ascii").c_str ());
443 stack.EnableAsciiIpv4All (ascii_wrap);
445 for (uint16_t index = 0; index < num_flows; index++)
447 std::string flowString (
"");
450 flowString =
"-flow" + std::to_string (index);
459 prefix_file_name + flowString +
"-cwnd.data", index+1);
461 prefix_file_name + flowString +
"-ssth.data", index+1);
462 Simulator::Schedule (
Seconds (start_time * index + 0.00001), &
TraceRtt,
463 prefix_file_name + flowString +
"-rtt.data", index+1);
464 Simulator::Schedule (
Seconds (start_time * index + 0.00001), &
TraceRto,
465 prefix_file_name + flowString +
"-rto.data", index+1);
467 prefix_file_name + flowString +
"-next-tx.data", index+1);
469 prefix_file_name + flowString +
"-inflight.data", index+1);
471 prefix_file_name + flowString +
"-next-rx.data", num_flows+index+1);
488 Simulator::Stop (
Seconds (stop_time));
496 Simulator::Destroy ();
a polymophic address class
AttributeValue implementation for Address.
holds a vector of ns3::Application pointers.
void Start(Time start)
Arrange for all of the Applications in this container to Start() at the Time given as a parameter.
void Stop(Time stop)
Arrange for all of the Applications in this container to Stop() at the Time given as a parameter.
Manage ASCII trace files for device models.
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.
AttributeValue implementation for Boolean.
A helper to make it easier to instantiate an ns3::BulkSendApplication on a set of nodes.
Parse command-line arguments.
Class for representing data rates.
Hold variables of type enum.
Helper to enable IP flow monitoring on a set of Nodes.
Ptr< FlowMonitor > InstallAll()
Enable flow monitoring on all nodes.
void SerializeToXmlFile(std::string fileName, bool enableHistograms, bool enableProbes)
Same as SerializeToXmlStream, but writes to a file instead.
aggregate IP/TCP/UDP functionality to existing Nodes.
A helper class to make life easier while doing simple IPv4 address assignment in scripts.
holds a vector of std::pair of Ptr<Ipv4> and interface index.
void Add(const Ipv4InterfaceContainer &other)
Concatenate the entries in the other container with ours.
Ipv4Address GetAddress(uint32_t i, uint32_t j=0) const
holds a vector of ns3::NetDevice pointers
keep track of a set of node pointers.
uint32_t GetN(void) const
Get the number of Ptr<Node> stored in this container.
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.
A class encapsulating an output stream.
A helper to make it easier to instantiate an ns3::PacketSinkApplication on a set of nodes.
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 ...
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 SetChannelAttribute(std::string name, const AttributeValue &value)
Set an attribute value to be propagated to each Channel created by the helper.
NetDeviceContainer Install(NodeContainer c)
Hold objects of type Ptr<T>.
Class for representing queue sizes.
AttributeValue implementation for QueueSize.
void SetStream(int64_t stream)
Specifies the stream number for the RngStream.
Determine which packets are errored corresponding to an underlying distribution, rate,...
void SetRate(double rate)
void SetUnit(enum ErrorUnit error_unit)
void SetRandomVariable(Ptr< RandomVariableStream >)
Hold variables of type string.
Simulation virtual time values and global simulation resolution.
double GetSeconds(void) const
Get an approximation of the time stored in this instance in the indicated unit.
Build a set of QueueDisc objects.
QueueDiscContainer Install(NetDeviceContainer c)
uint16_t SetRootQueueDisc(const std::string &type, Args &&... args)
Helper function used to set a root queue disc of the given type and with the given attributes.
a unique identifier for an interface.
AttributeValue implementation for TypeId.
Hold an unsigned integer type.
void SetDefault(std::string name, const AttributeValue &value)
void Connect(std::string path, const CallbackBase &cb)
#define NS_ABORT_MSG_UNLESS(cond, msg)
Abnormal program termination if a condition is false, with a message.
#define NS_FATAL_ERROR(msg)
Report a fatal error with a message and terminate.
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
#define NS_LOG_LOGIC(msg)
Use NS_LOG to output a message of level LOG_LOGIC.
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
@ BYTES
Use number of bytes for queue size.
@ PACKETS
Use number of packets for queue size.
Time Now(void)
create an ns3::Time instance which contains the current simulation time.
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, Ts... > MakeCallback(R(T::*memPtr)(Ts...), OBJ objPtr)
Build Callbacks for class method members which take varying numbers of arguments and potentially retu...
static void RttTracer(std::string context, Time oldval, Time newval)
static std::map< uint32_t, bool > firstCwnd
static std::map< uint32_t, uint32_t > cWndValue
static void TraceInFlight(std::string &in_flight_file_name, uint32_t nodeId)
static void NextRxTracer(std::string context, SequenceNumber32 old, SequenceNumber32 nextRx)
static std::map< uint32_t, Ptr< OutputStreamWrapper > > nextTxStream
static std::map< uint32_t, Ptr< OutputStreamWrapper > > inFlightStream
static std::map< uint32_t, bool > firstSshThr
static std::map< uint32_t, bool > firstRto
static std::map< uint32_t, Ptr< OutputStreamWrapper > > nextRxStream
static uint32_t GetNodeIdFromContext(std::string context)
static std::map< uint32_t, Ptr< OutputStreamWrapper > > rtoStream
static void InFlightTracer(std::string context, uint32_t old, uint32_t inFlight)
static void NextTxTracer(std::string context, SequenceNumber32 old, SequenceNumber32 nextTx)
static std::map< uint32_t, uint32_t > ssThreshValue
static void TraceRtt(std::string rtt_tr_file_name, uint32_t nodeId)
static void TraceSsThresh(std::string ssthresh_tr_file_name, uint32_t nodeId)
static std::map< uint32_t, bool > firstRtt
static void TraceNextTx(std::string &next_tx_seq_file_name, uint32_t nodeId)
static void CwndTracer(std::string context, uint32_t oldval, uint32_t newval)
static void SsThreshTracer(std::string context, uint32_t oldval, uint32_t newval)
static std::map< uint32_t, Ptr< OutputStreamWrapper > > ssThreshStream
static std::map< uint32_t, Ptr< OutputStreamWrapper > > rttStream
static void TraceCwnd(std::string cwnd_tr_file_name, uint32_t nodeId)
static void RtoTracer(std::string context, Time oldval, Time newval)
static void TraceNextRx(std::string &next_rx_seq_file_name, uint32_t nodeId)
static std::map< uint32_t, Ptr< OutputStreamWrapper > > cWndStream
static void TraceRto(std::string rto_tr_file_name, uint32_t nodeId)
bool tracing
Flag to enable/disable generation of tracing files.