A Discrete-Event Network Simulator
API
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
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/network-module.h"
19 #include "ns3/wifi-module.h"
20 #include "ns3/mobility-module.h"
21 #include "ns3/mpi-interface.h"
22 #include "ns3/ipv4-global-routing-helper.h"
23 #include "ns3/udp-echo-helper.h"
24 #include "ns3/point-to-point-helper.h"
25 #include "ns3/csma-helper.h"
26 #include "ns3/internet-stack-helper.h"
27 #include "ns3/ipv4-address-helper.h"
28 #include "ns3/ipv4-interface-container.h"
29 
30 #ifdef NS3_MPI
31 #include <mpi.h>
32 #endif
33 
34 // Default Network Topology (same as third.cc from tutorial)
35 // Distributed simulation, split along the p2p link
36 // Number of wifi or csma nodes can be increased up to 250
37 //
38 // Wifi 10.1.3.0
39 // AP
40 // * * * *
41 // | | | | 10.1.1.0
42 // n5 n6 n7 n0 -------------- n1 n2 n3 n4
43 // point-to-point | | | |
44 // ================
45 // | LAN 10.1.2.0
46 // |
47 // Rank 0 | Rank 1
48 // -------------------------|----------------------------
49 
50 using namespace ns3;
51 
52 NS_LOG_COMPONENT_DEFINE ("ThirdExampleDistributed");
53 
54 int
55 main (int argc, char *argv[])
56 {
57 #ifdef NS3_MPI
58 
59  bool verbose = true;
60  uint32_t nCsma = 3;
61  uint32_t nWifi = 3;
62  bool nullmsg = false;
63  bool tracing = false;
64 
65  CommandLine cmd;
66  cmd.AddValue ("nCsma", "Number of \"extra\" CSMA nodes/devices", nCsma);
67  cmd.AddValue ("nWifi", "Number of wifi STA devices", nWifi);
68  cmd.AddValue ("verbose", "Tell echo applications to log if true", verbose);
69  cmd.AddValue ("nullmsg", "Enable the use of null-message synchronization", nullmsg);
70  cmd.AddValue ("tracing", "Enable pcap tracing", tracing);
71  cmd.Parse (argc,argv);
72 
73  // Check for valid number of csma or wifi nodes
74  // 250 should be enough, otherwise IP addresses
75  // soon become an issue
76  if (nWifi > 250 || nCsma > 250)
77  {
78  std::cout << "Too many wifi or csma nodes, max 200 each." << std::endl;
79  return 1;
80  }
81 
82  if (verbose)
83  {
84  LogComponentEnable ("UdpEchoClientApplication", LOG_LEVEL_INFO);
85  LogComponentEnable ("UdpEchoServerApplication", LOG_LEVEL_INFO);
86  }
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  uint32_t systemId = MpiInterface::GetSystemId ();
103  uint32_t 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 
114  NodeContainer p2pNodes;
115  Ptr<Node> p2pNode1 = CreateObject<Node> (0); // Create node with rank 0
116  Ptr<Node> p2pNode2 = CreateObject<Node> (1); // Create node with rank 1
117  p2pNodes.Add (p2pNode1);
118  p2pNodes.Add (p2pNode2);
119 
121  pointToPoint.SetDeviceAttribute ("DataRate", StringValue ("5Mbps"));
122  pointToPoint.SetChannelAttribute ("Delay", StringValue ("2ms"));
123 
124  NetDeviceContainer p2pDevices;
125  p2pDevices = pointToPoint.Install (p2pNodes);
126 
127  NodeContainer csmaNodes;
128  csmaNodes.Add (p2pNodes.Get (1));
129  csmaNodes.Create (nCsma, 1); // Create csma nodes with rank 1
130 
131  CsmaHelper csma;
132  csma.SetChannelAttribute ("DataRate", StringValue ("100Mbps"));
133  csma.SetChannelAttribute ("Delay", TimeValue (NanoSeconds (6560)));
134 
135  NetDeviceContainer csmaDevices;
136  csmaDevices = csma.Install (csmaNodes);
137 
138  NodeContainer wifiStaNodes;
139  wifiStaNodes.Create (nWifi, 0); // Create wifi nodes with rank 0
140  NodeContainer wifiApNode = p2pNodes.Get (0);
141 
144  phy.SetChannel (channel.Create ());
145 
147  wifi.SetRemoteStationManager ("ns3::AarfWifiManager");
148 
150 
151  Ssid ssid = Ssid ("ns-3-ssid");
152  mac.SetType ("ns3::StaWifiMac",
153  "Ssid", SsidValue (ssid),
154  "ActiveProbing", BooleanValue (false));
155 
156  NetDeviceContainer staDevices;
157  staDevices = wifi.Install (phy, mac, wifiStaNodes);
158 
159  mac.SetType ("ns3::ApWifiMac",
160  "Ssid", SsidValue (ssid));
161 
162  NetDeviceContainer apDevices;
163  apDevices = wifi.Install (phy, mac, wifiApNode);
164 
165  MobilityHelper mobility;
166 
167  mobility.SetPositionAllocator ("ns3::GridPositionAllocator",
168  "MinX", DoubleValue (0.0),
169  "MinY", DoubleValue (0.0),
170  "DeltaX", DoubleValue (5.0),
171  "DeltaY", DoubleValue (5.0),
172  "GridWidth", UintegerValue (10),
173  "LayoutType", StringValue ("RowFirst"));
174 
175  mobility.SetMobilityModel ("ns3::RandomWalk2dMobilityModel",
176  "Bounds", RectangleValue (Rectangle (-250, 250, -250, 250)));
177  mobility.Install (wifiStaNodes);
178 
179  mobility.SetMobilityModel ("ns3::ConstantPositionMobilityModel");
180  mobility.Install (wifiApNode);
181 
183  stack.Install (csmaNodes);
184  stack.Install (wifiApNode);
185  stack.Install (wifiStaNodes);
186 
188 
189  address.SetBase ("10.1.1.0", "255.255.255.0");
190  Ipv4InterfaceContainer p2pInterfaces;
191  p2pInterfaces = address.Assign (p2pDevices);
192 
193  address.SetBase ("10.1.2.0", "255.255.255.0");
194  Ipv4InterfaceContainer csmaInterfaces;
195  csmaInterfaces = address.Assign (csmaDevices);
196 
197  address.SetBase ("10.1.3.0", "255.255.255.0");
198  address.Assign (staDevices);
199  address.Assign (apDevices);
200 
201  // If this simulator has system id 1, then
202  // it should contain the server application,
203  // since it is on one of the csma nodes
204  if (systemId == 1)
205  {
207  ApplicationContainer serverApps = echoServer.Install (csmaNodes.Get (nCsma));
208  serverApps.Start (Seconds (1.0));
209  serverApps.Stop (Seconds (10.0));
210  }
211 
212  // If the simulator has system id 0, then
213  // it should contain the client application,
214  // since it is on one of the wifi nodes
215  if (systemId == 0)
216  {
217  UdpEchoClientHelper echoClient (csmaInterfaces.GetAddress (nCsma), 9);
218  echoClient.SetAttribute ("MaxPackets", UintegerValue (1));
219  echoClient.SetAttribute ("Interval", TimeValue (Seconds (1.)));
220  echoClient.SetAttribute ("PacketSize", UintegerValue (1024));
221 
223  echoClient.Install (wifiStaNodes.Get (nWifi - 1));
224  clientApps.Start (Seconds (2.0));
225  clientApps.Stop (Seconds (10.0));
226  }
227 
229 
230  Simulator::Stop (Seconds (10.0));
231 
232  if (tracing == true)
233  {
234  // Depending on the system Id (rank), the pcap information
235  // traced will be different. For example, the ethernet pcap
236  // will be empty for rank0, since these nodes are placed on
237  // on rank 1. All ethernet traffic will take place on rank 1.
238  // Similar differences are seen in the p2p and wirless pcaps.
239  if (systemId == 0)
240  {
241  pointToPoint.EnablePcapAll ("third-distributed-rank0");
242  phy.EnablePcap ("third-distributed-rank0", apDevices.Get (0));
243  csma.EnablePcap ("third-distributed-rank0", csmaDevices.Get (0), true);
244  }
245  else
246  {
247  pointToPoint.EnablePcapAll ("third-distributed-rank1");
248  phy.EnablePcap ("third-distributed-rank1", apDevices.Get (0));
249  csma.EnablePcap ("third-distributed-rank1", csmaDevices.Get (0), true);
250  }
251  }
252 
253  Simulator::Run ();
255  // Exit the MPI execution environment
257  return 0;
258 
259 #else
260  NS_FATAL_ERROR ("Can't use distributed simulator without MPI compiled in");
261 #endif
262 }
holds a vector of ns3::Application pointers.
tuple pointToPoint
Definition: first.py:28
void SetChannelAttribute(std::string n1, const AttributeValue &v1)
Definition: csma-helper.cc:69
Hold a bool native type.
Definition: boolean.h:38
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:73
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:18
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:42
Create an application which sends a UDP packet and waits for an echo of this packet.
static void Run(void)
Run the simulation until one of:
Definition: simulator.cc:157
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition: log.h:170
aggregate IP/TCP/UDP functionality to existing Nodes.
NetDeviceContainer Install(Ptr< Node > node) const
This method creates an ns3::CsmaChannel with the attributes configured by CsmaHelper::SetChannelAttri...
Definition: csma-helper.cc:215
#define NS_FATAL_ERROR(msg)
fatal error handling
Definition: fatal-error.h:95
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.
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:88
virtual NetDeviceContainer Install(const WifiPhyHelper &phy, const WifiMacHelper &mac, NodeContainer c) const
Definition: wifi-helper.cc:102
tuple clientApps
Definition: first.py:53
ApplicationContainer Install(Ptr< Node > node) const
Create a UdpEchoServerApplication on the specified Node.
hold objects of type ns3::Rectangle
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 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 ...
hold objects of type ns3::Time
Definition: nstime.h:1008
static void Enable(int *pargc, char ***pargv)
Sets up parallel communication interface.
Hold an unsigned integer type.
Definition: uinteger.h:46
holds a vector of ns3::NetDevice pointers
static NqosWifiMacHelper Default(void)
Create a mac helper in a default working state.
static void Bind(std::string name, const AttributeValue &value)
void Start(Time start)
Arrange for all of the Applications in this container to Start() at the Time given as a parameter...
create non QoS-enabled MAC layers for a ns3::WifiNetDevice.
Parse command-line arguments.
Definition: command-line.h:177
int main(int argc, char *argv[])
static void Destroy(void)
Every event scheduled by the Simulator::insertAtDestroy method is invoked.
Definition: simulator.cc:121
tuple echoClient
Definition: first.py:48
tuple serverApps
Definition: first.py:44
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...
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:35
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:435
static void Stop(void)
If an event invokes this method, it will be the last event scheduled by the Simulator::run method bef...
Definition: simulator.cc:165
Ptr< Node > Get(uint32_t i) const
Get the Ptr stored in this container at a given index.
hold objects of type ns3::Ssid
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.
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...
Hold a floating point type.
Definition: double.h:41
a 2d rectangle
Definition: rectangle.h:33
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.
void LogComponentEnable(char const *name, enum LogLevel level)
Enable the logging output associated with that log component.
Definition: log.cc:318
bool verbose
Ipv4Address GetAddress(uint32_t i, uint32_t j=0) const
static WifiHelper Default(void)
Definition: wifi-helper.cc:65