[XMOVE自主设计的体感方案] XMove 4.0 无线组网协议

简介:

一. 综述

  XMove 4.0需要支持多节点混合组网,在用户超过两个或两个以上时,可能会有多达40个以上的节点接入到系统之中。这些节点可能包括来自前几代的兼容节点,也可能是4.0的超微节点和手持节点。如何使这些节点正常无干扰的工作,并处于低功耗,是一个非常复杂而艰巨的任务。

  无线协议有以下具体任务:

  •   尽可能准确有效无丢包的将节点数据传递给上位机
  • 将上位机的控制信息有效的传递给节点,并使节点改变为相应的工作状态
  • 支持多节点多拓扑混合组网

  

  作者为通信专业出身,对无线协议有一定的了解。我通过以下方式来解决该问题:

  •   扁平的节点类型,尽可能简化的无线协议
  • 建立上行链路(从节点到PC机)和下行链路(从PC机到节点)
  • 所有协议全部内置PC端,由PC端发送指令实现控制逻辑,节点只负责按照工作模式执行工作
  • 使用多信道方式解决无线干扰问题,采用自动信道分配算法,实现最优接收结构

二. 节点状态描述

  所有节点都继承于XNode类,该类为基本的通信,工作模式提供了服务。具体细节请参看文集中的节点设计部分。

  1. 节点区分标记

  节点通过NodeType字段表明节点类型:

  

  

    例如,超微型节点XNodeMini处于XMOVE4.0,类型号为1,因此nodeTypeID=1。

  节点通过RawID确定其硬件ID号。

  注意,不同类型的节点允许存在相同ID,但相同类型节点不允许存在相同ID,否则系统无法判断。

   2. 节点能力描述

  

  六个属性分别给出该节点是否包含对应传感器是否存在的标识。

  3.节点工作状态描述

  对于节点工作状态,有两个类来描述,它们分别是描述节点自身工作状态,以及系统要求的工作状态。此处只介绍节点自身工作状态描述。

  

  三. 上行链路:从节点到PC机

  XMove上行信道统一采用24byte包长形式,其各位标记如下:

  其中,电池电量,三轴传感器数据的定义随节点不同而不同,此处不硬性规定。

四. 下行链路:从PC机到节点

  XMove下行链路控制更为简单,包长与上行一致,为24byte. 由于PC机通常没有2.4GHz无线通信能力,必须经过转接节点。转接节点收到数据后转发给各子节点。

  

  TransferID是要发送到的桥接节点ID,桥接节点发现本机ID与该字段一致时,才会认为是己方数据。

  PacketType是包类型描述,1代表是RF信道配置,用于配置本机不同射频模块的RF参数,后面每两个字节代表一个射频模块,分别是模块ID和要配置的信道ID。

  2代表配置子节点状态,桥接节点收到后,不经过任何处理,直接转发给子节点。子节点收到数据后,在该包中找到匹配的RawID,并通过该位下一位的WorkMode修正自身的工作模式。

五.  工作模式和信道控制逻辑

  控制信道涉及对节点工作模式和射频的控制两大部分。但实际上,它们是在一起发送的,下面我们分别介绍它们。

  1. 工作模式控制

  为了尽可能的降低节点功耗,节点的刷新速率和陀螺仪开启状态是应该根据需求动态调整的。在不需要节点传输数据时,节点应该以最低的4s一次的“呼吸包”通知管理器该节点依旧“存活”。而实际上,可能有多种应用同时需要该节点的数据,他们对该节点的工作状态需求是不同的。应该找到能满足这些应用的最低需求。为解决这个问题,我们设计了这个类:

  该类从NodeWorkMode继承,多了一个新属性:myNeededList ,它存储了所有应用对该节点的所有需求。当外界读取该类的WorkMode值时,它会返回满足这些需求的最低需求。它实际上是一个字典: Dictionary<IProgramWPF, Tuple<bool, NodeFreshSpeed>>。

  至于应用如何给出节点的工作模式需求,请参考XMove Studio应用开发API介绍。

  2. 信道分配算法

  为了尽可能提升系统的无线性能,硬件上采用了多个信道分配的策略,但这也造成了如何分配信道的问题。我们设计了如下的信道枚举:


