Abstract

The efficient coverage of underwater wireless sensor networks (UWSNs) has become increasingly important because of the scarcity of underwater node resources. Complex underwater environments, water flow forces, and undulating seabed reduce the coverage effect of underwater nodes, even leading to coverage holes in UWSNs. To solve the problems of uneven coverage distribution and coverage holes, a three-dimensional iterative enhancement algorithm is proposed for UWSN coverage hole recovery using intelligent search followed by virtual force. Benefiting from biological heuristic search algorithms, improved particle swarm optimization is applied for node pre-coverage. With the change in iteration times, the adaptive inertia weight, acceleration factor, and node position are constantly updated. To avoid excessive coverage holes caused by search falling into local optimum, underwater nodes are considered as particles in the potential field whose virtual forces are calculated to guide nodes towards higher coverage positions. In addition, based on the optimal node location obtained by the proposed algorithm, the monitoring area is divided based on the clustering idea. The underwater routing protocol DBR based on depth information is subsequently used to optimize node residual energy, and its average is calculated comprehensively and compared with the other three coverage algorithms using the DBR routing protocol. Based on the experimental data, after 100 iterations, the coverage rates for BES, 3D-IVFA, DABVF, and the proposed algorithm are 83.28%, 88.85%, 89.31%, and 91.36%, respectively. Moreover, the proposed algorithm is further verified from the aspects of different node numbers, coverage efficiency, node movement trajectory, coverage hole, and average residual energy of nodes, which provides conditions for resource development and scientific research in marine environments.

Full Text
Published version (Free)

Talk to us

Join us for a 30 min session where you can share your feedback and ask us any queries you have

Schedule a call