automaton.complement

Produce an automaton that accepts the complement of the language of the input automaton.

Precondition:

  • the labelset is free
  • the weightset is $\mathbb{B}$
  • the automaton is complete
  • the automaton is deterministic

Postcondition:

  • Result.is_complete()
  • Result.is_deterministic()

See also:

Examples

In [1]:
import vcsn
b = vcsn.context('lal_char(abc), b')
In [2]:
a = b.ratexp('a+b').standard().determinize().complete()
a
Out[2]:
%3 I0 0 0 I0->0 F1 F2 1 1 0->1 a 2 2 0->2 b 3 3 0->3 c 1->F1 1->3 [a-c] 2->F2 2->3 [a-c] 3->3 [a-c]
In [3]:
c = a.complement()
c
Out[3]:
%3 I0 0 0 I0->0 F0 F3 0->F0 1 1 0->1 a 2 2 0->2 b 3 3 0->3 c 1->3 [a-c] 2->3 [a-c] 3->F3 3->3 [a-c]
In [4]:
a.shortest(2)
Out[4]:
$a \oplus b$
In [5]:
c.shortest(10)
Out[5]:
$\varepsilon \oplus c \oplus \mathit{aa} \oplus \mathit{ab} \oplus \mathit{ac} \oplus \mathit{ba} \oplus \mathit{bb} \oplus \mathit{bc} \oplus \mathit{ca} \oplus \mathit{cb}$