1. Introduction
The long-range wide-area network (LoRaWAN) has been prominent among many wireless communication technologies due to its simple architecture and the utilization of unlicensed Industrial Scientific and Medical (ISM) bands [
1]. Furthermore, LoRaWAN has a number of advantages: low cost, low power, and long-range transmission distance, which enable the supply of the wide area for several years. In LoRaWAN, the spreading factor (SF) and the transmission power (TP) of the LoRa end nodes are controlled by the adaptive-data-rate (ADR) mechanism [
2]. Based on the channel condition, the ADR algorithm updates SF to determine the appropriate data rate and transmission power to guarantee that the LoRa node achieves successful transmission with low energy consumption. The orthogonality of different SFs leads to an increase in the number of nodes in a single-cell network [
3]. Several works proposed algorithms to allocate the SFs and TP, using a diverse set of parameters, including the estimation of a channel state similar to the ADR mechanism. In this article, the ADR+ algorithm, which has been implemented by the FLoRa module and was introduced in [
4], was improved. Following a rigorous experimental evaluation of ADR and ADR+, we observe that both algorithms at the network server (NS) have improved the link budget based on the channel condition of an individual node. The updates of SF and TP in the ADR algorithm were improved based on the maximum value of SNR of the last 20 frames, while the ADR algorithm was based on the average SNR of those frames in the ADR+ algorithm. In addition, most of the previous studies focused on the enhancement ADR and ADR+ for the individual node but did not take into consideration the overall energy consumption of all the LoRa nodes. Thus, we introduced a novel approach to improve the packet delivery ratio and energy efficiency of the ADR+ algorithm using an energy-efficiency controller term that depends on the average energy consumed by all LoRa nodes. The proposed energy-efficiency controller enhances the computing of the SNR margin in the ADR+ algorithm, which results in an improvement of the frames delivery ratio and a significant reduction in energy consumption by LoRa nodes in both urban and sub-urban high-varying channels.
The remainder of the paper is structured as follows. In
Section 2, we present an overview of the related work. The ADR and ADR+ configuration and the proposed ADR++ algorithm are introduced in
Section 3. The simulation results and the performance of the proposed game are given in
Section 4. Finally, the concluding remarks of this paper are made in
Section 5.
2. Related Work
In this section, we review a few of these studies that follow the way of ADR that are related to our work.
In [
3], the authors estimated the performance of ADR at a network server using the NS-3 simulator and proposed new modifications to the ADR algorithm. The network server increases the spreading factor of nodes when the estimated data-extraction rate (DER) is below 80%. This enhancement leads to a faster convergence data rate for nodes, and significant improvement of the overall packet delivery rate (PDR) in a dynamic network environment. The authors of [
5] provide insight into the run-time performance of the official ADR algorithm under dynamic link conditions and various network sizes. They found that if the link conditions change or the number of nodes increases, the convergence time of the ADR mechanism is increased and a large number of packets are therefore lost. The investigation found that the convergence rate can be improved by changing the ADR initialization parameters. Both of the proposed algorithms in [
3] and Ref. [
5] enhanced the standard ADR algorithm to improve the communication performance in terms of convergence rate. The author of [
6] improved the convergence of ADR by using the Gaussian filter to smooth the SNR that was used to update SF and TP. The algorithm was used to reduce the packet losses and therefore the convergence rate of ADR. The proposed approach has been limited to the high variability channel. However, the results only compared with the standard ADR, which has already proven to be an ineffective algorithm in this type of channel by [
4].
In [
4], a new open-source framework for LoRa simulations based on the OMNeT++ simulator named (FLoRa) was presented to implement the physical and medium access control layers of LoRa. The ADR algorithm was modified such that the maximum signal-to-noise ration (SNR) measured over last 20 frames was replaced by the average SNR. This modification improved the delivery ratio and energy consumption compared with ADR especially in moderate and high variable channels. The authors of [
7] noticed that the ADR link margin parameter can be used to compensate for inaccurate link-quality estimates. This modification led to a better service to nodes while maintaining low levels of energy consumption. These ADR algorithms were based on individual node information but not on network performance.
The authors of [
8] have introduced an ordered weighted average (OWA) algorithm to enhance the ADR algorithm in dense LoRa network deployment. The proposed algorithm has shown an improvement on the packet success delivery only in the high channel noise and with the same power consumption of other ADR algorithms. In [
9], a collision-aware ADR (CA-ADR) algorithm was proposed to minimize the collision probability when assigning the data rate. The introduced algorithm considered all the nodes in the network and kept the link performance under control; the results outperform standard solutions when connectivity is good, whereas the alogrithm behaves similarly in large areas. In [
10], the authors proposed an energy-efficient rate-control scheme based on the uplink channel quality, which allows LoRa nodes to rate up when the channel is better and rate down or increase the transmission power when recognizing failure transmission. The scheme was modelled as a continuous-time Markov chain, and the results show better performance in terms of transmission success probability, transmission rate, frame transmission delay, and energy consumption. An analytical model to evaluate the delivery ratio in a LoRa network has been proposed in [
11], in which the impact of several key factors such as multiple gateways and channel variation is considered. The authors of [
12] reviewed the ADR improvements that have been suggested in the literature and then described how the proposed E-ADR would handle a node mobility use case. The effect of weather conditions on LoRa IoT has been addressed in [
13]. The best equal SINR alorithm BE-LoRa has been proposed in [
14] to improve the packet-delivery ration and minimize the power consumption. The updated SF has been modified based on the received signal strength indicator (RSSI), and the updated transmission power was improved based on the comparison between the optimal SINR of each SF and SNR recorded by last 20 frames. The work was limited to the ideal channel, where the standard deviations in the path loss
was set to zero. In [
15], the authors proposed a new dynamic ADR algorithm to solve the mobility of LoRaWAN and the poor communication quality in harsh environments. An adjustable noise factor
based on the noise factor has been introduced to simulate the varying degrees of impact on RSSI and SNR in the link when when environmental conditions change. The above approaches were sought to achieve good performance in power consumption, packet-delivery success rate and convergence. Furthermore, there are two existing approaches that seek to develop the standard adaptive-data-rate algorithm and can be classified into two categories, i.e., link-based approaches, which focus on developing the existing link-adapted ADR algorithm without taking into account the impact of collision [
3,
6,
7,
8,
15], and network-aware approaches, which are new development models of power and SF allocation that consider the collision [
2,
9,
10,
14]. In this work, we developed the standard ADR+ algorithm by considering the energy consumed per successful transmission computed at a network server to find the best energy-efficiency controller value. The energy-efficiency controller is able to adjust the margin SNR value to ensure efficient power and SF allocation without substantially changing the existing standard ADR.
3. ADR and ADR+ Configuration
The TP and SF are considered as the most important parameters in LoRaWAN. The TP depends on the region, and it varies from 2 to 14 dBm, in 3 dBm steps [
4]. The configuration of the SF allows for different transmission data rates, which the lower SF transmits at higher data rate and vice versa. The SFs in the LoRa range from SF7 to SF12, which are semi-orthogonal signals, and each SF has different SNR requirements as a minimum to receive the packet. In fact, selecting different SFs assists the gateway to successfully receive distinct signals at the same time. Moreover, the SNR required to successfully demodulate the frame at the gateway is higher in the lower SF and smaller in higher SF, allowing for longer-range transmission [
7].
Table 1 lists the SNR and the bit rate for the LoRaWAN configuration at the bandwidth 125 kHz.
Based on Internet of Thing (IoT) application, LoRaWAN has three different classes: Class A, Class B, and Class C [
1]. Class A is most popular due to the energy consumption advantage compared to other classes. The successful transmission between LoRa and the gateway occurs when the received power is greater than the receiver sensitivity. The received power
depends on transmit power
and the path loss due to the attenuation and shadowing. In this work, we used the log-distance path loss model with shadowing, which depends on the distance between the node and the gateway [
17]. The received power is computed as follows:
where
represents transmit power of node
i,
denotes the mean path loss at the reference distance
in [dB],
represents the distance between node
i and the gateway,
n denotes the path loss exponent, and
is a zero-mean Gaussian distributed random variable with standard deviation
[dB].
The data rate and transmission power are the most important parameters in the physical layer that have a direct impact on the network capacity and scalability of LoRa network. Thus, the ADR algorithm described in LoRaWAN specification is able to modify these parameters to improve the link between the nodes and the gateway. In LoRaWAN, a collision occurs when two or more packets are overlapped simultaneously and frequently at the receiver [
14]. In such simultaneous receptions of packets, the signal of the desired packet that needs to be demodulated is compared to the summation of the interfering signals of other packets, which refer to the signal-to-interference ratio (SIR) above a margin. The co-SF interference occurs when interference signals and the desired signal have the same SF, and the inter-SF interference occurs when interference signals have different SF than the desired signal. The margin SIR of both co-SF and inter-SF interference is presented in
Table 2.
3.1. ADR+ NS Algorithm
In LoRaWAN, ADR estimates the link budget between a node and a gateway and then allocates a high data rate with a low SF to the node close to the gateway and a low data rate with a high SF to the far node. In addition, it allocates a low TP to the close node and a high TP to the far node. There are two concurrent algorithms running at the NS and node sides. However, the NS ADR algorithm converges faster than the node algorithm, and it is not necessary that both algorithms converge to the same data rate [
3].
The ADR algorithm at the node side has a counter that increments or decrements based on the downlink message. A node requests a response from the network server when the counter reaches the (ADR ACK LIMIT). If the node does not receive any response after the delay time (ADR ACK DELAY), it starts to increase the spreading factor SF till the maximum value is reached. This SF increment leads to an increase in the transmission range and the probability to reach the gateway. If the downlink transmission is received, the counter returns to zero.
On the NS side, the maximum SNR of the last 20 records with the required SNR for each SF and error margin (device margin) in dB is used to compute the number of adjustment steps required to improve the link quality. The number of steps is given by
The number of steps computed in (2) is used to decrease SF and adjust transmission power (increase/decrease) by 3 dBm. It was found in [
4] that estimating the link quality by using the maximum SNR value is ideal when there is no variability in the channel quality, but it is not the optimal approach when the physical channel conditions are variable. Thus, the authors proposed a simple modification by changing the
operator in the NS algorithm by the average function
and referred to this algorithm as ADR+.
The part of ADR running at the NS (ADR+ NS) is illustrated in Algorithm 1.
Algorithm 1.
NS ADR+ algorithm |
- 1:
←(SNR of last 20 frames) - 2:
← demodulation floor (current data rate) - 3:
← 10 - 4:
) - 5:
/3) - 6:
while and do - 7:
- 8:
- 9:
end while - 10:
while and do - 11:
3dBm - 12:
- 13:
end while - 14:
while and do - 15:
3dBm - 16:
- 17:
end while
|
3.2. Proposed ADR++
It is shown in the previous subsection that ADR+ can improve the network performance when the channel conditions are variable. Both ADR and ADR+ are based on the link budget of the individual link between the node and the gateway.
Thus, we propose another modification to the ADR+, wherein the average SNR in Algorithm 1 can be adjusted by decrementing it to find the best average value that ensures efficient energy consumption. The average operator in the first line of Algorithm 1 is multiplied by , where represents the energy-efficiency controller of the system. We refer to this new algorithm as ADR++, and it will be applied in high-variability, fast-fading conditions.
Assuming the number of LoRa nodes is
N, the NS computes the energy consumption per successful transmission of all nodes
E that result from the ADR+ algorithm (
), which is
as
where
is the total energy consumed and
the number of packets received successfully.
The ADR++ algorithm updates
in ADR+ again after decrementing
, by a positive value,
. The ADR+ will be run but with multiplying line 1 with the new
. If the energy consumption
at this new
improves the energy consumed with respect to the previous instance, the factor
is decremented and the procedure is repeated. We continue until the energy consumption level becomes worse than the previous step; then, we declare the last value of the energy-efficiency controller to be the best factor
. The
value will be multiplied by the first line of Algorithm 1; thus, the computation complexity remains the same as ADR+. The way
is determined by the NS can be summarized as in the Algorithm 2 format.
Algorithm 2.
NS ADR++ algorithm |
- 1:
Set and use it in NS ADR+ algorithm avg(SNR of last 20 frames) × - 2:
Get energy consumption of all nodes N, - 3:
decrement and use it in NS ADR+ algorithm - 4:
Get energy consumption of all nodes N - 5:
if
then - 6:
Go step 3 - 7:
else - 8:
declare ; - 9:
end if
|
Figure 1 represents the whole operation of the proposed ADR++ algorithm in the LoRaWAN node and the network server.
4. Results
We evaluate the performance of the proposed ADR++ algorithm in LoRa networks through simulations. We employed FLoRa to evaluate the performance of LoRa networks with ADR+ and with our proposed ADR++ algorithm. Each LoRa node initially used the maximum spreading factor SF12 and the maximum transmission power level 14 dBm. A uniform distribution of nodes is assumed within a network area of 480 m × 480 m, which adequately represents an urban deployment scenario, and 9800 m × 9800 m, which represents the sub-urban deployment scenario. The urban represents the built-up environment wherein deployments are partially indoor, while the sub-urban corresponds to a few tall-building environments. The default path loss parameters
,
n used in the two cases shown in
Table 3 have been derived from the measurements carried out in [
19].
A single gateway is located at the center and connected to the network server. The LoRa nodes and the gateway adhered to a 1% duty cycle restriction. We evaluate the performance with the standard deviations in the path loss (
) set to represent the typical variability (
= 3.57) in urban and (
= 7.08) in sub-urban scenarios. The bandwidth (BW) is 125 KHz, the frequency is 868 MHz, the device Margin is 10 dB, and the code rate is 4/5. The
for each SF is as in
Table 4.
The simulation time for each experiment is 12 days, and the simulations included a warm-up period of 2 days during which statistics were not collected while the network reached steady state. We run 10 iterations of each experiment according to the independent replication method of OMNET++.
The state-based energy consumer module in FLoRa is used to model the energy expenditure of the LoRa nodes. It computes the energy consumed depending on the time spent by the LoRa radio in the main three states: transmit, receive, and sleep state [
4]. The energy consumed in the transmit state depends on the values of the instantaneous current of each transmission power level [
19]. The sleep state occurs after transmitting or receiving a frame, and the current drawn during the receive and sleep modes is derived from the Semtech SX1272/73 data sheet with a supply voltage of 3.3 V [
20].
Figure 2 represents the relation between the energy consumed and the energy-efficiency controller of 100 nodes in the urban scenario, and it is constructed by letting Algorithm 1 complete all the steps at each value of
using
. We terminate decrementing the energy-efficiency controller if the energy consumed by all the nodes is worse than the previous step. It is shown that the energy consumed decreases by gradually decreasing
from 1 (as used by ADR+) until
is reached, and then it increases when
. In the proposed ADR++ algorithm, the decrementing was terminated at
, which represents the minimum energy consumption of all the nodes.
Next, we applied the ADR++ algorithm when the network size varies from 100 to 500 in steps of 100 nodes with and compared the output with ADR+. We evaluated the performance by using two metrics, which are
The delivery ratio: the number of packets correctly received by the network server divided by the total number of messages sent by the end nodes.
The energy consumed per successful transmission: the total energy used by all the LoRa nodes divided by the total number of messages successfully received by the network server.
In general, the delivery ratio is decreased and the energy consumption is increased by increasing the number of nodes. It can be observed that the solution of ADR++ with
offers a significant improvement in the packet delivery ratio with respect to the solution offered by ADR+, as shown in
Figure 3a. In the ADR++ algorithm, LoRa nodes are assigned to SFs that guarantee sending packets to the gateway successfully using minimum transmission powers.
Figure 3b shows how the power consumption was reduced when the LoRa nodes used ADR++ with
compared with the ADR++ algorithm. We note that the number of steps computed in ADR+ were based on the average of the last 20 SNR records of the individual node, while the individual node depends on the overall system energy consumption in the ADR++ algorithm. Choosing
has implications of a max–min fair outcome, for which we start with
, which assigns spreading factors and transmission powers based on ADR+ and continues decrement
to improve energy consumption until the latest result is worse than the previous one.
Figure 4 shows the final assignment of SFs to the LoRa nodes. It is obvious that the number of nodes assigned to SF9 and SF10 increases by decrement
and decreases with other SFs that improve the data rate and the delivery ratio.
Furthermore, we applied the ADR++ algorithm in a sub-urban environment and compared the results of the delivery ratio and energy consumed with traditional ADR+. In the sub-urban scenario, the energy consumed is decreased by decrement , and in the urban scenario. The energy consumed is decreased by decreasing the efficiency controller from 1 (as used by ADR+) until reaching , and then it increased when . Thus, the ADR++ declare is the best.
Figure 5a shows that the ADR++ algorithm with
offers a significant improvement in the packet delivery ratio to above 70% with a different network size compared with ADR+, which achieved less than 60%. Moreover, the power consumption was significantly reduced when the LoRa nodes used ADR++ with
compared with ADR++ algorithm, as shown in
Figure 5b.
Both the ADR+ and ADR++ algorithms improve the link budget by appropriately selecting the spreading factor and transmission power for each link. The ADR and ADR++ approaches do not does not take into consideration the possibility of collisions that can significantly decrease the delivery ratio in dense networks [
4]. However, the proposed ADR++ algorithm computes the energy consumed per successful transmission of all nodes in different steps of
and then use the best energy-efficiency controller
to guide each individual node to the best performance. Updating the SF of each link has a direct impact to the received signal strength (RSS) in which increasing SF will reduce the required RSSI at the receiver by 3 dB.
The summary of performance improvement of ADR++ at
shown in
Table 5.