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/mobility-module.h"
22 #include "ns3/csma-module.h"
23 #include "ns3/internet-module.h"
24 #include "ns3/mpi-module.h"
25 #include "ns3/yans-wifi-helper.h"
26 #include "ns3/ssid.h"
27 
28 // Default Network Topology
29 //
30 // (same as third.cc from tutorial)
31 // Distributed simulation, split across the p2p link
32 // |
33 // Rank 0 | Rank 1
34 // -------------------------|----------------------------
35 // Wifi 10.1.3.0
36 // AP
37 // * * * *
38 // | | | | 10.1.1.0
39 // n5 n6 n7 n0 -------------- n1 n2 n3 n4
40 // point-to-point | | | |
41 // ================
42 // LAN 10.1.2.0
43 
44 using namespace ns3;
45 
46 NS_LOG_COMPONENT_DEFINE ("ThirdExampleDistributed");
47 
48 int
49 main (int argc, char *argv[])
50 {
51  bool verbose = true;
52  uint32_t nCsma = 3;
53  uint32_t nWifi = 3;
54  bool tracing = false;
55  bool nullmsg = false;
56 
57  CommandLine cmd (__FILE__);
58  cmd.AddValue ("nCsma", "Number of \"extra\" CSMA nodes/devices", nCsma);
59  cmd.AddValue ("nWifi", "Number of wifi STA devices", nWifi);
60  cmd.AddValue ("verbose", "Tell echo applications to log if true", verbose);
61  cmd.AddValue ("tracing", "Enable pcap tracing", tracing);
62  cmd.AddValue ("nullmsg", "Enable the use of null-message synchronization", nullmsg);
63 
64  cmd.Parse (argc,argv);
65 
66  // The underlying restriction of 18 is due to the grid position
67  // allocator's configuration; the grid layout will exceed the
68  // bounding box if more than 18 nodes are provided.
69  if (nWifi > 18)
70  {
71  std::cout << "nWifi should be 18 or less; otherwise grid layout exceeds the bounding box" << std::endl;
72  return 1;
73  }
74 
75  if (verbose)
76  {
77  LogComponentEnable ("UdpEchoClientApplication", LOG_LEVEL_INFO);
78  LogComponentEnable ("UdpEchoServerApplication", LOG_LEVEL_INFO);
79  }
80 
81  // Sequential fallback values
82  uint32_t systemId = 0;
83  uint32_t systemCount = 1;
84 
85  // Distributed simulation setup; by default use granted time window algorithm.
86  if(nullmsg)
87  {
88  GlobalValue::Bind ("SimulatorImplementationType",
89  StringValue ("ns3::NullMessageSimulatorImpl"));
90  }
91  else
92  {
93  GlobalValue::Bind ("SimulatorImplementationType",
94  StringValue ("ns3::DistributedSimulatorImpl"));
95  }
96 
97  MpiInterface::Enable (&argc, &argv);
98 
99  systemId = MpiInterface::GetSystemId ();
100  systemCount = MpiInterface::GetSize ();
101 
102  // Check for valid distributed parameters.
103  // Must have 2 and only 2 Logical Processors (LPs)
104  if (systemCount != 2)
105  {
106  std::cout << "This simulation requires 2 and only 2 logical processors." << std::endl;
107  return 1;
108  }
109 
110  // System id of Wifi side
111  uint32_t systemWifi = 0;
112 
113  // System id of CSMA side
114  uint32_t systemCsma = systemCount - 1;
115 
117  // Create each end of the P2P link on a separate system (rank)
118  Ptr<Node> p2pNode1 = CreateObject<Node> (systemWifi);
119  Ptr<Node> p2pNode2 = CreateObject<Node> (systemCsma);
120  p2pNodes.Add (p2pNode1);
121  p2pNodes.Add (p2pNode2);
122 
124  pointToPoint.SetDeviceAttribute ("DataRate", StringValue ("5Mbps"));
125  pointToPoint.SetChannelAttribute ("Delay", StringValue ("2ms"));
126 
128  p2pDevices = pointToPoint.Install (p2pNodes);
129 
131  csmaNodes.Add (p2pNodes.Get (1));
132  // Create the csma nodes on one system (rank)
133  csmaNodes.Create (nCsma, systemCsma);
134 
136  csma.SetChannelAttribute ("DataRate", StringValue ("100Mbps"));
137  csma.SetChannelAttribute ("Delay", TimeValue (NanoSeconds (6560)));
138 
140  csmaDevices = csma.Install (csmaNodes);
141 
143  // Create the wifi nodes on the other system (rank)
144  wifiStaNodes.Create (nWifi, systemWifi);
146 
149  phy.SetChannel (channel.Create ());
150 
152  wifi.SetRemoteStationManager ("ns3::AarfWifiManager");
153 
155  Ssid ssid = Ssid ("ns-3-ssid");
156  mac.SetType ("ns3::StaWifiMac",
157  "Ssid", SsidValue (ssid),
158  "ActiveProbing", BooleanValue (false));
159 
161  staDevices = wifi.Install (phy, mac, wifiStaNodes);
162 
163  mac.SetType ("ns3::ApWifiMac",
164  "Ssid", SsidValue (ssid));
165 
167  apDevices = wifi.Install (phy, mac, wifiApNode);
168 
170 
171  mobility.SetPositionAllocator ("ns3::GridPositionAllocator",
172  "MinX", DoubleValue (0.0),
173  "MinY", DoubleValue (0.0),
174  "DeltaX", DoubleValue (5.0),
175  "DeltaY", DoubleValue (10.0),
176  "GridWidth", UintegerValue (3),
177  "LayoutType", StringValue ("RowFirst"));
178 
179  mobility.SetMobilityModel ("ns3::RandomWalk2dMobilityModel",
180  "Bounds", RectangleValue (Rectangle (-50, 50, -50, 50)));
181  mobility.Install (wifiStaNodes);
182 
183  mobility.SetMobilityModel ("ns3::ConstantPositionMobilityModel");
184  mobility.Install (wifiApNode);
185 
187  stack.Install (csmaNodes);
188  stack.Install (wifiApNode);
189  stack.Install (wifiStaNodes);
190 
192 
193  address.SetBase ("10.1.1.0", "255.255.255.0");
195  p2pInterfaces = address.Assign (p2pDevices);
196 
197  address.SetBase ("10.1.2.0", "255.255.255.0");
200 
201  address.SetBase ("10.1.3.0", "255.255.255.0");
202  address.Assign (staDevices);
203  address.Assign (apDevices);
204 
205  // If this rank is systemCsma,
206  // it should contain the server application,
207  // since it is on one of the csma nodes
208  if (systemId == systemCsma)
209  {
211 
213  serverApps.Start (Seconds (1.0));
214  serverApps.Stop (Seconds (10.0));
215  }
216 
217  // If this rank is systemWifi
218  // it should contain the client application,
219  // since it is on one of the wifi nodes
220  if (systemId == systemWifi)
221  {
223  echoClient.SetAttribute ("MaxPackets", UintegerValue (1));
224  echoClient.SetAttribute ("Interval", TimeValue (Seconds (1.0)));
225  echoClient.SetAttribute ("PacketSize", UintegerValue (1024));
226 
228  echoClient.Install (wifiStaNodes.Get (nWifi - 1));
229  clientApps.Start (Seconds (2.0));
230  clientApps.Stop (Seconds (10.0));
231  }
232 
234 
235  Simulator::Stop (Seconds (10.0));
236 
237  if (tracing == true)
238  {
239  // Depending on the system Id (rank), the pcap information
240  // traced will be different. For example, the ethernet pcap
241  // will be empty for rank0, since these nodes are placed on
242  // on rank 1. All ethernet traffic will take place on rank 1.
243  // Similar differences are seen in the p2p and wireless pcaps.
244  if (systemId == systemCsma)
245  {
246  pointToPoint.EnablePcapAll ("third-distributed-csma");
247  phy.EnablePcap ("third-distributed-csma", apDevices.Get (0));
248  csma.EnablePcap ("third-distributed-csma", csmaDevices.Get (0), true);
249  }
250  else // systemWifi
251  {
252  pointToPoint.EnablePcapAll ("third-distributed-wifi");
253  phy.EnablePcap ("third-distributed-wifi", apDevices.Get (0));
254  csma.EnablePcap ("third-distributed-wifi", csmaDevices.Get (0), true);
255  }
256  }
257 
258  Simulator::Run ();
260 
261  // Exit the MPI execution environment
263 
264  return 0;
265 }
holds a vector of ns3::Application pointers.
nCsma
Definition: second.py:36
csmaInterfaces
Definition: second.py:78
AttributeValue implementation for Boolean.
Definition: boolean.h:36
holds a vector of std::pair of Ptr<Ipv4> 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.
Definition: string.h:41
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.
serverApps
Definition: first.py:52
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:172
echoServer
Definition: first.py:50
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition: log.h:205
aggregate IP/TCP/UDP functionality to existing Nodes.
staDevices
Definition: third.py:103
cmd
Definition: second.py:35
static void Disable()
Terminates the parallel environment.
Build a set of PointToPointNetDevice objects.
static YansWifiPhyHelper Default(void)
Create a PHY helper in a default working state.
helps to create WifiNetDevice objects
Definition: wifi-helper.h:318
stack
Definition: first.py:41
channel
Definition: third.py:92
mobility
Definition: third.py:108
phy
Definition: third.py:93
AttributeValue implementation for Rectangle.
Definition: rectangle.h:97
p2pDevices
Definition: second.py:61
Create a server application which waits for input UDP packets and sends them back to the original sen...
void LogComponentEnable(char const *name, enum LogLevel level)
Enable the logging output associated with that log component.
Definition: log.cc:361
AttributeValue implementation for Time.
Definition: nstime.h:1342
Time NanoSeconds(uint64_t value)
Construct a Time in the indicated unit.
Definition: nstime.h:1302
static void Enable(int *pargc, char ***pargv)
Sets up parallel communication interface.
echoClient
Definition: first.py:56
Hold an unsigned integer type.
Definition: uinteger.h:44
ssid
Definition: third.py:100
pointToPoint
Definition: first.py:35
LOG_INFO and above.
Definition: log.h:107
holds a vector of ns3::NetDevice pointers
mac
Definition: third.py:99
wifiApNode
Definition: third.py:90
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...
csma
Definition: second.py:63
Parse command-line arguments.
Definition: command-line.h:226
static void Destroy(void)
Execute the events scheduled with ScheduleDestroy().
Definition: simulator.cc:136
Every class exported by the ns3 library is enclosed in the ns3 namespace.
keep track of a set of node pointers.
address
Definition: first.py:44
manage and create wifi channel objects for the YANS model.
p2pInterfaces
Definition: second.py:75
create MAC layers for a ns3::WifiNetDevice.
The IEEE 802.11 SSID Information Element.
Definition: ssid.h:35
csmaNodes
Definition: second.py:53
build a set of CsmaNetDevice objects
Definition: csma-helper.h:46
wifi
Definition: third.py:96
Helper class used to assign positions and mobility models to nodes.
static uint32_t GetSystemId()
static void Stop(void)
Tell the Simulator the calling event should be the last one executed.
Definition: simulator.cc:180
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition: nstime.h:1278
AttributeValue implementation for Ssid.
Definition: ssid.h:105
apDevices
Definition: third.py:106
clientApps
Definition: first.py:61
p2pNodes
Definition: second.py:50
A helper class to make life easier while doing simple IPv4 address assignment in scripts.
wifiStaNodes
Definition: third.py:88
nWifi
Definition: third.py:43
This class can be used to hold variables of floating point type such as &#39;double&#39; or &#39;float&#39;...
Definition: double.h:41
a 2d rectangle
Definition: rectangle.h:34
static uint32_t GetSize()
bool tracing
Flag to enable/disable generation of tracing files.
Definition: wifi-bianchi.cc:82
csmaDevices
Definition: second.py:67
bool verbose