A Discrete-Event Network Simulator
API
nsclick-udp-client-server-wifi.cc
Go to the documentation of this file.
1/*
2 * This program is free software; you can redistribute it and/or modify
3 * it under the terms of the GNU General Public License version 2 as
4 * published by the Free Software Foundation;
5 *
6 * This program is distributed in the hope that it will be useful,
7 * but WITHOUT ANY WARRANTY; without even the implied warranty of
8 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
9 * GNU General Public License for more details.
10 *
11 * You should have received a copy of the GNU General Public License
12 * along with this program; if not, write to the Free Software
13 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
14 */
15
16// Adaptation of examples/udp/udp-client-server.cc for
17// Click based nodes running wifi.
18//
19// Network topology:
20//
21// (1.4)
22// (( n4 ))
23//
24// 172.16.1.0/24
25//
26// (1.1) (1.2) (1.3)
27// n0 )) (( n1 )) (( n2
28// WLAN
29//
30// - UDP flows from n0 to n1 and n2 to n1.
31// - All nodes are Click based.
32// - The single ethernet interface that each node
33// uses is named 'eth0' in the Click file.
34// - Node 4 is running in promiscuous mode and can listen in on
35// the packets being exchanged between n0-n1 and n2-n1.
36//
37
38#include "ns3/applications-module.h"
39#include "ns3/click-internet-stack-helper.h"
40#include "ns3/core-module.h"
41#include "ns3/internet-module.h"
42#include "ns3/ipv4-click-routing.h"
43#include "ns3/mobility-module.h"
44#include "ns3/network-module.h"
45#include "ns3/wifi-module.h"
46
47#include <fstream>
48
49using namespace ns3;
50
51NS_LOG_COMPONENT_DEFINE("NsclickUdpClientServerWifi");
52
53#ifdef NS3_CLICK
54void
55ReadArp(Ptr<Ipv4ClickRouting> clickRouter)
56{
57 // Access the handlers
58 NS_LOG_INFO(clickRouter->ReadHandler("wifi/arpquerier", "table"));
59 NS_LOG_INFO(clickRouter->ReadHandler("wifi/arpquerier", "stats"));
60}
61
62void
63WriteArp(Ptr<Ipv4ClickRouting> clickRouter)
64{
65 // Access the handler
67 clickRouter->WriteHandler("wifi/arpquerier", "insert", "172.16.1.2 00:00:00:00:00:02"));
68}
69#endif
70
71int
72main(int argc, char* argv[])
73{
74#ifdef NS3_CLICK
75 std::string clickConfigFolder = "src/click/examples";
76
77 CommandLine cmd(__FILE__);
78 cmd.AddValue("clickConfigFolder",
79 "Base folder for click configuration files",
80 clickConfigFolder);
81 cmd.Parse(argc, argv);
82
83 //
84 // Enable logging
85 //
86 LogComponentEnable("NsclickUdpClientServerWifi", LOG_LEVEL_INFO);
87
88 //
89 // Explicitly create the nodes required by the topology (shown above).
90 //
91 NS_LOG_INFO("Create nodes.");
93 n.Create(4);
94
95 NS_LOG_INFO("Create channels.");
96 //
97 // Explicitly create the channels required by the topology (shown above).
98 //
99 std::string phyMode("DsssRate1Mbps");
100
101 // disable fragmentation for frames below 2200 bytes
102 Config::SetDefault("ns3::WifiRemoteStationManager::FragmentationThreshold",
103 StringValue("2200"));
104 // turn off RTS/CTS for frames below 2200 bytes
105 Config::SetDefault("ns3::WifiRemoteStationManager::RtsCtsThreshold", StringValue("2200"));
106 // Fix non-unicast data rate to be the same as that of unicast
107 Config::SetDefault("ns3::WifiRemoteStationManager::NonUnicastMode", StringValue(phyMode));
108
110 wifi.SetStandard(WIFI_STANDARD_80211b);
111
112 YansWifiPhyHelper wifiPhy;
113 // This is one parameter that matters when using FixedRssLossModel
114 // set it to zero; otherwise, gain will be added
115 wifiPhy.Set("RxGain", DoubleValue(0));
116 // ns-3 supports RadioTap and Prism tracing extensions for 802.11b
117 wifiPhy.SetPcapDataLinkType(WifiPhyHelper::DLT_IEEE802_11_RADIO);
118
119 YansWifiChannelHelper wifiChannel;
120 wifiChannel.SetPropagationDelay("ns3::ConstantSpeedPropagationDelayModel");
121 // The below FixedRssLossModel will cause the rss to be fixed regardless
122 // of the distance between the two stations, and the transmit power
123 wifiChannel.AddPropagationLoss("ns3::FixedRssLossModel", "Rss", DoubleValue(-80));
124 wifiPhy.SetChannel(wifiChannel.Create());
125
126 // Add an upper mac and disable rate control
127 WifiMacHelper wifiMac;
128 wifi.SetRemoteStationManager("ns3::ConstantRateWifiManager",
129 "DataMode",
130 StringValue(phyMode),
131 "ControlMode",
132 StringValue(phyMode));
133 // Set it to adhoc mode
134 wifiMac.SetType("ns3::AdhocWifiMac");
135 NetDeviceContainer d = wifi.Install(wifiPhy, wifiMac, n);
136
138 Ptr<ListPositionAllocator> positionAlloc = CreateObject<ListPositionAllocator>();
139 positionAlloc->Add(Vector(0.0, 0.0, 0.0));
140 positionAlloc->Add(Vector(10.0, 0.0, 0.0));
141 positionAlloc->Add(Vector(20.0, 0.0, 0.0));
142 positionAlloc->Add(Vector(0.0, 10.0, 0.0));
143 mobility.SetPositionAllocator(positionAlloc);
144 mobility.SetMobilityModel("ns3::ConstantPositionMobilityModel");
145 mobility.Install(n);
146
147 //
148 // Install Click on the nodes
149 //
150 ClickInternetStackHelper clickinternet;
151 clickinternet.SetClickFile(n.Get(0),
152 clickConfigFolder + "/nsclick-wifi-single-interface.click");
153 clickinternet.SetClickFile(n.Get(1),
154 clickConfigFolder + "/nsclick-wifi-single-interface.click");
155 clickinternet.SetClickFile(n.Get(2),
156 clickConfigFolder + "/nsclick-wifi-single-interface.click");
157
158 // Node 4 is to run in promiscuous mode. This can be verified
159 // from the pcap trace Node4_in_eth0.pcap generated after running
160 // this script.
161 clickinternet.SetClickFile(n.Get(3),
162 clickConfigFolder + "/nsclick-wifi-single-interface-promisc.click");
163 clickinternet.SetRoutingTableElement(n, "rt");
164 clickinternet.Install(n);
166 //
167 // We've got the "hardware" in place. Now we need to add IP addresses.
168 //
169 NS_LOG_INFO("Assign IP Addresses.");
170 ipv4.SetBase("172.16.1.0", "255.255.255.0");
171 Ipv4InterfaceContainer i = ipv4.Assign(d);
172
173 NS_LOG_INFO("Create Applications.");
174 //
175 // Create one udpServer applications on node one.
176 //
177 uint16_t port = 4000;
178 UdpServerHelper server(port);
179 ApplicationContainer apps = server.Install(n.Get(1));
180 apps.Start(Seconds(1.0));
181 apps.Stop(Seconds(10.0));
182
183 //
184 // Create one UdpClient application to send UDP datagrams from node zero to
185 // node one.
186 //
187 uint32_t MaxPacketSize = 1024;
188 Time interPacketInterval = Seconds(0.5);
189 uint32_t maxPacketCount = 320;
190 UdpClientHelper client(i.GetAddress(1), port);
191 client.SetAttribute("MaxPackets", UintegerValue(maxPacketCount));
192 client.SetAttribute("Interval", TimeValue(interPacketInterval));
193 client.SetAttribute("PacketSize", UintegerValue(MaxPacketSize));
194 apps = client.Install(NodeContainer(n.Get(0), n.Get(2)));
195 apps.Start(Seconds(2.0));
196 apps.Stop(Seconds(10.0));
197
198 wifiPhy.EnablePcap("nsclick-udp-client-server-wifi", d);
199
200 // Force the MAC address of the second node: The current ARP
201 // implementation of Click sends only one ARP request per incoming
202 // packet for an unknown destination and does not retransmit if no
203 // response is received. With the scenario of this example, all ARP
204 // requests of node 3 are lost due to interference from node
205 // 1. Hence, we fill in the ARP table of node 2 before at the
206 // beginning of the simulation
207 Simulator::Schedule(Seconds(0.5), &ReadArp, n.Get(2)->GetObject<Ipv4ClickRouting>());
208 Simulator::Schedule(Seconds(0.6), &WriteArp, n.Get(2)->GetObject<Ipv4ClickRouting>());
209 Simulator::Schedule(Seconds(0.7), &ReadArp, n.Get(2)->GetObject<Ipv4ClickRouting>());
210
211 //
212 // Now, do the actual simulation.
213 //
214 NS_LOG_INFO("Run Simulation.");
215 Simulator::Stop(Seconds(20.0));
216 Simulator::Run();
217 Simulator::Destroy();
218 NS_LOG_INFO("Done.");
219#else
220 NS_FATAL_ERROR("Can't use ns-3-click without NSCLICK compiled in");
221#endif
222
223 return 0;
224}
holds a vector of ns3::Application pointers.
void Start(Time start)
Arrange for all of the Applications in this container to Start() at the Time given as a parameter.
void Stop(Time stop)
Arrange for all of the Applications in this container to Stop() at the Time given as a parameter.
Parse command-line arguments.
Definition: command-line.h:232
This class can be used to hold variables of floating point type such as 'double' or 'float'.
Definition: double.h:42
A helper class to make life easier while doing simple IPv4 address assignment in scripts.
void SetBase(Ipv4Address network, Ipv4Mask mask, Ipv4Address base="0.0.0.1")
Set the base network number, network mask and base address.
Ipv4InterfaceContainer Assign(const NetDeviceContainer &c)
Assign IP addresses to the net devices specified in the container based on the current network prefix...
Class to allow a node to use Click for external routing.
holds a vector of std::pair of Ptr<Ipv4> and interface index.
Ipv4Address GetAddress(uint32_t i, uint32_t j=0) const
Helper class used to assign positions and mobility models to nodes.
holds a vector of ns3::NetDevice pointers
keep track of a set of node pointers.
void Create(uint32_t n)
Create n nodes and append pointers to them to the end of this NodeContainer.
Ptr< Node > Get(uint32_t i) const
Get the Ptr<Node> stored in this container at a given index.
Ptr< T > GetObject() const
Get a pointer to the requested aggregated Object.
Definition: object.h:471
void EnablePcap(std::string prefix, Ptr< NetDevice > nd, bool promiscuous=false, bool explicitFilename=false)
Enable pcap output the indicated net device.
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:78
Hold variables of type string.
Definition: string.h:42
Simulation virtual time values and global simulation resolution.
Definition: nstime.h:105
AttributeValue implementation for Time.
Definition: nstime.h:1425
Create a client application which sends UDP packets carrying a 32bit sequence number and a 64 bit tim...
Create a server application which waits for input UDP packets and uses the information carried into t...
Hold an unsigned integer type.
Definition: uinteger.h:45
Vector3D Vector
Vector alias typedef for compatibility with mobility models.
Definition: vector.h:324
helps to create WifiNetDevice objects
Definition: wifi-helper.h:325
create MAC layers for a ns3::WifiNetDevice.
void SetType(std::string type, Args &&... args)
void SetPcapDataLinkType(SupportedPcapDataLinkTypes dlt)
Set the data link type of PCAP traces to be used.
Definition: wifi-helper.cc:543
void Set(std::string name, const AttributeValue &v)
Definition: wifi-helper.cc:163
manage and create wifi channel objects for the YANS model.
void SetPropagationDelay(std::string name, Ts &&... args)
void AddPropagationLoss(std::string name, Ts &&... args)
Ptr< YansWifiChannel > Create() const
Make it easy to create and manage PHY objects for the YANS model.
void SetChannel(Ptr< YansWifiChannel > channel)
uint16_t port
Definition: dsdv-manet.cc:45
void SetDefault(std::string name, const AttributeValue &value)
Definition: config.cc:891
#define NS_FATAL_ERROR(msg)
Report a fatal error with a message and terminate.
Definition: fatal-error.h:160
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition: log.h:202
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
Definition: log.h:275
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition: nstime.h:1338
@ WIFI_STANDARD_80211b
Every class exported by the ns3 library is enclosed in the ns3 namespace.
@ LOG_LEVEL_INFO
LOG_INFO and above.
Definition: log.h:107
void LogComponentEnable(const char *name, enum LogLevel level)
Enable the logging output associated with that log component.
Definition: log.cc:358
cmd
Definition: second.py:33
wifi
Definition: third.py:88
mobility
Definition: third.py:96