This section outlines the development of the proposed routing protocol, including proposed clustering strategy, neighboring UAV discovery process, cluster formation, central node resolution factor, central node discovery process and delay awareness of the proposed protocol. The reactive protocol considers factors like distance, speed, direction, network quality, and reliability to enhance rapid and dependable data exchange. The proposed routing protocol involves broadcasting Route Request (RREQ) messages to discover routes, with neighboring UAVs replying with Route Reply (RREP) messages containing path delay, reliability factor (RF), and residual energy (RE). UAVs evaluate these replies and select the most reliable paths based on the Central Node Resolution Factor (CNRF), electing Central Nodes (CNs) accordingly. Data packets are routed through these CNs for stability and efficiency, and alternative routes are used if a link fails. The protocol dynamically adjusts to network changes, continuously monitoring link quality and energy levels for optimal performance.
4.1. Proposed Clustering Strategy
In our proposed Cognitive Radio UAV networks (CR-UAV), it introduces a distributed clustering scheme aimed at optimizing network performance. This approach adapts channel access timing within each cluster through synchronized super-frames.
In our proposed super-frame setup, the Central Node (CN) initiates the beacon period by broadcasting a beacon message containing essential cluster information such as its ID, time synchronization data, SCH ID, and control/resource allocation details. Following this, during the spectrum sensing period, nodes assess channel availability and update their list of usable channels accordingly. If the channel is clear, the CN proceeds to transmit data; if not, it waits and retries later using a Distributed Coordination Function (DCF). Each cluster has its common channels chosen by the CN, and if a Primary User (PU) appears, the CN switches to the next channel to avoid interference, with other nodes following suit.
In our proposed super-frame setup, the Neighbor Discovery phase immediately follows the Spectrum Sensing period. It has a critical time for both discovering neighbors and forming clusters. Nodes entering the network begin by scanning available channels and compiling a list of accessible channels. They then organize these channels and cycle through them to locate nearby nodes. If a Primary User signal is detected on a channel, nodes move to the next one. The goal is for nodes to spend sufficient time on each channel to identify all nearby nodes. Once neighboring UAVs are found, nodes exchange their lists of available channels and establish connections.
Finally, the data period split into communicating within clusters and communicating between clusters. These phases are very important for making sure our clusters work seamlessly and can communicate with each other effectively in our CR-UAV network (
Figure 3).
Neighbour Discovery Process
In our proposed network framework, the Neighbor Discovery phase represents a crucial step for Cognitive Radio-UAV (CR-UAV) nodes seeking to join the network. Through this phase, CR-UAV nodes can identify neighboring nodes and/or neighboring clusters, facilitating the exchange of control information essential for network integration.
The process begins with the identification of available free spectrum by the CR-UAV node, followed by the preparation of its Accessible Channels List (ACL). Once the ACL is established, the CR-UAV node arranges the channels in sequential order, optimizing the process for neighbor discovery.
Channel hopping then ensues, as the CR-UAV node sequentially explores the identified channels to listen for beacon signals. To ensure synchronization and coordination, a global common control channel is utilized to obtain a common time reference. During this phase, the CR-UAV node remains on each channel for a defined channel stopover time, allowing ample duration to detect neighboring nodes within the vicinity.
Upon successfully receiving a beacon signal, the CR-UAV node promptly responds by transmitting a HELLO message to the Central Node (CN), initiating communication. Subsequently, the CR node awaits a REPLY message from the neighboring CN. A timer is activated during the transmission of the HELLO message to establish a maximum waiting time for the receipt of the REPLY message.
In cases where no reply is received within the specified time frame or upon failure to receive the REPLY message, the CR-UAV node employs a retransmission mechanism to ensure data transmission reliability. However, it is essential to note that the total duration of all re-transmissions and corresponding timers for any particular HELLO message should not surpass the channel stopover time.
Following successful communication and receipt of a REPLY message from a neighboring cluster, the CR-UAV node proceeds to initiate the node joining process, as detailed further in the Node Move-in and Node Move-out subsection of our paper. Conversely, if no beacon signal is detected from any cluster during the neighbor discovery phase, the CR-UAV node initiates the cluster formation process, a topic explored extensively in the subsequent section of our paper.
Through this comprehensive neighbor discovery process, CR-UAV nodes efficiently establish connections with neighboring nodes and clusters, laying the foundation for seamless network integration and collaboration within the Cognitive Radio environment.
4.2. Central Node Resolution Factor
This part of this section introduces the Routing metric Central Node Resolution Factor (CNRF), total cumulative CNRF
is calculated considering the path P is expressed as follows,
The source node sends an RREQ to nearby UAVs for data transmission, and neighboring nodes calculate their distance using Received Signal Strength Indication (RSSI) to determine their positions. RSSI is chosen because it is a simple and cost-effective method that can be implemented with existing hardware on commercial wireless devices. While RSSI can vary due to environmental factors such as interference and obstacles, it offers a practical balance between cost and complexity. To mitigate some of the variability and improve accuracy, it employ techniques such as averaging multiple RSSI readings and filtering.
Here,
k is inspected as path loss,
is the exponent of signal loss,
v is the received signal’s wavelength and
is reference distance. When a UAV receives a signal, it saves its current coordinates and timestamps
. It then waits for a certain amount of time before responding with its coordinates and sending time
. This paper discusses the UAV node’s transmission-related speed
may be calculated as follows:
Here, the coordinates for UAVs are
receiving and sending individually.
indicates the transmission time. Consequently, the direction between neighbor and destination nodes is defined during packet reception and transmission.
The displacement between two nodes in the time of sending packets at the time
is measured as (
),
So, the weighted value during data transmission
between two nearby nodes is calculated by every other UAV and may shown as follows,
In this case,
represents the data transmission range between two UAV nodes,
represents the displacement of two UAV nodes,
is the total of connection delays when routing and
s is UAV speed during transmission.
The proposed protocol assesses network failure using back-off, switching, and queuing delays. It also handles traffic density issues in congested areas, considering the number of nearby nodes (
),
data rate of
, and
S as the size of sending packets, so the queuing delay
of
is calculated as follows,
UAV nodes use random back-off time for collision reduction, by using the following equation:
Here,
is symbolized as the probability of collision
is the nearby UAV nodes on the channel
and
w is the window size.
Intermediate nodes may switch channels during discovery with minimal time spent, typically considered as zero time. Switching delay
is the time needed to change channels within a channel group if a drone
is required to switch channel
p to
q in its channel group whilst forwarding the message to next-hop
.
where
a is a positive real number and the tuning delay of two UAVs is regarded to have a specified step size
a. let’s consider step size 5 MHz, a is 5 ms [
24]. So, it calculates The link delay
using the above equation,
The suggested protocol uses the RF factor to provide safe data transfer, which may be computed as follows:
represents the reported number of suspected nodes in data transmission, indicating the importance of transmitting weight value
and
N, Cognitive nodes calculate the CNRF value makes increasing stability during transmission as the UAV nodes choose the highest
in the routing path.
, number of common ideal channels, link delay
, the reliability factor is
, Residual Energy is
, Residual Energy (RE) is calculated using Initial Energy (IE) minus Consumed Energy (EC). EC includes Transmission Energy (TE), which results from the power used for N packet transmissions.
4.3. Central Node Discovery Process
In the proposed routing Algorithm 1, the route discovery procedure starts with broadcasting the Route Request (RREQ) to its nearby nodes. The nearby nodes then evaluate the trustworthiness of the mediator nodes using the Suspected UAV Node (SQN) value. If the SQN value exceeds 50%, that particular node is declared malicious and flagged with an infinity value, initiating the node exit process for the suspicious UAVs.
The proposed protocol also examines Residual Energy (RE) and Reliability Factor (RF) during the process. Based on the distance, angle, speed ratio, and number of free channels of a node, a destination node calculates the Central Node Resolution Factor (CNRF). RREQ and Route Reply (RREP) messages are exchanged between nodes to discover all possible paths, collectively referred to as the ‘Path’ of the algorithm. The ‘Path’ represents the overall route that data packets will follow, consisting of a sequence of nodes or waypoints. In contrast, a ‘path’ represents a single segment or connection between two nodes within the overall ‘Path’. Both ‘Path’ and ‘path’ are implemented using list data structures, with each element corresponding to a node or waypoint. The source node calculates and stores the CNRF, RE, and RF, ensuring efficient and reliable routing by selecting the most optimal ‘Path’ based on these parameters.
The Cluster Formation Algorithm runs periodically, optimizing energy consumption by processing, sending, and receiving messages at defined intervals. It involves each node (
) scanning and constructing an Adjacent Cluster List (
) and Node List (
), which are then transmitted to neighboring nodes (
). Based on gathered information, each node constructs a graph component (
) from its previous graph information (
). Each node determines its Central Node Route Factor (
) and shares it with its neighbors. The node with the highest
within its neighborhood is selected as the Cluster Node (
), forming a cluster and selecting Sub-Cluster Nodes (
) based on
values. If there are multiple neighbors with higher
values, the node with the smallest ID is chosen. This process continues until clusters are formed with selected CNs and Cluster Members (
). Considering the number of neighbors (
n) and the number of nodes in the network (
N), the total number of accessible channels is
C, and a particular node’s accessible channels is
X. For one node, the route discovery algorithm has a complexity of
, where
represents the accessible channels for that node. For
N nodes, the algorithm’s complexity becomes
. However, when the number of nodes (
N) in the network is significantly larger than the constant
, the complexity simplifies to
.
Algorithm 1: Central Node Discovery Process |
|
4.4. Cluster Formation
Based on the availability of spectrum, our proposed clustering mechanism strategically organizes the network into distinct logical groups. After completing the neighbor discovery phase, each node compiles its list of neighbors and exchanges Accessible Channels Lists (ACLs) with neighboring nodes within a single hop. Our clustering scheme is designed to minimize the number of clusters while simultaneously maximizing the common channels within each cluster.
The process of forming clusters, as outlined in Algorithm 2, is framed as a maximum edge biclique problem. The objective is to create clusters that encompass the greatest number of nodes while incorporating the maximum possible number of shared channels within each cluster, as illustrated in
Figure 4.
Algorithm 2: Cluster Formation |
|
Initially based on nodes and channel list, the maximum bipartite vertices set can be split into two disjoint sets. where the connected nodes to the ACL’s big set can be split into a weighted graph and maximum biclique are taken into consideration. Using this, all nodes are connected to the available channels, so if one of the channels need to get back to it’s PU and the other nodes can move forward with the other maximum left ACLs. The nodes then forms a cluster using the accessible channel list and the maximum biclique.
Using Equation (12), it set the value for all the nodes, and by the maximum weight value it decides the Central Node (CN) in the cluster. Same as that the second highest valued node becomes the Secondary Central Node (SCN). By following the same process, all the nearby nodes creates their own cluster and cluster heads. Moreover, the node that is connected with two or more clusters CN is nominated as Nearby Node (NN). which works as a bridge into two nearby clusters while communication and optimizes the energy and makes the communication faster.
From the proposed Algorithm 2, the Initial UAV Node () scans and constructs the initial Available Channel List (). Then the transmits and initial Neighbor List to the neighboring UAV nodes . then generates the initial Maximum edge biclique graph () from the initial bipartite graph (). then determines the value of the initial Central Node Resolution Factor () and shares with the .
If the value of is greater than the value of the Neighboring Central Node Resolution Factor (), the node states as the Central Node (CN) and forms its cluster. Moreover, it selects the Secondary Central Node () based on the second highest value of among the Cluster Members ().
If the is greater than the , then it check if the number of channels is more than 1 or not. Again, if the ’s highest value is more than 1, then the initial node asks the CN to join as CM where the ID of the neighboring node is minimum. Else, the states as CN directly with its ID and asks to join the cluster as CM.
If the Channel Number (N) is less than 1. the requests to join as CM. If the initial ID () is less than the neighboring ID () then states as CN and form a cluster. Else it requests to join as CM where the is minimum.
In our cluster formation approach, each group is led by a central node (CN). This CN acts as a hub for all communication within the group, so other nodes, called Cluster Members (CMs), rely on it to send and receive messages. It organises clusters in a way that maximizes communication efficiency.
Once a cluster is formed, the CN decides on the best frequencies for communication within the group. If neighboring clusters are detected, the CN assigns some CMs as Nearest Nodes for forwarding nodes (NNs) to improve connectivity with those clusters. NNs help relay messages between different clusters, enhancing overall network performance.
Clusters typically consist of a CN, a Secondary Central Node (SCN), and CMs. However, since the network environment can change rapidly, the proposed protocol is to handle nodes joining or leaving clusters. These protocols ensure that our network remains stable and efficient, even as it adapts to dynamic conditions.
4.4.1. Node Move-In
The Node Move-In protocol outlines how a node can join an existing cluster or form a new one in our proposed clustering mechanism. When a node, denoted as , detects a beacon from a neighboring Central Node (CN), it initiates the joining process. Here is how it aligns with our clustering approach:
Node Identification and Preparation: The joining UAV node () identifies free channels and prepares its Accessible Channels List (ACL). It then scans for beacons on these channels, allowing it to identify neighboring clusters and nodes.
Broadcasting and Sharing: Upon detecting neighboring clusters, broadcasts its neighbor and channel lists. This information exchange facilitates cluster formation and connectivity assessment.
Graph Construction and CNRF Calculation: constructs bipartite and maximum edge biclique graphs based on the received information. It then calculates the Central Node Resolution Factor (CNRF) to evaluate connectivity.
Cluster Joining: If neighboring CNs are detected, attempts to join the cluster. It selects the CN with the highest CNRF value or the lowest ID if CNRF values are identical. then compares its CNRF with the selected CN and requests to join as a Cluster Member (CM).
Cluster Formation: If ’s CNRF is higher than the selected CN’s, and its neighboring node set matches the CN’s CM list, becomes the new CN, and the existing CN becomes the Secondary CN (SCN). Otherwise, joins as a CM or attempts to form a new cluster if no suitable cluster is found.
Further Considerations: If provides better connectivity than the existing Nearest Node (NN) with a neighboring cluster, it becomes the NN. Additionally, can declare itself as CN and form a new cluster if joining existing clusters fails.
This protocol ensures flawless integration of nodes into clusters, optimizing network organization and communication efficiency.
From Algorithm 3, The joining UAV Node (
) starts to scan its span and prepares the
for
.
then broadcasts
and
and create biclique graph (
) based on bipartite graph (
) and calculates
. then it shares the value with neighboring
. After that, it checks if the joining node belongs to the neighboring node or not, if the value of the joining node’s channel is greater than 1 then it again checks if the joining accessible channel list intersects with the central node’s ACL and is greater than 2. The
then joins
as CM. Otherwise,
rejects the joining request from
and tries to join with other
s. However, If
fails to join any cluster it makes its cluster and states CN.
Algorithm 3: Node Move-In |
|
If the value of is greater than the value of , it checks if is the neighboring CN or not. then becomes the new CN and becomes the Secondary Central Node (SCN). Again if the neighboring cluster head is a proper sub-set of the neighboring UAV Nodes, then the calculates new CNRF for which is the neighboring cluster head (). Then it checks if the value of is greater than then it follows the same procedure from the algorithm from line 25.
If the is not equal to ; then it follows the algorithm procedure from line 13. Also, it looks the same if is less than and if the channel list is not a maximum biclique edge graph.
When joining the nearest node () belongs to () then it check if the joining node number is more than one, it then selects the with the highest CNRF and forms a new cluster and becomes cluster’s Central node. Otherwise, the result remains the same as before and joins the cluster if the does not belong to the set of . then joins new cluster with new and selects with highest and with second highest value.
4.4.2. Node Move-Out
The Node Move-Out protocol governs the process of nodes leaving the network, including Central Node (CN), Nearest Nodes (NN), and Cluster Members (CM). Here is how it aligns with our clustering mechanism:
Leaving Process Initiation: When a node detects a decrease in beacon signal strength, indicating movement, it initiates the leaving process. Depending on its role as a CN, NN, or CM, different leaving scenarios are considered.
Leaving Message Broadcast: The leaving node, denoted as , broadcasts a leaving message to its neighbors (). first checks its neighbor list to determine its role and potential connections with other nodes.
CH Departure Handling: If is a CN, it informs neighboring CMs about the departure and assigns the Secondary CN (SCN) as the new CN. The SCN selects a new CN based on CNRF values, ensuring continuity in cluster leadership.
NN Departure Handling: If is an NN, it informs the parent CN () and neighboring clusters about the movement. If direct connection with a neighboring cluster is not possible, requests a CM to act as an NN or selects a new NN based on CNRF values.
CM Departure Handling: If is a CM, it informs about the departure. selects a new SCN from the CMs and adjusts intra-cluster communication accordingly. The neighboring cluster is informed about the departure and potential joining scenarios.
Inter-Cluster Connectivity: In all leaving scenarios, efforts are made to maintain inter-cluster connectivity. Nodes are assigned new roles or connections based on CNRF values, ensuring network stability and continuity of communication.
This protocol ensures smooth transitions when nodes leave the network, maintaining connectivity and stability within and between clusters.
From Algorithm 4, initially, the leaving UAV (
) broadcasts a leaving decision to the neighboring UAVs. Then it checks if the leaving Central Node belongs to neighboring UAVs then it checks if the number of nodes is more than one, and the leaving UAV informs the leaving central node about the leaving information. While the
leaves, it checks if the non-leaving members (
) do not belong to the leaving central node’s subset and non-leaving cluster members belong to the neighboring central node. If the channel of a non-leaving node is higher than one, the non-leaving cluster members are selected by its CNRF and the leaving central node requests the non-leaving member to be its Nearest Node. The non-leaving members then forward this message to the non-leaving central node (
) and the
becomes the NN to maintain the connectivity.
Algorithm 4: Node Move-Out |
|
Otherwise, leaving the Central node sends a message to the leaving cluster member for the neighboring member list. if the leaving central node belongs to the neighboring cluster member, then the cluster member forwards the request message to the leaving central node. The leaving member then becomes the Nearest Node (NN). Otherwise, if the non-leaving cluster member forwards a message request to the non-leaving central node the leaving cluster member then becomes the NN along with the non-leaving cluster member for safer connectivity. If the is less than the number of then it follow the same procedure from line 6.
Otherwise, it checks if the leaving UAV node is the cluster’s secondary Central node or not, if it is then a new SCN is selected from the cluster members, or else the node leaves the cluster.
If the leaving cluster node not belong to the neighboring UAVs, the leaving UAV simply informs all the cluster members and the SCN becomes the new central node and a new SCN is selected based on the CNRF from the CMs.