Multi-robot deployment from LTL specifications with reduced communication - technical report - Marius Kloetzer, Xu Chu Ding, and Calin Belta Abstract —In this work, we develop a computational framework for fully automatic deployment of a team of unicycles from a global specification given as an LTL formula over some regions of interest. Our hierarchical approach consists of four steps: (i) the construction of finite abstractions for the motions of each robot, (ii) the parallel composition of the abstractions, (iii) the generation of a satisfying motion of the team; (iv) mapping this motion to individual robot control and communication strategies. The main result of the paper is an algorithm to reduce the amount of inter-robot communication during the fourth step of the procedure. I. INTRODUCTION Motion planning and control is a fundamental problem that have been extensively studied in the robotics literature [1]. Most of the existing works have focused on point-to-point navigation, where a mobile robot is required to travel from an initial to a final point or region, while avoiding obstacles. Several solutions have been proposed for this problem, in- cluding cell decomposition based approaches that use graph search algorithms such as A ∗ [1], [2], continuous approaches involving navigation functions and potential fields [3], and sampling-based methods such as Rapidly-Exploring Random Trees (RRTs) [4], [5]. However, the above approaches can- not accommodate complex task specifications, where a robot might be required to satisfy some temporal and logic con- straints, e.g., “avoid E for all times; visit A or B and then be at either C or D for all times”. In recent years, there has been an increased interest in using temporal logics to specify mission plans for robots [6]–[12]. Temporal logics [13]–[15] are appealing because they provide formal, rich, and high level languages in which to describe complex missions. For example, the above task specification translates immediately to the Linear Temporal Logic (LTL) formula  ¬ E ∧ ♦ (( A ∨ B ) ∧ ♦  ( C ∨ D )) , where ¬ , ∨ , ∧ are the usual Boolean operators, and ♦ ,  are two temporal operators standing for “eventually” and “always”, respectively. Computation Tree Logic (CTL) and μ -calculus have also been advocated as robot motion specification languages [7], [11]. This work was partially supported by the CNCS-UEFISCDI grant PN- II-RU PD 333/2010 at the Technical University of Iasi, Romania, and by ONR MURI N00014-09-1051, ARO W911NF-09-1-0088, AFOSR YIP FA9550-09- 1-020 and NSF CNS-0834260 at Boston University. M. Kloetzer is with the Department of Automatic Control and Ap- plied Informatics, Technical University “Gheorghe Asachi” of Iasi, Romania kmarius@ac.tuiasi.ro X. C. Ding and C. Belta are with the Department of Me- chanical Engineering, Boston University, Boston, MA 02215, USA { xcding,cbelta } @bu.edu To use formal languages and model checking techniques for robot motion planning and control, a fundamental challenge is to construct finite models that accurately capture the robot motion and control capabilities. Most current approaches are based on the notion of abstraction [16]. Enabled by recent developments in hierarchical abstractions of dynamical sys- tems [17]–[21]), it is now possible to model the motions of several types of robots as finite transition systems over a cell-based decomposition of the environment. By using equivalence relations such as simulations and bisimulations [22], the motion planning and control problem can be reduced to a model checking or formal synthesis problem for a finite transition system, for which several techniques are readily available [14], [23]–[25]. Some recent works suggest that such single-robot tech- niques can be extended to multi-robot systems through the use of parallel composition (synchronous products) [11], [26]. The main advantage of such a bottom-up approach is that the motion planning problem can be solved by off-the-shelf model checking on the parallel composition followed by canonical projection on the individual transition systems. The two main limitations, both caused by the parallel composition, are the state space explosion problem and the need for inter- robot synchronization (communication) every time a robot leaves its current region. In our previous work, we proposed bisimulation-type techniques to reduce the size of the syn- chronous product in the case when the robots are identical [27] and derived classes of specifications that do not require any inter-robot communication [26]. By drawing inspiration from distributed formal synthesis [28], we have also proposed top- down approaches that do not require the parallel composition of the individual transition systems [29]. While cheaper, this method restricts the specifications to regular expressions. In this paper, we focus on bottom-up approaches based on parallel composition and address one of the limitations men- tioned above. Specifically, we develop an algorithm that deter- mines a reduced number of synchronization (communication) moments along a satisfying run of the parallel composition. Our approach is heuristic - we do not minimize the necessary amount of communication. However, our approach can be directly modified to produce minimal sets of synchronization moments. Our extensive experiments show that the proposed algorithm leads to a significant reduction in the number of synchronizations. We integrate this algorithm into a software tool for automatic deployment of unicycles with polyhedral control constraints from specifications given as LTL formulas arXiv:1108.3240v1 [cs.RO] 16 Aug 2011 over the regions of an environment with a polyhedral partition. The user friendly tool, which is freely downloadable from http: //hyness.bu.edu/ ∼ software/MRRC.htm, takes as input a user- defined environment, an LTL formula over some polytopes, the number of unicycles, and their forward and angular velocity constraints. It returns a control and communication strategy for each robot in the team. While transparent to the user, the tool also implements triangulation and polyhedral operation algorithms from [8], [30], [31], LTL to B ̈ uchi conversion [32], and robot abstraction by combining the affine vector field computation from [21] with input-output regulation [20]. The remainder of the paper is organized as follows. Sec. IIpresents some preliminary notions necessary throughout the paper. Sec. III formulates the general problem we want to solve, outlines the solution and then presents a specific prob- lem of interest. The main contribution of the paper is given in Sec. IV. To illustrate the method and the main concepts, a case study is examined throughout the paper and concluded in Sec. V, while an additional case study is included in Sec. VI. The paper ends with conclusions and final remarks in Sec. VII. II. PRELIMINARIES Definition 2.1: A deterministic finite transition system is a tuple T = ( Q , q 0 , → , Π , ρ ) , where Q is a (finite) set of states, q 0 ∈ Q is the initial state, →⊆ Q × Q is a transition relation, Π is a finite set of atomic propositions (observations), and ρ : Q → 2 Π is the observation map. To avoid supplementary notations, we do not include control inputs in Definition 2.1 since T is deterministic, i.e. we can choose any available transition at a given state. A trajectory or run of T starting from q is an infinite sequence r = r ( 1 ) r ( 2 ) r ( 3 ) . . . with the property that r ( 1 ) = q 0 , r ( i ) ∈ Q , and ( r ( i ) , r ( i + 1 )) ∈→ , ∀ i ≥ 1. A trajectory r = r ( 1 ) r ( 2 ) r ( 3 ) . . . defines an infinite word over set 2 Π , w = w ( 1 ) w ( 2 ) w ( 3 ) . . . , where w ( i ) = ρ ( r ( i )) . With a slight abuse of notation, we will denote by ρ ( r ) the word generated by run r . The set of all words that can be generated by T is called the ( ω -) language of T . In this paper we consider motion specifications given as formulas of Linear Temporal Logic (LTL) [14]. A formal definition for the syntax and semantics of LTL formulas is beyond the scope of this paper. Informally, the LTL formulas are recursively defined over a set of atomic propositions Π , by using the standard boolean operators and a set of temporal operators. The boolean operators are ¬ (negations), ∨ (disjunc- tion), ∧ (conjunction), and the temporal operators that we use are: U (standing for “until”),  (“always”), ♦ (“eventually”). LTL formulas are interpreted over infinite words over set 2 Π , as are those generated by transition system T . For LTL formulas satisfied by continuous systems, we restrict the class of specifications to LTL − X , which are LTL formulas without the “next” temporal operator. We note that, the class of LTL − X is not at all restrictive, since for continuous systems LTL − X captures the full expressivity power of LTL [8]. All LTL formulas can be converted into a generalized B ̈ uchi automaton [32] defined below: Definition 2.2 (Generalized B ̈ uchi automaton): A gen- eralized B ̈ uchi automaton is a tuple B = ( S , s 0 , Σ , → B , F ) , where • S is a finite set of states, • S 0 ⊆ S is the set of initial states, • Σ is the input alphabet, • → B ⊆ S × Σ × S is a (nondeterministic) transition relation, • F ⊆ 2 S is the set of sets of accepting (final) states. The semantics of a B ̈ uchi automaton is defined over infinite input words over Σ . An input word is accepted by automaton B if and only if there exists a run produced by that word with the property that all sets from F are infinitely often visited. Due to the complicated acceptance condition (multiple sets have to be infinitely often visited), a generalized B ̈ uchi automaton is usually converted into a regular (degeneralized) B ̈ uchi automaton. A regular B ̈ uchi automaton has only one set of final states, i.e. F ∈ 2 S . Any generalized B ̈ uchi automaton can be transformed into a regular B ̈ uchi automaton that accepts the exact same words. A conversion algorithm can be found in [32]. For any LTL formula φ over a set of atomic propositions Π , there exists a (generalized or regular) B ̈ uchi automaton B φ with input alphabet Σ ⊆ 2 Π accepting all and only infinite words over Π satisfying formula φ [33]. Given a transition system T with set of observations Π and an LTL formula φ over Π , one can find a trajectory of T which generates a word satisfying φ . This can be done by using model checking inspired tools [8], which begin by translating φ to a regular B ̈ uchi automaton B φ . Then, the product of T with B φ is computed, operation that can be informally viewed as a matching between observations of T and transitions of B φ . An accepted run (if any) of the obtained product automaton is chosen. This accepted run is projected into a run r of T , which generates a word satisfying φ . Although r is infinite, it has a finite-representable form, namely it consists of a finite string called prefix , followed by infinite repetitions of another finite string called suffix (such a run is said to be in the prefix-suffix form). A cost criterion can be imposed on the obtained run r , e.g. the minimum memory for storing it, or a minimum cost on transitions of T encountered when following the prefix and a finite number of repetitions of the suffix. The run r can be be directly generated on T if one can deterministically control (impose) the transition that appears in each state (which is true for a deterministic transition system T defined in 2.1). III. PROBLEM FORMULATION AND APPROACH In this paper we are interested in developing an automated framework for deploying identical unicycle robots in planar environments. Assume that such a robot is described by ( x , y , θ ) , where ( x , y ) ∈ R 2 gives the position vector of the robot’s center of rotation, and θ is its orientation. The control w = [ v , ω ] T ∈ W ⊆ R 2 consists of forward driving ( v ) and steering ( ω ) speeds, where W is a set capturing control bounds. We assume that W includes an open ball around the origin, which implies that v can be also negative ( i.e. the robot can drive backwards). The kinematics of the unicycle are given by:    ̇ x = v cos θ ̇ y = v sin θ ̇ θ = ω (1) Assume that some robots move in a polygonal convex environment with kinematics given by (1), where a set Π of non-overlapping convex polygonal regions 1 are defined. The general deployment problem for a team of unicycle robots satisfying an LTL formula is given by: Problem 3.1: Given a team of n unicycles and a task in the form of an LTL − X formula φ over a set of regions of interest Π , design individual communication and control strategies for the mobile robots such that the motion of the team satisfies the specification. We assume that the unicycles are identical and have a small (negligible) size when compared to the size of the environment and of the predefined regions. Moreover, we consider that a unicycle visits (or avoids) a region when a specific reference point on it visits (or avoids) that region. To fully understand Problem 3.1, we say that the motion of the team satisfies an LTL formula φ if the word generated during the motion satisfies φ . The word generated by a set of n continuous trajectories is a straightforward generalization of the definition of the word generated by a single trajectory [8]. Informally, the word generated by the team motion consists of a sequence of elements of 2 Π containing the satisfied propositions (visited regions) as time evolves. In a generated word, there are no finite successive repetition of the same element of 2 Π , and infinite successive repetitions of the same element appear if and only if each robot trajectory stays inside a region. Case study : For better understanding of introduced con- cepts, throughout this paper, we consider a case study with the environment illustrated by Fig. 1, where 3 unicycle-type mobile robots evolve. The reference point of each unicycle is its “nose”, the center of rotation is the middle of the rear axis, and the initial deployment of robots is the one from Fig. 1. The imposed specification requires that “regions π 1 and π 4 and π 6 are simultaneously visited, and regions π 2 and π 5 are simultaneously visited, infinitely often, while region π 3 is always avoided”. This specification translates to the following LTL formula: φ =  ¬ π 3 ∧  ♦ (( π 1 ∧ π 4 ∧ π 6 ) ∧ ♦ ( π 2 ∧ π 5 )) (2) To provide a deployment strategy for Problem 3.1, we will first combine various techniques from computational geom- etry, motion planning and model checking until we obtain a solution in the form of a sequence of tuples of smaller regions and feedback control laws in each of these regions. After this, 1 Note that convex non-polygonal regions can be bounded by convex polygonal regions with arbitrary accuracy, and non-convex regions can be divided into adjacent convex regions π 1 π 2 π 4 π 5 π 6 π 3 Fig. 1. A polygonal environment, six regions of interest, and the initial deployment of three unicycle robots. Robot 1 is green, robot 2 is blue, and robot 3 is red; there is no relation between the robot and the region colors. Fig. 2. Triangular partition consisting of 40 regions, corresponding to the environment from Fig. 1. we focus on the main contribution of the paper, namely finding a reduced set of communication (synchronization) moments among robots, while still guaranteeing the satisfaction of the specification. The main steps of the algorithmic approach for solving Problem 3.1 are given in the following 3 subsections. A. Robot Abstraction We first abstract the motion capabilities of each robot to a finite transition system. To this end, the environment is first partitioned into convex regions (cells) such that two adjacent cells exactly share a facet, and each region from Π consists of a set of adjacent cells. Such a partition can be constructed by employing cell decomposition algorithms used in motion planning and computational geometry, e.g. one can use a constraint triangulation [21] or a polytopal partition [8]. Let us denote the set of partition elements by C = { c 1 , c 2 , . . . , c | C | } . For a clear understanding, Fig. 2 presents a triangular partition obtained for the environment from Fig. 1. We use a triangular partition for the case study presented throughout this paper, although our approach can be applied to any partition scheme. The second step is to reduce each unicycle with kinematics (1) to a fully-actuated point robot placed in unicycle’s ref- erence point. We use the approach from [20], where a non- singular map relates the velocity u of the reference point to the initial controls w = [ v , ω ] T . Note that u can be conservatively bounded by a polyhedral set U , such that the resulted control w is in W . Definition 3.1: The transition system abstracting the mo- tion capabilities of unicycle i , i = 1 , . . . , n has the form T i = ( Q i , q 0 i , → i , Π ∪ { / 0 } , ρ ) , where: • Q i = C , i.e. the set of states is given by the cells from partition; • The initial state q 0 i ∈ C is the cell where the reference point of unicycle i is initially deployed; • The transition relation → i ∈ C × C is created as follows: – ( c i , c i ) ∈→ i if we can design a feedback control law making cell c i invariant with respect to the trajectories of the reference point of unicycle i , and – ( c i , c j ) ∈→ i , i 6 = j if c i and c j are adjacent and we can design a feedback control law such that the reference point of unicycle i leaves cell c i in finite time, by crossing the common facet of c i and c j ; • Π labels the set of regions of interest, and symbol / 0 corresponds to the space not covered by any region of interest; • The observation map ρ associates each cell from the partition with the corresponding proposition from Π , or with the symbol / 0. Considering the unicycles reduced to their reference point, the construction of the continuous controllers corresponding to the transition relation from Definition 3.1 is done by using results for facet reachability and invariance in polytopes [21]. We just mention that designing such feedback control laws reduces to solving a set of linear programming problems in every cell from partition, where the constraints result from the control bounds U and the considered adjacent cells. Also, since the reference point is fully-actuated and the control bounds U include the origin, we obtain a transition between every adjacent cells, as well as a self-loop in every state of T i . Therefore, a run of T i can be implemented by unicycle i by imposing specific control laws for the reference point in the visited cells, and by mapping these controls to w . We note that, since the unicycles are identical, the only difference between transition systems T i is given by their initial states. Case study revisited: The partition from Fig. 2 enables us to construct a transition system with 40 states corresponding to each robot, where the transitions are based on adjacency relation between cells from environment, and the observations are given by the satisfied region. Fig. 3 illustrates some vector fields obtained from driving-to-facet control problems and from invariance controlled design, as well as the corresponding transitions from system T i . B. Satisfying Behavior of the Team In this part of the solution, we use ideas from [26], [27] to find a run (for the whole team) satisfying the formula φ . The n transition systems T i are combined into a global one, T G , capturing the synchronized motion of the team (synchronized in the sense that robots change at the same time the occupied π 2 Ø Ø c 8 c 15 c 6 c 8 c 6 c 15 Fig. 3. Left: vector fields driving any initial state from cell c 8 to a neighbor (blue and red colors), and vector field making c 6 invariant (black). Right: transitions from T i are colored in accordance with the colors of the created vector fields. Observation given by map ρ is placed near each state. cells from partition, or states from T i ). Then, by using model checking inspired techniques as mentioned in Sec. II, we find a run for the whole team, in the form of a prefix-suffix sequence of tuples. Definition 3.2: The transition system T G = ( Q G , q G 0 , → G , Π , ρ G ) capturing the behavior of the group of n robots is defined as the synchronous product of all T i ’s, i = 1 , . . . , n : • Q G = Q 1 × . . . × Q n , • q G 0 = ( q 01 , . . . , q 0 n ) , • → G ⊂ Q G × Q G is defined by (( q 1 , . . . , q n ) , ( q ′ 1 , . . . , q ′ n )) ∈→ G if and only if ( q i , q ′ i ) ∈→ i , i = 1 , . . . , n , • Π is the observation set, • ρ G : Q G → 2 Π is defined by ρ G (( q 1 , . . . , q n )) = ∪ n i = 1 { ρ ( q i ) } . We now find a run R of T G such that the generated word ρ G ( R ) satisfies φ . For this, we use the tool from [8], and we impose the optimality criterion that during the prefix and one iteration of the suffix, the total number of movements between partition cells is minimized. This is accomplished by adding weights to transitions of T G , where the weight of a transition equals the number of robots that change their state from T i . These weight are inherited when taking the product of T G with B φ . This optimality criterion minimizes the memory used on robots for storing motion controllers (feedback control laws driving robots from one cell to an adjacent one). In [26], [27], such a global run was projected to individual runs of robots. Then, the robots can be controlled by the affine feedback controllers that map to unicycle controls from Sec. III-A. In deployment, when the team makes a transition from one tuple of the run to the next, the robots must synchronize (communicate) with each other and wait until every member finishes the previous transition. The synchronization will occur on the boundaries of the cells when crossing from a cell to another. Remark 3.1: Since the robots are identical, the number of states from T G can be reduced by designing a bisimilar (equivalent) transition system (the quotient induced by robot permutations) [27]. Thus, the computation complexity of find- ing a run R is manageable even for large teams. Case study revisited: For the above introduced example (Fig. 1 and 2, and specification (2)), we obtain a team run R = prefix, suffix, suffix , . . . , with 7 states in prefix and 8 states in suffix, as shown in Eqn. (3). prefix =   c 7 c 4 c 28     c 2 c 3 c 28     c 1 c 6 c 28     c 10 c 8 c 28     c 9 c 17 c 25     c 18 c 11 c 26     c 16 c 11 c 24   suffix =   c 31 c 12 c 38     c 31 c 11 c 38     c 31 c 17 c 24     c 31 c 8 c 27     c 31 c 6 c 20     c 31 c 8 c 27     c 31 c 17 c 27     c 31 c 11 c 24   (3) Run R means that the robots start from their initial cells, and the first to robots evolve to cells c 2 and c 3 respectively. The synchronization imposed by the construction of T G and used in [26], [27] would require that the first two robots cross from c 7 to c 2 and from c 4 to c 3 synchronously (at exactly the same time), and so on. By construction, the word generated by R over the set of propositions Π , ρ G ( R ) , satisfies formula φ from Eqn. (2). However, the mentioned synchronizations are disadvantageous, because they require a lot of communication and waiting, and they imply many discontinuities is the control input of each robot (due to the frequent stops at the facets of traversed cell). Intuitively, one can observe that synchroniza- tions along prefix of R for example do not contribute to the satisfaction of the formula, nor they would lead to its violation, because the robots just head towards some regions they have to visit. As evident from the case study, deployment strategies for a satisfying run R as proposed in [26], [27] require a significant amount of synchronization (and thus communication) among the team. In this paper, rather than synchronizing robots for each transition in R , we aim in finding a reduced set of transitions along R that require synchronization. This problem is formalized in Sec. III-C. Its solution is given in Sec. IV, in the form of an algorithmic procedure returning a reduced number of necessary synchronization moments along R , together with deployment strategies for robots. We note that in [26], we developed an algorithmic tool that tests if unsynchronized motion of the team can lead to a violation of the formula. If the answer is yes (such is the case for the case study considered in this paper), then synchronization required in [26] cannot be reduced. Therefore, the solution to the problem formulated in Sec. III-C constitutes a significant improvement over [26]. C. Minimizing Communication Problem 3.2: Given a run R of T G that satisfies the LTL specification φ , find a team control and communication strat- egy that requires a reduced number of inter-robot synchroniza- tions than in the synchronization-based deployment, while at the same time guaranteeing that the produced motion of the team satisfies φ . Central to our approach to Problem 3.2 is an algorithm that takes as input the satisfying run R = R ( 1 ) R ( 2 ) R ( 3 ) . . . and returns a reduced number of necessary synchronization moments , where the i th moment along R is defined as the index i corresponding to R ( i ) . Motivated by the fact that synchronization by stopping and waiting at region boundaries is not always necessary to produce a desired tuple, we consider two types of synchronizations: in a weak synchronization, a certain tuple is generated because there exists an instant of time at which the robots are in the corresponding cells; a strong synchronization ensures that a sequence of two successive tuples from R is observed. Note that a strong synchronization at each moment in R is exactly the stop and wait strategy from [26], [27]. Since the run is given in the prefix-suffix form, our algorithmic framework will return a finite set of moments that require synchronization, as well as the type for each synchronization moment. IV. SOLUTION TO PROBLEM 3.2 This section provides a solution to Problem 3.2. We first construct an algorithmic procedure for finding a set of neces- sary synchronization moments (Sec. IV-A - IV-C), and then we present a communication strategy guaranteeing that the synchronization moments are satisfied (Sec. IV-D). Without loss of generality, we assume that run R = R ( 1 ) R ( 2 ) R ( 3 ) . . . is in the prefix-suffix form (see Sec. II). Assume that the prefix has length k − 1 and the suffix has length l − k + 1, with R ( j ) = ( c 1 j , c 2 j , . . . , c n j ) T , for j = 1 , . . . , l (and R ( l + 1 ) = R ( k ) , R ( l + 2 ) = R ( k + 1 ) , . . . ). For avoiding supplementary notations implying repetitions of the suffix, we assume that whenever an index along R exceeds l , that index is automatically mapped to the set { k , . . . , l } , i.e. if j = l , then index j + 1 is replaced with k , and so on. For an easier understanding, we use superscripts for identifying a robot and subscripts for indexing the cells. For any robot i = 1 , . . . , n and for any moment j = 1 , . . . , l − 1, cells c ij and c ij + 1 are either adjacent or identical, and the same is true for cells c i l and c i k . Recall that from the abstraction process of continuous robot trajectories, R does not contain any successive and finite repetition of a n -tuple. A. Finding Synchronization Moments The idea of constructing a solution to Problem 3.2 is to start with no synchronization moments, and iteratively test if the formula can be violated and update the set of synchronization moments and their type. Let S ⊆ { 1 , . . . , l } be an arbitrary set of synchronization moments, and let us impose the type of each synchronization moment by creating a map τ : S → { weak , strong } , where τ ( j ) = weak means a weak synchronization at position j , and τ ( j ) = strong means a strong synchronization at position j , ∀ j ∈ S . As mentioned in Sec. III-C, a weak synchronization at moment j along run R means that the tuple R ( j ) is reached by the robots, i.e., there is a moment when the robots are in cells c 1 j , c 2 j , . . . , c n j , respectively. A strong synchronization at moment j along run R means that there is a weak synchro- nization at j , and additionally the robots synchronously enter the next tuple ( R ( j + 1 ) ). In other words, all moving robots i cross from cells c ij to cells c ij + 1 at the same time. One can observe that a strong synchronization at position j is not equivalent to two weak synchronizations at j and j + 1. The strong synchronization guarantees that in the generated team run the tuple R ( j ) is immediately followed by the tuple R ( j + 1 ) . However, the weak moments guarantee that the R ( j ) and R ( j + 1 ) tuples are generated, but there may appear different tuples between them. It can be noted that a weak synchronization at moment j is equivalent with a strong one at the same moment if and only if j = k and the suffix of R has length 1 ( k = l ). For testing the correctness of a set of synchronization moments, we developed a procedure test f easibility φ ( R , S , τ ) , which takes as inputs the formula φ , the run R , a set S of synchronization moments and a map τ . The returned output is either “feasible” (set S with map τ guarantees the satisfaction of the formula, no matter how the robots move in between synchronization moments) or “not feasible” (it is possible to violate the formula by imposing just the moments from S with type τ ). We postpone the details on test f easibility φ ( R , S , τ ) until Sec. IV-B. We use Algorithm 1 for obtaining a solution to Problem 3.2, in the form of a set S of synchronization moments and a map τ . The intuition behind this algorithm is to start with no synchronization moment ( S = / 0) and increase S until we obtain a feasible set together with a corresponding map τ . We show the correctness of the solution given by Algorithm 1 in Sec. IV-C, together with more informal explanations on the provided pseudo-code. Remark 4.1 (Complexity): Algorithm 1 is guaranteed to finish, because in the worst case it returns the set S = { 1 , . . . , l } , meaning that strong synchronizations are needed at every moment (see Sec. IV-C). The worst case complexity requires 3 l ( l + 3 ) / 2 iterations of the test feasibility procedure. Remark 4.2 (Optimality): Algorithm 1 can be tailored such that it returns an optimal solution (with respect to a cost defined by weighting different synchronization moments). This can be done by first constructing all possible pairs S , τ (there are 3 l such pairs). Then, these pairs should be ordered according to their associated cost. Finally, the pairs should be tested (in the found order) against the test feasibility procedure, until a feasible response is obtained. Of course, the worst case would require 3 l iterations of test feasibility (when the only solution is S = { 1 , . . . , l } and strong synchronization at every moment). B. Testing a Set of Synchronization Moments Procedure test f easibility φ ( R , S , τ ) follows several main steps: (i) It produces an automaton A R , S , τ generating all the infinite words (sequences of observed propositions) that can Algorithm 1 Solution to Problem 3.2 Inputs: Run R , formula φ Outputs: Set S , map τ 1: for synch type ∈ { weak , strong } do 2: S = / 0, τ undefined 3: lower bound = 1, moment = l 4: while moment ≥ lower bound do 5: if test f easibility φ ( R , S , τ ) = “feasible” then 6: Return set S and map τ 7: end if 8: S temp = S ∪ { moment , moment + 1 , . . . , l } 9: τ temp ( i ) = τ ( i ) , ∀ i ∈ S 10: τ temp ( i ) = synch type , ∀ i ∈ { moment + 1 , . . . , l } 11: for τ temp ( moment ) ∈ { weak , strong } do 12: if test f easibility φ ( R , S temp , τ temp ) = “feasible” then 13: S : = S ∪ { moment } 14: τ ( moment ) = τ temp ( moment ) 15: lower bound = moment 16: moment = l 17: Break “for” loop on τ temp 18: else 19: moment : = moment − 1 20: end if 21: end for 22: end while 23: end for result while the robots evolve and obey synchronization moments from S (this automaton has the form of a B ̈ uchi automaton with an observation map); (ii) If necessary, A R , S , τ is transformed into a standard (de- generalized) form; (iii) The product automaton between A R , S , τ and the B ̈ uchi cor- responding to negated LTL formula ( B ¬ φ ) is computed and its language is checked for emptiness; (iv) If the language is empty, the procedure returns “feasible” and otherwise it returns “not feasible”. For step (i), the run R is projected to n individual runs, each corresponding to a specific robot. In each of these individual runs, we collapse the finite successive repetitions of identical states (cells) into a single occurrence (such repetitions mean that the individual robot stays inside a cell). Let us denote the resulted runs by R i = q i 1 q i 2 . . . [ q i k i . . . q i l i ] . . . , where prefix has length k i − 1 ( k i ≤ k ) and suffix has length l i − k i + 1 ( l i ≤ l ), i = 1 , . . . , n . Together with individual projections and collapsing, we construct a set of maps β i : { 1 , 2 , . . . , l } → { 1 , 2 , . . . , l i } , i = 1 , . . . , n , mapping each index from run R to the corresponding index from the individual run R i ( e.g. β i ( j ) = β i ( j + 1 ) if we have the same i th element in tuples R ( j ) and R ( j + 1 ) ). Next, we obtain a generalized B ̈ uchi automaton A R , S , τ (see Def. 2.2) whose runs are the possible sequences of tuples of cells visited during the team evolution. Thus, the language of A R , S , τ contains all possible sequences of elements from 2 Π observed during the team movement. Each robot moves without synchronizing with the others, except for the moments from set S with type τ . Definition 4.1: The automaton A R , S , τ is defined as A R , S , τ = ( Q A , q A 0 , → A , F A , Π , ρ ) , where: • Q A = { q 1 1 , q 1 2 , . . . , q 1 l 1 } × { q 2 1 , q 2 2 , . . . , q 2 l 2 } × . . . × { q n 1 , q n 2 , . . . , q n l n } is the set of states, • q A 0 = ( q 1 1 , q 2 1 , . . . , q n 1 ) is the initial state, • → A : Q A → 2 Q A is the transition relation, • F A ⊂ 2 Q A is the set of sets of final states, • Π is the observation set, • ρ A : Q A → 2 Π is the observation map, ρ A ( q 1 , q 2 , . . . , q n ) = ∪ n i = 1 { ρ ( q i ) } . The transition relation → A is defined as follows: ∀ q , q ′ ∈ Q A , with q = ( q 1 j 1 , q 2 j 2 , . . . , q n j n ) and q ′ = ( q ′ 1 j 1 , q ′ 2 j 2 , . . . , q ′ n j n ) , ( q , q ′ ) ∈→ A if and only if the following rules are simultane- ously satisfied: (a) q = q ′ if and only if j i = k i and k i = l i , i = 1 , . . . , n ; (b) q ′ ij ∈ { q ij , q ij + 1 } if j ∈ { 1 , 2 , . . . , l i − 1 } , and q ′ ij ∈ { q i l i , q i k i } if j = l i , i = 1 , 2 , . . . , n ; (c) if ∃ s ∈ S such that j i = β i ( s ) for i ∈ I ⊆ { 1 , . . . , n } , where I is the largest possible subset of robots satisfying this requirement, then: (1) if I 6 = { 1 , . . . , n } , then q ′ ij i = q ij i , ∀ i ∈ I ; (2) if I = { 1 , . . . , n } and τ ( s ) = strong , then q ′ ij i = q i β i ( s + 1 ) , ∀ i ∈ I . Informally, requirements (a) and (b) capture a global progress/movement along individual runs of robots, by also capturing the possible situations when some robots advance “slower” (from the point of view that it takes more time for them to reach the next cell from partition). Requirement (c) restricts transitions by assuming that the agents satisfy all synchronization moments from S with type given by τ . Before detailing the construction of F A , we say that we consider as a generated word of A R , S , τ any trajectory that infinitely often visits all sets of states from F A . This definition of generated words is exactly the definition of accepting words of generalized B ̈ uchi automata. Moreover, A R , S , τ has a structure similar to a B ̈ uchi automaton, which has final sets of states that are infinitely often encountered along an accepted run. The set of sets of final states of A R , S , τ ( F A ) is created by using Algorithm 2. The construction from Algorithm 2 matches the purpose of generated runs of A R , S , τ , in the sense that any run contains infinitely many revisits to tuples from suffix of R where synchronization is imposed. More details on the construction of A R , S , τ are given in Sec. IV-C. Once A R , S , τ is constructed, we have to check if there exists a generated word of A R , S , τ that violates the LTL formula (by satisfying the negation of the formula). As mentioned at the beginning of this section, this basically implies checking for emptiness the language of a product between A R , S , τ and B ¬ φ (steps (ii)-(iv)). Similar to finding a run as mentioned in Sec. II, this emptiness checking can be done by using available software Algorithm 2 Set of final sets of automaton A R , S , τ 1: S su f f ix = S ∩ { k , . . . , l } 2: if S su f f ix = / 0 then 3: F A = { q 1 k 1 , . . . , q 1 l 1 } × { q 2 k 2 , . . . , q 2 l 2 } × . . . × { q n k n , . . . , q n l n } 4: else 5: Assume S su f f ix = { s 1 , s 2 , . . . , s | S su f f ix | } 6: F A = { F 1 , F 2 , . . . , F | S su f f ix | } 7: for j = 1 , 2 , . . . , | S su f f ix | do 8: F j = { q 1 β 1 ( s j ) , q 2 β 2 ( s j ) , . . . , q n β n ( s j ) } 9: end for 10: end if tools for normal (degeneralized) B ̈ uchi automata. In case that F A contains more than one set, A R , S , τ has the structure of a generalized B ̈ uchi automata. If this is the case, we first convert A R , S , τ into a degeneralized form (as mentioned in Sec. II), and then we construct the product with B ¬ φ . The construction of this product is similar to the one constructed between transition systems and B ̈ uchi automata [8]. The only difference is that the set of final states of product equals the cartesian product between final states of (degeneralized) A R , S , τ and the final states of B ̈ uchi. Example of constructing A R , S , τ : We include here a simple example, solely for the purpose of understanding the construc- tion of A R , S , τ . Therefore, we do not define an environment, nor we impose an LTL formula. Consider a team of 2 robots and the following run R : R = ( c 5 c 6 ) [( c 1 c 2 ) ( c 7 c 2 ) ( c 3 c 4 ) ] . . . (4) R has a prefix of length 1, and a suffix of length 3 (the suffix is represented between square brackets). First, assume an empty set of synchronization moments, S = / 0. By projecting R to individual runs and collapsing successive identical states, we obtain: R 1 = q 1 1 [ q 1 2 q 1 3 q 1 4 ] and R 2 = q 2 1 [ q 2 2 q 2 3 ] , where q 1 1 = c 5 , q 1 2 = c 1 , q 1 3 = c 7 , q 1 4 = c 3 , q 2 1 = c 6 , q 2 2 = c 2 , q 2 3 = c 4 . The obtained automaton A R , / 0 , / 0 is given in Fig. 4(a), where the initial state is ( q 1 1 , q 2 1 ) . This automaton is already in degeneralized form (it has a single set of final states), because S does not contain synchronization moments along suffix. Also, note that once the final set of A R , / 0 , / 0 is reached, it is never left. This corresponds to the fact that both robots reach and follow their suffixes (independently), and any possible observed sequence during the movement corresponds to a word generated by A R , / 0 , / 0 . Now, assume a set S = { 2 , 4 } , with τ ( 2 ) = strong and τ ( 4 ) = weak . This means there is a strong synchronization at the beginning of every iteration of suffix of R (state ( c 1 , c 2 ) ) and a weak synchronization at the end (state ( c 3 , c 4 ) ). The automaton A R , S , τ created as described in this subsection is given in Fig. 4(b). This automaton has the same set of states and observations as A R , / 0 , / 0 , but the set of transitions is reduced because of synchronization rules. A R , S , τ is in generalized form, because it has 2 sets of final states ( F 1 = ( q 1 2 , q 2 2 ) and F 2 = ( q 1 4 , q 2 3 ) ). They gray states become unreachable because the       1 2 1 1 , q q 1 2 1 2 , q q 1 2 1 3 , q q   1 2 2 1 , q q   1 2 2 2 , q q   1 2 2 3 , q q   1 2 3 1 , q q   1 2 3 2 , q q   1 2 3 3 , q q   1 2 4 1 , q q   1 2 4 2 , q q   1 2 4 3 , q q       1 2 1 1 , q q 1 2 1 2 , q q 1 2 1 3 , q q   1 2 2 1 , q q   1 2 2 2 , q q   1 2 2 3 , q q   1 2 3 1 , q q   1 2 3 2 , q q   1 2 3 3 , q q   1 2 4 1 , q q   1 2 4 2 , q q   1 2 4 3 , q q 1 F 2 F (a) (b) Fig. 4. Examples of two automata constructed as described in Sec. IV-B, from run R from Eqn. (4): (a) A R , / 0 , / 0 ; (b) A R , { 2 , 4 } , τ , with τ ( 2 ) = strong and τ ( 4 ) = weak . Final states are double encircled, with different line types corresponding to different final sets, and the gray states are not reachable. reduced transitions of A R , S , τ . Note that any word generated by A R , S , τ infinitely often visits state ( q 1 2 , q 2 2 ) (which corresponds to the first synchronization moment from S ) and state ( q 1 4 , q 2 3 ) (corresponding to the second synchronization moment from S ). Also, there is only one outgoing transition from ( q 1 2 , q 2 2 ) , in accordance with the strong synchronization in this state. It should be clear why in this case we have 2 sets of final states: if we had a single set, containing both ( q 1 2 , q 2 2 ) and ( q 1 4 , q 2 3 ) , then A R , S , τ would have been accepting words like ( q 1 1 , q 2 1 ) [ ( q 1 2 , q 2 2 ) ( q 1 3 , q 2 2 ) ( q 1 4 , q 2 2 ) ] . . . . However, such a word would correspond to a spurious (impossible) movement of robots, because state ( q 1 4 , q 2 3 ) would never be visited, although it corresponds to a synchronization moment. C. Correctness of Solution to Problem 3.2 Theorem 4.1: Any solution returned by Algorithm 1 is a feasible solution to Problem 3.2, and Algorithm 1 returns a solution in a finite number of steps. Proof: The correctness of Algorithm 1 and of the “test feasibility” procedure results by the construction we performed in this section, as detailed below. Correctness of “test feasibility” procedure: We first prove that the “test feasibility” procedure cannot yield a “feasible” output if the inputs S and τ can produce a vio- lation of the formula. This comes from the requirements of the transition relation → A and from the construction of F A . Requirement (a) from definition of → A means that A R , S , τ does not self-loops, except for the case when all individual runs have suffixes of length 1 (in this case a self-loop exists for reiterating the suffix). Requirement (b) results from the fact that every robot i follows its individual run R i and iterates the suffix; the fact that there is no synchronization (a moving robot might not change its current cell, while others advance along their individual runs) is captured by the possibility of having q j = q ′ j for some robots. Thus, requirements (a) and (b) capture a global progress/movement along individual runs of robots, by enforcing iterations of individual suffixes. If we ignore requirement (c), and we assume that F A is just a single set constructed as in line 3 of Algorithm 2, A R , S , τ can generate any possible run resulted while robots evolve without any synchronization (set S and map τ were not yet used). Thus, if “test feasibility” returns a “feasible” answer, it means that even the unsynchronized movement is feasible, so the motion restricted by ( S , τ ) would definitely imply a satisfaction of φ . However, such an approach would be very conservative, because it does not restrict the possible generated runs of A R , S , τ based on S and τ 2 . Conservativeness reduction of → A : Requirement (c) re- stricts transitions based on synchronization moments and their type. Thus, (c.(1)) guarantees that if one or more robots arrived at a synchronization moment, then they will not continue following the individual runs (by changing their states) unless all other robots arrived at that synchronization moment. This way, (c.(1)) captures the fact that the weak synchronization moments and the first part of the strong ones (visiting a certain tuple) are satisfied. Requirement (c.(2)) ensures that a tuple of cells corresponding to a strong synchronization moment is synchronously left by all robots that have to move at that index (the moving robots synchronously go to the next state from their individual run, while for other robots β i ( s + 1 ) implies remaining in the same state/cell). The reduced set of transitions of A R , S , τ captures the satisfaction of all synchro- nization moments, and includes all possible unsynchronized (independent) movements of robots between synchronization moments. Therefore, the correctness of “test feasibility” is not affected, while its conservativeness is reduced. Construction of F A : If there is no synchronization moment in the suffix of R , then F A contains only one set, equal to the cartesian product of the sets of states composing the suffixes of individual runs R i , i = 1 , . . . , n (line 3 in Algorithm 2). This is because no synchronization moment in suffix of R means no synchronization moments in suffixes of individual runs. Therefore, the robots independently follow their suffixes and any n -tuple from set F A can be infinitely often observed during the team evolution. In this case A R , S , τ is still too conservative, because it can generate many runs that cannot result from the actual movement of robots ( e.g. infinite surveillance of just two states from F A ). The set of accepted runs is drastically reduced if there are x synchronization moments in suffix of R (and also in individual suffixes). In this case, F A will contain x sets (in Algorithm 2, x = | S su f f ix | ). Each of these sets contains just one tuple, which corresponds to one synchronization moment along individual suffixes. This construction comes from the following aspects: (i) due to synchronization moments along suffixes, we have additional information about some infinitely visited states, and considering F A as in line 3 of Algorithm 2 would be too conservative. (ii) If there are more synchroniza- tion moments along suffix, having a single set of final states that contains all the corresponding tuples would be again too conservative. This is because the transitions of A R , S , τ might allow infinitely often revisits to just a single element of that set, and we might get spurious counterexamples when testing A R , S , τ against the negation of LTL formula. (iii) In case of 2 A similar conservative approach was used in [26], where only unsyn- chronized movements could be tested, and synchronization moments could not be handled. a strong synchronization moment j along the suffix, adding two states (tuples corresponding to R ( j ) and R ( j + 1 ) ) in the corresponding element of F A would not bring any additional benefit than adding just R ( j ) (as done in Algorithm 2). This is because requirement (c.(2)) implies that the only possible transition from state corresponding to R ( j ) is to the state corresponding to R ( j + 1 ) . Therefore, construction of F A as in Algorithm 2 further reduces the conservativeness of A R , S , τ by restricting its set of generated runs with respect to S and τ . A R , S , τ still generates all possible sets of tuples that the team can follow while moments from S with type τ are satisfied. There is one more step in proving the correctness of “test feasibility”, namely that there exists a pair S , τ for which “test feasibility” returns a “feasible” output. This pair is S = { 1 , . . . , l } and τ ( j ) = strong , ∀ j ∈ S . Indeed, in this case every state of A R , S , τ has only one outgoing transition, and the only run generated by A R , S , τ is R . The word generated by R satisfies formula φ (because R was constructed by assuming it is strongly synchronized at every position). Therefore, the language of the product between the degeneralized A R , S , τ and B ¬ φ is empty, and “test feasibility” returns “feasible”. Correctness of Algorithm 1: We now prove that Algorithm 1 returns a feasible pair ( S , τ ) in a finite number of steps. First, we explain Algorithm 1 and we show that the worst case ( S = { 1 , . . . , l } and τ ( j ) = strong , ∀ j ∈ S ) is returned, if no other less restrictive pair ( S , τ ) was encountered. Algorithm 1 starts with S = / 0 and τ undefined, and increases S with at most one moment at every iteration of the “while” loop from line 4. For this, it goes from the last index in suffix of R (moment l ) towards the first one, and it con- structs a temporary set of synchronization moments ( S temp ). S temp includes all the moments from S (initially none) and all indices after the current moment until l . All moments following the currently tested one are first assumed to be weakly synchronized, and if no solution is obtained, they will be assumed strong (line 10 and “for” loop starting on line 1). This is because we consider a strong synchronization more disadvantageous than a weak one, due to the waiting and communication at borders separating adjacent cells. The current moment is first tested with a weak synchronization, and if no feasible answer results, it is tested with strong synchronization (loop starting on line 11). If the current test (with S temp and τ temp ) is feasible, we add to set S only the current moment, with its current synchronization type stored in map τ (lines 13, 14). Then, on line 15 we update the lower bound for the current synchronization moment (it doesn’t make sense to go lower than the just found moment), and we start again the while loop on line 4 (from moment l towards the lower bound). For each disjoint assignment of “ synch type ” (“for” loop on line 1), the currently tested moment inside the “while” loop from line 4 is build on the feasible moments existing in S and τ until that instant (those moments are included in S temp and τ temp on lines 8, 9). Once a feasible pair S temp , τ temp is encountered, all future iterations from Algorithm 1) try to reduce the number of moments from S temp and relax their synchronization type. In the worst case the same pair will be returned: if no other feasible pair included in this one is found, after a number of iterations of the “while” loop the same pair is again encountered (but this time, the first element of the old/feasible S temp is already in S ). Now, the second element from the old S temp (the first from the new S temp ) is added to S and the “while” loop is again iterated, and so on. Thus, once a feasible pair is encountered, Algorithm 1 finishes in a finite number of steps. For proving that a feasible pair ( S temp , τ temp ) is ever en- countered, we show that, if no other feasible pair is found, the algorithm eventually tests the pair where S temp = { 1 , . . . , l } and τ temp ( j ) = strong , ∀ j ∈ S temp (this pair is deemed feasible by the “test feasibility” procedure, as shown before). When synch type = weak (first iteration of “for” loop on line 1), we iterate the “while” loop for l times and we do not get any feasible result. For synch type = strong we would get S temp = { 1 , . . . , l } and τ temp ( j ) = strong , ∀ j ∈ S temp after another l iterations of the “while” loop. Even though we get a “feasible” answer from “test feasibility”, we add just the first moment from S temp to S (so S = { 1 } ) and reiterate. This time, at the ( l − 1 ) th iteration of the “while” loop we would get the same pair ( S temp , τ temp ) (when moment = 2). Now, S is updated to S = { 1 , 2 } and the “while” loop is reiterated with lower bound = 2. Since each iteration of “while” loop includes 3 calls to the “test feasibility” procedure, the total number of such calls is: 3 ( l + l + ( l − 1 ) + ( l − 2 ) + . . . + 1 ) = 3 l ( l + 3 ) / 2. By using a similar reasoning as above, it can be easily shown that if there exists a set S ⊆ { 1 , . . . , l } and a map τ for which test f easibility φ ( R , S , τ ) =“feasible”, then the pair ( S , τ ) will be encountered by Algorithm 1 if other feasible pair is not encountered before. This shows why Algorithm 1 does not necessarily find an optimal solution (with respect to a cost defined by weighting different synchronization moments): once a feasible pair ( S temp , τ temp ) is encountered, all future iterations test only subsets of S temp , not other sets from { 1 , . . . , l } . D. Communication and Control Strategy We complete the solution to Problem 3.2 by providing a deployment strategy such that the synchronization moments from set S with type τ are correctly implemented. A weak synchronization at moment j along R is achieved by enforcing each robot i to wait inside cell c ij (and signal this to others) until it receives a similar signal from all other robots. A strong synchronization at moment j is accomplished by first enforcing a weak synchronization at moment j , and then temporary stopping the robots for which c ij 6 = c ij + 1 just before leaving cell c ij (and entering c ij + 1 ). Since we need individual strategies, we have to adapt the set S and map τ to descriptions suitable for each robot i that moves along its individual run R i , i = 1 , . . . , n . To solve this, for each robot i we construct a queue memory Q i , where each entry contains the index along R i when there should be enforced a synchronization, and the synchronization type. Alg. 3 creates these queue memories by adding | S | entries, in the ascending order of moments from S . Algorithm 3 Queue memory Q i 1: Q i = / 0 2: for all s ∈ S do 3: Assume that S is sorted and states in S are enumerated sequentially 4: moment = β i ( s ) 5: type = τ ( s ) 6: Add entry [ moment , type ] at the end of Q i 7: end for The queues Q i will be used by the robots in a FIFO manner, as in Alg. 4. Each robot follows the infinite run R i , by applying correct feedback controllers and by synchronizing with other robots when required. After fulfilling a synchronization mo- ment, the corresponding entry from Q i is removed or moved to the end, depending on the inclusion of the current moment in prefix or suffix. The current index in R i is incremented based on specific conditions, for correctly handling the situations when two or more synchronization moments from S yield the same value through map β i . Note that the robots not changing their cell when a strong synchronization moment is required still synchronize twice on that moment (for the weak and then the strong part), but they apply a convergence controller inside current cell. V. CASE STUDY REVISITED This section concludes the case study illustrated throughout the paper, by applying the procedure described in Sec. IV to the run from Eqn. (3). We obtain only two weak syn- chronization moments, at indices 8 and 12 of run R (first and fifth positions of every repetition of suffix). This makes sense, since the propositions satisfied by the team at the two synchronization moments are the two sets of regions ( { π 1 , π 4 , π 6 } and { π 2 , π 5 } ) that are required to be visited for the satisfaction of the formula. The individual runs of the robots are given in Eqn. (5), where the square brackets delimitate each suffix, and the two weak synchronization moments are marked in bold: R 1 = c 7 c 2 c 1 c 10 c 9 c 18 c 16 [ c 31 ] [ c 31 ] . . . R 2 = c 4 c 3 c 6 c 8 c 17 c 11 [ c 12 c 11 c 17 c 8 c 6 c 8 c 17 c 11 ] . . . R 3 = c 28 c 25 c 26 c 24 [ c 38 c 24 c 27 c 20 c 27 c 24 ] . . . (5) The control and communication protocol from Sec. IV-D points to the following deployment strategy for each robot: the robot moves along its individual run without any communica- tion, until it encounters a required synchronization moment. Then, it broadcasts that it is in a “ready” mode for the syn- chronization moment, and it waits inside the current cell until it receives “ready” signals for the current moment from all other robots. After this, each robot evolves again individually (without any synchronization) until the next synchronization moment. Note that for the above example, once robot 1 reaches its suffix it keeps applying a convergence controller inside c 31 Algorithm 4 Individual strategy for robot i 1: j = 1 2: while TRUE do 3: Read first entry [ moment , type ] from Q i 4: Read second entry [ next moment , next type ] from Q i 5: if moment = j then 6: while “ready” signals not received from all other robots do 7: Broadcast a “ready to synchronize” signal 8: Apply convergence controller inside current cell q ij from run R i 9: end while 10: if next moment 6 = j then 11: Apply controller driving to the next cell q ij + 1 until border between q ij and q ij + 1 is reached 12: end if 13: if type = strong then 14: while “ready” signals not received from all other robots do 15: Broadcast a “ready to synchronize” signal 16: if next moment 6 = j then 17: Stop robot 18: else 19: Apply convergence controller inside current cell q ij 20: end if 21: end while 22: end if 23: if j < k i then 24: Remove first entry from Q i 25: else 26: Move first entry from Q i to the end of Q i 27: end if 28: if next moment 6 = j then 29: j : = j + 1 30: end if 31: else 32: if q ij 6 = q ij + 1 then 33: Apply controller driving to the next cell q ij + 1 until border between q ij and q ij + 1 is reached 34: j : = j + 1 35: else 36: Apply convergence controller inside current cell q ij 37: end if 38: end if 39: end while and broadcasting a “ready” signal (so that it does not induce waiting for other robots). Some snapshots from the deployment (implemented accord- ing to Sec. IV-D) are shown in Fig. 5, where two repetitions of the suffix for each robot are included. A movie for the case study is available at http://hyness.bu.edu/ ∼ software/unicycles. mp4. For comparison, if we avoided solving Problem 3.2 and instead used the deployment strategy from [26], we would get the team trajectory illustrated by the movie http://hyness. bu.edu/ ∼ software/unicycles-full-synch.mp4. In this movie, we can see that the motions of the robots are not as “smooth” as our proposed approach, and the iterations for each suffix require more time. Our approach is more suitable for real experiments as robots have less frequent stops at region borders. Computation time: The most computationally intensive part of the solution to Problem 3.1 is finding a run R (as in Sec. III-A and III-B). For our case study, this took about 100 minutes on a medium performance computer. In contrast, the solution we proposed for Prob. 3.2 (Sec. IV) took only 30 seconds. To generate a solution for Prob. 3.2, 26 iterations of the test feasibility procedure were performed until the set of synchronization moments was found. VI. ADDITIONAL EXAMPLE This section briefly presents another example on the same environment as in Fig. 1, but considering two robots and the LTL formula: φ = {¬ ( π 3 ∨ π 5 ) U ( π 1 ∧ π 2 ) }∧ {¬ ( π 3 ∨ π 4 ∨ π 5 ) U ( π 4 ∧ π 5 ) } ∧ {♦  ( π 3 ∨ π 6 ) } (6) The curly brackets are only inserted to logically delimitate the requirements: (i) black and cyan regions ( π 3 and π 5 ) should be avoided until red and green regions are visited, and (ii) black region is avoided until blue and cyan regions are entered at the same time , and (iii) eventually either the black or the magenta region should be visited and never left after that. By considering the robots initially deployed in regions c 1 and c 26 respectively, we obtained a run for the team with 12 tuples in prefix and one in suffix. Informally, first robot goes to red region and the second one to the green one, then the robots move toward blue and cyan regions, and after these regions are simultaneously entered, the second robot goes to the black region and converge there, while the first robot remains in the blue region. By searching synchronization moments, we obtain only two such moments: a weak one, at the tuple when robots visit the red and green regions, and a strong one at the tuple before visiting the blue and cyan regions. The second synchronization moment guarantees that the blue and cyan regions are entered at the same time. These synchronization moments automatically found by our approach are natural at an insightful study of the requirement. The movement of the robots is depicted in the movie available at http://hyness.bu. edu/ ∼ software/unicycles-example2.mp4. In this movie one can observe both synchronization moments: (1) red robot arrives in the red region and it starts to converge there until the green robot visits the green region; (2) green robot arrives in cell c 40 and starts to converge there until red robot visit cell c 37 (this is the weak synchronization part of the strong moment), and then the robots move towards blue and cyan regions. Red robot stops at the border between c 37 and c 29 and waits until the green robot reaches the border between c 40 and c 21 - this ensures the strong part of the synchronization (simultaneously change occupied cells). After this, no other communication between robots is required. VII. CONCLUSIONS We presented a fully automated framework for deploying a team of unicycles from a task specified as a linear temporal logic formula over some regions of interest. The approach con- sists of abstracting the motion capabilities of each robot into a finite state representation, using model checking tools to find a satisfying run, and mapping the solution to a communication and control strategy for each unicycle. The main contribution of the paper is the development of an algorithmic procedure that returns a reduced set of moments when the robots should communicate and synchronize, with the guarantee that the specification is satisfied. A secondary contribution is the inte- gration of this algorithm as part of a fully automatic procedure for deployment of teams of unicycles from specifications given as LTL formulas over regions of interest in an environment. Future research direction includes extending this framework to probabilistic systems such as Markov Decision Processes (MDPs) or Partially Observable Markov Decision Processes (POMDPs), for satisfaction of probabilistic temporal logics, such as probabilistic LTL or probabilistic CTL. R EFERENCES [1] S. M. LaValle, Planning Algorithms . Cambridge University Press, 2006, available at http://planning.cs.uiuc.edu. [2] S. Russell and P. Norvig, Artificial Intelligence: A Modern Approach , 2nd ed. Prentice Hall, 2003. [3] E. Rimon and D. E. Koditschek, “Exact robot navigation using artificial potential functions,” IEEE Transactions on Robotics and Automation , vol. 8, no. 5, pp. 501–518, 1992. [4] S. M. LaValle and J. J. Kuffner, “Randomized kinodynamic planning,” International Journal of Robotics Research , vol. 20, no. 5, pp. 378–400, 2001. [5] R. Tedrake, I. R. Manchester, M. M. Tobenkin, and J. W. Roberts, “LQR- trees: Feedback motion planning via sums of squares verification,” International Journal of Robotics Research , vol. 29, no. 8, pp. 1038– 1052, 2010. [6] M. Antoniotti and B. Mishra, “Discrete event models + temporal logic = supervisory controller: Automatic synthesis of locomotion controllers,” in IEEE Int. Conf. on Robotics and Automation , Nagoya, Japan, 1995, pp. 1441–1446. [7] S. Karaman and E. Frazzoli, “Sampling-based motion planning with deterministic μ -calculus specifications,” in IEEE Conf. on Decision and Control , Shanghai, China, 2009, pp. 2222 – 2229. [8] M. Kloetzer and C. Belta, “A fully automated framework for control of linear systems from temporal logic specifications,” IEEE Transactions on Automatic Control , vol. 53, no. 1, pp. 287–297, 2008. [9] H. Kress-Gazit, G. Fainekos, and G. J. Pappas, “Where’s Waldo? Sensor- based temporal logic motion planning,” in IEEE Int. Conf. on Robotics and Automation , Rome, Italy, 2007, pp. 3116–3121. [10] S. G. Loizou and K. J. Kyriakopoulos, “Automatic synthesis of mul- tiagent motion tasks based on LTL specifications,” in IEEE Conf. on Decision and Control , Paradise Island, Bahamas, 2004, pp. 153–158. (a) (b) (c) (d) (e) (f) (g) (h) Fig. 5. Several configurations reached during movement ((a) . . . (g)), and traces of robots (h). (a) Robot 1 (green) heads to c 31 , robot 2 (blue) heads to c 12 , robot 3 (red) heads to c 38 ; (b) Robot 3 begins to wait for the first weak synchronization moment from suffix; (c) Robots 2 and 3 are waiting (by converging inside their regions); (d) First synchronization moment is accomplished, all robots continue normal movement; (e) Robot 3 begins waiting for the second synchronization moment; (f) Synchronization accomplished, robots 2 and 3 head back to c 12 and c 38 respectively; (g) Robot 3 begins waiting for the first synchronization moment from suffix, and when robot 2 reaches c 12 a new iteration of suffix begins. [11] M. M. Quottrup, T. Bak, and R. Izadi-Zamanabadi, “Multi-robot motion planning: A timed automata approach,” in IEEE Int. Conf. on Robotics and Automation , New Orleans, LA, 2004, pp. 4417–4422. [12] T. Wongpiromsarn, U. Topcu, and R. M. Murray, “Receding horizon temporal logic planning for dynamical systems,” in IEEE Conf. on Decision and Control , Shanghai, China, 2009, pp. 5997–6004. [13] C. Baier, J.-P. Katoen, and K. G. Larsen, Principles of Model Checking . MIT Press, 2008. [14] E. M. Clarke, D. Peled, and O. Grumberg, Model checking . MIT Press, 1999. [15] J. Hopcroft, R. Motwani, and J. D. Ullman, Introduction to Automata Theory, Languages, and Computation . Addison Wesley, 2007. [16] R. Alur, T. A. Henzinger, G. Lafferriere, and G. J. Pappas, “Discrete abstractions of hybrid systems,” Proceedings of the IEEE , vol. 88, pp. 971–984, 2000. [17] C. Belta and L. Habets, “Controlling a class of nonlinear systems on rectangles,” IEEE Transactions on Automatic Control , vol. 51, no. 11, pp. 1749–1759, 2006. [18] R. Burridge, A. Rizzi, and D. Koditschek, “Sequential composition of dynamically dexterous robot behaviors,” The International Journal of Robotics Research , vol. 18, no. 6, p. 534, 1999. [19] D. Conner, H. Choset, and A. Rizzi, “Integrated planning and control for convex-bodied nonholonomic systems using local feedback control policies,” Proceedings of robotics: Science and systems II , 2006. [20] J. Desai, J. Ostrowski, and V. Kumar, “Controlling formations of multiple mobile robots,” in Proc. IEEE Int. Conf. Robot. Automat. , Leuven, Belgium, 1998. [21] L. Habets, P. Collins, and J. van Schuppen, “Reachability and control synthesis for piecewise-affine hybrid systems on simplices,” IEEE Trans- actions on Automatic Control , vol. 51, pp. 938–948, 2006. [22] R. Milner, Communication and concurrency . Prentice-Hall, 1989. [23] M. Y. Vardi and P. Wolper, “An automata-theoretic approach to automatic program verification,” in Logic in Computer Science , 1986, pp. 322–331. [24] G. Holzmann, “The model checker SPIN,” IEEE Transactions on Software Engineering , vol. 25, no. 5, pp. 279–295, 1997. [25] J. Barnat, L. Brim, and P. Roˇ ckai, “DiVinE 2.0: High-performance model checking,” in High Performance Computational Systems Biology . IEEE Computer Society Press, 2009, pp. 31–32. [26] M. Kloetzer and C. Belta, “Automatic deployment of distributed teams of robots from temporal logic motion specifications,” IEEE Transactions on Robotics , vol. 26, no. 1, pp. 48–61, 2010. [27] ——, “LTL planning for groups of robots,” in IEEE International Conference on Networking, Sensing, and Control , Ft. Lauderdale, FL, 2006. [28] M. Mukund, “From global specifications to distributed implementa- tions,” in Synthesis and control of discrete event systems . Kluwer, 2002, pp. 19–34. [29] Y. Chen, X. Ding, A. Stefanescu, and C. Belta, “A formal approach to deployment of robotic teams in an urban-like environment,” in 10th International Symposium on Distributed Autonomous Robotics Systems (DARS 2010) , 2010 (to appear). [30] J. Shewchuk, “Triangle,” http://www.cs.cmu.edu/ ~quake/triangle.html. [31] K. Fukuda, “cdd/cdd+ package,” http://www.ifor.math.ethz.ch/ ~fukuda/cdd _ home/. [32] P. Gastin and D. Oddoux, “Fast LTL to B ̈ uchi automata translation,” in Conf. on Computer Aided Verification , ser. Lecture Notes in Computer Science, no. 2102. Springer, 2001, pp. 53–65. [33] P. Wolper, M. Vardi, and A. Sistla, “Reasoning about infinite computa- tion paths,” in Proceedings of the 24th IEEE Symposium on Foundations of Computer Science , E. N. et al., Ed., Tucson, AZ, 1983.