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 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);
149  NodeContainer wifiApNode = p2pNodes.Get (0);
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");
203  csmaInterfaces = address.Assign (csmaDevices);
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 
216  ApplicationContainer serverApps = echoServer.Install (csmaNodes.Get (nCsma));
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  {
226  UdpEchoClientHelper echoClient (csmaInterfaces.GetAddress (nCsma), 9);
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 }
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:71
AttributeValue implementation for Boolean.
Definition: boolean.h:36
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:719
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:226
#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:217
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:213
tuple cmd
Definition: second.py:35
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:369
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:1055
Time NanoSeconds(uint64_t value)
Construct a Time in the indicated unit.
Definition: nstime.h:1017
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
virtual NetDeviceContainer Install(const WifiPhyHelper &phy, const WifiMacHelper &mac, NodeContainer::Iterator first, NodeContainer::Iterator last) const
Definition: wifi-helper.cc:748
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:190
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:35
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:498
static void Stop(void)
Tell the Simulator the calling event should be the last one executed.
Definition: simulator.cc:234
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:993
AttributeValue implementation for Ssid.
Definition: ssid.h:117
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