automaton.coaccessible

Create a new automaton from the coaccessible part of the input, i.e., the subautomaton whose states can be reach a final state.

Preconditions:

  • None

Postconditions:

  • Result.is_coaccessible

See also:

Examples

In [1]:
import vcsn

The following automaton has states that cannot be reach any final(s) states:

In [2]:
a = vcsn.automaton('''
digraph
{
  vcsn_context = "lal_char(abc), b"
  I -> 0
  0 -> 1 [label = "a"]
  1 -> F
  i -> 0 [label = "a"]
  1 -> f [label = "a"]
}
''')
a
Out[2]:
%3 I0 0 0 I0->0 F1 1 1 0->1 a 1->F1 3 3 1->3 a 2 2 2->0 a
In [3]:
a.is_coaccessible()
Out[3]:
False

Calling coaccessible returns the same automaton, but without its non-coaccessible states:

In [4]:
a.coaccessible()
Out[4]:
%3 I0 0 0 I0->0 F1 1 1 0->1 a 1->F1 2 2 2->0 a
In [5]:
a.coaccessible().is_coaccessible()
Out[5]:
True