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 
158  Ssid ssid = Ssid ("ns-3-ssid");
159  mac.SetType ("ns3::StaWifiMac",
160  "Ssid", SsidValue (ssid),
161  "ActiveProbing", BooleanValue (false));
162 
164  staDevices = wifi.Install (phy, mac, wifiStaNodes);
165 
166  mac.SetType ("ns3::ApWifiMac",
167  "Ssid", SsidValue (ssid));
168 
170  apDevices = wifi.Install (phy, mac, wifiApNode);
171 
173 
174  mobility.SetPositionAllocator ("ns3::GridPositionAllocator",
175  "MinX", DoubleValue (0.0),
176  "MinY", DoubleValue (0.0),
177  "DeltaX", DoubleValue (5.0),
178  "DeltaY", DoubleValue (10.0),
179  "GridWidth", UintegerValue (3),
180  "LayoutType", StringValue ("RowFirst"));
181 
182  mobility.SetMobilityModel ("ns3::RandomWalk2dMobilityModel",
183  "Bounds", RectangleValue (Rectangle (-50, 50, -50, 50)));
184  mobility.Install (wifiStaNodes);
185 
186  mobility.SetMobilityModel ("ns3::ConstantPositionMobilityModel");
187  mobility.Install (wifiApNode);
188 
190  stack.Install (csmaNodes);
191  stack.Install (wifiApNode);
192  stack.Install (wifiStaNodes);
193 
195 
196  address.SetBase ("10.1.1.0", "255.255.255.0");
198  p2pInterfaces = address.Assign (p2pDevices);
199 
200  address.SetBase ("10.1.2.0", "255.255.255.0");
202  csmaInterfaces = address.Assign (csmaDevices);
203 
204  address.SetBase ("10.1.3.0", "255.255.255.0");
205  address.Assign (staDevices);
206  address.Assign (apDevices);
207 
208  // If this rank is systemCsma,
209  // it should contain the server application,
210  // since it is on one of the csma nodes
211  if (systemId == systemCsma)
212  {
214 
215  ApplicationContainer serverApps = echoServer.Install (csmaNodes.Get (nCsma));
216  serverApps.Start (Seconds (1.0));
217  serverApps.Stop (Seconds (10.0));
218  }
219 
220  // If this rank is systemWifi
221  // it should contain the client application,
222  // since it is on one of the wifi nodes
223  if (systemId == systemWifi)
224  {
225  UdpEchoClientHelper echoClient (csmaInterfaces.GetAddress (nCsma), 9);
226  echoClient.SetAttribute ("MaxPackets", UintegerValue (1));
227  echoClient.SetAttribute ("Interval", TimeValue (Seconds (1.0)));
228  echoClient.SetAttribute ("PacketSize", UintegerValue (1024));
229 
231  echoClient.Install (wifiStaNodes.Get (nWifi - 1));
232  clientApps.Start (Seconds (2.0));
233  clientApps.Stop (Seconds (10.0));
234  }
235 
237 
238  Simulator::Stop (Seconds (10.0));
239 
240  if (tracing == true)
241  {
242  // Depending on the system Id (rank), the pcap information
243  // traced will be different. For example, the ethernet pcap
244  // will be empty for rank0, since these nodes are placed on
245  // on rank 1. All ethernet traffic will take place on rank 1.
246  // Similar differences are seen in the p2p and wireless pcaps.
247  if (systemId == systemWifi)
248  {
249  pointToPoint.EnablePcapAll ("third-distributed-wifi");
250  phy.EnablePcap ("third-distributed-wifi", apDevices.Get (0));
251  csma.EnablePcap ("third-distributed-wifi", csmaDevices.Get (0), true);
252  }
253  else // systemCsma
254  {
255  pointToPoint.EnablePcapAll ("third-distributed-csma");
256  phy.EnablePcap ("third-distributed-csma", apDevices.Get (0));
257  csma.EnablePcap ("third-distributed-csma", csmaDevices.Get (0), true);
258  }
259  }
260 
261  Simulator::Run ();
263 
264 #ifdef NS3_MPI
265  // Exit the MPI execution environment
267 #endif
268 
269  return 0;
270 }
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:74
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)
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())
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:200
#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:96
tuple cmd
Definition: second.py:35
virtual NetDeviceContainer Install(const WifiPhyHelper &phy, const WifiMacHelper &mac, NodeContainer c) const
Definition: wifi-helper.cc:103
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 NqosWifiMacHelper Default(void)
Create a mac helper in a default working state.
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
create non QoS-enabled MAC layers for a ns3::WifiNetDevice.
Parse command-line arguments.
Definition: command-line.h:201
tuple p2pDevices
Definition: second.py:61
static void Destroy(void)
Execute the events scheduled with ScheduleDestroy().
Definition: simulator.cc:164
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.
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
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:491
static void Stop(void)
Tell the Simulator the calling event should be the last one executed.
Definition: simulator.cc:208
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
static WifiHelper Default(void)
Definition: wifi-helper.cc:66