A Discrete-Event Network Simulator
API
wifi-ap.cc
Go to the documentation of this file.
1 /* -*- Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2005,2006,2007 INRIA
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License version 2 as
7  * published by the Free Software Foundation;
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17  *
18  * Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
19  */
20 
21 
22 #include "ns3/core-module.h"
23 #include "ns3/network-module.h"
24 #include "ns3/applications-module.h"
25 #include "ns3/mobility-module.h"
26 #include "ns3/config-store-module.h"
27 #include "ns3/wifi-module.h"
28 #include "ns3/athstats-helper.h"
29 
30 #include <iostream>
31 
32 using namespace ns3;
33 
34 static bool g_verbose = true;
35 
36 void
37 DevTxTrace (std::string context, Ptr<const Packet> p)
38 {
39  if (g_verbose)
40  {
41  std::cout << " TX p: " << *p << std::endl;
42  }
43 }
44 void
45 DevRxTrace (std::string context, Ptr<const Packet> p)
46 {
47  if (g_verbose)
48  {
49  std::cout << " RX p: " << *p << std::endl;
50  }
51 }
52 void
53 PhyRxOkTrace (std::string context, Ptr<const Packet> packet, double snr, WifiMode mode, enum WifiPreamble preamble)
54 {
55  if (g_verbose)
56  {
57  std::cout << "PHYRXOK mode=" << mode << " snr=" << snr << " " << *packet << std::endl;
58  }
59 }
60 void
61 PhyRxErrorTrace (std::string context, Ptr<const Packet> packet, double snr)
62 {
63  if (g_verbose)
64  {
65  std::cout << "PHYRXERROR snr=" << snr << " " << *packet << std::endl;
66  }
67 }
68 void
69 PhyTxTrace (std::string context, Ptr<const Packet> packet, WifiMode mode, WifiPreamble preamble, uint8_t txPower)
70 {
71  if (g_verbose)
72  {
73  std::cout << "PHYTX mode=" << mode << " " << *packet << std::endl;
74  }
75 }
76 void
77 PhyStateTrace (std::string context, Time start, Time duration, enum WifiPhy::State state)
78 {
79  if (g_verbose)
80  {
81  std::cout << " state=" << state << " start=" << start << " duration=" << duration << std::endl;
82  }
83 }
84 
85 static void
86 SetPosition (Ptr<Node> node, Vector position)
87 {
89  mobility->SetPosition (position);
90 }
91 
92 static Vector
94 {
96  return mobility->GetPosition ();
97 }
98 
99 static void
101 {
102  Vector pos = GetPosition (node);
103  pos.x += 5.0;
104  if (pos.x >= 210.0)
105  {
106  return;
107  }
108  SetPosition (node, pos);
109 
110  if (g_verbose)
111  {
112  //std::cout << "x="<<pos.x << std::endl;
113  }
115 }
116 
117 int main (int argc, char *argv[])
118 {
120  cmd.AddValue ("verbose", "Print trace information if true", g_verbose);
121 
122  cmd.Parse (argc, argv);
123 
125 
126  // enable rts cts all the time.
127  Config::SetDefault ("ns3::WifiRemoteStationManager::RtsCtsThreshold", StringValue ("0"));
128  // disable fragmentation
129  Config::SetDefault ("ns3::WifiRemoteStationManager::FragmentationThreshold", StringValue ("2200"));
130 
133  NodeContainer stas;
134  NodeContainer ap;
135  NetDeviceContainer staDevs;
136  PacketSocketHelper packetSocket;
137 
138  stas.Create (2);
139  ap.Create (1);
140 
141  // give packet socket powers to nodes.
142  packetSocket.Install (stas);
143  packetSocket.Install (ap);
144 
145  WifiMacHelper wifiMac;
148  wifiPhy.SetChannel (wifiChannel.Create ());
149  Ssid ssid = Ssid ("wifi-default");
150  wifi.SetRemoteStationManager ("ns3::ArfWifiManager");
151  // setup stas.
152  wifiMac.SetType ("ns3::StaWifiMac",
153  "Ssid", SsidValue (ssid));
154  staDevs = wifi.Install (wifiPhy, wifiMac, stas);
155  // setup ap.
156  wifiMac.SetType ("ns3::ApWifiMac",
157  "Ssid", SsidValue (ssid));
158  wifi.Install (wifiPhy, wifiMac, ap);
159 
160  // mobility.
161  mobility.Install (stas);
162  mobility.Install (ap);
163 
165 
166  PacketSocketAddress socket;
167  socket.SetSingleDevice (staDevs.Get (0)->GetIfIndex ());
168  socket.SetPhysicalAddress (staDevs.Get (1)->GetAddress ());
169  socket.SetProtocol (1);
170 
171  OnOffHelper onoff ("ns3::PacketSocketFactory", Address (socket));
172  onoff.SetConstantRate (DataRate ("500kb/s"));
173 
174  ApplicationContainer apps = onoff.Install (stas.Get (0));
175  apps.Start (Seconds (0.5));
176  apps.Stop (Seconds (43.0));
177 
178  Simulator::Stop (Seconds (44.0));
179 
180  Config::Connect ("/NodeList/*/DeviceList/*/Mac/MacTx", MakeCallback (&DevTxTrace));
181  Config::Connect ("/NodeList/*/DeviceList/*/Mac/MacRx", MakeCallback (&DevRxTrace));
182  Config::Connect ("/NodeList/*/DeviceList/*/Phy/State/RxOk", MakeCallback (&PhyRxOkTrace));
183  Config::Connect ("/NodeList/*/DeviceList/*/Phy/State/RxError", MakeCallback (&PhyRxErrorTrace));
184  Config::Connect ("/NodeList/*/DeviceList/*/Phy/State/Tx", MakeCallback (&PhyTxTrace));
185  Config::Connect ("/NodeList/*/DeviceList/*/Phy/State/State", MakeCallback (&PhyStateTrace));
186 
187  AthstatsHelper athstats;
188  athstats.EnableAthstats ("athstats-sta", stas);
189  athstats.EnableAthstats ("athstats-ap", ap);
190 
191  Simulator::Run ();
192 
194 
195  return 0;
196 }
holds a vector of ns3::Application pointers.
Simulation virtual time values and global simulation resolution.
Definition: nstime.h:102
static void AdvancePosition(Ptr< Node > node)
Definition: wifi-ap.cc:100
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:683
Ptr< T > GetObject(void) const
Get a pointer to the requested aggregated Object.
Definition: object.h:462
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.
def start()
Definition: core.py:1482
void DevTxTrace(std::string context, Ptr< const Packet > p)
Definition: wifi-ap.cc:37
an address for a packet socket
static void Run(void)
Run the simulation.
Definition: simulator.cc:201
Vector GetPosition(void) const
void PhyStateTrace(std::string context, Time start, Time duration, enum WifiPhy::State state)
Definition: wifi-ap.cc:77
void PhyRxErrorTrace(std::string context, Ptr< const Packet > packet, double snr)
Definition: wifi-ap.cc:61
static YansWifiPhyHelper Default(void)
Create a phy helper in a default working state.
helps to create WifiNetDevice objects
Definition: wifi-helper.h:231
represent a single transmission modeA WifiMode is implemented by a single integer which is used to lo...
Definition: wifi-mode.h:99
static Vector GetPosition(Ptr< Node > node)
Definition: wifi-ap.cc:93
A helper to make it easier to instantiate an ns3::OnOffApplication on a set of nodes.
Definition: on-off-helper.h:42
Give ns3::PacketSocket powers to ns3::Node.
tuple cmd
Definition: second.py:35
void SetSingleDevice(uint32_t device)
Set the address to match only a specified NetDevice.
static void SetPosition(Ptr< Node > node, Vector position)
Definition: wifi-ap.cc:86
virtual NetDeviceContainer Install(const WifiPhyHelper &phy, const WifiMacHelper &mac, NodeContainer c) const
Definition: wifi-helper.cc:712
a polymophic address class
Definition: address.h:90
Class for representing data rates.
Definition: data-rate.h:88
WifiPreamble
The type of preamble to be used by an IEEE 802.11 transmission.
Definition: wifi-preamble.h:30
Keep track of the current position and velocity of an object.
void SetChannel(Ptr< YansWifiChannel > channel)
void Install(Ptr< Node > node) const
"Layout" a single node according to the current position allocator type.
tuple mobility
Definition: third.py:101
static EventId Schedule(Time const &delay, MEM mem_ptr, OBJ obj)
Schedule an event to expire after delay.
Definition: simulator.h:1238
static void EnablePrinting(void)
Enable printing packets metadata.
Definition: packet.cc:535
holds a vector of ns3::NetDevice pointers
Callback< R > MakeCallback(R(T::*memPtr)(void), OBJ objPtr)
Definition: callback.h:1489
void PhyRxOkTrace(std::string context, Ptr< const Packet > packet, double snr, WifiMode mode, enum WifiPreamble preamble)
Definition: wifi-ap.cc:53
void Start(Time start)
Arrange for all of the Applications in this container to Start() at the Time given as a parameter...
Parse command-line arguments.
Definition: command-line.h:205
void Connect(std::string path, const CallbackBase &cb)
Definition: config.cc:835
static void Destroy(void)
Execute the events scheduled with ScheduleDestroy().
Definition: simulator.cc:165
void DevRxTrace(std::string context, Ptr< const Packet > p)
Definition: wifi-ap.cc:45
Every class exported by the ns3 library is enclosed in the ns3 namespace.
keep track of a set of node pointers.
void PhyTxTrace(std::string context, Ptr< const Packet > packet, WifiMode mode, WifiPreamble preamble, uint8_t txPower)
Definition: wifi-ap.cc:69
create AthstatsWifiTraceSink instances and connect them to wifi devices
tuple ssid
Definition: third.py:93
manage and create wifi channel objects for the yans model.
void Install(Ptr< Node > node) const
Aggregate an instance of a ns3::PacketSocketFactory onto the provided node.
create MAC layers for a ns3::WifiNetDevice.
void SetPosition(const Vector &position)
void EnableAthstats(std::string filename, uint32_t nodeid, uint32_t deviceid)
The IEEE 802.11 SSID Information Element.
Definition: ssid.h:38
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())
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...
void AddValue(const std::string &name, const std::string &help, T &value)
Add a program argument, assigning to POD.
Definition: command-line.h:495
static void Stop(void)
Tell the Simulator the calling event should be the last one executed.
Definition: simulator.cc:209
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 SetDefault(std::string name, const AttributeValue &value)
Definition: config.cc:774
static bool g_verbose
Definition: wifi-ap.cc:34
void Parse(int argc, char *argv[])
Parse the program arguments.
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.
State
The state of the PHY layer.
Definition: wifi-phy.h:168