59 #include "ns3/core-module.h"
60 #include "ns3/network-module.h"
61 #include "ns3/mpi-interface.h"
62 #include "ns3/ipv4-global-routing-helper.h"
63 #include "ns3/ipv4-static-routing-helper.h"
64 #include "ns3/ipv4-list-routing-helper.h"
65 #include "ns3/point-to-point-helper.h"
66 #include "ns3/internet-stack-helper.h"
67 #include "ns3/ipv4-nix-vector-helper.h"
68 #include "ns3/ipv4-address-helper.h"
69 #include "ns3/on-off-helper.h"
70 #include "ns3/packet-sink-helper.h"
81 main (
int argc,
char *argv[])
91 cmd.
AddValue (
"nix",
"Enable the use of nix-vector or global routing", nix);
92 cmd.
AddValue (
"nullmsg",
"Enable the use of null-message synchronization", nullmsg);
93 cmd.
AddValue (
"tracing",
"Enable pcap tracing", tracing);
94 cmd.
Parse (argc, argv);
115 uint32_t rightHalfSystemId = 777;
119 if (systemCount == 2)
121 rightHalfSystemId = 0;
123 else if (systemCount == 3)
125 rightHalfSystemId = 1;
129 std::cout <<
"This simulation requires 2 or 3 logical processors." << std::endl;
140 leftLeafNodes.
Create (4, 0);
146 Ptr<Node> routerNode1 = CreateObject<Node> (0);
147 Ptr<Node> routerNode2 = CreateObject<Node> (rightHalfSystemId);
148 routerNodes.
Add (routerNode1);
149 routerNodes.
Add (routerNode2);
153 rightLeafNodes.
Create (4, rightHalfSystemId);
165 routerDevices = routerLink.
Install (routerNodes);
170 for (uint32_t i = 0; i < 4; ++i)
173 leftLeafDevices.
Add (temp.
Get (0));
174 leftRouterDevices.
Add (temp.
Get (1));
180 for (uint32_t i = 0; i < 4; ++i)
183 rightLeafDevices.
Add (temp.
Get (0));
184 rightRouterDevices.
Add (temp.
Get (1));
192 list.
Add (staticRouting, 0);
193 list.
Add (nixRouting, 10);
209 leftAddress.
SetBase (
"10.1.1.0",
"255.255.255.0");
212 routerAddress.
SetBase (
"10.2.1.0",
"255.255.255.0");
215 rightAddress.
SetBase (
"10.3.1.0",
"255.255.255.0");
218 routerInterfaces = routerAddress.
Assign (routerDevices);
221 for (uint32_t i = 0; i < 4; ++i)
224 ndc.
Add (leftLeafDevices.
Get (i));
225 ndc.
Add (leftRouterDevices.
Get (i));
227 leftLeafInterfaces.
Add (ifc.
Get (0));
228 leftRouterInterfaces.
Add (ifc.
Get (1));
233 for (uint32_t i = 0; i < 4; ++i)
236 ndc.
Add (rightLeafDevices.
Get (i));
237 ndc.
Add (rightRouterDevices.
Get (i));
239 rightLeafInterfaces.
Add (ifc.
Get (0));
240 rightRouterInterfaces.
Add (ifc.
Get (1));
253 routerLink.
EnablePcap(
"router-left", routerDevices,
true);
254 leafLink.
EnablePcap(
"leaf-left", leftLeafDevices,
true);
257 if (systemId == rightHalfSystemId)
259 routerLink.
EnablePcap(
"router-right", routerDevices,
true);
260 leafLink.
EnablePcap(
"leaf-right", rightLeafDevices,
true);
265 uint16_t
port = 50000;
266 if (systemId == rightHalfSystemId)
271 for (uint32_t i = 0; i < 4; ++i)
273 sinkApp.
Add (sinkHelper.Install (rightLeafNodes.
Get (i)));
283 clientHelper.SetAttribute
284 (
"OnTime",
StringValue (
"ns3::ConstantRandomVariable[Constant=1]"));
285 clientHelper.SetAttribute
286 (
"OffTime",
StringValue (
"ns3::ConstantRandomVariable[Constant=0]"));
289 for (uint32_t i = 0; i < 4; ++i)
293 clientHelper.SetAttribute (
"Remote", remoteAddress);
294 clientApps.
Add (clientHelper.Install (leftLeafNodes.
Get (i)));
307 NS_FATAL_ERROR (
"Can't use distributed simulator without MPI compiled in");
holds a vector of ns3::Application pointers.
static Ipv4Address GetAny(void)
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...
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.
Ptr< NetDevice > Get(uint32_t i) const
Get the Ptr stored in this container at a given index.
NetDeviceContainer Install(NodeContainer c)
void Add(ApplicationContainer other)
Append the contents of another ApplicationContainer to the end of this container. ...
static void Run(void)
Run the simulation.
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Helper class that adds Nix-vector routing to nodes.
aggregate IP/TCP/UDP functionality to existing Nodes.
#define NS_FATAL_ERROR(msg)
Fatal error handling.
A helper to make it easier to instantiate an ns3::PacketSinkApplication on a set of nodes...
static void Disable()
Terminates the parallel environment.
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.
A helper to make it easier to instantiate an ns3::OnOffApplication on a set of nodes.
a polymophic address class
void LogComponentEnable(char const *name, enum LogLevel level)
Enable the logging output associated with that log component.
void InstallAll(void) const
Aggregate IPv4, IPv6, UDP, and TCP stacks to all nodes in the simulation.
void Add(NetDeviceContainer other)
Append the contents of another NetDeviceContainer to the end of this container.
static void Enable(int *pargc, char ***pargv)
Sets up parallel communication interface.
Hold an unsigned integer type.
holds a vector of ns3::NetDevice pointers
static void Bind(std::string name, const AttributeValue &value)
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.
static void Destroy(void)
Execute the events scheduled with ScheduleDestroy().
void SetDefault(std::string name, const AttributeValue &value)
Every class exported by the ns3 library is enclosed in the ns3 namespace.
keep track of a set of node pointers.
void Add(const Ipv4RoutingHelper &routing, int16_t priority)
void SetChannelAttribute(std::string name, const AttributeValue &value)
Set an attribute value to be propagated to each Channel created by the helper.
AttributeValue implementation for 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 Add(NodeContainer other)
Append the contents of another NodeContainer to the end of this container.
static uint32_t GetSystemId()
Helper class that adds ns3::Ipv4StaticRouting objects.
void AddValue(const std::string &name, const std::string &help, T &value)
Add a program argument, assigning to POD.
static void Stop(void)
Tell the Simulator the calling event should be the last one executed.
Ptr< Node > Get(uint32_t i) const
Get the Ptr stored in this container at a given index.
Time Seconds(double value)
Construct a Time in the indicated unit.
Ipv4Address NewNetwork(void)
Increment the network number and reset the IP address counter to the base value provided in the SetBa...
Helper class that adds ns3::Ipv4ListRouting objects.
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 EnablePcap(std::string prefix, Ptr< NetDevice > nd, bool promiscuous=false, bool explicitFilename=false)
Enable pcap output the indicated net device.
static uint32_t GetSize()
void SetRoutingHelper(const Ipv4RoutingHelper &routing)
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