Disclosed embodiments relate generally to wireless communications, more specifically to Bluetooth Low Energy (BLE) automation mesh network (BLE-Mesh) communications.
BLE-Mesh is a wireless personal area network (WPAN) technology that uses a flooding-based packet protocol that with packet retransmission extends the range of BLE devices by including the ability to send messages to and amongst groups of devices. The devices in the BLE-Mesh network can support both BLE and BLE-mesh, but not necessarily both. A rebroadcasting mesh network works by flooding each message to all device nodes in the network through broadcasts.
The nodes in the mesh network all share a set of indexed data slots. Each time a device receives a broadcast message from another device in the mesh, the device repeats the message (rebroadcasts it), enabling its neighboring devices to ‘hear’ the new message. The neighboring devices rebroadcast this message to all their neighbors, and the process is repeated until all devices in the Mesh have received the same message. Flooding thus enables wireless devices to ‘talk’ to each other without being within a direct radio range, as devices between them help by relaying the messages. In a typical WPAN there are edge device(s) which are battery powered, relay devices that are always on as they are always in the listening mode, and there are functional end device(s), such as lights.
Each packet contains the sender's source address (SRC) for packet addressing as well as a packet sequence (SEQ) number, and the payload is also tagged with the type of message that is called a model. The packet also contains the address to whom (which device node) the packet is addressed. The packet generally specifies a unique address of each device in the mesh than can be derived from the device's Universally Unique Identifier (UUID). The SEQ number is a field indicating the sequence number of a message, which prevents device nodes from relaying packets that they have received before. For example a single bit for a single bit SEQ where the SEQ number bit is initialized to 0 by the device upon entering the connection state, and where the SEQ number bit is changed (from 0 to 1 or vice versa) for each new packet sent by the device, but the SEQ number bit is not changed when a packet is relayed (resent, so not new) by the device. Models are application implementations, such as a lighting model that defines the command to dim a light, or get status.
A network device that receives the packet checks the intended address to determine if it is the intended receiver of the packet, and if so begins processing the information within the packet. Devices that hear the packet but are not the intended receiver discard them, or send them back out as a broadcast. This relay function is possible, since a time-to-live (TTL) counter is used so that the packet will only be repeated so many times and since packets that come around are being recognized as already received, they will not be repeated. With this TTL-based packet relaying arrangement flooding the mesh can be avoided.
This Summary is provided to introduce a brief selection of disclosed concepts in a simplified form that are further described below in the Detailed Description including the drawings provided. This Summary is not intended to limit the claimed subject matter's scope.
The BLE-Mesh specification may utilize a data rate that is lower than the data rate supported by some commercially available BLE-Mesh devices that may be in the mesh network. For example, a maximum Physical Layer (PHY) data rate utilized throughout the mesh network may be 1 Mbit/s. Thus, although there may be BLE-Mesh devices that provide a data rate >1 Mbit/s in the mesh network, there is no known technique for data rate switching to support higher data rate network communications with such higher data rate BLE-mesh devices.
Disclosed speed switching is for exploiting high-speed in BLE-Mesh networks which applies to relay devices supporting both a higher-speed and lower-speed mode to enable exploiting the high-speed mode when the high-speed mode is determined to supported by the neighboring device nodes, and to utilize the lower-speed mode when the high-speed mode is determined to not be supported by the neighboring device nodes. The higher-speed data rate can be at least 50% higher than the lower-speed data rate. High-speed data rate operation when supported is implemented to reduce network congestion by improving multi-hop latency, and can also be used for faster over the air (OTA) firmware updates to the neighboring devices. Disclosed methods are especially useful for large scale BLE-mesh deployments which as known in the art are prone to congestion.
Disclosed embodiments include a BLE-Mesh device including a controller having a processor and a transceiver, wherein the controller implements an applications layer including BLE applications and Mesh applications, and a BLE stack and a mesh stack. The BLE-Mesh device has a switchable high-speed and low-speed mode and a speed switching algorithm for implementing a method of communications in BLE-mesh network. A broadcast ping is sent to neighborhood devices with a TTL=1. A manufacturer's ID is analyzed to identify a manufacturer's ID field in pongs received to determine whether a higher-speed capable device or a lower-speed device. A higher-speed data rate is utilized for mesh communications if the percentage of higher-speed capable devices is≧a threshold percentage, or a lower-speed data rate is utilized for the mesh communications if the percentage of higher-speed capable devices is<the threshold percentage.
Reference will now be made to the accompanying drawings, which are not necessarily drawn to scale, wherein:
Example embodiments are described with reference to the drawings, wherein like reference numerals are used to designate similar or equivalent elements. Illustrated ordering of acts or events should not be considered as limiting, as some acts or events may occur in different order and/or concurrently with other acts or events. Furthermore, some illustrated acts or events may not be required to implement a methodology in accordance with this disclosure.
Also, the terms “coupled to” or “couples with” (and the like) as used herein without further qualification are intended to describe either an indirect or direct electrical connection. Thus, if a first device “couples” to a second device, that connection can be through a direct electrical connection where there are only parasitics in the pathway, or through an indirect electrical connection via intervening items including other devices and connections. For indirect coupling, the intervening item generally does not modify the information of a signal but may adjust its current level, voltage level, and/or power level.
The device address range in the pong packet is analyzed by the ping sender device to determine the manufacturer's ID which is used to decide whether or not the neighboring BLE-Mesh device is a high speed capable device. The relay device performing the ping can compile and maintain a neighborhood list with the high speed capable vs. non-high speed capable device nodes marked in the list. If the same neighboring BLE-Mesh device is from the same manufacturer then the receiving BLE-Mesh device knows what speeds are supported by its neighbor BLE-Mesh device.
From the pongs the communication speed (device data rate) can then be determined. The non-high speed device nodes will not ‘hear’ high-speed ping packets. There are various methods to flood (relay) packets. One can send pings in only high-speed. This results in the non-high speed device nodes not decoding packets, thus not sensing pongs responsive to the ping. However, also certain high-speed device nodes that are connected only through non-high speed device nodes will not receive the ping packet either.
Another method to flood relay packets is to send separate pings to provide a ping in both the regular speed (e.g., 1 MB/sec) and in the high-speed (e.g., 2 MB/sec). However, this generally causes additional latency and overhead unnecessarily. Another method to flood relay packets is to use a relatively simple algorithm that comprises picking if a device node should relay in regular speed or in high speed. A relay-type index is maintained in a neighbor list identifying the respective BLE-Mesh device nodes as being high-speed capable or not high-speed capable.
If the number of neighbor high-speed capable BLE-Mesh device nodes ≧a threshold percentage (e.g., a fixed percentage ≧50%), then it can be determined for the BLE-Mesh device to use relay-type index=1, thus to use high-speed, else 0 and thus use the lower speed. The threshold percentage can be a configurable parameter which can be set to any percentage at deployment time, or it can be dynamically set at run time by the network administrator. In the case of mixed high-speed/regular speed BLE-Mesh neighboring devices only the supported speed devices will receive the packets. If the destination BLE-Mesh device node is a neighbor, then one can base the determination of high-speed capable device or not based on the destination node type. If the packet destination is an immediate neighbor, direct communication with that BLE-Mesh device is possible. Hence one can directly use the highest speed supported by the device. Otherwise, if there are sufficient number reflected in the threshold percentage of neighbor devices capable of high-speed the relay-type is 1, then one can use the higher-speed, else use the regular lower-speed.
The percentage of neighborhood higher-speed capable devices can change during network operations if the BLE-Mesh devices in the network are mobile or if new devices are added to the network, and this change can result in being on a different side relative to the threshold percentage. Responsive to a change in the percentage of neighborhood higher-speed capable devices which results in moving to a different side relative to the threshold percentage, the BLE-Mesh device for its mesh communications can change from utilizing a higher-speed data rate to a lower-speed data rate in the case of added lower-speed device(s), or from utilizing a lower-speed data rate to a higher-speed data rate in the case of added higher-speed capable device(s).
Benefits of disclosed speed switching for exploiting high-speed in BLE-mesh systems includes improvement in less contention, thereby providing greater robustness. There is also a reduction in congestion which improves scalability and latency. Disclosed speed switching can be used for faster OTA firmware updates.
Disclosed speed switching can be detected in a variety of ways. The switching of the BLE-Mesh device between different speeds can be detected by tracking that particular device communication. A high-speed capable BLE-mesh device when using the high-speed mode can receive high-speed mesh packets and thereby be detected by using a packet sniffer at the high speed rate. For tracking, the unique device address in the packet can be used (that is in the packet besides the manufacturer's ID) in conjunction with multiple packet sniffers operating at different data rates. If the BLE-mesh device is speed switching, then packets from that BLE-mesh device will be observed on the different rate sniffers.
The BLE-Mesh device 400 comprises a controller 420 including a processor 425, a memory 422 including software 422a for disclosed speed switching for exploiting a high-speed BLE-Mesh networks algorithm, and a transceiver 424 including an RF driver 424a that is adapted to be coupled to an antenna 428. The processor 425 can comprises a digital signal processor (DSP) or microcontroller. The controller 420 implements a BLE stack 460 for BLE operations and a mesh stack 454 for mesh operations. The transceiver 424 is also shown including hardware comprising digital logic 424b that can be used as an alternative to software 422a for implementing a disclosed speed switching for exploiting high-speed BLE-Mesh networks algorithm. As known in the art the transceiver 424 includes a transmitter and a receiver. The transmitter generally comprises a media access control (MAC) module, an encoder, a modulator, an Inverse Fast Fourier Transform (IFFT) unit, a digital to analog conversion (DAC)/filter module, and an RF/antenna module. The receiver generally comprises an RF/antenna unit, an analog to digital conversion (ADC)/filter unit, a FFT unit, a demodulator, a decoder, and a MAC module.
The memory 422 is more generally configured to store information including data, instructions, or both. The memory 422 may be any storage medium accessible by the controller 420, such as a read only memory (ROM), a random access memory (RAM), a register, cache memory, or magnetic media device such as internal hard disks and removable disks. A phase lock loop (PLL) 432 is also provided for purposes including mixing and frequency synthesis.
The controller 420 is coupled to the memory 422 and to the transceiver 424. In some implementations, the transceiver 424 comprises baseband units (not shown) and analog units (not shown) to transmit and receive RF signals. The baseband unit may comprise hardware to perform baseband signal processing including digital signal processing, coding and decoding, modulation, and demodulation. The analog unit may comprise hardware to perform ADC, DAC, filtering, gain adjusting, up-conversion, and down-conversion. The analog unit may receive RF signals from an access point and down-convert the received RF signals to baseband signals to be processed by the baseband unit, or receive baseband signals from the baseband unit and up-convert the received baseband signals to RF wireless signals for uplink transmission. The analog unit comprises a mixer to up-convert the baseband signals and down-convert the RF signals with a carrier signal oscillated at the radio frequencies of the BLE-mesh network. The higher-speed data rate utilized by the BLE-Mesh device 400 for higher-speed data rate communications may be in the 2.4 GHz to 2.483-GHz frequency band and the lower-speed data rate may in a frequency band in the range from 1.0 GHz to 1.5 GHz.
The Mesh adaptation layer 450 formats for BLE or Mesh accordingly and signals appropriate for the particular application. The RF driver 424a includes driver Application Programming Interface (API) software and the radio itself in hardware. There is also a flooding module 452, Mesh stack 454 including Mesh security, all for mesh communications. There is also a routing block 465 that is different from the flooding module-based mesh. If routing is present, then the routing block 465 at each node maintains neighbor tables and messages that are sent via deterministic paths to reach a specific destination. In a flooding-based mesh controlled by flooding module, messages are broadcast to all devices across the network over multiple hops.
BLE-Mesh device 400′ also includes a BLE stack 460. BLE stack 460 controls connections and advertising in Bluetooth, and describes how data is exchanged from two connected devices for BLE. BLE-Mesh device 400′ is also shown having a real-time operating system (RTOS) 470. RTOS 470 scales from a low-footprint, real-time preemptive multi-tasking kernel to a complete RTOS with additional middleware components including a power manager, TCP/IP and USB stacks, an embedded file system and device drivers.
Those skilled in the art to which this disclosure relates will appreciate that many other embodiments and variations of embodiments are possible within the scope of the claimed invention, and further additions, deletions, substitutions and modifications may be made to the described embodiments without departing from the scope of this disclosure.
This application and the subject matter disclosed herein claims the benefit of Provisional Application Ser. No. 62/328,387 entitled “Exploiting High-Speed in BLE-Mesh Systems” filed Apr. 27, 2016, which is herein incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
62328387 | Apr 2016 | US |