1. Introduction
LoRa (long range), proposed by Semtech, employs chirp spread spectrum technology. In low-power wide area networks (LPWAN), LoRa offers advantages such as low power consumption, long transmission distance, strong anti-interference capability, and high network capacity [
1]. LoRaWAN, built on LoRa technology, is suitable for a variety of remote IoT applications. Since end devices are often deployed in environments that are difficult to maintain and rely on battery power, they need to operate in a low-power state for extended periods to prolong battery life.
The physical layer of LoRa technology employs specific modulation and coding schemes [
2,
3], allowing devices to select an appropriate data transmission rate based on the scenario. The data rate is adjusted by configuring the spreading factor (SF) and bandwidth (BW), and signals with different SFs do not interfere with each other. Gateways in a LoRa network can simultaneously demodulate LoRa signals with different SFs and BWs. LoRaWAN (long range wide area network), an open standard maintained by the LoRa Alliance, operates as an MAC layer protocol on top of LoRa and is designed to handle traffic from large numbers of low-power devices. LoRa technology is widely used in applications such as smart homes, precision agriculture [
4,
5], smart metering, and remote healthcare [
6,
7], favored for its low cost, long transmission distance, ease of deployment, and excellent scalability. Its chirp spread spectrum modulation technology allows flexible adjustment of the data rate, achieving wide coverage and low power consumption.
In practical operation, the link of a LoRa network is affected by the low power consumption of EDs and environmental factors. The communication link is unstable and time-varying, requiring an evaluation and optimization of link stability. Since Class A EDs in LoRa networks use the ALOHA scheme for transmission, a fixed data rate cannot guarantee optimal network performance. The typical architecture of a LoRaWAN network includes end devices (EDs), gateways (GWs), network server (NS), and application server (AS), as shown in
Figure 1. The GW and EDs use a star topology, where the ED transmits data to the GW using LoRa modulation. The GW forwards the data to the NS, which processes the data and sends them to the application server. The GW is responsible only for data forwarding and does not participate in data processing.
Most existing adaptive data rate (ADR) algorithms are based on the LoRaWAN architecture, primarily operating on the NS side and typically optimizing only the uplink communication link of EDs or certain aspects of network performance [
8]. To address this limitation, this paper first establishes an evaluation model for the stability and reliability of the communication link. Then, based on the characteristics of data transmission from EDs in a LoRa network, models for ED power consumption, network throughput, and ED latency are constructed. Based on these models, an ADR algorithm is proposed that optimizes overall network performance based on the communication link state. Through a two-level optimization—link state and network performance—the algorithm aims to reduce ED power consumption while improving network performance.
The remainder of this paper is organized as follows.
Section 2 reviews the current research on ADR algorithms for LoRa networks.
Section 3 constructs a link state evaluation model using the weighted combination method based on the characteristics of LoRa communication links.
Section 4 determines the performance evaluation methods for LoRa networks by establishing models for network throughput, average power consumption of EDs, and average latency of EDs.
Section 5 introduces the algorithm for obtaining selectable parameters for EDs based on link state and the ADR control method based on network performance optimization.
Section 6 presents the verification and analysis of the algorithm.
Section 7 summarizes the paper and describes future work to be carried out.
2. Related Work
The ADR algorithm in LoRaWAN [
9,
10] dynamically allocates the transmission rate of EDs based on network conditions to reduce power consumption and enhance network capacity and stability. ADR algorithm consists of two main mechanisms: on the ED side, the data rate is lowered to increase communication range and ensure connectivity with the GW; on the network server side, the data rate and transmission power are adjusted according to the maximum signal-to-noise ratio (SNR) of each packet, thereby reducing the power consumption of the EDs. This algorithm analyzes the link status of the EDs and flexibly adjusts communication parameters to ensure communication robustness and reliability.
In further optimizing the ADR mechanism, M. Slabicki et al. proposed the ADR+ algorithm [
11], which uses the average SNR of the most recent 20 packets instead of the maximum SNR value, improving performance under unstable link conditions. This allows the ED to maintain better communication quality even in fluctuating channel conditions. Abdelfadeel proposed the FADR algorithm [
12], which allocates the spreading factor and transmission power based on RSSI to achieve fairness between EDs and reduce collisions. However, FADR has limitations in network scalability, as the addition or removal of nodes affects fairness, limiting its application in large-scale networks.
In addition, Davide et al. proposed the I-SFA algorithm [
13], focusing on addressing channel variations by adjusting fixed spreading factors. While effective initially, it lacks the ability to adaptively adjust the data rate, resulting in inadequate performance in dynamic environments. In contrast, Riccardo et al. proposed the CA-ADR algorithm [
14], which reduces collision probability during data transmission by considering the distribution of all EDs, improving packet success rate and network throughput, particularly in large, dense networks. This algorithm reduces conflicts between nodes by assigning different spreading factors and further optimizes data rates through collision awareness.
Zhou et al. proposed the DRCC algorithm [
15], which dynamically adjusts data rates and channel control to support large-scale ED deployments. The algorithm can evaluate channel conditions in real time and reduce collisions through multichannel load balancing, thereby improving network throughput and reducing latency, making it ideal for dense ED scenarios. Sandoval et al. [
16] employed a reinforcement learning method to maximize ED throughput. Although highly scalable, the algorithm’s complexity is high, and it does not adequately address the power consumption of EDs, limiting its effectiveness in practical applications.
Zhao et al. proposed the EF-LoRa algorithm [
17], which enhances energy fairness among EDs (EDs) and extends network lifetime by optimizing spreading factors, transmission power, and channel allocation. The algorithm employs a max–min fairness model and uses a greedy algorithm for resource allocation, demonstrating significant advantages in large-scale network simulations. However, the algorithm struggles with dynamic network changes and may lead to performance fluctuations in large-scale networks. Additionally, the algorithm lacks granularity in ED resource allocation, preventing real-time adaptive adjustments, which could result in delays in resource distribution.
Pang et al. [
18] introduced a channel quality rating and prediction method that incorporates the concept of channel quality scores, offering a more precise evaluation of link quality compared to packet reception rate (PRR). This method uses a gated recurrent unit (GRU) algorithm to build a channel quality rating model, classifying EDs based on their current channel quality scores and spatial channel parameters (SCPs). While this approach improves evaluation accuracy, its complexity can lead to prediction biases. Additionally, the method faces challenges in real-time performance and environmental adaptability.
Park et al. [
19] proposed the EARN mechanism, an enhanced ADR algorithm that adapts coding rate (CR) based on the capture effect, optimizing data transmission success rate and energy consumption. Although EARN improves energy efficiency, its focus is primarily on uplink communication, lacking system-level optimization for the entire LoRa network. Gabriel et al. [
20] introduced the ADRx adaptive data rate algorithm, which dynamically adjusts link margin values in real time to overcome the limitations of traditional ADR in estimating channel quality, thus improving data extraction rate (DER) and energy efficiency. By dynamically adjusting ED data rates, ADRx optimizes ED power consumption while also enhancing overall network performance.
Jiang et al. [
21] applied the ordinary kriging (OK) function to analyze the spatiotemporal correlation of signal-to-noise ratio (SNR) across different time points, proposing the K-ADR algorithm. This algorithm accurately detects changes in link conditions and predicts future link status in real time, improving ADR performance under challenging channel conditions. However, as overall channel conditions deteriorate, the packet delivery rate advantage of K-ADR diminishes, though improvements in ED energy consumption are still observed.
Lodhi et al. [
22] proposed the ND-ADR algorithm, which dynamically adjusts link parameters by combining RSSI and SNR values. This algorithm provides a more accurate assessment of communication quality and dynamically adjusts network parameters, improving communication reliability in harsh environments and reducing power consumption.
In terms of physical layer optimization, Xia et al. proposed the XCopy algorithm [
23], which improves SNR by repeatedly retransmitting weak signals and coherently accumulating them, providing more than 10 dB of gain in low-SNR environments. This makes communication more reliable, particularly for EDs in harsh conditions. Sun et al. [
24] introduced the FLoRa algorithm, which improves the energy efficiency and reliability of firmware updates over-the-air (FUOTA) in LoRa networks through incremental updates, channel coding, and beamforming techniques. This effectively addresses the low energy efficiency and unreliable transmission issues in traditional FUOTA. Hou et al. [
25] proposed the one-shot method, which aggregates data from multiple nodes, significantly improving transmission accuracy and efficiency, especially in large-scale LoRa networks.
Although these physical layer optimization algorithms perform well in improving communication reliability and energy efficiency, they also increase the hardware cost for EDs. In contrast, ADR algorithms flexibly adjust ED parameters, leveraging LoRa’s features to optimize link connectivity and network performance.
Table 1 compares the different algorithms, listing their optimization approaches and objectives.
5. Adaptive Data Rate Algorithm Design
LoRaWAN leverages the advantages of the LoRa physical layer by optimizing the communication performance of EDs through adjusting data rates (i.e., LoRaWAN ADR). In actual network deployments, adjusting the data rate requires balancing communication quality and network performance. When the environment where the ED operates is subject to interference, communication quality should be prioritized. Additionally, since LoRa networks use the pure ALOHA protocol, data rate allocation must also consider network performance optimization. A new ADR algorithm based on link state and network performance optimization is proposed. Based on the link state, the transmission power and a list of selectable data rates are first determined, followed by the optimal data rate allocation in combination with network optimization.
Figure 9 shows the overall flowchart for designing the adaptive data rate algorithm.
5.1. ED Optional Parameter Acquisition Algorithm Based on Link State
The ED optional parameter acquisition algorithm based on the link state determines the selectable data rate for the current ED based on the link state score. Every time the ED sends 20 data packets, it is considered a statistical window, during which the values of SNR, RSSI, and PRR are recorded. The link state score is calculated according to the link state evaluation method described in
Section 3.
The inputs to the algorithm include the ED’s current data rate, transmission power combination, and link state score. First, the calculation methods for SNR margin
and link budget
are clarified. The formulas are given as Equation (
40).
where
and
represent the average SNR and RSSI of the received packets within the window, respectively;
represents the minimum demodulation SNR for the current ED’s SF, with the corresponding relationship between SF and minimum demodulation SNR shown in
Table 7;
represents the receiver sensitivity under the ED’s current communication parameters; and
and
represent the extra margins for two margins. The calculations for
and
are given as Equation (
41).
where
represents the current ED’s link state score, which measures the reliability and stability of the communication. When the link state score is low, both
and
take larger values, as the link stability is poor and adjustments to the data rate should be more conservative. Conversely, when the link state score is high, both
and
take smaller values.
Table 8 provides the description of each parameter in Algorithm 1. The detailed process of the ED optional parameter acquisition algorithm based on link state awareness is shown in Algorithm 1.
Algorithm 1 End device optional parameter acquisition algorithm based on link state. |
Input: , , , score, , , Output: , , list(SF), list(BW) , , , , list(SF) = [], list(BW) = [] , if
then while and do , dB, end while while and do dB, dB, end while else if then while and do dB, dB, end while while and do , dB, end while end if end if if
then while dB and do , dB end while else while dB and do , dB end while end if while
do append to list(BW), end while Return: , , list(BW), list(SF)
|
Algorithm 1 outlines the basic steps of the ED optional parameter acquisition algorithm based on link state. The specific process is as follows: First, based on the obtained SNR margin, the sufficiency of link resources is determined. When there is redundancy in the link resources, the SF is reduced to increase the data rate or the transmission power is lowered to reduce power consumption. When the link resources are insufficient, the transmission power is increased to improve the signal quality or the SF is increased to reduce the data rate. Additionally, when the theoretical link budget is large, the BW is increased to improve the data rate; when the theoretical link budget is small, the BW is reduced to lower the data rate. Based on the values of the SNR margin and theoretical link budget , the algorithm outputs a selectable list of transmission power and data rate under the premise of maintaining the communication reachability of the ED.
5.2. Adaptive Data Rate Control Algorithm Based on Network Performance Optimization
The goal of network performance optimization is to allocate a data rate to each ED to maximize the network performance score and achieve optimal network performance. During the optimization process, it is essential to ensure the communication link quality between each ED and the GW. The optimal data rate must fall within the range of selectable data rates and other communication parameters determined by Algorithm 1. Additionally, the characteristics of the receiver and other relevant constraints must also be considered.
5.2.1. Zebra Optimization Algorithm
The Zebra Optimization Algorithm (ZOA) is a metaheuristic algorithm that solves optimization problems by simulating the foraging and defensive behaviors of zebras, searching for the global optimal solution from an initial solution [
38,
39]. Zebras rely on keen perception and swift running while foraging and evading predators. The algorithm includes foraging behavior and defensive behavior, and the basic steps are as follows:
Step 1: Initialization phase. An initial population of zebras (candidate solutions) is generated within the search space, where each zebra represents a potential solution.
Step 2: Foraging phase. The positions of the population are updated through foraging behavior. In this phase, the best member of the population (the lead zebra) guides the other members toward its position. The position update is represented by Equations (
42) and (
43).
Equation (
42),
represents the new position of the
i-th zebra in the
j-th dimension, and
represents the current position of the
i-th zebra in the
j-th dimension.
r is a random number within the range
, introducing randomness.
represents the position of the lead zebra (current optimal solution) in the
j-th dimension, while
I is a binary number that indicates the update strength, typically 0 or 1. Equation (
43),
represents the current position of the
i-th zebra, and
is the updated position of the
i-th zebra in foraging mode. If the fitness value
of the updated position is better than the current fitness value
, the position is updated to
; otherwise, the position remains unchanged.
Step 3: Defense phase. This phase simulates the defensive actions of zebras to update the position of each member. When a zebra is attacked by its natural predator, the lion, its position is updated using
in Equation (
44). When it is attacked by other predators (non-natural enemies), its position is updated using
in Equation (
44). The final update of the position is achieved using Equation (
45).
Equation (
44),
represents the updated value of the
i-th zebra in the
j-th dimension in defense mode. Here,
denotes the current position of the
i-th zebra in the
j-th dimension;
is a randomly generated probability in the range
;
and
are adaptive scaling factors used to adjust the search range;
R is a constant typically set to 2.5;
r is a random number in the range
;
t and
T represent the current iteration count and the maximum number of iterations, respectively;
represents the position of the lead zebra in the
j-th dimension; and
I is a constant used for adjustment. Equation (
45),
represents the updated position of the
i-th zebra. If the fitness value
of the updated position is better than the current fitness value
, the position
is updated to
; otherwise, the position remains unchanged.
5.2.2. Adaptive Data Rate Algorithm for Network Performance Optimization
The main factors affecting network performance are the number of different data rates and the number of EDs using the same data rate. As the receiver of data from LoRa EDs, the GW can simultaneously demodulate LoRa signals with different data rates without interference. However, most GWs can demodulate a maximum of eight different data rates at the same time, which serves as a constraint for network performance optimization. Using the optional communication parameters for each ED obtained in Algorithm 1 as constraints, the implementation of the network performance optimization algorithm becomes a solution to an engineering optimization problem.
Assuming there are
n EDs in the network and different data rates, the selectable transmission power for each ED obtained through Algorithm 1 is
, the selectable SF list is
, and the selectable BW list is
. The number of EDs using data rate
is
. The optimization objective of this problem is to maximize the network performance score
, and this optimization problem is represented by Equation (
46).
Table 9 describes each parameter used in the algorithm, and the algorithm flow of the network performance optimization algorithm is shown in Algorithm 2.
Algorithm 2 is an ADR algorithm based on network performance optimization, with the goal of obtaining the optimal transmission parameter combination for each ED in the network. The specific steps of the algorithm are as follows:
First, the algorithm takes each ED’s
,
, and
as inputs, and selects the minimum SF and maximum BW to generate the initial configuration. Based on these initial configurations, the algorithm calculates the network performance score, including the average power consumption of the EDs, network throughput, and average latency of the EDs. Next, the algorithm generates an initial set of candidate solutions through the initialize_population() function, where each solution contains different ED configuration combinations.
Algorithm 2 Adaptive data rate algorithm for network performance optimization. |
Input: , where Output:
, for each do , append to if then end if end for for to do if then for each terminal in Zebra_population do , end for else for each terminal in Zebra_population do end for end if if then if and then end if end if end for Return:
|
During the iterative process, the zebra population is updated using random probabilities and adjustment values. The selection method involves either randomly generating new configurations or adjusting based on the current best solution. For each updated configuration, the algorithm recalculates the network performance score. If the new score is higher than the current best score and meets the constraints (such as the maximum number of ED data rate combinations and the total number of EDs), the best score and configuration are updated. When the maximum number of iterations is reached or the optimal configuration is found, the algorithm returns . Through this process, the algorithm gradually finds the optimal ED configuration combination in the complex search space, thereby improving overall network performance.
6. Testing and Result Analysis
To test the proposed ADR algorithm, this section designs an experimental scenario to verify the effectiveness of the algorithm from two perspectives: link state and network performance, assessing its performance in real-world applications. The experiment aims to determine whether the algorithm can effectively improve both link state and network performance. To ensure the accuracy of the results, the experiment was conducted in a real-world environment, testing multiple network performance metrics, including PRR, network throughput, average power consumption of the EDs, and average latency of the EDs. The experiment also compared the performance of this algorithm with the I-SFA scheme mentioned in [
13], the LoRaWAN ADR algorithm, and the ADR+ algorithm.
6.1. Construction of LoRa Network
6.1.1. GW Hardware Design
The LoRa GW plays a key role in the LoRa network by serving as a protocol converter, responsible for converting IP packets from the network server into LoRa signals to be sent to the EDs and encapsulating the LoRa packets from the EDs into IP packets for upload to the network server. It mainly handles the forwarding of uplink and downlink messages, connecting LoRa EDs and the network server. Due to varying deployment environments, the GW needs to possess multiple networking capabilities, such as using Ethernet or Wi-Fi in urban areas, while relying on 3G/4G network connections in rural or outdoor settings. Additionally, the GW must support remote debugging and OTA (over-the-air) upgrades, and provide a certain level of computing power to support edge computing, thereby alleviating the burden on the network server.
In terms of hardware, the GW uses the MediaTek MT7620A (manufactured by MediaTek Inc., Hsinchu, Taiwan) as the main control chip, which not only has strong computing capabilities but also supports the OpenWRT system for easier development. The RF section employs a four-channel MCU + SX1262 unit instead of Semtech’s SX1301 chip, reducing costs while supporting bandwidth adjustment. To meet network demands, the system is designed to operate with two GWs working in coordination, with each GW equipped with four antennas, collectively achieving a configuration of eight antennas. Each RF unit is controlled by the main control chip through USB-extended serial ports and driven by the MCU to operate the SX1262. The GW also includes a 4G module for wireless access, LAN and WAN ports for Ethernet connections, and a Wi-Fi module for client access.
Figure 10 shows the schematic diagram of the GW hardware architecture;
Figure 11 displays the physical image of the GW.
6.1.2. ED Hardware Design
In the LoRa network, the EDs are critical components responsible for collecting sensor data and transmitting them to the gateway. The hardware design needs to support multiple sensor interfaces to accommodate different types of sensors while considering low power consumption requirements. To meet these demands, the STM32F103RCT6 was selected as the microcontroller (MCU), paired with Semtech’s SX1262 chip as the LoRa communication module. The SX1262 chip features higher transmission power, smaller packaging, and lower power consumption, making it highly suitable for low-power EDs.
For the power supply design, an AC–DC conversion chip was employed, supporting both 5 V or 3.3 V DC input and AC power supply options. Additionally, the ED is equipped with an SMA RF interface, connecting to the antenna via an SMA to IPEX RF cable for the transmission of LoRa signals. This design ensures reliable communication for EDs across various application scenarios.
Figure 12 shows the structural diagram of the ED hardware module, while
Figure 13 displays the physical image of the ED.
6.1.3. NS Design and Implementation
The NS is the core of the entire LoRa network, responsible for managing all devices and meeting various application service requirements. The NS designed for this study is developed using Java and deployed on an Alibaba Cloud Ubuntu 20.04 operating system. It utilizes Docker technology to package the relevant environment and server program into a Docker image, simplifying the deployment process and enabling easy migration to different platforms.
The architecture of the NS is based on the Spring Boot, MyBatis, and Netty frameworks to enhance system scalability. The front end uses the React framework and adopts a separation of front-end and back-end design to ensure low coupling. The back-end program is quickly built using Spring Boot, which simplifies the coding, deployment, and configuration processes. Additionally, MyBatis is used as the persistence layer framework, significantly reducing the complexity of SQL connection queries and storage procedures.
Given that the NS needs to support concurrent connections from multiple gateways and devices, the Netty framework is employed to build TCP/UDP network applications, enabling it to handle large-scale, high-concurrency connections among network devices, thereby ensuring network stability and efficiency.
Figure 14 shows the functional design of the NS.
6.2. Single ED Communication Link Testing Scenario
In this test scenario, the GW was deployed on the roof of a 20 m high building, while the ED was located on a floor inside the same building, with a straight-line distance of 50 m between them. The deployment diagram of the ED and GW is shown in
Figure 15. The initial communication parameters of the ED are shown in
Table 10, configured with a 500 kHz modulation BW and SF 7. The node generates one 20-byte data packet per second.
The position of the GW is fixed, while the EDs select suitable locations within the given distances for testing in a campus environment, such as inside buildings (50 m), on the playground (300 m), at the north gate (500 m), and in the northeast corner of the campus (1000 m). This scenario aims to test the optimization effects on the link performance of a single ED and compare the impact on PRR among I-SFA, LoRaWAN ADR, ADR+, and the algorithm proposed in this paper over a period of 3600 s.
Figure 16 shows the variation of PRR over 3600 s for four adaptive data rate adjustment schemes under a single ED communication link at different testing distances, while
Figure 17 compares the average PRR at four distances. The test results indicate that the proposed algorithm maintains a PRR of over 90% across all testing distances, with its advantages becoming increasingly apparent as the distance increases. Inside the building environment (50 m), the proposed algorithm is able to maintain a reliable link performance despite the link fluctuations caused by building shading and people walking around. At a distance of 1000 m, the PRR of the proposed algorithm improves by 20% compared to the standard LoRaWAN ADR algorithm.
Although the ADR+ algorithm shows performance improvements over the standard LoRaWAN ADR algorithm, it still has limitations compared to the proposed algorithm. The I-SFA scheme primarily allocates the spreading factor during the initial phase at the ED, configured according to the sensitivity of the gateway, but does not consider the reliability and stability of the link, nor does it possess the ability to adaptively adjust the spreading factor. The standard ADR scheme uses the maximum SNR within a fixed time window to assess link status, while the ADR+ scheme employs the average SNR. However, both schemes inadequately assess the stability of the link, failing to effectively address short-term fluctuations in link status, resulting in limited improvements in packet reception rates.
In contrast, the proposed algorithm evaluates the link state from both stability and reliability perspectives, taking into account factors such as average SNR, average signal strength, PRR, SNR variance, and signal strength variance. This multidimensional assessment method provides a more accurate judgment of link conditions, allowing the algorithm to demonstrate significant advantages in long-distance communication.
6.3. Multi-ED Network Performance Testing Scenario
The GW is deployed on the roof of a 20 m high building, with 50 EDs distributed around the GW in campus and urban environments.
Table 11 shows the initial communication parameter configuration of the EDs in the network.
Figure 18 illustrates the distribution of the GW and EDs in the LoRa network.
This experimental scenario is used to test the proposed algorithm’s optimization of network throughput, average energy consumption of EDs, and average latency of EDs in the LoRa network, and compares the network performance with the I-SFA scheme, LoRaWAN ADR, and ADR+ algorithms.
Figure 19 shows the actual deployment environment of the EDs and the GW.
The results show the number of EDs corresponding to different data rates, as calculated by the NS after the algorithm has been completed. According to the algorithm’s results, EDs that are closer to the GW and have better link quality are preferentially assigned higher data rates, thereby minimizing the use of lower data rates while ensuring communication reachability. There are 17 end devices (EDs) operating with the combination of spreading factor (SF) 7 and bandwidth (BW) 500, while 4 EDs use SF 7 and BW 250. For the combination of SF 8 and BW 500, 10 EDs are in operation, and 4 EDs use SF 9 and BW 500. Additionally, 5 EDs operate with SF 10 and BW 250, and 3 EDs use SF 11 and BW 500. Finally, 5 EDs correspond to the combination of SF 12 and BW 500, and 2 EDs use SF 12 and BW 125. To optimize network performance and reduce ED power consumption, a larger number of EDs are assigned higher data rates, while fewer devices are assigned lower data rates. This reduces the probability of packet collisions during transmission.
At the beginning of network operation, all EDs work at the lowest data rate, generating a 20-byte data packet every 20 s.
Figure 20 shows a comparison of the average power consumption of EDs under four different ADR algorithms. The results indicate that the proposed algorithm reduces the average power consumption of EDs by 15.9% compared to the I-SFA scheme; in contrast, the LoRaWAN ADR algorithm and the ADR+ algorithm reduce power consumption by 6.2% and 11.3%, respectively. This advantage arises from the comprehensive evaluation of the link state in the proposed algorithm, which determines the optimal data rate for each ED, thereby effectively reducing power consumption. The I-SFA scheme, on the other hand, assigns SFs based solely on RSSI without optimizing power consumption. The LoRaWAN ADR and ADR+ algorithms rely on partial statistical information, causing EDs to tend to use faster data rates, which increases the probability of packet collisions and, consequently, the average power consumption of the EDs.
Figure 21 shows a comparison of network throughput and average latency of EDs for four different ADR algorithms. The results indicate that the proposed algorithm significantly increases the network throughput corresponding to the data rates of EDs, surpassing the I-SFA scheme and outperforming the LoRaWAN ADR algorithm and the ADR+ algorithm. At the same time, the average latency of the EDs under the proposed ADR algorithm is slightly lower than that of the other three algorithms. This is primarily due to the proposed algorithm’s link state awareness, which obtains the transmission power and a list of selectable data rates for each ED, optimizing the stability and reliability of communication links. To further optimize network performance metrics, the algorithm continuously adjusts the data rates of the EDs, ultimately finding a set of optimal data rate combinations that minimize packet collision probability, maximize network throughput, and minimize average latency. By comprehensively considering the link state of the EDs and network performance, the algorithm minimizes average power consumption while maximizing network throughput and minimizing average latency.
6.4. Algorithm Complexity Analysis
On a standard server equipped with a 2.4 GHz CPU and 8 GB of memory, the execution time of the algorithm can be divided into two parts. First, the transmission power and selectable data rate list for each ED are extracted based on the link state, with the algorithm’s complexity being. The runtime for a single ED is 8.012 ms, which includes saving the relevant information. Second, based on the selectable communication parameters of the EDs in the network, the data rate required to achieve optimal network performance for each ED is calculated, with the complexity increasing as the number of EDs in the network grows. In a scenario with 50 EDs and 500 iterations, the total execution time of the algorithm is 0.95 s. This demonstrates that the algorithm can meet application requirements.
7. Conclusions and Future Work
This paper proposes an ADR algorithm specifically designed for LoRa networks with EDs constrained by limited power in actual deployments. First, based on link state awareness, the algorithm assesses the transmission power and optional data rate list for each ED in the network. Second, considering network throughput, average ED power consumption, and average ED delay, an optimization model is established to determine the objective function for network performance enhancement, leading to the design of an algorithm capable of adaptively adjusting the data rate. Finally, the proposed algorithm is validated in a deployed LoRa network.
The proposed ADR algorithm achieves adaptability in static ED scenarios through link state awareness and dynamic adjustments. Specifically, the algorithm dynamically selects appropriate transmission power and data rates by real-time evaluation of link states such as SNR and RSSI. This effectively addresses fluctuations in channel quality, interference, and changes in network topology, ensuring optimal communication performance across various scenarios. The proposed algorithm, based on real-time monitoring and parameter adjustment, demonstrates adaptability in multiple scenarios, including static and dynamic node deployments and variations in network density. Additionally, by integrating ED power consumption, network throughput, and delay models, the algorithm can flexibly optimize communication parameters to enhance overall network performance.
In future work, the LoRa communication characteristics inside the building environment can be explored, while by combining with techniques such as transfer learning or few-shot learning, the flexibility and adaptive capability of the system can be further enhanced, especially when facing brand new scenarios or environments with sparse business data; the system will be able to adapt faster to different deployment environments or new network conditions, and utilize a small amount of data for rapid learning and adjustment,. This further enhances the system’s adaptive capability.