Zigbee—网络层地址分配机制

简介: Zigbee—网络层地址分配机制

前言

       本文主要是介绍对于zigbee网络层中地址分配机制中对于各个节点的网络地址的计算,对于其他的知识点可能总结的不是很到位。诸如以下的题目:


        计算如下图所示各个节点的网络地址

2.png


一、Zigbee网络层地址分配介绍

      水一下定义啦,怎么计算从后面的小点开始

       Zigbee网络层地址分配是指在Zigbee网络中为节点分配唯一的网络地址,以实现节点之间的通信。网络层地址由16位地址组成,通常用十六进制表示。Zigbee网络中有两种类型的地址:短地址和扩展地址。

       短地址用于节点在网络中的直接寻址。短地址是由协调器分配,并且只在网络内唯一。短地址是16位的,范围为0x0000到0xfffe,其中0xfffe保留。协调器的短地址为0x0000。

扩展地址用于唯一标识节点。扩展地址是64位的,由厂商分配。扩展地址通常用于在网络层建立长期的安全连接,以保护通信安全。

       Zigbee网络中还存在一个特殊的短地址0xffff,用于向所有节点广播消息。这个地址无论在哪个网络中都是预留的。

       在Zigbee网络中,节点可以使用短地址或扩展地址进行通信。节点可以根据需要选择使用哪种地址。要向网络中的节点发送消息,需要知道节点的地址。节点的地址可以通过网络扫描或直接查询节点得到。


二、 网络层地址分配计算

       现给出一个公式,请一定一定要记住!!!

3.png

 对于该公式的说明:


      C->每个父节点最多可连的节点数

       R->父节点下的那C个子节点最多可有的路由器节点数

       L->网络的最大深度

       d->网络深度

       Cskip(d)->网络深度d的父节点为子节点分配的地址之间的偏移量


      注意:我们对于分配地址的计算的要点就是围绕这些来进行的!!!其中最主要的便是Cskip,务必要计算准确!!! 其中C、R、L通常题目会给出!


  一些额外的说明

(1)当一个路由器节点的Cskip(d)为0时,它就不具备为子节点分配地址的能力意思就是不用往后算了!!!),也即表明不能够在使用别的节点通过他加入网络

(2)当Cskip(d)大于0时表明父节点可以接受其他节点为其子节点意思是你要你要往后继续算!!!),并为子节点分配网络地址。父节点会为第一个与它关联的路由器分配比他大1的地址,之后与之关联的路由器节点的地址之间都相隔偏移量Cskip(d)。

(3)每个父节点最多可以分配R个这样的地址。伪终端节点分配地址和为路由器节点分配地址不同,假设父节点的地址为Ap,则第N个与之关联的终端节点地址An按下式计算:

33.png

 通过一道例题来进一步理解 :

  1. 计算如下图所示各个节点的网络地址。其中,1号节点为ZigBee协调器,与协调器相连的其他节点为路由器和终端;假设在当前的网络结构中,每个父节点最多可以连接4个子节点,子节点最多可以有4个路由器节点,当前网络的最大深度为3。

4.png

 分析一下这道题目:父节点最多可以连接4个子节点->C=4,子节点最多可以有4个路由器节点->R=4,最大深度为3->L=3,结合图来分析:

再来看这个公式,我们已经知道R为4的情况下,对此选择下半公式来进行计算!

5.png

计算如下:分别计算出深度为0、1、2时的Cskip


      Cskip(0) = (1+4-4-(4*4^(3-0-1)))/(1-4) = 21

       Cskip(1) = (1+4-4-(4*4^(3-1-1)))/(1-4) = 5

       Cskip(2) = (1+4-4-(4*4^(3-2-1)))/(1-4) = 1

    在计算完成之后其实已近完成了大半的工作,接下来按照规则来分配节点即可:

首先从ZigBee协调器相邻的节点开始分配,分配完成后,再依次分配各自的子节点。

       如下图所示:

接下来是重点,请注意!!!


       由于本题未说明终端节点以及以及路由器,对此本题按一下规则:


       我们就将所有节点都看作为路由器吧!现在,(1)我们选择与父节点(默认1号节点地址addr(1)=0)相邻的任意一个节点,剩下的先放在一边,让这个节点在根节点的地址基础上+1!!!这里选择了2号节点,则二号节点的地址:addr(2) = addr(1)+1。(2)其他剩余的节点按照逆时针、顺时针都可以分别用上一层次深度的Cskip加上相邻节点的地址,例:3号:addr(3) = addr(2) + Cskip(0) = 1+21 = 22,4号:addr(4) = addr(3) + Cskip(0) = 22+21 = 43,5号:addr(5) = addr(4) + Cskip(0) = 43+21 = 64 既:如下图所示:

