A Discrete-Event Network Simulator
API
third-distributed.cc
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * This program is free software; you can redistribute it and/or modify
4  * it under the terms of the GNU General Public License version 2 as
5  * published by the Free Software Foundation;
6  *
7  * This program is distributed in the hope that it will be useful,
8  * but WITHOUT ANY WARRANTY; without even the implied warranty of
9  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10  * GNU General Public License for more details.
11  *
12  * You should have received a copy of the GNU General Public License
13  * along with this program; if not, write to the Free Software
14  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
15  */
16 
17 #include "ns3/core-module.h"
18 #include "ns3/point-to-point-module.h"
19 #include "ns3/network-module.h"
20 #include "ns3/applications-module.h"
21 #include "ns3/wifi-module.h"
22 #include "ns3/mobility-module.h"
23 #include "ns3/csma-module.h"
24 #include "ns3/internet-module.h"
25 
26 #include "ns3/mpi-module.h"
27 
28 // Default Network Topology
29 //
30 // (same as third.cc from tutorial)
31 // Distributed simulation, split along the p2p link
32 // Number of wifi or csma nodes can be increased up to 250
33 // |
34 // Rank 0 | Rank 1
35 // -------------------------|----------------------------
36 // Wifi 10.1.3.0
37 // AP
38 // * * * *
39 // | | | | 10.1.1.0
40 // n5 n6 n7 n0 -------------- n1 n2 n3 n4
41 // point-to-point | | | |
42 // ================
43 // LAN 10.1.2.0
44 
45 using namespace ns3;
46 
47 NS_LOG_COMPONENT_DEFINE ("ThirdExampleDistributed");
48 
49 int
50 main (int argc, char *argv[])
51 {
52  bool verbose = true;
53  uint32_t nCsma = 3;
54  uint32_t nWifi = 3;
55  bool tracing = false;
56  bool nullmsg = false;
57 
59  cmd.AddValue ("nCsma", "Number of \"extra\" CSMA nodes/devices", nCsma);
60  cmd.AddValue ("nWifi", "Number of wifi STA devices", nWifi);
61  cmd.AddValue ("verbose", "Tell echo applications to log if true", verbose);
62  cmd.AddValue ("tracing", "Enable pcap tracing", tracing);
63  cmd.AddValue ("nullmsg", "Enable the use of null-message synchronization", nullmsg);
64 
65  cmd.Parse (argc,argv);
66 
67  // Check for valid number of csma or wifi nodes
68  // 250 should be enough, otherwise IP addresses
69  // soon become an issue
70  if (nWifi > 250 || nCsma > 250)
71  {
72  std::cout << "Too many wifi or csma nodes, no more than 250 each." << std::endl;
73  return 1;
74  }
75 
76  if (verbose)
77  {
78  LogComponentEnable ("UdpEchoClientApplication", LOG_LEVEL_INFO);
79  LogComponentEnable ("UdpEchoServerApplication", LOG_LEVEL_INFO);
80  }
81 
82  // Sequential fallback values
83  uint32_t systemId = 0;
84  uint32_t systemCount = 1;
85 
86 #ifdef NS3_MPI
87 
88  // Distributed simulation setup; by default use granted time window algorithm.
89  if(nullmsg)
90  {
91  GlobalValue::Bind ("SimulatorImplementationType",
92  StringValue ("ns3::NullMessageSimulatorImpl"));
93  }
94  else
95  {
96  GlobalValue::Bind ("SimulatorImplementationType",
97  StringValue ("ns3::DistributedSimulatorImpl"));
98  }
99 
100  MpiInterface::Enable (&argc, &argv);
101 
102  systemId = MpiInterface::GetSystemId ();
103  systemCount = MpiInterface::GetSize ();
104 
105  // Check for valid distributed parameters.
106  // Must have 2 and only 2 Logical Processors (LPs)
107  if (systemCount != 2)
108  {
109  std::cout << "This simulation requires 2 and only 2 logical processors." << std::endl;
110  return 1;
111  }
112 
113 #endif // NS3_MPI
114 
115  // System id of Wifi side
116  uint32_t systemWifi = 0;
117 
118  // System id of CSMA side
119  uint32_t systemCsma = systemCount - 1;
120 
122  Ptr<Node> p2pNode1 = CreateObject<Node> (systemWifi); // Create node with rank 0
123  Ptr<Node> p2pNode2 = CreateObject<Node> (systemCsma); // Create node with rank 1
124  p2pNodes.Add (p2pNode1);
125  p2pNodes.Add (p2pNode2);
126 
128  pointToPoint.SetDeviceAttribute ("DataRate", StringValue ("5Mbps"));
129  pointToPoint.SetChannelAttribute ("Delay", StringValue ("2ms"));
130 
132  p2pDevices = pointToPoint.Install (p2pNodes);
133 
135  csmaNodes.Add (p2pNodes.Get (1));
136  csmaNodes.Create (nCsma, systemCsma); // Create csma nodes with rank 1
137 
139  csma.SetChannelAttribute ("DataRate", StringValue ("100Mbps"));
140  csma.SetChannelAttribute ("Delay", TimeValue (NanoSeconds (6560)));
141 
143  csmaDevices = csma.Install (csmaNodes);
144 
146  wifiStaNodes.Create (nWifi, systemWifi); // Create wifi nodes with rank 0
147  NodeContainer wifiApNode = p2pNodes.Get (0);
148 
151  phy.SetChannel (channel.Create ());
152 
154  wifi.SetRemoteStationManager ("ns3::AarfWifiManager");
155 
157  Ssid ssid = Ssid ("ns-3-ssid");
158  mac.SetType ("ns3::StaWifiMac",
159  "Ssid", SsidValue (ssid),
160  "ActiveProbing", BooleanValue (false));
161 
163  staDevices = wifi.Install (phy, mac, wifiStaNodes);
164 
165  mac.SetType ("ns3::ApWifiMac",
166  "Ssid", SsidValue (ssid));
167 
169  apDevices = wifi.Install (phy, mac, wifiApNode);
170 
172 
173  mobility.SetPositionAllocator ("ns3::GridPositionAllocator",
174  "MinX", DoubleValue (0.0),
175  "MinY", DoubleValue (0.0),
176  "DeltaX", DoubleValue (5.0),
177  "DeltaY", DoubleValue (10.0),
178  "GridWidth", UintegerValue (3),
179  "LayoutType", StringValue ("RowFirst"));
180 
181  mobility.SetMobilityModel ("ns3::RandomWalk2dMobilityModel",
182  "Bounds", RectangleValue (Rectangle (-50, 50, -50, 50)));
183  mobility.Install (wifiStaNodes);
184 
185  mobility.SetMobilityModel ("ns3::ConstantPositionMobilityModel");
186  mobility.Install (wifiApNode);
187 
189  stack.Install (csmaNodes);
190  stack.Install (wifiApNode);
191  stack.Install (wifiStaNodes);
192 
194 
195  address.SetBase ("10.1.1.0", "255.255.255.0");
197  p2pInterfaces = address.Assign (p2pDevices);
198 
199  address.SetBase ("10.1.2.0", "255.255.255.0");
201  csmaInterfaces = address.Assign (csmaDevices);
202 
203  address.SetBase ("10.1.3.0", "255.255.255.0");
204  address.Assign (staDevices);
205  address.Assign (apDevices);
206 
207  // If this rank is systemCsma,
208  // it should contain the server application,
209  // since it is on one of the csma nodes
210  if (systemId == systemCsma)
211  {
213 
214  ApplicationContainer serverApps = echoServer.Install (csmaNodes.Get (nCsma));
215  serverApps.Start (Seconds (1.0));
216  serverApps.Stop (Seconds (10.0));
217  }
218 
219  // If this rank is systemWifi
220  // it should contain the client application,
221  // since it is on one of the wifi nodes
222  if (systemId == systemWifi)
223  {
224  UdpEchoClientHelper echoClient (csmaInterfaces.GetAddress (nCsma), 9);
225  echoClient.SetAttribute ("MaxPackets", UintegerValue (1));
226  echoClient.SetAttribute ("Interval", TimeValue (Seconds (1.0)));
227  echoClient.SetAttribute ("PacketSize", UintegerValue (1024));
228 
230  echoClient.Install (wifiStaNodes.Get (nWifi - 1));
231  clientApps.Start (Seconds (2.0));
232  clientApps.Stop (Seconds (10.0));
233  }
234 
236 
237  Simulator::Stop (Seconds (10.0));
238 
239  if (tracing == true)
240  {
241  // Depending on the system Id (rank), the pcap information
242  // traced will be different. For example, the ethernet pcap
243  // will be empty for rank0, since these nodes are placed on
244  // on rank 1. All ethernet traffic will take place on rank 1.
245  // Similar differences are seen in the p2p and wireless pcaps.
246  if (systemId == systemWifi)
247  {
248  pointToPoint.EnablePcapAll ("third-distributed-wifi");
249  phy.EnablePcap ("third-distributed-wifi", apDevices.Get (0));
250  csma.EnablePcap ("third-distributed-wifi", csmaDevices.Get (0), true);
251  }
252  else // systemCsma
253  {
254  pointToPoint.EnablePcapAll ("third-distributed-csma");
255  phy.EnablePcap ("third-distributed-csma", apDevices.Get (0));
256  csma.EnablePcap ("third-distributed-csma", csmaDevices.Get (0), true);
257  }
258  }
259 
260  Simulator::Run ();
262 
263 #ifdef NS3_MPI
264  // Exit the MPI execution environment
266 #endif
267 
268  return 0;
269 }
tuple channel
Definition: third.py:85
holds a vector of ns3::Application pointers.
tuple nCsma
Definition: second.py:42
tuple pointToPoint
Definition: first.py:28
void SetChannelAttribute(std::string n1, const AttributeValue &v1)
Definition: csma-helper.cc:69
AttributeValue implementation for Boolean.
Definition: boolean.h:34
holds a vector of std::pair of Ptr and interface index.
Ptr< YansWifiChannel > Create(void) const
void SetRemoteStationManager(std::string type, std::string n0="", const AttributeValue &v0=EmptyAttributeValue(), std::string n1="", const AttributeValue &v1=EmptyAttributeValue(), std::string n2="", const AttributeValue &v2=EmptyAttributeValue(), std::string n3="", const AttributeValue &v3=EmptyAttributeValue(), std::string n4="", const AttributeValue &v4=EmptyAttributeValue(), std::string n5="", const AttributeValue &v5=EmptyAttributeValue(), std::string n6="", const AttributeValue &v6=EmptyAttributeValue(), std::string n7="", const AttributeValue &v7=EmptyAttributeValue())
Definition: wifi-helper.cc:683
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
Ptr< NetDevice > Get(uint32_t i) const
Get the Ptr stored in this container at a given index.
Make it easy to create and manage PHY objects for the yans model.
static YansWifiChannelHelper Default(void)
Create a channel helper in a default working state.
NetDeviceContainer Install(NodeContainer c)
tuple echoServer
Definition: first.py:43
Create an application which sends a UDP packet and waits for an echo of this packet.
static void Run(void)
Run the simulation.
Definition: simulator.cc:201
#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.
LOG_INFO and above.
Definition: log.h:103
NetDeviceContainer Install(Ptr< Node > node) const
This method creates an ns3::CsmaChannel with the attributes configured by CsmaHelper::SetChannelAttri...
Definition: csma-helper.cc:215
tuple nWifi
Definition: third.py:52
static void Disable()
Terminates the parallel environment.
tuple csmaNodes
Definition: second.py:53
Build a set of PointToPointNetDevice objects.
static YansWifiPhyHelper Default(void)
Create a phy helper in a default working state.
void SetDeviceAttribute(std::string name, const AttributeValue &value)
Set an attribute value to be propagated to each NetDevice created by the helper.
helps to create WifiNetDevice objects
Definition: wifi-helper.h:231
tuple cmd
Definition: second.py:35
virtual NetDeviceContainer Install(const WifiPhyHelper &phy, const WifiMacHelper &mac, NodeContainer c) const
Definition: wifi-helper.cc:712
tuple clientApps
Definition: first.py:54
AttributeValue implementation for Rectangle.
Definition: rectangle.h:97
tuple csmaDevices
Definition: second.py:67
void SetChannel(Ptr< YansWifiChannel > channel)
Create a server application which waits for input UDP packets and sends them back to the original sen...
void Install(Ptr< Node > node) const
"Layout" a single node according to the current position allocator type.
void LogComponentEnable(char const *name, enum LogLevel level)
Enable the logging output associated with that log component.
Definition: log.cc:351
tuple mobility
Definition: third.py:101
tuple phy
Definition: third.py:86
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 ...
tuple csmaInterfaces
Definition: second.py:78
AttributeValue implementation for Time.
Definition: nstime.h:957
Time NanoSeconds(uint64_t value)
Construct a Time in the indicated unit.
Definition: nstime.h:919
static void Enable(int *pargc, char ***pargv)
Sets up parallel communication interface.
Hold an unsigned integer type.
Definition: uinteger.h:44
tuple p2pInterfaces
Definition: second.py:75
holds a vector of ns3::NetDevice pointers
tuple staDevices
Definition: third.py:96
static void Bind(std::string name, const AttributeValue &value)
Iterate over the set of GlobalValues until a matching name is found and then set its value with Globa...
tuple mac
Definition: third.py:92
void Start(Time start)
Arrange for all of the Applications in this container to Start() at the Time given as a parameter...
tuple p2pNodes
Definition: second.py:50
Parse command-line arguments.
Definition: command-line.h:205
tuple p2pDevices
Definition: second.py:61
static void Destroy(void)
Execute the events scheduled with ScheduleDestroy().
Definition: simulator.cc:165
tuple echoClient
Definition: first.py:49
tuple serverApps
Definition: first.py:45
tuple wifiApNode
Definition: third.py:83
Every class exported by the ns3 library is enclosed in the ns3 namespace.
tuple apDevices
Definition: third.py:99
keep track of a set of node pointers.
void SetMobilityModel(std::string type, std::string n1="", const AttributeValue &v1=EmptyAttributeValue(), std::string n2="", const AttributeValue &v2=EmptyAttributeValue(), std::string n3="", const AttributeValue &v3=EmptyAttributeValue(), std::string n4="", const AttributeValue &v4=EmptyAttributeValue(), std::string n5="", const AttributeValue &v5=EmptyAttributeValue(), std::string n6="", const AttributeValue &v6=EmptyAttributeValue(), std::string n7="", const AttributeValue &v7=EmptyAttributeValue(), std::string n8="", const AttributeValue &v8=EmptyAttributeValue(), std::string n9="", const AttributeValue &v9=EmptyAttributeValue())
void Install(std::string nodeName) const
Aggregate implementations of the ns3::Ipv4, ns3::Ipv6, ns3::Udp, and ns3::Tcp classes onto the provid...
tuple ssid
Definition: third.py:93
manage and create wifi channel objects for the yans model.
create MAC layers for a ns3::WifiNetDevice.
tuple stack
Definition: first.py:34
The IEEE 802.11 SSID Information Element.
Definition: ssid.h:38
build a set of CsmaNetDevice objects
Definition: csma-helper.h:46
virtual void SetType(std::string type, std::string n0="", const AttributeValue &v0=EmptyAttributeValue(), std::string n1="", const AttributeValue &v1=EmptyAttributeValue(), std::string n2="", const AttributeValue &v2=EmptyAttributeValue(), std::string n3="", const AttributeValue &v3=EmptyAttributeValue(), std::string n4="", const AttributeValue &v4=EmptyAttributeValue(), std::string n5="", const AttributeValue &v5=EmptyAttributeValue(), std::string n6="", const AttributeValue &v6=EmptyAttributeValue(), std::string n7="", const AttributeValue &v7=EmptyAttributeValue(), std::string n8="", const AttributeValue &v8=EmptyAttributeValue(), std::string n9="", const AttributeValue &v9=EmptyAttributeValue(), std::string n10="", const AttributeValue &v10=EmptyAttributeValue())
void SetChannelAttribute(std::string name, const AttributeValue &value)
Set an attribute value to be propagated to each Channel created by the helper.
Helper class used to assign positions and mobility models to nodes.
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()
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.
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition: nstime.h:895
AttributeValue implementation for Ssid.
Definition: ssid.h:95
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.
tuple wifi
Definition: third.py:89
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
void EnablePcap(std::string prefix, Ptr< NetDevice > nd, bool promiscuous=false, bool explicitFilename=false)
Enable pcap output the indicated net device.
void SetPositionAllocator(Ptr< PositionAllocator > allocator)
Set the position allocator which will be used to allocate the initial position of every node initiali...
This class can be used to hold variables of floating point type such as 'double' or 'float'...
Definition: double.h:41
a 2d rectangle
Definition: rectangle.h:34
static uint32_t GetSize()
void SetBase(Ipv4Address network, Ipv4Mask mask, Ipv4Address base="0.0.0.1")
Set the base network number, network mask and base address.
bool verbose
tuple csma
Definition: second.py:63
Ipv4Address GetAddress(uint32_t i, uint32_t j=0) const
tuple wifiStaNodes
Definition: third.py:81