38#include "ns3/constant-position-mobility-model.h"
39#include "ns3/core-module.h"
41#include "ns3/lr-wpan-module.h"
42#include "ns3/packet.h"
43#include "ns3/propagation-delay-model.h"
44#include "ns3/propagation-loss-model.h"
45#include "ns3/simulator.h"
46#include "ns3/single-model-spectrum-channel.h"
47#include "ns3/zigbee-module.h"
63 <<
"Traceroute to destination [" << dst <<
"]:\n";
73 if (zstack->GetNwk()->GetNetworkAddress() == target)
79 bool neighbor =
false;
80 target = zstack->GetNwk()->FindRoute(dst, neighbor);
83 std::cout << count <<
". Node " << zstack->GetNode()->GetId() <<
" ["
84 << zstack->GetNwk()->GetNetworkAddress() <<
" | "
85 << zstack->GetNwk()->GetIeeeAddress() <<
"]: "
86 <<
" Destination Unreachable\n";
90 std::cout << count <<
". Node " << zstack->GetNode()->GetId() <<
" ["
91 << zstack->GetNwk()->GetNetworkAddress() <<
" | "
92 << zstack->GetNwk()->GetIeeeAddress() <<
"]: "
93 <<
"NextHop [" << target <<
"] ";
96 std::cout <<
"(*Neighbor)\n";
112 <<
"NsdeDataIndication: Received packet of size " << p->GetSize() <<
"\n";
118 std::cout <<
"NlmeNetworkFormationConfirmStatus = " << params.m_status <<
"\n";
129 if (params.m_status == NwkStatus::SUCCESS)
131 std::cout <<
" Network discovery confirm Received. Networks found ("
132 << params.m_netDescList.size() <<
"):\n";
134 for (
const auto& netDescriptor : params.m_netDescList)
136 std::cout <<
" ExtPanID: 0x" << std::hex << netDescriptor.m_extPanId <<
"\n"
137 << std::dec <<
" CH: " <<
static_cast<uint32_t>(netDescriptor.m_logCh)
139 << std::hex <<
" Pan ID: 0x" << netDescriptor.m_panId <<
"\n"
140 <<
" Stack profile: " << std::dec
141 <<
static_cast<uint32_t>(netDescriptor.m_stackProfile) <<
"\n"
142 <<
"--------------------\n";
159 NS_ABORT_MSG(
"Unable to discover networks | status: " << params.m_status);
166 if (params.m_status == NwkStatus::SUCCESS)
169 <<
" The device joined the network SUCCESSFULLY with short address " << std::hex
170 << params.m_networkAddress <<
" on the Extended PAN Id: " << std::hex
171 << params.m_extendedPanId <<
"\n"
183 std::cout <<
" The device FAILED to join the network with status " << params.m_status
191 std::cout <<
"NlmeRouteDiscoveryConfirmStatus = " << params.m_status <<
"\n";
207 dataReqParams.
m_dstAddr = stackDst->GetNwk()->GetNetworkAddress();
217 stackSrc->GetNwk()->GetNetworkAddress(),
218 stackDst->GetNwk()->GetNetworkAddress());
232main(
int argc,
char* argv[])
256 dev0->GetMac()->SetExtendedAddress(
"00:00:00:00:00:00:CA:FE");
257 dev1->GetMac()->SetExtendedAddress(
"00:00:00:00:00:00:00:01");
258 dev2->GetMac()->SetExtendedAddress(
"00:00:00:00:00:00:00:02");
259 dev3->GetMac()->SetExtendedAddress(
"00:00:00:00:00:00:00:03");
260 dev4->GetMac()->SetExtendedAddress(
"00:00:00:00:00:00:00:04");
269 channel->AddPropagationLossModel(propModel);
270 channel->SetPropagationDelayModel(delayModel);
272 dev0->SetChannel(channel);
273 dev1->SetChannel(channel);
274 dev2->SetChannel(channel);
275 dev3->SetChannel(channel);
276 dev4->SetChannel(channel);
298 zstack0->GetNwk()->AssignStreams(0);
299 zstack1->GetNwk()->AssignStreams(10);
300 zstack2->GetNwk()->AssignStreams(20);
301 zstack3->GetNwk()->AssignStreams(30);
302 zstack4->GetNwk()->AssignStreams(40);
307 dev0Mobility->SetPosition(Vector(0, 0, 0));
308 dev0->GetPhy()->SetMobility(dev0Mobility);
311 dev1Mobility->SetPosition(Vector(90, 0, 0));
312 dev1->GetPhy()->SetMobility(dev1Mobility);
315 dev2Mobility->SetPosition(Vector(170, 0, 0));
316 dev2->GetPhy()->SetMobility(dev2Mobility);
319 dev3Mobility->SetPosition(Vector(250, 0, 0));
320 dev3->GetPhy()->SetMobility(dev3Mobility);
323 dev4Mobility->SetPosition(Vector(90, 50, 0));
324 dev4->GetPhy()->SetMobility(dev4Mobility);
331 zstack0->GetNwk()->SetNlmeNetworkFormationConfirmCallback(
333 zstack0->GetNwk()->SetNlmeRouteDiscoveryConfirmCallback(
336 zstack0->GetNwk()->SetNldeDataIndicationCallback(
338 zstack1->GetNwk()->SetNldeDataIndicationCallback(
340 zstack2->GetNwk()->SetNldeDataIndicationCallback(
342 zstack3->GetNwk()->SetNldeDataIndicationCallback(
344 zstack4->GetNwk()->SetNldeDataIndicationCallback(
347 zstack1->GetNwk()->SetNlmeNetworkDiscoveryConfirmCallback(
349 zstack2->GetNwk()->SetNlmeNetworkDiscoveryConfirmCallback(
351 zstack3->GetNwk()->SetNlmeNetworkDiscoveryConfirmCallback(
353 zstack4->GetNwk()->SetNlmeNetworkDiscoveryConfirmCallback(
helps to manage and create IEEE 802.15.4 NetDevice objects
NetDeviceContainer Install(NodeContainer c)
Install a LrWpanNetDevice and the associated structures (e.g., channel) in the nodes.
This class can contain 16 bit addresses.
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.
Smart pointer class similar to boost::intrusive_ptr.
static void SetRun(uint64_t run)
Set the run number of simulation.
static void SetSeed(uint32_t seed)
Set the seed.
static EventId Schedule(const Time &delay, FUNC f, Ts &&... args)
Schedule an event to expire after delay.
static void Destroy()
Execute the events scheduled with ScheduleDestroy().
static void ScheduleWithContext(uint32_t context, const Time &delay, FUNC f, Ts &&... args)
Schedule an event with the given context.
static Time Now()
Return the current simulation virtual time.
static void Run()
Run the simulation.
static EventId ScheduleNow(FUNC f, Ts &&... args)
Schedule an event to expire Now.
static void Stop()
Tell the Simulator the calling event should be the last one executed.
TimeWithUnit As(const Unit unit=Time::AUTO) const
Attach a unit to a Time, to facilitate output in a specific unit.
Setup a Zigbee stack to be used with LrWpanNetDevice.
zigbee::ZigbeeStackContainer Install(NetDeviceContainer c)
Install the Zigbee stack on top of an existing LrWpanNetDevice.
Network layer to device interface.
void PrintRoutingTable(Ptr< OutputStreamWrapper > stream) const
Print the entries in the routing table.
void NlmeStartRouterRequest(NlmeStartRouterRequestParams params)
Zigbee Specification r22.1.0, section 3.2.2.9 NLME-START-ROUTER.request This primitive allows the nex...
void NldeDataRequest(NldeDataRequestParams params, Ptr< Packet > packet)
Zigbee Specification r22.1.0, Section 3.2.1.1 NLDE-DATA.request Request to transfer a NSDU.
void PrintNeighborTable(Ptr< OutputStreamWrapper > stream) const
Print the entries in the neighbor table.
void NlmeNetworkDiscoveryRequest(NlmeNetworkDiscoveryRequestParams params)
Zigbee Specification r22.1.0, section 3.2.2.3 NLME-NETWORK-DISCOVERY.request Allows the next higher l...
void NlmeJoinRequest(NlmeJoinRequestParams params)
Zigbee Specification r22.1.0, section 3.2.2.13 NLME-JOIN.request This primitive allows the next highe...
void PrintRouteDiscoveryTable(Ptr< OutputStreamWrapper > stream)
Print the entries in the route discovery table.
void NlmeNetworkFormationRequest(NlmeNetworkFormationRequestParams params)
Zigbee Specification r22.1.0, Section 3.2.2.5 and 3.6.1.1 NLME-NETWORK-FORMATION.request Request the ...
Holds a vector of ns3::ZigbeeStack pointers.
Iterator End() const
Get an iterator which indicates past the last ZigbeeStack in the container.
Iterator Begin() const
Get and iterator which refers to the first ZigbeeStack in the container.
Ptr< ZigbeeStack > Get(uint32_t i) const
Get a stack element from the container.
void Add(ZigbeeStackContainer other)
Append the contents of another ZigbeeStackContainer to the end of this container.
Zigbee protocol stack to device interface.
#define NS_ABORT_MSG(msg)
Unconditional abnormal program termination with a message.
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
auto MakeBoundCallback(R(*fnPtr)(Args...), BArgs &&... bargs)
Make Callbacks with varying number of bound arguments.
Ptr< T > CreateObject(Args &&... args)
Create an object by type, with varying number of constructor parameters.
Ptr< T > Create(Ts &&... args)
Create class instances by constructors with varying numbers of arguments and return them by Ptr.
Time Seconds(double value)
Construct a Time in the indicated unit.
@ UCST_BCST
Unicast or Broadcast address mode.
@ ENABLE_ROUTE_DISCOVERY
Enable route discovery.
static constexpr uint32_t ALL_CHANNELS
Bitmap representing all channels (11~26) LSB b0-b26, b27-b31 MSB Page 0 in Zigbee (250kbps O-QPSK)
Every class exported by the ns3 library is enclosed in the ns3 namespace.
LogLevel
Logging severity classes and levels.
@ LOG_PREFIX_FUNC
Prefix all trace prints with function.
@ LOG_PREFIX_TIME
Prefix all trace prints with simulation time.
@ LOG_PREFIX_NODE
Prefix all trace prints with simulation node.
void LogComponentEnableAll(LogLevel level)
Enable the logging output for all registered log components.
uint8_t channelPageCount
The number of the channel page structures contained in the channel list structure.
std::vector< uint32_t > channelsField
The set of channels for a given page.
NLDE-DATA.indication params.
NLDE-DATA.request params.
Mac16Address m_dstAddr
The destination address.
uint8_t m_nsduHandle
The NSDU handle.
AddressMode m_dstAddrMode
Destination address mode.
uint8_t m_discoverRoute
0x01 Enable Route Discovery | 0x00: Suppress Route discovery
NLME-JOIN.confirm params.
NLME-JOIN.request params.
JoiningMethod m_rejoinNetwork
This parameter controls the method of joining the network.
uint8_t m_capabilityInfo
The operating capabilities of the device being directly joined (Bit map).
uint64_t m_extendedPanId
The 64 bit PAN identifier of the the network to join.
NLME-NETWORK-DISCOVERY.confirm params.
NLME-NETWORK-DISCOVERY.request params.
uint8_t m_scanDuration
A value used to calculate the length of time to spend.
ChannelList m_scanChannelList
The list of all channel pages and the associated channels that shall be scanned.
NLME-ROUTE-DISCOVERY.confirm params.
NLME-START-ROUTER.request params.
static void NwkNetworkDiscoveryConfirm(Ptr< ZigbeeStack > stack, NlmeNetworkDiscoveryConfirmParams params)
static void SendData(Ptr< ZigbeeStack > stackSrc, Ptr< ZigbeeStack > stackDst)
static void TraceRoute(Mac16Address src, Mac16Address dst)
static void NwkDataIndication(Ptr< ZigbeeStack > stack, NldeDataIndicationParams params, Ptr< Packet > p)
static void NwkJoinConfirm(Ptr< ZigbeeStack > stack, NlmeJoinConfirmParams params)
ZigbeeStackContainer zigbeeStacks
static void NwkRouteDiscoveryConfirm(Ptr< ZigbeeStack > stack, NlmeRouteDiscoveryConfirmParams params)
static void NwkNetworkFormationConfirm(Ptr< ZigbeeStack > stack, NlmeNetworkFormationConfirmParams params)