1 \documentclass[a4paper,twoside]{article}
13 \usepackage{SCITEPRESS}
14 \usepackage[small]{caption}
16 \usepackage[linesnumbered,ruled,vlined,commentsnumbered]{algorithm2e}
17 \usepackage{mathtools}
25 %\title{Authors' Instructions \subtitle{Preparation of Camera-Ready Contributions to SCITEPRESS Proceedings} }
27 \title{Distributed Lifetime Coverage Optimization Protocol \\in Wireless Sensor Networks}
29 \author{\authorname{Ali Kadhum Idrees, Karine Deschinkel, Michel Salomon, and Rapha\"el Couturier}
30 \affiliation{FEMTO-ST Institute, UMR 6174 CNRS, University of Franche-Comt\'e, Belfort, France}
31 %\affiliation{\sup{2}Department of Computing, Main University, MySecondTown, MyCountry}
32 \email{ali.idness@edu.univ-fcomte.fr, $\lbrace$karine.deschinkel, michel.salomon, raphael.couturier$\rbrace$@univ-fcomte.fr}
33 %\email{\{f\_author, s\_author\}@ips.xyz.edu, t\_author@dc.mu.edu}
36 \keywords{Wireless Sensor Networks, Area Coverage, Network lifetime,
37 Optimization, Scheduling.}
39 \abstract{ One of the main research challenges faced in Wireless Sensor Networks
40 (WSNs) is to preserve continuously and effectively the coverage of an area (or
41 region) of interest to be monitored, while simultaneously preventing as much
42 as possible a network failure due to battery-depleted nodes. In this paper we
43 propose a protocol, called Distributed Lifetime Coverage Optimization protocol
44 (DiLCO), which maintains the coverage and improves the lifetime of a wireless
45 sensor network. First, we partition the area of interest into subregions using
46 a classical divide-and-conquer method. Our DiLCO protocol is then distributed
47 on the sensor nodes in each subregion in a second step. To fulfill our
48 objective, the proposed protocol combines two effective techniques: a leader
49 election in each subregion, followed by an optimization-based node activity
50 scheduling performed by each elected leader. This two-step process takes
51 place periodically, in order to choose a small set of nodes remaining active
52 for sensing during a time slot. Each set is built to ensure coverage at a low
53 energy cost, allowing to optimize the network lifetime. More precisely, a
54 period consists of four phases: (i)~Information Exchange, (ii)~Leader
55 Election, (iii)~Decision, and (iv)~Sensing. The decision process, which
56 results in an activity scheduling vector, is carried out by a leader node
57 through the solving of an integer program. In comparison with some other
58 protocols, the simulations done using the discrete event simulator OMNeT++
59 show that our approach is able to increase the WSN lifetime and provides
60 improved coverage performance. }
62 \onecolumn \maketitle \normalsize \vfill
64 \section{\uppercase{Introduction}}
65 \label{sec:introduction}
68 Energy efficiency is a crucial issue in wireless sensor networks since sensory
69 consumption, in order to maximize the network lifetime, represents the major
70 difficulty when designing WSNs. As a consequence, one of the scientific research
71 challenges in WSNs, which has been addressed by a large amount of literature
72 during the last few years, is the design of energy efficient approaches for
73 coverage and connectivity~\cite{conti2014mobile}. Coverage reflects how well a
74 sensor field is monitored. On the one hand we want to monitor the area of
75 interest in the most efficient way~\cite{Nayak04}. On the other hand we want to
76 use as little energy as possible. Sensor nodes are battery-powered with no
77 means of recharging or replacing, usually due to environmental (hostile or
78 unpractical environments) or cost reasons. Therefore, it is desired that the
79 WSNs are deployed with high densities so as to exploit the overlapping sensing
80 regions of some sensor nodes to save energy by turning off some of them during
81 the sensing phase to prolong the network lifetime.
83 In this paper we design a protocol that focuses on the area coverage problem
84 with the objective of maximizing the network lifetime. Our proposition, the
85 Distributed Lifetime Coverage Optimization (DILCO) protocol, maintains the
86 coverage and improves the lifetime in WSNs. The area of interest is first
87 divided into subregions using a divide-and-conquer algorithm and an activity
88 scheduling for sensor nodes is then planned by the elected leader in each
89 subregion. In fact, the nodes in a subregion can be seen as a cluster where each
90 node sends sensing data to the cluster head or the sink node. Furthermore, the
91 activities in a subregion/cluster can continue even if another cluster stops due
92 to too many node failures. Our DiLCO protocol considers periods, where a period
93 starts with a discovery phase to exchange information between sensors of the
94 same subregion, in order to choose in a suitable manner a sensor node (the
95 leader) to carry out the coverage strategy. In each subregion the activation of
96 the sensors for the sensing phase of the current period is obtained by solving
97 an integer program. The resulting activation vector is broadcast by a leader
98 to every node of its subregion.
100 The remainder of the paper continues with Section~\ref{sec:Literature Review}
101 where a review of some related works is presented. The next section describes
102 the DiLCO protocol, followed in Section~\ref{cp} by the coverage model
103 formulation which is used to schedule the activation of
104 sensors. Section~\ref{sec:Simulation Results and Analysis} shows the simulation
105 results. The paper ends with a conclusion and some suggestions for further work
106 in Section~\ref{sec:Conclusion and Future Works}.
108 \section{\uppercase{Literature Review}}
109 \label{sec:Literature Review}
111 \noindent In this section, we summarize some related works regarding the coverage
112 problem and distinguish our DiLCO protocol from the works presented in the
115 The most discussed coverage problems in literature
116 can be classified into three types \cite{li2013survey}: area coverage \cite{Misra} where
117 every point inside an area is to be monitored, target coverage \cite{yang2014novel} where the main
118 objective is to cover only a finite number of discrete points called targets,
119 and barrier coverage \cite{Kumar:2005}\cite{kim2013maximum} to prevent intruders from entering into the region of interest. In \cite{Deng2012} authors transform the area coverage problem to the target coverage problem taking into account the intersection points among disks of sensors nodes or between disk of sensor nodes and boundaries.
120 {\it In DiLCO protocol, the area coverage, i.e. the coverage of every point in
121 the sensing region, is transformed to the coverage of a fraction of points
122 called primary points. }
125 The major approach to extend network lifetime while preserving coverage is to
126 divide/organize the sensors into a suitable number of set covers (disjoint or
127 non-disjoint), where each set completely covers a region of interest, and to
128 activate these set covers successively. The network activity can be planned in
129 advance and scheduled for the entire network lifetime or organized in periods,
130 and the set of active sensor nodes is decided at the beginning of each period \cite{ling2009energy}.
131 Active node selection is determined based on the problem requirements (e.g. area
132 monitoring, connectivity, power efficiency). For instance, Jaggi et al. \cite{jaggi2006}
133 address the problem of maximizing network lifetime by dividing sensors into the maximum number of disjoint subsets such that each subset can ensure both coverage and connectivity. A greedy algorithm is applied once to solve this problem and the computed sets are activated in succession to achieve the desired network lifetime.
134 Vu \cite{chin2007}, Padmatvathy et al. \cite{pc10}, propose algorithms working in a periodic fashion where a cover set is computed at the beginning of each period.
135 {\it Motivated by these works, DiLCO protocol works in periods, where each period contains a preliminary
136 phase for information exchange and decisions, followed by a sensing phase
137 where one cover set is in charge of the sensing task.}
139 Various approaches, including centralized, or distributed
140 algorithms, have been proposed to extend the network lifetime.
141 In distributed algorithms~\cite{yangnovel,ChinhVu,qu2013distributed},
142 information is disseminated throughout the network and sensors decide
143 cooperatively by communicating with their neighbors which of them will remain in
144 sleep mode for a certain period of time. The centralized
145 algorithms~\cite{cardei2005improving,zorbas2010solving,pujari2011high} always
146 provide nearly or close to optimal solution since the algorithm has global view
147 of the whole network. But such a method has the disadvantage of requiring high
148 communication costs, since the node (located at the base station) making the
149 decision needs information from all the sensor nodes in the area and the amount of information can be huge.
150 {\it In order to be suitable for large-scale network, in the DiLCO protocol, the area coverage is divided into several smaller
151 subregions, and in each one, a node called the leader is in charge for
152 selecting the active sensors for the current period.}
154 A large variety of coverage scheduling algorithms has been developed. Many of
155 the existing algorithms, dealing with the maximization of the number of cover
156 sets, are heuristics. These heuristics involve the construction of a cover set
157 by including in priority the sensor nodes which cover critical targets, that is
158 to say targets that are covered by the smallest number of sensors \cite{berman04,zorbas2010solving}. Other
159 approaches are based on mathematical programming formulations~\cite{cardei2005energy,5714480,pujari2011high,Yang2014} and dedicated
160 techniques (solving with a branch-and-bound algorithms available in optimization
161 solver). The problem is formulated as an optimization problem (maximization of
162 the lifetime or number of cover sets) under target coverage and energy
163 constraints. Column generation techniques, well-known and widely practiced
164 techniques for solving linear programs with too many variables, have also been
165 used~\cite{castano2013column,rossi2012exact,deschinkel2012column}. {\it In DiLCO protocol, each leader, in each subregion, solves an integer
166 program with a double objective consisting in minimizing the overcoverage and
167 limiting the undercoverage. This program is inspired from the work of
168 \cite{pedraza2006} where the objective is to maximize the number of cover
175 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
177 \section{\uppercase{Description of the DiLCO protocol}}
178 \label{sec:The DiLCO Protocol Description}
180 \noindent In this section, we introduce the DiLCO protocol which is distributed
181 on each subregion in the area of interest. It is based on two efficient
182 techniques: network leader election and sensor activity scheduling for coverage
183 preservation and energy conservation, applied periodically to efficiently
184 maximize the lifetime in the network.
188 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
190 \subsection{Assumptions and models}
192 \noindent We consider a sensor network composed of static nodes distributed
193 independently and uniformly at random. A high density deployment ensures a high
194 coverage ratio of the interested area at the start. The nodes are supposed to
195 have homogeneous characteristics from a communication and a processing point of
196 view, whereas they have heterogeneous energy provisions. Each node has access
197 to its location thanks, either to a hardware component (like a GPS unit), or a
198 location discovery algorithm.
200 \indent We consider a boolean disk coverage model which is the most widely used
201 sensor coverage model in the literature. Thus, since a sensor has a constant
202 sensing range $R_s$, every space points within a disk centered at a sensor with
203 the radius of the sensing range is said to be covered by this sensor. We also
204 assume that the communication range $R_c \geq 2R_s$. In fact, Zhang and
205 Zhou~\cite{Zhang05} proved that if the transmission range fulfills the previous
206 hypothesis, a complete coverage of a convex area implies connectivity among the
207 working nodes in the active mode.
209 \indent For each sensor we also define a set of points called primary
210 points~\cite{idrees2014coverage} to approximate the area coverage it provides,
211 rather than working with a continuous coverage. Thus, a sensing disk
212 corresponding to a sensor node is covered by its neighboring nodes if all its
213 primary points are covered. Obviously, the approximation of coverage is more or
214 less accurate according to the number of primary points.
217 \subsection{Main idea}
219 \noindent We start by applying a divide-and-conquer algorithm to partition the
220 area of interest into smaller areas called subregions and then our protocol is
221 executed simultaneously in each subregion.
225 \includegraphics[width=75mm]{FirstModel.pdf} % 70mm
226 \caption{DiLCO protocol}
230 As shown in Figure~\ref{fig2}, the proposed DiLCO protocol is a periodic
231 protocol where each period is decomposed into 4~phases: Information Exchange,
232 Leader Election, Decision, and Sensing. For each period there will be exactly
233 one cover set in charge of the sensing task. A periodic scheduling is
234 interesting because it enhances the robustness of the network against node
235 failures. First, a node that has not enough energy to complete a period, or
236 which fails before the decision is taken, will be excluded from the scheduling
237 process. Second, if a node fails later, whereas it was supposed to sense the
238 region of interest, it will only affect the quality of the coverage until the
239 definition of a new cover set in the next period. Constraints, like energy
240 consumption, can be easily taken into consideration since the sensors can update
241 and exchange their information during the first phase. Let us notice that the
242 phases before the sensing one (Information Exchange, Leader Election, and
243 Decision) are energy consuming for all the nodes, even nodes that will not be
244 retained by the leader to keep watch over the corresponding area.
246 During the execution of the DiLCO protocol, two kinds of packet will be used:
247 %\begin{enumerate}[(a)]
249 \item INFO packet: sent by each sensor node to all the nodes inside a same
250 subregion for information exchange.
251 \item ActiveSleep packet: sent by the leader to all the nodes in its subregion
252 to inform them to stay Active or to go Sleep during the sensing phase.
255 and each sensor node will have five possible status in the network:
256 %\begin{enumerate}[(a)]
258 \item LISTENING: sensor is waiting for a decision (to be active or not);
259 \item COMPUTATION: sensor applies the optimization process as leader;
260 \item ACTIVE: sensor is active;
261 \item SLEEP: sensor is turned off;
262 \item COMMUNICATION: sensor is transmitting or receiving packet.
266 An outline of the protocol implementation is given by Algorithm~\ref{alg:DiLCO}
267 which describes the execution of a period by a node (denoted by $s_j$ for a
268 sensor node indexed by $j$). At the beginning a node checks whether it has
269 enough energy to stay active during the next sensing phase. If yes, it exchanges
270 information with all the other nodes belonging to the same subregion: it
271 collects from each node its position coordinates, remaining energy ($RE_j$), ID,
272 and the number of one-hop neighbors still alive. Once the first phase is
273 completed, the nodes of a subregion choose a leader to take the decision based
274 on the following criteria with decreasing importance: larger number of
275 neighbors, larger remaining energy, and then in case of equality, larger index.
276 After that, if the sensor node is leader, it will execute the integer program
277 algorithm (see Section~\ref{cp}) which provides a set of sensors planned to be
278 active in the next sensing phase. As leader, it will send an Active-Sleep packet
279 to each sensor in the same subregion to indicate it if it has to be active or
280 not. Alternately, if the sensor is not the leader, it will wait for the
281 Active-Sleep packet to know its state for the coming sensing phase.
288 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
290 \begin{algorithm}[h!]
293 %\emph{Initialize the sensor node and determine it's position and subregion} \;
295 \If{ $RE_j \geq E_{th}$ }{
296 \emph{$s_j.status$ = COMMUNICATION}\;
297 \emph{Send $INFO()$ packet to other nodes in the subregion}\;
298 \emph{Wait $INFO()$ packet from other nodes in the subregion}\;
299 %\emph{UPDATE $RE_j$ for every sent or received INFO Packet}\;
300 %\emph{ Collect information and construct the list L for all nodes in the subregion}\;
302 %\If{ the received INFO Packet = No. of nodes in it's subregion -1 }{
303 \emph{LeaderID = Leader election}\;
304 \If{$ s_j.ID = LeaderID $}{
305 \emph{$s_j.status$ = COMPUTATION}\;
306 \emph{$\left\{\left(X_{1},\dots,X_{k},\dots,X_{J}\right)\right\}$ =
307 Execute Integer Program Algorithm($J$)}\;
308 \emph{$s_j.status$ = COMMUNICATION}\;
309 \emph{Send $ActiveSleep()$ to each node $k$ in subregion} \;
310 \emph{Update $RE_j $}\;
313 \emph{$s_j.status$ = LISTENING}\;
314 \emph{Wait $ActiveSleep()$ packet from the Leader}\;
316 \emph{Update $RE_j $}\;
320 \Else { Exclude $s_j$ from entering in the current sensing phase}
323 \caption{DiLCO($s_j$)}
328 \section{\uppercase{Coverage problem formulation}}
331 \indent Our model is based on the model proposed by \cite{pedraza2006} where the
332 objective is to find a maximum number of disjoint cover sets. To accomplish
333 this goal, the authors proposed an integer program which forces undercoverage
334 and overcoverage of targets to become minimal at the same time. They use binary
335 variables $x_{jl}$ to indicate if sensor $j$ belongs to cover set $l$. In our
336 model, we consider that the binary variable $X_{j}$ determines the activation of
337 sensor $j$ in the sensing phase. We also consider primary points as targets.
338 The set of primary points is denoted by $P$ and the set of sensors by $J$.
340 \noindent Let $\alpha_{jp}$ denote the indicator function of whether the primary
341 point $p$ is covered, that is:
343 \alpha_{jp} = \left \{
345 1 & \mbox{if the primary point $p$ is covered} \\
346 & \mbox{by sensor node $j$}, \\
347 0 & \mbox{otherwise.}\\
351 The number of active sensors that cover the primary point $p$ can then be
352 computed by $\sum_{j \in J} \alpha_{jp} * X_{j}$ where:
356 1& \mbox{if sensor $j$ is active,} \\
357 0 & \mbox{otherwise.}\\
361 We define the Overcoverage variable $\Theta_{p}$ as:
363 \Theta_{p} = \left \{
365 0 & \mbox{if the primary point}\\
366 & \mbox{$p$ is not covered,}\\
367 \left( \sum_{j \in J} \alpha_{jp} * X_{j} \right)- 1 & \mbox{otherwise.}\\
371 \noindent More precisely, $\Theta_{p}$ represents the number of active sensor
372 nodes minus one that cover the primary point~$p$. The Undercoverage variable
373 $U_{p}$ of the primary point $p$ is defined by:
377 1 &\mbox{if the primary point $p$ is not covered,} \\
378 0 & \mbox{otherwise.}\\
383 \noindent Our coverage optimization problem can then be formulated as follows:
384 \begin{equation} \label{eq:ip2r}
387 \min \sum_{p \in P} (w_{\theta} \Theta_{p} + w_{U} U_{p})&\\
388 \textrm{subject to :}&\\
389 \sum_{j \in J} \alpha_{jp} X_{j} - \Theta_{p}+ U_{p} =1, &\forall p \in P\\
391 %\sum_{t \in T} X_{j,t} \leq \frac{RE_j}{e_t} &\forall j \in J \\
393 \Theta_{p}\in \mathbb{N}, &\forall p \in P\\
394 U_{p} \in \{0,1\}, &\forall p \in P \\
395 X_{j} \in \{0,1\}, &\forall j \in J
401 \item $X_{j}$ : indicates whether or not the sensor $j$ is actively sensing (1
402 if yes and 0 if not);
403 \item $\Theta_{p}$ : {\it overcoverage}, the number of sensors minus one that
404 are covering the primary point $p$;
405 \item $U_{p}$ : {\it undercoverage}, indicates whether or not the primary point
406 $p$ is being covered (1 if not covered and 0 if covered).
409 The first group of constraints indicates that some primary point $p$ should be
410 covered by at least one sensor and, if it is not always the case, overcoverage
411 and undercoverage variables help balancing the restriction equations by taking
412 positive values. Two objectives can be noticed in our model. First, we limit the
413 overcoverage of primary points to activate as few sensors as possible. Second,
414 to avoid a lack of area monitoring in a subregion we minimize the
415 undercoverage. Both weights $w_\theta$ and $w_U$ must be carefully chosen in
416 order to guarantee that the maximum number of points are covered during each
419 \section{\uppercase{Protocol evaluation}}
420 \label{sec:Simulation Results and Analysis}
421 \noindent \subsection{Simulation framework}
423 To assess the performance of our DiLCO protocol, we have used the discrete
424 event simulator OMNeT++ \cite{varga} to run different series of simulations.
425 Table~\ref{table3} gives the chosen parameters setting.
428 \caption{Relevant parameters for network initializing.}
431 % used for centering table
433 % centered columns (4 columns)
435 %inserts double horizontal lines
436 Parameter & Value \\ [0.5ex]
438 %Case & Strategy (with Two Leaders) & Strategy (with One Leader) & Simple Heuristic \\ [0.5ex]
442 % inserts single horizontal line
443 Sensing Field & $(50 \times 25)~m^2 $ \\
444 % inserting body of the table
446 Nodes Number & 50, 100, 150, 200 and 250~nodes \\
448 Initial Energy & 500-700~joules \\
450 Sensing Period & 60 Minutes \\
451 $E_{th}$ & 36 Joules\\
455 % [1ex] adds vertical space
461 % is used to refer this table in the text
464 Simulations with five different node densities going from 50 to 250~nodes were
465 performed considering each time 25~randomly generated networks, to obtain
466 experimental results which are relevant. The nodes are deployed on a field of
467 interest of $(50 \times 25)~m^2 $ in such a way that they cover the field with a
470 We chose as energy consumption model the one proposed proposed by~\cite{ChinhVu}
471 and based on ~\cite{raghunathan2002energy} with slight modifications. The energy
472 consumed by the communications is added and the part relative to a variable
473 sensing range is removed. We also assume that the nodes have the characteristics
474 of the Medusa II sensor node platform \cite{raghunathan2002energy}. A sensor
475 node typically consists of four units: a MicroController Unit, an Atmels AVR
476 ATmega103L in case of Medusa II, to perform the computations; a communication
477 (radio) unit able to send and receive messages; a sensing unit to collect data;
478 a power supply which provides the energy consumed by node. Except the battery,
479 all the other unit can be switched off to save energy according to the node
480 status. Table~\ref{table4} summarizes the energy consumed (in milliWatt per
481 second) by a node for each of its possible status.
484 \caption{Energy consumption model}
487 % used for centering table
489 \begin{tabular}{|c|c|c|c|c|}
490 % centered columns (4 columns)
492 %inserts double horizontal lines
493 Sensor status & MCU & Radio & Sensing & Power (mW) \\ [0.5ex]
495 % inserts single horizontal line
496 Listening & ON & ON & ON & 20.05 \\
497 % inserting body of the table
499 Active & ON & OFF & ON & 9.72 \\
501 Sleep & OFF & OFF & OFF & 0.02 \\
503 Computation & ON & ON & ON & 26.83 \\
505 %\multicolumn{4}{|c|}{Energy needed to send/receive a 1-bit} & 0.2575\\
511 % is used to refer this table in the text
514 Less influent energy consumption sources like when turning on the radio,
515 starting the sensor node, changing the status of a node, etc., will be neglected
516 for the sake of simplicity. Each node saves energy by switching off its radio
517 once it has received its decision status from the corresponding leader (it can
518 be itself). As explained previously in subsection~\ref{main_idea}, two kinds of
519 packets for communication are considered in our protocol: INFO packet and
520 ActiveSleep packet. To compute the energy needed by a node to transmit or
521 receive such packets, we use the equation giving the energy spent to send a
522 1-bit-content message defined in~\cite{raghunathan2002energy} (we assume
523 symmetric communication costs), and we set their respective size to 112 and
524 24~bits. The energy required to send or receive a 1-bit-content message is thus
527 Each node has an initial energy level, in Joules, which is randomly drawn in the
528 interval $[500-700]$. If its energy provision reaches a value below the
529 threshold $E_{th}=36$~Joules, the minimum energy needed for a node to stay
530 active during one period, it will no longer take part in the coverage task. This
531 value corresponds to the energy needed by the sensing phase, obtained by
532 multiplying the energy consumed in active state (9.72 mW) by the time in seconds
533 for one period (3,600 seconds), and adding the energy for the pre-sensing phases.
534 According to the interval of initial energy, a sensor may be active during at
537 In the simulations, we introduce the following performance metrics to evaluate
538 the efficiency of our approach:
540 %\begin{enumerate}[i)]
542 \item {{\bf Network Lifetime}:} we define the network lifetime as the time until
543 the coverage ratio drops below a predefined threshold. We denote by
544 $Lifetime_{95}$ (respectively $Lifetime_{50}$) the amount of time during which
545 the network can satisfy an area coverage greater than $95\%$ (respectively
546 $50\%$). We assume that the sensor network can fulfill its task until all its
547 nodes have been drained of their energy or it becomes disconnected. Network
548 connectivity is crucial because an active sensor node without connectivity
549 towards a base station cannot transmit any information regarding an observed
550 event in the area that it monitors.
553 \item {{\bf Coverage Ratio (CR)}:} it measures how well the WSN is able to
554 observe the area of interest. In our case, we discretized the sensor field
555 as a regular grid, which yields the following equation to compute the
559 \mbox{CR}(\%) = \frac{\mbox{$n$}}{\mbox{$N$}} \times 100.
561 where $n$ is the number of covered grid points by active sensors of every
562 subregions during the current sensing phase and $N$ is the total number of grid
563 points in the sensing field. In our simulations, we have a layout of $N = 51
564 \times 26 = 1326$ grid points.
567 %The accuracy of this method depends on the distance between grids. In our
568 %simulations, the sensing field has been divided into 50 by 25 grid points, which means
569 %there are $51 \times 26~ = ~ 1326$ points in total.
570 % Therefore, for our simulations, the error in the coverage calculation is less than ~ 1 $\% $.
573 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
575 \item {{\bf Energy Consumption}:} energy consumption (EC) can be seen as the
576 total amount of energy consumed by the sensors during $Lifetime_{95}$ or
577 $Lifetime_{50}$, divided by the number of periods. Formally, the computation
578 of EC can be expressed as follows:
581 \mbox{EC} = \frac{\sum\limits_{m=1}^{M} \left( E^{\mbox{com}}_m+E^{\mbox{list}}_m+E^{\mbox{comp}}_m
582 + E^{a}_m+E^{s}_m \right)}{M},
585 where $M$ corresponds to the number of periods. The total amount of energy consumed by
586 the sensors (EC) comes through taking into consideration four main energy
587 factors. The first one, denoted $E^{\scriptsize \mbox{com}}_m$, represents the
588 energy consumption spent by all the nodes for wireless communications during
589 period $m$. $E^{\scriptsize \mbox{list}}_m$, the next factor, corresponds to
590 the energy consumed by the sensors in LISTENING status before receiving the
591 decision to go active or sleep in period $m$. $E^{\scriptsize \mbox{comp}}_m$
592 refers to the energy needed by all the leader nodes to solve the integer program
593 during a period. Finally, $E^a_{m}$ and $E^s_{m}$ indicate the energy consumed
594 by the whole network in the sensing phase (active and sleeping nodes).
601 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
606 %\subsection{Performance Analysis for different subregions}
607 \subsection{Performance analysis}
610 In this subsection, we first focus on the performance of our DiLCO protocol for
611 different numbers of subregions. We consider partitions of the WSN area into
612 $2$, $4$, $8$, $16$, and $32$ subregions. Thus the DiLCO protocol is declined in
613 five versions: DiLCO-2, DiLCO-4, DiLCO-8, DiLCO-16, and DiLCO-32. Simulations
614 without partitioning the area of interest, cases which correspond to a
615 centralized approach, are not presented because they require high execution
616 times to solve the integer program and therefore consume too much energy.
618 We compare our protocol to two other approaches. The first one, called DESK and
619 proposed by ~\cite{ChinhVu} is a fully distributed coverage algorithm. The
620 second one, called GAF ~\cite{xu2001geography}, consists in dividing the region
621 into fixed squares. During the decision phase, in each square, one sensor is
622 chosen to remain active during the sensing phase.
624 \subsubsection{Coverage ratio}
626 Figure~\ref{fig3} shows the average coverage ratio for 150 deployed nodes. It
627 can be seen that both DESK and GAF provide a coverage ratio which is slightly better
628 compared to DiLCO in the first thirty periods. This can be easily explained by
629 the number of active nodes: the optimization process of our protocol activates
630 less nodes than DESK or GAF, resulting in a slight decrease of the coverage
631 ratio. In case of DiLCO-2 (respectively DiLCO-4), the coverage ratio exhibits a
632 fast decrease with the number of periods and reaches zero value in period~18
633 (respectively 46), whereas the other versions of DiLCO, DESK, and GAF ensure a
634 coverage ratio above 50\% for subsequent periods. We believe that the results
635 obtained with these two methods can be explained by a high consumption of energy
636 and we will check this assumption in the next subsection.
638 Concerning DiLCO-8, DiLCO-16, and DiLCO-32, these methods seem to be more
639 efficient than DESK and GAF, since they can provide the same level of coverage
640 (except in the first periods where DESK and GAF slightly outperform them) for a
641 greater number of periods. In fact, when our protocol is applied with a large
642 number of subregions (from 8 to 32~regions), it activates a restricted number of
643 nodes, and thus enables the extension of the network lifetime.
648 \includegraphics[scale=0.45] {R/CR.pdf}
649 \caption{Coverage ratio}
656 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
657 \subsubsection{Energy consumption}
659 Based on the results shown in Figure~\ref{fig3}, we focus on the DiLCO-16 and
660 DiLCO-32 versions of our protocol, and we compare their energy consumption with
661 the DESK and GAF approaches. For each sensor node we measure the energy consumed
662 according to its successive status, for different network densities. We denote
663 by $\mbox{\it Protocol}/50$ (respectively $\mbox{\it Protocol}/95$) the amount
664 of energy consumed while the area coverage is greater than $50\%$ (repectively
665 $95\%$), where {\it Protocol} is one of the four protocols we compare.
666 Figure~\ref{fig95} presents the energy consumptions observed for network sizes
667 going from 50 to 250~nodes. Let us notice that the same network sizes will be
668 used for the different performance metrics.
672 \includegraphics[scale=0.45]{R/EC.pdf}
673 \caption{Energy consumption per period}
677 The results depict the good performance of the different versions of our
678 protocol. Indeed, the protocols DiLCO-16/50, DiLCO-32/50, DiLCO-16/95, and
679 DiLCO-32/95 consume less energy than their DESK and GAF counterparts for a
680 similar level of area coverage. This observation reflects the larger number of
681 nodes set active by DESK and GAF.
683 \subsubsection{Execution time}
685 Another interesting point to investigate is the evolution of the execution time
686 with the size of the WSN and the number of subregions. Therefore, we report for
687 every version of our protocol the average execution times in seconds needed to
688 solve the optimization problem for different WSN sizes. The execution times are
689 obtained on a laptop DELL which has an Intel Core~i3~2370~M~(2.4~GHz) dual core
690 processor and a MIPS rating equal to 35330. The corresponding execution times on
691 a MEDUSA II sensor node are then extrapolated according to the MIPS rate of the
692 Atmels AVR ATmega103L microcontroller (6~MHz), which is equal to 6, by
693 multiplying the laptop times by $\left(\frac{35330}{2} \times
694 \frac{1}{6}\right)$. The expected times on a sensor node are reported on
699 \includegraphics[scale=0.45]{R/T.pdf}
700 \caption{Execution time in seconds}
704 Figure~\ref{fig8} shows that DiLCO-32 has very low execution times in comparison
705 with other DiLCO versions, because the activity scheduling is tackled by a
706 larger number of leaders and each leader solves an integer problem with a
707 limited number of variables and constraints. Conversely, DiLCO-2 requires to
708 solve an optimization problem with half of the network nodes and thus presents a
709 high execution time. Nevertheless if we refer to Figure~\ref{fig3}, we observe
710 that DiLCO-32 is slightly less efficient than DilCO-16 to maintain as long as
711 possible high coverage. In fact an excessive subdivision of the area of interest
712 prevents it to ensure a good coverage especially on the borders of the
713 subregions. Thus, the optimal number of subregions can be seen as a trade-off
714 between execution time and coverage performance.
719 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
720 \subsubsection{Network lifetime}
722 In the next figure, the network lifetime is illustrated. Obviously, the lifetime
723 increases with the network size, whatever the considered protocol, since the
724 correlated node density also increases. A high network density means a high
725 node redundancy which allows to turn-off many nodes and thus to prolong the
730 \includegraphics[scale=0.45]{R/LT.pdf}
731 \caption{Network lifetime}
735 As highlighted by Figure~\ref{figLT95}, when the coverage level is relaxed
736 ($50\%$) the network lifetime also improves. This observation reflects the fact
737 that the higher the coverage performance, the more nodes must be active to
738 ensure the wider monitoring. For a similar level of coverage, DiLCO outperforms
739 DESK and GAF for the lifetime of the network. More specifically, if we focus on
740 the larger level of coverage ($95\%$) in the case of our protocol, the subdivision
741 in $16$~subregions seems to be the most appropriate.
747 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
748 \section{\uppercase{Conclusion and future work}}
749 \label{sec:Conclusion and Future Works}
751 A crucial problem in WSN is to schedule the sensing activities of the different
752 nodes in order to ensure both coverage of the area of interest and longer
753 network lifetime. The inherent limitations of sensor nodes, in energy provision,
754 communication and computing capacities, require protocols that optimize the use
755 of the available resources to fulfill the sensing task. To address this
756 problem, this paper proposes a two-step approach. Firstly, the field of sensing
757 is divided into smaller subregions using the concept of divide-and-conquer
758 method. Secondly, a distributed protocol called Distributed Lifetime Coverage
759 Optimization is applied in each subregion to optimize the coverage and lifetime
760 performances. In a subregion, our protocol consists in electing a leader node
761 which will then perform a sensor activity scheduling. The challenges include how
762 to select the most efficient leader in each subregion and the best
763 representative set of active nodes to ensure a high level of coverage. To assess
764 the performance of our approach, we compared it with two other approaches using
765 many performance metrics like coverage ratio or network lifetime. We have also
766 studied the impact of the number of subregions chosen to subdivide the area of
767 interest, considering different network sizes. The experiments show that
768 increasing the number of subregions improves the lifetime. The more subregions there are, the more robust the network is against random disconnection
769 resulting from dead nodes. However, for a given sensing field and network size
770 there is an optimal number of subregions. Therefore, in case of our simulation
771 context a subdivision in $16$~subregions seems to be the most relevant. The
772 optimal number of subregions will be investigated in the future.
778 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
779 \section*{\uppercase{Acknowledgements}}
781 \noindent As a Ph.D. student, Ali Kadhum IDREES would like to gratefully
782 acknowledge the University of Babylon - IRAQ for the financial support and
783 Campus France for the received support. This paper is also partially funded by
784 the Labex ACTION program (contract ANR-11-LABX-01-01).
787 \bibliographystyle{apalike}
789 \bibliography{Example}}