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"
116 int main (
int argc,
char *argv[])
118 std::string transport_prot =
"TcpWestwood";
119 double error_p = 0.0;
120 std::string bandwidth =
"2Mbps";
121 std::string access_bandwidth =
"10Mbps";
122 std::string access_delay =
"45ms";
123 bool tracing =
false;
124 std::string tr_file_name =
"";
125 std::string cwnd_tr_file_name =
"";
126 std::string ssthresh_tr_file_name =
"";
127 double data_mbytes = 0;
128 uint32_t mtu_bytes = 400;
129 uint16_t num_flows = 1;
130 float duration = 100;
132 bool flow_monitor =
true;
136 cmd.
AddValue (
"transport_prot",
"Transport protocol to use: TcpTahoe, TcpReno, TcpNewReno, TcpWestwood, TcpWestwoodPlus ", transport_prot);
137 cmd.
AddValue (
"error_p",
"Packet error rate", error_p);
138 cmd.
AddValue (
"bandwidth",
"Bottleneck bandwidth", bandwidth);
139 cmd.
AddValue (
"access_bandwidth",
"Access link bandwidth", access_bandwidth);
140 cmd.
AddValue (
"delay",
"Access link delay", access_delay);
141 cmd.
AddValue (
"tracing",
"Flag to enable/disable tracing", tracing);
142 cmd.
AddValue (
"tr_name",
"Name of output trace file", tr_file_name);
143 cmd.
AddValue (
"cwnd_tr_name",
"Name of output trace file", cwnd_tr_file_name);
144 cmd.
AddValue (
"ssthresh_tr_name",
"Name of output trace file", ssthresh_tr_file_name);
145 cmd.
AddValue (
"data",
"Number of Megabytes of data to transmit", data_mbytes);
146 cmd.
AddValue (
"mtu",
"Size of IP packets to send in bytes", mtu_bytes);
147 cmd.
AddValue (
"num_flows",
"Number of flows", num_flows);
148 cmd.
AddValue (
"duration",
"Time to allow flows to run in seconds", duration);
149 cmd.
AddValue (
"run",
"Run index (for setting repeatable seeds)", run);
150 cmd.
AddValue (
"flow_monitor",
"Enable flow monitor", flow_monitor);
151 cmd.
Parse (argc, argv);
170 uint32_t tcp_adu_size = mtu_bytes - (ip_header + tcp_header);
174 float start_time = 0.1;
175 float stop_time = start_time + duration;
178 if (transport_prot.compare (
"TcpTahoe") == 0)
182 else if (transport_prot.compare (
"TcpReno") == 0)
186 else if (transport_prot.compare (
"TcpNewReno") == 0)
190 else if (transport_prot.compare (
"TcpWestwood") == 0)
195 else if (transport_prot.compare (
"TcpWestwoodPlus") == 0)
211 sources.
Create (num_flows);
234 address.
SetBase (
"10.0.0.0",
"255.255.255.0");
242 for (
int i = 0; i < num_flows; i++)
245 devices = LocalLink.
Install (sources.
Get (i), gateways.
Get (0));
248 devices = UnReLink.
Install (gateways.
Get (0), sinks.
Get (i));
250 interfaces = address.
Assign (devices);
251 sink_interfaces.
Add (interfaces.
Get (1));
257 uint16_t
port = 50000;
261 for (uint16_t i = 0; i < sources.
GetN (); i++)
265 if (transport_prot.compare (
"TcpTahoe") == 0
266 || transport_prot.compare (
"TcpReno") == 0
267 || transport_prot.compare (
"TcpNewReno") == 0
268 || transport_prot.compare (
"TcpWestwood") == 0
269 || transport_prot.compare (
"TcpWestwoodPlus") == 0)
288 NS_LOG_DEBUG (
"Invalid transport protocol " << transport_prot <<
" specified");
296 if (tr_file_name.compare (
"") != 0)
300 ascii.open (tr_file_name.c_str ());
305 if (cwnd_tr_file_name.compare (
"") != 0)
310 if (ssthresh_tr_file_name.compare (
"") != 0)
holds a vector of ns3::Application pointers.
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 until one of:
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.
static EventId Schedule(Time const &time, MEM mem_ptr, OBJ obj)
Schedule an event to expire at the relative time "time" is reached.
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.
ApplicationContainer Install(NodeContainer c) const
Install an ns3::BulkSendApplication on each node of the input container configured with all the attri...
int main(int argc, char *argv[])
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'
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.
hold objects of type ns3::TypeId
Callback< R > MakeCallback(R(T::*memPtr)(void), OBJ objPtr)
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)
Every event scheduled by the Simulator::insertAtDestroy method is invoked.
static void CwndTracer(uint32_t oldval, uint32_t newval)
static TypeId GetTypeId(void)
Get the type ID.
void SetDefault(std::string name, const AttributeValue &value)
keep track of a set of node pointers.
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.
Helper to enable IP flow monitoring on a set of Nodes.
static Time Now(void)
Return the "current simulation 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 it will duplicate the seed value 6 times
void SetUnit(enum ErrorUnit error_unit)
hold objects of type ns3::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)
If an event invokes this method, it will be the last event scheduled by the Simulator::run method bef...
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 SetRandomVariable(Ptr< RandomVariableStream >)
Ipv4Address NewNetwork(void)
Increment the network number and reset the IP address counter to the base value provided in the SetBa...
ApplicationContainer Install(NodeContainer c) const
Install an ns3::PacketSinkApplication on each node of the input container configured with all the att...
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.
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.
void SetAttribute(std::string name, const AttributeValue &value)
Helper function used to set the underlying application attributes, not the socket attributes...
Determine which packets are errored corresponding to an underlying distribution, rate, and unit.
static void TraceCwnd(std::string cwnd_tr_file_name)
static void SsThreshTracer(uint32_t oldval, uint32_t newval)
void ConnectWithoutContext(std::string path, const CallbackBase &cb)
std::ostream * GetStream(void)
Return a pointer to an ostream previously set in the wrapper.
Ptr< OutputStreamWrapper > ssThreshStream
void SetAttribute(std::string name, const AttributeValue &value)
Helper function used to set the underlying application attributes.
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