Optimal online and offline algorithms for robot-assisted restoration of barrier coverage ∗ J. Czyzowicz 1 , E. Kranakis 2 , D. Krizanc 3 , L. Narayanan 4 , and J. Opatrny 4 1D ́ ep. d’informatique, Universit ́ e du Qu ́ ebec en Outaouais, Gatineau, QC, Canada, Jurek.Czyzowicz@uqo.ca 2School of Computer Science, Carleton University, Ottawa, ON, Canada kranakis@scs.carleton.ca 3Dept. of Math. and Computer Science, Wesleyan University, Middletown, CT, USA dkrizanc@wesleyan.edu 4Dept. of Comp. Science and Software Eng., Concordia University, Montreal, QC, Canada lata, opatrny@cs.concordia.ca Abstract Cooperation between mobile robots and wireless sensor networks is a line of research that is currently attracting a lot of attention. In this context, we study the following prob- lem of barrier coverage by stationary wireless sensors that are assisted by a mobile robot with the capacity to move sensors. Assume that n sensors are initially arbitrarily dis- tributed on a line segment barrier. Each sensor is said to cover the portion of the barrier that intersects with its sensing area. Owing to incorrect initial position, or the death of some of the sensors, the barrier is not completely covered by the sensors. We employ a mobile robot to move the sensors to final positions on the barrier such that barrier cover- age is guaranteed. We seek algorithms that minimize the length of the robot’s trajectory, since this allows the restoration of barrier coverage as soon as possible. We give an opti- mal linear-time offline algorithm that gives a minimum-length trajectory for a robot that starts at one end of the barrier and achieves the restoration of barrier coverage. We also study two different online models: one in which the online robot does not know the length of the barrier in advance, and the other in which the online robot knows the length of the barrier. For the case when the online robot does not know the length of the barrier, we prove a tight bound of 3 / 2 on the competitive ratio, and we give a tight lower bound of 5 / 4 on the competitive ratio in the other case. Thus for each case we give an optimal online algorithm. ∗ This work was partially supported by NSERC grants 1 arXiv:1410.6726v1 [cs.DS] 24 Oct 2014 1 Introduction Mobile robots and wireless sensor networks are related areas of research that have largely been studied by different communities of researchers. Recently, there has been increasing interest in the possibilities uncovered by utilizing both technologies [13]: what if mobile robots and wireless sensors could cooperate to solve problems and perform tasks? Environments where autonomous networked entities such as robots and sensors cooperate to achieve a common goal are sometimes called mixed-mode environments and have been the subject of several recent research events, e.g., [17, 9]. In this paper, we study a related mixed-mode problem for barrier coverage. Assume n stationary sensors have initial positions on a line segment barrier. Owing to incorrect initial placement, or the death of some sensors due to battery failure or a disaster, the barrier is not completely covered by the sensors. An illustration is given in Figure 1(a), where the segment of the barrier covered by a sensor is represented as a box. s 1 s 2 s 4 s 6 s 1 s 2 s 6 s 4 robot robot robot 4.3 3.6 L=7.8 7.3 0 0.3 2.6 2.7 5.2 s 7,8 0 1 2 3 4 5 6 7 (a) 0 L s 8 (b) 0 L trajectory 1.5 3.6 7.5 7.3 (c) 0 L trajectory 1.5 3.6 7.5 7.3 2.7 3.5 (d) s 3 s 5 s 7 Figure 1: Robot-assisted restoration of barrier coverage problem with sensor range equal to 0.5: (a) the initial configuration on segment [ 0 , L ] with gaps in coverage, (b) a possible solu- tion, (c) and (d) give examples of trajectories that could be followed by the robot to obtain the final configuration in (b). The task of the mobile robot is to walk along the barrier segment, pick up and move 2 sensors to final positions such that barrier coverage is restored, i.e. , in their final positions, the sensors collectively cover the entire line segment barrier as in Figure 1(b). Note that the final positions that achieve barrier coverage are not unique. Since sensors may need to be moved in different directions, i.e. left or right, to assure coverage, the robot may sometimes need to turn or change direction in order to restore coverage. The robot may decide to resolve the gap as soon as possible, as late as possible, or some time in between. The robot thus follows a certain trajectory , which can be specified by the starting point, and a sequence of points where the robot alternately turns left and right before it reaches its termination point. Given the initial configuration of Figure 1(a), two of the possible trajectories that achieve the same final positions of sensors are shown in Figures 1(c) and (d). The time needed to restore barrier coverage is clearly related to the length of the robot’s trajectory, which in turn depends on the knowledge it has of the initial positions of sensors. The problem we are interested in is finding an optimal trajectory for the mobile robot in order to achieve barrier coverage as fast as possible. Sensor relocation model. In the sequel we define the capabilities of the sensors and the robot, as well as the trajectory of the robot. Sensors. Assume that n sensors s 1 , s 2 , . . . , s n are distributed on the line segment [ 0 , L ] of length L with endpoints 0 and L in locations x 1 ≤ x 2 ≤ . . . ≤ x n . The range of all sensors is assumed to be identical, and is equal to a positive real number r > 0. Thus sensor s i in position x i defines a closed interval [ x i − r , x i + r ] of length 2 r centered at the current position x i of the sensor, in which it can detect an intruding object or an event of interest. See Figure 1(a) for an illustration of a problem instance. We say that the sensor covers the closed interval [ x i − r , x i + r ] . We assume that the total range of the sensors is sufficient to cover the entire line segment [ 0 , L ] , i.e., 2 rn ≥ L . We define a gap to be a closed subinterval G of [ 0 , L ] such that no point in G is within the range of a sensor. Clearly, an initial placement of the sensors may have gaps. The sensors provide complete coverage of [ 0 , L ] if they leave no gaps. Robot. There is a mobile robot that can move the sensors to positions that guarantee coverage of the entire line segment. We assume that the robot can pick, carry, move and drop/deposit sensors from any initial position to any desired position on the line segment. There is no constraint on the direction and number of turns it can take (left or right) so as to pick and/or drop sensors, and no restriction on where in the line segment it can drop the sensors. We study the case when sensors are small enough and thus the robot can potentially carry all the sensors it needs at the same time. Robot trajectory and length. Our goal is to provide offline and online algorithms so as to minimize the time taken to restore barrier coverage. Assuming constant speed, we measure this by the distance travelled by the robot from its starting position to complete the task of moving sensors to positions which guarantee complete coverage of the barrier. We assume that the mobile robot starts at position 0 and moves to the right. At some point it can turn and move left, then again turn and move right and so on. Thus its trajectory can be specified as a sequence of points on the barrier: [ t 0 = 0 , t 1 , t 2 , . . . , t m ] , where the points t 1 , t 3 , . . . are the points where the robot turns left, the points t 2 , t 4 , . . . are the points where the robot turns right, and finally, the point t m is the termination point of the trajectory. Therefore, t i > t i − 1 for all odd i while t i < t i − 1 for all even i where 0 < i ≤ m , and the robot’s trajectory is the sequence of line 3 segments [ 0 , t 1 ] , [ t 1 , t 2 ] , · · · , [ t m − 1 , t m ] . The length of the trajectory is defined as Σ m i = 1 | t i − t i − 1 | . We seek algorithms that calculate an optimal trajectory for the mobile robot that ensure barrier coverage, i.e. a trajectory of smallest possible length. A mobile robot using an offline algorithm to calculate its trajectory is assumed to know all the initial positions of sensors before starting its trajectory. On the other hand, a robot using an online algorithm knows about sensors only in the parts of the barrier segment where it has already travelled. Specifically, an online robot discovers the presence or absence of a sensor at position x only when reaching x . Therefore, at the start of the algorithm, such a robot has no knowledge about any of the sensors’ positions. It can of course remember any sensors that it has seen previously. Related work. Barrier coverage using wireless sensors has been the subject of intensive research in the last decade [1, 15, 18]. Some papers assumed randomized deployment of sensors on the barrier and analyzed the probability of barrier coverage. Other papers have studied the case of relocatable sensors [20, 21], which start at arbitrary positions and can move to final positions that achieve barrier coverage. Centralized algorithms for minimizing the maximum and average movement of sensors were studied in [5, 6] and [7] respectively. Multiple barriers were studied in [2], and distributed algorithms for barrier coverage were given for the first time in [10]. Charikar et al. [4] consider the k -delivery TSP problem for transporting efficiently n iden- tical objects, placed at arbitrary initial locations, to n target locations with a vehicle that can carry at most k objects at a time. Chalopin et al. [3] provide hardness results, exact, approx- imation, and resource-augmented algorithms for the problem of whether there is a schedule of agents’ movements that collaboratively deliver data from specified sources of a network to a central repository. Our problem differs both in being uncapacitated, and in the fact that the locations of the sources and targets are not known in advance. Online vehicle routing problems and the online travelling salesman problem have been studied previously; see [11] for a survey. Our problem and our conception of online are quite different: the locations the robot needs to deposit sensors are not pre-determined, and we assume an online robot discovers the positions of sensors as it moves along the barrier. Cooperation between mobile robots and wireless sensors is a relatively new research area and has been explored in several research events in the last couple of years [9, 13, 16, 17]. The authors of [8] and [19] use information obtained from wireless sensors for the problem of localization of a mobile robot. In [12], mobile robots and stationary sensors cooperate in a target tracking problem: stationary sensors track moving sensors in their sensor range, while mobile robots explore regions not covered by the fixed sensors. A common evaluation platform for mixed-mode environments incorporating both mobile robots and wireless sensor networks is described in [14]. Our results. We give a linear time offline algorithm that computes an optimal trajectory for a robot starting at an endpoint of the barrier to restore barrier coverage. For the online case, we show that when the robot does not know the length of the barrier and recognizes the end of it only when reaching it, any algorithm must have a competitive ratio of at least 3 / 2. We give a simple algorithm that matches this bound. When the robot does know the length of the barrier, we show a lower bound of 5 / 4 on the competitive ratio of any online algorithm for the problem. We then give an adaptive online algorithm whose competitive ratio matches this 4 lower bound. 2 Optimal Offline Algorithm In our offline algorithm we assume that the robot has global knowledge of the positions of sensors on the line segment, and that during the course of its movement, can pick up and carry as many sensors as necessary and deposit them as required. All sensors have identical range denoted by r , and the robot starts at the endpoint 0 of the interval [ 0 , L ] , and the number of given sensors is sufficient to cover the given interval. Obviously, when the barrier does not contain any gap, the trajectory is empty and we consider below instances containing gaps. We begin by establishing the properties of optimal non-empty trajectories of the robot, which are crucial to the development of the algorithm. We say that a solution is order-preserving if the final order of the position of the sensors is the same as their initial positions. Secondly, a solution is called fully stretched if the robot places all sensors in attached positions , i.e., two consecutive sensors encountered by the robot are placed at distance 2 r and the first sensor is at distance r from 0, except possibly the sensors at or after the termination point t m as in the example in Figure 1(b). Lemma 1 (Order-preserving fully stretched solution) There exists an optimal trajectory for the robot that produces an order-preserving fully-stretched solution. Proof. Let s i and s j be two sensors such that x i < x j and assume that the robot, when following an optimal trajectory places s i to the right of s j . Clearly, on any optimal trajectory the robot encounters s i before s j . If on the trajectory of the robot, the placement of s i occurs after the robot encounters s j , then the robot can pick s j when traversing it and reverse the placements of s i and s j . If on the trajectory of the robot, the placement of s i occurs before the robot encounters s j then the robot makes a left turn after encountering s j and the trajectory of the robot must cross the final position of s i . When crossing s i , the robot can replace s i by s j , and place later s i in place of s j using the same trajectory. Since the sensors have identical ranges, this exchange of positions of s i and s j gives the same barrier coverage. When following an order preserving trajectory, the robot can pick any sensor it encounters and delay the drop of a sensor, or drop it earlier so that the distance to the beginning of the segment is r or to the preceding sensor is 2 r . This can be done as long as the span of the trajectory extends 2 r past the previous sensor. Lemma 2 (Three Visits Lemma) The trajectory of an optimal algorithm does not contain the same point of the line segment more than three times. Furthermore, the last point of the trajectory can occur in the trajectory at most twice. Proof. The idea is to demonstrate that a robot visiting a point in the line segment more than three times produces a non-optimal trajectory. This is based on the early pick-up, late drop principle, i.e. we show that if a point p is visited more than three times, we can replace a part 5 of a trajectory with a new, shorter trajectory in which pick-ups of sensors are done as early as possible, and drops of sensors are delayed to after the picking in the affected part is finished. Assume on the contrary that a point, say p , on the line segment is visited by the robot at least k times, k ≥ 4, during its optimal trajectory T , see Figure 2. Consider trajectory T 1 , a part of trajectory T , that the robot follows from the first to the last visit of p . Let a be the rightmost point and b be the leftmost point of the segment [ 0 , L ] occurring on T 1 . Let T 2 be a part of trajectory T from b to p prior to reaching p for the first time. Part T 2 must exist since the trajectory starts at 0. Clearly, all sensors that the robot deposits between b and a when following T up to the last visit of p are from among the sensors that the robot carried when entering T 2 and those sensors the robot found on the segment between b and a . Thus the robot can achieve the same result by replacing T 2 and T 1 by trajectory T 3 consisting of three parts: Part one of T 3 is segment [ b , a ] , and the robot when moving from b to a picks all sensors found there. (This “early pick” allows the robot to have all sensors needed later on), Part two is segment [ a , b ] and the robot when moving from a to b drops the sensors in the same order as achieved by T 1 and T 2 (the late drop part). The third part is segment [ b , p ] moving from b to p , where the robot does no picks or drops of sensors, see Figure 3 (a). When following T 3 , the robot picked all sensors found between b and a and dropped the same sensors as when following T 2 and T 1 . Thus, when it reaches p for the third time, it carries at least the same or more sensors than when reaching p along T for the last time. Thus the robot then can continue along the rest of T and achieve the same result, while visiting p only three times. This trajectory is shorter, a contradiction. If T ends at p , then the third part [ b , p ] of T 3 is not needed, since the robot is doing nothing, and the trajectory should end at b . This implies that the last point of an optimal trajectory can be visited at most twice. The case when trajectory T 3 ends at b is shown in Figure 3 (b). p T 1 2 T a b Figure 2: More than three visits of the point p by the trajectory of the robot. p a b (b) p b a (a) Figure 3: Replacing the old trajectory of the robot with either of the two depicted trajectories. 6 Observe that the above lemmas applies to both offline and online algorithms. Furthermore, once a trajectory is specified, the robot can produce an order-preserving fully stretched solu- tion as discussed below, so it suffices to specify the trajectory of the robot. Given an optimal trajectory [ t 0 , t 1 , t 2 , t 3 . . . , t m − 1 , t m ] , the robot makes a left turn at t 1 , t 3 , . . . and right turns at t 2 , t 4 , . . . . Therefore, the segments [ t 2 , t 1 ] , [ t 4 , t 3 ] , . . . , [ t 2 i , t 2 i − 1 ] , . . . of [ 0 , L ] are traversed by the robot three times, 1 ≤ i ≤ ( m − 1 ) / 2, and if m is even, then the segment [ t m , t m − 1 ] , is traversed twice. Furthermore, all these segments are pairwise disjoint, except possibly for the endpoints of the segments. We call the part of the trajectory [ t 2 i , t 2 i − 1 ] , 1 ≤ i ≤ ( m − 1 ) / 2, traversed by the robot three times, a triple , t 2 i − 1 is called its left turning point and t 2 i is called its right turning point . If m is even, then the segment [ t m , t m − 1 ] is called a double and t m − 1 is called its left turning point . Any line segment in the trajectory that is traversed exactly once by the robot is called a straight line segment (see Figure 4). When following a straight line segment the robot necessarily has sufficient supply of sensors and deposits them in attached positions. When following a segment of a triple or a double for the first time, the robot picks all sensors found there and deposits then in attached positions when going back over the segment (see the proof of Lemma 2). Clearly, if two consecutive triples, or a triple and a double share an endpoint, these two moves can be merged into a single triple, or a double. This observation and the preceding lemmas imply the following corollary. Corollary 1 There is an optimal order-preserving and fully stretched trajectory of the robot that produces a complete coverage of [ 0 , L ] which consists of k consecutive triples and straight line segments for some k ≥ 0 , and ends with a straight line segment or a double (see Figure 4). (a) (b) t t t t t t t t t t t t t 2 1 4 3 m 2 1 4 3 m 0 L 0 L m−1 m−1 m−2 Figure 4: Two possible shapes of an optimal trajectory. To construct an optimal trajectory of the robot we need to determine, from the given input instance, the ends of the triples and a double. The following definition of coverage balance is used to determine them. 7 Definition 1 The coverage balance of sensor s i at location x i is defined to be C i = ( 2 ri − r ) − x i , i.e., the difference between the total length that can be covered by sensors s 1 , s 2 , . . . , s i up to the center of s i , and the distance of s i to the beginning of the interval. Consider the example in Figure 1. The coverage balance of sensors listed from left to right are 0 . 2 , − 1 . 1 , − 0 . 2 , − 0 . 1 , 0 . 2 , 0 . 3 , − 0 . 8 and 0 . 2. Notice that in the two examples of trajecto- ries in this figure each left turn is done at a sensor with negative coverage balance. However, doing a left turn at every sensor with negative coverage balance would be wrong, because it could violate the three visits lemma. Similarly, doing a triple involving many consecutive sensors with negative coverage balance can be sub-optimal as well, as seen in the trajectory of Figure 1(c). The following lemma specifies all potential left turning points. Lemma 3 Let ([ t 0 , t 1 , t 2 , t 3 . . . , t m − 1 , t m ]) be an optimal trajectory which minimizes the number of triples. 1. Every sensor with negative coverage balance is shifted left, and thus its location is in a triple or the double segment. 2. No triple segment contains the location of a sensor with nonnegative coverage balance. 3. In a double segment the rightmost sensor has negative coverage balance. 4. For every triple [ t 2 i , t 2 i − 1 ] , the left-turning point t 2 i − 1 is a location of a sensor x j for some integer j such that either − 2 r < C j < 0 , or both, − 2 r = C j and x j = x j + 1 , and the coverage balance of every other sensor located in the interval [ t 2 i , t 2 i − 1 ] is less than or equal to − 2 r. 5. Let k be the smallest integer such that all gaps in [ 0 , L ] are to the left of 2 rk. Then s k is the last sensor to be moved. Let c = x k if C k < 0 , else c = x k + C k . If the trajectory does not end with a double then C k ≥ 0 , m is odd, and the termination point t m = c. Otherwise the trajectory ends with a double, and t m − 1 = c, i.e., the left-turning point of the double is c. Proof. Clearly, any sensor with negative coverage balance needs to be shifted to the left and this is done using a triple of the double . If interval [ t 2 i , t 2 i − 1 ] is a triple than it cannot contain a sensor with nonnegative coverage balance or otherwise we can replace one triple with a shorter triple or two triples that are shorter in total. If the rightmost sensor of a double has nonnegative coverage balance, the double can be made shorter by omitting this sensor from the double and by making any shift of it to the right when it is encountered the first time. Clearly, the left turning point of any triple should be a location of a sensor with negative coverage balance, otherwise the triple can be made shorter. If C j ≤ − 2 r , and x j < x j + 1 then sensor s j + 1 must be shifted left to the position t 2 i − 1 , or to the left of it by another triple or double. This would either allow a merge of triple [ t 2 i , t 2 i − 1 ] with another triple or double, or it would contradict the three visits lemma. Thus, either − 2 r < C j < 0, or C j = 2 r and x j = x j + 1 . 8 Since all gaps are to the left of 2 rk , placing sensors s 1 , s 2 , . . . , s k in attached position covers all gaps and s k is the rightmost sensor on the trajectory. If C k is negative, the robot must turn right at x k for a double. If there is no double, C K ≥ 0 and by Corollary 1 the trajectory ends with a straight line segment, terminating at c . Thus, by the preceding lemma, the potential left turning points in the example in Figure 1 are the initial locations of sensors s 3 , s 4 , and s 7 , but not s 2 . Definition 2 Let m be the number of sensors whose coverage balance is either − 2 r < C j < 0 , or − 2 r = C j and x j = x j + 1 . The list A of indices of sensors of potential triple delimiters is a list of pairs A = [( b 1 , a 1 ) , ( b 2 , a 2 ) , · · · , ( b m , a m )] of sensor indices such that 1. a 1 < a 2 < · · · < a m are the indices of all sensors such that either − 2 r < C j < 0 , or − 2 r = C j and x j = x j + 1 2. b 1 is the smallest index of a sensor with negative coverage balance, and for 1 < i ≤ m the value of b i is the smallest index larger than a i − 1 with negative coverage balance. Lemma 4 Let A be the list of indices of sensors of potential triple delimiters, m be the number of pairs in A, and c be defined as in Lemma 3. There is an optimal, order preserving, fully- stretched trajectory such that for some integer j, 0 ≤ j ≤ m, 1. the trajectory contains j triples [ x b i + C b i , x a i ] , 1 ≤ i ≤ j, 2. If j < m then the trajectory ends with a double, [ x b j + 1 + C b j + 1 , c ] , otherwise the trajectory ends with a straight line and its termination point is c. Proof. Consider an optimal trajectory T which minimizes the number of triples. Each pair in list A gives an interval of indices of sensors with negative coverage balance. According to Lemma 3, these sensors must be moved left by a triple or a double. Furthermore the left turning point of any triple is the location of a sensor s a i . Thus, if T contains j triples then 1 ≤ j ≤ m , and the triples are as stated in the lemma. If j < m then all remaining sensors with negative coverage must be shifted left by a double, and, by Lemma 3, this move is [ x b j + 1 + C b j + 1 , c ] . If j = m then the trajectory must end at c . The main idea of our offline algorithm is to calculate the list A of potential triple delimiters as defined in Definition 2. Let T j be a trajectory that uses triples on the first j pairs of A , 0 ≤ j ≤ m , and one double if j < m . We define the overhead o j of a trajectory T j to be the difference between the length of T j and the straight line trajectory. Clearly, o j = { c − x b j + 1 − C b j + 1 + ∑ j i = 1 2 ( x a i − x b i − C b i ) for 1 < j < m , ∑ m i = 1 2 ( x a i − x b i − C b i ) for j = m The algorithm calculates the overhead of T j trajectories for 1 ≤ j ≤ m and chooses the tra- jectory with the minimum overhead. By Lemma 4, the trajectory with the minimum overhead is optimal. Thus a robot finds the coordinates of an optimal trajectory by executing the offline algorithm below. 9 Offline Algorithm Input: the length L of the segment, the number n of sensors, their initial locations x 1 ≤ x 2 ≤ . . . ≤ x n , and their range r ; Output: the trajectory points for the robot. 1 Scan x 1 , x 2 , . . . , x n for gaps; 2 if gaps exist then 2.1 Compute the smallest integer k such that all gaps are to the left of x k ; 2.2 Compute the sequence C i = ( 2 ri − r ) − x i , 1 ≤ i ≤ k ; 2.3 if C k < 0 then c ← x k ; else c ← x k + C k ; // c is the potential left-turning point of a double. 2.4 Scan the sequence C 1 , C 2 , . . . , C k and compute list < A , B > = [( b 1 , a 1 ) , ( b 2 , a 2 ) , · · · , ( b m , a m )] ; // potential triple delimiters 2.5 o j ← ( c − x b j + 1 − C b j + 1 ) + ∑ j i = 1 2 ( x a i − x b i − C b i ) , 1 ≤ j ≤ m − 1; // T j overhead 2.6 o m ← ∑ m i = 1 2 ( x a i − x b i − C b i ) ; // T m overhead 2.7 Compute min { o 1 , o 2 , . . . , o m } ; and its index k ; 2.8 Output x a 1 , x b 1 + C b 1 , x a 2 , x b 2 + C b 2 , . . . , x a k , x b 2 + C b 2 ; //the sequence of left/right turning points of the optimal trajectory, 2.9 If k < m then Output there is a double from c to x b k + 1 + C b k + 1 ; else the trajectory ends at c ; else [ 0 , L ] is initially completely covered, robot does nothing; Since algorithm Offline calculates the overheads of all trajectories that satisfy Lemma 4 and picks the one with the smallest overhead, the Corollary 1 and Lemma 4 imply that the selected trajectory is optimal. Clearly, all calculations in each step are of O ( n ) complexity. Thus we have the following theorem. Theorem 1 Assume we are given n sensors in the line segment [ 0 , L ] and a robot with starting position 0 . Algorithm Offline computes an optimal trajectory for the robot to follow in O ( n ) time. 3 Optimal Online Algorithms We now consider online algorithms for restoration of barrier coverage by a robot. For the online algorithm we assume that the robot starts at position 0, it can move along the given line segment, but the robot does not know the positions of sensors until it comes upon them. As usual, we define the competitive ratio of an online algorithm as the length of the trajectory of the online algorithm divided by the length of the trajectory of the optimal offline algorithm. At the outset, observe that on the input instance where the sensors are placed in such a way that there is no gap in the barrier coverage, the offline algorithm produces a trajectory 10 of length 0, while the online algorithm must traverse the entire barrier segment to ensure that the barrier is covered. Thus no online algorithm can have a bounded competitive ratio. To provide a more meaningful comparison of online with offline algorithms, we only consider below input instances where there is a gap in coverage at the very end of the barrier, that is, the point L is uncovered. On such instances, all valid robot trajectories must have length at least L − r . We also consider the possibility that L , the length of the barrier, is not known to the robot and the robot will find it out only when reaching the end of the barrier. Since the performance of online algorithms depends on the knowledge of L , we consider the two possibilities separately. We use below the notion of potential left and right turning points as defined in the previous section. When the value of L is unknown to the robot we show the following result. Theorem 2 Assume that the robot does not know the length L of the barrier [ 0 , L ] . For any 0 < ε  1 , the competitive ratio of any online algorithm is at least 3 2 − ε . Furthermore, there is an online algorithm with competitive ratio at most 3 2 . Proof. Assume there is an online algorithm A with competitive ratio 3 / 2 − ε for some ε > 0. We give an adversary argument. Start with an input that has no sensors until position x = 2 ir where there are i > 0 sensors for some i to be specified later. Clearly there are just enough sensors at x to cover the segment [ 0 , x ] . Following this, the adversary starts placing sensors in attached position starting at position x + 2 r . The robot has to make a turn at some point y ≥ x to cover the gap in coverage before x . If it does not make a turn before 6 x , the adversary can set L = 6 x , and the robot must do a double to the beginning, see Figure 5 (a). The trajectory produced by A has length at least 2 L − r = 12 x − r , while the offline algorithm covers the gap before x with a triple from x using a trajectory of at most 3 x − 2 r + 5 x = 8 x − 2 r . This gives the competitive ratio of at least ( 12 x − r ) / ( 8 x − 2 r ) > 3 / 2. If the robot turns at any point y such that x ≤ y < 6 x , then the adversary concludes the barrier at L = y + r + δ , see Figure 5 (b). Clearly, the trajectory produced by A has length at least 3 y − r + δ while the offline algorithm uses a trajectory of at most 2 y + 2 δ . Thus the competitive ratio of the algorithm is at least ( 3 y − r + δ ) / ( 2 y + 2 δ ) ≥ 3 / 2 − ( r + 2 δ ) / ( 2 x + 2 δ ) ≥ 3 / 2 − ( r + 2 δ ) / ( 2 ir + 2 δ ) ≥ 3 / 2 − ε for sufficiently large i . To prove the second part of the theorem observe that the algorithm that solves any gap in coverage with a triple from any potential left turning point has competitive ratio at most 3 / 2. In the remainder of the section, we assume that L , the length of the barrier segment, is known to the online algorithm. We first prove a lower bound on the competitive ratio of any online algorithm for the problem. Theorem 3 Assume that the online robot knows the length L of the barrier [ 0 , L ] . For any 0 < ε  1 , the competitive ratio of any online algorithm is at least 5 4 − ε . Proof. Once again, we provide an adversary argument. We first give the high-level idea of the argument: the adversary creates a gap followed by a pile of k stacked sensors that is just sufficient to cover the gap (see Figure 6). If the online robot decides to use a triple to cover the 11 0 x y L=y+r+ δ offline online (b) 0 x online offline L=6x (a) Figure 5: Competitive ratio for the case when the robot does not know L . In (a) the robot turns at L or y ≥ 6 x , in (b) the robot turns at y < 6 x . k 2rk−2 2rk−2 0 L Figure 6: Example for the lower bound on the competitive ratio gap, the adversary repeats the pattern. If at some point, the online robot does not return with a triple to cover the gap, the adversary creates no more gaps. We then show that regardless of when the online robot decides not to cover a given gap with a triple, its trajectory is at least 5 4 times the optimal trajectory. We proceed to give the details of the argument, constructing the input progressively as a function of the behaviour of the robot. Assume that the length of the barrier is L ; the values of k and r will be specified later as functions of L . We repeat the following steps: We create a gap of size 2 r ( k − 1 ) followed by k sensors all at position 2 r ( k − 1 ) + r . It is clear that the first k − 1 sensors can cover the first gap. We now observe the online robot. If the robot turns left at any point y ≥ x and does a triple to cover the gap before x , then as soon as possible after it returns to y , we repeat the same configuration: a gap of the same length followed by a stack of k sensors. Until the robot turns left, we simply place sensors 2 r apart. These steps are repeated until we reach L − 2 r , at which point we shorten the last gap if needed, and add as many sensors as needed to cover the preceding gap. We also add an additional (and last) sensor, to force every algorithm, online and offline, to come to position L − r to cover the gap at L . Consider the online robot after it has finished its operation. Define the last gap that the robot covered with a triple to be the i th gap and let x be the position of the stack of sensors immediately after this gap. Then x ≥ 2 ikr − r . Observe that the input instance has exactly one more gap after x , and the robot needs to cover the i + 1 st gap with a double. We denote the length of the online robot’s trajectory by T A . The length of the robot’s trajectory until x is at least 3 x − 4 ir + 2 r and the length of the double to return to cover the i + 1 st gap is 12 2 r + 2 ( L − r − ( x + 2 r )) . Therefore T A = x + 2 L − 4 ir − 2 r . We compare the performance of the robot with two specific offline algorithms. The first algorithm does no triples and achieves coverage simply by doing one double. We denote the length of its trajectory by T 1 ; clearly, T 1 = 2 L − 3 r . The second algorithm uses the same trajectory as the online robot for all its triples, proceeds to cover the i + 1 st gap also with a triple followed by moving right to L − r . (Recall that after the i + 1 st stack of sensors, there are no gaps except the last gap at L .) We denote the length of the second algorithm’s trajectory by T 2 . Then the length of the trajectory for the second algorithm until x + 2 rk is 3 ( x + 2 rk ) − 4 ( i + 1 ) r + 2 r and the length of the final (single) segment is L − r − ( x + 2 rk ) . T 2 = 2 x + L + 4 rk − 4 ir − 3 r Suppose x ≥ L / 2 − 2 rk . Then: T A T 1 ≥ x + 2 L − 4 ir − 2 r 2 L > L / 2 − 2 rk + 2 L − 4 ir − 2 r 2 L = 5 4 − 2 rk + 4 ir + 2 r 2 L Suppose instead x < L / 2 − 2 rk . Then T A T 2 ≥ x + 2 L − 4 ir − 2 r 2 x + L + 4 rk − 4 ir − 3 r > x + 2 L − 4 ir − 2 r 2 x + L + 4 rk = x + L / 2 + 2 rk 2 x + L + 4 rk + + 3 L / 2 − 2 r ( k + 1 ) − 4 ir 2 x + L + 4 rk > 1 2 + 3 L / 2 − 2 r ( k + 1 ) − 4 ir 2 L = 5 4 − 2 rk + 4 ir + 2 r 2 L By choosing r = k = L 1 / 3 , we obtain i = O ( L 1 / 3 ) . This gives a lower bound on the competitive ratio of the online robot of 5 4 − O ( L − 1 / 3 ) . By choosing L to be as large as needed, the theorem follows. The optimal offline algorithm suggests that if the online robot stops doing triples too soon, it may be beaten by an algorithm that does perhaps just one more triple which avoids the double at the end. However if it keeps doing triples for too long, it may be beaten by an algorithm that does fewer triples. It is natural to ask whether there an optimal fraction of the segment such that the online robot can decide in advance to do triples only until then. We say that an online algorithm has a fixed switching point z if it covers each gap before z with a triple, and all gaps after z with the final double. Therefore, the online robot turns left at most once after z , and if it does, it turns at position L − r to do the final double. We show below a tight bound on the competitive ratio of an online algorithm with a fixed switching point. Theorem 4 Assume that the robot knows the length L of the barrier [ 0 , L ] . 1. For any 0 < ε  1 , the competitive ratio of any online algorithm with a fixed switching point is at least 4 3 − ε . 2. There is an online algorithm with fixed switching point with competitive ratio at most 4 3 . 13 Proof. Consider an online robot that has a fixed switching point z such that 0 ≤ z ≤ L . Suppose z ≤ 2 L / 3, and let k = b ( z + r ) / 2 r c . Consider an input consisting of k attached sensors that clearly cover the barrier until 2 kr , then the next sensor at position 2 kr + 3 r / 2. Clearly, there is a gap of length r / 2 between the k th and ( k + 1 ) st sensors. Next place a sensor at position 2 kr + 3 r and sensors in attached position after this until almost the endpoint with the usual gap at the end of the barrier. Thus the only two gaps are between the k th and ( k + 1 ) st sensors, and the one at the end. However, since z < 2 kr + r , the online robot cannot turn back at the ( k + 1 ) st sensor to do a triple to cover the gap before that sensor, and must instead cover both gaps with a double. Therefore, the online robot’s trajectory is of length at least 2 L − 2 kr − 3 r ≥ 2 L − z − 4 r , while the optimal trajectory contains a triple to complete the gap after z , and has length at most L . Since z ≤ 2 L / 3, the competitive ratio of the algorithm is at least 4 / 3 − 4 r / L > 4 / 3 − ε for 4 r / L < ε . Suppose instead that z > 2 L / 3 and let k = d z / 2 r e . Now consider an input that has a gap from the beginning and then a stack of k sensors at z that suffice to cover the gap before z , followed by the next sensor at 2 kr + 3 r / 2 and attached sensors after that until almost the endpoint of the barrier as before. Observe that there are three gaps: the gap before z that can be solved by turning left at z and doing a triple, the gap between the k th and ( k + 1 ) st sensors after z , and the gap at the end (If z is so close to the right endpoint that there is no room for two gaps after z , then it is easy to show that the competitive ratio is actually ≈ 3 / 2.) Thus the online robot must turn at z to cover the gap with a triple, and cover the remaining gaps with a double, with a trajectory of length at least 2 L + z − 8 r , while the optimal trajectory has length 2 L − 3 r . Since z > 2 L / 3, the competitive ratio of the algorithm is at least 4 / 3 − 4 r / L . By choosing 4 r / L < ε for any given ε , we obtain a lower bound of 4 / 3 − ε for the competitive ratio. Consider now an online algorithm A with a fixed switching point 2 L / 3: it turns left at every potential left turning point before 2 L / 3 to cover the preceding gap with a triple. After it passes z however, it will only turn left at the end and do a double if necessary. We claim that A has competitive ratio 4 / 3. Suppose the optimal offline algorithm O does at least one fewer triple than A . Then it is not difficult to see that T A T 0 ≤ 8 L / 3 − 8 r 2 L − 3 r < 4 3 . If instead the optimal algorithm does at least one more triple than A , then it is not difficult to see that T A T 0 ≤ 4 L / 3 − r L < 4 3 . Thus in both cases the competitive ratio of the algorithm is at most 4 / 3, matching the lower bound. Thus, by deciding in advance a switching point at which to stop doing triples, it is im- possible to derive an online algorithm that matches the lower bound of Theorem 3. We now specify AdaptiveOnline , an online algorithm for a robot which, when starting at location 0, relocates sensors on the segment [ 0 , L ] to achieve complete barrier coverage. We calculate an 14 upper bound on the competitive ratio of this online algorithm and prove that it asymptotically matches the lower bound of 5 / 4 from Theorem 3. Clearly, an online algorithm can calculate the coverage balance of any sensor it encounters. We now describe two functions for the on- line robot used in the algorithm. The first function is called walk-in-surplus and is defined as follows: When at a potential left-turning point (or the start of the barrier) the robot moves right picking up sensors having a positive coverage balance and deposits them 2 r apart (as the optimal offline algorithm constructing a fully-stretched solution would do), until reaching a point x such that the last sensor it dropped was at location x − 2 r , and no sensors were en- countered in the interval [ x − 2 r , x ] . Observe that at such a position x , the robot knows that x is a potential right-turning point. The function then returns the value x . The second function is called walk-in-deficit : When first time at a potential right-turning point, robot moves right picking up sensors with negative coverage balance on its way until it reaches a sensor with negative coverage balance greater than − 2 r , or balance exactly − 2 r and collocated with the next sensor. Thus, this is a potential left turning point y ; the function then returns the value y . The functions a triple , and a double behave the same way as in the offline algorithm. The main challenge for the online algorithm is to determine, when it reaches a potential left turning point, whether to do a triple at this point, or to switch to solving the remaining segment as part of the final double. We specify our adaptive online algorithm as a recursive procedure AdaptiveOnline(t,L,r) in which [ t , L ] is the subinterval on which the robot has not yet travelled, and barrier coverage remains to be achieved, and r is the range of sensors. To calculate the coverage of [ 0 , L ] we execute AdaptiveOnline(0,L,r) . We assume that there is a gap at position 0; if not, we simply execute the walk-in-surplus function until reaching a potential right turning-point x and then call AdaptiveOnline on the segment [ x − r , L ] . It is clear that the initial part of the trajectory executed until x is optimal, and cannot increase the competitive ratio on the entire input. We give the pseudocode for the algorithm below. Algorithm AdaptiveOnline ( t , L , r ) ; Input: t , L , the subinterval being solved, with a gap at t and r is the range of sensors Output: the moves of the robot; Variables: : x ; // the current position T ; // current trajectory length γ i ; // ratio trajectory/distance at left-turning point in iteration i β i ; // ratio trajectory/distance at right-turning point in iteration i functions: walk-in-surplus, walk in deficit, triple and double x ← t + r ; T ← 0; i ← 0; // initialization of variables repeat i ← i + 1; // iteration of loop b i ← x ; // potential right-turning point β i ← ( T + r ) / b i // ratio at start of possible triple 15 a i ← walk-in-deficit; // potential left-turning point T ← T + r + 3 ( a i − b i ) ; // trajectory if triple is done γ i ← T / a i ; // ratio at end of possible triple if γ i a i − a i > L − t break // exit the loop else do a triple on segment [ b i , a i ] , x ← walk-in-surplus; // gap starting at x − r T ← T + ( x − r − a i ) ; //update trajectory until start of gap If x < L and T / ( x − r ) ≤ 2 . 5 then AdaptiveOnLine(x-r,L,r); until x = L ; if ( L not reached) then do a double (to L − r and back to b i ); T ← T + ( L − a i ) − ( a i − b i ) ; The key idea is as follows: First, the online robot keeps track of the ratio between its trajectory so far versus the distance it has covered. If it discovers that this ratio is less than 5 / 2, then it ”forgets about” the segment covered so far (it will be shown that it has achieved a competitive ratio of at most 5 / 4 for this part), and restarts its computations. The ratio between its trajectory and distance travelled so far is computed only at potential left and right turning points. Secondly, when it reaches a potential left-turning point, the online robot calculates the cost of the triple: the difference between its trajectory if it executes the triple and the distance covered so far. If this difference is too high, it decides to stop doing triples, and finish by doing a double. Observe that before making a recursive call, at least one gap is covered by the robot. Since the number of gaps is finite, the algorithm terminates. It is also clear that AdaptiveOnLine constructs a trajectory that results in barrier coverage. It remains only to analyze the compet- itive ratio of the trajectory length. Let T A ( I ) and T o ( I ) be the lengths of the trajectories of the algorithm AdaptiveOnline and the optimal offline algorithm on an input instance I respec- tively. We prove a bound of 5 / 4 on max I { T A ( I ) / T o ( I ) } , thereby matching the lower bound of Theorem 3. Fix an input instance I . Observe that the algorithm AdaptiveOnline partitions the segment [ 0 , L ] into sub-segments that are solved in each recursive call of the algorithm. We call each of these sub-segments an epoch ; let n be the number of epochs, such that while traversing epoch j , there is no recursive call. Let T j be the length of the the trajectory of the online robot in epoch j , and let O j be the length of the trajectory of the optimal offline robot in the same epoch. Every epoch starts with a gap, and in every epoch except possibly the last, the mobile robot does triples from the first encountered left-turning point to cover gaps. Lemma 5 T j / O j ≤ 5 / 4 for 1 ≤ j ≤ n − 1 Proof. Let the length of epoch j be ` j . Since the epoch starts with a gap, the optimal algorithm either does the same thing as the mobile robot in the epoch, in which case T j / O j = 1 or it does part of the epoch using a double in which case T j / O j ≤ T j 2 ` j . Since in each of the epochs j 16 for 1 ≤ j ≤ n − 1, the recursive call is made only when T j /` j ≤ 2 . 5, we have T j ≤ 2 . 5 ` j . The lemma follows. Lemma 6 The difference between the trajectory length and the distance covered on the seg- ment stays the same while executing walk-in-surplus or walk-in-deficit . Proof. Let T be the trajectory length at point z just before executing walk-in-surplus (or walk- in-deficit) and let T ′ be the trajectory at point z ′ at the end of its execution. Then T ′ − z ′ = ( T + z ′ − z ) − z ′ = T − z . Lemma 7 T n / O n ≤ 5 / 4 Proof. In epoch n , there are no recursive calls. For simplifying the analysis, we assume t = 0 and L = 1. Assume the loop was exited in iteration i . Observe that the loop can be exited either because x = 1 or because T − a i > 1. We first consider the case when the loop is exited because x = 1. In this case, we know that γ i a i − a i ≤ 1 and the online robot walked in surplus after this till the end. Thus, the optimal offline algorithm could not have done more triples than the online robot. Consider an optimal offline algorithm that does fewer triples. Then T n O n ≤ T n 2 = γ i a i + ( 1 − a i ) 2 ≤ 2 2 = 1 (1) Thus T n / O n = 1 in this case. Next we consider the case when the loop is exited in iteration i because T − a i > 1. If i = 1, since T = r + 3 ( a i − r ) , this implies 2 a i − 2 r > 1. Observe that the online robot does no triples at all, and does only a double and has a trajectory of length 2 − r . An algorithm that does the triple in the segment [ r , a i ] has length at least r + 3 ( a i − r ) + 1 − a i = 1 + 2 a i − 2 r > 2 which means it is sub-optimal. Therefore, in this case again T n / O n = 1. Suppose instead the loop is exited in iteration i > 1 because T − a i = γ i a i − a i > 1. Denote by d , the distance between a and b , that is, d = a − b . Then β i = γ i a i − 3 d a i − d (2) Next observe that since at the end of iteration i − 1, the value of T / ( x − r ) > 2 . 5, we obtain 3 ≥ β i = ( T + r ) / x > 2 . 5. It follows now from Equation 2 that γ i > 2 . 5 (3) Since the loop was not exited in iteration i − 1, it must be that γ i − 1 a i − 1 − a i − 1 ≤ 1 and since the only moves between a i − 1 and b i are achieved by walk-in-surplus and walk-in-deficit, it follows from Lemma 6 that β i b i − b i = γ i − 1 a i − 1 − a i − 1 ≤ 1. Substituting b i = a i − d , and using Equation 2, we obtain: γ i a i − a i − 2 d ≤ 1 . (4) Finally, recall that γ i a i − a i > 1 (5) For reasons that will be clear later, we now prove the following claim: 17 Claim 1 γ i a i − 2 a i − d ≤ 0 . 5 Proof. Suppose a i ≤ 0 . 5 + d . Then since γ i ≤ 3, we conclude that γ i a i − 2 a i − d ≤ 3 a i − 2 a i − d = a i − d ≤ 0 . 5. If instead that a i > 0 . 5 + d , then it follows from Equation 4 that γ i a i − 2 a i − d < 1 − ( a i − d ) < 0 . 5 Now consider the value of T n . We have T n = γ i a i + 2 ( 1 − a i ) − d = 2 + γ i a i − 2 a i − d (6) Suppose the optimal algorithm did fewer triples than AdaptiveOnline . Then T n O n ≤ T n 2 = 2 + γ i a i − 2 a i − d 2 ≤ 5 4 (7) where the last inequality follows from Claim 1. If instead the optimal algorithm did more triples that AdaptiveOnline , its trajectory is of length at least γ i a i + 1 − a i . Therefore T n O n ≤ T n γ i a i + 1 − a i ≤ T n 2 ≤ 5 4 (8) where the second inequality uses (5). Lemmas, 5, 7 show that in each epoch the competitive ratio is at most 5 / 4. Thus we get the following theorem. Theorem 5 AdaptiveOnline is an online algorithm for barrier coverage of a line segment of known length and has competitive ratio at most 5 / 4 , and is therefore optimal. References [1] P. Balister, B. Bollobas, A. Sarkar, and S. Kumar. Reliable density estimates for coverage and connectivity in thin strips of finite length. In Proc. of MobiCom’07 , pages 75–86, 2007. [2] B. Bhattacharya, M. Burmester, Y. Hu, E. Kranakis, Q. Shi, and A. Wiese. Optimal movement of mobile sensors for barrier coverage of a planar region. Theoretical Com- puter Science , 410(52):5515–5528, 2009. [3] J. Chalopin, S. Das, M. Mihalak, P. Penna, and P. Widmayer. Data delivery by energy- constrained mobile agents. In proceedings of Algosensors 2013, LNCS , volume 8243, pages 111–122. Springer, 2013. [4] M. Charikar, S. Khuller, and B. Raghavachari. Algorithms for capacitated vehicle rout- ing. SIAM Journal on Computing , 31(3):665–682, 2001. [5] D. Chen, Y. Gu, J. Li, and H. Wang. Algorithms on minimizing the maximum sensor movement for barrier coverage of a linear domain. In Proceedings of SWAT 2012, LNCS , volume 2012, pages 177–188. Springer, 2012. 18 [6] J. Czyzowicz, E. Kranakis, D. Krizanc, I. Lambadaris, L. Narayanan, J. Opatrny, L. Sta- cho, J. Urrutia, and M. Yazdani. On minimizing the maximum sensor movement for barrier coverage of a line segment. In Proceedings of AdHocNow 2009, LNCS , volume 5793, pages 194–212, 2009. [7] J. Czyzowicz, E. Kranakis, D. Krizanc, I. Lambadaris, L. Narayanan, J. Opatrny, L. Sta- cho, J. Urrutia, and M. Yazdani. On minimizing the sum of sensor movements for barrier coverage of a line segment. In Proceeding of AdHocNow, LNCS , volume 6288, pages 29–42, 2010. [8] J. Djugash, S. Singh, G.A. Kantor, and W. Zhang. Range-only SLAM for robots operat- ing cooperatively with sensor networks. In Proceedings of IEEE International Confer- ence on Robotics and Automation , pages 2078 – 2084, May 2006. [9] GKmM summer school 2012 website. http://www.gkmm.tu-darmstadt.de/ summerschool/ . Accessed Jan 25, 2014. [10] M. E. Hesari, E. Kranakis, D. Krizanc, O. Morales-Ponce, L. Narayanan, J. Opatrny, and S. Shende. Distributed algorithms for barrier coverage using relocatable sensors. In Proceedings of PODC 2013 , pages 383–392, 2013. [11] P. Jaillet and M.R. Wagner. Online vehicle routing problems: A survey. In The Vehicle Routing Problem: Latest Advances and New Challenges , pages 221–237. Springer US, 2008. [12] B. Jung and G. Sukhatme. Cooperative tracking using mobile robots and environment- embedded networked sensors. In International Symposium on Computational Intelli- gence in Robotics and Automation , pages 206–211, 2001. [13] A. Koubaa and A. Khelil, editors. Cooperative robots and Sensor Networks . Studies in Computational Intelligence. Springer, 2013. [14] M. Kropff, C. Reinl, K. Listmann, K. Petersen, K. Radkhah, F.K. Shaikh, A. Herzog, A. Strobel, D. Jacobi, and O. von Stryk. MM-ulator: Towards a common evaluation platform for mixed mode environments. In Simulation, Modeling, and Programming for Autonomous Robots (SIMPAR): Springer-Verlag LNAI , volume 5325, pages 41–52, 2008. [15] S. Kumar, T. H. Lai, and A. Arora. Barrier coverage with wireless sensors. In Proceed- ings of MobiCom’05 , pages 284–298, 2005. [16] Robosense 2012 workshop website. www.robosense.org . Accessed Jan 25, 2014. [17] Robosense 2013 workshop website. http://www.coins-lab.org/events/ RoboSense13/ . Accessed Jan 25, 2014. 19 [18] A. Saipulla, C. Westphal, B. Liu, and J. Wang. Barrier coverage of line-based deployed wireless sensor networks. In Proceedings of IEEE INFOCOM’09 , pages 127–135, 2009. [19] C. K. Seow, W. K. G. Seah, and Z. Liu. Hybrid mobile wireless sensor network cooper- ative localization. In Proceedings of IEEE 22 nd Int. Symposium on Intelligent Control , pages 29–34, 2007. [20] W. Shi and J.-P. Corriveau. A comprehensive review of sensor relocation. In Proceed- ing of IEEE/ACM International Conference on Green Computing and Communications , pages 780–785, 2010. [21] J. Teng, T. Bolbrock, G. Cao, and T. La Porta. Sensor relocation with mobile sensors: Design, implementation, and evaluation. In Proceedings of IEEE MASS , pages 1–9, 2007. 20