/// <summary>
    /// 信道ID
    /// </summary>
    public enum RFChannel
    {
        /// <summary>
        /// 基础信道,默认节点开启时,处在该信道
        /// </summary>
        RF0=0,
        RF1=1,
        RF2=2,
        RF3=3,
        RF4=4,
        RF5=5,
        RF6=6,
        RF7=7
    }

 当节点开启时,所有的RF节点都以一秒一次的速度在RF0信道上工作。

  当所有节点都在通信方法的节点映射表中注册之后,系统会自动启动信道分配算法,并开始控制逻辑。其原则如下:

  •   系统中可能包含多个桥接节点,它们的RF信道数量可能不同,
  • 系统中包含大量子节点,它们都默认工作在RF0信道,应该将其均匀的分配在各信道中。
  • 若某信道的误包率太大,则应该将该节点切换到信道状态良好的信道。

  作者设计了RFChannelDistributor类专门解决信道分配问题:

  其具体操作流程如下:

  

  3. 发送控制信息

  当系统发现节点的工作模式与系统需求的工作模式不匹配时,系统就会启动控制信息发送过程。

  由于下行链路的包长为24字节,因此一次最多只能控制11个节点。系统只发送状态不正确的节点控制信息,若一次发不完,则分开发送。每个包发送后,都会经过300ms的延时,再发送一次,总共发送三次,保证数据发送无误。

六. 节点工作状态监视

  系统提供了节点工作状态监视组件。

  左边的列表给出了所有激活的节点队列,点选其中任意一项,右边的监测器就会对其工作状态进行监视,具体属性可参看使用说明,此处不赘述。

  若您希望手动更正所有节点工作模式和频段,在菜单栏中的“通信”一栏的“重配射频信道”选项,可以帮您完成该过程。

七. 总结

  本文详细介绍了XMove4.0的组网问题和工作模式描述。一篇文章无法描述完整内容。在上下行链路中,也仅仅介绍了2.4G射频信道的数据格式,手机蓝牙信道等都没有提及。

  实践证明,该配置可以简单高效的解决信道分配的问题,在实现各应用需求下实现最佳性能和最低功耗。

  有任何问题,欢迎讨论。

相关文章
|
5G 网络架构
5G 系统网络架构 | 带你读《5G 无线系统设计与国际标准》之四
为了适应各种部署场景,5G 支持了两种部署方式:一种为分布式部署,这种方式与 LTE系统类似,网络由基站组成,基站支持全协议栈的功能;另一种为集中式部署,基站进一步分为集中单元(CU,Centralized Unit)和分布单元(DU,Distributed Unit)两个节点,CU 和 DU 分别支持不同的协议栈和功能,
5G 系统网络架构  | 带你读《5G 无线系统设计与国际标准》之四
|
负载均衡 监控 安全
把网关系统设计的炉火纯青!(2)
把网关系统设计的炉火纯青!
125 0
把网关系统设计的炉火纯青!(2)
|
监控 前端开发 IDE
把网关系统设计的炉火纯青!(3)
把网关系统设计的炉火纯青!
110 0
把网关系统设计的炉火纯青!(3)
|
安全 Java Devops
把网关系统设计的炉火纯青!(1)
把网关系统设计的炉火纯青!
131 0
把网关系统设计的炉火纯青!(1)
|
物联网 人工智能
一文读懂物联网硬件接入难点与破解(内含智慧养殖、水处理案例详解)|MVP时间
前微软(中国).NET MF开发团队成员,CSDN十大MVB刘洪峰授课!IOT落地难点一网打尽,更有丰富实践案例等你来学
2741 0
一文读懂物联网硬件接入难点与破解(内含智慧养殖、水处理案例详解)|MVP时间
|
移动开发 前端开发 JavaScript
对无线电商动态化方案的思考(一)
如题,接下里的一段时间里,我会从无线电商动态化的角度谈一谈自己的理解和思考 ## 无线电商动态化 ### 无线 首先要谈的是无线,或者说移动。手机和传统桌面端计算机有着非常大的不同,首先是随时随地,这样它就需要同时也可以拥有更多的传感器,比如镜头、体感、定位、蓝牙、NFC 等等,当
4087 0
|
移动开发 前端开发 JavaScript
对无线电商动态化方案的思考(三)
之前两篇我们分别谈到了对无线电商动态化的理解,以及我们自己的技术方案:Weex都比较宏观和抽象,今天我们分享一些其中的技术细节。
2892 0
【实践】工业用变频器上云 【3】 硬件开发,使用嵌入式硬件通过485通讯的ModBusRTU协议控制变频器
本系列介绍,如何将一台台达变频器接入阿里云物联网,并且实现云端操控的实践案例。本章着重解决让硬件正确的驱动变频器实现下面级的正确控制