Generate the Thompson automaton from an expression.
Caveats:
Result.is_valid()
Properties:
Result.proper().is_isomorphic(r.standard())
See also:
The Thompson procedure generates an automaton with spontaneous-transitions, which requires a labelset that feature a "one" label. The nullableset and wordset labelsets (and their compositions) does support a "one" label.
import vcsn
from IPython.display import display
vcsn.context('lan_char, b').ratexp('a[bc]d').thompson()
vcsn.context('law_char, b').ratexp("'aa'[bc]'dd'").thompson()
You may, however, use a labelset which does not feature a "one", in which case the context of the automaton will be different from the one of the expression.
vcsn.context('lal_char, b').ratexp("a").thompson().context()
Weights are supported.
r = vcsn.context('lan_char(abc), q').ratexp('(<1/6>a*+<1/3>b*)*')
r
t = r.thompson()
t
t.proper()
r.standard()
Note however that you may generate invalid automata:
t = vcsn.context('lan_char(abc), q').ratexp('\e*').thompson()
t
t.is_valid()