86 #include "ns3/core-module.h"
87 #include "ns3/point-to-point-module.h"
88 #include "ns3/internet-module.h"
89 #include "ns3/applications-module.h"
90 #include "ns3/network-module.h"
91 #include "ns3/packet-sink.h"
92 #include "ns3/flow-monitor-module.h"
93 #include "ns3/ipv4-global-routing-helper.h"
94 #include "ns3/traffic-control-module.h"
146 main (
int argc,
char *argv[])
150 uint32_t maxBytes = 0;
151 std::string transportProtocol =
"ns3::TcpNewReno";
154 DataRate bottleneckBandwidth (
"10Mbps");
156 DataRate regLinkBandwidth =
DataRate (4 * bottleneckBandwidth.GetBitRate ());
160 bool isPacingEnabled =
true;
162 bool useQueueDisc =
true;
163 bool shouldPaceInitialWindow =
true;
171 cmd.AddValue (
"tracing",
"Flag to enable/disable Ascii and Pcap tracing",
tracing);
172 cmd.AddValue (
"maxBytes",
"Total number of bytes for application to send", maxBytes);
173 cmd.AddValue (
"isPacingEnabled",
"Flag to enable/disable pacing in TCP", isPacingEnabled);
174 cmd.AddValue (
"maxPacingRate",
"Max Pacing Rate", maxPacingRate);
175 cmd.AddValue (
"useEcn",
"Flag to enable/disable ECN", useEcn);
176 cmd.AddValue (
"useQueueDisc",
"Flag to enable/disable queue disc on bottleneck", useQueueDisc);
177 cmd.AddValue (
"shouldPaceInitialWindow",
"Flag to enable/disable pacing of TCP initial window", shouldPaceInitialWindow);
178 cmd.AddValue (
"simulationEndTime",
"Simulation end time", simulationEndTime);
179 cmd.Parse (argc, argv);
230 ipv4.
SetBase (
"10.1.1.0",
"255.255.255.0");
233 ipv4.
SetBase (
"10.1.2.0",
"255.255.255.0");
236 ipv4.
SetBase (
"10.1.3.0",
"255.255.255.0");
239 ipv4.
SetBase (
"10.1.4.0",
"255.255.255.0");
242 ipv4.
SetBase (
"10.1.5.0",
"255.255.255.0");
250 uint16_t sinkPort = 8080;
258 sinkApps4.
Stop (simulationEndTime);
260 sinkApps5.
Stop (simulationEndTime);
276 sourceApps0.
Stop (simulationEndTime);
278 sourceApps1.
Stop (simulationEndTime);
287 cwndStream.open (
"tcp-dynamic-pacing-cwnd.dat", std::ios::out);
288 cwndStream <<
"#Time(s) Congestion Window (B)" << std::endl;
290 pacingRateStream.open (
"tcp-dynamic-pacing-pacing-rate.dat", std::ios::out);
293 ssThreshStream.open (
"tcp-dynamic-pacing-ssthresh.dat", std::ios::out);
294 ssThreshStream <<
"#Time(s) Slow Start threshold (B)" << std::endl;
308 monitor->CheckForLostPackets ();
311 for (std::map<FlowId, FlowMonitor::FlowStats>::const_iterator i = stats.begin (); i != stats.end (); ++i)
316 std::cout <<
" Tx Packets: " << i->second.txPackets <<
"\n";
317 std::cout <<
" Tx Bytes: " << i->second.txBytes <<
"\n";
318 std::cout <<
" TxOffered: " << i->second.txBytes * 8.0 / simulationEndTime.
GetSeconds () / 1000 / 1000 <<
" Mbps\n";
319 std::cout <<
" Rx Packets: " << i->second.rxPackets <<
"\n";
320 std::cout <<
" Rx Bytes: " << i->second.rxBytes <<
"\n";
321 std::cout <<
" Throughput: " << i->second.rxBytes * 8.0 / simulationEndTime.
GetSeconds () / 1000 / 1000 <<
" Mbps\n";
a polymophic address class
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.
void EnableAsciiAll(std::string prefix)
Enable ascii trace output on each device (which is of the appropriate type) in the set of all nodes c...
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.
uint64_t GetBitRate() const
Get the underlying bitrate.
AttributeValue implementation for DataRate.
Hold variables of type enum.
Helper to enable IP flow monitoring on a set of Nodes.
Ptr< FlowClassifier > GetClassifier()
Retrieve the FlowClassifier object for IPv4 created by the Install* methods.
Ptr< FlowMonitor > InstallAll()
Enable flow monitoring on all nodes.
std::map< FlowId, FlowStats > FlowStatsContainer
Container: FlowId, FlowStats.
aggregate IP/TCP/UDP functionality to existing Nodes.
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...
static Ipv4Address GetAny(void)
static void PopulateRoutingTables(void)
Build a routing database and initialize the routing tables of the nodes in the simulation.
holds a vector of std::pair of Ptr<Ipv4> and interface index.
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.
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.
uint32_t GetSize(void) const
Returns the the size in bytes of the packet (including the zero-filled initial payload).
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)
void SetStream(int64_t stream)
Specifies the stream number for the RngStream.
static void Stop(void)
Tell the Simulator the calling event should be the last one executed.
static void Destroy(void)
Execute the events scheduled with ScheduleDestroy().
static EventId Schedule(Time const &delay, FUNC f, Ts &&... args)
Schedule an event to expire after delay.
static void Run(void)
Run the simulation.
static Time Now(void)
Return the current simulation virtual time.
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.
AttributeValue implementation for Time.
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.
static TypeId LookupByName(std::string name)
Get a TypeId by name.
AttributeValue implementation for TypeId.
Hold an unsigned integer type.
void SetDefault(std::string name, const AttributeValue &value)
void ConnectWithoutContext(std::string path, const CallbackBase &cb)
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
void(* DataRate)(DataRate oldValue, DataRate newValue)
TracedValue callback signature for DataRate.
Time MicroSeconds(uint64_t value)
Construct a Time in the indicated unit.
Time Seconds(double value)
Construct a Time in the indicated unit.
Time MilliSeconds(uint64_t 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...
Structure to classify a packet.
Ipv4Address sourceAddress
Source address.
Ipv4Address destinationAddress
Destination address.
std::ofstream packetTraceStream
static void TxTracer(Ptr< const Packet > p, Ptr< Ipv4 > ipv4, uint32_t interface)
static void RxTracer(Ptr< const Packet > p, Ptr< Ipv4 > ipv4, uint32_t interface)
void ConnectSocketTraces(void)
std::ofstream ssThreshStream
static void CwndTracer(uint32_t oldval, uint32_t newval)
std::ofstream pacingRateStream
static void SsThreshTracer(uint32_t oldval, uint32_t newval)
static void PacingRateTracer(DataRate oldval, DataRate newval)
bool tracing
Flag to enable/disable generation of tracing files.