# Reactive Synthesis of Systems over Data Words

Léo Exibard <sup>12</sup> Emmanuel Filiot <sup>1</sup> Pierre-Alain Reynier <sup>2</sup>

<sup>1</sup>Méthodes Formelles et Vérification Université libre de Bruxelles

<sup>2</sup>Laboratoire d'Informatique et Systèmes Aix-Marseille Université







□ : *G*, "always"  $\diamond$  : *F*, "in the future"

Figure 1. Universal co-Büchi automaton checking that every request is eventually granted.

Figure 2. LTL formula expressing that for each client  $c \in \{1, \ldots, n\}$ , each of its requests is eventually granted

#### **Known Results**

 $\rightarrow$  Target implementation I is a deterministic transducer

| Specification                    | Complexity                                 |
|----------------------------------|--------------------------------------------|
| Nondeterministic Büchi Automaton | ExpTime-complete (Büchi & Landweber, 1969) |
| Linear Temporal Logic formula    | 2-ExpTime-complete (Pnueli & Rosner, 1989) |



•  $\mathcal{D}$  infinite set of *data* 

2 2 3 1 3 1 req req grt req grt grt req ...

Figure 4. A data word with labels  $\Sigma = \{req, grt\}$  and data  $\mathcal{D} = \mathbb{N}$ .

 $\rightarrow$  Large literature on data words:

Kaminski and Francez, 1994

Segoufin, 2006

Bojańczyk, David, Muscholl, Schwentick, and Segoufin, 2011

Schwentick and Zeume, 2012

• Formula  $\varphi$  to compare incoming data d with register content  $\uparrow r$ 



Figure 5. Universal co-Büchi register automaton checking that every request is eventually granted (the  $\varphi = T$  tests are omitted).

#### **Test-Free**

- Input transitions do not conduct test on data:  $\varphi$  is always T
- Output transitions output the content of some register:  $\varphi$  is always an equality test  $d = \uparrow r$ .

 $\rightarrow$  The register automaton of Figure 5 is not test-free.

## Results

**Bounded Synthesis** 

 $\rightarrow$  The number of registers of the implementation is **fixed**.

| Specification (Register Automaton) | Status                                           |
|------------------------------------|--------------------------------------------------|
| Nondeterministic Büchi             | Undecidable                                      |
| Universal co-Büchi                 | Decidable (Khalimov, Maderbacher, & Bloem, 2018) |
|                                    | we provide simpler proof techniques              |

- $i \in \Sigma_{in}$ ,  $o \in \Sigma_{out}$  input and output letters
- $\varphi$  a test over input data
- $r_{in} \in R$  register where the input data is stored

•  $r_{out} \in R$  register whose content is output



Figure 6. A register transducer immediately granting each request.

### **Test-Free**

 Defined analogously • Transitions are  $q \xrightarrow{i \mid \downarrow r_{\text{in}}, o, \uparrow r_{\text{out}}} q'$ 

 $\rightarrow$  The register transducer of Figure 6 is *test-free*.

## **Future Work**

- Examine the case where the number of registers of the implementation is **not fixed**.
- Synthesise from specifications expressed as **logical formulae**.
- Synthesise from asynchronous specifications and implementations: no strict alternation between input letters and output letters  $\rightarrow$  gather information before producing output.
- Relax constraints over the implementation: synthesise an algorithm instead of a transducer (in the

| Nondeterministic Test-Free Decidable (implementation is also Test-Free | e) |
|------------------------------------------------------------------------|----|

#### **Proof Techniques**

- Reduce to the finite case
- Keep track of equality relations between registers
- Abstract actions by equality types

spirit of Ehlers, Seshia, & Kress-Gazit, 2014)

## References

- Bojańczyk, M., David, C., Muscholl, A., Schwentick, T., & Segoufin, L. (2011). Two-variable logic on data words. ACM Transactions on Computational Logic.
- Büchi, J. R. & Landweber, L. H. (1969). Solving Sequential Conditions by Finite-State Strategies. Transactions of the American Mathematical Society.
- Ehlers, R., Seshia, S. A., & Kress-Gazit, H. (2014). Synthesis with identifiers. In 15th International Conference on Verification, Model Checking, and Abstract Interpretation (VMCAI 2014).
- Kaminski, M. & Francez, N. (1994). Finite-memory automata. *Theoretical Computater Science*. Khalimov, A., Maderbacher, B., & Bloem, R. (2018). Bounded synthesis of register transducers. In 16th International Symposium on Automated Technology for Verification and Analysis (ATVA 2018).
- Pnueli, A. & Rosner, R. (1989). On the synthesis of a reactive module. In 16th ACM SIGPLAN-SIGACT Symposium on Principles of Programming Languages (POPL 1989).
- Schwentick, T. & Zeume, T. (2012). Two-variable logic with two order relations. Logical Methods in Computer Science.
- Segoufin, L. (2006). Automata and logics for words and trees over an infinite alphabet. In Computer Science Logic.









