Multi-Hop LoRa Network Protocol with Minimized Latency
<p>Structure of the minimized latency Multi-hop LoRa network.</p> "> Figure 2
<p>Four timeslots in each cycle in the network construction period of the minimized latency Multi-hop LoRa network.</p> "> Figure 3
<p>N cycles in the network construction period.</p> "> Figure 4
<p>Packet collisions during the NCP. (<b>a</b>) Collision between JOIN packets, (<b>b</b>) Collision between INIT packets.</p> "> Figure 5
<p>An example network. (<b>a</b>) Network before NCP starts, (<b>b</b>) Network after NCP finishes.</p> "> Figure 6
<p>All the nodes’ operations in the NCP process for the example network in <a href="#energies-13-01368-f005" class="html-fig">Figure 5</a>.</p> "> Figure 7
<p>The collision avoidance mechanism. (<b>a</b>) Contention avoidance mechanism example with two nodes; (<b>b</b>) Symbol time (Tsym).</p> "> Figure 8
<p>Parent choice example.</p> "> Figure 9
<p>Data transmission before receiving the REDUCE command packet. (<b>a</b>) Data transmission in the UTC; (<b>b</b>) Data transmission in the DTC.</p> "> Figure 10
<p>Data transmission after receiving the REDUCE command packet. (<b>a</b>) Data transmission in UTC; (<b>b</b>) Data transmission in UTC.</p> "> Figure 11
<p>Addition of an NCP cycle in the data transmission structure after receiving an ADD command from the Sink Node. (<b>a</b>) Before receiving ADD command packet; (<b>b</b>) After receiving ADD command packet.</p> "> Figure 12
<p>Removing an NCP cycle from the data transmission structure after receiving the REMOVE_ADD command from the sink node. (<b>a</b>) Before receiving REMOVE_ADD command packet; (<b>b</b>) After receiving REMOVE_ADD command.</p> "> Figure 13
<p>Resynchronizing time between the child and parent nodes.</p> "> Figure 14
<p>Nodes deployment in the scenario. (<b>a</b>) Nodes deployed in the Scenario; (<b>b</b>) LoRa node prototype.</p> "> Figure 15
<p>Percentage of joined nodes during the NCP.</p> ">
Abstract
:1. Introduction
- DeAMON [9] and DiSCA [10] are distributed scheduling protocols for wireless sensor networks. They are not suitable when we apply them to LoRa because the time to transmit one packet in LoRa technology is much longer than other wireless sensor network technologies. A large number of packets are exchanged to assign timeslots and channels for all nodes in the network construction period; thus, the network construction period is long.
- PC-LLF [11] and CLLF [12] are centralized scheduling protocols for wireless sensor networks. In centralized scheduling, the sink node has to collect all the network information, then make the schedule and then forward this information to all the nodes in the network. A lot of packets are exchanged to assign a timeslot and channel for all nodes; thus, centralized scheduling is not suitable for LoRa protocols.
- The Multi-hop LoRa linear protocol [8] is of high reliability. However, it shows high latency because the number of timeslots in the slot frame in the data transmission equals the number of deployed nodes.
- SCSMA [13] has a contention-based design that eliminates collision from both hidden and neighbor nodes to improve throughput and reliability of data transmission. However, this protocol employs Request To Send (RTS) and Clear To Send (CTS) control messages; therefore, it is not suitable for very low bandwidths such as LoRa.
- SSMADBTC [14] is based on a slotted sense multiple access (SSMA) mechanism, in which a sharable slot is allocated to each tree level, and the nodes at the tree level compete to send data to their respective parents using Carrier Sense Multiple Access (CSMA) within the sharable slot. Data transmission is performed progressively, starting with the nodes at the highest level and proceeding to those at level 2 (the lowest sending level). However, this protocol employed RTS and CTS control messages; therefore, it is not suitable for very low bandwidths such as LoRa.
2. Background
2.1. Network and Protocol Model
2.2. Related Work
- The DeAMON [9] protocol is a distributed scheduling protocol for wireless sensor networks. These protocols contain three phases, namely, the tree construction period, building command period and signaling slot period. In the tree construction period, packets are exchanged between nodes to construct the tree; in the building command period, it starts from a sink node and the building command packet is exchanged to assign priority to all nodes. Finally, in the signaling slot period, this protocol exchanges a signaling slot packet to assign a timeslot and channel for all nodes in the network. Thus, in this protocol, a large number of packets are exchanged to assign a timeslot and channel for all nodes. It is not suitable when we apply it to LoRa because the time to transmit one packet in LoRa technology is much longer than other technologies in a wireless sensor network.
- SCSMA [13] is a contention-based protocol based on Carrier Sense Multiple Access with Collision Avoidance (CSMA/CA) that uses the RTS/CTS mechanism. First, this protocol uses blind learning (BL) to assign a start delay number (SDN) for all nodes in the network to eliminate collision from both hidden and neighbor nodes to improve throughput and reliability. Based on SDN, a node chooses the delay time to check the channel before transmitting the RTS packet to the receiver. The child and parent nodes exchange RTS/CTS packets before the child node transmits the data packet. Therefore, it is not suitable for very low bandwidths, such as LoRa.
- SSMADBTC [14] proposed an optimally balanced tree construction with distributed scheduling. First, the sink node transmits the Tree Construction Request (TCR) packet to start the protocol. After receiving the TCR packet, the receiver node updates the parent candidate list (PCL) and the level of this node. Based on the parent candidate list and the level of the node, each node calculates the delay time before transmitting the Join Request (JREQ) packet. In the delay time period, the node tries to overhear the JREQ packet; if the node overhears the JREQ packet, the node updates the PCL and the level of the node. When the delay time is up, the node transmits the JREQ packet to the parent node, which is chosen based on the PCL and the number of children. After receiving the JREQ packet, the parent node broadcasts the Acknowledgment (ACK) packet to assign the channel for the child node when the node transmits the data packet. If the child node receives the ACK packet, this node updates the channel to communicate to the parent node. When other nodes receive the ACK packet, they update the child list of the sender node. This process repeats until the tree construction period is finished. In Data transmission, data is transmitted from the highest level to the lowest level using CSMA/CA with the RTS/CTS mechanism. Therefore, it is not suitable for very low bandwidths such as LoRa.
- In the LoRaBlink [7] protocol, every node has to listen to a beacon to synchronize time in the beacon slot. When a node wants to transmit a data packet, the node transmits the packet to the parent node; then, the parent node forwards this packet until receiving the sink node. Thus, collisions can occur, which means it has low reliability, and all the nodes have to listen during every timeslot, incurring high power consumption.
- The LoRaWAN [6] protocol is applied to the star topology standardized by the LoRa Alliance. In LoRaWAN, the LoRa gateway nodes communicate directly with LoRa end devices. The LoRaWAN specifications define three types of nodes: classes A (Baseline), B (Beacon) and C (Continuous). In class A, each end-device transmits packets to the Gateway during certain periods. Then, the end-device opens two reception slots to receive the packet to which the Gateway transmits. Class B extends from class A by adding scheduled packet reception slots. After the BEACON_PERIOD time, the gateway uses the beacon packet to synchronize the time with the end-device nodes. In class C, end-devices continuously open receive windows, which are only closed when transmitting the packet; this results in high energy consumption. The disadvantage of this is that this protocol only applies to star topology and it has low reliability.
- The Multi-hop LoRa linear protocol [8] has a slot frame length equal to the number of deployed nodes in the data transmission period. Every node transmits a packet with a different timeslot. In the data transmission period, first, the leaf node transmits the data packet to the parent node. After receiving the data packet, the parent node combines its own data, then transmits that to its parent. This process repeats until the receiver node becomes a sink node. Although this protocol has high reliability, it shows high latency. Thus, this protocol is not suitable to apply to a wide area.
- DQ-LoRa [19] is a Medium Access Control (MAC) protocol based on a tree-splitting algorithm that extends from LoRaWAN [6] for star topology. First, in each frame, the end-device nodes compete to transmit Random Access Preamble (RAP) packet to the gateway. After that gateway broadcasts the feedback packet (FBP) to all end-devices, the value of two logical queues, Collision Resolution Queue (CRQ) and Data Transmission Queue (DTQ), is updated at end-devices. Based on the value of two logical queues, the DQ algorithm determines which end-devices node will transmit the data packet in the next frame. This process repeats until all nodes have transmitted the data packet successfully or until the Beacon (BCN) period finishes. This protocol does not resolve all collisions; however, it improves the throughput and saves the latency when it is compared with a pure Aloha system. The performance of the protocol depends on the number of end-devices and it only applies to star topology.
3. Minimized Latency Multi-hop LoRa Network Protocol
3.1. Minimized Latency Multi-hop LoRa’s Key Aspects
- Distributed Aggregation Scheduling: all the nodes in the network make the schedule without all network topology information; they only know their neighbor nodes’ information.
- Parallel Transmissions: the proposed protocol allows parallel non-conflicting transmission in the network. This approach reduces the latency in the network and minimizes the number of timeslots that are assigned to all the links in the network.
- Minimize Packet Size: in the proposed protocol, based on the choice of parent, the packet sizes at the nodes will be minimized.
3.2. Network Construction Period
3.3. Packet Collision Avoidance Mechanism
3.4. Timeslot and Channel Assignment
Algorithm 1: Timeslot and channel assignment |
|
3.5. Parent Choice Mechanism
- The node has the lowest depth.
- The node has the smallest number of children.
- The node has the latest timeslot assigned for communication with its parent node.
3.6. Data Transmission in the Proposed Protocol
3.7. Resynchronize Time Mechanism
- Time on Air:
- PL is the number of payload bytes
- SF is the spreading factor
- H = 0 when the header is enabled, and H = 1 when no header is present
- DE = 1 when low data rate optimization is enabled; DE = 0 when it is disabled
- CR is the coding rate from 1 to 4
- npreamble is the number of programmed preamble symbols
- Tsym =
4. Experiment Evaluation
5. Conclusions
Author Contributions
Funding
Conflicts of Interest
References
- Mekki, K.; Bajic, E.; Chaxel, F.; Meyer, F. A comparative study of LPWAN technologies for large-scale IoT deployment. ICT Express 2019, 5, 1–7. [Google Scholar] [CrossRef]
- LoRa. Available online: https://www.semtech.com/LoRa/what-is-LoRa (accessed on 2 March 2019).
- Zourmand, A.; Hing, A.L.K.; Hung, C.W.; AbdulRehman, M. Internet of Things (IoT) using LoRa technology. In Proceedings of the 2019 IEEE International Conference on Automatic Control and Intelligent Systems (I2CACIS), Shah Alam, Malaysia, 29 June 2019; pp. 324–330. [Google Scholar]
- Lavric, A. LoRa (Long-Range) High-Density Sensors for Internet of Things. J. Sens. 2019, 2019, 3502987. [Google Scholar] [CrossRef]
- Nguyen, T.T.; Oh, H. A receiver for resource-constrained wireless sensor devices to remove the effect of multipath fading. IEEE Trans. Ind. Electron. 2017, 65, 6009–6016. [Google Scholar] [CrossRef]
- LoRaWAN. Available online: https://LoRa-alliance.org/resource-hub/LoRawan-specification-v11 (accessed on 4 December 2018).
- Bor, M.; Vidler, J.E.; Roedig, U. Lora for the Internet of Things. In Proceedings of the 2016 International Conference on Embedded Wireless Systems and Networks (EWSN ’16), TU Graz, Styria, Austria, 15–17 February 2016; pp. 361–366. [Google Scholar]
- Duong, C.-T.; Kim, M.-K. Reliable Multi-Hop Linear Network Based on LoRa. Int. J. Control Autom. 2018, 11, 143–154. [Google Scholar] [CrossRef]
- Aijaz, A.; Raza, U. DeAMON: A decentralized adaptive multi-hop scheduling protocol for 6TiSCH wireless networks. IEEE Sens. J. 2017, 17, 6825–6836. [Google Scholar] [CrossRef]
- Soua, R.; Minet, P.; Livolant, E. DiSCA: A distributed scheduling for convergecast in multichannel wireless sensor networks. In Proceedings of the 2015 IFIP/IEEE International Symposium on Integrated Network Management (IM), Ottawa, ON, Canada, 11–15 May 2015; pp. 156–164. [Google Scholar]
- Darbandi, A.; Kim, M.K. Path Collision-aware Real-time Link Scheduling for TSCH Wireless Networks. KSII Trans. Internet Inf. Syst. 2019, 13, 4429–4445. [Google Scholar]
- Saifullah, A.; Xu, Y.; Lu, C.; Chen, Y. Real-Time Scheduling for WirelessHART Networks. In Proceedings of the 2010 31st IEEE Real-Time Systems Symposium, San Diego, CA, USA, 30 November–3 December 2010; pp. 150–159. [Google Scholar]
- Nguyen, T.T.; Oh, H. SCSMA: A Smart CSMA/CA Using Blind Learning for Wireless Sensor Networks. IEEE Trans. Ind. Electron. 2019. [Google Scholar] [CrossRef]
- Nguyen, T.T.; Oh, H. Constructing an optimally balanced tree to maximize data throughput with multiple channels. Wirel. Netw. 2018, 24, 993–1005. [Google Scholar] [CrossRef]
- Gao, Y.; Li, X.; Li, J.; Gao, Y. Distributed and Efficient Minimum-Latency Data Aggregation Scheduling for Multichannel Wireless Sensor Networks. IEEE Internet Things J. 2019, 6, 8482–8495. [Google Scholar] [CrossRef]
- Zhao, M.; Kumar, A.; Chong, P.H.J.; Lu, R. A reliable and energy-efficient opportunistic routing protocol for dense lossy networks. IEEE Wirel. Commun. Lett. 2016, 6, 26–29. [Google Scholar] [CrossRef]
- Lavric, A.; Petrariu, A.I.; Popa, V. Long range sigfox communication protocol scalability analysis under large-scale, high-density conditions. IEEE Access 2019, 7, 35816–35825. [Google Scholar] [CrossRef]
- Ikpehai, A.; Adebisi, B.; Rabie, K.M.; Anoh, K.; Ande, R.E.; Hammoudeh, M.; Gacanin, H.; Mbanaso, U.M. Low-power wide area network technologies for internet-of-things: A comparative review. IEEE Internet Things J. 2018, 6, 2225–2240. [Google Scholar] [CrossRef] [Green Version]
- Wu, W.; Li, Y.; Zhang, Y.; Wang, B.; Wang, W. Distributed Queueing Based Random Access Protocol for LoRa Networks. IEEE Internet Things J. 2019, 7, 763–772. [Google Scholar] [CrossRef]
- Semtech Transceiver SX1272 Datasheet. Available online: https://semtech.my.salesforce.com/sfc/p/#E0000000JelG/a/440000001NCE/v_VBhk1IolDgxwwnOpcS_vTFxPfSEPQbuneK3mWsXlU (accessed on 10 March 2020).
- MultiTech mDot Module. Available online: https://www.multitech.com/documents/publications/data-sheets/86002171.pdf (accessed on 10 March 2020).
- Liao, C.-H.; Zhu, G.; Kuwabara, D.; Suzuki, M.; Morikawa, H. Multi-hop LoRa networks enabled by concurrent transmission. IEEE Access 2017, 5, 21430–21446. [Google Scholar] [CrossRef]
Node | P | D | Cd | UC | ||||
---|---|---|---|---|---|---|---|---|
Before NCP | After NCP | Before NCP | After NCP | Before NCP | After NCP | Before NCP | After NCP | |
S | NULL | NULL | 0 | 0 | Empty | (B, Ch0, T5), (A, Ch0, T4) | Empty | (Ch1, T4), (Ch0, T3), (Ch1, T3) |
A | NULL | (S, Ch0, T4) | −1 | 1 | Empty | (D, Ch1, T3) | Empty | (Ch0, T5), (Ch1, T4), (Ch0, T3) |
B | NULL | (S, Ch0, T5) | −1 | 1 | Empty | (C, Ch0, T3) (E, Ch1, T4) | Empty | (Ch0, T4), (Ch1, T3) |
C | NULL | (B, Ch0, T3) | −1 | 2 | Empty | Empty | Empty | (Ch0, T5), (Ch0, T4), (Ch1, T4), (Ch1,T3) |
D | NULL | (A, Ch1, T3) | −1 | 2 | Empty | Empty | Empty | (Ch0, T4), (Ch0, T3) |
E | NULL | (B, Ch1, T4) | −1 | 2 | Empty | Empty | Empty | (Ch0, T5), (Ch0, T3) |
Number of Deployed Nodes | 16 | Coding Rate (CR) | CR 4/5 |
Bandwidth (BW) | 125 kHz | Preamble length | 8 symbols |
Transmission Power | 0 dBm | Header mode | explicit |
CRC | enable | Spreading factor | SF7 |
Max Depth | 4 | Number of UTCs in the UTP | 50 |
Number of Nodes | Maximum Children: 2 | Maximum Children: 3 |
---|---|---|
Number of used timeslots | Number of used timeslots | |
6 | 3 | 3 |
11 | 5 | 4 |
16 | 6 | 6 |
Number of Nodes | Maximum Children: 2 | Maximum Children: 3 |
---|---|---|
E2E delay average | E2E delay average | |
6 | 1.2 | 1.2 |
11 | 2 | 2.1 |
16 | 2.6 | 2.4 |
© 2020 by the authors. Licensee MDPI, Basel, Switzerland. This article is an open access article distributed under the terms and conditions of the Creative Commons Attribution (CC BY) license (http://creativecommons.org/licenses/by/4.0/).
Share and Cite
Mai, D.L.; Kim, M.K. Multi-Hop LoRa Network Protocol with Minimized Latency. Energies 2020, 13, 1368. https://doi.org/10.3390/en13061368
Mai DL, Kim MK. Multi-Hop LoRa Network Protocol with Minimized Latency. Energies. 2020; 13(6):1368. https://doi.org/10.3390/en13061368
Chicago/Turabian StyleMai, Dinh Loc, and Myung Kyun Kim. 2020. "Multi-Hop LoRa Network Protocol with Minimized Latency" Energies 13, no. 6: 1368. https://doi.org/10.3390/en13061368
APA StyleMai, D. L., & Kim, M. K. (2020). Multi-Hop LoRa Network Protocol with Minimized Latency. Energies, 13(6), 1368. https://doi.org/10.3390/en13061368