A Discrete-Event Network Simulator
API
example-ping-lr-wpan-beacon.cc
Go to the documentation of this file.
1/*
2 * Copyright (c) 2020 Ritsumeikan University, Shiga, Japan
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation;
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program; if not, write to the Free Software
15 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 *
17 * Author: Alberto Gallegos Ramonet <ramonet@fc.ritsumei.ac.jp>
18 */
19
20#include "ns3/core-module.h"
21#include "ns3/internet-apps-module.h"
22#include "ns3/internet-module.h"
23#include "ns3/lr-wpan-module.h"
24#include "ns3/mobility-module.h"
25#include "ns3/propagation-module.h"
26#include "ns3/sixlowpan-module.h"
27#include "ns3/spectrum-module.h"
28
29#include <fstream>
30
31using namespace ns3;
32
33static void
35{
36 // In the case of transmissions with the Ack flag activated, the transaction is only
37 // successful if the Ack was received.
39 {
40 NS_LOG_UNCOND("**********" << Simulator::Now().As(Time::S)
41 << " | Transmission successfully sent");
42 }
43}
44
45int
46main(int argc, char** argv)
47{
48 bool verbose = false;
49
50 CommandLine cmd(__FILE__);
51 cmd.AddValue("verbose", "turn on log components", verbose);
52 cmd.Parse(argc, argv);
53
54 if (verbose)
55 {
59 LogComponentEnable("LrWpanCsmaCa", LOG_LEVEL_INFO);
60 LogComponentEnable("LrWpanHelper", LOG_LEVEL_ALL);
61 LogComponentEnable("Ping6Application", LOG_LEVEL_INFO);
62 }
63
65 nodes.Create(2);
66
68 mobility.SetMobilityModel("ns3::ConstantPositionMobilityModel");
69 mobility.SetPositionAllocator("ns3::GridPositionAllocator",
70 "MinX",
71 DoubleValue(0.0),
72 "MinY",
73 DoubleValue(0.0),
74 "DeltaX",
75 DoubleValue(20),
76 "DeltaY",
77 DoubleValue(20),
78 "GridWidth",
80 "LayoutType",
81 StringValue("RowFirst"));
82 mobility.SetMobilityModel("ns3::ConstantPositionMobilityModel");
83 mobility.Install(nodes);
84
85 LrWpanHelper lrWpanHelper;
86 // Add and install the LrWpanNetDevice for each node
87 NetDeviceContainer lrwpanDevices = lrWpanHelper.Install(nodes);
88
89 Ptr<LrWpanNetDevice> dev1 = lrwpanDevices.Get(0)->GetObject<LrWpanNetDevice>();
90 Ptr<LrWpanNetDevice> dev2 = lrwpanDevices.Get(1)->GetObject<LrWpanNetDevice>();
91
94 dev1->GetMac()->SetMcpsDataConfirmCallback(cb1);
95 dev2->GetMac()->SetMcpsDataConfirmCallback(cb1);
96
97 // Fake PAN association, coordinator assignment, short address assignment and initialization
98 // of beacon-enabled mode in 802.15.4-2011.
99 // This is needed because the lr-wpan module does not provide (yet)
100 // a full PAN association procedure.
101
102 // AssociateToBeaconPan (devices, PAN ID, Coordinator Address, Beacon Order, Superframe Order)
103
104 // Must be careful not setting the beacon order (BO) and the superframe order (SO) too far apart
105 // or the ping reply (ICMPV6 echo reply) can time out during the inactive period of the
106 // superframe. A full time table of the BO/SO time equivalence can be found at the end of this
107 // document. The current configuration is BO = 14, SO = 13 :
108
109 // Contention Access Period (CAP) Inactive
110 // (125.82912 secs) (125.82088)
111 // |---------------------------------------------|-------------------------------------------|
112 // Beacon Beacon
113 // Beacon Interval = 251.65 secs
114 // |-----------------------------------------------------------------------------------------|
115
116 lrWpanHelper.AssociateToBeaconPan(lrwpanDevices, 0, Mac16Address("00:01"), 14, 13);
117
118 InternetStackHelper internetv6;
119 internetv6.Install(nodes);
120
121 SixLowPanHelper sixlowpan;
122 NetDeviceContainer devices = sixlowpan.Install(lrwpanDevices);
123
125 ipv6.SetBase(Ipv6Address("2001:2::"), Ipv6Prefix(64));
126 Ipv6InterfaceContainer deviceInterfaces;
127 deviceInterfaces = ipv6.Assign(devices);
128
129 // Send ping packets after the 2nd second of the simulation during the
130 // first 8 seconds of the CAP in the incoming superframe
131
132 uint32_t packetSize = 10;
133 uint32_t maxPacketCount = 5;
134 Time interPacketInterval = Seconds(1);
135 Ping6Helper ping6;
136
137 ping6.SetLocal(deviceInterfaces.GetAddress(0, 1));
138 ping6.SetRemote(deviceInterfaces.GetAddress(1, 1));
139
140 ping6.SetAttribute("MaxPackets", UintegerValue(maxPacketCount));
141 ping6.SetAttribute("Interval", TimeValue(interPacketInterval));
142 ping6.SetAttribute("PacketSize", UintegerValue(packetSize));
143 ApplicationContainer apps = ping6.Install(nodes.Get(0));
144
145 apps.Start(Seconds(2.0));
146 apps.Stop(Seconds(10.0));
147
148 AsciiTraceHelper ascii;
149 lrWpanHelper.EnableAsciiAll(ascii.CreateFileStream("Ping-6LoW-lr-wpan-beacon.tr"));
150 lrWpanHelper.EnablePcapAll(std::string("Ping-6LoW-lr-wpan-beacon"), true);
151
152 Simulator::Stop(Seconds(600));
153
154 Simulator::Run();
155 Simulator::Destroy();
156}
157
158// BO/SO values to time equivalence
159// These times are only valid for a 250kbps O-QPSK modulation,
160// times differ with other modulation configurations.
161
162// +------------------------+
163// | BO/SO | Time (secs) |
164// +------------------------+
165// | 0 | 0.01536 secs |
166// | 1 | 0.03072 secs |
167// | 2 | 0.06144 secs |
168// | 3 | 0.12288 secs |
169// | 4 | 0.24576 secs |
170// | 5 | 0.49152 secs |
171// | 6 | 0.98304 secs |
172// | 7 | 1.96608 secs |
173// | 8 | 3.93216 secs |
174// | 9 | 7.86432 secs |
175// | 10 | 15.72864 secs |
176// | 11 | 31.45728 secs |
177// | 12 | 62.91456 secs |
178// | 13 | 125.82912 secs |
179// | 14 | 251.65 secs |
180// +------------------------+
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.
void EnableAsciiAll(std::string prefix)
Enable ascii trace output on each device (which is of the appropriate type) in the set of all nodes c...
Manage ASCII trace files for device models.
Definition: trace-helper.h:173
Ptr< OutputStreamWrapper > CreateFileStream(std::string filename, std::ios::openmode filemode=std::ios::out)
Create and initialize an output stream object we'll use to write the traced bits.
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
aggregate IP/TCP/UDP functionality to existing Nodes.
void Install(std::string nodeName) const
Aggregate implementations of the ns3::Ipv4, ns3::Ipv6, ns3::Udp, and ns3::Tcp classes onto the provid...
Helper class to auto-assign global IPv6 unicast addresses.
void SetBase(Ipv6Address network, Ipv6Prefix prefix, Ipv6Address base=Ipv6Address("::1"))
Set the base network number, network prefix, and base interface ID.
Ipv6InterfaceContainer Assign(const NetDeviceContainer &c)
Allocate an Ipv6InterfaceContainer with auto-assigned addresses.
Describes an IPv6 address.
Definition: ipv6-address.h:50
Keep track of a set of IPv6 interfaces.
Ipv6Address GetAddress(uint32_t i, uint32_t j) const
Get the address for the specified index.
Describes an IPv6 prefix.
Definition: ipv6-address.h:456
helps to manage and create IEEE 802.15.4 NetDevice objects
void AssociateToBeaconPan(NetDeviceContainer c, uint16_t panId, Mac16Address coor, uint8_t bcnOrd, uint8_t sfrmOrd)
Associate the nodes to the same PAN and initiate beacon enabled mode.
NetDeviceContainer Install(NodeContainer c)
Install a LrWpanNetDevice and the associated structures (e.g., channel) in the nodes.
Network layer to device interface.
Ptr< LrWpanMac > GetMac() const
Get the MAC used by this NetDevice.
This class can contain 16 bit addresses.
Definition: mac16-address.h:44
Helper class used to assign positions and mobility models to nodes.
holds a vector of ns3::NetDevice pointers
Ptr< NetDevice > Get(uint32_t i) const
Get the Ptr<NetDevice> stored in this container at a given index.
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.
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 ...
Ping6 application helper.
Definition: ping6-helper.h:38
void SetRemote(Ipv6Address ip)
Set the remote IPv6 address.
Definition: ping6-helper.cc:41
ApplicationContainer Install(NodeContainer c)
Install the application in Nodes.
Definition: ping6-helper.cc:53
void SetAttribute(std::string name, const AttributeValue &value)
Set some attributes.
Definition: ping6-helper.cc:47
void SetLocal(Ipv6Address ip)
Set the local IPv6 address.
Definition: ping6-helper.cc:35
Setup a sixlowpan stack to be used as a shim between IPv6 and a generic NetDevice.
NetDeviceContainer Install(NetDeviceContainer c)
Install the SixLoWPAN stack on top of an existing NetDevice.
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
Hold an unsigned integer type.
Definition: uinteger.h:45
static void dataSentMacConfirm(McpsDataConfirmParams params)
#define NS_LOG_UNCOND(msg)
Output the requested message unconditionally.
@ IEEE_802_15_4_SUCCESS
Definition: lr-wpan-mac.h:194
Time Now()
create an ns3::Time instance which contains the current simulation time.
Definition: simulator.cc:296
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition: nstime.h:1338
NodeContainer nodes
devices
Definition: first.py:35
Every class exported by the ns3 library is enclosed in the ns3 namespace.
Callback< R, Args... > MakeCallback(R(T::*memPtr)(Args...), OBJ objPtr)
Build Callbacks for class method members which take varying numbers of arguments and potentially retu...
Definition: callback.h:691
@ LOG_LEVEL_ALL
Print everything.
Definition: log.h:116
@ LOG_PREFIX_FUNC
Prefix all trace prints with function.
Definition: log.h:118
@ LOG_PREFIX_TIME
Prefix all trace prints with simulation time.
Definition: log.h:119
@ 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
void LogComponentEnableAll(enum LogLevel level)
Enable the logging output for all registered log components.
Definition: log.cc:380
cmd
Definition: second.py:33
mobility
Definition: third.py:96
bool verbose
MCPS-DATA.confirm params.
Definition: lr-wpan-mac.h:361
LrWpanMcpsDataConfirmStatus m_status
The status of the last MSDU transmission.
Definition: lr-wpan-mac.h:363
static const uint32_t packetSize
Packet size generated at the AP.