]> AND Private Git Repository - Sensornets15.git/blob - Example.tex
Logo AND Algorithmique Numérique Distribuée

Private GIT Repository
bd29ee69d763da4d19ad50ad77cb5694cc7e7357
[Sensornets15.git] / Example.tex
1 \documentclass[a4paper,twoside]{article}
2
3 \usepackage{epsfig}
4 \usepackage{subfigure}
5 \usepackage{calc}
6 \usepackage{amssymb}
7 \usepackage{amstext}
8 \usepackage{amsmath}
9 \usepackage{amsthm}
10 \usepackage{multicol}
11 \usepackage{pslatex}
12 \usepackage{apalike}
13 \usepackage{SCITEPRESS}
14 \usepackage[small]{caption}
15
16 \usepackage[linesnumbered,ruled,vlined,commentsnumbered]{algorithm2e}
17 \usepackage{mathtools}  
18
19 \subfigtopskip=0pt
20 \subfigcapskip=0pt
21 \subfigbottomskip=0pt
22
23 \begin{document}
24
25 %\title{Authors' Instructions  \subtitle{Preparation of Camera-Ready Contributions to SCITEPRESS Proceedings} }
26
27 \title{Distributed Lifetime Coverage Optimization Protocol \\in Wireless Sensor Networks}
28
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}
34 }
35
36 \keywords{Wireless   Sensor   Networks,   Area   Coverage,   Network   lifetime,
37 Optimization, Scheduling.}
38
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. }
61
62 \onecolumn \maketitle \normalsize \vfill
63
64 \section{\uppercase{Introduction}}
65 \label{sec:introduction}
66
67 \noindent 
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.
82
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.
99
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}.
107
108 \section{\uppercase{Literature Review}}
109 \label{sec:Literature Review}
110
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
113 literature.
114
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. }
123
124
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.}
138
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.}
153
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
169   sets.}
170
171 <<<<<<< HEAD
172 =======
173
174
175 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
176
177 \section{\uppercase{Description of the DiLCO protocol}}
178 \label{sec:The DiLCO Protocol Description}
179
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.
185 <<<<<<< HEAD
186 =======
187
188 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
189
190 \subsection{Assumptions and models}
191
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. 
199
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.
208
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.
215
216
217 \subsection{Main idea}
218 \label{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.
222
223 \begin{figure}[ht!]
224 \centering
225 \includegraphics[width=75mm]{FirstModel.pdf} % 70mm
226 \caption{DiLCO protocol}
227 \label{fig2}
228 \end{figure} 
229
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.
245
246 During the execution of the DiLCO protocol, two kinds of packet will be used:
247 %\begin{enumerate}[(a)]
248 \begin{itemize} 
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.
253 \end{itemize}
254 %\end{enumerate}
255 and each sensor node will have five possible status in the network:
256 %\begin{enumerate}[(a)] 
257 \begin{itemize} 
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.
263 \end{itemize}
264 %\end{enumerate}
265
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.
282
283 <<<<<<< HEAD
284 =======
285
286
287
288 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
289
290 \begin{algorithm}[h!]                
291
292   \BlankLine
293   %\emph{Initialize the sensor node and determine it's position and subregion} \; 
294   
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}\;
301       
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 $}\;
311       }   
312       \Else{
313         \emph{$s_j.status$ = LISTENING}\;
314         \emph{Wait $ActiveSleep()$ packet from the Leader}\;
315
316         \emph{Update $RE_j $}\;
317       }  
318       %  }
319   }
320   \Else { Exclude $s_j$ from entering in the current sensing phase}
321   
322  %   \emph{return X} \;
323 \caption{DiLCO($s_j$)}
324 \label{alg:DiLCO}
325
326 \end{algorithm}
327
328 \section{\uppercase{Coverage problem formulation}}
329 \label{cp}
330
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$.
339
340 \noindent Let $\alpha_{jp}$ denote the indicator function of whether the primary
341 point $p$ is covered, that is:
342 \begin{equation}
343 \alpha_{jp} = \left \{ 
344 \begin{array}{l l}
345   1 & \mbox{if the primary point $p$ is covered} \\
346  & \mbox{by sensor node $j$}, \\
347   0 & \mbox{otherwise.}\\
348 \end{array} \right.
349 %\label{eq12} 
350 \end{equation}
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:
353 \begin{equation}
354 X_{j} = \left \{ 
355 \begin{array}{l l}
356   1& \mbox{if sensor $j$  is active,} \\
357   0 &  \mbox{otherwise.}\\
358 \end{array} \right.
359 %\label{eq11} 
360 \end{equation}
361 We define the Overcoverage variable $\Theta_{p}$ as:
362 \begin{equation}
363  \Theta_{p} = \left \{ 
364 \begin{array}{l l}
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.}\\
368 \end{array} \right.
369 \label{eq13} 
370 \end{equation}
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:
374 \begin{equation}
375 U_{p} = \left \{ 
376 \begin{array}{l l}
377   1 &\mbox{if the primary point $p$ is not covered,} \\
378   0 & \mbox{otherwise.}\\
379 \end{array} \right.
380 \label{eq14} 
381 \end{equation}
382
383 \noindent Our coverage optimization problem can then be formulated as follows:
384 \begin{equation} \label{eq:ip2r}
385 \left \{
386 \begin{array}{ll}
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\\
390 %\label{c1} 
391 %\sum_{t \in T} X_{j,t} \leq \frac{RE_j}{e_t} &\forall j \in J \\
392 %\label{c2}
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
396 \end{array}
397 \right.
398 \end{equation}
399
400 \begin{itemize}
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).
407 \end{itemize}
408
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
417 period.
418
419 \section{\uppercase{Protocol evaluation}}  
420 \label{sec:Simulation Results and Analysis}
421 \noindent \subsection{Simulation framework}
422
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.
426
427 \begin{table}[ht]
428 \caption{Relevant parameters for network initializing.}
429 % title of Table
430 \centering
431 % used for centering table
432 \begin{tabular}{c|c}
433 % centered columns (4 columns)
434       \hline
435 %inserts double horizontal lines
436 Parameter & Value  \\ [0.5ex]
437    
438 %Case & Strategy (with Two Leaders) & Strategy (with One Leader) & Simple Heuristic \\ [0.5ex]
439 % inserts table
440 %heading
441 \hline
442 % inserts single horizontal line
443 Sensing  Field  & $(50 \times 25)~m^2 $   \\
444 % inserting body of the table
445 %\hline
446 Nodes Number &  50, 100, 150, 200 and 250~nodes   \\
447 %\hline
448 Initial Energy  & 500-700~joules  \\  
449 %\hline
450 Sensing Period & 60 Minutes \\
451 $E_{th}$ & 36 Joules\\
452 $R_s$ & 5~m   \\     
453 %\hline
454 $w_{\Theta}$ & 1   \\
455 % [1ex] adds vertical space
456 %\hline
457 $w_{U}$ & $|P|^2$
458 %inserts single line
459 \end{tabular}
460 \label{table3}
461 % is used to refer this table in the text
462 \end{table}
463
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
468 high coverage ratio.
469
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.
482
483 \begin{table}[ht]
484 \caption{Energy consumption model}
485 % title of Table
486 \centering
487 % used for centering table
488 {\scriptsize
489 \begin{tabular}{|c|c|c|c|c|}
490 % centered columns (4 columns)
491       \hline
492 %inserts double horizontal lines
493 Sensor status & MCU   & Radio & Sensing & Power (mW) \\ [0.5ex]
494 \hline
495 % inserts single horizontal line
496 Listening & ON & ON & ON & 20.05 \\
497 % inserting body of the table
498 \hline
499 Active & ON & OFF & ON & 9.72 \\
500 \hline
501 Sleep & OFF & OFF & OFF & 0.02 \\
502 \hline
503 Computation & ON & ON & ON & 26.83 \\
504 %\hline
505 %\multicolumn{4}{|c|}{Energy needed to send/receive a 1-bit} & 0.2575\\
506  \hline
507 \end{tabular}
508 }
509
510 \label{table4}
511 % is used to refer this table in the text
512 \end{table}
513
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
525  equal to 0.2575 mW.
526
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
535 most 20 periods.
536
537 In the simulations,  we introduce the following performance  metrics to evaluate
538 the efficiency of our approach:
539
540 %\begin{enumerate}[i)]
541 \begin{itemize}
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.
551   
552     
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
556   coverage ratio: 
557 \begin{equation*}
558 \scriptsize
559 \mbox{CR}(\%) = \frac{\mbox{$n$}}{\mbox{$N$}} \times 100.
560 \end{equation*}
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.
565 <<<<<<< HEAD
566 =======
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 $\% $.
571
572
573 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
574
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:
579   \begin{equation*}
580     \scriptsize
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},
583   \end{equation*}
584
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).
595
596 <<<<<<< HEAD
597 =======
598
599
600
601 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
602 \end{itemize}
603 %\end{enumerate}
604
605
606 %\subsection{Performance Analysis for different subregions}
607 \subsection{Performance analysis}
608 \label{sub1}
609
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.
617
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.
623
624 \subsubsection{Coverage ratio} 
625
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.
637
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.
644
645 \parskip 0pt    
646 \begin{figure}[t!]
647 \centering
648  \includegraphics[scale=0.45] {R/CR.pdf} 
649 \caption{Coverage ratio}
650 \label{fig3}
651 \end{figure} 
652
653 <<<<<<< HEAD
654 =======
655
656 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
657 \subsubsection{Energy consumption}
658
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.
669
670 \begin{figure}[h!]
671 \centering
672 \includegraphics[scale=0.45]{R/EC.pdf} 
673 \caption{Energy consumption per period}
674 \label{fig95}
675 \end{figure} 
676
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.
682
683 \subsubsection{Execution time}
684
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
695 Figure~\ref{fig8}.
696
697 \begin{figure}[h!]
698 \centering
699 \includegraphics[scale=0.45]{R/T.pdf}  
700 \caption{Execution time in seconds}
701 \label{fig8}
702 \end{figure} 
703
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.
715
716 <<<<<<< HEAD
717 =======
718
719 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
720 \subsubsection{Network lifetime}
721
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
726 network lifetime.
727
728 \begin{figure}[h!]
729 \centering
730 \includegraphics[scale=0.45]{R/LT.pdf}  
731 \caption{Network lifetime}
732 \label{figLT95}
733 \end{figure} 
734
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.
742
743 <<<<<<< HEAD
744 =======
745
746
747 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
748 \section{\uppercase{Conclusion and future work}}
749 \label{sec:Conclusion and Future Works} 
750
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.
773
774 <<<<<<< HEAD
775 =======
776
777
778 >>>>>>> ec736a6c4605ef475156098f1b75d72120a294ba
779 \section*{\uppercase{Acknowledgements}}
780
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).
785
786 %\vfill
787 \bibliographystyle{apalike}
788 {\small
789 \bibliography{Example}}
790
791 %\vfill
792 \end{document}