The transducer synthesis problem on finite words asks, given a specification S ⊆ I × O, where I and O are sets of finite words, whether there exists an implementation f : I → O which (1) fulfils the specification, i.e., (i, f (i)) ∈ S for all i ∈ I, and (2) can be defined by some inputdeterministic (aka sequential) transducer T f . If such an implementation f exists, the procedure should also output T f . The realisability problem is the corresponding decision problem. For specifications given by synchronous transducers (which read and write alternately one symbol), this is the finite variant of the classical synthesis problem on ω-words, solved by Büchi and Landweber in 1969, and the realisability problem is known to be ExpTime-c in both finite and ω-word settings. For specifications given by asynchronous transducers (which can write a batch of symbols, or none, in a single step), the realisability problem is known to be undecidable. We consider here the class of multi-sequential specifications, defined as finite unions of sequential transducers over possibly incomparable domains. We provide optimal decision procedures for the realisability problem in both the synchronous and asynchronous setting, showing that it is PSpace-c. Moreover, whenever the specification is realisable, we expose the construction of a sequential transducer that realises it and has a size that is doubly exponential, which we prove to be optimal. Acknowledgements We warmly thank the anonymous reviewers for their helpful comments and Christof Löding for pointing us to some related references.
Introduction
Asynchronous transducer synthesis In the asynchronous setting, specifications may not strictly alternate between input and output symbols, hence they can no longer be seen as languages over Σ i × Σ o . Similarly, the target implementations may not be synchronous: the system can delay its production of outputs, or produce several symbols at once. Transducers, in contrast to synchronous transducers, are by definition asynchronous: their transitions are labelled by pairs (i, w) where i ∈ Σ i is a symbol and w ∈ Σ * o a word, possibly empty. Since they are generally non-deterministic, to a single input word may correspond several output words, and thus transducers define subsets of Σ * i × Σ * o . Therefore, they are well-suited to represent (asynchronous) specifications, and in their sequential version, asynchronous implementations. Any asynchronous specification is realisable by some unambiguous (functional) asynchronous transducer [24, 11, 3] . However, evaluating unambiguous transducers on arbitrarily long or even infinite input words may require arbitrarily large memory. Therefore, just as in Church's setting, a sequentiality requirement can be put on implementations for efficient memory usage. However, the realisability of asynchronous specifications by (asynchronous) sequential transducers, which is called the sequential uniformisation problem in transducer-theoretic terms, is undecidable for finite words [4, 12] . If the specification is finite-valued (i.e. any input word has a constant number of output words), the problem is in 3ExpTime [12] . The proof of [12] is based on Ramsey's theorem and word combinatorics arguments, and it is not clear how to reduce the complexity. This raises the question of whether there are natural and non-trivial subclasses of asynchronous specifications with better complexity.
Multi-sequential specifications
In this paper, we consider a class of specifications S on finite words, i.e. S ⊆ Σ * i × Σ * o , which strictly restricts the class of finite-valued specifications to so-called multi-sequential specifications. Such class is obtained by closure under finite unions of graphs of sequential functions. Precisely, S = n i=1 S i where S i is the graph of a (partial) function f i : Σ * i → Σ * o defined by a sequential transducer. Likewise, a transducer is multi-sequential if it is a union of state-disjoint sequential transducers. For instance, consider the specification S consisting of the pairs (w, w ) such that w is a subword of w of fixed length k. This specification is multi-sequential: S = w ∈Σ k i S w where S w = {(w, w ) | w subword of w}. Clearly, S w can be represented by a sequential transducer, because w is fixed: once the first symbol of w is met in w, output it, and proceed to the second symbol of w , etc., until the last symbol of w is produced, reject otherwise. The notion of multi-sequentiality has been introduced for functions in [6] and studied for relations in [19] . An important property of the class of multi-sequential specifications is its decidability in PTime: Given a transducer, it is decidable in PTime whether it defines a multi-sequential specification [19] . This fact and their natural definition as closure of sequential functions under union make multi-sequential specifications a good candidate for a class of specifications with better complexity than the known results of the literature.
Contributions
We investigate the complexity of sequential transducer synthesis from specifications defined by multi-sequential transducers on finite words. We show that both in the synchronous and asynchronous settings, the realisability problem is PSpace-complete. To the best of our knowledge, it is the first non-trivial class of specifications which admits a realisability test below ExpTime. If the specification is realisable, we show how to extract an implementation as a winning strategy in a two-player game called the synthesis game. It is parameterised by a value k ∈ N which bounds the maximal number of output symbols which can be queued before being outputted, allowing for an incremental synthesis algorithm. To keep track of such output symbols, we use the notion of delay [2] .
Difficulties and examples Let us briefly explain what are the main difficulties to overcome. Consider S = i S i a multi-sequential specification. If all of the S i have disjoint domains, then S is a function, which is realisable by a sequential transducer iff it is sequential. The latter can be tested in PTime [2] . The problem becomes more interesting and challenging when the S i have domains which are not necessarily disjoint. Consider for example the 2-sequential transducer D 1 ∪ D 2 of Fig. 1 . The transducer D 1 accepts the words containing at least two a's, and replaces b's with a's, and D 2 accepts the words containing at least one b, and replaces a's with b's. This specification can be realised by a sequential transducer which waits two steps before outputting something, since it then knows whether the input contains at least one b or two a's. It then behaves as D 1 in the first case, and as D 2 in the second.
This example shows that a sequential realiser may have to wait before reacting, keeping in memory what remains to be output in the future. Take on the contrary the 2-sequential transducer D 1 ∪ D 2 of Fig. 1 , which is the same as D 1 ∪ D 2 except that it can additionally read and copy c's at any moment. In that case, a sequential realiser would have to store arbitrary long sequences of c's before outputting them, for instance when processing words in ac * {a, b, c} * . In particular, this specification is not sequentially realisable. Structure of the paper After a formal definition of transducer synthesis (Section 2), we solve the synchronous case and provide a characterisation of realisable synchronous multisequential specifications, decidable in PSpace (Section 3). Then, we present the notion of synthesis game (Section 4), which is a useful tool for the proofs and also to get a synthesis procedure. For the asynchronous setting, we define a recursive characterisation of realisable multi-sequential specifications and show that it can be decided in PSpace (Section 5).
M F C S
Related work Games with delays have been used in [4, 15] . Perhaps the closest formulation to ours is that of [4] . However, it is tailored to automatic relation. Our game structure is more general, as it is defined for uniformising any transducer (defining a rational relation).
In particular, our game structure is exponentially larger that the one of [4] . We would also like to mention an interesting related line of works on ω-words, where the specification is synchronous, but the implementation may be asynchronous [15, 17, 22, 23, 30, 31, 32] . Unlike the setting where the specification and implementations are both asynchronous, the realisability problem is decidable here, for ω-regular specifications (i.e., regular ω-languages over Σ i × Σ o ), and ExpTime-c if the specification is given by a parity automaton [22] . In this setting, the authors often consider a notion of delay games. In these games, the delay is a quantitative notion, corresponding to the waiting time before outputting a symbol, while for us, a delay is a word that still remains to be output (this is a standard terminology in transducer theory). It is known in particular that constant "waiting time" (depending on the specification) is always sufficient to win, for ω-regular specifications. This is different to our setting: for instance, the function f mapping any word of the form a n σ, for n > 0 and σ ∈ {a, b}, to σ is realisable by a sequential transducer, but the production of a and b might have to be delayed for an unbounded amount of time.
2
Transducer synthesis problem Words For an alphabet Σ, we denote by Σ * the set of finite words over it, and by the empty word. The length |w| of a word w is its number of symbols. For k ∈ N, we denote by Σ k (resp. Σ ≤k ) the set of words of length k (resp. at most k). For u, v ∈ Σ * , we write u v if u is a prefix of v, and denote by u −1 v the word such that u(u
Automata In this paper, finite (non-deterministic) automata over an alphabet Σ are denoted as tuples A = (Σ, Q, I, F, ∆) where Σ is the alphabet, Q the set of states, among which I (resp. F ) denotes the initial (resp. final or accepting) states, and ∆ ⊆ Q × Σ × Q is the transition relation. A is deterministic if there is only one initial state and for all (q, σ) ∈ Q×Σ, there exists at most one q ∈ Q such that (q, σ, q ) ∈ ∆. A run of A on a word w = σ 1 . . . σ n consists in either a single state q ∈ Q if n = 0, or a sequence r ∈ ∆ * of n transitions t 1 . . . t n such that the target state of t i equals the source state of t i+1 for all 1 ≤ i < n. It is said to be initial if the source state of t 1 is initial, and accepting if the target state of t n is accepting. If p is the source state of t 1 and q the target state of t n , we may write p w − − → A q to mean that there exists a run from p to q on w. The language accepted by an automaton A, denoted L(A), is the set of words admitting an accepting run. A state q ∈ Q is reachable (resp. co-reachable) if there is a run from an initial state (resp. to a final state) for some u ∈ Σ * . A state is said to be useful if it is both reachable and co-reachable, and A is said to be trim if all its states are useful. It is well-known that any automaton can be transformed into an equivalent trim automaton in PTime. Given two automata
Transducers A transducer 4 over two alphabets Σ, Γ is a tuple T = (A, ρ, τ ) such that A = (Σ, Q, I, F, ∆) is an automaton over Σ, called the input automaton, ρ : ∆ → Γ * is a mapping, called the output function, associating with every transition an output word, and τ : F → Γ * is a terminal function associating with every accepting state an output word. Given a run r of A on a word w, its output out(r) ∈ Γ * is defined by if w = , and by ρ(t 1 ) . . . ρ(t n ) if r = t 1 . . . t n for some n ≥ 1. We write p u|v − −− → T q whenever there exists a run r of A on u from p to q, such that v = out(r), and say that r produces v. The relation defined by T is the set T of pairs (u,
We define dom(T ) by dom(T ) = dom( T ) = L(A).
A transducer is trim if its input automaton is trim. It is called sequential if its input automaton is deterministic, and functional if T is a function, i.e. for all u ∈ dom(T ), there exists at most one pair (u, v) ∈ T . In that case we let T (u) = v. Note that any sequential transducer is functional. A transducer T = (A, ρ, τ ) is called synchronous (or sometimes letter-to-letter in the literature) if, whenever it reads an input symbol, it produces exactly one output symbol, i.e. for all transition t, |ρ(t)| = 1, and τ (q) = for all accepting state q. For example, consider the transducer D 1 on Fig. 1 (the terminal function is assumed to output and is not depicted). It is sequential and synchronous. Its domain is L = b * ab * a(a + b) * . Two transducers are said to be equivalent if they define the same relation. Finally, the disjoint union of transducers is naturally defined as the disjoint union of their input automata and the disjoint union of their output functions (seen as graphs). For all transducers T 1 , T 2 , we have
Transducer Synthesis Problem Let Σ i , Σ o be two alphabets of input and output symbols respectively. They may not necessarily be disjoint. A specification is a subset of Σ * i × Σ * o , and an implementation is a function, possibly partial, from Σ * i to Σ * o . The transducer realisability problem asks, given a specification S defined by a transducer T , i.e. S = T , whether there exists a sequential transducer I such that (1) dom(I) = dom(T ) and (2) for all u ∈ dom(T ), (u, I(u)) ∈ T . In that case, we say that I realises S (or T ), and that S is realisable by a sequential transducer, or sequentially realisable. We also say that I is a realiser of S. The synthesis problem asks to output I. The realisability problem is undecidable in
46:6 Transducer Synthesis from Multi-Sequential Specifications
general [4, 12] , but decidable, in 3ExpTime, if T is finite-valued, i.e. there exists k ∈ N such that for all u ∈ dom(T ), |{v | (u, v) ∈ T }| ≤ k [12] .
Multi-sequential specifications A transducer T is called k-sequential if it is the disjoint union of k sequential transducers. It is called multi-sequential if it is k-sequential for some k. Observe that when the k sequential transducers have pairwise disjoint domains, then T is functional, but it may not be the case in general. Deciding whether given a transducer T , there exists an equivalent multi-sequential transducer T , can be done in PTime; however, T may be exponentially larger than T [19] . Minimising the number of sequential transducers of the disjoint union is also doable: deciding whether T is equivalent to some k-sequential transducer for k given in unary is decidable in PSpace [8] . In this paper, we consider multi-sequential specification, i.e. relations S ⊆ Σ * i × Σ * o defined by multi-sequential transducers.
PSpace-hardness In both the synchronous and asynchronous case, the realisability problem of multi-sequential specifications by (a)synchronous sequential transducers is PSpace-hard.
We build a reduction from the emptiness problem of the intersection of n DFA A 1 , . . . , A n on some alphabet Σ, proven PSpace-c in [25] . We define a specification S over Σ ∪ {#, a, b}
, then on the domain w# * {a, b}, the specification is a function which is not definable by any sequential transducer, thus not sequentially realisable, since it would imply counting the #s (in the synchronous setting, it suffices to take m = 1 since a synchronous transducer would be forced to guess the future). Conversely, if n i=1 L(A i ) = ∅, then the identity function (trivially definable by a synchronous sequential transducer) realises the specification.
It is readily seen that each S i (resp. N i ) is definable by a 2-(resp. 1-)sequential transducer, hence S is multi-sequential, concluding the proof.
3
The synchronous setting
In this section, we consider first the synchronous setting, where the specification is given as a disjoint union of synchronous sequential transducers, and the target implementations are synchronous sequential transducers. Not only is this setting interesting in itself, but it helps to understand the asynchronous setting. First, we characterise the realisable specifications through a property called the residual property, then we show it is decidable in PSpace.
Residual property Let
Intuitively, the residual property says that if on some input prefix u, two sequential transducers of the union disagree on their outputs, i.e. produce different outputs, then a synchronous realiser of T must "drop" one of the two transducers. However, it must do so while preserving the residual domain u −1 dom(T ), i.e., the realiser must still accept any word of u −1 dom(T ). For example, consider again Fig. 1 and the specification defined by D 1 D 2 . On input a, the two transducers disagree, hence, since we want a synchronous realiser, a choice has to be made and therefore one of the two transducers must be dropped. However, by doing so, the residual domain will not be fully covered by the remaining transducer. For example, if a realiser chooses to output a when reading a, the residual language b * is not covered anymore. As a matter of fact, D 1 D 2 is not realisable by any sequential and synchronous transducer.
Formally, let u ∈ Σ * i and let r i , r j be runs of some D i , D j respectively, on u. We say that r i and r j agree on their output if out(r i ) = out(r j ). Now, u is called smooth if every D i admits an initial run on input u, and all these runs agree on the corresponding output. The word u is called critical if it is not smooth.
We say that T satisfies the residual property if for every critical prefix u ∈ Σ * i of a word of dom(T ), there exists a subset P {1, . . . , n} satisfying: 1. All the transducers D i , i ∈ P , produce the same output φ(u) on u;
−1 D i is realisable by a synchronous and sequential transducer.
Theorem 1. A specification S defined by a synchronous multi-sequential transducer T is realisable by a synchronous sequential transducer iff T satisfies the residual property.
Sketch. If T is realised by a synchronous sequential transducer U, for every critical prefix u, let P be the set of i such that D i and U map the same output to u. Property 1 is satisfied by definition, and the other two follow from the fact that U is sequential and realises T .
Conversely, if the residual property is satisfied, we can construct a synchronous and sequential realiser. The idea is to make a synchronised product of all the transducers D i , and, whenever on some input symbol σ at least two of them disagree on the output, we know by the residual property that there exists a subset P of them having the good properties 1, 2, 3. Then, the realiser just goes on simulating all the transducers D i corresponding to P in parallel.
It also shows that if the property is satisfied, then we can synthesise a realiser, which might however be exponentially larger than T .
Theorem 2. The realisability problem of synchronous multi-sequential specifications by synchronous sequential transducers is PSpace-complete.
Sketch. The PSpace-hardness is obtained by reducing the problem from the emptiness problem of the intersection of n DFAs (cf Section 2 p. 6).
To show membership to PSpace, given a transducer T = n i=1 D i , we show that the residual property can be tested by a non-deterministic algorithm running in polynomial space. First, we bound the size of witnesses of the negation of the property: roughly, if there is such witness, namely a critical prefix u, then there exists a critical prefix v of exponential length (in T ) such that for any subset P {1, . . . , n}, one of the conditions 1, 2, 3 is falsified. Then, the algorithm guesses the prefix v on the fly, simulating all transducers D i in parallel and keeping their states in memory (it also needs a counter for the length of v). As soon as the transducers disagree on an output symbol, for each subset P {1, . . . , n} (they can obviously be enumerated using only polynomial space), the algorithm checks whether property 1, 2 or 3 is falsified. Checking property 1 is easy: it suffices to look at the symbols produced when reading the last input symbol. Checking property 2 can be done using the current set of states reached by the transducers on input v, and by using any PSpace algorithm for automata inclusion. Finally, to check property 3, it suffices to recursively apply the PSpace algorithm described so far on a smaller set of transducers. The stack of recursive calls is linear in n, hence the memory used by the whole procedure remains polynomial.
4
The synthesis game
We now define a 2-player safety game from a transducer T such that if Eve wins the game then T is realisable by a sequential transducer. This game notion will prove useful to show the correctness of the characterisation of Theorem 5, and may also be used as a practical way to synthesise implementations, as winning strategies of this game. In the asynchronous setting,
46:8 Transducer Synthesis from Multi-Sequential Specifications
two different runs of a transducer on the same input word may not only produce different outputs, but also the same output at different rates (i.e. one run is ahead, output-wise, of the other for some time). This leads us to the notion of delays, a classical tool to compare outputs in transducer theory. Let us define this notion formally.
Delays Given two words u 1 , u 2 ∈ Σ * , their longest common prefix is denoted by u 1 ∧ u 2 . The delay between u 1 and u 2 is an element of Σ * × Σ * defined by del(u 1 , u 2 ) = (
o , where w is intended to be some delay associated with state q, given a transition t = (q, σ, q ) ∈ ∆ and some output word u prefix of wρ(t), we denote by next((q, w), t, u) the "next" pair (state,delay), assuming that u is output, i. 
The synthesis game In the synchronous setting, synthesis problems are classically solved by reduction to two-player games in which the players alternately choose one input symbol (the adversary, whom we call Adam) and one output symbol (the protagonist, called Eve).
Their interaction induces a pair of input and output words by concatenating their respective symbols, and the protagonist wins if such pair satisfies the specification, or if the input word is out of the domain. Then, a finite-memory winning strategy in the game corresponds to an implementation of the specification. In the asynchronous setting, the protagonist may choose arbitrary output words at each round instead of a single symbol, and one needs to introduce output delays in the game in order to define the winning condition in a regular manner. The game we now present follows this idea. Given a transducer T = (A, ρ, τ ) with A = (Σ i , Q, I, F, ∆), ρ : ∆ → Σ * o and τ : F → Σ * o , we build a two-player safety game Eve's vertices are Adam's vertices extended with the last input symbol picked by Adam. Suppose now that the game has been played for some rounds and is currently in some vertex (C, D) of Adam. Along these rounds, Adam has chosen a sequence u of input symbols, and Eve has chosen a set of runs over u from the initial states. C is the set of states in which these runs end. Each run induces some delays compared to the longest common prefix of all the outputs they can produce. D maps each state to the delays of the runs ending in it. Eve's actions consist in selecting some of these runs to prevent some delays to grow too high, i.e., she can drop from any set D(q) some of its elements. By restricting the set of possible runs, Eve can be in a situation where some state q of C is accepting while none of the states of live(D) is, in which case she loses, as none of the runs she has selected accepts the input word chosen by Adam. Such vertices constitute the set of unsafe vertices she needs to avoid.
More precisely, the set of Adam's transitions T ∀ and Eve's transitions T ∃ are defined as follows. From any game position (C, D), Adam can pick a symbol σ ∈ Σ i and the game evolves to the position (C, D, σ) . From (C, D, σ), Eve's actions is a subset α ⊆ next(D, σ) (she can "drop" some pairs of next (D, σ) ), and the game evolves to (C , D α ) where C is the set of states reached from C by reading σ, and D α maps any q ∈ Q to the set {w | (q, w) ∈ α}.
Given K ∈ N, we define the K-synthesis game as the restriction of G T to delays of length at most K: 
Synthesis algorithm
It is worth noting that the synthesis game allows for a synthesis procedure: for ascending values of K, test whether Eve wins the K-synthesis game (this can be done in PTime in the size of the game). If it is the case, then by Proposition 3 the specification is realisable, and we can even extract an implementation corresponding to a winning strategy of Eve. If it is not the case, then increment K and try again, until K reaches some given upper bound B. The K-synthesis game is exponentially large in general (in the transducer defining the specification, and in K). Solving this game efficiently, using for instance symbolic methods, as done for LTL synthesis in the synchronous case [10, 13] , is beyond the scope of this paper, but is an interesting research direction. This algorithm is not complete in general: it is shown for instance in [12] that some specifications defined by transducers are realisable by sequential transducers while Eve has no winning strategy in G T ,K for any K. Still, the converse of Proposition 3 holds for some subclasses of specifications T . For example, in the synchronous setting, where we want to synthesise a synchronous sequential transducer, it suffices to take K = 0. This gives an ExpTime procedure to check the realisability of T by a synchronous sequential transducer. If T is finite-valued, then by taking K large enough (triply exponential in T ), we get completeness [12] . Finally, if T is functional, then Eve wins G T ,K for some K iff T is equivalent to a sequential transducer, and a polynomial K (in T ) suffices [2] .
In this paper, we obtain completeness for multi-sequential specifications by taking K exponential in T (Proposition 6). While this allows us to decide realisability using the game approach, the time complexity will not be optimal (2ExpTime). We indeed devise, in Section 5, a PSpace realisability-checking procedure based on an effective characterisation of realisable multi-sequential specifications. If the PSpace procedure concludes that the specification is realisable, one can run the former game-solving procedure to synthesise a realiser, for ascending values of K. This way, one may hope to synthesise a "small" realiser.
5
The asynchronous setting
We first characterise recursively the multi-sequential specifications which are sequentially realisable (Theorem 5). Then, we provide an equivalent characterisation, non-recursive and easier to check algorithmically, but more technical.
Similarly to the synchronous case, we define a notion of critical situation to which a realiser must react. In the synchronous case, it was just a prefix on which at least two sequential transducers were producing different outputs. In the asynchronous case, two sequential transducers may produce different outputs on the same prefix, but this may not be problematic in the case where one is ahead of the other, i.e., the output of one run is a prefix of the output of the other. A critical situation is rather a prefix where the delays between all the outputs of the sequential transducers are too large. Since no bound is known a priori to define "too large", we formalise a critical situation as a prefix of the form uv, such that at least two sequential transducers loop on v, and have a different delay before and after the loop. By iterating this loop, i.e. by taking a prefix uv n , the delay between these two transducers will grow unboundedly when n increases. For such loops, the situation will get critical if a realiser does not react.
Definition 4 (critical loop). Let
..,n} such that 1. for all i ∈ X , there exists an initial run
Our characterisation echoes the one of the synchronous setting. It says that whenever there is a critical situation (a critical loop), a realiser must be able to drop some of the sequential transducers, in order to prevent the delays to grow unboundedly, while preserving the residual domain. Formally:
3. i∈Y (u, ) −1 D i is realisable by a sequential transducer, where = i∈X α i .
Sketch. ⇒ Let U be a sequential transducer realising T . For every critical loop (u, v, X ) of T , the corresponding set Y is obtained by getting rid of all the transducers that stray arbitrarily far from U on the input words of the form uv * . Then, the first property is immediate, and the other two follow from the fact that U is sequential and realises T .
⇐ Conversely, assuming that whenever a critical loop is met there exists a set Y satisfying the three conditions, we prove by induction on the degree n of sequentiality of T that Eve has a winning strategy in the K T -synthesis game for T , for some well-chosen value K T depending on T . By Proposition 3, this entails the existence of a sequential realiser.
Note that in the synthesis game, since T is a union of sequential transducers, for each accessible vertex (C, D) of Adam, and for every i ∈ {1, . . . , n}, there is at most one state q i of D i occurring in live(D), and if there exists such a state, |D(q i )| = 1. As a consequence, Eve's actions in the synthesis game, which consist in dropping a subset of pairs (state,delay), actually correspond here to "dropping" a subset of sequential transducers.
If n = 1, then T is sequential, and the strategy of Eve that consists in never dropping T is winning. Now, suppose that n > 1. In order to demonstrate that Eve has a winning strategy, we show that for every input word chosen by Adam, either Eve can keep track of all the transducers in the K T -synthesis game, which ensures her a win, or she can drop some transducers on the way, while reaching a state from which she has a winning strategy. The proof of Theorem 5 shows that if a multi-sequential specification is realisable, Eve wins the K-synthesis game for K computable from the specification, as stated in Proposition 6. As explained in Section 4, solving the k-synthesis game for ascending values of k then provides a practical way to synthesise a realiser, but the complexity is not optimal.
Proposition 6 (bounded delay). Let S be a specification defined by an n-sequential transducer T . Then S is realisable by some sequential transducer iff Eve wins the K-synthesis game for
where L is the longest output occurring on a transition of T , and M is the maximal number of states of a sequential transducer of T .
Theorem 7. A realisable specification S defined by a multi-sequential transducer T with m states admits a realiser of size doubly exponential in m.
Moreover, there exists a family (S n ) n∈N of realisable specifications such that for every n ∈ N, S n is definable by a multisequential transducer of size polynomial in n, and every sequential transducer realising S n has a size that is doubly exponential in n.
Proof. Let S ⊂ Σ * × Γ * be a realisable specification defined by an n-sequential transducer T with a set of states Q of size m. Note that n ≤ m, hence, by Proposition 6, Eve wins the K-synthesis game for some K exponential in m. Then, the construction presented in the proof of Proposition 3 exposes a realiser whose set of states Q consists of Adam's vertices that are reachable in the K-synthesis game. For every such vertex (C,
since T is n-sequential, there is at most n sates q ∈ Q satisfying D(q) = ∅. Moreover, for every such state we have D(q) = {w} for some w ∈ Γ * satisfying |w| ≤ K. Therefore, the size of Q is bounded by 2 m (m(|Γ| K+1 )) n , which is doubly exponential in m. In order to expose the family (S n ) n∈N , we use the notion of j-pairs, presented in [22] . For every n ∈ N, let us consider the alphabet I n = {1, . . . , n}. A bad j-pair of a word u = i 1 . . . i m ∈ I * n is a pair of positions 1 ≤ k < k ≤ m such that i k = i k = j, and for all k < < k , i ≤ j. Then every u ∈ I * n satisfying |u| ≥ 2 n admits a bad j-pair for some 1 ≤ j ≤ n, and there exists a word, denoted by ψ n , that has size 2 n − 1, and contains no j-pair (see [22] ). We now consider the finite alphabet Σ = {a, b}. For every n ∈ N, let Σ n denote the alphabet I n × Σ. We denote by π 1 : Σ * n → I * n and π 2 : Σ * n → Σ * the projections on the first, respectively second component. Let f : Σ * n → Σ * be the function mapping w ∈ Σ * n to the word obtained by taking the last letter of π 2 (w) and putting it at the beginning, i.e., f (w) = σv where σ ∈ Σ and v ∈ Σ * satisfy π 2 (w) = vσ. We consider the specification
n contains a bad j-pair for some 1 ≤ j ≤ n}.
Then S n is definable by an (n + 2)-sequential transducers with 3(n + 2) states, since the function f is definable by the union of 2 sequential transducers of size 3, and for every Sketch. PSpace-hardness has been shown in Section 2. To show PSpace-easyness, we reduce the problem to deciding the emptiness of the language of a counter machine, whose counters make at most 1 reversal (i.e. move from increasing to decreasing mode). This is known to be in NLogSpace [16] . Our machine is exponentially large (in the transducer defining the specification), but can be constructed on the fly, hence we get PSpace.
A bit more precisely, we first define the notion of skeleton s, which is a witness without the words u x , v x , hence there are finitely many skeletons, each one of polynomial size. Given an enumeration x 1 . . . x n in depth-first order of the nodes of s, we construct a counter machine M s which recognises sequences of the form x 1 w x1 #v x1 . . . x n w xn #v xn such that if we extend any label of a node x in s with the pair of words (w y1 . . . w y k , v x ), where y 1 . . . y k is the path from the root to x, we get a witness. Hence, there exists a witness iff there exists a skeleton s such that L(M s ) is non-empty. Our algorithm non-deterministically guesses a skeleton and runs a procedure to check in PSpace the emptiness of M s .
Let us intuitively explain how M s works. Conditions 1, 3, 4 and 6 are regular, so no counter is needed there. Counters are only necessary to check Condition 5, for instance to compute the length of the words β x,i , and to check the existence of a mismatch between a word α x,i and a word α x,j . First, a mismatch position m is guessed, by incrementing for some time two counters c i,x and c j,x in parallel. Then, they are decremented according to the length of outputs produced by simulating the transitions of D i and D j respectively. When one of them reaches 0, say c i,x , we store the mth symbol of the output of D i on u x in memory. We do the same for c j,x and later on check that the two stored symbols are different.
Conclusion
We have identified a class of specifications (whose membership is decidable in PTime), for which the sequential realisability problem is PSpace-c, both in the asynchronous and synchronous settings. This is in contrast to the general case, which is ExpTime-c for synchronous specifications, and undecidable in the asynchronous case. Our procedure allows to synthesise a sequential transducer whenever the specification is realisable, and allows for incremental testing, via the solvability of a two-player game parameterised by the longest output allowed to be queued by a realiser before being output. While the class of multi-sequential specifications is natural, as the closure of graphs of sequential functions under finite unions, we believe that it may also be interesting for practical applications. In particular, Vardi and Lustig have defined the concept of synthesis from component libraries [26] , in the synchronous setting, over infinite words. In this setting, given a set of components (synchronous sequential transducers over finite words), a specification S over infinite words, the question is whether the components can be arranged in such a way which realises the specification (by linking the final states of the components to the initial state of another component). This problem was shown to be decidable. We would like to investigate another way of reusing existing components, which is tightly related to multi-sequential specifications: given components C 1 , . . . , C n represented as sequential transducers and a specification S, decide whether there exists a sequential function f such that f and S have the same domain, f ⊆ i C i and f satisfies S. This is beyond the scope of this paper but we plan to investigate further this question in the near future.