在进行完上面的步骤后,我们分别以各个已近分配好地址的节点为父节点,接着重复(1)(2)操作即可,(特别注意:在Cskip=0时就没必要继续分配了

以下是本文的总体解题:

1号:addr(1)=0

Cskip(0)=21

2号:2addr(2) = addr(1)+1=1

3号::addr(3) = addr(2) + Cskip(0) = 1+21 = 22

4号:addr(4) = addr(3) + Cskip(0) = 22+21 = 43

5号:addr(5) = addr(4) + Cskip(0) = 43+21 = 64

Cskip(1)=5

9号:addr(9) = addr(5) + 1 = 64+1 = 65

6号:addr(6) = addr(9) + Cskip(1) = 65+5 = 70

7号:addr(7) = addr(3) + 1 = 22+1 = 23

8号:addr(8) = addr(4) + 1 = 43+1 = 44

特别注意!!!

       如若是区分协调器以及终端的题目则对终端用以下公式:

这里就不多阐述了,对于终端就多注意一下就好


感谢你耐心的看到这里ღ( ´・ᴗ・` )比心,如有哪里有错误请踢一脚作者o(╥﹏╥)o! 

                   

相关文章
|
11月前
|
容器
基于Arduino的植物浇水系统
基于Arduino的植物浇水系统
188 0
|
Linux C++ Windows
code规范 --- 驼峰命名法
code规范 --- 驼峰命名法
1114 0
|
存储 运维 监控
|
Android开发
Android Studio: 解决Gradle sync failed 错误
本文介绍了解决Android Studio中出现的Gradle同步失败错误的步骤,包括从`gradle-wrapper.properties`文件中获取Gradle的下载链接,手动下载Gradle压缩包,并替换默认下载路径中的临时文件,然后重新触发Android Studio的"Try Again"来完成同步。
6292 0
Android Studio: 解决Gradle sync failed 错误
|
Java 索引
Java String 类详解
Java 中的 `String` 类用于表示不可变的字符序列,是 Java 标准库 `java.lang` 包的一部分。字符串对象一旦创建,其内容不可更改,修改会生成新对象。
258 7
|
11月前
|
消息中间件 NoSQL Kafka
大数据-116 - Flink DataStream Sink 原理、概念、常见Sink类型 配置与使用 附带案例1:消费Kafka写到Redis
大数据-116 - Flink DataStream Sink 原理、概念、常见Sink类型 配置与使用 附带案例1:消费Kafka写到Redis
716 0
|
网络协议 搜索推荐
网络中的单播、多播和广播
【8月更文挑战第24天】
550 0
|
IDE Linux 开发工具
IntelliJ IDEA2022破解IDEA2022.2永久破解激活教程
IDEA 目前已经更新到最新的 2022.2.2 版本了,群里的小伙伴私聊问我,为啥之前 2021.3.1 的激活套路对新版本 2022.2.2 不管用了,是个什么情况? 很显然,IDEA 官方发现了这种破解路数,新版本加入了更严厉的反制破解。所以说,小伙伴们破解成功了以后,尽量不要升级 IDEA, 不然大概率又不行了。 好在z大又更新了新的补丁,针对最新版本,这边笔者亲测可行,仅以下文记录本人 IntelliJ IDEA 2022.2.2 版本的激活破解到 2099 年的全过程,步骤非常详细,跟着图文来就行~
63216 3
IntelliJ IDEA2022破解IDEA2022.2永久破解激活教程
|
SQL 存储 缓存
老司机总结的12条 SQL 优化方案(非常实用)(一)
老司机总结的12条 SQL 优化方案(非常实用)
老司机总结的12条 SQL 优化方案(非常实用)(一)
复习单片机:流水灯(内含2种方法(左移操作符法+crol法)+设计思路+原始代码)
复习单片机:流水灯(内含2种方法(左移操作符法+crol法)+设计思路+原始代码)
2117 0
复习单片机:流水灯(内含2种方法(左移操作符法+crol法)+设计思路+原始代码)