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 
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 #ifdef NS3_MPI
86 
87  // Distributed simulation setup; by default use granted time window algorithm.
88  if(nullmsg)
89  {
90  GlobalValue::Bind ("SimulatorImplementationType",
91  StringValue ("ns3::NullMessageSimulatorImpl"));
92  }
93  else
94  {
95  GlobalValue::Bind ("SimulatorImplementationType",
96  StringValue ("ns3::DistributedSimulatorImpl"));
97  }
98 
99  MpiInterface::Enable (&argc, &argv);
100 
101  systemId = MpiInterface::GetSystemId ();
102  systemCount = MpiInterface::GetSize ();
103 
104  // Check for valid distributed parameters.
105  // Must have 2 and only 2 Logical Processors (LPs)
106  if (systemCount != 2)
107  {
108  std::cout << "This simulation requires 2 and only 2 logical processors." << std::endl;
109  return 1;
110  }
111 
112 #endif // NS3_MPI
113 
114  // System id of Wifi side
115  uint32_t systemWifi = 0;
116 
117  // System id of CSMA side
118  uint32_t systemCsma = systemCount - 1;
119 
121  // Create each end of the P2P link on a separate system (rank)
122  Ptr<Node> p2pNode1 = CreateObject<Node> (systemWifi);
123  Ptr<Node> p2pNode2 = CreateObject<Node> (systemCsma);
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  // Create the csma nodes on one system (rank)
137  csmaNodes.Create (nCsma, systemCsma);
138 
140  csma.SetChannelAttribute ("DataRate", StringValue ("100Mbps"));
141  csma.SetChannelAttribute ("Delay", TimeValue (NanoSeconds (6560)));
142 
144  csmaDevices = csma.Install (csmaNodes);
145 
147  // Create the wifi nodes on the other system (rank)
148  wifiStaNodes.Create (nWifi, systemWifi);
150 
153  phy.SetChannel (channel.Create ());
154 
156  wifi.SetRemoteStationManager ("ns3::AarfWifiManager");
157 
159  Ssid ssid = Ssid ("ns-3-ssid");
160  mac.SetType ("ns3::StaWifiMac",
161  "Ssid", SsidValue (ssid),
162  "ActiveProbing", BooleanValue (false));
163 
165  staDevices = wifi.Install (phy, mac, wifiStaNodes);
166 
167  mac.SetType ("ns3::ApWifiMac",
168  "Ssid", SsidValue (ssid));
169 
171  apDevices = wifi.Install (phy, mac, wifiApNode);
172 
174 
175  mobility.SetPositionAllocator ("ns3::GridPositionAllocator",
176  "MinX", DoubleValue (0.0),
177  "MinY", DoubleValue (0.0),
178  "DeltaX", DoubleValue (5.0),
179  "DeltaY", DoubleValue (10.0),
180  "GridWidth", UintegerValue (3),
181  "LayoutType", StringValue ("RowFirst"));
182 
183  mobility.SetMobilityModel ("ns3::RandomWalk2dMobilityModel",
184  "Bounds", RectangleValue (Rectangle (-50, 50, -50, 50)));
185  mobility.Install (wifiStaNodes);
186 
187  mobility.SetMobilityModel ("ns3::ConstantPositionMobilityModel");
188  mobility.Install (wifiApNode);
189 
191  stack.Install (csmaNodes);
192  stack.Install (wifiApNode);
193  stack.Install (wifiStaNodes);
194 
196 
197  address.SetBase ("10.1.1.0", "255.255.255.0");
199  p2pInterfaces = address.Assign (p2pDevices);
200 
201  address.SetBase ("10.1.2.0", "255.255.255.0");
204 
205  address.SetBase ("10.1.3.0", "255.255.255.0");
206  address.Assign (staDevices);
207  address.Assign (apDevices);
208 
209  // If this rank is systemCsma,
210  // it should contain the server application,
211  // since it is on one of the csma nodes
212  if (systemId == systemCsma)
213  {
215 
217  serverApps.Start (Seconds (1.0));
218  serverApps.Stop (Seconds (10.0));
219  }
220 
221  // If this rank is systemWifi
222  // it should contain the client application,
223  // since it is on one of the wifi nodes
224  if (systemId == systemWifi)
225  {
227  echoClient.SetAttribute ("MaxPackets", UintegerValue (1));
228  echoClient.SetAttribute ("Interval", TimeValue (Seconds (1.0)));
229  echoClient.SetAttribute ("PacketSize", UintegerValue (1024));
230 
232  echoClient.Install (wifiStaNodes.Get (nWifi - 1));
233  clientApps.Start (Seconds (2.0));
234  clientApps.Stop (Seconds (10.0));
235  }
236 
238 
239  Simulator::Stop (Seconds (10.0));
240 
241  if (tracing == true)
242  {
243  // Depending on the system Id (rank), the pcap information
244  // traced will be different. For example, the ethernet pcap
245  // will be empty for rank0, since these nodes are placed on
246  // on rank 1. All ethernet traffic will take place on rank 1.
247  // Similar differences are seen in the p2p and wireless pcaps.
248  if (systemId == systemCsma)
249  {
250  pointToPoint.EnablePcapAll ("third-distributed-csma");
251  phy.EnablePcap ("third-distributed-csma", apDevices.Get (0));
252  csma.EnablePcap ("third-distributed-csma", csmaDevices.Get (0), true);
253  }
254  else // systemWifi
255  {
256  pointToPoint.EnablePcapAll ("third-distributed-wifi");
257  phy.EnablePcap ("third-distributed-wifi", apDevices.Get (0));
258  csma.EnablePcap ("third-distributed-wifi", csmaDevices.Get (0), true);
259  }
260  }
261 
262  Simulator::Run ();
264 
265 #ifdef NS3_MPI
266  // Exit the MPI execution environment
268 #endif
269 
270  return 0;
271 }
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:45
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:170
echoServer
Definition: first.py:43
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition: log.h:204
aggregate IP/TCP/UDP functionality to existing Nodes.
staDevices
Definition: third.py:96
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:299
stack
Definition: first.py:34
channel
Definition: third.py:85
mobility
Definition: third.py:101
phy
Definition: third.py:86
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:369
AttributeValue implementation for Time.
Definition: nstime.h:1124
Time NanoSeconds(uint64_t value)
Construct a Time in the indicated unit.
Definition: nstime.h:1086
static void Enable(int *pargc, char ***pargv)
Sets up parallel communication interface.
echoClient
Definition: first.py:49
Hold an unsigned integer type.
Definition: uinteger.h:44
ssid
Definition: third.py:93
pointToPoint
Definition: first.py:28
LOG_INFO and above.
Definition: log.h:106
holds a vector of ns3::NetDevice pointers
mac
Definition: third.py:92
wifiApNode
Definition: third.py:83
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:213
static void Destroy(void)
Execute the events scheduled with ScheduleDestroy().
Definition: simulator.cc:134
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:37
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:89
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:178
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition: nstime.h:1062
AttributeValue implementation for Ssid.
Definition: ssid.h:110
apDevices
Definition: third.py:99
clientApps
Definition: first.py:54
p2pNodes
Definition: second.py:50
A helper class to make life easier while doing simple IPv4 address assignment in scripts.
wifiStaNodes
Definition: third.py:81
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()
csmaDevices
Definition: second.py:67
bool verbose