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

Private GIT Repository
abb42a49883b295630f4fb006bc3ebb526bf9d43
[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-Comte, 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. As  a  first step  we  partition the  area  of interest  into
46   subregions using a classical  divide-and-conquer method. Our DiLCO protocol is
47   then distributed  on the sensor nodes in  each subregion in a  second step. To
48   fulfill  our   objective,  the   proposed  protocol  combines   two  effective
49   techniques:   a  leader   election   in  each   subregion,   followed  by   an
50   optimization-based node activity scheduling  performed by each elected leader.
51   This two-step process takes place periodically, in order to choose a small set
52   of nodes remaining  active for sensing during a time slot.   Each set is built
53   to ensure  coverage at  a low  energy cost, allowing  to optimize  the network
54   lifetime. More  precisely, a period  consists of four  phases: (i)~Information
55   Exchange,  (ii)~Leader   Election,  (iii)~Decision,  and   (iv)~Sensing.   The
56   decision process,  which result in  an activity scheduling vector,  is carried
57   out by a leader node through  the solving of an integer program. In comparison
58   with  some other  protocols, the  simulations  done using  the discrete  event
59   simulator OMNeT++ show that our approach  is able to increase the WSN lifetime
60   and provides improved coverage performance. }
61
62 \onecolumn \maketitle \normalsize \vfill
63
64 \section{\uppercase{Introduction}}
65 \label{sec:introduction}
66 \noindent 
67 Energy efficiency  is a crucial issue  in wireless sensor  networks since sensor
68 nodes drain their  energy from batteries. In fact,  strong constraints on energy
69 consumption,  in order  to maximize  the network  lifetime, represent  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. The  most discussed coverage problems  in literature
75 can  be classified into  three types  \cite{li2013survey}: area  coverage (where
76 every point inside an area is  to be monitored), target coverage (where the main
77 objective is to  cover only a finite number of  discrete points called targets),
78 and  barrier coverage (to  prevent intruders  from entering  into the  region of
79 interest). On the one  hand we want to monitor the area  of interest in the most
80 efficient way~\cite{Nayak04}. On the other hand we want to use as less energy as
81 possible. % TO BE CONTINUED
82 Sensor nodes runs on batteries with limited capacities~\cite{Sudip03}
83 and  it  is  impossible,  difficult  or expensive  to  recharge  and/or  replace
84 batteries  in remote,  hostile, or  unpractical environments.  Therefore,  it is
85 desired that  the WSNs  are deployed with  high densities  so as to  exploit the
86 overlapping sensing regions  of some sensor nodes to save  energy by turning off
87 some of them during the sensing phase to prolong the network lifetime.
88
89 In this paper we concentrate on  the area coverage problem with the objective of
90 maximizing the network lifetime by using DiLCO protocol to maintain the coverage
91 and  to improve  the lifetime  in WSNs.  The area  of interest  is  divided into
92 subregions using divide-and-conquer method and an activity scheduling for sensor
93 nodes is planned by the elected leader  in each subregion. In fact, the nodes in
94 a subregion can be  seen as a cluster where each node  sends sensing data to the
95 cluster   head  or   the  sink   node.    Furthermore,  the   activities  in   a
96 subregion/cluster can  continue even  if another cluster  stops due to  too many
97 node failures.  Our DiLCO protocol considers periods, where a period starts with
98 a discovery phase  to exchange information between sensors  of the subregion, in
99 order to choose in a suitable manner a sensor node (the leader) to carry out the
100 coverage  strategy.  Our  DiLCO protocol  involves solving  an  integer program,
101 which  provides the  activation of  the  sensors for  the sensing  phase of  the
102 current period.
103
104 The remainder  of the  paper continues with  Section~\ref{sec:Literature Review}
105 where a  review of some related  works is presented. The  next section describes
106 the  DiLCO  protocol,  followed   in  Section~\ref{cp}  by  the  coverage  model
107 formulation    which    is    used     to    schedule    the    activation    of
108 sensors. Section~\ref{sec:Simulation Results  and Analysis} shows the simulation
109 results. The paper ends with conclusions and some suggestions for futher work in
110 Section~\ref{sec:Conclusion and Future Works}.
111
112 \section{\uppercase{Literature Review}}
113 \label{sec:Literature Review}
114 \noindent In this section, we summarize some related works regarding coverage lifetime maximization and scheduling, and distinguish our DiLCO protocol from the works presented in the literature. Some algorithms have been developed in ~\cite{yang2014energy,ChinhVu,vashistha2007energy,deschinkel2012column,shi2009,qu2013distributed,ling2009energy,xin2009area,cheng2014achieving,ling2009energy} to solve the area coverage problem so as to preserve coverage and prolong the network lifetime.
115
116
117 Yang et al.~\cite{yang2014energy} investigated full area coverage problem
118 under the probabilistic sensing model in the sensor networks. They have studied the relationship between the
119 coverage of two adjacent points mathematically and then convert the problem of full area coverage into point coverage problem. They proposed $\varepsilon$-full area coverage optimization (FCO) algorithm to select a subset
120 of sensors to provide probabilistic area coverage dynamically so as to extend the network lifetime.
121
122
123 Vu et al.~\cite{ChinhVu} proposed a localized and distributed greedy algorithm named DESK for generating non-disjoint cover sets which provide the k-area coverage for the whole network. 
124
125  
126 Qu et al.~\cite{qu2013distributed} developed a distributed algorithm using  adjustable sensing sensors
127 for maintaining the full coverage of such sensor networks. The
128 algorithm contains two major parts: the first part aims at
129 providing $100\%$ coverage and the second part aims at saving
130 energy by decreasing the sensing radius.
131
132 Shi et al.~\cite{shi2009} modeled the Area Coverage Problem (ACP), which will be changed into a set coverage
133 problem. By using this model, they are proposed  an  Energy-Efficient central-Scheduling greedy algorithm, which can reduces energy consumption and increases network lifetime, by selecting a appropriate subset of sensor nodes to support the networks periodically. 
134
135 The work in~\cite{cheng2014achieving} presented a unified sensing architecture for duty cycled sensor networks, called uSense, which comprises three ideas: Asymmetric Architecture, Generic Switching and Global Scheduling. The objective is to  provide a flexible and efficient coverage in sensor networks.
136
137  In~\cite{ling2009energy}, the lifetime of
138 a sensor node is divided into epochs. At each epoch, the
139 base station deduces the current sensing coverage requirement
140 from application or user request. It then applies the heuristic algorithm in order to produce the set of active nodes which take the mission of sensing during the current epoch.  After that, the produced schedule is sent to the sensor nodes in the network. 
141
142
143 \iffalse
144
145 The work in ~\cite{vu2009delaunay} considered the area coverage problem for variable sensing radii in WSNs by improving the energy balancing heuristic proposed in ~\cite{wang2007energy} so that  the area of interest can be full covered using Delaunay triangulation structure.
146
147 Diongue and Thiare~\cite{diongue2013alarm} proposed an energy aware sleep scheduling algorithm for lifetime maximization in wireless sensor networks (ALARM).  The proposed approach permits to schedule redundant nodes according to the weibull distribution. This work did not analyze the ALARM scheme under the coverage problem. 
148  
149
150 In~\cite{xin2009area}, the authors proposed a circle intersection localized coverage algorithm
151 to maintain connectivity  based  on loose connectivity critical condition
152 . By using the connected coverage node set, it can maintain network
153 connection in the case which loose condition is not meet.
154 The authors in ~\cite{vashistha2007energy} addressed the full area coverage problem using information
155 coverage. They are proposed a low-complexity heuristic algorithm to obtain full area information covers (FAIC), which they refer to as Grid Based FAIC (GB-FAIC) algorithm. Using these FAICs, they are obtained the optimal schedule for applying the sensing activity of sensor nodes  in order to
156 achieve increased sensing lifetime of the network. 
157
158
159 \fi
160   
161
162
163 In \cite{xu2001geography}, Xu et al. proposed a Geographical Adaptive Fidelity (GAF) algorithm, which uses geographic location information to divide the area of interest into fixed square grids. Within each grid, it keeps only one node staying awake to take the responsibility of sensing and communication.
164
165 The main contributions of our DiLCO Protocol can be summarized as follows:
166 (1) The distributed optimization over the subregions in the area of interest, 
167 (2) The distributed dynamic leader election at each round by each sensor node in the subregion, 
168 (3) The primary point coverage model to represent each sensor node in the network, 
169 (4) The activity scheduling based optimization on the subregion, which are based on  the primary point coverage model to activate as less number as possible of sensor nodes  to take the mission of the coverage in each subregion, and (5) The improved energy consumption model.
170
171 \iffalse
172 The work presented in~\cite{luo2014parameterized,tian2014distributed} tries to solve the target coverage problem so as to extend the network lifetime since it is easy to verify the coverage status of discreet target.
173 %Je ne comprends pas la phrase ci-dessus
174 The work proposed in~\cite{kim2013maximum} considers the barrier-coverage problem in WSNs. The final goal is to maximize the network lifetime such that any penetration of the intruder is detected.
175 %inutile de parler de ce papier car il concerne barrier coverage
176 In \cite{ChinhVu},  the authors propose a localized and distributed greedy algorithm named DESK for generating non-disjoint cover sets which provide the k-coverage for the whole network. 
177 Our Work in~\cite{idrees2014coverage} proposes a coverage optimization protocol to improve the lifetime in heterogeneous energy wireless sensor networks. In this work, the coverage protocol distributed in each sensor node in the subregion but the optimization take place over the the whole subregion. We are considered only distributing the coverage protocol over two subregions.  
178
179 The work presented in ~\cite{Zhang} focuses on a distributed clustering method, which aims to extend the network lifetime, while the coverage is ensured.
180
181 The work proposed by \cite{qu2013distributed} considers the coverage problem in WSNs where each sensor has variable sensing radius. The final objective is to maximize the network coverage lifetime in WSNs.
182 \fi
183
184 \iffalse
185 Casta{\~n}o et al.~\cite{castano2013column} proposed a multilevel approach based on column generation (CG) to  extend the network lifetime with connectivity and coverage constraints. They are included  two heuristic methods  within the CG framework so as to accelerate the solution process. 
186 In \cite{diongue2013alarm}, diongue is proposed an energy Aware sLeep scheduling AlgoRithm for lifetime maximization in WSNs (ALARM) algorithm for coverage lifetime maximization in wireless sensor networks. ALARM is sensor node scheduling approach for lifetime maximization in WSNs in which it schedule redundant nodes according to the weibull distribution  taking into consideration frequent nodes failure.
187 Yu et al.~\cite{yu2013cwsc} presented a connected k-coverage working sets construction
188 approach (CWSC) to maintain k-coverage and connectivity. This approach try to select the minimum number of connected sensor nodes that can provide k-coverage ($k \geq 1$).
189 In~\cite{cheng2014achieving}, the authors are presented a unified sensing architecture for duty cycled sensor networks, called uSense, which comprises three ideas: Asymmetric Architecture, Generic Switching and Global Scheduling. The objective is to  provide a flexible and efficient coverage in sensor networks.
190
191 In~\cite{yang2013energy}, the authors are investigated full area coverage problem
192 under the probabilistic sensing model in the sensor networks. %They are designed $\varepsilon-$full area coverage optimization (FCO) algorithm to select a subset of sensors to provide probabilistic area coverage dynamically so as to extend the network lifetime.
193 In \cite{xu2001geography}, Xu et al. proposed a Geographical Adaptive Fidelity (GAF) algorithm, which uses geographic location information to divide the area of interest into fixed square grids. Within each grid, it keeps only one node staying awake to take the responsibility of sensing and communication.
194
195 The main contributions of our DiLCO Protocol can be summarized as follows:
196 (1) The distributed optimization over the subregions in the area of interest, 
197 (2) The distributed dynamic leader election at each round by each sensor node in the subregion, 
198 (3) The primary point coverage model to represent each sensor node in the network, 
199 (4) The activity scheduling based optimization on the subregion, which are based on  the primary point coverage model to activate as less number as possible of sensor nodes  to take the mission of the coverage in each subregion,
200 (5) The improved energy consumption model.
201
202 \fi
203
204 \section{ The DiLCO Protocol Description}
205 \label{sec:The DiLCO Protocol Description}
206
207 \noindent In this section, we introduce a Distributed Lifetime Coverage Optimization protocol, which is called DiLCO. It is  distributed on each subregion in the area of interest. It is based on two efficient techniques: network leader election and sensor activity scheduling for coverage preservation and energy conservation continuously and efficiently to maximize the lifetime in the network.  
208 \iffalse The main features of our DiLCO protocol:
209 i)It divides the area of interest into subregions by using divide-and-conquer concept, ii)It requires only the information of the nodes within the subregion, iii) it divides the network lifetime into rounds, iv)It based on the autonomous distributed decision by the nodes in the subregion to elect the Leader, v)It apply the activity scheduling based optimization on the subregion, vi)  it achieves an energy consumption balancing among the nodes in the subregion by selecting different nodes as a leader during the network lifetime, vii) It uses the optimization to select the best representative set of sensors in the subregion by optimize the coverage and the lifetime over the area of interest, viii)It uses our proposed primary point coverage model, which represent the sensing range of the sensor as a set of points, which are used by the our optimization algorithm, ix) It uses a simple energy model that takes communication, sensing and computation energy consumptions into account to evaluate the performance of our protocol.
210 \fi
211 \subsection{ Assumptions and Models}
212 \noindent We consider  a randomly and  uniformly deployed network  consisting of
213 static  wireless sensors. The  wireless sensors  are deployed  in high
214 density to ensure initially a high coverage ratio of the interested area. We
215 assume that  all nodes are  homogeneous in terms of  communication and
216 processing capabilities and heterogeneous in term of energy provision.
217 The  location  information is  available  to  the  sensor node  either
218 through hardware such as embedded GPS or through location discovery
219 algorithms. We consider a boolean  disk coverage model which is the most
220 widely used sensor coverage model in the literature. Each sensor has a
221 constant sensing range $R_s$. All space points within a disk centered
222 at the sensor with the radius of the sensing range is said to be
223 covered by this sensor. We also assume that the communication range $R_c \geq 2R_s$.
224 In  fact,   Zhang  and Zhou~\cite{Zhang05} proved that if the transmission range fulfills the
225 previous hypothesis, a complete coverage of a convex area implies
226 connectivity among the working nodes in the active mode.
227
228 \indent Instead of working with the coverage area, we consider for each
229 sensor a set of points called  primary points~\cite{idrees2014coverage}. We also assume that the
230 sensing disk defined  by a sensor is covered if all the primary points of
231 this sensor are covered.
232
233 \iffalse
234 By  knowing the  position (point  center: ($p_x,p_y$))  of  a wireless
235 sensor node  and its $R_s$,  we calculate the primary  points directly
236 based on the proposed model. We  use these primary points (that can be
237 increased or decreased if necessary)  as references to ensure that the
238 monitored  region  of interest  is  covered  by  the selected  set  of
239 sensors, instead of using all the points in the area.
240
241 \indent  We can  calculate  the positions of the selected primary
242 points in the circle disk of the sensing range of a wireless sensor
243 node (see figure~\ref{fig1}) as follows:\\
244 $(p_x,p_y)$ = point center of wireless sensor node\\  
245 $X_1=(p_x,p_y)$ \\ 
246 $X_2=( p_x + R_s * (1), p_y + R_s * (0) )$\\           
247 $X_3=( p_x + R_s * (-1), p_y + R_s * (0)) $\\
248 $X_4=( p_x + R_s * (0), p_y + R_s * (1) )$\\
249 $X_5=( p_x + R_s * (0), p_y + R_s * (-1 )) $\\
250 $X_6= ( p_x + R_s * (\frac{-\sqrt{2}}{2}), p_y + R_s * (0)) $\\
251 $X_7=( p_x + R_s *  (\frac{\sqrt{2}}{2}), p_y + R_s * (0))$\\
252 $X_8=( p_x + R_s * (\frac{-\sqrt{2}}{2}), p_y + R_s * (\frac{-\sqrt{2}}{2})) $\\
253 $X_9=( p_x + R_s * (\frac{\sqrt{2}}{2}), p_y + R_s * (\frac{-\sqrt{2}}{2})) $\\
254 $X_{10}=( p_x + R_s * (\frac{-\sqrt{2}}{2}), p_y + R_s * (\frac{\sqrt{2}}{2})) $\\
255 $X_{11}=( p_x + R_s * (\frac{\sqrt{2}}{2}), p_y + R_s * (\frac{\sqrt{2}}{2})) $\\
256 $X_{12}=( p_x + R_s * (0), p_y + R_s * (\frac{\sqrt{2}}{2})) $\\
257 $X_{13}=( p_x + R_s * (0), p_y + R_s * (\frac{-\sqrt{2}}{2})) $.
258
259  \begin{figure}[h!]
260 \centering
261  \begin{multicols}{3}
262 \centering
263 %\includegraphics[scale=0.20]{fig21.pdf}\\~ ~ ~ ~ ~(a)
264 %\includegraphics[scale=0.20]{fig22.pdf}\\~ ~ ~ ~ ~(b)
265 \includegraphics[scale=0.25]{principles13.pdf}%\\~ ~ ~ ~ ~(c)
266 %\includegraphics[scale=0.10]{fig25.pdf}\\~ ~ ~(d)
267 %\includegraphics[scale=0.10]{fig26.pdf}\\~ ~ ~(e)
268 %\includegraphics[scale=0.10]{fig27.pdf}\\~ ~ ~(f)
269 \end{multicols} 
270 \caption{Wireless Sensor Node represented by 13 primary points}
271 %\caption{Wireless Sensor Node represented by (a)5, (b)9 and (c)13 primary points respectively}
272 \label{fig1}
273 \end{figure}
274
275 \fi
276
277 \subsection{The Main Idea}
278 \noindent The   area  of  interest   can  be  divided using the
279 divide-and-conquer strategy into smaller areas  called subregions and
280 then  our coverage  protocol  will be  implemented  in each  subregion
281 simultaneously. Our DiLCO protocol works in periods fashion as shown in figure~\ref{fig2}.
282 \begin{figure}[ht!]
283 \centering
284 \includegraphics[width=75mm]{FirstModel.pdf} % 70mm
285 \caption{DiLCO protocol}
286 \label{fig2}
287 \end{figure} 
288
289 %Modifier la figure pour faire apparaitre des periodes et dans le schema en bleu, indiquer sensing round au lieu de sensing tout seul.
290
291 Each period  is divided  into 4 phases  : Information  (INFO) Exchange,
292 Leader  Election, Decision,  and  Sensing.  For  each  period there  is
293 exactly one set cover responsible for the sensing task. This protocol is
294 more reliable  against an unexpected node failure  because it works
295 in periods. On the  one hand,  if a node failure is detected before
296 making the decision, the node will not participate to this phase, and,
297 on the other hand, if the  node failure occurs after the decision, the
298 sensing task of the network  will be temporarily affected: only during
299 the period of sensing until a new period starts, since a new set cover
300 will take charge of the sensing task in the next period.  The energy
301 consumption and some other constraints can easily be taken into
302 account since the sensors can update and then exchange  their
303 information (including their residual energy) at the beginning of each
304 period.  However,   the  pre-sensing  phases   (INFO  Exchange,  Leader
305 Election,  Decision) are energy  consuming for  some nodes,  even when
306 they do not  join the network to monitor the  area. 
307 We define two types of packets to be used by our DiLCO protocol.
308 %\begin{enumerate}[(a)]
309 \begin{itemize} 
310 \item INFO packet: sent by each sensor node to all the nodes inside a same subregion for information exchange.
311 \item ActiveSleep packet: sent by the leader to all the nodes in its subregion to inform them to be Active or Sleep during the sensing phase.
312 \end{itemize}
313 %\end{enumerate}
314
315 There are five status for each sensor node in the network :
316 %\begin{enumerate}[(a)] 
317 \begin{itemize} 
318 \item LISTENING: Sensor is waiting for a decision (to be active or not)
319 \item COMPUTATION: Sensor applies the optimization process as leader
320 \item ACTIVE: Sensor is active
321 \item SLEEP: Sensor is turned off
322 \item COMMUNICATION: Sensor is transmitting or receiving packet
323 \end{itemize}
324 %\end{enumerate}
325 %Below, we describe each phase in more details.
326 Algorithm 1 gives a brief description of the protocol applied by each sensor node (denoted by $s_j$ for a sensor node indexed by $j$).
327 Initially, the sensor node checks its remaining energy in order to participate in the current period. After that, all the sensors collect position coordinates, remaining energy $RE_j$, sensor node id, and the number of its one-hop live neighbors during the information exchange. 
328 Then all the sensor nodes in the same subregion will select the leader based on the received informations. The selection criteria for the leader in order  of priority  are: larger number  of neighbours,  larger remaining  energy, and  then in  case of equality, larger index. After that, if the sensor node is leader, it will execute the integer program algorithm (see section~\ref{cp}) which provides a set of sensors planned to be active in the sensing round. As leader, it will send an Active-Sleep packet to each sensor in the same subregion to indicate it if it has to be active or not. On the contrary, if the sensor is not the leader, it will wait for the Active-Sleep packet to know its state for the sensing round.
329
330
331
332 \iffalse
333 \subsubsection{Information Exchange Phase}
334
335 Each sensor node $j$ sends its position, remaining energy $RE_j$, and
336 the number of neighbours  $NBR_j$ to all wireless sensor nodes in
337 its subregion by using an INFO packet and then listens to the packets
338 sent from  other nodes.  After that, each  node will  have information
339 about  all the  sensor  nodes in  the  subregion.  In  our model,  the
340 remaining energy corresponds to the time that a sensor can live in the
341 active mode.
342
343 \subsubsection{Leader Election Phase}
344 This  step includes choosing  the Wireless  Sensor Node  Leader (WSNL),
345 which  will  be  responsible  for executing  the coverage  algorithm.  Each
346 subregion  in  the   area  of  interest  will  select   its  own  WSNL
347 independently  for each  round.  All the  sensor  nodes cooperate  to
348 select WSNL.  The nodes in the  same subregion will  select the leader
349 based on  the received  information from all  other nodes in  the same
350 subregion.  The selection criteria  in order  of priority  are: larger
351 number  of neighbours,  larger remaining  energy, and  then in  case of
352 equality, larger index. 
353
354 \subsubsection{Decision phase}
355 The  WSNL will  solve an  integer  program (see  section~\ref{cp})  to
356 select which sensors will be  activated in the following sensing phase
357 to cover  the subregion.  WSNL will send  Active-Sleep packet  to each
358 sensor in the subregion based on the algorithm's results.
359
360
361 \subsubsection{Sensing phase}
362 Active  sensors  in the  round  will  execute  their sensing  task  to
363 preserve maximal  coverage in the  region of interest. We  will assume
364 that the cost  of keeping a node awake (or asleep)  for sensing task is
365 the same  for all wireless sensor  nodes in the  network.  Each sensor
366 will receive  an Active-Sleep  packet from WSNL  informing it  to stay
367 awake or to go to sleep  for a time  equal to  the period of  sensing until
368 starting a new round. Algorithm 1, which
369 will be executed by each node at the beginning of a round, explains how the
370 Active-Sleep packet is obtained.
371
372 \fi
373
374
375 \iffalse
376 \subsection{DiLCO protocol Algorithm}
377 we first show the pseudo-code of DiLCO protocol, which is executed by each sensor in the subregion and then describe it in more detail. 
378 \fi
379
380 \begin{algorithm}[h!]                
381  % \KwIn{all the parameters related to information exchange}
382 %  \KwOut{$winer-node$ (: the id of the winner sensor node, which is the leader of current round)}
383   \BlankLine
384   %\emph{Initialize the sensor node and determine it's position and subregion} \; 
385   
386   \If{ $RE_j \geq E_{th}$ }{
387       \emph{$s_j.status$ = COMMUNICATION}\;
388       \emph{Send $INFO()$ packet to other nodes in the subregion}\;
389       \emph{Wait $INFO()$ packet from other nodes in the subregion}\; 
390       %\emph{UPDATE $RE_j$ for every sent or received INFO Packet}\;
391       %\emph{ Collect information and construct the list L for all nodes in the subregion}\;
392       
393       %\If{ the received INFO Packet = No. of nodes in it's subregion -1  }{
394       \emph{LeaderID = Leader election}\;
395       \If{$ s_j.ID = LeaderID $}{
396         \emph{$s_j.status$ = COMPUTATION}\;
397         \emph{$\left\{\left(X_{1},\dots,X_{k},\dots,X_{J}\right)\right\}$ =
398           Execute Integer Program Algorithm($J$)}\;
399         \emph{$s_j.status$ = COMMUNICATION}\;
400         \emph{Send $ActiveSleep()$ to each node $k$ in subregion} \;
401         \emph{Update $RE_j $}\;
402       }   
403       \Else{
404         \emph{$s_j.status$ = LISTENING}\;
405         \emph{Wait $ActiveSleep()$ packet from the Leader}\;
406         % \emph{After receiving Packet, Retrieve the schedule and the $T$ rounds}\;
407         \emph{Update $RE_j $}\;
408       }  
409       %  }
410   }
411   \Else { Exclude $s_j$ from entering in the current sensing phase}
412   
413  %   \emph{return X} \;
414 \caption{DiLCO($s_j$)}
415 \label{alg:DiLCO}
416
417 \end{algorithm}
418
419 \iffalse
420 The DiLCO protocol work in rounds and executed at each sensor node in the network , each sensor node can still sense data while being in
421 LISTENING mode. Thus, by entering the LISTENING mode at the beginning of each round,
422 sensor nodes still executing sensing task while participating in the leader election and decision phases. More specifically, The DiLCO protocol algorithm works as follow: 
423 Initially, the sensor node check it's remaining energy in order to participate in the current round. Each sensor node determines it's position and it's subregion based Embedded GPS  or Location Discovery Algorithm. After that, All the sensors collect position coordinates, current remaining energy, sensor node id, and the number of its one-hop live neighbors during the information exchange. It stores this information into a list L.
424 The sensor node enter in listening mode waiting to receive ActiveSleep packet from the leader to take the decision. Each sensor node will execute the Algorithm~1 to know who is the leader. After that, if the sensor node is leader, It will execute the integer program algorithm ( see section~\ref{cp}) to optimize the coverage and the lifetime in it's subregion. After the decision, the optimization approach will select the set of sensor nodes to take the mission of coverage during the sensing phase. The leader will send ActiveSleep packet to each sensor node in the subregion to inform him to it's status during the period of sensing, either Active or sleep until the starting of next round. Based on the decision, the leader as other nodes in subregion, either go to be active or go to be sleep during current sensing phase. the other nodes in the same subregion will stay in listening mode waiting the ActiveSleep packet from the leader. After finishing the time period for sensing, all the sensor nodes in the same subregion will start new round by executing the DiLCO protocol and the lifetime in the subregion will continue until all the sensor nodes are died or the network becomes disconnected in the subregion.
425 \fi
426
427
428 \section{Coverage problem formulation}
429 \label{cp}
430
431 \indent   Our   model   is   based   on  the   model   proposed   by
432 \cite{pedraza2006} where the objective is  to find a maximum number of
433 disjoint  cover sets.   To accomplish  this goal,  authors  proposed an
434 integer program, which forces undercoverage and overcoverage of targets
435 to  become  minimal at  the  same  time.   They use  binary  variables
436 $x_{jl}$ to indicate  if sensor $j$ belongs to cover  set $l$.  In our
437 model,  we  consider  binary  variables $X_{j}$,  which  determine  the
438 activation of  sensor $j$ in the  sensing round. We also
439 consider  primary points  as targets.   The set  of primary  points is
440 denoted by $P$ and the set of sensors by $J$.
441
442 \noindent  For  a primary  point  $p$,  let  $\alpha_{jp}$ denote  the
443 indicator function of whether the point $p$ is covered, that is:
444 \begin{equation}
445 \alpha_{jp} = \left \{ 
446 \begin{array}{l l}
447   1 & \mbox{if the primary point $p$ is covered} \\
448  & \mbox{by sensor node $j$}, \\
449   0 & \mbox{otherwise.}\\
450 \end{array} \right.
451 %\label{eq12} 
452 \end{equation}
453 The number of active sensors that cover the primary point $p$ is equal
454 to $\sum_{j \in J} \alpha_{jp} * X_{j}$ where:
455 \begin{equation}
456 X_{j} = \left \{ 
457 \begin{array}{l l}
458   1& \mbox{if sensor $j$  is active,} \\
459   0 &  \mbox{otherwise.}\\
460 \end{array} \right.
461 %\label{eq11} 
462 \end{equation}
463 We define the Overcoverage variable $\Theta_{p}$ as:
464 \begin{equation}
465  \Theta_{p} = \left \{ 
466 \begin{array}{l l}
467   0 & \mbox{if the primary point}\\
468     & \mbox{$p$ is not covered,}\\
469   \left( \sum_{j \in J} \alpha_{jp} * X_{j} \right)- 1 & \mbox{otherwise.}\\
470 \end{array} \right.
471 \label{eq13} 
472 \end{equation}
473 \noindent More precisely, $\Theta_{p}$ represents the number of active
474 sensor  nodes  minus  one  that  cover the  primary  point  $p$.\\
475 The Undercoverage variable $U_{p}$ of the primary point $p$ is defined
476 by:
477 \begin{equation}
478 U_{p} = \left \{ 
479 \begin{array}{l l}
480   1 &\mbox{if the primary point $p$ is not covered,} \\
481   0 & \mbox{otherwise.}\\
482 \end{array} \right.
483 \label{eq14} 
484 \end{equation}
485
486 \noindent Our coverage optimization problem can then be formulated as follows
487 \begin{equation} \label{eq:ip2r}
488 \left \{
489 \begin{array}{ll}
490 \min \sum_{p \in P} (w_{\theta} \Theta_{p} + w_{U} U_{p})&\\
491 \textrm{subject to :}&\\
492 \sum_{j \in J}  \alpha_{jp} X_{j} - \Theta_{p}+ U_{p} =1, &\forall p \in P\\
493 %\label{c1} 
494 %\sum_{t \in T} X_{j,t} \leq \frac{RE_j}{e_t} &\forall j \in J \\
495 %\label{c2}
496 \Theta_{p}\in \mathbb{N} , &\forall p \in P\\
497 U_{p} \in \{0,1\}, &\forall p \in P \\
498 X_{j} \in \{0,1\}, &\forall j \in J
499 \end{array}
500 \right.
501 \end{equation}
502
503
504
505 \begin{itemize}
506 \item $X_{j}$  : indicates whether or  not the sensor  $j$ is actively
507   sensing in the round (1 if yes and 0 if not);
508 \item $\Theta_{p}$  : {\it overcoverage}, the number  of sensors minus
509   one that are covering the primary point $p$;
510 \item $U_{p}$  : {\it undercoverage},  indicates whether or  not the primary point
511   $p$ is being covered (1 if not covered and 0 if covered).
512 \end{itemize}
513
514 The first group  of constraints indicates that some  primary point $p$
515 should be covered by at least one  sensor and, if it is not always the
516 case,  overcoverage  and  undercoverage  variables  help  balancing  the
517 restriction  equations by taking  positive values.  There are  two main         
518 objectives.  First, we limit the overcoverage of primary points in order to
519 activate a minimum number of sensors.  Second we prevent the absence of monitoring on
520  some parts of the subregion by  minimizing the undercoverage.   The
521 weights  $w_\theta$  and  $w_U$  must  be properly  chosen  so  as  to
522 guarantee that  the maximum number  of points are covered  during each
523 round.
524
525
526
527
528 \section{\uppercase{Simulation Results and Analysis}}  
529 \label{sec:Simulation Results and Analysis}
530 \noindent \subsection{Simulation Framework}
531 In this subsection, we conducted a series of simulations to evaluate the
532 efficiency and the relevance of our DiLCO protocol, using the discrete event
533 simulator OMNeT++  \cite{varga}. The simulation parameters are summarized in
534 Table~\ref{table3}.
535
536 \begin{table}[ht]
537 \caption{Relevant parameters for network initializing.}
538 % title of Table
539 \centering
540 % used for centering table
541 \begin{tabular}{c|c}
542 % centered columns (4 columns)
543       \hline
544 %inserts double horizontal lines
545 Parameter & Value  \\ [0.5ex]
546    
547 %Case & Strategy (with Two Leaders) & Strategy (with One Leader) & Simple Heuristic \\ [0.5ex]
548 % inserts table
549 %heading
550 \hline
551 % inserts single horizontal line
552 Sensing  Field  & $(50 \times 25)~m^2 $   \\
553 % inserting body of the table
554 %\hline
555 Nodes Number &  50, 100, 150, 200 and 250~nodes   \\
556 %\hline
557 Initial Energy  & 500-700~joules  \\  
558 %\hline
559 Sensing Period & 60 Minutes \\
560 $E_{th}$ & 36 Joules\\
561 $R_s$ & 5~m   \\     
562 %\hline
563 $w_{\Theta}$ & 1   \\
564 % [1ex] adds vertical space
565 %\hline
566 $w_{U}$ & $|P|^2$
567 %inserts single line
568 \end{tabular}
569 \label{table3}
570 % is used to refer this table in the text
571 \end{table}
572
573 We  performed  simulations for five different densities varying from 50 to 250~nodes. Experimental results are the average obtained from 25 randomly generated networks (25 for each network density) in which nodes are deployed over a $(50 \times 25)~m^2 $ sensing field. More precisely, the deployment is controlled at a coarse scale in order to ensure that the deployed nodes can cover the sensing field with a high coverage ratio.\\
574
575 We first concentrate on the required number of subregions making effective our protocol. Thus our DiLCO protocol is declined into five versions: DiLCO-2, DiLCO-4, DiLCO-8, DiLCO-16, and DiLCO-32, corresponding to $2$, $4$, $8$, $16$ or $32$ subregions (leaders).  
576
577 We use an energy consumption model proposed by~\cite{ChinhVu} and based on ~\cite{raghunathan2002energy} with slight modifications.
578 The energy consumption for sending/receiving the packets is added whereas the part related to the sensing range is removed because we consider a fixed sensing range.
579 % We are took into account the energy consumption needed for the high computation during executing the algorithm on the sensor node. 
580 %The new energy consumption model will take into account the energy consumption for communication (packet transmission/reception), the radio of the sensor node, data sensing, computational energy of Micro-Controller Unit (MCU) and high computation energy of MCU. 
581 %revoir la phrase
582
583 For our energy consumption model, we refer to the sensor node Medusa II which uses Atmels AVR ATmega103L microcontroller~\cite{raghunathan2002energy}. The typical architecture of a sensor is composed of four subsystems : the MCU subsystem which is capable of computation, communication subsystem (radio) which is responsible for
584 transmitting/receiving messages, sensing subsystem that collects data, and the power supply which  powers the complete sensor node ~\cite{raghunathan2002energy}. Each of the first three subsystems can be turned on or off depending on the current status of the sensor. Energy consumption (expressed in milliWatt per second)  for the different status of the sensor is summarized in Table~\ref{table4}. 
585
586 \begin{table}[ht]
587 \caption{The Energy Consumption Model}
588 % title of Table
589 \centering
590 % used for centering table
591 \begin{tabular}{|c|c|c|c|c|}
592 % centered columns (4 columns)
593       \hline
594 %inserts double horizontal lines
595 Sensor mode & MCU   & Radio & Sensing & Power (mW) \\ [0.5ex]
596 \hline
597 % inserts single horizontal line
598 Listening & ON & ON & ON & 20.05 \\
599 % inserting body of the table
600 \hline
601 Active & ON & OFF & ON & 9.72 \\
602 \hline
603 Sleep & OFF & OFF & OFF & 0.02 \\
604 \hline
605 Computation & ON & ON & ON & 26.83 \\
606 %\hline
607 %\multicolumn{4}{|c|}{Energy needed to send/receive a 1-bit} & 0.2575\\
608  \hline
609 \end{tabular}
610
611 \label{table4}
612 % is used to refer this table in the text
613 \end{table}
614
615 For the sake of simplicity we ignore the energy needed to turn on the
616 radio, to start up the sensor node, the transition from one status to another, etc. 
617 %We also do not consider the need of collecting sensing data. PAS COMPRIS
618 Thus, when a sensor becomes active (i.e., it already decides its status), it can turn its radio off to save battery. DiLCO protocol uses two types of packets for communication. The size of the INFO-Packet and Status-Packet are 112 bits and 24 bits respectively. 
619 The value of energy spent to send a 1-bit-content message is obtained by using the equation in ~\cite{raghunathan2002energy} to calculate the energy cost for transmitting messages and we propose the same value for receiving the packets.
620 The energy needed to send or receive a 1-bit is equal to $0.2575 mW$.
621
622 The initial energy of each node is randomly set in the interval $[500-700]$.  Each  sensor  node will  not participate in the next round if its remaining energy is less than $E_{th}=36 Joules$, the minimum energy needed for the node to stay alive during one round. This value has been computed by multiplying the energy consumed in active state (9.72 mW) by the time in second for one round (3600 seconds). According to the interval of initial energy, a sensor may be alive during at most 20 rounds.\\ 
623
624
625 In the simulations, we introduce the following performance metrics to evaluate the efficiency of our approach: 
626
627 %\begin{enumerate}[i)]
628 \begin{itemize}
629   
630 \item {{\bf Coverage Ratio (CR)}:} the coverage ratio measures how much the area of a sensor field is  covered. In our case, we treated the sensing fields as a grid, and used each grid point as a sample point
631 for calculating the coverage. The coverage ratio can be calculated by:
632 \begin{equation*}
633 \scriptsize
634 \mbox{CR}(\%) = \frac{\mbox{$n$}}{\mbox{$N$}} \times 100.
635 \end{equation*}
636 where  $n$ is the number of covered grid points by the active sensors of all subregions during the current sensing phase and $N$ is total number of grid points in the sensing field of the network. In our simulation $N = 51 \times 26 = 1326$ grid points.
637 %The accuracy of this method depends on the distance between grids. In our
638 %simulations, the sensing field has been divided into 50 by 25 grid points, which means
639 %there are $51 \times 26~ = ~ 1326$ points in total.
640 % Therefore, for our simulations, the error in the coverage calculation is less than ~ 1 $\% $.
641
642 \iffalse
643
644 \item{{\bf Number of Active Sensors Ratio(ASR)}:} It is important to have as few active nodes as possible in each round,
645 in  order to  minimize  the communication  overhead  and maximize  the
646 network lifetime. The Active Sensors Ratio is defined as follows:
647 \begin{equation*}
648 \scriptsize
649 \mbox{ASR}(\%) =  \frac{\sum\limits_{r=1}^R \mbox{$A_r^t$}}{\mbox{$S$}} \times 100 .
650 \end{equation*}
651 Where: $A_r^t$ is the number of active sensors in the subregion $r$ during round $t$ in the current sensing phase, $S$ is the total number of sensors in the network, and $R$ is the total number of the subregions in the network.
652
653 \fi
654
655 \item {{\bf Network Lifetime}:} we define the network lifetime as the time until the coverage ratio drops below a predefined threshold. We denoted by $Lifetime95$ (respectively  $Lifetime50$) as the amount of  time during which  the network  can  satisfy an area  coverage greater than $95\%$ (repectively $50\%$). We assume that the network
656 is alive  until all  nodes have  been drained of  their energy  or the
657 sensor network becomes disconnected . Network connectivity is important because an
658 active sensor node without  connectivity towards a base station cannot
659 transmit information on an event in the area that it monitors.
660  
661
662 \item {{\bf Energy Consumption}:}
663
664  Energy Consumption (EC) can be seen as the total energy consumed by the sensors during the $Lifetime95$ or $Lifetime50$ divided by the number of periods. The EC can be computed as follow: \\
665  \begin{equation*}
666 \scriptsize
667 \mbox{EC} = \frac{\sum\limits_{m=1}^{M} \left( E^{\mbox{com}}_m+E^{\mbox{list}}_m+E^{\mbox{comp}}_m  + E^{a}+E^{s} \right)}{M_L},
668 \end{equation*}
669
670 %\begin{equation*}
671 %\scriptsize
672 %\mbox{EC} =  \frac{\mbox{$\sum\limits_{d=1}^D E^c_d$}}{\mbox{$D$}} + \frac{\mbox{$\sum\limits_{d=1}^D %E^l_d$}}{\mbox{$D$}} + \frac{\mbox{$\sum\limits_{d=1}^D E^a_d$}}{\mbox{$D$}} + %\frac{\mbox{$\sum\limits_{d=1}^D E^s_d$}}{\mbox{$D$}}.
673 %\end{equation*}
674
675 where $M$ corresponds to the number of  periods.  The total  energy consumed by  the sensors
676 (EC) comes through taking into consideration four main energy factors. The first
677 one ,  denoted $E^{\scriptsize \mbox{com}}_m$, represent  the energy consumption
678 spent  by  all  the  nodes   for  wireless  communications  during  period  $m$.
679 $E^{\scriptsize  \mbox{list}}_m$, the  next  factor, corresponds  to the  energy
680 consumed by the sensors in LISTENING  status before receiving the decision to go
681 active or  sleep in  period $m$. $E^{\scriptsize  \mbox{comp}}_m$ refers  to the
682 energy needed  by all  the leader nodes  to solve  the integer program  during a
683 period. Finally, $E^a_{m}$ and $E^s_{m}$  indicate the energy consumed by the whole network in the sensing round.
684
685 \iffalse 
686 \item {{\bf Execution Time}:} a  sensor  node has  limited  energy  resources  and computing  power,
687 therefore it is important that the proposed algorithm has the shortest
688 possible execution  time. The energy of  a sensor node  must be mainly
689 used   for  the  sensing   phase,  not   for  the   pre-sensing  ones.   
690  
691 \item {{\bf Stopped simulation runs}:} A simulation
692 ends  when the  sensor network  becomes
693 disconnected (some nodes are dead and are not able to send information to the base station). We report the number of simulations that are stopped due to network disconnections and for which round it occurs.
694
695 \fi
696
697 \end{itemize}
698 %\end{enumerate}
699
700
701 %\subsection{Performance Analysis for differnet subregions}
702 \subsection{Performance Analysis}
703 \label{sub1}
704 In this subsection, we study the performance of our DiLCO protocol for  different number of subregions (Leaders).
705 The DiLCO-1 protocol is a centralized approach on all the area of the interest, while  DiLCO-2, DiLCO-4, DiLCO-8, DiLCO-16 and DiLCO-32 are distributed on two, four, eight, sixteen, and thirty-two subregions respectively. We do not take into account the DiLC0-1 protocol in our simulation results because it requires  high execution time to solve the integer program and thus it is too costly in term of energy.
706
707 Our method is compared with other two approaches. The first approach, called DESK and proposed by ~\cite{ChinhVu}  is a full distributed coverage algorithm. The second approach, called GAF ~\cite{xu2001geography}, consists in dividing the region into fixed squares.   During the  decision phase,  in  each square,  one sensor  is chosen to remain on during the sensing phase time. 
708
709
710 \subsubsection{Coverage Ratio} 
711 Figure~\ref{fig3} shows the average coverage ratio for 150 deployed nodes.  
712 \parskip 0pt    
713 \begin{figure}[h!]
714 \centering
715  \includegraphics[scale=0.45] {R/CR.pdf} 
716 \caption{The Coverage Ratio}
717 \label{fig3}
718 \end{figure} 
719
720 Figure~\ref{fig3} shows that DESK and GAF provide a
721 a little better coverage ratio compared to DiLCO in the first thirty periods. This is due to the fact that our DiLCO protocol versions  put in sleep mode some sensors through optimization process (which slightly decreases the coverage ratio) while there are more active nodes  with DESK or GAF. With DiLCO-2 (respectively DiLCO-4), the coverage ratio decreases rapidly to reach zero value in period ... (respectively in period ....) whereas other methods guarantee a coverage ratio greater than $50\%$ after this period. We believe that the results obtained with these two methods can be explained by a high consumption of energy
722 and we will check this assumption in the next paragraph. Concerning DiLCO-8, DiLCO-16 and DiLCO-32, these methods seem to be more efficient than DESK and GAF because they can provide the same level of coverage (except in the first periods, slightly lower) for a greater number of periods. Unlike other methods, their strategy enables to activate a restricted number of nodes, and thus extends the lifetime of the network.
723 %As shown in the figure ~\ref{fig3}, as the number of subregions increases,  the coverage preservation for area of interest increases for a larger number of periods. Coverage ratio decreases when the number of periods increases due to dead nodes. Although  some nodes are dead,
724 %thanks to  DiLCO-8,  DiLCO-16 and  DiLCO-32 protocols,  other nodes are  preserved to  ensure the coverage. Moreover, when  we have a dense sensor network, it leads to maintain the  coverage for a larger number of rounds. DiLCO-8,  DiLCO-16 and  DiLCO-32 protocols are
725 %slightly more efficient than other protocols, because they subdivides
726 %the area of interest into 8, 16 and 32~subregions if one of the subregions becomes disconnected, the coverage may be still ensured in the remaining subregions.%
727
728
729
730 \subsubsection{The Energy Consumption}
731 Based on previous results in figure~\ref{fig3}, we keep DiLCO-16 and  DiLCO-32  and we compare their performances in terms of energy consumption with the two other approaches. We measure the energy consumed by the sensors during the communication, listening, computation, active, and sleep modes for different network densities.  Figure~\ref{fig95} illustrates the energy consumption for different network sizes.
732 % for $Lifetime95$ and $Lifetime50$. 
733 We denote by $DiLCO-/50$ (respectively  $DiLCO-/95$) as the amount of energy consumed during which the network can satisfy an area coverage greater than $50\%$ (repectively $95\%$) and we refer to the same definition for the two other approaches.
734 \begin{figure}[h!]
735 \centering
736 \includegraphics[scale=0.45]{R/EC.pdf} 
737 \caption{The Energy Consumption}
738 \label{fig95}
739 \end{figure} 
740
741 The results show that DiLCO-16/50, DiLCO-32/50, DiLCO-16/95 and DiLCO-32/95 protocols are the most competitive from the energy consumption point of view. The other approaches have a high energy consumption due to activating a larger number of redundant nodes. 
742
743
744 %In fact,  a distributed  method on the subregions greatly reduces the number of communications and the time of listening so thanks to the partitioning of the initial network into several independent subnetworks. 
745 %As shown in Figures~\ref{fig95} and ~\ref{fig50} , DiLCO-2 consumes more energy than the other versions of DiLCO, especially for large sizes of network. This is easy to understand since the bigger the number of sensors involved in the integer program, the larger the time computation to solve the optimization problem as well as the higher energy consumed during the communication.  
746
747
748 \subsubsection{Execution Time}
749 We observe the impact of the network size and of the number of subregions on the computation time. We report the average execution times in seconds needed to solve the optimization problem for the different approaches and various numbers of sensors. 
750 The original execution time is computed on a laptop DELL with intel Core i3 2370 M (2.4 GHz) processor (2 cores) and the MIPS (Million Instructions Per Second) rate equal to 35330. To be consistent with the use of a sensor node with Atmels AVR ATmega103L microcontroller (6 MHz) and a MIPS rate equal to 6 to run the optimization resolution, this time is multiplied by 2944.2 $\left( \frac{35330}{2} \times \frac{1}{6}\right)$ and reported on Figure~\ref{fig8}.
751
752 \begin{figure}[h!]
753 \centering
754 \includegraphics[scale=0.45]{R/T.pdf}  
755 \caption{Execution Time (in seconds)}
756 \label{fig8}
757 \end{figure} 
758
759
760 Figure~\ref{fig8} shows that DiLCO-32 has very low execution times in comparison with other DiLCO versions, because the activity scheduling is tackled by a larger number of leaders  and each leader solves an integer problem with a limited number of variables and constraints. Conversely, DiLCO-2 requires to solve an optimization problem with half of the network nodes and thus presents  a high execution time. Nevertheless if we refer to figure~\ref{fig3}, we observe that DiLCO-32 is slightly less efficient than DilCO-16 to maintain as long as possible high coverage. Excessive subdivision of the area of interest prevents to ensure good coverage especially on the borders of the subregions.
761
762 %The DiLCO-32 has more suitable times in the same time it turn on redundent nodes more.  We think that in distributed fashion the solving of the  optimization problem in a subregion can be tackled by sensor nodes. Overall, to be able to deal  with very large networks,  a distributed method is clearly required.
763
764
765 \subsubsection{The Network Lifetime}
766 In figure~\ref{figLT95}, network lifetime is illustrated for different network sizes. The term $/50$ (respectively  $/95$) next to the name of the method refers to the amount of time during which the network can satisfy an area coverage greater than $50\%$ ($Lifetime50$)(repectively $95\%$ ($Lifetime95$)) 
767
768 \begin{figure}[h!]
769 \centering
770 \includegraphics[scale=0.45]{R/LT.pdf}  
771 \caption{The Network Lifetime}
772 \label{figLT95}
773 \end{figure} 
774
775
776 As highlighted by figure~\ref{figLT95}, the network lifetime obviously
777 increases when the size of the network increases. For the same level of coverage, DiLCO outperforms DESK and GAF for the lifetime of the network. If we focus on level of coverage greater than $95\%$, The subdivision in $16$ subregions seems to be the most appropriate. 
778
779
780 % with  our DiLCO-16/50, DiLCO-32/50, DiLCO-16/95 and DiLCO-32/95 protocols
781 % that leads to the larger lifetime improvement in comparison with other approaches. By choosing the best 
782 % suited nodes, for each round, to cover the area of interest and by
783 % letting the other ones sleep in order to be used later in next rounds. Comparison shows that our DiLCO-16/50, DiLCO-32/50, DiLCO-16/95 and DiLCO-32/95 protocols, which are used distributed optimization over the subregions, are the best one because it is robust to network disconnection during the network lifetime as well as it consume less energy in comparison with other approaches. It also means that distributing the protocol in each node and subdividing the sensing field into many subregions, which are managed
784 % independently and simultaneously, is the most relevant way to maximize the lifetime of a network.
785
786
787
788
789 \section{\uppercase{Conclusion and Future Works}}
790 \label{sec:Conclusion and Future Works}
791 In this paper, we have  addressed the problem of the coverage and the lifetime
792 optimization in wireless  sensor networks. This is a key issue as
793 sensor nodes have limited resources in terms of memory,  energy and
794 computational power. To cope with this problem, the field of sensing
795 is divided into smaller subregions using the concept of divide-and-conquer method, and then a DiLCO protocol for optimizing the coverage and lifetime performances in each subregion.
796 The proposed protocol combines two efficient techniques:  network
797 leader election and sensor activity scheduling, where the challenges
798 include how to select the  most efficient leader in each subregion and
799 the best representative set of active nodes to ensure a high level of coverage.
800 We have compared this method with two other approaches using many metrics as coverage ratio, execution time, lifetime.
801 Some experiments have been performed to study the choice of the number of
802 subregions  which subdivide  the  sensing field,  considering different  network
803 sizes. They show that as the number of subregions increases, so does the network
804 lifetime. Moreover,  it makes  the DiLCO protocol  more robust  against random
805 network  disconnection due  to node  failures.  However,  too  much subdivisions
806 reduces the advantage  of the optimization. In fact, there  is a balance between
807 the  benefit  from the  optimization  and the  execution  time  needed to  solve
808 it. Therefore, the subdivision in $16$ subregions seems to be the most appropriate. 
809 \iffalse
810 \noindent In this paper, we have  addressed the problem of the coverage and the lifetime
811 optimization in wireless  sensor networks. This is a key issue as
812 sensor nodes have limited resources in terms of memory,  energy and
813 computational power. To cope with this problem, the field of sensing
814 is divided into smaller subregions using the concept of divide-and-conquer method, and then a DiLCO protocol for optimizing the coverage and lifetime performances in each subregion.
815 The proposed protocol combines two efficient techniques:  network
816 leader election and sensor activity scheduling, where the challenges
817 include how to select the  most efficient leader in each subregion and
818 the best representative active nodes that will optimize the network lifetime
819 while  taking the responsibility of covering the corresponding
820 subregion. The network lifetime in each subregion is divided into
821 rounds, each round consists  of four phases: (i) Information Exchange,
822 (ii) Leader Election, (iii) an optimization-based Decision in order to
823 select the  nodes remaining  active for  the  last phase,  and  (iv)
824 Sensing.  The  simulations show the relevance  of the proposed DiLCO
825 protocol in terms of lifetime, coverage ratio, active sensors ratio, energy consumption, execution time, and the number of stopped simulation runs due to network disconnection. Indeed, when
826 dealing with large and dense wireless sensor networks, a distributed
827 approach like the one we are proposed allows to reduce the difficulty of a
828 single global optimization problem by partitioning it in many smaller
829 problems, one per subregion, that can be solved more easily.
830
831 In future work, we plan to study  and propose a coverage optimization protocol, which
832 computes  all active sensor schedules in one time, using
833 optimization  methods. \iffalse The round  will still consist of 4 phases, but the
834   decision phase will compute the schedules for several sensing phases
835   which, aggregated together, define a kind of meta-sensing phase.
836 The computation of all cover sets in one time is far more
837 difficult, but will reduce the communication overhead. \fi
838 \fi
839 \section*{\uppercase{Acknowledgements}}
840 \noindent As a Ph.D. student, Ali Kadhum IDREES would like to gratefully acknowledge the University of Babylon - IRAQ for the financial support and Campus France for the received support.
841
842
843
844
845
846 %\vfill
847 \bibliographystyle{apalike}
848 {\small
849 \bibliography{Example}}
850
851
852 %\vfill
853 \end{document}