<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">


<html xmlns="http://www.w3.org/1999/xhtml">
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    
    <title>Welcome to FAdo’s documentation &mdash; FAdo 1.2 documentation</title>
    
    <link rel="stylesheet" href="_static/sphinxdoc.css" type="text/css" />
    <link rel="stylesheet" href="_static/pygments.css" type="text/css" />
    
    <script type="text/javascript">
      var DOCUMENTATION_OPTIONS = {
        URL_ROOT:    './',
        VERSION:     '1.2',
        COLLAPSE_INDEX: false,
        FILE_SUFFIX: '.html',
        HAS_SOURCE:  true
      };
    </script>
    <script type="text/javascript" src="_static/jquery.js"></script>
    <script type="text/javascript" src="_static/underscore.js"></script>
    <script type="text/javascript" src="_static/doctools.js"></script>
    <script type="text/javascript" src="http://cdn.mathjax.org/mathjax/latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML"></script>
    <link rel="top" title="FAdo 1.2 documentation" href="#" /> 
  </head>
  <body>
    <div class="related">
      <h3>Navigation</h3>
      <ul>
        <li class="right" style="margin-right: 10px">
          <a href="genindex.html" title="General Index"
             accesskey="I">index</a></li>
        <li class="right" >
          <a href="py-modindex.html" title="Python Module Index"
             >modules</a> |</li>
        <li><a href="#">FAdo 1.2 documentation</a> &raquo;</li> 
      </ul>
    </div>
      <div class="sphinxsidebar">
        <div class="sphinxsidebarwrapper">
  <h3><a href="#">Table Of Contents</a></h3>
  <ul>
<li><a class="reference internal" href="#">Welcome to FAdo&#8217;s documentation</a><ul>
<li><a class="reference internal" href="#what-is-fado">What is FAdo?</a><ul>
<li><a class="reference internal" href="#regular-languages">Regular Languages</a></li>
<li><a class="reference internal" href="#finite-languages">Finite Languages</a></li>
<li><a class="reference internal" href="#transducers">Transducers</a></li>
<li><a class="reference internal" href="#codes">Codes</a></li>
</ul>
</li>
<li><a class="reference internal" href="#module-fa">Module: Finite Automata (<tt class="docutils literal"><span class="pre">fa</span></tt>)</a><ul>
<li><a class="reference internal" href="#class-fa-abstract-class-for-finite-automata">Class FA (abstract class for Finite Automata)</a></li>
<li><a class="reference internal" href="#class-semidfa-semi-automata-class">Class SemiDFA (Semi-Automata class)</a></li>
<li><a class="reference internal" href="#class-ofa-one-way-finite-automata-class">Class OFA (one-way finite automata class)</a></li>
<li><a class="reference internal" href="#class-dfa-deterministic-finite-automata">Class DFA (Deterministic Finite Automata)</a></li>
<li><a class="reference internal" href="#class-nfa-nondeterministic-finite-automata">Class NFA (Nondeterministic Finite Automata)</a></li>
<li><a class="reference internal" href="#class-nfar-nondeterministic-finite-automata-w-reverse-transition-f">Class NFAr (Nondeterministic Finite Automata w/ reverse transition f.)</a></li>
<li><a class="reference internal" href="#class-gfa-generalized-finite-automata">Class GFA (Generalized Finite Automata)</a></li>
<li><a class="reference internal" href="#class-ssemigroup-syntactic-semigroup">Class SSemiGroup (Syntactic SemiGroup)</a></li>
<li><a class="reference internal" href="#class-enuml-language-enumeration">Class EnumL (Language Enumeration)</a></li>
<li><a class="reference internal" href="#functions">Functions</a></li>
</ul>
</li>
<li><a class="reference internal" href="#module-common">Module: Common Definitions (&#8220;common&#8221;)</a><ul>
<li><a class="reference internal" href="#class-word">Class Word</a></li>
</ul>
</li>
<li><a class="reference internal" href="#module-fio">Module: FAdo IO Functions (&#8220;fio&#8221;)</a><ul>
<li><a class="reference internal" href="#class-parserfado-yappy-parser-for-fado-fa-files">Class ParserFAdo (Yappy parser for FAdo FA files)</a></li>
<li><a class="reference internal" href="#id1">Functions</a></li>
</ul>
</li>
<li><a class="reference internal" href="#module-reex">Module: Regular Expressions (<tt class="docutils literal"><span class="pre">reex</span></tt>)</a><ul>
<li><a class="reference internal" href="#class-regexp-regular-expression">Class regexp (regular expression)</a></li>
<li><a class="reference internal" href="#class-specialconstant">Class specialConstant</a></li>
<li><a class="reference internal" href="#class-epsilon">Class epsilon</a></li>
<li><a class="reference internal" href="#class-emptyset">Class emptyset</a></li>
<li><a class="reference internal" href="#class-connective">Class connective</a></li>
<li><a class="reference internal" href="#class-star">Class star</a></li>
<li><a class="reference internal" href="#class-concat">Class concat</a></li>
<li><a class="reference internal" href="#class-disj">Class disj</a></li>
<li><a class="reference internal" href="#class-position">Class position</a></li>
<li><a class="reference internal" href="#class-parsereg">Class ParseReg</a></li>
<li><a class="reference internal" href="#id2">Functions</a></li>
</ul>
</li>
<li><a class="reference internal" href="#module-xre">Module: Extended Regular Expressions (<tt class="docutils literal"><span class="pre">xre</span></tt>)</a><ul>
<li><a class="reference internal" href="#class-xre-extended-regular-expression">Class xre (extended regular expression)</a></li>
<li><a class="reference internal" href="#id3">Functions</a></li>
</ul>
</li>
<li><a class="reference internal" href="#module-transducers">Module: Transducers (<tt class="docutils literal"><span class="pre">transducers</span></tt>)</a><ul>
<li><a class="reference internal" href="#class-transducer">Class Transducer</a></li>
<li><a class="reference internal" href="#class-sft-standard-form-transducers">Class SFT (Standard Form Transducers)</a></li>
<li><a class="reference internal" href="#id4">Functions</a></li>
</ul>
</li>
<li><a class="reference internal" href="#module-fl">Module: Finite Languages (<tt class="docutils literal"><span class="pre">fl</span></tt>)</a><ul>
<li><a class="reference internal" href="#class-fl-finite-language">Class FL (Finite Language)</a></li>
<li><a class="reference internal" href="#class-dcfa-deterministic-cover-finite-automata">Class DCFA (Deterministic Cover Finite Automata)</a></li>
<li><a class="reference internal" href="#class-afa-acyclic-finite-automata">Class AFA (Acyclic Finite Automata)</a></li>
<li><a class="reference internal" href="#class-adfa-acyclic-deterministic-finite-automata">Class ADFA (Acyclic Deterministic Finite Automata)</a></li>
<li><a class="reference internal" href="#class-anfa-acyclic-non-deterministic-finite-automata">Class ANFA (Acyclic Non-deterministic Finite Automata)</a></li>
<li><a class="reference internal" href="#class-rndwgen-random-word-generator">Class RndWGen (Random Word Generator)</a></li>
<li><a class="reference internal" href="#id5">Functions</a></li>
</ul>
</li>
<li><a class="reference internal" href="#module-graphs">Module: graphs (graph creation and manipulation)</a></li>
<li><a class="reference internal" href="#module-cfg">Module: Context Free Grammars Manipulation (<tt class="docutils literal"><span class="pre">cfg</span></tt>)</a><ul>
<li><a class="reference internal" href="#class-cfgrammar-context-free-grammar">Class CFGrammar (Context Free Grammar)</a></li>
<li><a class="reference internal" href="#class-cnf">Class CNF</a></li>
<li><a class="reference internal" href="#class-cfggenerator">Class cfgGenerator</a></li>
<li><a class="reference internal" href="#class-restringrgenerator-reg-exp-generator">Class reStringRGenerator (Reg Exp Generator)</a></li>
<li><a class="reference internal" href="#id6">Functions</a></li>
</ul>
</li>
<li><a class="reference internal" href="#module-rndfa">Module: Random DFA Generator (<tt class="docutils literal"><span class="pre">rndfa</span></tt>)</a><ul>
<li><a class="reference internal" href="#class-icdfargen-generator-container">Class ICDFArgen (Generator container)</a></li>
<li><a class="reference internal" href="#class-icdfarnd-complete-icdfa-random-generator">Class ICDFArnd (Complete ICDFA random generator)</a></li>
<li><a class="reference internal" href="#class-icdfarndincomple-incomplete-icdfa-generator">Class ICDFArndIncomple (Incomplete ICDFA generator)</a></li>
</ul>
</li>
<li><a class="reference internal" href="#module-comboperations">Module: Combo Operations (<tt class="docutils literal"><span class="pre">comboperations</span></tt>)</a></li>
<li><a class="reference internal" href="#module-codes">Module: Codes (<tt class="docutils literal"><span class="pre">codes</span></tt>)</a><ul>
<li><a class="reference internal" href="#class-codeproperty">Class CodeProperty</a></li>
<li><a class="reference internal" href="#class-trajprop">Class TrajProp</a></li>
<li><a class="reference internal" href="#class-iptprop">Class IPTProp</a></li>
<li><a class="reference internal" href="#class-iatprop">Class IATProp</a></li>
<li><a class="reference internal" href="#class-prefixprop">Class PrefixProp</a></li>
<li><a class="reference internal" href="#class-errdetectprop">Class ErrDetectProp</a></li>
<li><a class="reference internal" href="#class-errcorrectprop">Class ErrCorrectProp</a></li>
<li><a class="reference internal" href="#id7">Functions</a></li>
</ul>
</li>
<li><a class="reference internal" href="#module-grail">Module: Grail Compatibility (<tt class="docutils literal"><span class="pre">grail</span></tt>)</a><ul>
<li><a class="reference internal" href="#class-parsergrail">Class ParserGrail</a></li>
<li><a class="reference internal" href="#class-grail">Class Grail</a></li>
<li><a class="reference internal" href="#id8">Functions</a></li>
</ul>
</li>
<li><a class="reference internal" href="#module-verso">Module: Verso Language (<tt class="docutils literal"><span class="pre">verso</span></tt>)</a></li>
<li><a class="reference internal" href="#a-small-tutorial-for-fado">A small tutorial for FAdo</a></li>
<li><a class="reference internal" href="#indices-and-tables">Indices and tables</a></li>
</ul>
</li>
</ul>

  <h3>This Page</h3>
  <ul class="this-page-menu">
    <li><a href="_sources/index.txt"
           rel="nofollow">Show Source</a></li>
  </ul>
<div id="searchbox" style="display: none">
  <h3>Quick search</h3>
    <form class="search" action="search.html" method="get">
      <input type="text" name="q" />
      <input type="submit" value="Go" />
      <input type="hidden" name="check_keywords" value="yes" />
      <input type="hidden" name="area" value="default" />
    </form>
    <p class="searchtip" style="font-size: 90%">
    Enter search terms or a module, class or function name.
    </p>
</div>
<script type="text/javascript">$('#searchbox').show(0);</script>
        </div>
      </div>

    <div class="document">
      <div class="documentwrapper">
        <div class="bodywrapper">
          <div class="body">
            
  <div class="section" id="welcome-to-fado-s-documentation">
<h1>Welcome to FAdo&#8217;s documentation<a class="headerlink" href="#welcome-to-fado-s-documentation" title="Permalink to this headline">¶</a></h1>
<div class="toctree-wrapper compound">
<ul class="simple">
</ul>
</div>
<p><strong>FAdo: Tools for Language Models Manipulation</strong></p>
<p><em>Authors:</em> Rogério Reis &amp; Nelma Moreira</p>
<p>The support of transducers and all its operations, is a
collaborativejoint work with <em>Stavros Konstantinidis</em> (St. Mary&#8217;s University, Halifax, NS, Canada) (<a class="reference external" href="http://cs.smu.ca/~stavros/">http://cs.smu.ca/~stavros/</a>).</p>
<p>Contributions by</p>
<table class="hlist"><tr><td><ul class="simple">
<li>Marco Almeida</li>
<li>Ivone Amorim</li>
<li>Rafaela Bastos</li>
<li>Hugo Gouveia</li>
<li>Rizó Isrof</li>
</ul>
</td><td><ul class="simple">
<li>Eva Maia</li>
<li>Casey Meijer</li>
<li>Davide Nabais</li>
<li>Meng Yang</li>
<li>Joshua Young</li>
</ul>
</td></tr></table>
<p><em>Page of the project:</em>   <a class="reference external" href="http://fado.dcc.fc.up.pt">http://fado.dcc.fc.up.pt</a>.</p>
<p><em>Version:</em> 1.2</p>
<p><em>Copyright:</em> 1999-2014 Rogério Reis &amp; Nelma Moreira {rvr,nam}&#64;dcc.fc.up.pt</p>
<p><em>Faculdade de Ciências da Universidade do Porto</em></p>
<p><em>Centro de Matemática da Universidade do Porto</em></p>
<p><strong>Licence:</strong></p>
<p>This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.</p>
<p>This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more details.</p>
<p>You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.</p>
<div class="section" id="what-is-fado">
<h2>What is FAdo?<a class="headerlink" href="#what-is-fado" title="Permalink to this headline">¶</a></h2>
<p>The <strong>FAdo</strong> system aims to provide an open source extensible high-performance software library for the symbolic
manipulation of automata and other models of computation.</p>
<p>To allow high-level programming with complex data structures, easy prototyping of algorithms, and portability
(to use in computer grid systems for example), are its main features. Our main motivation is the theoretical
and experimental research, but we have also in mind the construction of a pedagogical tool for teaching automata
theory and formal languages.</p>
<div class="section" id="regular-languages">
<h3>Regular Languages<a class="headerlink" href="#regular-languages" title="Permalink to this headline">¶</a></h3>
<p>It currently includes most standard operations for the manipulation of regular languages. Regular languages can
be represented by regular expressions (regexp) or finite automata, among other formalisms. Finite automata may
be deterministic (DFA), non-deterministic (NFA) or generalized (GFA). In <strong>FAdo</strong> these representations are implemented
as Python classes.</p>
<p>Elementary regular languages operations as union, intersection, concatenation, complementation and reverse are
implemented for each class. Also several combined operations are available for specific models.</p>
<p>Several conversions between these representations are implemented:</p>
<ul class="simple">
<li>NFA -&gt; DFA: subset construction</li>
<li>NFA -&gt; RE: recursive method</li>
<li>GFA -&gt; RE: state elimination, with possible choice of state orderings</li>
<li>RE -&gt; NFA: Thompson method, Glushkov method, follow, Brzozowski, and partial derivatives.</li>
<li>For DFAs several minimization algorithms are available: Moore, Hopcroft, and some incremental algorithms. Brzozowski minimization is available for NFAs.</li>
<li>An algorithm for hyper-minimization of DFAs</li>
<li>Language equivalence of two DFAs can be determined by reducing their correspondent minimal DFA to a canonical form, or by the Hopcroft and Karp algorithm.</li>
<li>Enumeration of the first words of a language or all words of a given length (Cross Section)</li>
<li>Some support for the transition semigroups of DFAs</li>
</ul>
</div>
<div class="section" id="finite-languages">
<h3>Finite Languages<a class="headerlink" href="#finite-languages" title="Permalink to this headline">¶</a></h3>
<p>Special methods for finite languages are available:</p>
<ul class="simple">
<li>Construction of a ADFA (acyclic finite automata) from a set of words</li>
<li>Minimization of ADFAs</li>
<li>Several methods for ADFAs random generation</li>
<li>Methods for deterministic cover finite automata (DCFA)</li>
</ul>
</div>
<div class="section" id="transducers">
<h3>Transducers<a class="headerlink" href="#transducers" title="Permalink to this headline">¶</a></h3>
<p>Several methods for transducers in standard form (SFT) are available:</p>
<ul class="simple">
<li>Rational operations: union, inverse, reversal, composition, concatenation, star</li>
<li>Test if a transducer is functional</li>
<li>Input intersection and Output intersection operations</li>
</ul>
</div>
<div class="section" id="codes">
<h3>Codes<a class="headerlink" href="#codes" title="Permalink to this headline">¶</a></h3>
<p>A <em>language property</em> is a set of languages. Given a property specified by a transducer, several language tests are possible.</p>
<ul class="simple">
<li>Satisfaction i.e. if a language satisfies the property</li>
<li>Maximality i.e. the language satisfies the property and is maximal</li>
<li>Properties implemented by transducers include: input preserving, input altering, trajectories, and fixed properties</li>
<li>Computation of the edit distance of a regular language, using input altering transducers</li>
</ul>
</div>
</div>
<div class="section" id="module-fa">
<span id="module-finite-automata-fa"></span><h2>Module: Finite Automata (<tt class="docutils literal"><span class="pre">fa</span></tt>)<a class="headerlink" href="#module-fa" title="Permalink to this headline">¶</a></h2>
<p><strong>Finite automata manipulation.</strong></p>
<p>Deterministic and non-deterministic automata manipulation, conversion and evaluation.</p>
<div class="section" id="class-fa-abstract-class-for-finite-automata">
<h3>Class FA (abstract class for Finite Automata)<a class="headerlink" href="#class-fa-abstract-class-for-finite-automata" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="fa.FA">
<em class="property">class </em><tt class="descclassname">fa.</tt><tt class="descname">FA</tt><a class="reference internal" href="_modules/fa.html#FA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <tt class="xref py py-class docutils literal"><span class="pre">common.Drawable</span></tt></p>
<p>Base class for Finite Automata.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Variables:</th><td class="field-body"><ul class="first last simple">
<li><strong>States</strong> &#8211; set of states</li>
<li><strong>Sigma</strong> &#8211; alphabet set</li>
<li><strong>Initial</strong> &#8211; the initial state</li>
<li><strong>Final</strong> &#8211; set of final states</li>
<li><strong>delta</strong> &#8211; the transition function</li>
</ul>
</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">This is just an abstract class.
<strong>Not to be used directly!!</strong></p>
</div>
<dl class="method">
<dt id="fa.FA.addFinal">
<tt class="descname">addFinal</tt><big>(</big><em>stateindex</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.addFinal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.addFinal" title="Permalink to this definition">¶</a></dt>
<dd><p>A new state is added to the already defined set of final states.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>stateindex</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; index of the new final state</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.FA.addSigma">
<tt class="descname">addSigma</tt><big>(</big><em>sym</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.addSigma"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.addSigma" title="Permalink to this definition">¶</a></dt>
<dd><p>Adds a new symbol to the alphabet.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>sym</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; symbol to be added</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises DFAepsilonRedefenition:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body">if sym is Epsilon</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<ul class="last simple">
<li>There is no problem with duplicate symbols because Sigma is a Set.</li>
<li>No symbol Epsilon can be added.</li>
</ul>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.FA.addState">
<tt class="descname">addState</tt><big>(</big><em>name=None</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.addState"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.addState" title="Permalink to this definition">¶</a></dt>
<dd><p>Adds a new state to an FA. If no name is given a new name is created.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>name</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#object" title="(in Python v2.7)"><em>object</em></a>) &#8211; Name of the state to be added</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">Current number of states (the new state index)</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">int</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises DuplicateName:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body">if a state with that name already exists</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.FA.conjunction">
<tt class="descname">conjunction</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.conjunction"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.conjunction" title="Permalink to this definition">¶</a></dt>
<dd><p>A simple literate invocation of __and__</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> &#8211; the other FA</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.6.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.FA.countTransitions">
<tt class="descname">countTransitions</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#FA.countTransitions"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.countTransitions" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluates the size of FA transitionwise</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the number of transitions</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">int</td>
</tr>
</tbody>
</table>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 1.0.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.FA.delFinal">
<tt class="descname">delFinal</tt><big>(</big><em>st</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.delFinal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.delFinal" title="Permalink to this definition">¶</a></dt>
<dd><p>Deletes a state from the final states list</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>st</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state to be marked as not final</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.FA.delFinals">
<tt class="descname">delFinals</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#FA.delFinals"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.delFinals" title="Permalink to this definition">¶</a></dt>
<dd><p>Deletes all the information about final states.</p>
</dd></dl>

<dl class="method">
<dt id="fa.FA.deleteState">
<tt class="descname">deleteState</tt><big>(</big><em>sti</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.deleteState"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.deleteState" title="Permalink to this definition">¶</a></dt>
<dd><p>Remove the given state and the transitions related with that state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>sti</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; index of the state to be removed</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises DFAstateUnknown:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body">if state index does not exist</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.FA.disj">
<tt class="descname">disj</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.disj"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.disj" title="Permalink to this definition">¶</a></dt>
<dd><p>Another simple literate invocation of __or__</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> &#8211; the other FA</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.6.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.FA.disjunction">
<tt class="descname">disjunction</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.disjunction"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.disjunction" title="Permalink to this definition">¶</a></dt>
<dd><p>A simple literate invocation of __or__</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> &#8211; the other FA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.FA.dotDrawState">
<tt class="descname">dotDrawState</tt><big>(</big><em>sti</em>, <em>sep='n'</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.dotDrawState"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.dotDrawState" title="Permalink to this definition">¶</a></dt>
<dd><p>Draw a state in dot format</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>sti</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; index of the state</li>
<li><strong>sep</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; separator</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">str</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.FA.dotDrawTransition">
<tt class="descname">dotDrawTransition</tt><big>(</big><em>st1</em>, <em>sym</em>, <em>st2</em>, <em>sep</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.dotDrawTransition"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.dotDrawTransition" title="Permalink to this definition">¶</a></dt>
<dd><p>Draw a transition in dot format</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>st1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; departing state</li>
<li><strong>sym</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; label</li>
<li><strong>st2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; arriving state</li>
<li><strong>sep</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; separator</li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.FA.dotFormat">
<tt class="descname">dotFormat</tt><big>(</big><em>size='20</em>, <em>20'</em>, <em>direction='LR'</em>, <em>sep='n'</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.dotFormat"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.dotFormat" title="Permalink to this definition">¶</a></dt>
<dd><p>A dot representation</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>direction</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; direction of drawing</li>
<li><strong>size</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; size of image</li>
<li><strong>sep</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; line separator</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">the dot representation</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">str</p>
</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.6.</span></p>
</div>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 0.9.8.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.FA.eliminateDeadName">
<tt class="descname">eliminateDeadName</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#FA.eliminateDeadName"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.eliminateDeadName" title="Permalink to this definition">¶</a></dt>
<dd><p>Eliminates dead state name (common.DeadName) renaming the state</p>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">works inplace</p>
</div>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.2.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.FA.equivalentP">
<tt class="descname">equivalentP</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.equivalentP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.equivalentP" title="Permalink to this definition">¶</a></dt>
<dd><p>Test equivalence</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> &#8211; the other automata</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.6.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.FA.evalSymbol">
<tt class="descname">evalSymbol</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#FA.evalSymbol"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.evalSymbol" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluation of a single symbol</p>
</dd></dl>

<dl class="method">
<dt id="fa.FA.finalP">
<tt class="descname">finalP</tt><big>(</big><em>state</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.finalP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.finalP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if a state is final</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>state</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.FA.finalsP">
<tt class="descname">finalsP</tt><big>(</big><em>states</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.finalsP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.finalsP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if al the states in a set are final</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>states</strong> (<a class="reference external" href="http://docs.python.org/library/stdtypes.html#set" title="(in Python v2.7)"><em>set</em></a>) &#8211; set of state indexes</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.0.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.FA.hasStateIndexP">
<tt class="descname">hasStateIndexP</tt><big>(</big><em>st</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.hasStateIndexP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.hasStateIndexP" title="Permalink to this definition">¶</a></dt>
<dd><p>Checks if a state index pertains to an FA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>st</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; index of the state</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.FA.indexList">
<tt class="descname">indexList</tt><big>(</big><em>lstn</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.indexList"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.indexList" title="Permalink to this definition">¶</a></dt>
<dd><p>Converts a list of stateNames into a set of stateIndexes.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>lstn</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#list" title="(in Python v2.7)"><em>list</em></a>) &#8211; list of names</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">the list of state indexes</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">Set of int</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises DFAstateUnknown:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body">if a state name is unknown</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.FA.initialP">
<tt class="descname">initialP</tt><big>(</big><em>state</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.initialP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.initialP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if a state is initial</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>state</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.FA.initialSet">
<tt class="descname">initialSet</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#FA.initialSet"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.initialSet" title="Permalink to this definition">¶</a></dt>
<dd><p>The set of initial states</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the set of the initial states</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">set of States</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.FA.inputS">
<tt class="descname">inputS</tt><big>(</big><em>i</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.inputS"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.inputS" title="Permalink to this definition">¶</a></dt>
<dd><p>Input labels coming out of state i</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>i</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">set of input labels</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">set of str</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.0.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.FA.noBlankNames">
<tt class="descname">noBlankNames</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#FA.noBlankNames"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.noBlankNames" title="Permalink to this definition">¶</a></dt>
<dd><p>Eliminates blank names</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">self</td>
</tr>
</tbody>
</table>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">in place transformation</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.FA.plus">
<tt class="descname">plus</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#FA.plus"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.plus" title="Permalink to this definition">¶</a></dt>
<dd><p>Plus of a FA (star without the adding of epsilon)</p>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.6.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.FA.renameState">
<tt class="descname">renameState</tt><big>(</big><em>st</em>, <em>name</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.renameState"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.renameState" title="Permalink to this definition">¶</a></dt>
<dd><p>Rename a given state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>st</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index</li>
<li><strong>name</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#object" title="(in Python v2.7)"><em>object</em></a>) &#8211; name</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first last">self</p>
</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">Deals gacefully both with int and str names in the case of name collision.</p>
</div>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">the object is modified in place</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.FA.renameStates">
<tt class="descname">renameStates</tt><big>(</big><em>nameList=None</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.renameStates"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.renameStates" title="Permalink to this definition">¶</a></dt>
<dd><p>Renames all states using a new list of names.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>nameList</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#list" title="(in Python v2.7)"><em>list</em></a>) &#8211; list of new names</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises DFAerror:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body">if provided list is too short</td>
</tr>
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">self</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">If no list of names is given, state indexes are used.</p>
</div>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">the object is modified in place</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.FA.reversal">
<tt class="descname">reversal</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#FA.reversal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.reversal" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns a NFA that recognizes the reversal of the language</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">NFA recognizing reversal language</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.FA.same_nullability">
<tt class="descname">same_nullability</tt><big>(</big><em>s1</em>, <em>s2</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.same_nullability"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.same_nullability" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if this two states have the same nullability</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>s1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index</li>
<li><strong>s2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">bool</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.FA.setFinal">
<tt class="descname">setFinal</tt><big>(</big><em>statelist</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.setFinal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.setFinal" title="Permalink to this definition">¶</a></dt>
<dd><p>Sets the final states of the FA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>statelist</strong> (<em>int|list|set</em>) &#8211; a list (or set) of final states indexes</td>
</tr>
</tbody>
</table>
<div class="admonition caution">
<p class="first admonition-title">Caution</p>
<p class="last">it erases any previous definition of the final state set.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.FA.setInitial">
<tt class="descname">setInitial</tt><big>(</big><em>stateindex</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.setInitial"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.setInitial" title="Permalink to this definition">¶</a></dt>
<dd><p>Sets the initial state of a FA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>stateindex</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; index of the initial state</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.FA.setSigma">
<tt class="descname">setSigma</tt><big>(</big><em>symbolSet</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.setSigma"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.setSigma" title="Permalink to this definition">¶</a></dt>
<dd><p>Defines the alphabet for the FA.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>symbolSet</strong> (<em>list|set</em>) &#8211; alphabet symbols</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.FA.stateIndex">
<tt class="descname">stateIndex</tt><big>(</big><em>name</em>, <em>autoCreate=False</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.stateIndex"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.stateIndex" title="Permalink to this definition">¶</a></dt>
<dd><p>Index of given state name.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>name</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#object" title="(in Python v2.7)"><em>object</em></a>) &#8211; name of the state</li>
<li><strong>autoCreate</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; flag to create state if not already done</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">state index</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first">int</p>
</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises DFAstateUnknown:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body"><p class="first last">if the state name is unknown and autoCreate==False</p>
</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">Replaces stateName</p>
</div>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">If the state name is not known and flag is set creates it on the fly</p>
</div>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.0.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.FA.stateName">
<tt class="descname">stateName</tt><big>(</big><em>*args</em>, <em>**kwargs</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.stateName"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.stateName" title="Permalink to this definition">¶</a></dt>
<dd><p>Index of given state name.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>name</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#object" title="(in Python v2.7)"><em>object</em></a>) &#8211; name of the state</li>
<li><strong>autoCreate</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; flag to create state if not already done</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">state index</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first">int</p>
</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises DFAstateUnknown:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body"><p class="first last">if the state name is unknown and autoCreate==False</p>
</td>
</tr>
</tbody>
</table>
<div class="deprecated">
<p><span class="versionmodified">Deprecated since version 1.0: </span>Use: <a class="reference internal" href="#fa.FA.stateIndex" title="fa.FA.stateIndex"><tt class="xref py py-func docutils literal"><span class="pre">stateIndex()</span></tt></a> instead</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.FA.succintTransitions">
<tt class="descname">succintTransitions</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#FA.succintTransitions"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.succintTransitions" title="Permalink to this definition">¶</a></dt>
<dd><p>Collapsed transitions
:rtype: list</p>
</dd></dl>

<dl class="method">
<dt id="fa.FA.union">
<tt class="descname">union</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.union"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.union" title="Permalink to this definition">¶</a></dt>
<dd><p>A simple literate invocation of __or__</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> &#8211; right hand operand</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.FA.words">
<tt class="descname">words</tt><big>(</big><em>stringo=True</em><big>)</big><a class="reference internal" href="_modules/fa.html#FA.words"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.FA.words" title="Permalink to this definition">¶</a></dt>
<dd><p>Lexicografical word generator</p>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">does not generate the empty word</p>
</div>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>stringo</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; are words strings?</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.8.</span></p>
</div>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-semidfa-semi-automata-class">
<h3>Class SemiDFA (Semi-Automata class)<a class="headerlink" href="#class-semidfa-semi-automata-class" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="fa.SemiDFA">
<em class="property">class </em><tt class="descclassname">fa.</tt><tt class="descname">SemiDFA</tt><a class="reference internal" href="_modules/fa.html#SemiDFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.SemiDFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <tt class="xref py py-class docutils literal"><span class="pre">common.Drawable</span></tt></p>
<p>Class of automata without initial or final states</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Variables:</th><td class="field-body"><ul class="first last simple">
<li><strong>States</strong> &#8211; list of states</li>
<li><strong>delta</strong> &#8211; transition function</li>
<li><strong>Sigma</strong> &#8211; alphabet set</li>
</ul>
</td>
</tr>
</tbody>
</table>
<dl class="method">
<dt id="fa.SemiDFA.dotDrawState">
<tt class="descname">dotDrawState</tt><big>(</big><em>sti</em>, <em>sep='n'</em><big>)</big><a class="reference internal" href="_modules/fa.html#SemiDFA.dotDrawState"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.SemiDFA.dotDrawState" title="Permalink to this definition">¶</a></dt>
<dd><p>Dot representation of a state</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>sti</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index</li>
<li><strong>sep</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; separator</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">str</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="staticmethod">
<dt id="fa.SemiDFA.dotDrawTransition">
<em class="property">static </em><tt class="descname">dotDrawTransition</tt><big>(</big><em>st1</em>, <em>lbl1</em>, <em>st2</em>, <em>sep='n'</em><big>)</big><a class="reference internal" href="_modules/fa.html#SemiDFA.dotDrawTransition"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.SemiDFA.dotDrawTransition" title="Permalink to this definition">¶</a></dt>
<dd><p>Draw a transition in dot format</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>st1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; departing state</li>
<li><strong>lbl1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; label</li>
<li><strong>st2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; arriving state</li>
<li><strong>sep</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; separator</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">str</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.SemiDFA.dotFormat">
<tt class="descname">dotFormat</tt><big>(</big><em>size='20</em>, <em>20'</em>, <em>direction='LR'</em>, <em>sep='n'</em><big>)</big><a class="reference internal" href="_modules/fa.html#SemiDFA.dotFormat"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.SemiDFA.dotFormat" title="Permalink to this definition">¶</a></dt>
<dd><p>Dot format of automata</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>size</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; image size</li>
<li><strong>direction</strong> &#8211; direction of drawing</li>
<li><strong>sep</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; separator</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">str</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-ofa-one-way-finite-automata-class">
<h3>Class OFA (one-way finite automata class)<a class="headerlink" href="#class-ofa-one-way-finite-automata-class" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="fa.OFA">
<em class="property">class </em><tt class="descclassname">fa.</tt><tt class="descname">OFA</tt><a class="reference internal" href="_modules/fa.html#OFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#fa.FA" title="fa.FA"><tt class="xref py py-class docutils literal"><span class="pre">fa.FA</span></tt></a></p>
<p>Base class for one-way automata
.. inheritance-diagram:: OFA</p>
<dl class="method">
<dt id="fa.OFA.SPRegExp">
<tt class="descname">SPRegExp</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.SPRegExp"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.SPRegExp" title="Permalink to this definition">¶</a></dt>
<dd><p>Checks if FA is SP (Serial-PArallel), and if so returns the regular expression whose language is recognised by the FA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">equivalent regular expression</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">regexp</td>
</tr>
<tr class="field-odd field"><th class="field-name">Raises NotSP:</th><td class="field-body">if the automaton is not Serial-Parallel</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Moreira &amp; Reis, Fundamenta Informatica, Series-Parallel automata and short regular expressions,
n.91 3-4, pag 611-629.
<a class="reference external" href="http://www.dcc.fc.up.pt/~nam/publica/spa07.pdf">http://www.dcc.fc.up.pt/~nam/publica/spa07.pdf</a></p>
</div>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">Automata must be Serial-Parallel</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.acyclicP">
<tt class="descname">acyclicP</tt><big>(</big><em>strict=True</em><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.acyclicP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.acyclicP" title="Permalink to this definition">¶</a></dt>
<dd><p>Checks if the FA is acyclic</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>strict</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; if not True loops are allowed</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">True if the FA is acyclic</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.addTransition">
<tt class="descname">addTransition</tt><big>(</big><em>st1</em>, <em>sym</em>, <em>st2</em><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.addTransition"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.addTransition" title="Permalink to this definition">¶</a></dt>
<dd><p>Add transition
:param int st1: departing state
:param str sym: label
:param int st2: arriving state</p>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.allRegExps">
<tt class="descname">allRegExps</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.allRegExps"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.allRegExps" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluates the alphabetic length of the equivalent regular expression using every possible order of state
elimination.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">list of tuples (int, list of states)</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.complete">
<tt class="descname">complete</tt><big>(</big><em>dead='&#64;DeaD'</em><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.complete"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.complete" title="Permalink to this definition">¶</a></dt>
<dd><p>Transforms the automata into a complete one. If Sigma is empty nothing is done.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>dead</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; dead state name</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">the complete FA</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">Adds a dead state (if necessary) so that any word can be processed with the automata. The new state is
named <tt class="docutils literal"><span class="pre">dead</span></tt>, so this name should never be used for other purposes.</p>
</div>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">The object is modified in place.</p>
</div>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 1.0.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.completeP">
<tt class="descname">completeP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.completeP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.completeP" title="Permalink to this definition">¶</a></dt>
<dd><p>Checks if it is a complete FA (if delta is total)</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.cutPoints">
<tt class="descname">cutPoints</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.cutPoints"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.cutPoints" title="Permalink to this definition">¶</a></dt>
<dd><p>Set of FA&#8217;s cut points</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">set of states</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">set of int</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.deleteStates">
<tt class="descname">deleteStates</tt><big>(</big><em>del_states</em><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.deleteStates"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.deleteStates" title="Permalink to this definition">¶</a></dt>
<dd><p>To be implemented below</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>del_states</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#list" title="(in Python v2.7)"><em>list</em></a>) &#8211; states to be deleted</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="staticmethod">
<dt id="fa.OFA.dotDrawTransition">
<em class="property">static </em><tt class="descname">dotDrawTransition</tt><big>(</big><em>st1</em>, <em>label</em>, <em>st2</em>, <em>sep='n'</em><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.dotDrawTransition"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.dotDrawTransition" title="Permalink to this definition">¶</a></dt>
<dd><p>Draw a transition in Dot Format</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>st1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; starting state</li>
<li><strong>st2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; ending state</li>
<li><strong>label</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; symbol</li>
<li><strong>sep</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; separator</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">str</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.dump">
<tt class="descname">dump</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.dump"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.dump" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns a python representation of the object</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the python representation (Tags,States,Sigma,delta,Initial,Final)</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">tuple</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.dup">
<tt class="descname">dup</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.dup"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.dup" title="Permalink to this definition">¶</a></dt>
<dd><p>Duplicate OFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">duplicate object</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.eliminateSingles">
<tt class="descname">eliminateSingles</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.eliminateSingles"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.eliminateSingles" title="Permalink to this definition">¶</a></dt>
<dd><p>Eliminates every state that only have one successor and one predecessor.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">GFA after eliminating states</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">GFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.eliminateStout">
<tt class="descname">eliminateStout</tt><big>(</big><em>st</em><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.eliminateStout"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.eliminateStout" title="Permalink to this definition">¶</a></dt>
<dd><p>Eliminate all transitions outgoing from a given state</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>st</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; the state index to loose all outgoing transitions</td>
</tr>
</tbody>
</table>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">performs in place alteration of the automata</p>
</div>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.6.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.emptyP">
<tt class="descname">emptyP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.emptyP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.emptyP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if the automaton accepts a empty language</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.0.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.evalNumberOfStateCycles">
<tt class="descname">evalNumberOfStateCycles</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.evalNumberOfStateCycles"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.evalNumberOfStateCycles" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluates the number of cycles each state participates</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">state-&gt;list of cycle lengths</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">dict</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.evalSymbol">
<tt class="descname">evalSymbol</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.evalSymbol"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.evalSymbol" title="Permalink to this definition">¶</a></dt>
<dd><p>Eval symbol</p>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.finalCompP">
<tt class="descname">finalCompP</tt><big>(</big><em>s</em><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.finalCompP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.finalCompP" title="Permalink to this definition">¶</a></dt>
<dd><p>To be implemented below</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>s</strong> &#8211; state</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">list</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.initialComp">
<tt class="descname">initialComp</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.initialComp"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.initialComp" title="Permalink to this definition">¶</a></dt>
<dd><p>Initial component</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">list</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.minimalBrzozowski">
<tt class="descname">minimalBrzozowski</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.minimalBrzozowski"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.minimalBrzozowski" title="Permalink to this definition">¶</a></dt>
<dd><p>Constructs the equivalent minimal DFA using Brzozowski&#8217;s
algorithm</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">equivalent minimal DFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.minimalBrzozowskiP">
<tt class="descname">minimalBrzozowskiP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.minimalBrzozowskiP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.minimalBrzozowskiP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if the FA is minimal using Brzozowski&#8217;s algorithm</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.reCG">
<tt class="descname">reCG</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.reCG"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.reCG" title="Permalink to this definition">¶</a></dt>
<dd><p>Regular expression from state elimination whose language is recognised by the FA. Uses a heuristic to choose
the order of elimination.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the equivalent regular expression</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">regexp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.reCG_nn">
<tt class="descname">reCG_nn</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.reCG_nn"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.reCG_nn" title="Permalink to this definition">¶</a></dt>
<dd><p>Regular expression from state elimination whose language is recognised by the FA. Uses a heuristic to choose
the order of elimination. The FA is not normalized before the state elimination.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the equivalent regular expression</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">regexp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.reDynamicCycleHeuristic">
<tt class="descname">reDynamicCycleHeuristic</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.reDynamicCycleHeuristic"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.reDynamicCycleHeuristic" title="Permalink to this definition">¶</a></dt>
<dd><p>State elimination Heuristic based on the number of cycles that passes through each state. Here those
numbers are evaluated dynamically after each elimination step</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">an equivalent regular expression</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">regexp</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Nelma Moreira, Davide Nabais, and Rogério Reis. State elimination ordering strategies: Some experimental
results. Proc. of 11th Workshop on Descriptional Complexity of Formal Systems (DCFS10),
pages 169-180.2010. DOI: 10.4204/EPTCS.31.16</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.reStaticCycleHeuristic">
<tt class="descname">reStaticCycleHeuristic</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.reStaticCycleHeuristic"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.reStaticCycleHeuristic" title="Permalink to this definition">¶</a></dt>
<dd><p>State elimination Heuristic based on the number of cycles that passes through each state. Here those
numbers are evaluated statically in the beginning of the process</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">a equivalent regular expression</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">regexp</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Nelma Moreira, Davide Nabais, and Rogério Reis. State elimination ordering strategies: Some experimental
results. Proc. of 11th Workshop on Descriptional Complexity of Formal Systems (DCFS10),
pages 169-180.2010. DOI: 10.4204/EPTCS.31.16</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.re_stateElimination">
<tt class="descname">re_stateElimination</tt><big>(</big><em>order=None</em><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.re_stateElimination"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.re_stateElimination" title="Permalink to this definition">¶</a></dt>
<dd><p>Regular expression from state elimination whose language is recognised by the FA. The FA is normalized before
the state elimination.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>order</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#list" title="(in Python v2.7)"><em>list</em></a>) &#8211; state elimination sequence</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">the equivalent regular expression</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">regexp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.re_stateElimination_nn">
<tt class="descname">re_stateElimination_nn</tt><big>(</big><em>order=None</em><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.re_stateElimination_nn"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.re_stateElimination_nn" title="Permalink to this definition">¶</a></dt>
<dd><p>Regular expression from state elimination whose language is recognised by the FA. The FA is not normalized
before the state elimination.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>order</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#list" title="(in Python v2.7)"><em>list</em></a>) &#8211; state elimination sequence</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">the equivalent regular expression</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">regexp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.regexpSE">
<tt class="descname">regexpSE</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.regexpSE"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.regexpSE" title="Permalink to this definition">¶</a></dt>
<dd><p>A regular expression obtained by state elimination algorithm whose language is recognised by the FA.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the equivalent regular expression</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">regexp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.stateChildren">
<tt class="descname">stateChildren</tt><big>(</big><em>s</em><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.stateChildren"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.stateChildren" title="Permalink to this definition">¶</a></dt>
<dd><p>To be implemented below</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>s</strong> &#8211; state</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">list</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.succintTransitions">
<tt class="descname">succintTransitions</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.succintTransitions"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.succintTransitions" title="Permalink to this definition">¶</a></dt>
<dd><p>Collapsed transitions</p>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.toGFA">
<tt class="descname">toGFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.toGFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.toGFA" title="Permalink to this definition">¶</a></dt>
<dd><p>To be implemented below</p>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.topoSort">
<tt class="descname">topoSort</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.topoSort"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.topoSort" title="Permalink to this definition">¶</a></dt>
<dd><p>Topological order for the FA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">List of state indexes</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">list of int</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">self loops are taken in consideration</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.trim">
<tt class="descname">trim</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.trim"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.trim" title="Permalink to this definition">¶</a></dt>
<dd><p>Removes the states that do not lead to a final state, or, inclusively,
that can&#8217;t be reached from the initial state. Only useful states
remain.</p>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">in place transformation</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.trimP">
<tt class="descname">trimP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.trimP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.trimP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if the FA is trim: initially connected and co-accessible</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.uniqueRepr">
<tt class="descname">uniqueRepr</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.uniqueRepr"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.uniqueRepr" title="Permalink to this definition">¶</a></dt>
<dd><p>Abstract method</p>
</dd></dl>

<dl class="method">
<dt id="fa.OFA.usefulStates">
<tt class="descname">usefulStates</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#OFA.usefulStates"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.OFA.usefulStates" title="Permalink to this definition">¶</a></dt>
<dd><p>To be implemented below</p>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-dfa-deterministic-finite-automata">
<h3>Class DFA (Deterministic Finite Automata)<a class="headerlink" href="#class-dfa-deterministic-finite-automata" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="fa.DFA">
<em class="property">class </em><tt class="descclassname">fa.</tt><tt class="descname">DFA</tt><a class="reference internal" href="_modules/fa.html#DFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#fa.OFA" title="fa.OFA"><tt class="xref py py-class docutils literal"><span class="pre">fa.OFA</span></tt></a></p>
<p>Class for Deterministic Finite Automata.</p>
<p class="graphviz">
<img src="_images/inheritance-67420a62fbf62fe48e566ad2d41ad6709f72611e.png" alt="Inheritance diagram of DFA" usemap="#inheritancea9ae5a66b7" class="inheritance"/>
<map id="inheritancea9ae5a66b7" name="inheritancea9ae5a66b7">
<area shape="rect" id="node1" title="Any FAdo object that is drawable" alt="" coords="5,5,135,31"/>
<area shape="rect" id="node4" href="#fa.FA" title="Base class for Finite Automata." alt="" coords="183,5,255,31"/>
<area shape="rect" id="node2" href="#fa.DFA" title="Class for Deterministic Finite Automata." alt="" coords="423,5,495,31"/>
<area shape="rect" id="node3" href="#fa.OFA" title="Base class for one&#45;way automata" alt="" coords="303,5,375,31"/>
</map>
</p>
<dl class="method">
<dt id="fa.DFA.Delta">
<tt class="descname">Delta</tt><big>(</big><em>state</em>, <em>symbol</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.Delta"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.Delta" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluates the action of a symbol over a state</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>state</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index</li>
<li><strong>symbol</strong> &#8211; symbol</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">the action of symbol over state</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">int</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.aEquiv">
<tt class="descname">aEquiv</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.aEquiv"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.aEquiv" title="Permalink to this definition">¶</a></dt>
<dd><p>Computes almost equivalence, used by hyperMinimial</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">partition of states</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">dictionary</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">may be optimized to avoid dupped</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.addTransition">
<tt class="descname">addTransition</tt><big>(</big><em>sti1</em>, <em>sym</em>, <em>sti2</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.addTransition"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.addTransition" title="Permalink to this definition">¶</a></dt>
<dd><p>Adds a new transition from <tt class="docutils literal"><span class="pre">sti1</span></tt> to <tt class="docutils literal"><span class="pre">sti2</span></tt> consuming symbol <tt class="docutils literal"><span class="pre">sym</span></tt>.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>sti1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of departure</li>
<li><strong>sti2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of arrival</li>
<li><strong>sym</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; symbol consumed</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises DFAnotNFA:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body"><p class="first last">if one tries to add a non deterministic transition</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.compat">
<tt class="descname">compat</tt><big>(</big><em>s1</em>, <em>s2</em>, <em>data</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.compat"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.compat" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests compatibility between two states.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>data</strong> &#8211; </li>
<li><strong>s1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index</li>
<li><strong>s2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">bool</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.completeMinimal">
<tt class="descname">completeMinimal</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.completeMinimal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.completeMinimal" title="Permalink to this definition">¶</a></dt>
<dd><p>Completes a DFA assuming it is a minimal and avoiding de destruction of its minimality If the automaton is
not complete, all the non final states are checked to see if tey are not already a dead state. Only in the
negative case a new (dead) state is added to the automaton.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">The object is modified in place. If the alphabet is empty nothing is done</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.completeProduct">
<tt class="descname">completeProduct</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.completeProduct"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.completeProduct" title="Permalink to this definition">¶</a></dt>
<dd><p>Product structure</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> &#8211; the other DFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.computeKernel">
<tt class="descname">computeKernel</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.computeKernel"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.computeKernel" title="Permalink to this definition">¶</a></dt>
<dd><p>The Kernel of a ICDFA is the set of states that accept  a non finite language.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">triple (comp, center , mark) where comp are the strongly connected components,
center the set of center states and mark the kernel states</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">tuple</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.concat">
<tt class="descname">concat</tt><big>(</big><em>fa2</em>, <em>strict=False</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.concat"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.concat" title="Permalink to this definition">¶</a></dt>
<dd><p>Concatenation of two DFAs. If DFAs are not complete, they are completed.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>strict</strong> (<em>Boolean</em>) &#8211; should alphabets be checked?</li>
<li><strong>fa2</strong> (<em>DFA</em>) &#8211; the second DFA</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">the result of the concatenation</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first">DFA</p>
</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises DFAdifferentSigma:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body"><p class="first last">if alphabet are not equal</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.concatI">
<tt class="descname">concatI</tt><big>(</big><em>fa2</em>, <em>strict=False</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.concatI"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.concatI" title="Permalink to this definition">¶</a></dt>
<dd><p>Concatenation of two DFAs.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>fa2</strong> (<em>DFA</em>) &#8211; the second DFA</li>
<li><strong>strict</strong> (<em>Boolean</em>) &#8211; should alphabets be checked?</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">the result of the concatenation</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first">DFA</p>
</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises DFAdifferentSigma:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body"><p class="first last">if alphabet are not equal</p>
</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.5.</span></p>
</div>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">this is to be used with non complete DFAs</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.delTransition">
<tt class="descname">delTransition</tt><big>(</big><em>sti1</em>, <em>sym</em>, <em>sti2</em>, <em>_no_check=False</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.delTransition"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.delTransition" title="Permalink to this definition">¶</a></dt>
<dd><p>Remove a transition if existing and perform cleanup on the transition function&#8217;s internal data structure.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>_no_check</strong> (<em>Boolean</em>) &#8211; use unsecure code?</li>
<li><strong>sti1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of departure</li>
<li><strong>sti2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of arrival</li>
<li><strong>sym</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; symbol consumed</li>
</ul>
</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">Unused alphabet symbols will be discarded from Sigma.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.deleteStates">
<tt class="descname">deleteStates</tt><big>(</big><em>del_states</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.deleteStates"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.deleteStates" title="Permalink to this definition">¶</a></dt>
<dd><p>Delete given iterable collection of states from the automaton.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>del_states</strong> &#8211; collection of int representing states</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">delta function will always be rebuilt, regardless of whether the states list to remove is a suffix,
or a sublist, of the automaton&#8217;s states list.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.dist">
<tt class="descname">dist</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.dist"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.dist" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluate the distinguishability language for a DFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Cezar Câmpeanu, Nelma Moreira, Rogério Reis:
The distinguishability operation on regular languages. NCMA 2014: 85-100</p>
</div>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.8.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.distMin">
<tt class="descname">distMin</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.distMin"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.distMin" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluates the list of minimal words that distinguish each pair of states</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">set of minimal distinguishing words</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">FL</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.8.</span></p>
</div>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">If the DFA is not minimal, the method loops forever</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.distR">
<tt class="descname">distR</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.distR"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.distR" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluate the right distinguishability language for a DFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
<dl class="docutils">
<dt>..seealso:: Cezar Câmpeanu, Nelma Moreira, Rogério Reis:</dt>
<dd>The distinguishability operation on regular languages. NCMA 2014: 85-100</dd>
</dl>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.distRMin">
<tt class="descname">distRMin</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.distRMin"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.distRMin" title="Permalink to this definition">¶</a></dt>
<dd><p>Compute distRMin for DFA</p>
<p>:rtype FL</p>
<dl class="docutils">
<dt>..seealso:: Cezar Câmpeanu, Nelma Moreira, Rogério Reis:</dt>
<dd>The distinguishability operation on regular languages. NCMA 2014: 85-100</dd>
</dl>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.distTS">
<tt class="descname">distTS</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.distTS"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.distTS" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluate the two-sided distinguishability language for a DFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
<dl class="docutils">
<dt>..seealso:: Cezar Câmpeanu, Nelma Moreira, Rogério Reis:</dt>
<dd>The distinguishability operation on regular languages. NCMA 2014: 85-100</dd>
</dl>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.dup">
<tt class="descname">dup</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.dup"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.dup" title="Permalink to this definition">¶</a></dt>
<dd><p>Duplicate the basic structure into a new DFA. Basically a copy.deep.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.enumDFA">
<tt class="descname">enumDFA</tt><big>(</big><em>n=None</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.enumDFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.enumDFA" title="Permalink to this definition">¶</a></dt>
<dd><p>returns the set of words of words of length up to n accepted by self
:param n: highest length or all words if finite
:type n: int</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">list of strings or None</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.equal">
<tt class="descname">equal</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.equal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.equal" title="Permalink to this definition">¶</a></dt>
<dd><p>Verify if the two automata are equivalent. Both are verified to be minimum and complete,
and then one is matched against the other... Doesn&#8217;t destroy either dfa...</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> (<em>DFA</em>) &#8211; the other DFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.evalSymbol">
<tt class="descname">evalSymbol</tt><big>(</big><em>init</em>, <em>sym</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.evalSymbol"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.evalSymbol" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns the  state reached from given state through a given symbol.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>init</strong> (<em>set or list of int</em>) &#8211; set of current states indexes</li>
<li><strong>sym</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; symbol to be consumed</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">reached state</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first">int</p>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Raises:</th><td class="field-body"><ul class="first last simple">
<li><strong>DFAsymbolUnknown</strong> &#8211; if symbol not in alphabet</li>
<li><strong>DFAstopped</strong> &#8211; if transition function is not defined for the given input</li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.evalSymbolI">
<tt class="descname">evalSymbolI</tt><big>(</big><em>init</em>, <em>sym</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.evalSymbolI"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.evalSymbolI" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns the state reached from a given state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>init</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; current state</li>
<li><strong>sym</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; symbol to be consumed</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">reached state or -1</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first">set of int</p>
</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises DFAsymbolUnknown:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body"><p class="first last">if symbol not in alphabet</p>
</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.5.</span></p>
</div>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">this is to be used with non complete DFAs</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.evalSymbolL">
<tt class="descname">evalSymbolL</tt><big>(</big><em>ls</em>, <em>sym</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.evalSymbolL"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.evalSymbolL" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns the set of states reached from a given set of states through a given symbol</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>ls</strong> (<em>set of int</em>) &#8211; set of states indexes</li>
<li><strong>sym</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; symbol to be read</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">set of reached states</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">set of int</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.evalSymbolLI">
<tt class="descname">evalSymbolLI</tt><big>(</big><em>ls</em>, <em>sym</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.evalSymbolLI"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.evalSymbolLI" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns the set of states reached from a given set of states through a given symbol</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>ls</strong> (<em>set of int</em>) &#8211; set of current states</li>
<li><strong>sym</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; symbol to be consumed</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">set of reached states</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">set of int</p>
</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.5.</span></p>
</div>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">this is to be used with non complete DFAs</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.evalWordP">
<tt class="descname">evalWordP</tt><big>(</big><em>word</em>, <em>initial=None</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.evalWordP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.evalWordP" title="Permalink to this definition">¶</a></dt>
<dd><p>Verifies if the DFA recognises a given word</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>word</strong> (<em>list of symbols.</em>) &#8211; word to be recognised</li>
<li><strong>initial</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; starting state index</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">bool</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.finalCompP">
<tt class="descname">finalCompP</tt><big>(</big><em>s</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.finalCompP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.finalCompP" title="Permalink to this definition">¶</a></dt>
<dd><p>Verifies if there is a final state in  strongly connected component containing <tt class="docutils literal"><span class="pre">s</span></tt>.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>s</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">1 if yes, 0 if no</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.hasTrapStateP">
<tt class="descname">hasTrapStateP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.hasTrapStateP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.hasTrapStateP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if the automaton has a dead trap state</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.1.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.hyperMinimal">
<tt class="descname">hyperMinimal</tt><big>(</big><em>strict=False</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.hyperMinimal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.hyperMinimal" title="Permalink to this definition">¶</a></dt>
<dd><p>Hyperminization of a minimal DFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>strict</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; if strict=True it first minimizes the DFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">an hyperminimal DFA</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">M. Holzer and A. Maletti, An nlogn Algorithm for Hyper-Minimizing a (Minimized) Deterministic Automata,
TCS 411(38-39): 3404-3413 (2010)</p>
</div>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">if strict=False minimality is assumed</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.inDegree">
<tt class="descname">inDegree</tt><big>(</big><em>st</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.inDegree"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.inDegree" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns the in-degree of a given state in an FA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>st</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; index of the state</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">int</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.infix">
<tt class="descname">infix</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.infix"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.infix" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns a dfa that recognizes infix(L(a))</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.initialComp">
<tt class="descname">initialComp</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.initialComp"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.initialComp" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluates the connected component starting at the initial state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">list of state indexes in the component</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">list of int</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.initialP">
<tt class="descname">initialP</tt><big>(</big><em>state</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.initialP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.initialP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if a state is initial</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>state</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.initialSet">
<tt class="descname">initialSet</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.initialSet"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.initialSet" title="Permalink to this definition">¶</a></dt>
<dd><p>The set of initial states</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the set of the initial states</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">set of States</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.joinStates">
<tt class="descname">joinStates</tt><big>(</big><em>lst</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.joinStates"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.joinStates" title="Permalink to this definition">¶</a></dt>
<dd><p>Merge a list of states.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>lst</strong> (<em>iterable of state indexes.</em>) &#8211; set of equivalent states</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.markNonEquivalent">
<tt class="descname">markNonEquivalent</tt><big>(</big><em>s1</em>, <em>s2</em>, <em>data</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.markNonEquivalent"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.markNonEquivalent" title="Permalink to this definition">¶</a></dt>
<dd><p>Mark states with indexes s1 and s2 in given map as non equivalent states. If any back-effects exist,
apply them.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>s1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; one state&#8217;s index</li>
<li><strong>s2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; the other state&#8217;s index</li>
<li><strong>data</strong> &#8211; the matrix relating s1 and s2</li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.mergeStates">
<tt class="descname">mergeStates</tt><big>(</big><em>f</em>, <em>t</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.mergeStates"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.mergeStates" title="Permalink to this definition">¶</a></dt>
<dd><p>Merge the first given state into the second. If the first state is an initial state the second becomes the
initial state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>f</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; index of state to be absorbed</li>
<li><strong>t</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; index of remaining state</li>
</ul>
</td>
</tr>
</tbody>
</table>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">It is up to the caller to remove the disconnected state. This can be achieved with <tt class="docutils literal"><span class="pre">`trim()</span></tt>.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.minimal">
<tt class="descname">minimal</tt><big>(</big><em>method='minimalHopcroft'</em>, <em>complete=True</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.minimal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.minimal" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluates the equivalent minimal complete DFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>method</strong> &#8211; method to use in the minimization</li>
<li><strong>complete</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; should the result be completed?</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">equivalent minimal DFA</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">DFA</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.minimalHKP">
<tt class="descname">minimalHKP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.minimalHKP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.minimalHKP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests the DFA&#8217;s minimality using Hopcroft and Karp&#8217;s state equivalence algorithm</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">J. E. Hopcroft and R. M. Karp.A Linear Algorithm for Testing Equivalence of Finite Automata.TR 71&#8211;114. U.
California. 1971</p>
</div>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">The automaton must be complete.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.minimalHopcroft">
<tt class="descname">minimalHopcroft</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.minimalHopcroft"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.minimalHopcroft" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluates the equivalent minimal complete DFA using Hopcroft algorithm</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">equivalent minimal DFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">John Hopcroft,An nlog{n} algorithm for minimizing states in a  finite automaton.The Theory of Machines
and Computations.AP. 1971</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.minimalHopcroftP">
<tt class="descname">minimalHopcroftP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.minimalHopcroftP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.minimalHopcroftP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if a DFA is minimal</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.minimalIncremental">
<tt class="descname">minimalIncremental</tt><big>(</big><em>minimal_test=False</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.minimalIncremental"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.minimalIncremental" title="Permalink to this definition">¶</a></dt>
<dd><p>Minimizes the DFA with an incremental method using the Union-Find algorithm and memoized non-equivalence
intermediate results</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>minimal_test</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; starts by verifying that the automaton is not minimal?</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">equivalent minimal DFA</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<ol class="last upperalpha simple" start="13">
<li>Almeida and N. Moreira and and R. Reis.Incremental DFA minimisation. CIAA 2010. LNCS 6482. pp 39-48. 2010</li>
</ol>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.minimalIncrementalP">
<tt class="descname">minimalIncrementalP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.minimalIncrementalP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.minimalIncrementalP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if a DFA is minimal</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.minimalMoore">
<tt class="descname">minimalMoore</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.minimalMoore"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.minimalMoore" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluates the equivalent minimal automata with Moore&#8217;s algorithm</p>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">John E. Hopcroft and Jeffrey D. Ullman, Introduction to Automata Theory, Languages, and Computation, AW,
1979</p>
</div>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">minimal complete DFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.minimalMooreSq">
<tt class="descname">minimalMooreSq</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.minimalMooreSq"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.minimalMooreSq" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluates the equivalent minimal complete DFA using Moore&#8217;s (quadratic) algorithm</p>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">John E. Hopcroft and Jeffrey D. Ullman, Introduction to Automata Theory, Languages, and Computation, AW,
1979</p>
</div>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">equivalent minimal DFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.minimalMooreSqP">
<tt class="descname">minimalMooreSqP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.minimalMooreSqP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.minimalMooreSqP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if a DFA is minimal using the quadratic version of Moore&#8217;s algorithm</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.minimalNCompleteP">
<tt class="descname">minimalNCompleteP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.minimalNCompleteP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.minimalNCompleteP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if a non necessarely complete DFA is minimal, i.e., if the DFA is non complete,
if the minimal complete has only one more state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">True if not minimal</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">obsolete: use minimalP</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.minimalNotEquivP">
<tt class="descname">minimalNotEquivP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.minimalNotEquivP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.minimalNotEquivP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if the DFA is minimal by computing the set of distinguishable (not equivalent) pairs of states</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.minimalP">
<tt class="descname">minimalP</tt><big>(</big><em>method='minimalHopcroft'</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.minimalP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.minimalP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if the DFA is minimal</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>method</strong> &#8211; the minimization algorithm to be used</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
<p>..note: if DFA non complete test if  complete minimal has   one more state</p>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.minimalWatson">
<tt class="descname">minimalWatson</tt><big>(</big><em>test_only=False</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.minimalWatson"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.minimalWatson" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluates the equivalent minimal complete DFA using Waton&#8217;s incremental algorithm</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>test_only</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; is it only to test minimality</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">equivalent minimal DFA</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises DFAnotComplete:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body">if automaton is not complete</td>
</tr>
</tbody>
</table>
<dl class="docutils">
<dt>..attention::</dt>
<dd>automaton must be complete</dd>
</dl>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.minimalWatsonP">
<tt class="descname">minimalWatsonP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.minimalWatsonP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.minimalWatsonP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if a DFA is minimal using Watson&#8217;s incremental algorithm</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.notequal">
<tt class="descname">notequal</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.notequal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.notequal" title="Permalink to this definition">¶</a></dt>
<dd><p>Test non  equivalence of two DFAs</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> (<em>DFA</em>) &#8211; the other DFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.pairGraph">
<tt class="descname">pairGraph</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.pairGraph"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.pairGraph" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns pair graph</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">DiGraphVM</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">A graph theoretic approach to automata minimality. Antonio Restivo and Roberto Vaglica. Theoretical
Computer Science, 429 (2012) 282-291. doi:10.1016/j.tcs.2011.12.049 Theoretical Computer Science,
2012 vol. 429 (C) pp. 282-291. http://dx.doi.org/10.1016/j.tcs.2011.12.049</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.pref">
<tt class="descname">pref</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.pref"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.pref" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns a dfa that recognizes pref(L(self))</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.1.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.print_data">
<tt class="descname">print_data</tt><big>(</big><em>data</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.print_data"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.print_data" title="Permalink to this definition">¶</a></dt>
<dd><p>Prints table of compatibility (in the context of the minimalization algorithm).</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>data</strong> &#8211; data to print</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.product">
<tt class="descname">product</tt><big>(</big><em>other</em>, <em>complete=True</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.product"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.product" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns a DFA resulting of the simultaneous execution of two DFA. No final states set.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>other</strong> &#8211; the other DFA</li>
<li><strong>complete</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; evaluate product as a complete DFA</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">DFA</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.regexp">
<tt class="descname">regexp</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.regexp"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.regexp" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns a regexp for the current DFA considering the recursive method. Very inefficent.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">a regexp equivalent to the current DFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">regexp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.reorder">
<tt class="descname">reorder</tt><big>(</big><em>dicti</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.reorder"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.reorder" title="Permalink to this definition">¶</a></dt>
<dd><p>Reorders states according to given dictionary. Given a dictionary (not necessarily complete)... reorders
states accordingly.</p>
<p>:param dicti
:type dicti: dictionary</p>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.reverseTransitions">
<tt class="descname">reverseTransitions</tt><big>(</big><em>rev</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.reverseTransitions"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.reverseTransitions" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluate reverse transition function.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>rev</strong> (<em>DFA</em>) &#8211; DFA in which the reverse function will be stored</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.sMonoid">
<tt class="descname">sMonoid</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.sMonoid"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.sMonoid" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluation of the syntactic monoid of a DFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the semigroup</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">SSemiGroup</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.sSemigroup">
<tt class="descname">sSemigroup</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.sSemigroup"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.sSemigroup" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluation of the syntactic semigroup of a DFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the semigroup</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">SSemiGroup</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.shuffle">
<tt class="descname">shuffle</tt><big>(</big><em>other</em>, <em>strict=False</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.shuffle"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.shuffle" title="Permalink to this definition">¶</a></dt>
<dd><p>Shuffle of two languages: L1 W L2</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>other</strong> (<em>DFA</em>) &#8211; second automaton</li>
<li><strong>strict</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; should the alphabets be necessary equal?</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">DFA</p>
</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">C. Câmpeanu, K. Salomaa and S. Yu, <em>Tight lower bound for the state complexity of shuffle of regular
languages.</em> J. Autom. Lang. Comb. 7 (2002) 303–310.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.simDiff">
<tt class="descname">simDiff</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.simDiff"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.simDiff" title="Permalink to this definition">¶</a></dt>
<dd><p>Symetrical difference</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.sop">
<tt class="descname">sop</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.sop"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.sop" title="Permalink to this definition">¶</a></dt>
<dd><p>Strange operation</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> (<em>DFA</em>) &#8211; the other automaton</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.2b2.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.star">
<tt class="descname">star</tt><big>(</big><em>flag=False</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.star"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.star" title="Permalink to this definition">¶</a></dt>
<dd><p>Star of a DFA. If the DFA is not complete, it is completed.</p>
<p>..versionchanged: 0.9.6</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>flag</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; plus instead of star</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">the result of the star</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.starI">
<tt class="descname">starI</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.starI"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.starI" title="Permalink to this definition">¶</a></dt>
<dd><p>Star of an incomplete DFA.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the Kleene closure DFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.stateChildren">
<tt class="descname">stateChildren</tt><big>(</big><em>state</em>, <em>strict=False</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.stateChildren"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.stateChildren" title="Permalink to this definition">¶</a></dt>
<dd><p>Set of children of a state</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>strict</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; if not strict a state is never its own child even if a self loop is in place</li>
<li><strong>state</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state id queried</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">map children -&gt; multiplicity</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">dictionary</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.subword">
<tt class="descname">subword</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.subword"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.subword" title="Permalink to this definition">¶</a></dt>
<dd><blockquote>
<div>Returns a dfa that recognizes subword(L(self))</div></blockquote>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">dfa</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.1.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.succintTransitions">
<tt class="descname">succintTransitions</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.succintTransitions"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.succintTransitions" title="Permalink to this definition">¶</a></dt>
<dd><p>Collects the transition information in a compact way suitable for graphical representation.
:rtype: list of tupples</p>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.8.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.suff">
<tt class="descname">suff</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.suff"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.suff" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns a dfa that recognizes suff(L(self))</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.8.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.syncPower">
<tt class="descname">syncPower</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.syncPower"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.syncPower" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluates the power automata for the action of each symbol</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">The power automata being the set of all states the initial state and all singleton states final.</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.syncWords">
<tt class="descname">syncWords</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.syncWords"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.syncWords" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluates the regular expression corresponding to the synchronizing pwords of the automata.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">a regular expression of the sync words of the automata</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">regexp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.toADFA">
<tt class="descname">toADFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.toADFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.toADFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Try to convert DFA to ADFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the same automaton as a ADFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">ADFA</td>
</tr>
<tr class="field-odd field"><th class="field-name" colspan="2">Raises notAcyclic:</th></tr>
<tr class="field-odd field"><td>&nbsp;</td><td class="field-body">if this is not an acyclic DFA</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.2.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.toDFA">
<tt class="descname">toDFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.toDFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.toDFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Dummy function. It is already a DFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">a self deep copy</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.toGFA">
<tt class="descname">toGFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.toGFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.toGFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Creates a GFA equivalent to DFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">GFA deep copy</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">GFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.toNFA">
<tt class="descname">toNFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.toNFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.toNFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Migrates a DFA to a NFA as dup()</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">DFA seen as new NFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.uniqueRepr">
<tt class="descname">uniqueRepr</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.uniqueRepr"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.uniqueRepr" title="Permalink to this definition">¶</a></dt>
<dd><p>Normalise unique string for the string icdfa&#8217;s representation.</p>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">TCS 387(2):93-102, 2007 <a class="reference external" href="http://www.ncc.up.pt/~nam/publica/tcsamr06.pdf">http://www.ncc.up.pt/~nam/publica/tcsamr06.pdf</a></p>
</div>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">normalised representation</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">list</td>
</tr>
<tr class="field-odd field"><th class="field-name" colspan="2">Raises DFAnotComplete:</th></tr>
<tr class="field-odd field"><td>&nbsp;</td><td class="field-body">if DFA is not complete</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.unmark">
<tt class="descname">unmark</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.unmark"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.unmark" title="Permalink to this definition">¶</a></dt>
<dd><p>Unmarked NFA that corresponds to a marked DFA: in which each alfabetic symbol is a tuple (symbol, index)</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">a NFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.usefulStates">
<tt class="descname">usefulStates</tt><big>(</big><em>initial_states=None</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.usefulStates"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.usefulStates" title="Permalink to this definition">¶</a></dt>
<dd><p>Set of states reacheable from the given initial state(s) that have a path to a final state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>initial_states</strong> (<em>iterable of int</em>) &#8211; starting states</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">set of state indexes</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">set of int</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="staticmethod">
<dt id="fa.DFA.vDescription">
<em class="property">static </em><tt class="descname">vDescription</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.vDescription"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.vDescription" title="Permalink to this definition">¶</a></dt>
<dd><p>Generation of Verso interface description</p>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.5.</span></p>
</div>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the interface list</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.witness">
<tt class="descname">witness</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.witness"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.witness" title="Permalink to this definition">¶</a></dt>
<dd><p>Witness of non emptyness</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">word</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">str</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.DFA.witnessDiff">
<tt class="descname">witnessDiff</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/fa.html#DFA.witnessDiff"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.DFA.witnessDiff" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns a witness for the difference of two DFAs and:</p>
<table border="1" class="docutils">
<colgroup>
<col width="5%" />
<col width="95%" />
</colgroup>
<tbody valign="top">
<tr class="row-odd"><td>0</td>
<td>if the witness belongs to the <strong>other</strong> language</td>
</tr>
<tr class="row-even"><td>1</td>
<td>if the witness belongs to the <strong>self</strong> language</td>
</tr>
</tbody>
</table>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> (<em>DFA</em>) &#8211; the other DFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">a witness word</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">list of symbols</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises DFAequivalent:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body">if automata are equivalent</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-nfa-nondeterministic-finite-automata">
<h3>Class NFA (Nondeterministic Finite Automata)<a class="headerlink" href="#class-nfa-nondeterministic-finite-automata" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="fa.NFA">
<em class="property">class </em><tt class="descclassname">fa.</tt><tt class="descname">NFA</tt><a class="reference internal" href="_modules/fa.html#NFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#fa.OFA" title="fa.OFA"><tt class="xref py py-class docutils literal"><span class="pre">fa.OFA</span></tt></a></p>
<p>Class for Non-deterministic Finite Automata (epsilon-transitions allowed).</p>
<p class="graphviz">
<img src="_images/inheritance-ef957a9a0b69b16b5397a05eb8723d465e9d95c1.png" alt="Inheritance diagram of NFA" usemap="#inheritance58d251b24e" class="inheritance"/>
<map id="inheritance58d251b24e" name="inheritance58d251b24e">
<area shape="rect" id="node1" title="Any FAdo object that is drawable" alt="" coords="5,5,135,31"/>
<area shape="rect" id="node2" href="#fa.FA" title="Base class for Finite Automata." alt="" coords="183,5,255,31"/>
<area shape="rect" id="node4" href="#fa.OFA" title="Base class for one&#45;way automata" alt="" coords="303,5,375,31"/>
<area shape="rect" id="node3" href="#fa.NFA" title="Class for Non&#45;deterministic Finite Automata (epsilon&#45;transitions allowed)." alt="" coords="423,5,495,31"/>
</map>
</p>
<dl class="method">
<dt id="fa.NFA.addEpsilonLoops">
<tt class="descname">addEpsilonLoops</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.addEpsilonLoops"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.addEpsilonLoops" title="Permalink to this definition">¶</a></dt>
<dd><p>Add epsilon loops to every state
:return: self</p>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">in-place modification</p>
</div>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.0.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.addInitial">
<tt class="descname">addInitial</tt><big>(</big><em>stateindex</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.addInitial"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.addInitial" title="Permalink to this definition">¶</a></dt>
<dd><p>Add a new state to the set of initial states.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>stateindex</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; index of new initial state</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.addTransition">
<tt class="descname">addTransition</tt><big>(</big><em>sti1</em>, <em>sym</em>, <em>sti2</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.addTransition"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.addTransition" title="Permalink to this definition">¶</a></dt>
<dd><p>Adds a new transition. Transition is from <tt class="docutils literal"><span class="pre">sti1</span></tt> to <tt class="docutils literal"><span class="pre">sti2</span></tt> consuming symbol <tt class="docutils literal"><span class="pre">sym</span></tt>. <tt class="docutils literal"><span class="pre">sti2</span></tt> is a
unique state, not a set of them.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>sti1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of departure</li>
<li><strong>sti2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of arrival</li>
<li><strong>sym</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; symbol consumed</li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.addTransitionQ">
<tt class="descname">addTransitionQ</tt><big>(</big><em>srcI</em>, <em>dest</em>, <em>symb</em>, <em>qfuture</em>, <em>qpast</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.addTransitionQ"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.addTransitionQ" title="Permalink to this definition">¶</a></dt>
<dd><p>Add transition to the new transducer instance.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>qpast</strong> (<a class="reference external" href="http://docs.python.org/library/stdtypes.html#set" title="(in Python v2.7)"><em>set</em></a>) &#8211; past queue</li>
<li><strong>qfuture</strong> (<a class="reference external" href="http://docs.python.org/library/stdtypes.html#set" title="(in Python v2.7)"><em>set</em></a>) &#8211; future queue</li>
<li><strong>symb</strong> &#8211; symbol</li>
<li><strong>dest</strong> &#8211; destination state</li>
<li><strong>srcI</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; source state</li>
</ul>
</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.0.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.autobisimulation">
<tt class="descname">autobisimulation</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.autobisimulation"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.autobisimulation" title="Permalink to this definition">¶</a></dt>
<dd><p>Largest right invariant equivalence between states of the NFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">Incomplete equivalence relation (transitivity, and reflexivity not calculated) as a set of
unordered pairs of states</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">Set of frozensets</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Ilie&amp;Yu, 2003</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.autobisimulation2">
<tt class="descname">autobisimulation2</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.autobisimulation2"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.autobisimulation2" title="Permalink to this definition">¶</a></dt>
<dd><p>Alternative space-efficient definition of NFA.autobisimulation.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">Incomplete equivalence relation (reflexivity, symmetry, and transitivity not calculated) as a set
of pairs of states</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">list of tuples</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.closeEpsilon">
<tt class="descname">closeEpsilon</tt><big>(</big><em>st</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.closeEpsilon"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.closeEpsilon" title="Permalink to this definition">¶</a></dt>
<dd><p>Add all non epsilon transitions from the states in the epsilon closure of given state to given state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>st</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.concat">
<tt class="descname">concat</tt><big>(</big><em>other</em>, <em>middle='middle'</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.concat"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.concat" title="Permalink to this definition">¶</a></dt>
<dd><p>Concatenation of NFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>middle</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; glue state name</li>
<li><strong>other</strong> (<em>NFA|DFA</em>) &#8211; the other NFA</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">the result of the concatenation</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">NFA</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.countTransitions">
<tt class="descname">countTransitions</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.countTransitions"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.countTransitions" title="Permalink to this definition">¶</a></dt>
<dd><p>Number of transitions of a NFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">int</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.delTransition">
<tt class="descname">delTransition</tt><big>(</big><em>sti1</em>, <em>sym</em>, <em>sti2</em>, <em>_no_check=False</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.delTransition"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.delTransition" title="Permalink to this definition">¶</a></dt>
<dd><p>Remove a transition if existing and perform cleanup on the transition function&#8217;s internal data structure.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>sti1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of departure</li>
<li><strong>sti2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of arrival</li>
<li><strong>sym</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; symbol consumed</li>
<li><strong>_no_check</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; dismiss secure code</li>
</ul>
</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">unused alphabet symbols will be discarded from Sigma.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.deleteStates">
<tt class="descname">deleteStates</tt><big>(</big><em>del_states</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.deleteStates"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.deleteStates" title="Permalink to this definition">¶</a></dt>
<dd><p>Delete given iterable collection of states from the automaton.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>del_states</strong> (<em>set|list</em>) &#8211; collection of int representing states</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">delta function will always be rebuilt, regardless of whether the states list to remove is a suffix,
or a sublist, of the automaton&#8217;s states list.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.deterministicP">
<tt class="descname">deterministicP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.deterministicP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.deterministicP" title="Permalink to this definition">¶</a></dt>
<dd><p>Verify whether this NFA is actually deterministic</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.dotFormat">
<tt class="descname">dotFormat</tt><big>(</big><em>size='20</em>, <em>20'</em>, <em>direction='LR'</em>, <em>sep='n'</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.dotFormat"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.dotFormat" title="Permalink to this definition">¶</a></dt>
<dd><p>A dot representation
:arg direction: direction of drawing
:arg size: size of image
:arg sep: line separator
:return: the dot representation
type sep: str
:type direction: str
:type size: str
:rtype: str</p>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.6.</span></p>
</div>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 0.9.8.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.dup">
<tt class="descname">dup</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.dup"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.dup" title="Permalink to this definition">¶</a></dt>
<dd><p>Duplicate the basic structure into a new NFA. Basically a copy.deep.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.elimEpsilon">
<tt class="descname">elimEpsilon</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.elimEpsilon"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.elimEpsilon" title="Permalink to this definition">¶</a></dt>
<dd><p>Eliminate epsilon-transitions from this automaton.</p>
<p>:rtype : NFA</p>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">performs in place modification of automaton</p>
</div>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 1.1.1.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.eliminateEpsilonTransitions">
<tt class="descname">eliminateEpsilonTransitions</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.eliminateEpsilonTransitions"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.eliminateEpsilonTransitions" title="Permalink to this definition">¶</a></dt>
<dd><p>Eliminates all epslilon-transitions with no state addition</p>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">in-place modification</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.eliminateTSymbol">
<tt class="descname">eliminateTSymbol</tt><big>(</big><em>symbol</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.eliminateTSymbol"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.eliminateTSymbol" title="Permalink to this definition">¶</a></dt>
<dd><p>Delete all trasitions through a given symbol</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>symbol</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; the symbol to be excluded from delta</td>
</tr>
</tbody>
</table>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">in place alteration of the automata</p>
</div>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.6.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.enumNFA">
<tt class="descname">enumNFA</tt><big>(</big><em>n=None</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.enumNFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.enumNFA" title="Permalink to this definition">¶</a></dt>
<dd><p>returns the set of words of words of length up to n accepted by self
:param n: highest lenght or all words if finite
:type n: int</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">list of strings or None</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.epsilonClosure">
<tt class="descname">epsilonClosure</tt><big>(</big><em>st</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.epsilonClosure"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.epsilonClosure" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns the set of states epsilon-connected to from given state or set of states.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>st</strong> (<em>int|set</em>) &#8211; state index or set of state indexes</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">the list of state indexes epsilon connected to <tt class="docutils literal"><span class="pre">st</span></tt></td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">set of int</td>
</tr>
</tbody>
</table>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last"><tt class="docutils literal"><span class="pre">st</span></tt> must exist.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.epsilonP">
<tt class="descname">epsilonP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.epsilonP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.epsilonP" title="Permalink to this definition">¶</a></dt>
<dd><p>Whether this NFA has epsilon-transitions</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.epsilonPaths">
<tt class="descname">epsilonPaths</tt><big>(</big><em>start</em>, <em>end</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.epsilonPaths"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.epsilonPaths" title="Permalink to this definition">¶</a></dt>
<dd><p>All states in all paths (DFS) through empty words from a given starting state to a given ending state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>start</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; start state</li>
<li><strong>end</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; end state</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">states in epsilon paths from start to end</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">set of states</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.equivReduced">
<tt class="descname">equivReduced</tt><big>(</big><em>equiv_classes</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.equivReduced"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.equivReduced" title="Permalink to this definition">¶</a></dt>
<dd><p>Equivalent NFA reduced according to given equivalence classes.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>equiv_classes</strong> (<em>UnionFind</em>) &#8211; Equivalence classes</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">Equivalent NFA</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.evalSymbol">
<tt class="descname">evalSymbol</tt><big>(</big><em>stil</em>, <em>sym</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.evalSymbol"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.evalSymbol" title="Permalink to this definition">¶</a></dt>
<dd><p>Set of states reacheable from given states through given symbol and epsilon closure.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>stil</strong> (<em>set|list</em>) &#8211; set of current states</li>
<li><strong>sym</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; symbol to be consumed</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">set of reached state indexes</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first">set[int]</p>
</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises DFAsymbolUnknown:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body"><p class="first last">if symbol is not in alphabet</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.evalWordP">
<tt class="descname">evalWordP</tt><big>(</big><em>word</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.evalWordP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.evalWordP" title="Permalink to this definition">¶</a></dt>
<dd><p>Verify if the NFA recognises given word.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>word</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; word to be recognised</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.finalCompP">
<tt class="descname">finalCompP</tt><big>(</big><em>s</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.finalCompP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.finalCompP" title="Permalink to this definition">¶</a></dt>
<dd><p>Verify whether there is a final state in strongly connected component containing given state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>s</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">:: bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.half">
<tt class="descname">half</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.half"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.half" title="Permalink to this definition">¶</a></dt>
<dd><p>Half operation</p>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.6.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.hasTransitionP">
<tt class="descname">hasTransitionP</tt><big>(</big><em>state</em>, <em>symbol=None</em>, <em>target=None</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.hasTransitionP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.hasTransitionP" title="Permalink to this definition">¶</a></dt>
<dd><p>Whether there&#8217;s a transition from given state, optionally through given symbol,
and optionally to a specific target.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>state</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; source state</li>
<li><strong>symbol</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; optional transition symbol</li>
<li><strong>target</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; optional target state</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">if there is a transition</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">bool</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.homogenousP">
<tt class="descname">homogenousP</tt><big>(</big><em>x</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.homogenousP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.homogenousP" title="Permalink to this definition">¶</a></dt>
<dd><p>Whether this NFA is homogenous; that is, for all states, whether all incoming transitions to that state
are through the same symbol.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>x</strong> &#8211; dummy parameter to agree with the method in DFAr</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.initialComp">
<tt class="descname">initialComp</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.initialComp"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.initialComp" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluate the connected component starting at the initial state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">list of state indexes in the component</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">list of int</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.lEquivNFA">
<tt class="descname">lEquivNFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.lEquivNFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.lEquivNFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Equivalent NFA obtained from merging equivalent states from autobisimulation of this NFA&#8217;s reversal.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">returns copy of self if autobisimulation renders no equivalent states.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.lrEquivNFA">
<tt class="descname">lrEquivNFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.lrEquivNFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.lrEquivNFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Equivalent NFA obtained from merging equivalent states from autobisimulation of this NFA,
and from autobisimulation of its reversal; i.e., merges all states that are equivalent w.r.t. the largest
right invariant and largest left invariant equivalence relations.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">returns copy of self if autobisimulations render no equivalent states.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.minimal">
<tt class="descname">minimal</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.minimal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.minimal" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluates the equivalent minimal DFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">equivalent minimal DFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.minimalDFA">
<tt class="descname">minimalDFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.minimalDFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.minimalDFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluates the equivalent minimal complete DFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">equivalent minimal DFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.product">
<tt class="descname">product</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.product"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.product" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns a NFA (skeletom) resulting of the simultaneous execution of two DFA.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> (<em>NFA</em>) &#8211; the other automata</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">No final states are set.</p>
</div>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<ul class="last simple">
<li>the name <tt class="docutils literal"><span class="pre">EmptySet</span></tt> is used in a unique special state name</li>
<li>the method uses 3 internal functions for simplicity of code (really!)</li>
</ul>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.rEquivNFA">
<tt class="descname">rEquivNFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.rEquivNFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.rEquivNFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Equivalent NFA obtained from merging equivalent states from autobisimulation of this NFA.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">returns copy of self if autobisimulation renders no equivalent states.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.reorder">
<tt class="descname">reorder</tt><big>(</big><em>dicti</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.reorder"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.reorder" title="Permalink to this definition">¶</a></dt>
<dd><p>Reorder states indexes according to given dictionary.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>dicti</strong> (<em>dictionary</em>) &#8211; state name reorder</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">dictionary does not have to be complete</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.reversal">
<tt class="descname">reversal</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.reversal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.reversal" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns a NFA that recognizes the reversal of the language</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">NFA recognizing reversal language</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.reverseTransitions">
<tt class="descname">reverseTransitions</tt><big>(</big><em>rev</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.reverseTransitions"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.reverseTransitions" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluate reverse transition function.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>rev</strong> (<em>NFA</em>) &#8211; NFA in which the reverse function will be stored</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.setInitial">
<tt class="descname">setInitial</tt><big>(</big><em>statelist</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.setInitial"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.setInitial" title="Permalink to this definition">¶</a></dt>
<dd><p>Sets the initial states of an NFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>statelist</strong> (<em>set|list|int</em>) &#8211; an iterable of initial state indexes</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.shuffle">
<tt class="descname">shuffle</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.shuffle"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.shuffle" title="Permalink to this definition">¶</a></dt>
<dd><p>Shuffle of a NFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> (<em>FA</em>) &#8211; an FA</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">the resulting NFA</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.star">
<tt class="descname">star</tt><big>(</big><em>flag=False</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.star"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.star" title="Permalink to this definition">¶</a></dt>
<dd><p>Kleene star of a NFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>flag</strong> (<em>Boolean</em>) &#8211; plus instead of star</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">the resulting NFA</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.stateChildren">
<tt class="descname">stateChildren</tt><big>(</big><em>state</em>, <em>strict=False</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.stateChildren"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.stateChildren" title="Permalink to this definition">¶</a></dt>
<dd><p>Set of children of a state</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>strict</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; if not strict a state is never its own child even if a self loop is in place</li>
<li><strong>state</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state id queried</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">children states</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">Set of int</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.stronglyConnectedComponents">
<tt class="descname">stronglyConnectedComponents</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.stronglyConnectedComponents"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.stronglyConnectedComponents" title="Permalink to this definition">¶</a></dt>
<dd><p>Strong components</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">list</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.0.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.subword">
<tt class="descname">subword</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.subword"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.subword" title="Permalink to this definition">¶</a></dt>
<dd><p>returns a nfa that recognizes subword(L(self))</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">nfa</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.succintTransitions">
<tt class="descname">succintTransitions</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.succintTransitions"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.succintTransitions" title="Permalink to this definition">¶</a></dt>
<dd><p>Collects the transition information in a concat way suitable for graphical representation.
:rtype: list</p>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.toDFA">
<tt class="descname">toDFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.toDFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.toDFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Construct a DFA equivalent to this NFA, by the subset construction method.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">valid to epsilon-NFA</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.toGFA">
<tt class="descname">toGFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.toGFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.toGFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Creates a GFA equivalent to NFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">a GFA deep copy</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">GFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.toNFA">
<tt class="descname">toNFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.toNFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.toNFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Dummy identity function</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.toNFAr">
<tt class="descname">toNFAr</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.toNFAr"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.toNFAr" title="Permalink to this definition">¶</a></dt>
<dd><p>NFA with the reverse mapping of the delta function.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">shallow copy with reverse delta function added</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">NFAr</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.uniqueRepr">
<tt class="descname">uniqueRepr</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.uniqueRepr"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.uniqueRepr" title="Permalink to this definition">¶</a></dt>
<dd><p>Dummy representation. Used DFA.uniqueRepr()
:rtype: tuple</p>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.usefulStates">
<tt class="descname">usefulStates</tt><big>(</big><em>initial_states=None</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.usefulStates"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.usefulStates" title="Permalink to this definition">¶</a></dt>
<dd><p>Set of states reacheable from the given initial state(s) that have a path to a final state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>initial_states</strong> (<em>set of int or list of int</em>) &#8211; set of initial states</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">set of state indexes</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">set of int</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="staticmethod">
<dt id="fa.NFA.vDescription">
<em class="property">static </em><tt class="descname">vDescription</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.vDescription"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.vDescription" title="Permalink to this definition">¶</a></dt>
<dd><p>Generation of Verso interface description</p>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.5.</span></p>
</div>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the interface list</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.witness">
<tt class="descname">witness</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.witness"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.witness" title="Permalink to this definition">¶</a></dt>
<dd><p>Witness of non emptyness</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">word</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">str</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFA.wordImage">
<tt class="descname">wordImage</tt><big>(</big><em>word</em>, <em>ist=None</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFA.wordImage"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFA.wordImage" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluates the set of states reached consuming given word</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>word</strong> (<em>list of stings</em>) &#8211; the word</li>
<li><strong>ist</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; starting state index (or set of)</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">the set of ending states</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">Set of int</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-nfar-nondeterministic-finite-automata-w-reverse-transition-f">
<h3>Class NFAr (Nondeterministic Finite Automata w/ reverse transition f.)<a class="headerlink" href="#class-nfar-nondeterministic-finite-automata-w-reverse-transition-f" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="fa.NFAr">
<em class="property">class </em><tt class="descclassname">fa.</tt><tt class="descname">NFAr</tt><a class="reference internal" href="_modules/fa.html#NFAr"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFAr" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#fa.NFA" title="fa.NFA"><tt class="xref py py-class docutils literal"><span class="pre">fa.NFA</span></tt></a></p>
<p>Class for Non-deterministic Finite Automata with reverse delta function added by construction.</p>
<p class="graphviz">
<img src="_images/inheritance-3d2a628bbf2d722b2110e413db2677311fcdb610.png" alt="Inheritance diagram of NFAr" usemap="#inheritance06bf7d94fb" class="inheritance"/>
<map id="inheritance06bf7d94fb" name="inheritance06bf7d94fb">
<area shape="rect" id="node1" title="Any FAdo object that is drawable" alt="" coords="5,5,135,31"/>
<area shape="rect" id="node2" href="#fa.FA" title="Base class for Finite Automata." alt="" coords="183,5,255,31"/>
<area shape="rect" id="node4" href="#fa.OFA" title="Base class for one&#45;way automata" alt="" coords="303,5,375,31"/>
<area shape="rect" id="node3" href="#fa.NFA" title="Class for Non&#45;deterministic Finite Automata (epsilon&#45;transitions allowed)." alt="" coords="423,5,495,31"/>
<area shape="rect" id="node5" href="#fa.NFAr" title="Class for Non&#45;deterministic Finite Automata with reverse delta function added by construction." alt="" coords="543,5,615,31"/>
</map>
</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Variables:</th><td class="field-body"><strong>deltaReverse</strong> &#8211; the reversed transition function</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">Includes efficient methods for merging states.</p>
</div>
<dl class="method">
<dt id="fa.NFAr.addTransition">
<tt class="descname">addTransition</tt><big>(</big><em>sti1</em>, <em>sym</em>, <em>sti2</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFAr.addTransition"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFAr.addTransition" title="Permalink to this definition">¶</a></dt>
<dd><p>Adds a new transition. Transition is from <tt class="docutils literal"><span class="pre">sti1</span></tt> to <tt class="docutils literal"><span class="pre">sti2</span></tt> consuming symbol <tt class="docutils literal"><span class="pre">sym</span></tt>. <tt class="docutils literal"><span class="pre">sti2</span></tt> is a
unique state, not a set of them. Reversed transition function  is also computed</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>sti1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of departure</li>
<li><strong>sti2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of arrival</li>
<li><strong>sym</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; symbol consumed</li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFAr.delTransition">
<tt class="descname">delTransition</tt><big>(</big><em>sti1</em>, <em>sym</em>, <em>sti2</em>, <em>_no_check=False</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFAr.delTransition"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFAr.delTransition" title="Permalink to this definition">¶</a></dt>
<dd><p>Remove a transition if existing and perform cleanup on the transition function&#8217;s internal data structure
and in the reversal transition function</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>sti1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of departure</li>
<li><strong>sti2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of arrival</li>
<li><strong>sym</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; symbol consumed</li>
<li><strong>_no_check</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; dismiss secure code</li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFAr.deleteStates">
<tt class="descname">deleteStates</tt><big>(</big><em>del_states</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFAr.deleteStates"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFAr.deleteStates" title="Permalink to this definition">¶</a></dt>
<dd><p>Delete given iterable collection of states from the automaton. Performe deletion in the transition
function and its reversal.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>del_states</strong> (<em>set or list of int</em>) &#8211; collection of int representing states</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFAr.elimEpsilonO">
<tt class="descname">elimEpsilonO</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFAr.elimEpsilonO"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFAr.elimEpsilonO" title="Permalink to this definition">¶</a></dt>
<dd><p>Eliminate epsilon-transitions from this automaton, with reduction of states through elimination of
epsilon-cycles, and single epsilon-transition cases.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">itself</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">performs inplace modification of automaton</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFAr.homogenousP">
<tt class="descname">homogenousP</tt><big>(</big><em>inplace=False</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFAr.homogenousP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFAr.homogenousP" title="Permalink to this definition">¶</a></dt>
<dd><p>Checks is the automaton is homogenous, i.e.the transitions that reaches a state have all the same label.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>inplace</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; if True performs epsilon transitions elimination</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">True if homogenous</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFAr.mergeStates">
<tt class="descname">mergeStates</tt><big>(</big><em>f</em>, <em>t</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFAr.mergeStates"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFAr.mergeStates" title="Permalink to this definition">¶</a></dt>
<dd><p>Merge the first given state into the second. If first state is an initial or final state,
the second becomes respectively an initial or final state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>f</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; index of state to be absorbed</li>
<li><strong>t</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; index of remaining state</li>
</ul>
</td>
</tr>
</tbody>
</table>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">It is up to the caller to remove the disconnected
state. This can be achieved with <tt class="docutils literal"><span class="pre">`trim()</span></tt>.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFAr.mergeStatesSet">
<tt class="descname">mergeStatesSet</tt><big>(</big><em>tomerge</em>, <em>target=None</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFAr.mergeStatesSet"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFAr.mergeStatesSet" title="Permalink to this definition">¶</a></dt>
<dd><p>Merge a set of states with a target merge state. If the states in the set have transitions among them,
those transitions will be directly merged into the target state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>tomerge</strong> (<em>Set of initegers</em>) &#8211; set of states to merge with target</li>
<li><strong>target</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; optional target state</li>
</ul>
</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">if target state is not given, the minimal index with be considered.</p>
</div>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">The states of the list will become unreacheable, but won&#8217;t be removed. It is up to the caller to remove
them. That can be achieved with <tt class="docutils literal"><span class="pre">trim()</span></tt>.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFAr.toNFA">
<tt class="descname">toNFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#NFAr.toNFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFAr.toNFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Turn into an instance of NFA, and remove the reverse mapping of the delta function.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">shallow copy without reverse delta function</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.NFAr.unlinkSoleIncoming">
<tt class="descname">unlinkSoleIncoming</tt><big>(</big><em>state</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFAr.unlinkSoleIncoming"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFAr.unlinkSoleIncoming" title="Permalink to this definition">¶</a></dt>
<dd><p>If given state has only one incoming transition (indegree is one), and it&#8217;s through epsilon,
then remove such transition and return the source state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>state</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state to check</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">source state</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">int or None</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">if conditions aren&#8217;t met, returned source state is None, and automaton remains unmodified.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.NFAr.unlinkSoleOutgoing">
<tt class="descname">unlinkSoleOutgoing</tt><big>(</big><em>state</em><big>)</big><a class="reference internal" href="_modules/fa.html#NFAr.unlinkSoleOutgoing"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.NFAr.unlinkSoleOutgoing" title="Permalink to this definition">¶</a></dt>
<dd><p>If given state has only one outgoing transition (outdegree is one), and it&#8217;s through epsilon,
then remove such transition and return the target state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>state</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state to check</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">target state</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">int or None</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">if conditions aren&#8217;t met, returned target state is None, and automaton remains unmodified.</p>
</div>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-gfa-generalized-finite-automata">
<h3>Class GFA (Generalized Finite Automata)<a class="headerlink" href="#class-gfa-generalized-finite-automata" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="fa.GFA">
<em class="property">class </em><tt class="descclassname">fa.</tt><tt class="descname">GFA</tt><a class="reference internal" href="_modules/fa.html#GFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.GFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#fa.OFA" title="fa.OFA"><tt class="xref py py-class docutils literal"><span class="pre">fa.OFA</span></tt></a></p>
<p>Class for Generalized Finite Automata: NFA with a unique initial state and transitions are labeled with regexp.</p>
<p class="graphviz">
<img src="_images/inheritance-1998994f6e85d0c77d794421ae3e2b16f60f4e5e.png" alt="Inheritance diagram of GFA" usemap="#inheritance88ce569e1e" class="inheritance"/>
<map id="inheritance88ce569e1e" name="inheritance88ce569e1e">
<area shape="rect" id="node1" title="Any FAdo object that is drawable" alt="" coords="5,5,135,31"/>
<area shape="rect" id="node2" href="#fa.FA" title="Base class for Finite Automata." alt="" coords="183,5,255,31"/>
<area shape="rect" id="node4" href="#fa.OFA" title="Base class for one&#45;way automata" alt="" coords="303,5,375,31"/>
<area shape="rect" id="node3" href="#fa.GFA" title="Class for Generalized Finite Automata: NFA with a unique initial state and transitions are labeled with regexp." alt="" coords="423,5,495,31"/>
</map>
</p>
<dl class="method">
<dt id="fa.GFA.DFS">
<tt class="descname">DFS</tt><big>(</big><em>io</em><big>)</big><a class="reference internal" href="_modules/fa.html#GFA.DFS"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.GFA.DFS" title="Permalink to this definition">¶</a></dt>
<dd><p>Depth first search</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>io</strong> &#8211; </td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.GFA.addTransition">
<tt class="descname">addTransition</tt><big>(</big><em>sti1</em>, <em>sym</em>, <em>sti2</em><big>)</big><a class="reference internal" href="_modules/fa.html#GFA.addTransition"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.GFA.addTransition" title="Permalink to this definition">¶</a></dt>
<dd><dl class="docutils">
<dt>Adds a new transition from <tt class="docutils literal"><span class="pre">sti1</span></tt> to <tt class="docutils literal"><span class="pre">sti2</span></tt> consuming symbol <tt class="docutils literal"><span class="pre">sym</span></tt>. Label of the transition function</dt>
<dd>is a regexp.</dd>
</dl>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>sti1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of departure</li>
<li><strong>sti2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of arrival</li>
<li><strong>sym</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; symbol consumed</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises DFAepsilonRedefenition:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body"><p class="first last">if sym is Epsilon</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.GFA.assignLow">
<tt class="descname">assignLow</tt><big>(</big><em>st</em><big>)</big><a class="reference internal" href="_modules/fa.html#GFA.assignLow"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.GFA.assignLow" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>st</strong> &#8211; </td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.GFA.assignNum">
<tt class="descname">assignNum</tt><big>(</big><em>st</em><big>)</big><a class="reference internal" href="_modules/fa.html#GFA.assignNum"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.GFA.assignNum" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>st</strong> &#8211; </td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.GFA.completeDelta">
<tt class="descname">completeDelta</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#GFA.completeDelta"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.GFA.completeDelta" title="Permalink to this definition">¶</a></dt>
<dd><p>Adds empty set transitions between the automatons final and initial states in order to make it complete.
It&#8217;s only meant to be used in the final stage of SEA...</p>
</dd></dl>

<dl class="method">
<dt id="fa.GFA.deleteState">
<tt class="descname">deleteState</tt><big>(</big><em>sti</em><big>)</big><a class="reference internal" href="_modules/fa.html#GFA.deleteState"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.GFA.deleteState" title="Permalink to this definition">¶</a></dt>
<dd><p>deletes a state from the GFA
:param sti:</p>
</dd></dl>

<dl class="method">
<dt id="fa.GFA.dfs_visit">
<tt class="descname">dfs_visit</tt><big>(</big><em>s</em>, <em>visited</em>, <em>io</em><big>)</big><a class="reference internal" href="_modules/fa.html#GFA.dfs_visit"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.GFA.dfs_visit" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>s</strong> &#8211; state</li>
<li><strong>visited</strong> &#8211; list od states visited</li>
<li><strong>io</strong> &#8211; </li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.GFA.dup">
<tt class="descname">dup</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#GFA.dup"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.GFA.dup" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns a copy of a GFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">GFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.GFA.eliminate">
<tt class="descname">eliminate</tt><big>(</big><em>st</em><big>)</big><a class="reference internal" href="_modules/fa.html#GFA.eliminate"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.GFA.eliminate" title="Permalink to this definition">¶</a></dt>
<dd><p>Eliminate a state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>st</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state to be eliminated</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.GFA.eliminateAll">
<tt class="descname">eliminateAll</tt><big>(</big><em>lr</em><big>)</big><a class="reference internal" href="_modules/fa.html#GFA.eliminateAll"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.GFA.eliminateAll" title="Permalink to this definition">¶</a></dt>
<dd><p>Eliminate a list of states.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>lr</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#list" title="(in Python v2.7)"><em>list</em></a>) &#8211; list of states indexes</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.GFA.eliminateState">
<tt class="descname">eliminateState</tt><big>(</big><em>st</em><big>)</big><a class="reference internal" href="_modules/fa.html#GFA.eliminateState"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.GFA.eliminateState" title="Permalink to this definition">¶</a></dt>
<dd><p>Deletes a state and updates the automaton</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>st</strong> (<em>state index</em>) &#8211; the state to be deleted</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.GFA.normalize">
<tt class="descname">normalize</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#GFA.normalize"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.GFA.normalize" title="Permalink to this definition">¶</a></dt>
<dd><p>Create a single initial and final state with Epsilon transitions.</p>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">works in place</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.GFA.reorder">
<tt class="descname">reorder</tt><big>(</big><em>dictio</em><big>)</big><a class="reference internal" href="_modules/fa.html#GFA.reorder"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.GFA.reorder" title="Permalink to this definition">¶</a></dt>
<dd><p>Reorder states indexes according to given dictionary.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>dictio</strong> (<em>dictionary</em>) &#8211; order</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">dictionary does not have to be complete</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fa.GFA.stateChildren">
<tt class="descname">stateChildren</tt><big>(</big><em>state</em>, <em>strict=False</em><big>)</big><a class="reference internal" href="_modules/fa.html#GFA.stateChildren"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.GFA.stateChildren" title="Permalink to this definition">¶</a></dt>
<dd><p>Set of children of a state</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>strict</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; a state is never its own children even if a self loop is in place</li>
<li><strong>state</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state id queried</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">map: children -&gt; alphabetic length</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">dictionary</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.GFA.weight">
<tt class="descname">weight</tt><big>(</big><em>state</em><big>)</big><a class="reference internal" href="_modules/fa.html#GFA.weight"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.GFA.weight" title="Permalink to this definition">¶</a></dt>
<dd><p>Calculates the weight of a state based on a heuristic</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>state</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">the weight of the state</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">int</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.GFA.weightWithCycles">
<tt class="descname">weightWithCycles</tt><big>(</big><em>state</em>, <em>cycles</em><big>)</big><a class="reference internal" href="_modules/fa.html#GFA.weightWithCycles"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.GFA.weightWithCycles" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>state</strong> &#8211; </li>
<li><strong>cycles</strong> &#8211; </li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first last"></p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-ssemigroup-syntactic-semigroup">
<h3>Class SSemiGroup (Syntactic SemiGroup)<a class="headerlink" href="#class-ssemigroup-syntactic-semigroup" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="fa.SSemiGroup">
<em class="property">class </em><tt class="descclassname">fa.</tt><tt class="descname">SSemiGroup</tt><a class="reference internal" href="_modules/fa.html#SSemiGroup"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.SSemiGroup" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference external" href="http://docs.python.org/library/functions.html#object" title="(in Python v2.7)"><tt class="xref py py-class docutils literal"><span class="pre">object</span></tt></a></p>
<p>Class support for the Syntactic SemiGroup.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Variables:</th><td class="field-body"><ul class="first last simple">
<li><strong>elements</strong> &#8211; list of tuples representing the transformations</li>
<li><strong>words</strong> &#8211; a list of pairs (index of the prefix transformation, index of the suffix char)</li>
<li><strong>gen</strong> &#8211; a list of the max index of each generation</li>
<li><strong>Sigma</strong> &#8211; set of symbols</li>
</ul>
</td>
</tr>
</tbody>
</table>
<dl class="method">
<dt id="fa.SSemiGroup.WordI">
<tt class="descname">WordI</tt><big>(</big><em>i</em><big>)</big><a class="reference internal" href="_modules/fa.html#SSemiGroup.WordI"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.SSemiGroup.WordI" title="Permalink to this definition">¶</a></dt>
<dd><p>Representative of an element given as index</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>i</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; index of the element</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">the first word originating the element</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">str</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.SSemiGroup.WordPS">
<tt class="descname">WordPS</tt><big>(</big><em>pref</em>, <em>sym</em><big>)</big><a class="reference internal" href="_modules/fa.html#SSemiGroup.WordPS"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.SSemiGroup.WordPS" title="Permalink to this definition">¶</a></dt>
<dd><p>Representative of an element given as prefix symb</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>pref</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; prefix index</li>
<li><strong>sym</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; symbol index</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">word</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">str</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.SSemiGroup.add">
<tt class="descname">add</tt><big>(</big><em>tr</em>, <em>pref</em>, <em>sym</em>, <em>tmpLists</em><big>)</big><a class="reference internal" href="_modules/fa.html#SSemiGroup.add"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.SSemiGroup.add" title="Permalink to this definition">¶</a></dt>
<dd><p>Try to add a new transformation to the monoid</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>tr</strong> (<em>tuple of int</em>) &#8211; transformation</li>
<li><strong>pref</strong> (<em>int or None</em>) &#8211; prefix of the generating word</li>
<li><strong>sym</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; suffix symbol</li>
<li><strong>tmpLists</strong> (<em>pairs of lists as (elements,words)</em>) &#8211; this generation lists</li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.SSemiGroup.addGen">
<tt class="descname">addGen</tt><big>(</big><em>tmpLists</em><big>)</big><a class="reference internal" href="_modules/fa.html#SSemiGroup.addGen"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.SSemiGroup.addGen" title="Permalink to this definition">¶</a></dt>
<dd><p>Add a new generation to the monoid</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>tmpLists</strong> (<em>pair of lists as (elements, words)</em>) &#8211; the new generation data</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-enuml-language-enumeration">
<h3>Class EnumL (Language Enumeration)<a class="headerlink" href="#class-enuml-language-enumeration" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="fa.EnumL">
<em class="property">class </em><tt class="descclassname">fa.</tt><tt class="descname">EnumL</tt><big>(</big><em>aut</em>, <em>store=False</em><big>)</big><a class="reference internal" href="_modules/fa.html#EnumL"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.EnumL" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference external" href="http://docs.python.org/library/functions.html#object" title="(in Python v2.7)"><tt class="xref py py-class docutils literal"><span class="pre">object</span></tt></a></p>
<p>Class for enumerate FA languages</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Variables:</th><td class="field-body"><ul class="first last simple">
<li><strong>aut</strong> &#8211; Automaton of the language</li>
<li><strong>tmin</strong> &#8211; table for minimal words for each s in aut.States</li>
<li><strong>Words</strong> &#8211; list of words (if stored)</li>
<li><strong>Sigma</strong> &#8211; alphabet</li>
</ul>
</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.8.</span></p>
</div>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Efficient enumeration of words in regular languages, M. Ackerman and J. Shallit,
Theor. Comput. Sci. 410, 37, pp 3461-3470. 2009.
<a class="reference external" href="http://dx.doi.org/10.1016/j.tcs.2009.03.018">http://dx.doi.org/10.1016/j.tcs.2009.03.018</a></p>
</div>
<dl class="method">
<dt id="fa.EnumL.enum">
<tt class="descname">enum</tt><big>(</big><em>m</em><big>)</big><a class="reference internal" href="_modules/fa.html#EnumL.enum"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.EnumL.enum" title="Permalink to this definition">¶</a></dt>
<dd><p>Enumerates the first m words of L(A) according to the lexicographic order if there are at least m words.
Otherwise, enumerates all words accepted by A.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>m</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; </td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.EnumL.enumCrossSection">
<tt class="descname">enumCrossSection</tt><big>(</big><em>n</em><big>)</big><a class="reference internal" href="_modules/fa.html#EnumL.enumCrossSection"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.EnumL.enumCrossSection" title="Permalink to this definition">¶</a></dt>
<dd><p>Enumerates the nth cross-section of L(A)</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>n</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; nonnegative integer</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.EnumL.fillStack">
<tt class="descname">fillStack</tt><big>(</big><em>w</em><big>)</big><a class="reference internal" href="_modules/fa.html#EnumL.fillStack"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.EnumL.fillStack" title="Permalink to this definition">¶</a></dt>
<dd><p>Abstract method
:param w:
:type w: str</p>
</dd></dl>

<dl class="method">
<dt id="fa.EnumL.iCompleteP">
<tt class="descname">iCompleteP</tt><big>(</big><em>i</em>, <em>q</em><big>)</big><a class="reference internal" href="_modules/fa.html#EnumL.iCompleteP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.EnumL.iCompleteP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if state q is i-complete</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>i</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; int</li>
<li><strong>q</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index</li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fa.EnumL.initStack">
<tt class="descname">initStack</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fa.html#EnumL.initStack"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.EnumL.initStack" title="Permalink to this definition">¶</a></dt>
<dd><p>Abstract method</p>
</dd></dl>

<dl class="method">
<dt id="fa.EnumL.minWord">
<tt class="descname">minWord</tt><big>(</big><em>m</em><big>)</big><a class="reference internal" href="_modules/fa.html#EnumL.minWord"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.EnumL.minWord" title="Permalink to this definition">¶</a></dt>
<dd><p>Computes the minimal word of length m accepted by the automaton
:param m:
:type m: int</p>
</dd></dl>

<dl class="method">
<dt id="fa.EnumL.minWordT">
<tt class="descname">minWordT</tt><big>(</big><em>n</em><big>)</big><a class="reference internal" href="_modules/fa.html#EnumL.minWordT"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.EnumL.minWordT" title="Permalink to this definition">¶</a></dt>
<dd><p>Abstract method
:param n:
:type n: int</p>
</dd></dl>

<dl class="method">
<dt id="fa.EnumL.nextWord">
<tt class="descname">nextWord</tt><big>(</big><em>w</em><big>)</big><a class="reference internal" href="_modules/fa.html#EnumL.nextWord"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.EnumL.nextWord" title="Permalink to this definition">¶</a></dt>
<dd><p>Abstract method
:param w:
:type w: str</p>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="functions">
<h3>Functions<a class="headerlink" href="#functions" title="Permalink to this headline">¶</a></h3>
<dl class="function">
<dt id="fa.saveToString">
<tt class="descclassname">fa.</tt><tt class="descname">saveToString</tt><big>(</big><em>aut</em>, <em>sep='&amp;'</em><big>)</big><a class="reference internal" href="_modules/fa.html#saveToString"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.saveToString" title="Permalink to this definition">¶</a></dt>
<dd><p>Finite automata definition as a string using the input format.</p>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.5.</span></p>
</div>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 0.9.6: </span>Names are now used instead of indexes.</p>
</div>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 0.9.7: </span>New format with quotes and alphabet</p>
</div>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>aut</strong> (<em>FA</em>) &#8211; the FA</li>
<li><strong>sep</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; separation between <cite>lines</cite></li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">the representation</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">str</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="fa.stringToDFA">
<tt class="descclassname">fa.</tt><tt class="descname">stringToDFA</tt><big>(</big><em>s</em>, <em>f</em>, <em>n</em>, <em>k</em><big>)</big><a class="reference internal" href="_modules/fa.html#stringToDFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fa.stringToDFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Converts a string icdfa&#8217;s representation to dfa.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>s</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#list" title="(in Python v2.7)"><em>list</em></a>) &#8211; canonical string representation</li>
<li><strong>f</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#list" title="(in Python v2.7)"><em>list</em></a>) &#8211; bit map of final states</li>
<li><strong>n</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; number of states</li>
<li><strong>k</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; number of symbols</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">a complete dfa with Sigma [<tt class="docutils literal"><span class="pre">k</span></tt>], States [<tt class="docutils literal"><span class="pre">n</span></tt>]</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">DFA</p>
</td>
</tr>
</tbody>
</table>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 0.9.8: </span>symbols are converted to str</p>
</div>
</dd></dl>

</div>
</div>
<div class="section" id="module-common">
<span id="module-common-definitions-common"></span><h2>Module: Common Definitions (&#8220;common&#8221;)<a class="headerlink" href="#module-common" title="Permalink to this headline">¶</a></h2>
<p><strong>Common definitions for FAdo files</strong></p>
<div class="section" id="class-word">
<h3>Class Word<a class="headerlink" href="#class-word" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="common.Word">
<em class="property">class </em><tt class="descclassname">common.</tt><tt class="descname">Word</tt><big>(</big><em>it=</em><span class="optional">[</span><span class="optional">]</span><big>)</big><a class="reference internal" href="_modules/common.html#Word"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#common.Word" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference external" href="http://docs.python.org/library/functions.html#object" title="(in Python v2.7)"><tt class="xref py py-class docutils literal"><span class="pre">object</span></tt></a></p>
<p>Class to implement generic words as iterables with pretty-print</p>
<p>Basically a unified way to deal with words with caracters of of sizes different of one with no much fuss</p>
</dd></dl>

</div>
</div>
<div class="section" id="module-fio">
<span id="module-fado-io-functions-fio"></span><h2>Module: FAdo IO Functions (&#8220;fio&#8221;)<a class="headerlink" href="#module-fio" title="Permalink to this headline">¶</a></h2>
<p><strong>In/Out.</strong></p>
<p>FAdo IO.</p>
<div class="section" id="class-parserfado-yappy-parser-for-fado-fa-files">
<h3>Class ParserFAdo (Yappy parser for FAdo FA files)<a class="headerlink" href="#class-parserfado-yappy-parser-for-fado-fa-files" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="fio.ParserFAdo">
<em class="property">class </em><tt class="descclassname">fio.</tt><tt class="descname">ParserFAdo</tt><big>(</big><em>no_table=1</em>, <em>table='.tableFAdo'</em><big>)</big><a class="reference internal" href="_modules/fio.html#ParserFAdo"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fio.ParserFAdo" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <tt class="xref py py-class docutils literal"><span class="pre">yappy_parser.Yappy</span></tt></p>
<p>A parser for FAdo standard automata descriptions</p>
<p class="graphviz">
<img src="_images/inheritance-1556d04d4dca6ab83da7d3b289a7db1a01703ee4.png" alt="Inheritance diagram of ParserFAdo" usemap="#inheritance77c32d2d56" class="inheritance"/>
<map id="inheritance77c32d2d56" name="inheritance77c32d2d56">
<area shape="rect" id="node1" href="#fio.ParserFAdo" title="A parser for FAdo standard automata descriptions" alt="" coords="395,5,501,31"/>
<area shape="rect" id="node2" title="A basic class for parsing." alt="" coords="208,5,347,31"/>
<area shape="rect" id="node3" title="Class for LR parser" alt="" coords="5,5,160,31"/>
</map>
</p>
</dd></dl>

</div>
<div class="section" id="id1">
<h3>Functions<a class="headerlink" href="#id1" title="Permalink to this headline">¶</a></h3>
<dl class="function">
<dt id="fio.readFromFile">
<tt class="descclassname">fio.</tt><tt class="descname">readFromFile</tt><big>(</big><em>FileName</em><big>)</big><a class="reference internal" href="_modules/fio.html#readFromFile"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fio.readFromFile" title="Permalink to this definition">¶</a></dt>
<dd><p>Reads list of finite automata definition from a file.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>FileName</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; file name</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">list</td>
</tr>
</tbody>
</table>
<p>The format of these files must be the as simple as possible:</p>
<table class="hlist"><tr><td><ul class="simple">
<li><tt class="docutils literal"><span class="pre">#</span></tt> begins a comment</li>
<li><tt class="docutils literal"><span class="pre">&#64;DFA</span></tt> or <tt class="docutils literal"><span class="pre">&#64;NFA</span></tt> begin a new automata (and determines its type) and must be followed by the list of the
final states separated by blanks</li>
<li>fields are separated by a blank and transitions by a CR: <tt class="docutils literal"><span class="pre">state</span></tt> <tt class="docutils literal"><span class="pre">symbol</span></tt> <tt class="docutils literal"><span class="pre">new</span> <span class="pre">state</span></tt></li>
<li>in case of a NFA declaration, the &#8220;symbol&#8221; &#64;epsilon is interpreted as a epsilon-transition</li>
<li>the source state of the first transition is the initial state</li>
<li>in the case of a NFA, its declaration <tt class="docutils literal"><span class="pre">&#64;NFA</span></tt>  can, after the declaration of the final states,
have a <tt class="docutils literal"><span class="pre">*</span></tt> followed by the list of initial states</li>
<li>both, NFA and DFA, may have a declaration of alphabet starting with a <tt class="docutils literal"><span class="pre">$</span></tt> followed by the symbols of the
alphabet</li>
<li>a line with a sigle name, decrares a state</li>
</ul>
</td></tr></table>
<pre>
<strong id="grammar-token-FAdo">FAdo      </strong> ::=  FA | FA CR FAdo
<strong id="grammar-token-FA">FA        </strong> ::=  DFA | NFA | Transducer
<strong id="grammar-token-DFA">DFA       </strong> ::=  &quot;&#64;DFA&quot; LsStates Alphabet CR dTrans
<strong id="grammar-token-NFA">NFA       </strong> ::=  &quot;&#64;NFA&quot; LsStates Initials Alphabet CR nTrans
<strong id="grammar-token-Transducer">Transducer</strong> ::=  &quot;&#64;Transducer&quot; LsStates Initials Alphabet Output CR tTrans
<strong id="grammar-token-Initials">Initials  </strong> ::=  &quot;*&quot; LsStates | \epsilon
<strong id="grammar-token-Alphabet">Alphabet  </strong> ::=  &quot;$&quot; LsSymbols | \epsilon
<strong id="grammar-token-Output">Output    </strong> ::=  &quot;$&quot; LsSymbols | \epsilon
<strong id="grammar-token-nSymbol">nSymbol   </strong> ::=  symbol | &quot;&#64;epsilon&quot;
<strong id="grammar-token-LsStates">LsStates  </strong> ::=  stateid | stateid , LsStates
<strong id="grammar-token-LsSymbols">LsSymbols </strong> ::=  symbol | symbol , LsSymbols
<strong id="grammar-token-dTrans">dTrans    </strong> ::=  stateid symbol stateid |
               | stateid symbol stateid CR dTrans
<strong id="grammar-token-nTrans">nTrans    </strong> ::=  stateid nSymbol stateid |
               | stateid nSymbol stateid CR nTrans
<strong id="grammar-token-tTrans">tTrans    </strong> ::=  stateid nSymbol nSymbol stateid |
               | stateid nSymbol nSymbol stateid CR nTrans
</pre>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">If an error occur, either syntactic or because of a violation of the declared automata type,
an exception is raised</p>
</div>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 0.9.6.</span></p>
</div>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 1.0.</span></p>
</div>
</dd></dl>

<dl class="function">
<dt id="fio.saveToFile">
<tt class="descclassname">fio.</tt><tt class="descname">saveToFile</tt><big>(</big><em>FileName</em>, <em>fa</em>, <em>mode='a'</em><big>)</big><a class="reference internal" href="_modules/fio.html#saveToFile"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fio.saveToFile" title="Permalink to this definition">¶</a></dt>
<dd><p>Saves a list finite automata definition to a file using the input format</p>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 0.9.5.</span></p>
</div>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 0.9.6.</span></p>
</div>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 0.9.7: </span>New format with quotes and alphabet</p>
</div>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>FileName</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; file name</li>
<li><strong>fa</strong> (<em>list of FA</em>) &#8211; the FA</li>
<li><strong>mode</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; writing mode</li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

</div>
</div>
<div class="section" id="module-reex">
<span id="module-regular-expressions-reex"></span><h2>Module: Regular Expressions (<tt class="docutils literal"><span class="pre">reex</span></tt>)<a class="headerlink" href="#module-reex" title="Permalink to this headline">¶</a></h2>
<p><strong>Regular expressions manipulation</strong></p>
<p>Regular expression classes and manipulation</p>
<div class="section" id="class-regexp-regular-expression">
<h3>Class regexp (regular expression)<a class="headerlink" href="#class-regexp-regular-expression" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="reex.regexp">
<em class="property">class </em><tt class="descclassname">reex.</tt><tt class="descname">regexp</tt><big>(</big><em>val</em>, <em>sigma=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference external" href="http://docs.python.org/library/functions.html#object" title="(in Python v2.7)"><tt class="xref py py-class docutils literal"><span class="pre">object</span></tt></a></p>
<p>Base class for regular expressions.</p>
<p>Used directly to represent a symbol. The type of the symbol is arbitrary.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Variables:</th><td class="field-body"><ul class="first last simple">
<li><strong>Sigma</strong> &#8211; alphabet set of strings</li>
<li><strong>val</strong> &#8211; the actual symbol</li>
</ul>
</td>
</tr>
</tbody>
</table>
<p class="graphviz">
<img src="_images/inheritance-1c92fa4683bd93e4558ded9806ac033cf55cd562.png" alt="Inheritance diagram of regexp" usemap="#inheritancec3fb013de4" class="inheritance"/>
<map id="inheritancec3fb013de4" name="inheritancec3fb013de4">
<area shape="rect" id="node1" href="#reex.regexp" title="Base class for regular expressions." alt="" coords="5,5,96,31"/>
</map>
</p>
<p>Constructor of a regular expression symbol.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>val</strong> &#8211; the actual symbol</td>
</tr>
</tbody>
</table>
<dl class="method">
<dt id="reex.regexp.PD">
<tt class="descname">PD</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.PD"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.PD" title="Permalink to this definition">¶</a></dt>
<dd><p>Closure of partial derivatives of the regular expression in relation to all words.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">set of regular expressions</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">set</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Antimirov, 95</p>
</div>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.alphabeticLength">
<tt class="descname">alphabeticLength</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.alphabeticLength"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.alphabeticLength" title="Permalink to this definition">¶</a></dt>
<dd><p>Number of occurrences of alphabet symbols in the regular expression.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">integer</td>
</tr>
</tbody>
</table>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">Doesn&#8217;t include the empty word.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.compare">
<tt class="descname">compare</tt><big>(</big><em>r</em>, <em>cmp_method='compareMinimalDFA'</em>, <em>nfa_method='nfaPosition'</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.compare"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.compare" title="Permalink to this definition">¶</a></dt>
<dd><p>Compare with another regular expression for equivalence.
:param r:
:param cmp_method:
:param nfa_method:</p>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.compareMinimalDFA">
<tt class="descname">compareMinimalDFA</tt><big>(</big><em>r</em>, <em>nfa_method='nfaPosition'</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.compareMinimalDFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.compareMinimalDFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Compare with another regular expression for equivalence through minimal DFAs.
:param r:
:param nfa_method:</p>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.derivative">
<tt class="descname">derivative</tt><big>(</big><em>sigma</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.derivative"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.derivative" title="Permalink to this definition">¶</a></dt>
<dd><p>Derivative of the regular expression in relation to the given symbol.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>sigma</strong> &#8211; an arbitrary symbol.</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">regular expression</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">whether the symbols belong to the expression&#8217;s alphabet goes unchecked. The given symbol will be
matched against the string representation of the regular expression&#8217;s symbol.</p>
</div>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<ol class="last upperalpha simple" start="10">
<li><ol class="first upperalpha">
<li>Brzozowski, Derivatives of Regular Expressions. J. ACM 11(4): 481-494 (1964)</li>
</ol>
</li>
</ol>
</div>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.dfaPosition">
<tt class="descname">dfaPosition</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.dfaPosition"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.dfaPosition" title="Permalink to this definition">¶</a></dt>
<dd><p>Deterministic position automaton of a regular expression.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">position DFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
<tr class="field-odd field"><th class="field-name" colspan="2">Raises common.DFAnotNFAFAdo:</th></tr>
<tr class="field-odd field"><td>&nbsp;</td><td class="field-body">if not DFA</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">If this expression is not linear (cf. linearP()), exception may be raised
on non-deterministic transitions.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.emptyP">
<tt class="descname">emptyP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.emptyP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.emptyP" title="Permalink to this definition">¶</a></dt>
<dd><p>Whether the regular expression is the empty set.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">Boolean</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.epsilonLength">
<tt class="descname">epsilonLength</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.epsilonLength"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.epsilonLength" title="Permalink to this definition">¶</a></dt>
<dd><p>Number of occurrences of the empty word in the regular expression.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">integer</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.epsilonP">
<tt class="descname">epsilonP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.epsilonP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.epsilonP" title="Permalink to this definition">¶</a></dt>
<dd><p>Whether the regular expression is the empty word.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">Boolean</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.equivalentP">
<tt class="descname">equivalentP</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.equivalentP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.equivalentP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests equivalence</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.evalWordP">
<tt class="descname">evalWordP</tt><big>(</big><em>word</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.evalWordP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.evalWordP" title="Permalink to this definition">¶</a></dt>
<dd><p>Verifies if a word is a member of the language represented by the regular expression.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>word</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; the word</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.ewp">
<tt class="descname">ewp</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.ewp"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.ewp" title="Permalink to this definition">¶</a></dt>
<dd><p>Whether the empty word property holds for this regular expression&#8217;s language.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">Boolean</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.first">
<tt class="descname">first</tt><big>(</big><em>parent_first=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.first"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.first" title="Permalink to this definition">¶</a></dt>
<dd><p>List of possible symbols matching the first symbol of a string in the language of the regular expression.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>parent_first</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">list of symbols</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.followLists">
<tt class="descname">followLists</tt><big>(</big><em>lists=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.followLists"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.followLists" title="Permalink to this definition">¶</a></dt>
<dd><p>Map of each symbol&#8217;s follow list in the regular expression.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>lists</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">map of symbols&#8217; follow lists</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">{symbol: list of symbols}</td>
</tr>
</tbody>
</table>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">For first() and last() return lists, the follow list for certain symbols might have repetitions in the
case  of follow maps calculated from star operators. The union of last(),
first() and follow() sets are always disjoint when the regular expression is in star normal form (
Brüggemann-Klein, 92), therefore FAdo implements them as lists. You should order exclusively,
or take a set from a list in order to resolve repetitions.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.followListsD">
<tt class="descname">followListsD</tt><big>(</big><em>lists=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.followListsD"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.followListsD" title="Permalink to this definition">¶</a></dt>
<dd><p>Map of each symbol&#8217;s follow list in the regular expression.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>lists</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">map of symbols&#8217; follow lists</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">{symbol: list of symbols}</td>
</tr>
</tbody>
</table>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">For first() and last() return lists, the follow list for certain symbols might have repetitions in the case
of follow maps calculated from star operators. The union of last(), first() and follow() sets are always
disjoint</p>
</div>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Sabine Broda, António Machiavelo, Nelma Moreira, and Rogério Reis. On the average size of
glushkov and partial derivative automata. International Journal of Foundations of Computer Science,
23(5):969-984, 2012.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.followListsStar">
<tt class="descname">followListsStar</tt><big>(</big><em>lists=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.followListsStar"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.followListsStar" title="Permalink to this definition">¶</a></dt>
<dd><p>Map of each symbol&#8217;s follow list in the regular expression under a star.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>lists</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">map of symbols&#8217; follow lists</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">{symbol: list of symbols}</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.last">
<tt class="descname">last</tt><big>(</big><em>parent_last=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.last"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.last" title="Permalink to this definition">¶</a></dt>
<dd><p>List of possible symbols matching the last symbol of a string in the language of the regular expression.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>parent_last</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">list of symbols</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">list</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.linearForm">
<tt class="descname">linearForm</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.linearForm"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.linearForm" title="Permalink to this definition">¶</a></dt>
<dd><p>Linear form of the regular expression , as a mapping from heads to sets of tails, so that each pair (head,
tail) is a monomial in the set of linear forms.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">dictionary mapping heads to sets of tails</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">{symbol: set([regular expressions])}</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Antimirov, 95</p>
</div>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.linearP">
<tt class="descname">linearP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.linearP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.linearP" title="Permalink to this definition">¶</a></dt>
<dd><p>Whether the regular expression is linear; i.e., the occurrence of a symbol in the expression is unique.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">boolean</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.marked">
<tt class="descname">marked</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.marked"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.marked" title="Permalink to this definition">¶</a></dt>
<dd><p>Regular expression in which every alphabetic symbol is marked with its position.</p>
<p>The kind of regular expression returned is known, depending on the literary source, as marked,
linear or restricted regular expression.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">linear regular expression</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">regexp</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">R. McNaughton and H. Yamada, Regular Expressions and State Graphs for Automata,
IEEE Transactions on Electronic Computers, V.9 pp:39-47, 1960</p>
</div>
<p>..attention: mark and unmark do not preserve the alphabet, neither set the new alphabet</p>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.measure">
<tt class="descname">measure</tt><big>(</big><em>from_parent=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.measure"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.measure" title="Permalink to this definition">¶</a></dt>
<dd><p>A list with four measures for regular expressions.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>from_parent</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">[int,int,int,int]</td>
</tr>
</tbody>
</table>
<p>[alphabeticLength, treeLength, epsilonLength, starHeight]</p>
<ol class="arabic simple">
<li>alphabeticLength: number of occurences of symbols of the alphabet;</li>
<li>treeLength: number of functors in the regular expression, including constants.</li>
<li>epsilonLength: number of occurrences of the empty word.</li>
<li>starHeight: highest level of nested Kleene stars, starting at one for one star occurrence.</li>
</ol>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">Methods for each of the measures are implemented independently. This is the most effective for obtaining
more than one measure.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.nfaFollow">
<tt class="descname">nfaFollow</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.nfaFollow"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.nfaFollow" title="Permalink to this definition">¶</a></dt>
<dd><p>NFA that accepts the regular expression&#8217;s language, whose structure, and construction.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Ilie &amp; Yu (Follow Automata, 03)</p>
</div>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.nfaFollowEpsilon">
<tt class="descname">nfaFollowEpsilon</tt><big>(</big><em>trim=True</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.nfaFollowEpsilon"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.nfaFollowEpsilon" title="Permalink to this definition">¶</a></dt>
<dd><p>Epsilon-NFA constructed with Ilie and Yu&#8217;s method () that accepts the regular expression&#8217;s language.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>trim</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">NFA possibly with epsilon transitions</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFAe</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Ilie &amp; Yu, Follow automta, Inf. Comp. ,v. 186 (1),140-162,2003</p>
</div>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.nfaGlushkov">
<tt class="descname">nfaGlushkov</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.nfaGlushkov"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.nfaGlushkov" title="Permalink to this definition">¶</a></dt>
<dd><p>Position or Glushkov automaton of the regular expression. Recursive method.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.nfaNaiveFollow">
<tt class="descname">nfaNaiveFollow</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.nfaNaiveFollow"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.nfaNaiveFollow" title="Permalink to this definition">¶</a></dt>
<dd><p>NFA that accepts the regular expression&#8217;s language, and is equal in structure to the follow automaton.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">Included for testing purposes.</p>
</div>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Ilie &amp; Yu (Follow Automata, 2003)</p>
</div>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.nfaPD">
<tt class="descname">nfaPD</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.nfaPD"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.nfaPD" title="Permalink to this definition">¶</a></dt>
<dd><dl class="docutils">
<dt>NFA that accepts the regular expression&#8217;s language,</dt>
<dd>and which is constructed from the expression&#8217;s partial derivatives.</dd>
</dl>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">partial derivatives [or equation] automaton</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">V. M. Antimirov, Partial Derivatives of Regular Expressions and Finite Automaton Constructions
.Theor. Comput. Sci.155(2): 291-319 (1996)</p>
</div>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.nfaPDO">
<tt class="descname">nfaPDO</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.nfaPDO"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.nfaPDO" title="Permalink to this definition">¶</a></dt>
<dd><dl class="docutils">
<dt>NFA that accepts the regular expression&#8217;s language, and which is constructed from the expression&#8217;s partial</dt>
<dd>derivatives.</dd>
</dl>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">optimized version</p>
</div>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">partial derivatives [or equation] automaton</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.nfaPSNF">
<tt class="descname">nfaPSNF</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.nfaPSNF"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.nfaPSNF" title="Permalink to this definition">¶</a></dt>
<dd><p>Position or Glushkov automaton of the regular expression constructed from the expression&#8217;s star normal form.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">position automaton</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.nfaPosition">
<tt class="descname">nfaPosition</tt><big>(</big><em>lstar=True</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.nfaPosition"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.nfaPosition" title="Permalink to this definition">¶</a></dt>
<dd><p>Position automaton of the regular expression.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>lstar</strong> (<em>boolean</em>) &#8211; if not None followlists are computed dijunct</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">position NFA</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.nfaThompson">
<tt class="descname">nfaThompson</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.nfaThompson"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.nfaThompson" title="Permalink to this definition">¶</a></dt>
<dd><p>Epsilon-NFA constructed with Thompson&#8217;s method that accepts the regular expression&#8217;s language.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<ol class="last upperalpha simple" start="11">
<li>Thompson. Regular Expression Search Algorithm. CACM 11(6), 419-422 (1968)</li>
</ol>
</div>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.partialDerivatives">
<tt class="descname">partialDerivatives</tt><big>(</big><em>sigma</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.partialDerivatives"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.partialDerivatives" title="Permalink to this definition">¶</a></dt>
<dd><p>Set of partial derivatives of the regular expression in relation to given symbol.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>sigma</strong> &#8211; symbol in relation to which the derivative will be calculated.</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">set of regular expressions</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Antimirov, 95</p>
</div>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.reduced">
<tt class="descname">reduced</tt><big>(</big><em>hasEpsilon=False</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.reduced"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.reduced" title="Permalink to this definition">¶</a></dt>
<dd><p>Equivalent regular expression with the following cases simplified:</p>
<ol class="arabic simple">
<li>Epsilon.RE = RE.Epsilon = RE</li>
<li>EmptySet.RE = RE.EmptySet = EmptySet</li>
<li>EmptySet + RE = RE + EmptySet = RE</li>
<li>Epsilon + RE = RE + Epsilon = RE, where Epsilon is in L(RE)</li>
<li>RE** = RE*</li>
<li>EmptySet* = Epsilon* = Epsilon</li>
</ol>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>hasEpsilon</strong> &#8211; used internally to indicate that the language of which this term is a subterm has the empty
word.</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">regular expression</td>
</tr>
</tbody>
</table>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">Returned structure isn&#8217;t strictly a duplicate. Use __copy__() for that purpose.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.reversal">
<tt class="descname">reversal</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.reversal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.reversal" title="Permalink to this definition">¶</a></dt>
<dd><p>Reversal of regexp</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">regexp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.rpn">
<tt class="descname">rpn</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.rpn"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.rpn" title="Permalink to this definition">¶</a></dt>
<dd><p>RPN representation
:return: printable RPN representation</p>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.setOfSymbols">
<tt class="descname">setOfSymbols</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.setOfSymbols"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.setOfSymbols" title="Permalink to this definition">¶</a></dt>
<dd><p>Set of symbols that occur in a regular expression..</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">set of symbols</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">set of symbols</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.setSigma">
<tt class="descname">setSigma</tt><big>(</big><em>symbolSet</em>, <em>strict=False</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.setSigma"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.setSigma" title="Permalink to this definition">¶</a></dt>
<dd><p>Set the alphabet for a regular expression and all its nodes</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>symbolSet</strong> (<em>list or set of str</em>) &#8211; accepted symbols. If None, alphabet is unset.</li>
<li><strong>strict</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; if True checks if setOfSymbols is included in symbolSet</li>
</ul>
</td>
</tr>
</tbody>
</table>
<p>..attention: Normally this attribute is not defined in a regexp()</p>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.snf">
<tt class="descname">snf</tt><big>(</big><em>hollowdot=False</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.snf"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.snf" title="Permalink to this definition">¶</a></dt>
<dd><p>Star Normal Form (SNF) of the regular expression.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>hollowdot</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">regular expression in star normal form</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.starHeight">
<tt class="descname">starHeight</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.starHeight"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.starHeight" title="Permalink to this definition">¶</a></dt>
<dd><p>Maximum level of nested regular expressions with a star operation applied.</p>
<p>For instance, starHeight(((a*b)*+b*)*) is 3.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">integer</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.stringLength">
<tt class="descname">stringLength</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.stringLength"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.stringLength" title="Permalink to this definition">¶</a></dt>
<dd><p>Length of the string representation of the regular expression.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">integer</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.support">
<tt class="descname">support</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.support"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.support" title="Permalink to this definition">¶</a></dt>
<dd><p>&#8216;Support of a regular expression.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">set of regular expressions</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">set</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Champarnaud, J.M., Ziadi, D.: From Mirkin&#8217;s prebases to Antimirov&#8217;s word partial derivative.
Fundam. Inform. 45(3), 195-205 (2001)</p>
</div>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.toDFA">
<tt class="descname">toDFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.toDFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.toDFA" title="Permalink to this definition">¶</a></dt>
<dd><p>DFA that accepts the regular expression&#8217;s language</p>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.toNFA">
<tt class="descname">toNFA</tt><big>(</big><em>nfa_method='nfaPD'</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.toNFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.toNFA" title="Permalink to this definition">¶</a></dt>
<dd><p>NFA that accepts the regular expression&#8217;s language.
:param nfa_method:</p>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.treeLength">
<tt class="descname">treeLength</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.treeLength"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.treeLength" title="Permalink to this definition">¶</a></dt>
<dd><p>Number of nodes of the regular expression&#8217;s syntactical tree.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">integer</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.unmarked">
<tt class="descname">unmarked</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.unmarked"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.unmarked" title="Permalink to this definition">¶</a></dt>
<dd><p>The unmarked form of the regular expression. Each leaf in its syntactical tree becomes a regexp(),
the epsilon() or the emptyset().</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">(general) regular expression</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.regexp.wordDerivative">
<tt class="descname">wordDerivative</tt><big>(</big><em>word</em><big>)</big><a class="reference internal" href="_modules/reex.html#regexp.wordDerivative"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.regexp.wordDerivative" title="Permalink to this definition">¶</a></dt>
<dd><dl class="docutils">
<dt>Derivative of the regular expression in relation to the given word,</dt>
<dd>which is represented by a list of symbols.</dd>
</dl>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>word</strong> &#8211; list of arbitrary symbols.</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">regular expression</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<ol class="last upperalpha simple" start="10">
<li><ol class="first upperalpha">
<li>Brzozowski, Derivatives of Regular Expressions. J. ACM 11(4): 481-494 (1964)</li>
</ol>
</li>
</ol>
</div>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-specialconstant">
<h3>Class specialConstant<a class="headerlink" href="#class-specialconstant" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="reex.specialConstant">
<em class="property">class </em><tt class="descclassname">reex.</tt><tt class="descname">specialConstant</tt><big>(</big><em>sigma=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#specialConstant"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.specialConstant" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#reex.regexp" title="reex.regexp"><tt class="xref py py-class docutils literal"><span class="pre">reex.regexp</span></tt></a></p>
<p>Base class for Epsilon and EmptySet</p>
<p class="graphviz">
<img src="_images/inheritance-7943046f9a2fc605eb4b1de78a7e020a14f792df.png" alt="Inheritance diagram of specialConstant" usemap="#inheritance1079c0927b" class="inheritance"/>
<map id="inheritance1079c0927b" name="inheritance1079c0927b">
<area shape="rect" id="node1" href="#reex.regexp" title="Base class for regular expressions." alt="" coords="5,5,96,31"/>
<area shape="rect" id="node2" href="#reex.specialConstant" title="Base class for Epsilon and EmptySet" alt="" coords="144,5,288,31"/>
</map>
</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>sigma</strong> &#8211; </td>
</tr>
</tbody>
</table>
<dl class="method">
<dt id="reex.specialConstant.alphabeticLength">
<tt class="descname">alphabeticLength</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#specialConstant.alphabeticLength"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.specialConstant.alphabeticLength" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.specialConstant.derivative">
<tt class="descname">derivative</tt><big>(</big><em>sigma</em><big>)</big><a class="reference internal" href="_modules/reex.html#specialConstant.derivative"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.specialConstant.derivative" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>sigma</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.specialConstant.first">
<tt class="descname">first</tt><big>(</big><em>parent_first=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#specialConstant.first"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.specialConstant.first" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>parent_first</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.specialConstant.followLists">
<tt class="descname">followLists</tt><big>(</big><em>lists=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#specialConstant.followLists"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.specialConstant.followLists" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>lists</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.specialConstant.followListsD">
<tt class="descname">followListsD</tt><big>(</big><em>lists=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#specialConstant.followListsD"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.specialConstant.followListsD" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>lists</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.specialConstant.followListsStar">
<tt class="descname">followListsStar</tt><big>(</big><em>lists=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#specialConstant.followListsStar"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.specialConstant.followListsStar" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>lists</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.specialConstant.last">
<tt class="descname">last</tt><big>(</big><em>parent_last=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#specialConstant.last"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.specialConstant.last" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>parent_last</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.specialConstant.linearForm">
<tt class="descname">linearForm</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#specialConstant.linearForm"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.specialConstant.linearForm" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.specialConstant.reversal">
<tt class="descname">reversal</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#specialConstant.reversal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.specialConstant.reversal" title="Permalink to this definition">¶</a></dt>
<dd><p>Reversal of regexp</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">regexp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.specialConstant.setOfSymbols">
<tt class="descname">setOfSymbols</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#specialConstant.setOfSymbols"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.specialConstant.setOfSymbols" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.specialConstant.support">
<tt class="descname">support</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#specialConstant.support"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.specialConstant.support" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.specialConstant.unmarked">
<tt class="descname">unmarked</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#specialConstant.unmarked"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.specialConstant.unmarked" title="Permalink to this definition">¶</a></dt>
<dd><p>The unmarked form of the regular expression. Each leaf in its syntactical tree becomes a regexp(),
the epsilon() or the emptyset().</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">(general) regular expression</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.specialConstant.wordDerivative">
<tt class="descname">wordDerivative</tt><big>(</big><em>word</em><big>)</big><a class="reference internal" href="_modules/reex.html#specialConstant.wordDerivative"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.specialConstant.wordDerivative" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>word</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-epsilon">
<h3>Class epsilon<a class="headerlink" href="#class-epsilon" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="reex.epsilon">
<em class="property">class </em><tt class="descclassname">reex.</tt><tt class="descname">epsilon</tt><big>(</big><em>sigma=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#epsilon"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.epsilon" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#reex.specialConstant" title="reex.specialConstant"><tt class="xref py py-class docutils literal"><span class="pre">reex.specialConstant</span></tt></a></p>
<p>Class that represents the empty word.</p>
<p class="graphviz">
<img src="_images/inheritance-0335bb2d97153da4c05cd3b42e2997a16d0977da.png" alt="Inheritance diagram of epsilon" usemap="#inheritancee7a01cbf1d" class="inheritance"/>
<map id="inheritancee7a01cbf1d" name="inheritancee7a01cbf1d">
<area shape="rect" id="node1" href="#reex.epsilon" title="Class that represents the empty word." alt="" coords="336,5,428,31"/>
<area shape="rect" id="node2" href="#reex.specialConstant" title="Base class for Epsilon and EmptySet" alt="" coords="144,5,288,31"/>
<area shape="rect" id="node3" href="#reex.regexp" title="Base class for regular expressions." alt="" coords="5,5,96,31"/>
</map>
</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>sigma</strong> &#8211; </td>
</tr>
</tbody>
</table>
<dl class="method">
<dt id="reex.epsilon.epsilonLength">
<tt class="descname">epsilonLength</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#epsilon.epsilonLength"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.epsilon.epsilonLength" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">int</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.epsilon.epsilonP">
<tt class="descname">epsilonP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#epsilon.epsilonP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.epsilon.epsilonP" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.epsilon.ewp">
<tt class="descname">ewp</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#epsilon.ewp"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.epsilon.ewp" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.epsilon.measure">
<tt class="descname">measure</tt><big>(</big><em>from_parent=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#epsilon.measure"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.epsilon.measure" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>from_parent</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">measures</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.epsilon.nfaThompson">
<tt class="descname">nfaThompson</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#epsilon.nfaThompson"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.epsilon.nfaThompson" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.epsilon.partialDerivatives">
<tt class="descname">partialDerivatives</tt><big>(</big><em>sigma</em><big>)</big><a class="reference internal" href="_modules/reex.html#epsilon.partialDerivatives"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.epsilon.partialDerivatives" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>sigma</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.epsilon.rpn">
<tt class="descname">rpn</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#epsilon.rpn"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.epsilon.rpn" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">str</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.epsilon.snf">
<tt class="descname">snf</tt><big>(</big><em>_hollowdot=False</em><big>)</big><a class="reference internal" href="_modules/reex.html#epsilon.snf"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.epsilon.snf" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>_hollowdot</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-emptyset">
<h3>Class emptyset<a class="headerlink" href="#class-emptyset" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="reex.emptyset">
<em class="property">class </em><tt class="descclassname">reex.</tt><tt class="descname">emptyset</tt><big>(</big><em>sigma=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#emptyset"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.emptyset" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#reex.specialConstant" title="reex.specialConstant"><tt class="xref py py-class docutils literal"><span class="pre">reex.specialConstant</span></tt></a></p>
<p>Class that represents the empty set.</p>
<p class="graphviz">
<img src="_images/inheritance-4795b206b397f1d72204c4926f11254ec1d2633c.png" alt="Inheritance diagram of emptyset" usemap="#inheritancec66ba438b9" class="inheritance"/>
<map id="inheritancec66ba438b9" name="inheritancec66ba438b9">
<area shape="rect" id="node1" href="#reex.emptyset" title="Class that represents the empty set." alt="" coords="336,5,441,31"/>
<area shape="rect" id="node2" href="#reex.specialConstant" title="Base class for Epsilon and EmptySet" alt="" coords="144,5,288,31"/>
<area shape="rect" id="node3" href="#reex.regexp" title="Base class for regular expressions." alt="" coords="5,5,96,31"/>
</map>
</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>sigma</strong> &#8211; </td>
</tr>
</tbody>
</table>
<dl class="method">
<dt id="reex.emptyset.emptyP">
<tt class="descname">emptyP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#emptyset.emptyP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.emptyset.emptyP" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.emptyset.epsilonLength">
<tt class="descname">epsilonLength</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#emptyset.epsilonLength"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.emptyset.epsilonLength" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.emptyset.epsilonP">
<tt class="descname">epsilonP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#emptyset.epsilonP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.emptyset.epsilonP" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.emptyset.ewp">
<tt class="descname">ewp</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#emptyset.ewp"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.emptyset.ewp" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.emptyset.measure">
<tt class="descname">measure</tt><big>(</big><em>from_parent=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#emptyset.measure"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.emptyset.measure" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>from_parent</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="reex.emptyset.rpn">
<tt class="descname">rpn</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#emptyset.rpn"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.emptyset.rpn" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body"></td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-connective">
<h3>Class connective<a class="headerlink" href="#class-connective" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="reex.connective">
<em class="property">class </em><tt class="descclassname">reex.</tt><tt class="descname">connective</tt><big>(</big><em>arg1</em>, <em>arg2</em>, <em>sigma=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#connective"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.connective" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#reex.regexp" title="reex.regexp"><tt class="xref py py-class docutils literal"><span class="pre">reex.regexp</span></tt></a></p>
<p>Base class for concatenation, and disjunction operations.</p>
<p class="graphviz">
<img src="_images/inheritance-760467b3e582d8bef93ecc0a652964d23bdb125d.png" alt="Inheritance diagram of connective" usemap="#inheritancefdf8139b0b" class="inheritance"/>
<map id="inheritancefdf8139b0b" name="inheritancefdf8139b0b">
<area shape="rect" id="node1" href="#reex.connective" title="Base class for concatenation, and disjunction operations." alt="" coords="144,5,256,31"/>
<area shape="rect" id="node2" href="#reex.regexp" title="Base class for regular expressions." alt="" coords="5,5,96,31"/>
</map>
</p>
</dd></dl>

</div>
<div class="section" id="class-star">
<h3>Class star<a class="headerlink" href="#class-star" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="reex.star">
<em class="property">class </em><tt class="descclassname">reex.</tt><tt class="descname">star</tt><big>(</big><em>arg</em>, <em>sigma=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#star"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.star" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#reex.regexp" title="reex.regexp"><tt class="xref py py-class docutils literal"><span class="pre">reex.regexp</span></tt></a></p>
<p>Class for iteration operation (aka Kleene star, or Kleene closure) on regular expressions.</p>
<p class="graphviz">
<img src="_images/inheritance-19c9fc12356e83ed4e608cc2bd2829feed443c7e.png" alt="Inheritance diagram of star" usemap="#inheritance79c874b7ba" class="inheritance"/>
<map id="inheritance79c874b7ba" name="inheritance79c874b7ba">
<area shape="rect" id="node1" href="#reex.regexp" title="Base class for regular expressions." alt="" coords="5,5,96,31"/>
<area shape="rect" id="node2" href="#reex.star" title="Class for iteration operation (aka Kleene star, or Kleene closure) on regular expressions." alt="" coords="144,5,217,31"/>
</map>
</p>
<dl class="method">
<dt id="reex.star.nfaThompson">
<tt class="descname">nfaThompson</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#star.nfaThompson"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.star.nfaThompson" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns a NFA that accepts the RE.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
<p class="graphviz">
<img src="_images/graphviz-8bf4cfcd872749443a5d92bee869ea64e618c05b.png" alt="digraph foo {
 &quot;0&quot; -&gt; &quot;1&quot; [label=e];
 &quot;0&quot; -&gt; &quot;a&quot; [label=e];
 &quot;a&quot; -&gt; &quot;b&quot; [label=A];
 &quot;b&quot; -&gt; &quot;1&quot; [label=e];
 &quot;1&quot; -&gt; &quot;0&quot; [label=e];
 }" />
</p>
</dd></dl>

<dl class="method">
<dt id="reex.star.reversal">
<tt class="descname">reversal</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#star.reversal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.star.reversal" title="Permalink to this definition">¶</a></dt>
<dd><p>Reversal of regexp</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">regexp</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-concat">
<h3>Class concat<a class="headerlink" href="#class-concat" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="reex.concat">
<em class="property">class </em><tt class="descclassname">reex.</tt><tt class="descname">concat</tt><big>(</big><em>arg1</em>, <em>arg2</em>, <em>sigma=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#concat"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.concat" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#reex.connective" title="reex.connective"><tt class="xref py py-class docutils literal"><span class="pre">reex.connective</span></tt></a></p>
<p>Class for catenation operation on regular expressions.</p>
<p class="graphviz">
<img src="_images/inheritance-534a4189b2c5eb79d714442aa480675c1cb4f98e.png" alt="Inheritance diagram of concat" usemap="#inheritance8c374f0fd3" class="inheritance"/>
<map id="inheritance8c374f0fd3" name="inheritance8c374f0fd3">
<area shape="rect" id="node1" href="#reex.concat" title="Class for catenation operation on regular expressions." alt="" coords="304,5,395,31"/>
<area shape="rect" id="node2" href="#reex.connective" title="Base class for concatenation, and disjunction operations." alt="" coords="144,5,256,31"/>
<area shape="rect" id="node3" href="#reex.regexp" title="Base class for regular expressions." alt="" coords="5,5,96,31"/>
</map>
</p>
<dl class="method">
<dt id="reex.concat.reversal">
<tt class="descname">reversal</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#concat.reversal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.concat.reversal" title="Permalink to this definition">¶</a></dt>
<dd><p>Reversal of regexp
:rtype: regexp</p>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-disj">
<h3>Class disj<a class="headerlink" href="#class-disj" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="reex.disj">
<em class="property">class </em><tt class="descclassname">reex.</tt><tt class="descname">disj</tt><big>(</big><em>arg1</em>, <em>arg2</em>, <em>sigma=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#disj"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.disj" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#reex.connective" title="reex.connective"><tt class="xref py py-class docutils literal"><span class="pre">reex.connective</span></tt></a></p>
<p>Class for disjuction operation on regular expressions.</p>
<p class="graphviz">
<img src="_images/inheritance-cfb32986650c6aed99d18a2df82ddb79e484b3ed.png" alt="Inheritance diagram of disj" usemap="#inheritance0979a1098f" class="inheritance"/>
<map id="inheritance0979a1098f" name="inheritance0979a1098f">
<area shape="rect" id="node1" href="#reex.connective" title="Base class for concatenation, and disjunction operations." alt="" coords="144,5,256,31"/>
<area shape="rect" id="node3" href="#reex.disj" title="Class for disjuction operation on regular expressions." alt="" coords="304,5,376,31"/>
<area shape="rect" id="node2" href="#reex.regexp" title="Base class for regular expressions." alt="" coords="5,5,96,31"/>
</map>
</p>
<dl class="method">
<dt id="reex.disj.nfaThompson">
<tt class="descname">nfaThompson</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#disj.nfaThompson"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.disj.nfaThompson" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns an NFA (Thompson) that accepts the RE.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
<p class="graphviz">
<img src="_images/graphviz-ebe6bcf789cfde5084e76b3cd44e4cac5820b7e5.png" alt="digraph dij {
 &quot;0&quot; -&gt; &quot;si1&quot; [label=e];
 &quot;si1&quot; -&gt; &quot;sf1&quot; [label=&quot;arg1&quot;];
 &quot;sf1&quot; -&gt; &quot;1&quot; [label=e];
 &quot;0&quot; -&gt; &quot;si2&quot; [label=e];
 &quot;si2&quot; -&gt; &quot;sf2&quot; [label=&quot;arg2&quot;];
 &quot;sf2&quot; -&gt; &quot;1&quot; [label=e];
 }" />
</p>
</dd></dl>

<dl class="method">
<dt id="reex.disj.reversal">
<tt class="descname">reversal</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/reex.html#disj.reversal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.disj.reversal" title="Permalink to this definition">¶</a></dt>
<dd><p>Reversal of regexp
:rtype: regexp</p>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-position">
<h3>Class position<a class="headerlink" href="#class-position" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="reex.position">
<em class="property">class </em><tt class="descclassname">reex.</tt><tt class="descname">position</tt><big>(</big><em>(sym</em>, <em>pos)</em>, <em>sigma=None</em><big>)</big><a class="reference internal" href="_modules/reex.html#position"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.position" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#reex.regexp" title="reex.regexp"><tt class="xref py py-class docutils literal"><span class="pre">reex.regexp</span></tt></a></p>
<p>Class for marked regular expression symbols.</p>
<p class="graphviz">
<img src="_images/inheritance-713e962254f99ccfd8af278bd509fd85adcf2071.png" alt="Inheritance diagram of position" usemap="#inheritance47e9e010e5" class="inheritance"/>
<map id="inheritance47e9e010e5" name="inheritance47e9e010e5">
<area shape="rect" id="node1" href="#reex.position" title="Class for marked regular expression symbols." alt="" coords="144,5,240,31"/>
<area shape="rect" id="node2" href="#reex.regexp" title="Base class for regular expressions." alt="" coords="5,5,96,31"/>
</map>
</p>
</dd></dl>

</div>
<div class="section" id="class-parsereg">
<h3>Class ParseReg<a class="headerlink" href="#class-parsereg" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="reex.ParseReg">
<em class="property">class </em><tt class="descclassname">reex.</tt><tt class="descname">ParseReg</tt><big>(</big><em>no_table=0</em>, <em>table='tableambreg'</em><big>)</big><a class="reference internal" href="_modules/reex.html#ParseReg"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.ParseReg" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <tt class="xref py py-class docutils literal"><span class="pre">reex.ParseReg1</span></tt></p>
<p class="graphviz">
<img src="_images/inheritance-ac98d9fdf09382da8c7b7246c0e6d5f8a797dda6.png" alt="Inheritance diagram of ParseReg" usemap="#inheritancece2aca87ee" class="inheritance"/>
<map id="inheritancece2aca87ee" name="inheritancece2aca87ee">
<area shape="rect" id="node1" href="#reex.ParseReg" title=".. inheritance&#45;diagram:: ParseReg" alt="" coords="557,5,665,31"/>
<area shape="rect" id="node2" title=".. inheritance&#45;diagram:: ParseReg1" alt="" coords="395,5,509,31"/>
<area shape="rect" id="node3" title="A basic class for parsing." alt="" coords="208,5,347,31"/>
<area shape="rect" id="node4" title="Class for LR parser" alt="" coords="5,5,160,31"/>
</map>
</p>
<p>A parser for regular expressions with ambiguous rules: not working</p>
</dd></dl>

</div>
<div class="section" id="id2">
<h3>Functions<a class="headerlink" href="#id2" title="Permalink to this headline">¶</a></h3>
<dl class="function">
<dt id="reex.str2regexp">
<tt class="descclassname">reex.</tt><tt class="descname">str2regexp</tt><big>(</big><em>s</em>, <em>parser=&lt;class 'reex.ParseReg1'&gt;</em>, <em>no_table=1</em>, <em>sigma=None</em>, <em>strict=False</em><big>)</big><a class="reference internal" href="_modules/reex.html#str2regexp"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.str2regexp" title="Permalink to this definition">¶</a></dt>
<dd><p>Reads a regexp from string.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>s</strong> (<a class="reference external" href="http://docs.python.org/library/string.html#module-string" title="(in Python v2.7)"><em>string</em></a>) &#8211; the string representation of the regular expression</li>
<li><strong>parser</strong> (<em>Yappy</em>) &#8211; a parser generator for regexps</li>
<li><strong>no_table</strong> (<em>integer</em>) &#8211; </li>
<li><strong>sigma</strong> (<em>list or set of symbols</em>) &#8211; alphabet of the regular expression</li>
<li><strong>strict</strong> (<em>boolean</em>) &#8211; if True tests if the symbols of the regular expression are included in the sigma</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">regexp</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="reex.rpn2regexp">
<tt class="descclassname">reex.</tt><tt class="descname">rpn2regexp</tt><big>(</big><em>s</em>, <em>sigma=None</em>, <em>strict=False</em><big>)</big><a class="reference internal" href="_modules/reex.html#rpn2regexp"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#reex.rpn2regexp" title="Permalink to this definition">¶</a></dt>
<dd><p>Reads a regexp from a RPN representation</p>
<pre>
<strong id="grammar-token-R">R</strong> ::=  .RR | +RR | \*R | L | &#64;
<strong id="grammar-token-L">L</strong> ::=  [a-z] | [A-Z]
</pre>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>s</strong> (<a class="reference external" href="http://docs.python.org/library/string.html#module-string" title="(in Python v2.7)"><em>string</em></a>) &#8211; RPN representation</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">regexp</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">This method uses python stack... thus depdth limitations apply</p>
</div>
</dd></dl>

</div>
</div>
<div class="section" id="module-xre">
<span id="module-extended-regular-expressions-xre"></span><h2>Module: Extended Regular Expressions (<tt class="docutils literal"><span class="pre">xre</span></tt>)<a class="headerlink" href="#module-xre" title="Permalink to this headline">¶</a></h2>
<p><strong>Extended regular expressions manipulation</strong></p>
<p>Extended regular expression classes and its manipulation</p>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.8.</span></p>
</div>
<div class="section" id="class-xre-extended-regular-expression">
<h3>Class xre (extended regular expression)<a class="headerlink" href="#class-xre-extended-regular-expression" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="xre.xre">
<em class="property">class </em><tt class="descclassname">xre.</tt><tt class="descname">xre</tt><big>(</big><em>val</em>, <em>sigma=None</em><big>)</big><a class="reference internal" href="_modules/xre.html#xre"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#xre.xre" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#reex.regexp" title="reex.regexp"><tt class="xref py py-class docutils literal"><span class="pre">reex.regexp</span></tt></a></p>
<p>Base class for extended regular expressions, used directly to represent a symbol.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Variables:</th><td class="field-body"><strong>val</strong> &#8211; the actual symbol</td>
</tr>
</tbody>
</table>
<p>Constructor of a regular expression symbol.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>val</strong> &#8211; the actual symbol</td>
</tr>
</tbody>
</table>
<dl class="method">
<dt id="xre.xre.PD">
<tt class="descname">PD</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/xre.html#xre.PD"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#xre.xre.PD" title="Permalink to this definition">¶</a></dt>
<dd><p>Closure of partial derivatives of the regular expression in relation to all words.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">set of regular expressions</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">set</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="xre.xre.compare">
<tt class="descname">compare</tt><big>(</big><em>r</em>, <em>cmp_method='equivP'</em>, <em>nfa_method=None</em><big>)</big><a class="reference internal" href="_modules/xre.html#xre.compare"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#xre.xre.compare" title="Permalink to this definition">¶</a></dt>
<dd><p>Compare with another regular expression for equivalence.
:param r:
:param cmp_method:
:param nfa_method:</p>
</dd></dl>

<dl class="method">
<dt id="xre.xre.concatenation">
<tt class="descname">concatenation</tt><big>(</big><em>r</em><big>)</big><a class="reference internal" href="_modules/xre.html#xre.concatenation"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#xre.xre.concatenation" title="Permalink to this definition">¶</a></dt>
<dd><p>Computes the concatenation of two regular expressions.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>r</strong> (<a class="reference internal" href="#module-xre" title="xre"><em>xre</em></a>) &#8211; a regular expression</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">xre</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="xre.xre.derivative">
<tt class="descname">derivative</tt><big>(</big><em>sigma</em><big>)</big><a class="reference internal" href="_modules/xre.html#xre.derivative"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#xre.xre.derivative" title="Permalink to this definition">¶</a></dt>
<dd><p>Derivative of the regular expression in relation to the given symbol.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>sigma</strong> &#8211; an arbitrary symbol.</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">regular expression</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">whether the symbols belong to the expression&#8217;s alphabet goes unchecked. The given symbol will be
matched against the string representation of the regular expression&#8217;s symbol.</p>
</div>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<ol class="last upperalpha simple" start="10">
<li><ol class="first upperalpha">
<li>Brzozowski, Derivatives of Regular Expressions. J. ACM 11(4): 481-494 (1964)</li>
</ol>
</li>
</ol>
</div>
</dd></dl>

<dl class="method">
<dt id="xre.xre.dfaDerivatives">
<tt class="descname">dfaDerivatives</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/xre.html#xre.dfaDerivatives"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#xre.xre.dfaDerivatives" title="Permalink to this definition">¶</a></dt>
<dd><p>Word derivatives automaton of the regular expression</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">word derivatives automaton</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<ol class="last upperalpha simple" start="10">
<li><ol class="first upperalpha">
<li>Brzozowski, Derivatives of Regular Expressions. J. ACM 11(4): 481-494 (1964)</li>
</ol>
</li>
</ol>
</div>
</dd></dl>

<dl class="method">
<dt id="xre.xre.dfs">
<tt class="descname">dfs</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/xre.html#xre.dfs"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#xre.xre.dfs" title="Permalink to this definition">¶</a></dt>
<dd><p>Minimal DFA of an extended regular expression 
:return: minimal DFA
:rtype: DFA</p>
</dd></dl>

<dl class="method">
<dt id="xre.xre.equivP">
<tt class="descname">equivP</tt><big>(</big><em>reg</em><big>)</big><a class="reference internal" href="_modules/xre.html#xre.equivP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#xre.xre.equivP" title="Permalink to this definition">¶</a></dt>
<dd><p>Verifies if two regular expressions are equivalent.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>reg</strong> &#8211; regular expression</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="xre.xre.intersection">
<tt class="descname">intersection</tt><big>(</big><em>sx</em><big>)</big><a class="reference internal" href="_modules/xre.html#xre.intersection"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#xre.xre.intersection" title="Permalink to this definition">¶</a></dt>
<dd><p>Computes the intersection of two regular expressions.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>sx</strong> (<a class="reference internal" href="#module-xre" title="xre"><em>xre</em></a>) &#8211; a regular expression</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">xre</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="xre.xre.linearForm">
<tt class="descname">linearForm</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/xre.html#xre.linearForm"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#xre.xre.linearForm" title="Permalink to this definition">¶</a></dt>
<dd><dl class="docutils">
<dt>Linear form of the extended regular expression , as a mapping from heads to sets of tails,</dt>
<dd>so that each pair (head,tail) is a monomial in the set of linear forms.</dd>
</dl>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">dictionary mapping heads to sets of tails</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">{symbol: set([regular expressions])}</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Antimirov, 95</p>
</div>
</dd></dl>

<dl class="method">
<dt id="xre.xre.nfaPD">
<tt class="descname">nfaPD</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/xre.html#xre.nfaPD"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#xre.xre.nfaPD" title="Permalink to this definition">¶</a></dt>
<dd><dl class="docutils">
<dt>NFA that accepts the regular expression&#8217;s language, and which is constructed from the expression&#8217;s partial</dt>
<dd>derivatives.</dd>
</dl>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">partial derivatives [or equation] automaton</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">V. M. Antimirov, Partial Derivatives of Regular Expressions and Finite Automaton Constructions.
Theor. Comput. Sci.155(2): 291-319 (1996)</p>
</div>
<p>..attention why different from reex.nfaPD</p>
</dd></dl>

<dl class="method">
<dt id="xre.xre.partialDerivativeC">
<tt class="descname">partialDerivativeC</tt><big>(</big><em>sigma</em><big>)</big><a class="reference internal" href="_modules/xre.html#xre.partialDerivativeC"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#xre.xre.partialDerivativeC" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>sigma</strong> &#8211; </td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">xre</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="xre.xre.support">
<tt class="descname">support</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/xre.html#xre.support"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#xre.xre.support" title="Permalink to this definition">¶</a></dt>
<dd><p>&#8216;Support of a regular expression.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">set of regular expressions</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">set</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Champarnaud, J.M., Ziadi, D.: From Mirkin&#8217;s prebases to Antimirov&#8217;s word partial derivative.
Fundam. Inform. 45(3), 195-205 (2001)</p>
</div>
</dd></dl>

<dl class="method">
<dt id="xre.xre.toDFA">
<tt class="descname">toDFA</tt><big>(</big><em>dfa_method='dfaDerivatives'</em><big>)</big><a class="reference internal" href="_modules/xre.html#xre.toDFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#xre.xre.toDFA" title="Permalink to this definition">¶</a></dt>
<dd><p>DFA that accepts the regular expression&#8217;s language.
:param dfa_method:</p>
</dd></dl>

<dl class="method">
<dt id="xre.xre.toNFA">
<tt class="descname">toNFA</tt><big>(</big><em>nfa_method='nfaPD'</em><big>)</big><a class="reference internal" href="_modules/xre.html#xre.toNFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#xre.xre.toNFA" title="Permalink to this definition">¶</a></dt>
<dd><p>NFA that accepts the regular expression&#8217;s language.
:param nfa_method:</p>
</dd></dl>

<dl class="method">
<dt id="xre.xre.unionSigma">
<tt class="descname">unionSigma</tt><big>(</big><em>reg</em><big>)</big><a class="reference internal" href="_modules/xre.html#xre.unionSigma"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#xre.xre.unionSigma" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns the union of two alphabets</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>reg</strong> &#8211; xre</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">set</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="id3">
<h3>Functions<a class="headerlink" href="#id3" title="Permalink to this headline">¶</a></h3>
<dl class="function">
<dt id="xre.to_x">
<tt class="descclassname">xre.</tt><tt class="descname">to_x</tt><big>(</big><em>reg</em><big>)</big><a class="reference internal" href="_modules/xre.html#to_x"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#xre.to_x" title="Permalink to this definition">¶</a></dt>
<dd><p>Reads xre from FAdo regexp.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>reg</strong> (<em>regexp</em>) &#8211; </li>
<li><strong>re</strong> &#8211; the FAdo representation regexp for a regular expression.</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">xre</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

</div>
</div>
<div class="section" id="module-transducers">
<span id="module-transducers-transducers"></span><h2>Module: Transducers (<tt class="docutils literal"><span class="pre">transducers</span></tt>)<a class="headerlink" href="#module-transducers" title="Permalink to this headline">¶</a></h2>
<p><strong>Finite Tranducer Support</strong></p>
<p>Transducer manipulation.</p>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.0.</span></p>
</div>
<div class="section" id="class-transducer">
<h3>Class Transducer<a class="headerlink" href="#class-transducer" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="transducers.Transducer">
<em class="property">class </em><tt class="descclassname">transducers.</tt><tt class="descname">Transducer</tt><a class="reference internal" href="_modules/transducers.html#Transducer"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.Transducer" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#fa.NFA" title="fa.NFA"><tt class="xref py py-class docutils literal"><span class="pre">fa.NFA</span></tt></a></p>
<p>Base class for Transducers</p>
<p class="graphviz">
<img src="_images/inheritance-d52153dcdf31596ffccaee0a90810e9dd8cbc3de.png" alt="Inheritance diagram of Transducer" usemap="#inheritance9679772fb5" class="inheritance"/>
<map id="inheritance9679772fb5" name="inheritance9679772fb5">
<area shape="rect" id="node1" title="Any FAdo object that is drawable" alt="" coords="5,5,135,31"/>
<area shape="rect" id="node2" href="#fa.FA" title="Base class for Finite Automata." alt="" coords="183,5,255,31"/>
<area shape="rect" id="node4" href="#fa.OFA" title="Base class for one&#45;way automata" alt="" coords="303,5,375,31"/>
<area shape="rect" id="node3" href="#fa.NFA" title="Class for Non&#45;deterministic Finite Automata (epsilon&#45;transitions allowed)." alt="" coords="423,5,495,31"/>
<area shape="rect" id="node5" href="#transducers.Transducer" title="Base class for Transducers" alt="" coords="543,5,701,31"/>
</map>
</p>
<dl class="method">
<dt id="transducers.Transducer.setOutput">
<tt class="descname">setOutput</tt><big>(</big><em>listOfSymbols</em><big>)</big><a class="reference internal" href="_modules/transducers.html#Transducer.setOutput"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.Transducer.setOutput" title="Permalink to this definition">¶</a></dt>
<dd><p>Set Output</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>listOfSymbols</strong> (<em>set|list</em>) &#8211; output symbols</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.Transducer.succintTransitions">
<tt class="descname">succintTransitions</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#Transducer.succintTransitions"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.Transducer.succintTransitions" title="Permalink to this definition">¶</a></dt>
<dd><p>Collects the transition information in a concat way suitable for graphical representation.
:rtype: list of tupples</p>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-sft-standard-form-transducers">
<h3>Class SFT (Standard Form Transducers)<a class="headerlink" href="#class-sft-standard-form-transducers" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="transducers.SFT">
<em class="property">class </em><tt class="descclassname">transducers.</tt><tt class="descname">SFT</tt><a class="reference internal" href="_modules/transducers.html#SFT"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <tt class="xref py py-class docutils literal"><span class="pre">transducers.GFT</span></tt></p>
<p>Standard Form Tranducer</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Variables:</th><td class="field-body"><strong>Output</strong> (<a class="reference external" href="http://docs.python.org/library/stdtypes.html#set" title="(in Python v2.7)"><em>set</em></a>) &#8211; output alphabet</td>
</tr>
</tbody>
</table>
<p class="graphviz">
<img src="_images/inheritance-99df4ef24bac42b551409da4dbb071e17185a9ab.png" alt="Inheritance diagram of SFT" usemap="#inheritance20e4b2d00e" class="inheritance"/>
<map id="inheritance20e4b2d00e" name="inheritance20e4b2d00e">
<area shape="rect" id="node1" title="Any FAdo object that is drawable" alt="" coords="4,4,99,23"/>
<area shape="rect" id="node2" href="#fa.FA" title="Base class for Finite Automata." alt="" coords="135,4,188,23"/>
<area shape="rect" id="node4" href="#fa.OFA" title="Base class for one&#45;way automata" alt="" coords="224,4,277,23"/>
<area shape="rect" id="node3" href="#fa.NFA" title="Class for Non&#45;deterministic Finite Automata (epsilon&#45;transitions allowed)." alt="" coords="312,4,365,23"/>
<area shape="rect" id="node6" href="#transducers.Transducer" title="Base class for Transducers" alt="" coords="401,4,518,23"/>
<area shape="rect" id="node5" title="General Form Transducer" alt="" coords="553,4,641,23"/>
<area shape="rect" id="node7" href="#transducers.SFT" title="Standard Form Tranducer" alt="" coords="676,4,764,23"/>
</map>
</p>
<dl class="method">
<dt id="transducers.SFT.addEpsilonLoops">
<tt class="descname">addEpsilonLoops</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.addEpsilonLoops"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.addEpsilonLoops" title="Permalink to this definition">¶</a></dt>
<dd><p>Add a loop transition with epsilon input and output to every state in the transducer.</p>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.addOutput">
<tt class="descname">addOutput</tt><big>(</big><em>sym</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.addOutput"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.addOutput" title="Permalink to this definition">¶</a></dt>
<dd><p>Add a new symbol to the output alphabet</p>
<p>There is no problem with duplicate symbols because Output is a Set. No symbol Epsilon can be added</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>sym</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; symbol or regular expression to be added</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.addTransition">
<tt class="descname">addTransition</tt><big>(</big><em>stsrc</em>, <em>symi</em>, <em>symo</em>, <em>sti2</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.addTransition"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.addTransition" title="Permalink to this definition">¶</a></dt>
<dd><p>Adds a new transition</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>stsrc</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of departure</li>
<li><strong>sti2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of arrival</li>
<li><strong>symi</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; symbol consumed</li>
<li><strong>symo</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; symbol output</li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.addTransitionQ">
<tt class="descname">addTransitionQ</tt><big>(</big><em>src</em>, <em>dest</em>, <em>sym</em>, <em>out</em>, <em>futQ</em>, <em>pastQ</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.addTransitionQ"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.addTransitionQ" title="Permalink to this definition">¶</a></dt>
<dd><p>Add transition to the new transducer instance.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>src</strong> &#8211; source state</li>
<li><strong>dest</strong> &#8211; destination state</li>
<li><strong>sym</strong> &#8211; symbol</li>
<li><strong>out</strong> &#8211; output</li>
<li><strong>futQ</strong> (<a class="reference external" href="http://docs.python.org/library/stdtypes.html#set" title="(in Python v2.7)"><em>set</em></a>) &#8211; queue for later</li>
<li><strong>pastQ</strong> (<a class="reference external" href="http://docs.python.org/library/stdtypes.html#set" title="(in Python v2.7)"><em>set</em></a>) &#8211; past queue</li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.composition">
<tt class="descname">composition</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.composition"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.composition" title="Permalink to this definition">¶</a></dt>
<dd><p>Composition operation of a transducer with a transducer.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> (<em>SFT</em>) &#8211; the second transducer</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">SFT</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.concat">
<tt class="descname">concat</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.concat"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.concat" title="Permalink to this definition">¶</a></dt>
<dd><p>Concatenation of transducers</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> (<em>SFT</em>) &#8211; the other operand</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">SFT</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.delTransition">
<tt class="descname">delTransition</tt><big>(</big><em>sti1</em>, <em>sym</em>, <em>symo</em>, <em>sti2</em>, <em>_no_check=False</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.delTransition"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.delTransition" title="Permalink to this definition">¶</a></dt>
<dd><p>Remove a transition if existing and perform cleanup on the transition function&#8217;s internal data structure.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>symo</strong> &#8211; symbol output</li>
<li><strong>sti1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of departure</li>
<li><strong>sti2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state index of arrival</li>
<li><strong>sym</strong> &#8211; symbol consumed</li>
<li><strong>_no_check</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; dismiss secure code</li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.deleteState">
<tt class="descname">deleteState</tt><big>(</big><em>sti</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.deleteState"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.deleteState" title="Permalink to this definition">¶</a></dt>
<dd><p>Remove given state and transitions related with that state.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>sti</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; index of the state to be removed</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises DFAstateUnknown:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body">if state index does not exist</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.deleteStates">
<tt class="descname">deleteStates</tt><big>(</big><em>lstates</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.deleteStates"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.deleteStates" title="Permalink to this definition">¶</a></dt>
<dd><p>Delete given iterable collection of states from the automaton.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>lstates</strong> (<em>set|list</em>) &#8211; collection of int representing states</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.dup">
<tt class="descname">dup</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.dup"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.dup" title="Permalink to this definition">¶</a></dt>
<dd><p>Duplicate of itself
:rtype: SFT</p>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">only duplicates the initially connected component</p>
</div>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.emptyP">
<tt class="descname">emptyP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.emptyP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.emptyP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if the relation realized  the empty transducer</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.epsilonOutP">
<tt class="descname">epsilonOutP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.epsilonOutP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.epsilonOutP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if epsilon occurs in transition outputs</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.epsilonP">
<tt class="descname">epsilonP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.epsilonP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.epsilonP" title="Permalink to this definition">¶</a></dt>
<dd><p>Test whether this transducer has input epsilon-transitions</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.evalWordP">
<tt class="descname">evalWordP</tt><big>(</big><em>wp</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.evalWordP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.evalWordP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests whether the transducer returns the second word using the first one as input</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>wp</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#tuple" title="(in Python v2.7)"><em>tuple</em></a>) &#8211; pair of words</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.functionalP">
<tt class="descname">functionalP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.functionalP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.functionalP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if a  transducer is functional using Allauzer &amp; Mohri and Béal&amp;Carton&amp;Prieur&amp;Sakarovitch algorithms.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Cyril Allauzer and Mehryar Mohri, Journal of Automata Languages and Combinatorics,
Efficient Algorithms for Testing the Twins Property, 8(2): 117-144, 2003.</p>
</div>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">M.P. Béal, O. Carton, C. Prieur and J. Sakarovitch. Squaring transducers: An efficient
procedure for deciding functionality and sequentiality. Theoret. Computer Science 292:1 (2003), 45-63.</p>
</div>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">This is implemented using nonFunctionalW()</p>
</div>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.inIntersection">
<tt class="descname">inIntersection</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.inIntersection"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.inIntersection" title="Permalink to this definition">¶</a></dt>
<dd><p>Conjunction of transducer and automata: X &amp; Y.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> (<em>DFA|NFA</em>) &#8211; the automata needs to be operated.</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">SFT</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.inverse">
<tt class="descname">inverse</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.inverse"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.inverse" title="Permalink to this definition">¶</a></dt>
<dd><p>Switch the input label with the output label.</p>
<p>No initial or final state changed.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">Transducer with transitions switched.</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">SFT</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.nonEmptyW">
<tt class="descname">nonEmptyW</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.nonEmptyW"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.nonEmptyW" title="Permalink to this definition">¶</a></dt>
<dd><p>Witness of non emptyness</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">pair (in-word, out-word)</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">tuple</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.nonFunctionalW">
<tt class="descname">nonFunctionalW</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.nonFunctionalW"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.nonFunctionalW" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns a witness of non funcionality (if is that the case) or a None filled triple</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">witness</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">tuple</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.outIntersection">
<tt class="descname">outIntersection</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.outIntersection"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.outIntersection" title="Permalink to this definition">¶</a></dt>
<dd><p>Conjunction of transducer and automaton: X &amp; Y using output intersect operation.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> (<em>DFA|NFA</em>) &#8211; the automaton used as a filter of the output</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">SFT</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.outIntersectionDerived">
<tt class="descname">outIntersectionDerived</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.outIntersectionDerived"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.outIntersectionDerived" title="Permalink to this definition">¶</a></dt>
<dd><p>Naive version of outIntersection</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> (<em>DFA|NFA</em>) &#8211; the automaton used as a filter of the output</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">SFT</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.outputS">
<tt class="descname">outputS</tt><big>(</big><em>s</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.outputS"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.outputS" title="Permalink to this definition">¶</a></dt>
<dd><p>Output label coming out of the state i</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>s</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; index state</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">set</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.productInput">
<tt class="descname">productInput</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.productInput"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.productInput" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns a transducer (skeleton) resulting from the execution of the transducer with the automaton as
filter on the input.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> (<em>NFA</em>) &#8211; the automaton used as filter</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">SFT</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.reversal">
<tt class="descname">reversal</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.reversal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.reversal" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns a transducer that recognizes the reversal of the relation.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">Transducer recognizing reversal language</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">SFT</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.runOnNFA">
<tt class="descname">runOnNFA</tt><big>(</big><em>nfa</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.runOnNFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.runOnNFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Result of applying a transducer to an automaton</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>nfa</strong> (<em>DFA|NFA</em>) &#8211; input language to transducer</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">resulting language</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.runOnWord">
<tt class="descname">runOnWord</tt><big>(</big><em>word</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.runOnWord"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.runOnWord" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns the automaton accepting the outup of the transducer on the input word</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>word</strong> &#8211; the word</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.setInitial">
<tt class="descname">setInitial</tt><big>(</big><em>sts</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.setInitial"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.setInitial" title="Permalink to this definition">¶</a></dt>
<dd><p>Sets the initial state of a Transducer</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>sts</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#list" title="(in Python v2.7)"><em>list</em></a>) &#8211; list of states</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.square">
<tt class="descname">square</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.square"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.square" title="Permalink to this definition">¶</a></dt>
<dd><p>Conjunction of transducer with itself</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.square_fv">
<tt class="descname">square_fv</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.square_fv"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.square_fv" title="Permalink to this definition">¶</a></dt>
<dd><p>Conjunction of transducer with itself (Fast Version)</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.star">
<tt class="descname">star</tt><big>(</big><em>flag=False</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.star"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.star" title="Permalink to this definition">¶</a></dt>
<dd><p>Kleene star</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>flag</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; plus instead of star</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">the resulting Transducer</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">SFT</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.toInNFA">
<tt class="descname">toInNFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.toInNFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.toInNFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Delete the output labels in the transducer. Translate it into an NFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.toNFT">
<tt class="descname">toNFT</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.toNFT"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.toNFT" title="Permalink to this definition">¶</a></dt>
<dd><p>Transformation into Nomal Form Transducer</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">NFT</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.toOutNFA">
<tt class="descname">toOutNFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.toOutNFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.toOutNFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns the result of considering the output symbols of the transducer as input symbols of a NFA (ignoring
the input symbol, thus)</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the NFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">NFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.toSFT">
<tt class="descname">toSFT</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.toSFT"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.toSFT" title="Permalink to this definition">¶</a></dt>
<dd><p>Pacifying rule</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">SFT</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.trim">
<tt class="descname">trim</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.trim"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.trim" title="Permalink to this definition">¶</a></dt>
<dd><p>Remove states that do not lead to a final state, or, inclusively,
that can&#8217;t be reached from the initial state. Only useful states
remain.</p>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">in place transformation</p>
</div>
</dd></dl>

<dl class="method">
<dt id="transducers.SFT.union">
<tt class="descname">union</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/transducers.html#SFT.union"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#transducers.SFT.union" title="Permalink to this definition">¶</a></dt>
<dd><p>Union of the two transducers</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> (<em>SFT</em>) &#8211; the other operand</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">SFT</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="id4">
<h3>Functions<a class="headerlink" href="#id4" title="Permalink to this headline">¶</a></h3>
</div>
</div>
<div class="section" id="module-fl">
<span id="module-finite-languages-fl"></span><h2>Module: Finite Languages (<tt class="docutils literal"><span class="pre">fl</span></tt>)<a class="headerlink" href="#module-fl" title="Permalink to this headline">¶</a></h2>
<p>Finite languages and related automata manipulation</p>
<p>Finite languages manipulation</p>
<div class="section" id="class-fl-finite-language">
<h3>Class FL (Finite Language)<a class="headerlink" href="#class-fl-finite-language" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="fl.FL">
<em class="property">class </em><tt class="descclassname">fl.</tt><tt class="descname">FL</tt><big>(</big><em>wordsList=None</em>, <em>Sigma=set([])</em><big>)</big><a class="reference internal" href="_modules/fl.html#FL"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.FL" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference external" href="http://docs.python.org/library/functions.html#object" title="(in Python v2.7)"><tt class="xref py py-class docutils literal"><span class="pre">object</span></tt></a></p>
<p>Finite Language Class</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Variables:</th><td class="field-body"><ul class="first last simple">
<li><strong>Words</strong> &#8211; the elements of the language</li>
<li><strong>Sigma</strong> &#8211; the alphabet</li>
</ul>
</td>
</tr>
</tbody>
</table>
<dl class="method">
<dt id="fl.FL.addWords">
<tt class="descname">addWords</tt><big>(</big><em>wList</em><big>)</big><a class="reference internal" href="_modules/fl.html#FL.addWords"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.FL.addWords" title="Permalink to this definition">¶</a></dt>
<dd><p>Adds a list of words to a FL</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>wList</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#list" title="(in Python v2.7)"><em>list</em></a>) &#8211; words to add</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fl.FL.diff">
<tt class="descname">diff</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/fl.html#FL.diff"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.FL.diff" title="Permalink to this definition">¶</a></dt>
<dd><p>Difference of FL: a - b</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> (<a class="reference external" href="http://docs.python.org/library/fl.html#module-FL" title="(in Python v2.7)"><em>FL</em></a>) &#8211; right hand operand</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">FL</td>
</tr>
<tr class="field-odd field"><th class="field-name" colspan="2">Raises FAdoGeneralError:</th></tr>
<tr class="field-odd field"><td>&nbsp;</td><td class="field-body">if both arguments are not FL</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fl.FL.filter">
<tt class="descname">filter</tt><big>(</big><em>automata</em><big>)</big><a class="reference internal" href="_modules/fl.html#FL.filter"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.FL.filter" title="Permalink to this definition">¶</a></dt>
<dd><p>Separates a language in two other using a DFA of NFA as a filter</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>automata</strong> (<em>DFA|NFA</em>) &#8211; the automata to be used as a filter</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">the accepted/unaccepted pair of languages</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">tuple of FL</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fl.FL.intersection">
<tt class="descname">intersection</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/fl.html#FL.intersection"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.FL.intersection" title="Permalink to this definition">¶</a></dt>
<dd><p>Intersection of FL: a &amp; b</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> (<a class="reference external" href="http://docs.python.org/library/fl.html#module-FL" title="(in Python v2.7)"><em>FL</em></a>) &#8211; right hand operand</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises FAdoGeneralError:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body">if both arguments are not FL</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fl.FL.multiLineAutomaton">
<tt class="descname">multiLineAutomaton</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#FL.multiLineAutomaton"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.FL.multiLineAutomaton" title="Permalink to this definition">¶</a></dt>
<dd><p>Generates the trivial linear ANFA equivalent to this language</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">ANFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fl.FL.reunion">
<tt class="descname">reunion</tt><big>(</big><em>other</em><big>)</big><a class="reference internal" href="_modules/fl.html#FL.reunion"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.FL.reunion" title="Permalink to this definition">¶</a></dt>
<dd><p>Reunion of FL:   a | b</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>other</strong> (<a class="reference external" href="http://docs.python.org/library/fl.html#module-FL" title="(in Python v2.7)"><em>FL</em></a>) &#8211; right hand operand</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">FL</td>
</tr>
<tr class="field-odd field"><th class="field-name" colspan="2">Raises FAdoGeneralError:</th></tr>
<tr class="field-odd field"><td>&nbsp;</td><td class="field-body">if both arguments are not FL</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fl.FL.setSigma">
<tt class="descname">setSigma</tt><big>(</big><em>Sigma</em>, <em>Strict=False</em><big>)</big><a class="reference internal" href="_modules/fl.html#FL.setSigma"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.FL.setSigma" title="Permalink to this definition">¶</a></dt>
<dd><p>Sets the alphabet of a FL</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>Sigma</strong> (<a class="reference external" href="http://docs.python.org/library/stdtypes.html#set" title="(in Python v2.7)"><em>set</em></a>) &#8211; alphabet</li>
<li><strong>Strict</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; behaviour</li>
</ul>
</td>
</tr>
</tbody>
</table>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">Unless Strict flag is set to True, alphabet can only be enlarged.  The resulting alphabet is  in fact the
union of the former alphabet with the new one. If flag is set to True, the alphabet is simply replaced.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fl.FL.suffixClosedP">
<tt class="descname">suffixClosedP</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#FL.suffixClosedP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.FL.suffixClosedP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if a language is suffix closed</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fl.FL.toDFA">
<tt class="descname">toDFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#FL.toDFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.FL.toDFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Generates a DFA recognizing the language</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">ADFA</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.2.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fl.FL.toNFA">
<tt class="descname">toNFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#FL.toNFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.FL.toNFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Generates a NFA recognizing the language</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">ANFA</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.2.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fl.FL.trieFA">
<tt class="descname">trieFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#FL.trieFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.FL.trieFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Generates the trie automaton that recognises this language</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the trie automaton</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">ADFA</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-dcfa-deterministic-cover-finite-automata">
<h3>Class DCFA (Deterministic Cover Finite Automata)<a class="headerlink" href="#class-dcfa-deterministic-cover-finite-automata" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="fl.DCFA">
<em class="property">class </em><tt class="descclassname">fl.</tt><tt class="descname">DCFA</tt><a class="reference internal" href="_modules/fl.html#DCFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.DCFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#fa.DFA" title="fa.DFA"><tt class="xref py py-class docutils literal"><span class="pre">fa.DFA</span></tt></a></p>
<p>Deterministic Cover Automata class</p>
<p class="graphviz">
<img src="_images/inheritance-fee23f48b0348380df619fbb3190cd180ac33648.png" alt="Inheritance diagram of DCFA" usemap="#inheritance41ed8070c4" class="inheritance"/>
<map id="inheritance41ed8070c4" name="inheritance41ed8070c4">
<area shape="rect" id="node1" title="Any FAdo object that is drawable" alt="" coords="5,5,135,31"/>
<area shape="rect" id="node4" href="#fa.FA" title="Base class for Finite Automata." alt="" coords="183,5,255,31"/>
<area shape="rect" id="node2" href="#fa.DFA" title="Class for Deterministic Finite Automata." alt="" coords="423,5,495,31"/>
<area shape="rect" id="node5" href="#fl.DCFA" title="Deterministic Cover Automata class" alt="" coords="543,5,615,31"/>
<area shape="rect" id="node3" href="#fa.OFA" title="Base class for one&#45;way automata" alt="" coords="303,5,375,31"/>
</map>
</p>
<dl class="attribute">
<dt id="fl.DCFA.length">
<tt class="descname">length</tt><a class="reference internal" href="_modules/fl.html#DCFA.length"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.DCFA.length" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">size of the longest word</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">int</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-afa-acyclic-finite-automata">
<h3>Class AFA (Acyclic Finite Automata)<a class="headerlink" href="#class-afa-acyclic-finite-automata" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="fl.AFA">
<em class="property">class </em><tt class="descclassname">fl.</tt><tt class="descname">AFA</tt><a class="reference internal" href="_modules/fl.html#AFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.AFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference external" href="http://docs.python.org/library/functions.html#object" title="(in Python v2.7)"><tt class="xref py py-class docutils literal"><span class="pre">object</span></tt></a></p>
<p>Base class for Acyclic Finite Automata</p>
<p class="graphviz">
<img src="_images/inheritance-a04e3b1eb773acca488e33de9c986cb962d5cb9a.png" alt="Inheritance diagram of AFA" usemap="#inheritance3f5d71ff35" class="inheritance"/>
<map id="inheritance3f5d71ff35" name="inheritance3f5d71ff35">
<area shape="rect" id="node1" href="#fl.AFA" title="Base class for Acyclic Finite Automata" alt="" coords="5,5,77,31"/>
</map>
</p>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">This is just a container for some common methods. <strong>Not to be used directly!!</strong></p>
</div>
<dl class="method">
<dt id="fl.AFA.addState">
<tt class="descname">addState</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#AFA.addState"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.AFA.addState" title="Permalink to this definition">¶</a></dt>
<dd><table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">int</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fl.AFA.directRank">
<tt class="descname">directRank</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#AFA.directRank"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.AFA.directRank" title="Permalink to this definition">¶</a></dt>
<dd><p>Compute rank function</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">ranf map</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">dict</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fl.AFA.ensureDead">
<tt class="descname">ensureDead</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#AFA.ensureDead"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.AFA.ensureDead" title="Permalink to this definition">¶</a></dt>
<dd><p>Ensures that a state is defined as dead</p>
</dd></dl>

<dl class="method">
<dt id="fl.AFA.evalRank">
<tt class="descname">evalRank</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#AFA.evalRank"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.AFA.evalRank" title="Permalink to this definition">¶</a></dt>
<dd><p>Evaluates the rank map of a automaton</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">pair of sets of states by rank map, reverse delta accessability map</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">tuple</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fl.AFA.getLeaves">
<tt class="descname">getLeaves</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#AFA.getLeaves"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.AFA.getLeaves" title="Permalink to this definition">¶</a></dt>
<dd><p>The set of leaves, i.e. final states for last symbols of language words</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">set of leaves</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">set</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fl.AFA.ordered">
<tt class="descname">ordered</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#AFA.ordered"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.AFA.ordered" title="Permalink to this definition">¶</a></dt>
<dd><p>Orders states names in its topological order</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">ordered list of state indexes</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">list of int</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">one could use the FA.toposort() method, but special care must be taken with the dead state for the
algorithms related with cover automata.</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fl.AFA.setDeadState">
<tt class="descname">setDeadState</tt><big>(</big><em>sti</em><big>)</big><a class="reference internal" href="_modules/fl.html#AFA.setDeadState"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.AFA.setDeadState" title="Permalink to this definition">¶</a></dt>
<dd><p>Identifies the dead state</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>sti</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; index of the dead state</td>
</tr>
</tbody>
</table>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">nothing is done to ensure that the state given is legitimate</p>
</div>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">without dead state identified, most of the methods for acyclic automata can not be applied</p>
</div>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-adfa-acyclic-deterministic-finite-automata">
<h3>Class ADFA (Acyclic Deterministic Finite Automata)<a class="headerlink" href="#class-adfa-acyclic-deterministic-finite-automata" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="fl.ADFA">
<em class="property">class </em><tt class="descclassname">fl.</tt><tt class="descname">ADFA</tt><a class="reference internal" href="_modules/fl.html#ADFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.ADFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#fa.DFA" title="fa.DFA"><tt class="xref py py-class docutils literal"><span class="pre">fa.DFA</span></tt></a>, <a class="reference internal" href="#fl.AFA" title="fl.AFA"><tt class="xref py py-class docutils literal"><span class="pre">fl.AFA</span></tt></a></p>
<p>Acyclic Deterministic Finite Automata class</p>
<p class="graphviz">
<img src="_images/inheritance-b31093e295b640926a533bb8aa862f6836c95fbb.png" alt="Inheritance diagram of ADFA" usemap="#inheritance390c137a9f" class="inheritance"/>
<map id="inheritance390c137a9f" name="inheritance390c137a9f">
<area shape="rect" id="node1" title="Any FAdo object that is drawable" alt="" coords="5,5,135,31"/>
<area shape="rect" id="node4" href="#fa.FA" title="Base class for Finite Automata." alt="" coords="183,5,255,31"/>
<area shape="rect" id="node2" href="#fa.DFA" title="Class for Deterministic Finite Automata." alt="" coords="423,5,495,31"/>
<area shape="rect" id="node5" href="#fl.ADFA" title="Acyclic Deterministic Finite Automata class" alt="" coords="543,31,615,56"/>
<area shape="rect" id="node3" href="#fa.OFA" title="Base class for one&#45;way automata" alt="" coords="303,5,375,31"/>
<area shape="rect" id="node6" href="#fl.AFA" title="Base class for Acyclic Finite Automata" alt="" coords="423,55,495,80"/>
</map>
</p>
<dl class="method">
<dt id="fl.ADFA.complete">
<tt class="descname">complete</tt><big>(</big><em>dead=None</em><big>)</big><a class="reference internal" href="_modules/fl.html#ADFA.complete"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.ADFA.complete" title="Permalink to this definition">¶</a></dt>
<dd><p>Make the ADFA complete</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>dead</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; a state to be identified as dead state if one was not identified yet</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">ADFA</td>
</tr>
</tbody>
</table>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">The object is modified in place</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fl.ADFA.dup">
<tt class="descname">dup</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#ADFA.dup"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.ADFA.dup" title="Permalink to this definition">¶</a></dt>
<dd><p>Duplicate the basic structure into a new ADFA. Basically a copy.deep.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">ADFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fl.ADFA.forceToDCFA">
<tt class="descname">forceToDCFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#ADFA.forceToDCFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.ADFA.forceToDCFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Conversion to DCFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fl.ADFA.level">
<tt class="descname">level</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#ADFA.level"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.ADFA.level" title="Permalink to this definition">¶</a></dt>
<dd><p>Computes the level  for each state</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">levels of states</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">dict</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.8.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fl.ADFA.minDFCA">
<tt class="descname">minDFCA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#ADFA.minDFCA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.ADFA.minDFCA" title="Permalink to this definition">¶</a></dt>
<dd><p>Generates a minimal deterministic cover automata from a DFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">DCFA</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.8.</span></p>
</div>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Cezar Campeanu, Andrei Päun, and Sheng Yu, An efficient algorithm for constructing minimal cover
automata for finite languages, IJFCS</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fl.ADFA.minimal">
<tt class="descname">minimal</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#ADFA.minimal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.ADFA.minimal" title="Permalink to this definition">¶</a></dt>
<dd><p>Finds the minimal equivalent ADFA</p>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">[TCS 92 pp 181-189] Minimisation of acyclic deterministic automata in linear time, Dominique Revuz</p>
</div>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the minimal equivalent ADFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">ADFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fl.ADFA.minimalP">
<tt class="descname">minimalP</tt><big>(</big><em>method=None</em><big>)</big><a class="reference internal" href="_modules/fl.html#ADFA.minimalP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.ADFA.minimalP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if the DFA is minimal</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>method</strong> &#8211; minimization algorithm (here void)</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fl.ADFA.toANFA">
<tt class="descname">toANFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#ADFA.toANFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.ADFA.toANFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Converts the ADFA in a equivalent ANFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">ANFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="fl.ADFA.toNFA">
<tt class="descname">toNFA</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#ADFA.toNFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.ADFA.toNFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Converts the ADFA in a equivalent NFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">ANFA</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.2.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="fl.ADFA.trim">
<tt class="descname">trim</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#ADFA.trim"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.ADFA.trim" title="Permalink to this definition">¶</a></dt>
<dd><p>Remove states that do not lead to a final state, or, inclusively, that can&#8217;t be reached from the initial
state. Only useful states remain.</p>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">in place transformation</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fl.ADFA.wordGenerator">
<tt class="descname">wordGenerator</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#ADFA.wordGenerator"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.ADFA.wordGenerator" title="Permalink to this definition">¶</a></dt>
<dd><p>Creates a random word generator</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the random word generator</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">RndWGen</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.2.</span></p>
</div>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-anfa-acyclic-non-deterministic-finite-automata">
<h3>Class ANFA (Acyclic Non-deterministic Finite Automata)<a class="headerlink" href="#class-anfa-acyclic-non-deterministic-finite-automata" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="fl.ANFA">
<em class="property">class </em><tt class="descclassname">fl.</tt><tt class="descname">ANFA</tt><a class="reference internal" href="_modules/fl.html#ANFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.ANFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#fa.NFA" title="fa.NFA"><tt class="xref py py-class docutils literal"><span class="pre">fa.NFA</span></tt></a>, <a class="reference internal" href="#fl.AFA" title="fl.AFA"><tt class="xref py py-class docutils literal"><span class="pre">fl.AFA</span></tt></a></p>
<p>Acyclic Nondeterministic Finite Automata class</p>
<p class="graphviz">
<img src="_images/inheritance-40762411ce7afdcd4069f258d13e9c183d9b35d4.png" alt="Inheritance diagram of ANFA" usemap="#inheritance8ef0d3df44" class="inheritance"/>
<map id="inheritance8ef0d3df44" name="inheritance8ef0d3df44">
<area shape="rect" id="node1" title="Any FAdo object that is drawable" alt="" coords="5,5,135,31"/>
<area shape="rect" id="node2" href="#fa.FA" title="Base class for Finite Automata." alt="" coords="183,5,255,31"/>
<area shape="rect" id="node4" href="#fa.OFA" title="Base class for one&#45;way automata" alt="" coords="303,5,375,31"/>
<area shape="rect" id="node3" href="#fa.NFA" title="Class for Non&#45;deterministic Finite Automata (epsilon&#45;transitions allowed)." alt="" coords="423,5,495,31"/>
<area shape="rect" id="node6" href="#fl.ANFA" title="Acyclic Nondeterministic Finite Automata class" alt="" coords="543,31,615,56"/>
<area shape="rect" id="node5" href="#fl.AFA" title="Base class for Acyclic Finite Automata" alt="" coords="423,55,495,80"/>
</map>
</p>
<dl class="method">
<dt id="fl.ANFA.mergeInitial">
<tt class="descname">mergeInitial</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#ANFA.mergeInitial"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.ANFA.mergeInitial" title="Permalink to this definition">¶</a></dt>
<dd><p>Merge initial states</p>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">object is modified in place</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fl.ANFA.mergeLeaves">
<tt class="descname">mergeLeaves</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#ANFA.mergeLeaves"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.ANFA.mergeLeaves" title="Permalink to this definition">¶</a></dt>
<dd><p>Merge leaves</p>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">object is modified in place</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fl.ANFA.mergeStates">
<tt class="descname">mergeStates</tt><big>(</big><em>s1</em>, <em>s2</em><big>)</big><a class="reference internal" href="_modules/fl.html#ANFA.mergeStates"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.ANFA.mergeStates" title="Permalink to this definition">¶</a></dt>
<dd><p>Merge state s2 into state s1</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>s1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state</li>
<li><strong>s2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; state</li>
</ul>
</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">no attempt is made to check if the merging preserves the language of teh automaton</p>
</div>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">the object is modified in place</p>
</div>
</dd></dl>

<dl class="method">
<dt id="fl.ANFA.moveFinal">
<tt class="descname">moveFinal</tt><big>(</big><em>st</em>, <em>stf</em><big>)</big><a class="reference internal" href="_modules/fl.html#ANFA.moveFinal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.ANFA.moveFinal" title="Permalink to this definition">¶</a></dt>
<dd><p>Unsets a set as final transfering transition to another final
:param int st: the state to be &#8216;moved&#8217;
:param int stf: the destination final state</p>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">stf must be a &#8216;last&#8217; final state, i.e., must have no out transitions to anywhere but to a possible dead
state</p>
</div>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">the object is modified in place</p>
</div>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-rndwgen-random-word-generator">
<h3>Class RndWGen (Random Word Generator)<a class="headerlink" href="#class-rndwgen-random-word-generator" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="fl.RndWGen">
<em class="property">class </em><tt class="descclassname">fl.</tt><tt class="descname">RndWGen</tt><big>(</big><em>aut</em><big>)</big><a class="reference internal" href="_modules/fl.html#RndWGen"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.RndWGen" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference external" href="http://docs.python.org/library/functions.html#object" title="(in Python v2.7)"><tt class="xref py py-class docutils literal"><span class="pre">object</span></tt></a></p>
<p>Word random generator class</p>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.2.</span></p>
</div>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>aut</strong> (<em>ADFA</em>) &#8211; automata recognizing the language</td>
</tr>
</tbody>
</table>
<dl class="method">
<dt id="fl.RndWGen.next">
<tt class="descname">next</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/fl.html#RndWGen.next"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.RndWGen.next" title="Permalink to this definition">¶</a></dt>
<dd><p>Next word</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">a new random word</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="id5">
<h3>Functions<a class="headerlink" href="#id5" title="Permalink to this headline">¶</a></h3>
<dl class="function">
<dt id="fl.sigmaInitialSegment">
<tt class="descclassname">fl.</tt><tt class="descname">sigmaInitialSegment</tt><big>(</big><em>Sigma</em>, <em>l</em>, <em>exact=False</em><big>)</big><a class="reference internal" href="_modules/fl.html#sigmaInitialSegment"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.sigmaInitialSegment" title="Permalink to this definition">¶</a></dt>
<dd><p>Generates the ADFA recognizing Sigma^i for i&lt;=l
:param set Sigma: the alphabet
:param int l: length
:param bool exact: only the words with exactly that length?
:returns: the automaton
:rtype: ADFA</p>
</dd></dl>

<dl class="function">
<dt id="fl.genRndTrieBalanced">
<tt class="descclassname">fl.</tt><tt class="descname">genRndTrieBalanced</tt><big>(</big><em>maxL</em>, <em>Sigma</em>, <em>safe=True</em><big>)</big><a class="reference internal" href="_modules/fl.html#genRndTrieBalanced"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.genRndTrieBalanced" title="Permalink to this definition">¶</a></dt>
<dd><p>Generates a random trie automaton for a binary language of balanced words of a given leght for max word
:param int maxL: length of the max word
:param set Sigma: alphabet to be used
:param bool safe: should a word of size maxl be present in every language?
:return: the generated trie automaton
:rtype: ADFA</p>
</dd></dl>

<dl class="function">
<dt id="fl.genRndTrieUnbalanced">
<tt class="descclassname">fl.</tt><tt class="descname">genRndTrieUnbalanced</tt><big>(</big><em>maxL</em>, <em>Sigma</em>, <em>ratio</em>, <em>safe=True</em><big>)</big><a class="reference internal" href="_modules/fl.html#genRndTrieUnbalanced"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.genRndTrieUnbalanced" title="Permalink to this definition">¶</a></dt>
<dd><p>Generates a random trie automaton for a binary language of balanced words of a given length for max word</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>maxL</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; length of the max word</li>
<li><strong>Sigma</strong> (<a class="reference external" href="http://docs.python.org/library/stdtypes.html#set" title="(in Python v2.7)"><em>set</em></a>) &#8211; alphabet to be used</li>
<li><strong>ratio</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; the ratio of the unbalance</li>
<li><strong>safe</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; should a word of size maxl be present in every language?</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">the generated trie automaton</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">ADFA</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="fl.genRandomTrie">
<tt class="descclassname">fl.</tt><tt class="descname">genRandomTrie</tt><big>(</big><em>maxL</em>, <em>Sigma</em>, <em>safe=True</em><big>)</big><a class="reference internal" href="_modules/fl.html#genRandomTrie"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.genRandomTrie" title="Permalink to this definition">¶</a></dt>
<dd><p>Generates a random trie automaton for a finite language with a given length for max word
:param int maxL: length of the max word
:param set Sigma: alphabet to be used
:param bool safe: should a word of size maxl be present in every language?
:return: the generated trie automaton
:rtype: ADFA</p>
</dd></dl>

<dl class="function">
<dt id="fl.genRndTriePrefix">
<tt class="descclassname">fl.</tt><tt class="descname">genRndTriePrefix</tt><big>(</big><em>maxL</em>, <em>Sigma</em>, <em>ClosedP=False</em>, <em>safe=True</em><big>)</big><a class="reference internal" href="_modules/fl.html#genRndTriePrefix"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.genRndTriePrefix" title="Permalink to this definition">¶</a></dt>
<dd><p>Generates a random trie automaton for a finite (either prefix free or prefix closed) language with a given
length for max word
:param int maxL: length of the max word
:param set Sigma: alphabet to be used
:param bool ClosedP: should it be a prefix closed language?
:param bool safe: should a word of size maxl be present in every language?
:return: the generated trie automaton
:rtype: ADFA</p>
</dd></dl>

<dl class="function">
<dt id="fl.DFAtoADFA">
<tt class="descclassname">fl.</tt><tt class="descname">DFAtoADFA</tt><big>(</big><em>aut</em><big>)</big><a class="reference internal" href="_modules/fl.html#DFAtoADFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.DFAtoADFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Transforms an acyclic DFA into a ADFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>aut</strong> (<em>DFA</em>) &#8211; the automaton to be transformed</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises notAcyclic:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body">if the DFA is not acyclic</td>
</tr>
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">the converted automaton</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">ADFA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="fl.stringToADFA">
<tt class="descclassname">fl.</tt><tt class="descname">stringToADFA</tt><big>(</big><em>s</em><big>)</big><a class="reference internal" href="_modules/fl.html#stringToADFA"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#fl.stringToADFA" title="Permalink to this definition">¶</a></dt>
<dd><p>Convert a canonical string representation of a ADFA to a ADFA
:param list s: the string in its canonical order
:returns: the ADFA
:rtype: ADFA</p>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Marco Almeida, Nelma Moreira, and Rogério Reis. Exact generation of minimal acyclic deterministic finite
automata. International Journal of Foundations of Computer Science, 19(4):751-765, August 2008.</p>
</div>
</dd></dl>

</div>
</div>
<div class="section" id="module-graphs">
<span id="module-graphs-graph-creation-and-manipulation"></span><h2>Module: graphs (graph creation and manipulation)<a class="headerlink" href="#module-graphs" title="Permalink to this headline">¶</a></h2>
<p><strong>Graph support</strong></p>
<p>Basic Graph object support and manipulation</p>
<dl class="class">
<dt id="graphs.Graph">
<em class="property">class </em><tt class="descclassname">graphs.</tt><tt class="descname">Graph</tt><a class="reference internal" href="_modules/graphs.html#Graph"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#graphs.Graph" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <tt class="xref py py-class docutils literal"><span class="pre">common.Drawable</span></tt></p>
<p>Graph base class</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Variables:</th><td class="field-body"><ul class="first last simple">
<li><strong>Vertices</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#list" title="(in Python v2.7)"><em>list</em></a>) &#8211; Vertices&#8217; names</li>
<li><strong>Edges</strong> (<a class="reference external" href="http://docs.python.org/library/stdtypes.html#set" title="(in Python v2.7)"><em>set</em></a>) &#8211; set of pairs (always sorted)</li>
</ul>
</td>
</tr>
</tbody>
</table>
<p class="graphviz">
<img src="_images/inheritance-673bb257ad4e40f5d3103d2b55c9c9950321b7d3.png" alt="Inheritance diagram of Graph" usemap="#inheritance204b536329" class="inheritance"/>
<map id="inheritance204b536329" name="inheritance204b536329">
<area shape="rect" id="node1" title="Any FAdo object that is drawable" alt="" coords="5,5,135,31"/>
<area shape="rect" id="node2" href="#graphs.Graph" title="Graph base class" alt="" coords="183,5,283,31"/>
</map>
</p>
<dl class="method">
<dt id="graphs.Graph.addEdge">
<tt class="descname">addEdge</tt><big>(</big><em>v1</em>, <em>v2</em><big>)</big><a class="reference internal" href="_modules/graphs.html#Graph.addEdge"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#graphs.Graph.addEdge" title="Permalink to this definition">¶</a></dt>
<dd><p>Adds an edge
:param int v1: vertex 1 index
:param int v2: vertex 2 index
:raises GraphError: if edge is loop</p>
</dd></dl>

<dl class="method">
<dt id="graphs.Graph.addVertex">
<tt class="descname">addVertex</tt><big>(</big><em>vname</em><big>)</big><a class="reference internal" href="_modules/graphs.html#Graph.addVertex"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#graphs.Graph.addVertex" title="Permalink to this definition">¶</a></dt>
<dd><p>Adds a vertex (by name)</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>vname</strong> &#8211; vertex name</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">vertex index</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">int</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises DuplicateName:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body">if vname already exists</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="graphs.Graph.vertexIndex">
<tt class="descname">vertexIndex</tt><big>(</big><em>vname</em>, <em>autoCreate=False</em><big>)</big><a class="reference internal" href="_modules/graphs.html#Graph.vertexIndex"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#graphs.Graph.vertexIndex" title="Permalink to this definition">¶</a></dt>
<dd><p>Return vertex index</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>autoCreate</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; auto creation of non existing states</li>
<li><strong>vname</strong> &#8211; vertex name</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first">int</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name" colspan="2">Raises GraphError:</th></tr>
<tr class="field-odd field"><td>&nbsp;</td><td class="field-body"><p class="first last">if vname not found</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

<dl class="class">
<dt id="graphs.DiGraph">
<em class="property">class </em><tt class="descclassname">graphs.</tt><tt class="descname">DiGraph</tt><a class="reference internal" href="_modules/graphs.html#DiGraph"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#graphs.DiGraph" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#graphs.Graph" title="graphs.Graph"><tt class="xref py py-class docutils literal"><span class="pre">graphs.Graph</span></tt></a></p>
<p>Directed graph base class</p>
<p class="graphviz">
<img src="_images/inheritance-7cb76fb139015da68d0dc0d7bf1d260cd84855bf.png" alt="Inheritance diagram of DiGraph" usemap="#inheritancef387756b4f" class="inheritance"/>
<map id="inheritancef387756b4f" name="inheritancef387756b4f">
<area shape="rect" id="node1" title="Any FAdo object that is drawable" alt="" coords="5,5,135,31"/>
<area shape="rect" id="node3" href="#graphs.Graph" title="Graph base class" alt="" coords="183,5,283,31"/>
<area shape="rect" id="node2" href="#graphs.DiGraph" title="Directed graph base class" alt="" coords="331,5,443,31"/>
</map>
</p>
<dl class="method">
<dt id="graphs.DiGraph.addEdge">
<tt class="descname">addEdge</tt><big>(</big><em>v1</em>, <em>v2</em><big>)</big><a class="reference internal" href="_modules/graphs.html#DiGraph.addEdge"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#graphs.DiGraph.addEdge" title="Permalink to this definition">¶</a></dt>
<dd><p>Adds an edge</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>v1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; vertex 1 index</li>
<li><strong>v2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; vertex 2 index</li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="staticmethod">
<dt id="graphs.DiGraph.dotDrawEdge">
<em class="property">static </em><tt class="descname">dotDrawEdge</tt><big>(</big><em>st1</em>, <em>st2</em>, <em>sep='n'</em><big>)</big><a class="reference internal" href="_modules/graphs.html#DiGraph.dotDrawEdge"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#graphs.DiGraph.dotDrawEdge" title="Permalink to this definition">¶</a></dt>
<dd><p>Draw a transition in Dot Format</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>st1</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; starting state</li>
<li><strong>st2</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; ending state</li>
<li><strong>sep</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; separator</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">str</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="graphs.DiGraph.dotDrawVertex">
<tt class="descname">dotDrawVertex</tt><big>(</big><em>sti</em>, <em>sep='n'</em><big>)</big><a class="reference internal" href="_modules/graphs.html#DiGraph.dotDrawVertex"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#graphs.DiGraph.dotDrawVertex" title="Permalink to this definition">¶</a></dt>
<dd><p>Draw a Vertex in Dot Format</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>sti</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; index of the state</li>
<li><strong>sep</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; separator</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">str</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="graphs.DiGraph.dotFormat">
<tt class="descname">dotFormat</tt><big>(</big><em>size='20</em>, <em>20'</em>, <em>direction='LR'</em>, <em>sep='n'</em><big>)</big><a class="reference internal" href="_modules/graphs.html#DiGraph.dotFormat"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#graphs.DiGraph.dotFormat" title="Permalink to this definition">¶</a></dt>
<dd><p>A dot representation</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>direction</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; direction of drawing</li>
<li><strong>size</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; size of image</li>
<li><strong>sep</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; line separator</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">the dot representation</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">str</p>
</td>
</tr>
</tbody>
</table>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.6.</span></p>
</div>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 0.9.8.</span></p>
</div>
</dd></dl>

<dl class="method">
<dt id="graphs.DiGraph.inverse">
<tt class="descname">inverse</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/graphs.html#DiGraph.inverse"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#graphs.DiGraph.inverse" title="Permalink to this definition">¶</a></dt>
<dd><p>Inverse of a digraph</p>
</dd></dl>

</dd></dl>

<dl class="class">
<dt id="graphs.DiGraphVm">
<em class="property">class </em><tt class="descclassname">graphs.</tt><tt class="descname">DiGraphVm</tt><a class="reference internal" href="_modules/graphs.html#DiGraphVm"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#graphs.DiGraphVm" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#graphs.DiGraph" title="graphs.DiGraph"><tt class="xref py py-class docutils literal"><span class="pre">graphs.DiGraph</span></tt></a></p>
<p>Directed graph with marked vertices</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Variables:</th><td class="field-body"><strong>MarkedV</strong> (<a class="reference external" href="http://docs.python.org/library/stdtypes.html#set" title="(in Python v2.7)"><em>set</em></a>) &#8211; set of marked vertices</td>
</tr>
</tbody>
</table>
<p class="graphviz">
<img src="_images/inheritance-91738e37305c0cce889e895c4bc9b06b89eb73dc.png" alt="Inheritance diagram of DiGraphVm" usemap="#inheritance0cf104982c" class="inheritance"/>
<map id="inheritance0cf104982c" name="inheritance0cf104982c">
<area shape="rect" id="node1" title="Any FAdo object that is drawable" alt="" coords="5,5,135,31"/>
<area shape="rect" id="node3" href="#graphs.Graph" title="Graph base class" alt="" coords="183,5,283,31"/>
<area shape="rect" id="node2" href="#graphs.DiGraph" title="Directed graph base class" alt="" coords="331,5,443,31"/>
<area shape="rect" id="node4" href="#graphs.DiGraphVm" title="Directed graph with marked vertices" alt="" coords="491,5,623,31"/>
</map>
</p>
<dl class="method">
<dt id="graphs.DiGraphVm.markVertex">
<tt class="descname">markVertex</tt><big>(</big><em>v</em><big>)</big><a class="reference internal" href="_modules/graphs.html#DiGraphVm.markVertex"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#graphs.DiGraphVm.markVertex" title="Permalink to this definition">¶</a></dt>
<dd><p>Mark vertex v</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>v</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; vertex</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="module-cfg">
<span id="module-context-free-grammars-manipulation-cfg"></span><h2>Module: Context Free Grammars Manipulation (<tt class="docutils literal"><span class="pre">cfg</span></tt>)<a class="headerlink" href="#module-cfg" title="Permalink to this headline">¶</a></h2>
<p><strong>Context Free Grammars Manipulation.</strong></p>
<p>Basic context-free grammars manipulation for building uniform random generetors</p>
<div class="section" id="class-cfgrammar-context-free-grammar">
<h3>Class CFGrammar (Context Free Grammar)<a class="headerlink" href="#class-cfgrammar-context-free-grammar" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="cfg.CFGrammar">
<em class="property">class </em><tt class="descclassname">cfg.</tt><tt class="descname">CFGrammar</tt><big>(</big><em>gram</em><big>)</big><a class="reference internal" href="_modules/cfg.html#CFGrammar"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#cfg.CFGrammar" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference external" href="http://docs.python.org/library/functions.html#object" title="(in Python v2.7)"><tt class="xref py py-class docutils literal"><span class="pre">object</span></tt></a></p>
<p>Class for context-free grammars</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Variables:</th><td class="field-body"><ul class="first last simple">
<li><strong>Rules</strong> &#8211; grammar rules</li>
<li><strong>Terminals</strong> &#8211; terminals symbols</li>
<li><strong>Nonterminals</strong> &#8211; nonterminals symbols</li>
<li><strong>Start</strong> &#8211; start symbol</li>
<li><strong>ntr</strong> &#8211; dictionary of rules for each nonterminal</li>
</ul>
</td>
</tr>
</tbody>
</table>
<p>Initialization</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>gram</strong> &#8211; is a list for productions; each production is a tuple (LeftHandside, RightHandside) with
LeftHandside nonterminal, RightHandside list of symbols, First production is for start symbol</td>
</tr>
</tbody>
</table>
<dl class="method">
<dt id="cfg.CFGrammar.NULLABLE">
<tt class="descname">NULLABLE</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/cfg.html#CFGrammar.NULLABLE"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#cfg.CFGrammar.NULLABLE" title="Permalink to this definition">¶</a></dt>
<dd><p>Determines which nonterminals X -&gt;* []</p>
</dd></dl>

<dl class="method">
<dt id="cfg.CFGrammar.makenonterminals">
<tt class="descname">makenonterminals</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/cfg.html#CFGrammar.makenonterminals"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#cfg.CFGrammar.makenonterminals" title="Permalink to this definition">¶</a></dt>
<dd><p>Extracts C{nonterminals}  from grammar rules.</p>
</dd></dl>

<dl class="method">
<dt id="cfg.CFGrammar.maketerminals">
<tt class="descname">maketerminals</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/cfg.html#CFGrammar.maketerminals"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#cfg.CFGrammar.maketerminals" title="Permalink to this definition">¶</a></dt>
<dd><p>Extracts C{terminals} from the rules. Nonterminals must already exist</p>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-cnf">
<h3>Class CNF<a class="headerlink" href="#class-cnf" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="cfg.CNF">
<em class="property">class </em><tt class="descclassname">cfg.</tt><tt class="descname">CNF</tt><big>(</big><em>gram</em>, <em>mark='A&#64;'</em><big>)</big><a class="reference internal" href="_modules/cfg.html#CNF"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#cfg.CNF" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#cfg.CFGrammar" title="cfg.CFGrammar"><tt class="xref py py-class docutils literal"><span class="pre">cfg.CFGrammar</span></tt></a></p>
<p>No useless nonterminals or epsilon rules are ALLOWED... Given a CFG grammar description generates one in CNF
Then its possible to random generate words of a given size. Before some pre-calculations are nedded.</p>
<dl class="method">
<dt id="cfg.CNF.Chomsky">
<tt class="descname">Chomsky</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/cfg.html#CNF.Chomsky"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#cfg.CNF.Chomsky" title="Permalink to this definition">¶</a></dt>
<dd><p>Transform to CNF</p>
</dd></dl>

<dl class="method">
<dt id="cfg.CNF.elim_unitary">
<tt class="descname">elim_unitary</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/cfg.html#CNF.elim_unitary"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#cfg.CNF.elim_unitary" title="Permalink to this definition">¶</a></dt>
<dd><p>Elimination of unitary rules</p>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-cfggenerator">
<h3>Class cfgGenerator<a class="headerlink" href="#class-cfggenerator" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="cfg.cfgGenerator">
<em class="property">class </em><tt class="descclassname">cfg.</tt><tt class="descname">cfgGenerator</tt><big>(</big><em>cfgr</em>, <em>size</em><big>)</big><a class="reference internal" href="_modules/cfg.html#cfgGenerator"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#cfg.cfgGenerator" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference external" href="http://docs.python.org/library/functions.html#object" title="(in Python v2.7)"><tt class="xref py py-class docutils literal"><span class="pre">object</span></tt></a></p>
<p>CFG uniform genetaror</p>
<p>Object initialization
:param cfgr: grammar for the random objects
:type cfgr: CNF
:param size: size of objects
:type size: integer</p>
<dl class="method">
<dt id="cfg.cfgGenerator.generate">
<tt class="descname">generate</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/cfg.html#cfgGenerator.generate"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#cfg.cfgGenerator.generate" title="Permalink to this definition">¶</a></dt>
<dd><p>Generates a new random object generated from the start symbol</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">object</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">string</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-restringrgenerator-reg-exp-generator">
<h3>Class reStringRGenerator (Reg Exp Generator)<a class="headerlink" href="#class-restringrgenerator-reg-exp-generator" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="cfg.reStringRGenerator">
<em class="property">class </em><tt class="descclassname">cfg.</tt><tt class="descname">reStringRGenerator</tt><big>(</big><em>Sigma=['a', 'b'], size=10, cfgr=None, eps=None, empty=None, ident='Ti'</em><big>)</big><a class="reference internal" href="_modules/cfg.html#reStringRGenerator"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#cfg.reStringRGenerator" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#cfg.cfgGenerator" title="cfg.cfgGenerator"><tt class="xref py py-class docutils literal"><span class="pre">cfg.cfgGenerator</span></tt></a></p>
<p>Uniform random Generator for reStrings</p>
<p>Uniform random generator for regular expressions. Used without arguments generates an uncollapsible re
over {a,b} with size 10. For generate an arbitary re over an alphabet of 10 symbols of size 100:
reStringRGenerator (small_alphabet(10),100,reStringRGenerator.g_regular_base)</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>Sigma</strong> (<em>list or set</em>) &#8211; re alphabet (that will be the set of grammar terminals)</li>
<li><strong>size</strong> (<em>integer</em>) &#8211; word size</li>
<li><strong>cfgr</strong> &#8211; base grammar</li>
<li><strong>epsilon</strong> &#8211; if not None is added to a grammar terminals</li>
<li><strong>empty</strong> &#8211; if not None is added to a grammar terminals</li>
</ul>
</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">the grammar can have already this symbols</p>
</div>
<dl class="method">
<dt id="cfg.reStringRGenerator.generate">
<tt class="descname">generate</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/cfg.html#reStringRGenerator.generate"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#cfg.reStringRGenerator.generate" title="Permalink to this definition">¶</a></dt>
<dd><p>Generates a new random RE string</p>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="id6">
<h3>Functions<a class="headerlink" href="#id6" title="Permalink to this headline">¶</a></h3>
<dl class="function">
<dt id="cfg.gRules">
<tt class="descclassname">cfg.</tt><tt class="descname">gRules</tt><big>(</big><em>rules_list</em>, <em>rulesym='-&gt;'</em>, <em>rhssep=None</em>, <em>rulesep='|'</em><big>)</big><a class="reference internal" href="_modules/cfg.html#gRules"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#cfg.gRules" title="Permalink to this definition">¶</a></dt>
<dd><p>Transforms a list of rules into  a grammar description.</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>rules_list</strong> &#8211; is a list of rule where rule is a string  of the form: Word rulesym Word1 ... Word2 or  Word
rulesym []</li>
<li><strong>rulesym</strong> &#8211; LHS and RHS rule separator</li>
<li><strong>rhssep</strong> &#8211; RHS values separator (None for white chars)</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first last">a grammar description</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="cfg.smallAlphabet">
<tt class="descclassname">cfg.</tt><tt class="descname">smallAlphabet</tt><big>(</big><em>k</em>, <em>sigma_base='a'</em><big>)</big><a class="reference internal" href="_modules/cfg.html#smallAlphabet"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#cfg.smallAlphabet" title="Permalink to this definition">¶</a></dt>
<dd><p>Easy way to have small alphabets</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>k</strong> &#8211; alphabet size (must be less than 52)</li>
<li><strong>sigma_base</strong> &#8211; initial symbol</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">alphabet</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">list</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

</div>
</div>
<div class="section" id="module-rndfa">
<span id="module-random-dfa-generator-rndfa"></span><h2>Module: Random DFA Generator (<tt class="docutils literal"><span class="pre">rndfa</span></tt>)<a class="headerlink" href="#module-rndfa" title="Permalink to this headline">¶</a></h2>
<p><strong>Random DFA generation</strong></p>
<p>ICDFA Random generation binding</p>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 0.9.4: </span>Interface python to the C code</p>
</div>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 0.9.6: </span>Working with incomplete automata</p>
</div>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 0.9.8: </span>distinct classes for complete and incomplete ICDFA</p>
</div>
<div class="section" id="class-icdfargen-generator-container">
<h3>Class ICDFArgen (Generator container)<a class="headerlink" href="#class-icdfargen-generator-container" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="rndfa.ICDFArgen">
<em class="property">class </em><tt class="descclassname">rndfa.</tt><tt class="descname">ICDFArgen</tt><a class="reference internal" href="_modules/rndfa.html#ICDFArgen"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#rndfa.ICDFArgen" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference external" href="http://docs.python.org/library/functions.html#object" title="(in Python v2.7)"><tt class="xref py py-class docutils literal"><span class="pre">object</span></tt></a></p>
<p>Generic ICDFA random generator class</p>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Marco Almeida, Nelma Moreira, and Rogério Reis. Enumeration and generation with a string automata
representation. Theoretical Computer Science, 387(2):93-102, 2007</p>
</div>
<dl class="method">
<dt id="rndfa.ICDFArgen.next">
<tt class="descname">next</tt><big>(</big><big>)</big><a class="reference internal" href="_modules/rndfa.html#ICDFArgen.next"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#rndfa.ICDFArgen.next" title="Permalink to this definition">¶</a></dt>
<dd><p>Get the next generated DFA</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">a random generated ICDFA</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">DFA</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-icdfarnd-complete-icdfa-random-generator">
<h3>Class ICDFArnd (Complete ICDFA random generator)<a class="headerlink" href="#class-icdfarnd-complete-icdfa-random-generator" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="rndfa.ICDFArnd">
<em class="property">class </em><tt class="descclassname">rndfa.</tt><tt class="descname">ICDFArnd</tt><big>(</big><em>n</em>, <em>k</em><big>)</big><a class="reference internal" href="_modules/rndfa.html#ICDFArnd"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#rndfa.ICDFArnd" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#rndfa.ICDFArgen" title="rndfa.ICDFArgen"><tt class="xref py py-class docutils literal"><span class="pre">rndfa.ICDFArgen</span></tt></a></p>
<p>Complete ICDFA random generator class</p>
<p>This is the class for the uniform random generator for Initially Connected DFAs</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Variables:</th><td class="field-body"><ul class="first last simple">
<li><strong>n</strong> &#8211; number of states</li>
<li><strong>k</strong> &#8211; size of the alphabet</li>
</ul>
</td>
</tr>
</tbody>
</table>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p class="last">This is an abstract class, not to be used directly</p>
</div>
</dd></dl>

</div>
<div class="section" id="class-icdfarndincomple-incomplete-icdfa-generator">
<h3>Class ICDFArndIncomple (Incomplete ICDFA generator)<a class="headerlink" href="#class-icdfarndincomple-incomplete-icdfa-generator" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="rndfa.ICDFArndIncomplete">
<em class="property">class </em><tt class="descclassname">rndfa.</tt><tt class="descname">ICDFArndIncomplete</tt><big>(</big><em>n</em>, <em>k</em>, <em>bias=None</em><big>)</big><a class="reference internal" href="_modules/rndfa.html#ICDFArndIncomplete"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#rndfa.ICDFArndIncomplete" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#rndfa.ICDFArgen" title="rndfa.ICDFArgen"><tt class="xref py py-class docutils literal"><span class="pre">rndfa.ICDFArgen</span></tt></a></p>
<p>Incomplete ICDFA random generator class</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Variables:</th><td class="field-body"><ul class="first simple">
<li><strong>n</strong> &#8211; number of states</li>
<li><strong>k</strong> &#8211; size of alphabet</li>
<li><strong>bias</strong> &#8211; how often must the gost sink state appear (default None)</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">Raises IllegalBias:</th></tr>
<tr class="field-even field"><td>&nbsp;</td><td class="field-body"><p class="first last">if a bias &gt;=1 or &lt;=0 is provided</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

</div>
</div>
<div class="section" id="module-comboperations">
<span id="module-combo-operations-comboperations"></span><h2>Module: Combo Operations (<tt class="docutils literal"><span class="pre">comboperations</span></tt>)<a class="headerlink" href="#module-comboperations" title="Permalink to this headline">¶</a></h2>
<p><strong>Several combined operations for DFAs</strong></p>
<p>Deterministic and non-deterministic automata manipulation, conversion and evaluation.</p>
<p><em>Authors:</em> Rogério Reis &amp; Nelma Moreira</p>
<p><em>This is part of FAdo project</em>   <a class="reference external" href="http://fado.dcc.fc.up.pt">http://fado.dcc.fc.up.pt</a></p>
<p><em>Version:</em> 0.9.5</p>
<p><em>Copyright:</em> 1999-2012 Rogério Reis &amp; Nelma Moreira {rvr,nam}&#64;dcc.fc.up.pt</p>
<dl class="function">
<dt id="comboperations.starConcat">
<tt class="descclassname">comboperations.</tt><tt class="descname">starConcat</tt><big>(</big><em>fa1</em>, <em>fa2</em>, <em>strict=False</em><big>)</big><a class="reference internal" href="_modules/comboperations.html#starConcat"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#comboperations.starConcat" title="Permalink to this definition">¶</a></dt>
<dd><p>Star of concatenation of two languages: (L1.L2)*</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>fa1</strong> (<em>DFA</em>) &#8211; first automaton</li>
<li><strong>fa2</strong> (<em>DFA</em>) &#8211; second automaton</li>
<li><strong>strict</strong> (<em>Boolean</em>) &#8211; should the alphabets be necessary equal?</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">DFA</p>
</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Yuan Gao, Kai Salomaa, and Sheng Yu. &#8216;The state complexity of two combined operations: Star of catenation and
star of reversal&#8217;. Fundamenta Informaticae, 83:75–89, Jan 2008.</p>
</div>
</dd></dl>

<dl class="function">
<dt id="comboperations.concatWStar">
<tt class="descclassname">comboperations.</tt><tt class="descname">concatWStar</tt><big>(</big><em>fa1</em>, <em>fa2</em>, <em>strict=False</em><big>)</big><a class="reference internal" href="_modules/comboperations.html#concatWStar"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#comboperations.concatWStar" title="Permalink to this definition">¶</a></dt>
<dd><p>Concatenation combined with star: (L1.L2*)</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>fa1</strong> (<em>DFA</em>) &#8211; first automaton</li>
<li><strong>fa2</strong> (<em>DFA</em>) &#8211; second automaton</li>
<li><strong>strict</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#bool" title="(in Python v2.7)"><em>bool</em></a>) &#8211; should the alphabets be necessary equal?</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">DFA</p>
</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Bo Cui, Yuan Gao, Lila Kari, and Sheng Yu. &#8216;State complexity of two combined operations: Reversal-catenation
and star-catenation&#8217;. CoRR, abs/1006.4646, 2010.</p>
</div>
</dd></dl>

<dl class="function">
<dt id="comboperations.starWConcat">
<tt class="descclassname">comboperations.</tt><tt class="descname">starWConcat</tt><big>(</big><em>fa1</em>, <em>fa2</em>, <em>strict=False</em><big>)</big><a class="reference internal" href="_modules/comboperations.html#starWConcat"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#comboperations.starWConcat" title="Permalink to this definition">¶</a></dt>
<dd><p>Star combined with concatenation: (L1*.L2)</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>fa1</strong> (<em>DFA</em>) &#8211; first automaton</li>
<li><strong>fa2</strong> (<em>DFA</em>) &#8211; second automaton</li>
<li><strong>strict</strong> (<em>Boolean</em>) &#8211; should the alphabets be necessary equal?</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">DFA</p>
</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Bo Cui, Yuan Gao, Lila Kari, and Sheng Yu. &#8216;State complexity of catenation combined with star and reversal&#8217;.
CoRR, abs/1008.1648, 2010</p>
</div>
</dd></dl>

<dl class="function">
<dt id="comboperations.starDisj">
<tt class="descclassname">comboperations.</tt><tt class="descname">starDisj</tt><big>(</big><em>fa1</em>, <em>fa2</em>, <em>strict=False</em><big>)</big><a class="reference internal" href="_modules/comboperations.html#starDisj"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#comboperations.starDisj" title="Permalink to this definition">¶</a></dt>
<dd><p>Star of Union of two DFAs: (L1 + L2)*</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>fa1</strong> (<em>DFA</em>) &#8211; first automaton</li>
<li><strong>fa2</strong> (<em>DFA</em>) &#8211; second automaton</li>
<li><strong>strict</strong> (<em>Boolean</em>) &#8211; should the alphabets be necessary equal?</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">DFA</p>
</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Arto Salomaa, Kai Salomaa, and Sheng Yu. &#8216;State complexity of combined operations&#8217;. Theor. Comput. Sci.,
383(2-3):140–152, 2007.</p>
</div>
</dd></dl>

<dl class="function">
<dt id="comboperations.starInter0">
<tt class="descclassname">comboperations.</tt><tt class="descname">starInter0</tt><big>(</big><em>fa1</em>, <em>fa2</em>, <em>strict=False</em><big>)</big><a class="reference internal" href="_modules/comboperations.html#starInter0"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#comboperations.starInter0" title="Permalink to this definition">¶</a></dt>
<dd><p>Star of Intersection  of two DFAs: (L1 &amp; L2)*</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>fa1</strong> (<em>DFA</em>) &#8211; first automaton</li>
<li><strong>fa2</strong> (<em>DFA</em>) &#8211; second automaton</li>
<li><strong>strict</strong> (<em>Boolean</em>) &#8211; should the alphabets be necessary equal?</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">DFA</p>
</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Arto Salomaa, Kai Salomaa, and Sheng Yu. &#8216;State complexity of combined operations&#8217;. Theor. Comput. Sci.,
383(2-3):140–152, 2007.</p>
</div>
</dd></dl>

<dl class="function">
<dt id="comboperations.starInter">
<tt class="descclassname">comboperations.</tt><tt class="descname">starInter</tt><big>(</big><em>fa1</em>, <em>fa2</em>, <em>strict=False</em><big>)</big><a class="reference internal" href="_modules/comboperations.html#starInter"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#comboperations.starInter" title="Permalink to this definition">¶</a></dt>
<dd><p>Star of Intersection  of two DFAs: (L1 &amp; L2)*</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>fa1</strong> (<em>DFA</em>) &#8211; first automaton</li>
<li><strong>fa2</strong> (<em>DFA</em>) &#8211; second automaton</li>
<li><strong>strict</strong> (<em>Boolean</em>) &#8211; should the alphabets be necessary equal?</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">DFA</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="comboperations.disjWStar">
<tt class="descclassname">comboperations.</tt><tt class="descname">disjWStar</tt><big>(</big><em>f1</em>, <em>f2</em>, <em>strict=True</em><big>)</big><a class="reference internal" href="_modules/comboperations.html#disjWStar"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#comboperations.disjWStar" title="Permalink to this definition">¶</a></dt>
<dd><p>Union with star: (L1 + L2*)</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>f1</strong> (<em>DFA</em>) &#8211; first automaton</li>
<li><strong>f2</strong> (<em>DFA</em>) &#8211; second automaton</li>
<li><strong>strict</strong> (<em>Boolean</em>) &#8211; should the alphabets be necessary equal?</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">DFA</p>
</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Yuan Gao and Sheng Yu. &#8216;State complexity of union and intersection combined with star and reversal&#8217;. CoRR,
abs/1006.3755, 2010.</p>
</div>
</dd></dl>

<dl class="function">
<dt id="comboperations.interWStar">
<tt class="descclassname">comboperations.</tt><tt class="descname">interWStar</tt><big>(</big><em>f1</em>, <em>f2</em>, <em>strict=True</em><big>)</big><a class="reference internal" href="_modules/comboperations.html#interWStar"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#comboperations.interWStar" title="Permalink to this definition">¶</a></dt>
<dd><p>Intersection with star: (L1 &amp; L2*)</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>f1</strong> (<em>DFA</em>) &#8211; first automaton</li>
<li><strong>f2</strong> (<em>DFA</em>) &#8211; second automaton</li>
<li><strong>strict</strong> (<em>Boolean</em>) &#8211; should the alphabets be necessary equal?</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">DFA</p>
</td>
</tr>
</tbody>
</table>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Yuan Gao and Sheng Yu. &#8216;State complexity of union and intersection combined with star and reversal&#8217;. CoRR,
abs/1006.3755, 2010.</p>
</div>
</dd></dl>

</div>
<div class="section" id="module-codes">
<span id="module-codes-codes"></span><h2>Module: Codes (<tt class="docutils literal"><span class="pre">codes</span></tt>)<a class="headerlink" href="#module-codes" title="Permalink to this headline">¶</a></h2>
<p>Code theory module</p>
<div class="versionadded">
<p><span class="versionmodified">New in version 1.0.</span></p>
</div>
<div class="section" id="class-codeproperty">
<h3>Class CodeProperty<a class="headerlink" href="#class-codeproperty" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="codes.CodeProperty">
<em class="property">class </em><tt class="descclassname">codes.</tt><tt class="descname">CodeProperty</tt><big>(</big><em>name</em>, <em>alph</em><big>)</big><a class="reference internal" href="_modules/codes.html#CodeProperty"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.CodeProperty" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference external" href="http://docs.python.org/library/functions.html#object" title="(in Python v2.7)"><tt class="xref py py-class docutils literal"><span class="pre">object</span></tt></a></p>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">K. Dudzinski and S. Konstantinidis: Formal descriptions of code properties: decidability, complexity,
implementation. International Journal of Foundations of Computer Science 23:1 (2012), 67&#8211;85.</p>
</div>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Variables:</th><td class="field-body"><strong>Sigma</strong> &#8211; the alphabet</td>
</tr>
</tbody>
</table>
</dd></dl>

</div>
<div class="section" id="class-trajprop">
<h3>Class TrajProp<a class="headerlink" href="#class-trajprop" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="codes.TrajProp">
<em class="property">class </em><tt class="descclassname">codes.</tt><tt class="descname">TrajProp</tt><big>(</big><em>aut</em>, <em>Sigma</em><big>)</big><a class="reference internal" href="_modules/codes.html#TrajProp"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.TrajProp" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#codes.IATProp" title="codes.IATProp"><tt class="xref py py-class docutils literal"><span class="pre">codes.IATProp</span></tt></a></p>
<p>Class of trajectoty properties</p>
<p class="graphviz">
<img src="_images/inheritance-64c9fb55bf51440036b83f9709bca1148fd56f42.png" alt="Inheritance diagram of TrajProp" usemap="#inheritance171478694d" class="inheritance"/>
<map id="inheritance171478694d" name="inheritance171478694d">
<area shape="rect" id="node1" href="#codes.CodeProperty" title=".. seealso:: K. Dudzinski and S. Konstantinidis: Formal descriptions of code properties: decidability, complexity," alt="" coords="5,5,149,31"/>
<area shape="rect" id="node3" href="#codes.IPTProp" title="Input Preserving Transducer Property" alt="" coords="197,5,308,31"/>
<area shape="rect" id="node2" href="#codes.IATProp" title="Input Altering Transducer Property" alt="" coords="356,5,467,31"/>
<area shape="rect" id="node4" href="#codes.TrajProp" title="Class of trajectoty properties" alt="" coords="515,5,627,31"/>
</map>
</p>
<p>Constructor</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>aut</strong> (<em>DFA|NFA</em>) &#8211; regular expression over {0,1}</li>
<li><strong>Sigma</strong> (<a class="reference external" href="http://docs.python.org/library/stdtypes.html#set" title="(in Python v2.7)"><em>set</em></a>) &#8211; the alphabet</li>
</ul>
</td>
</tr>
</tbody>
</table>
<dl class="staticmethod">
<dt id="codes.TrajProp.trajToTransducer">
<em class="property">static </em><tt class="descname">trajToTransducer</tt><big>(</big><em>traj</em>, <em>Sigma</em><big>)</big><a class="reference internal" href="_modules/codes.html#TrajProp.trajToTransducer"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.TrajProp.trajToTransducer" title="Permalink to this definition">¶</a></dt>
<dd><p>Input Altering Tranducer corresponding to a Trajectory</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>traj</strong> (<em>NFA</em>) &#8211; trajectory language</li>
<li><strong>Sigma</strong> (<a class="reference external" href="http://docs.python.org/library/stdtypes.html#set" title="(in Python v2.7)"><em>set</em></a>) &#8211; alphabet</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">SFT</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-iptprop">
<h3>Class IPTProp<a class="headerlink" href="#class-iptprop" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="codes.IPTProp">
<em class="property">class </em><tt class="descclassname">codes.</tt><tt class="descname">IPTProp</tt><big>(</big><em>aut</em>, <em>name=None</em><big>)</big><a class="reference internal" href="_modules/codes.html#IPTProp"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.IPTProp" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#codes.CodeProperty" title="codes.CodeProperty"><tt class="xref py py-class docutils literal"><span class="pre">codes.CodeProperty</span></tt></a></p>
<p>Input Preserving Transducer Property</p>
<p class="graphviz">
<img src="_images/inheritance-f5bdcc278d4af678362344fff755af2eb0e53a1c.png" alt="Inheritance diagram of IPTProp" usemap="#inheritance5321d26081" class="inheritance"/>
<map id="inheritance5321d26081" name="inheritance5321d26081">
<area shape="rect" id="node1" href="#codes.CodeProperty" title=".. seealso:: K. Dudzinski and S. Konstantinidis: Formal descriptions of code properties: decidability, complexity," alt="" coords="5,5,145,31"/>
<area shape="rect" id="node2" href="#codes.IPTProp" title="Input Preserving Transducer Property" alt="" coords="193,5,300,31"/>
</map>
</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Variables:</th><td class="field-body"><ul class="first last simple">
<li><strong>Aut</strong> (<em>SFT</em>) &#8211; the transducer defining the property</li>
<li><strong>Sigma</strong> (<a class="reference external" href="http://docs.python.org/library/stdtypes.html#set" title="(in Python v2.7)"><em>set</em></a>) &#8211; alphabet</li>
</ul>
</td>
</tr>
</tbody>
</table>
<p>Constructor
:param SFT aut: Input preserving transducer</p>
<dl class="method">
<dt id="codes.IPTProp.maximalP">
<tt class="descname">maximalP</tt><big>(</big><em>aut</em>, <em>U=None</em><big>)</big><a class="reference internal" href="_modules/codes.html#IPTProp.maximalP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.IPTProp.maximalP" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if the language is maximal w.r.t. the property</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>aut</strong> (<em>NFA</em>) &#8211; the automaton</li>
<li><strong>U</strong> (<em>NFA</em>) &#8211; Universe of permitted words (Sigma^* as default)</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">bool</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="codes.IPTProp.notMaximalW">
<tt class="descname">notMaximalW</tt><big>(</big><em>aut</em>, <em>U=None</em><big>)</big><a class="reference internal" href="_modules/codes.html#IPTProp.notMaximalW"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.IPTProp.notMaximalW" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if the language is maximal w.r.t. the property</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>aut</strong> (<em>DFA|NFA</em>) &#8211; the automaton</li>
<li><strong>U</strong> (<em>DFA|NFA</em>) &#8211; Universe of permitted words (Sigma^* as default)</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first">bool</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name" colspan="2">Raises PropertyNotSatisfied:</th></tr>
<tr class="field-odd field"><td>&nbsp;</td><td class="field-body"><p class="first last">if not satisfied</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="codes.IPTProp.notSatisfiesW">
<tt class="descname">notSatisfiesW</tt><big>(</big><em>aut</em><big>)</big><a class="reference internal" href="_modules/codes.html#IPTProp.notSatisfiesW"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.IPTProp.notSatisfiesW" title="Permalink to this definition">¶</a></dt>
<dd><p>Return a witness of non-satisfaction of the property by the automaton language</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>aut</strong> (<em>DFA|NFA</em>) &#8211; the automaton</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">word witness pair</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">tuple</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="codes.IPTProp.satisfiesP">
<tt class="descname">satisfiesP</tt><big>(</big><em>aut</em><big>)</big><a class="reference internal" href="_modules/codes.html#IPTProp.satisfiesP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.IPTProp.satisfiesP" title="Permalink to this definition">¶</a></dt>
<dd><p>Satisfaction of the property by the automaton language</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>aut</strong> (<em>DFA|NFA</em>) &#8211; the automaton</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-iatprop">
<h3>Class IATProp<a class="headerlink" href="#class-iatprop" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="codes.IATProp">
<em class="property">class </em><tt class="descclassname">codes.</tt><tt class="descname">IATProp</tt><big>(</big><em>aut</em>, <em>name=None</em><big>)</big><a class="reference internal" href="_modules/codes.html#IATProp"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.IATProp" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#codes.IPTProp" title="codes.IPTProp"><tt class="xref py py-class docutils literal"><span class="pre">codes.IPTProp</span></tt></a></p>
<p>Input Altering Transducer Property</p>
<p class="graphviz">
<img src="_images/inheritance-2c3de97f2782f3d2089dae861342ec9557beae0c.png" alt="Inheritance diagram of IATProp" usemap="#inheritance3293a06299" class="inheritance"/>
<map id="inheritance3293a06299" name="inheritance3293a06299">
<area shape="rect" id="node1" href="#codes.CodeProperty" title=".. seealso:: K. Dudzinski and S. Konstantinidis: Formal descriptions of code properties: decidability, complexity," alt="" coords="5,5,149,31"/>
<area shape="rect" id="node3" href="#codes.IPTProp" title="Input Preserving Transducer Property" alt="" coords="197,5,308,31"/>
<area shape="rect" id="node2" href="#codes.IATProp" title="Input Altering Transducer Property" alt="" coords="356,5,467,31"/>
</map>
</p>
<p>Constructor
:param SFT aut: Input preserving transducer</p>
<dl class="method">
<dt id="codes.IATProp.notSatisfiesW">
<tt class="descname">notSatisfiesW</tt><big>(</big><em>aut</em><big>)</big><a class="reference internal" href="_modules/codes.html#IATProp.notSatisfiesW"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.IATProp.notSatisfiesW" title="Permalink to this definition">¶</a></dt>
<dd><p>Return a witness of non-satisfaction of the property by the automaton language</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>aut</strong> (<em>DFA|NFA</em>) &#8211; the automaton</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">word witness pair</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">tuple</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-prefixprop">
<h3>Class PrefixProp<a class="headerlink" href="#class-prefixprop" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="codes.PrefixProp">
<em class="property">class </em><tt class="descclassname">codes.</tt><tt class="descname">PrefixProp</tt><big>(</big><em>t</em><big>)</big><a class="reference internal" href="_modules/codes.html#PrefixProp"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.PrefixProp" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#codes.TrajProp" title="codes.TrajProp"><tt class="xref py py-class docutils literal"><span class="pre">codes.TrajProp</span></tt></a>, <tt class="xref py py-class docutils literal"><span class="pre">codes.FixedProp</span></tt></p>
<p>Prefix Property</p>
<p class="graphviz">
<img src="_images/inheritance-d5fd6dca99439a9d89dfe7bbd673c9f226e09e88.png" alt="Inheritance diagram of PrefixProp" usemap="#inheritancedca1fc6baa" class="inheritance"/>
<map id="inheritancedca1fc6baa" name="inheritancedca1fc6baa">
<area shape="rect" id="node1" href="#codes.CodeProperty" title=".. seealso:: K. Dudzinski and S. Konstantinidis: Formal descriptions of code properties: decidability, complexity," alt="" coords="5,29,141,53"/>
<area shape="rect" id="node2" title="Abstract class for fixed properties" alt="" coords="335,5,451,29"/>
<area shape="rect" id="node4" href="#codes.IPTProp" title="Input Preserving Transducer Property" alt="" coords="186,53,290,77"/>
<area shape="rect" id="node5" href="#codes.PrefixProp" title="Prefix Property" alt="" coords="646,29,763,53"/>
<area shape="rect" id="node3" href="#codes.IATProp" title="Input Altering Transducer Property" alt="" coords="341,53,445,77"/>
<area shape="rect" id="node6" href="#codes.TrajProp" title="Class of trajectoty properties" alt="" coords="496,53,601,77"/>
</map>
</p>
<dl class="method">
<dt id="codes.PrefixProp.satisfiesPrefixP">
<tt class="descname">satisfiesPrefixP</tt><big>(</big><em>aut</em><big>)</big><a class="reference internal" href="_modules/codes.html#PrefixProp.satisfiesPrefixP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.PrefixProp.satisfiesPrefixP" title="Permalink to this definition">¶</a></dt>
<dd><p>Satisfaction of property by the automaton language: faster than satisfiesP</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>aut</strong> (<em>DFA|NFA</em>) &#8211; the automaton</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="class-errdetectprop">
<h3>Class ErrDetectProp<a class="headerlink" href="#class-errdetectprop" title="Permalink to this headline">¶</a></h3>
<dl class="attribute">
<dt id="codes.ErrDetectProp">
<tt class="descclassname">codes.</tt><tt class="descname">ErrDetectProp</tt><a class="headerlink" href="#codes.ErrDetectProp" title="Permalink to this definition">¶</a></dt>
<dd><p>alias of <a class="reference internal" href="#codes.IPTProp" title="codes.IPTProp"><tt class="xref py py-class docutils literal"><span class="pre">IPTProp</span></tt></a></p>
</dd></dl>

</div>
<div class="section" id="class-errcorrectprop">
<h3>Class ErrCorrectProp<a class="headerlink" href="#class-errcorrectprop" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="codes.ErrCorrectProp">
<em class="property">class </em><tt class="descclassname">codes.</tt><tt class="descname">ErrCorrectProp</tt><big>(</big><em>t</em><big>)</big><a class="reference internal" href="_modules/codes.html#ErrCorrectProp"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.ErrCorrectProp" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference internal" href="#codes.IPTProp" title="codes.IPTProp"><tt class="xref py py-class docutils literal"><span class="pre">codes.IPTProp</span></tt></a></p>
<p>Error Correcting Property</p>
<p class="graphviz">
<img src="_images/inheritance-94c9f5e64789985870c1d851c22ea103ab7598d2.png" alt="Inheritance diagram of ErrCorrectProp" usemap="#inheritance8687bef198" class="inheritance"/>
<map id="inheritance8687bef198" name="inheritance8687bef198">
<area shape="rect" id="node1" href="#codes.CodeProperty" title=".. seealso:: K. Dudzinski and S. Konstantinidis: Formal descriptions of code properties: decidability, complexity," alt="" coords="5,5,149,31"/>
<area shape="rect" id="node3" href="#codes.IPTProp" title="Input Preserving Transducer Property" alt="" coords="197,5,308,31"/>
<area shape="rect" id="node2" href="#codes.ErrCorrectProp" title="Error Correcting Property" alt="" coords="356,5,507,31"/>
</map>
</p>
<dl class="method">
<dt id="codes.ErrCorrectProp.notMaximalW">
<tt class="descname">notMaximalW</tt><big>(</big><em>aut</em>, <em>U=None</em><big>)</big><a class="reference internal" href="_modules/codes.html#ErrCorrectProp.notMaximalW"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.ErrCorrectProp.notMaximalW" title="Permalink to this definition">¶</a></dt>
<dd><p>Tests if the language is maximal w.r.t. the property</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>aut</strong> (<em>DFA|NFA</em>) &#8211; the automaton</li>
<li><strong>U</strong> (<em>DFA|NFA</em>) &#8211; Universe of permitted words (Sigma^* as default)</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">bool</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="codes.ErrCorrectProp.notSatisfiesW">
<tt class="descname">notSatisfiesW</tt><big>(</big><em>aut</em><big>)</big><a class="reference internal" href="_modules/codes.html#ErrCorrectProp.notSatisfiesW"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.ErrCorrectProp.notSatisfiesW" title="Permalink to this definition">¶</a></dt>
<dd><p>Satisfaction of the code property by the automaton language</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>aut</strong> (<em>DFA|NFA</em>) &#8211; the automaton</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">tuple</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="codes.ErrCorrectProp.satisfiesP">
<tt class="descname">satisfiesP</tt><big>(</big><em>aut</em><big>)</big><a class="reference internal" href="_modules/codes.html#ErrCorrectProp.satisfiesP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.ErrCorrectProp.satisfiesP" title="Permalink to this definition">¶</a></dt>
<dd><p>Satisfaction of the property by the automaton language</p>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">S. Konstantinidis: Transducers and the Properties of Error-Detection, Error-Correction and
Finite-Delay Decodability. Journal Of Universal Computer Science 8 (2002), 278-291.</p>
</div>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>aut</strong> (<em>DFA|NFA</em>) &#8211; the automaton</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="id7">
<h3>Functions<a class="headerlink" href="#id7" title="Permalink to this headline">¶</a></h3>
<dl class="function">
<dt id="codes.buildTrajPropS">
<tt class="descclassname">codes.</tt><tt class="descname">buildTrajPropS</tt><big>(</big><em>regex</em>, <em>sigma</em><big>)</big><a class="reference internal" href="_modules/codes.html#buildTrajPropS"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.buildTrajPropS" title="Permalink to this definition">¶</a></dt>
<dd><p>Builds a TrajProp from a string regexp</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>regex</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; the regular expression</li>
<li><strong>sigma</strong> (<a class="reference external" href="http://docs.python.org/library/stdtypes.html#set" title="(in Python v2.7)"><em>set</em></a>) &#8211; alphabet</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">TrajProp</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="codes.buildIATPropF">
<tt class="descclassname">codes.</tt><tt class="descname">buildIATPropF</tt><big>(</big><em>fname</em><big>)</big><a class="reference internal" href="_modules/codes.html#buildIATPropF"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.buildIATPropF" title="Permalink to this definition">¶</a></dt>
<dd><p>Builds a IATProp from a FAdo SFT file</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>fname</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; file name</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">IATProp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="codes.buildIPTPropF">
<tt class="descclassname">codes.</tt><tt class="descname">buildIPTPropF</tt><big>(</big><em>fname</em><big>)</big><a class="reference internal" href="_modules/codes.html#buildIPTPropF"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.buildIPTPropF" title="Permalink to this definition">¶</a></dt>
<dd><p>Builds a IPTProp from a FAdo SFT file</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>fname</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; file name</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">IPTProp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="codes.buildIATPropS">
<tt class="descclassname">codes.</tt><tt class="descname">buildIATPropS</tt><big>(</big><em>s</em><big>)</big><a class="reference internal" href="_modules/codes.html#buildIATPropS"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.buildIATPropS" title="Permalink to this definition">¶</a></dt>
<dd><p>Builds a IATProp from a FAdo SFT string</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>s</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; string containing SFT</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">IATProp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="codes.buildIPTPropS">
<tt class="descclassname">codes.</tt><tt class="descname">buildIPTPropS</tt><big>(</big><em>s</em><big>)</big><a class="reference internal" href="_modules/codes.html#buildIPTPropS"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.buildIPTPropS" title="Permalink to this definition">¶</a></dt>
<dd><p>Builds a IPTProp from a FAdo SFT string</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>s</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; file name</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">IPTProp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="codes.buildErrorDetectPropF">
<tt class="descclassname">codes.</tt><tt class="descname">buildErrorDetectPropF</tt><big>(</big><em>fname</em><big>)</big><a class="reference internal" href="_modules/codes.html#buildErrorDetectPropF"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.buildErrorDetectPropF" title="Permalink to this definition">¶</a></dt>
<dd><p>Builds an Error Detecting Property</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>fname</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; file name</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">ErrDetectProp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="codes.buildErrorCorrectPropF">
<tt class="descclassname">codes.</tt><tt class="descname">buildErrorCorrectPropF</tt><big>(</big><em>fname</em><big>)</big><a class="reference internal" href="_modules/codes.html#buildErrorCorrectPropF"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.buildErrorCorrectPropF" title="Permalink to this definition">¶</a></dt>
<dd><p>Builds an Error Correcting Property</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>fname</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; file name</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">ErrCorrectProp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="codes.buildErrorDetectPropS">
<tt class="descclassname">codes.</tt><tt class="descname">buildErrorDetectPropS</tt><big>(</big><em>s</em><big>)</big><a class="reference internal" href="_modules/codes.html#buildErrorDetectPropS"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.buildErrorDetectPropS" title="Permalink to this definition">¶</a></dt>
<dd><p>Builds an Error Detecting Property from string</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>s</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; transducer string</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">ErrDetectProp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="codes.buildErrorCorrectPropS">
<tt class="descclassname">codes.</tt><tt class="descname">buildErrorCorrectPropS</tt><big>(</big><em>s</em><big>)</big><a class="reference internal" href="_modules/codes.html#buildErrorCorrectPropS"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.buildErrorCorrectPropS" title="Permalink to this definition">¶</a></dt>
<dd><p>Builds an Error Correcting Property from string</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>s</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; transducer string</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">ErrCorrectProp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="codes.buildPrefixProperty">
<tt class="descclassname">codes.</tt><tt class="descname">buildPrefixProperty</tt><big>(</big><em>alphabet</em><big>)</big><a class="reference internal" href="_modules/codes.html#buildPrefixProperty"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.buildPrefixProperty" title="Permalink to this definition">¶</a></dt>
<dd><p>Builds a Prefix Code Property</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>alphabet</strong> (<a class="reference external" href="http://docs.python.org/library/stdtypes.html#set" title="(in Python v2.7)"><em>set</em></a>) &#8211; alphabet</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">PrefixProp</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt>
<tt class="descclassname">codes.</tt><tt class="descname">buildTrajPropS</tt><big>(</big><em>regex</em>, <em>sigma</em><big>)</big><a class="reference internal" href="_modules/codes.html#buildTrajPropS"><span class="viewcode-link">[source]</span></a></dt>
<dd><p>Builds a TrajProp from a string regexp</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>regex</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; the regular expression</li>
<li><strong>sigma</strong> (<a class="reference external" href="http://docs.python.org/library/stdtypes.html#set" title="(in Python v2.7)"><em>set</em></a>) &#8211; alphabet</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">TrajProp</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="codes.editDistanceW">
<tt class="descclassname">codes.</tt><tt class="descname">editDistanceW</tt><big>(</big><em>auto</em><big>)</big><a class="reference internal" href="_modules/codes.html#editDistanceW"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.editDistanceW" title="Permalink to this definition">¶</a></dt>
<dd><p>Compute the edit distance of a given regular language accepted by the NFA via Input-altering transducer.</p>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">language should have at least two words</p>
</div>
<div class="admonition seealso">
<p class="first admonition-title">See also</p>
<p class="last">Lila Kari, Stavros Konstantinidis, Steffen Kopecki, Meng Yang. An efficient algorithm for computing
the edit distance of a regular language via input-altering transducers. arXiv:1406.1041 [cs.FL]</p>
</div>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>auto</strong> (<em>NFA</em>) &#8211; language recogniser</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">The edit distance of the given regular language plus a witness pair</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">tuple</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="codes.exponentialDensityP">
<tt class="descclassname">codes.</tt><tt class="descname">exponentialDensityP</tt><big>(</big><em>aut</em><big>)</big><a class="reference internal" href="_modules/codes.html#exponentialDensityP"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.exponentialDensityP" title="Permalink to this definition">¶</a></dt>
<dd><p>Checks if language density is exponential</p>
<p>Using breadth first search (BFS)</p>
<div class="admonition attention">
<p class="first admonition-title">Attention</p>
<p class="last">aut should not have Epsilon transitions</p>
</div>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>aut</strong> (<em>NFA</em>) &#8211; the representation of the language</td>
</tr>
<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">bool</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="codes.createInputAlteringSIDTrans">
<tt class="descclassname">codes.</tt><tt class="descname">createInputAlteringSIDTrans</tt><big>(</big><em>n</em>, <em>sigmaSet</em><big>)</big><a class="reference internal" href="_modules/codes.html#createInputAlteringSIDTrans"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#codes.createInputAlteringSIDTrans" title="Permalink to this definition">¶</a></dt>
<dd><p>Create an input-altering SID transducer based</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>n</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#int" title="(in Python v2.7)"><em>int</em></a>) &#8211; max number of errors</li>
<li><strong>sigmaSet</strong> (<a class="reference external" href="http://docs.python.org/library/stdtypes.html#set" title="(in Python v2.7)"><em>set</em></a>) &#8211; alphabet</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">a transducer representing the SID channel</p>
</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">SFT</p>
</td>
</tr>
</tbody>
</table>
</dd></dl>

</div>
</div>
<div class="section" id="module-grail">
<span id="module-grail-compatibility-grail"></span><h2>Module: Grail Compatibility (<tt class="docutils literal"><span class="pre">grail</span></tt>)<a class="headerlink" href="#module-grail" title="Permalink to this headline">¶</a></h2>
<p><strong>GRAIL support.</strong></p>
<p>GRAIL formats support. This is an auxiliary module that sould be imported by
fa.py</p>
<div class="versionadded">
<p><span class="versionmodified">New in version 0.9.4.</span></p>
</div>
<div class="section" id="class-parsergrail">
<h3>Class ParserGrail<a class="headerlink" href="#class-parsergrail" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="grail.ParserGrail">
<em class="property">class </em><tt class="descclassname">grail.</tt><tt class="descname">ParserGrail</tt><big>(</big><em>no_table=1</em>, <em>table='.tableGrail'</em><big>)</big><a class="reference internal" href="_modules/grail.html#ParserGrail"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#grail.ParserGrail" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <tt class="xref py py-class docutils literal"><span class="pre">yappy_parser.Yappy</span></tt></p>
<p>A parser form GRAIL standard automata descriptions</p>
<p class="graphviz">
<img src="_images/inheritance-b8e3e6773e743235c57062961b6aadc36be6e0a9.png" alt="Inheritance diagram of ParserGrail" usemap="#inheritance8dc0529aef" class="inheritance"/>
<map id="inheritance8dc0529aef" name="inheritance8dc0529aef">
<area shape="rect" id="node1" href="#grail.ParserGrail" title="A parser form GRAIL standard automata descriptions" alt="" coords="395,5,509,31"/>
<area shape="rect" id="node2" title="A basic class for parsing." alt="" coords="208,5,347,31"/>
<area shape="rect" id="node3" title="Class for LR parser" alt="" coords="5,5,160,31"/>
</map>
</p>
</dd></dl>

</div>
<div class="section" id="class-grail">
<h3>Class Grail<a class="headerlink" href="#class-grail" title="Permalink to this headline">¶</a></h3>
<dl class="class">
<dt id="grail.Grail">
<em class="property">class </em><tt class="descclassname">grail.</tt><tt class="descname">Grail</tt><a class="reference internal" href="_modules/grail.html#Grail"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#grail.Grail" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <a class="reference external" href="http://docs.python.org/library/functions.html#object" title="(in Python v2.7)"><tt class="xref py py-class docutils literal"><span class="pre">object</span></tt></a></p>
<p>A class for Grail execution</p>
<div class="versionchanged">
<p><span class="versionmodified">Changed in version 0.9.8: </span>tries to initialise execPath from fadorc </p>
</div>
<dl class="method">
<dt id="grail.Grail.do">
<tt class="descname">do</tt><big>(</big><em>cmd</em>, <em>*args</em><big>)</big><a class="reference internal" href="_modules/grail.html#Grail.do"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#grail.Grail.do" title="Permalink to this definition">¶</a></dt>
<dd><p>Execute Grail command</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
<li><strong>cmd</strong> (<a class="reference external" href="http://docs.python.org/library/string.html#module-string" title="(in Python v2.7)"><em>string</em></a>) &#8211; name of the command</li>
<li><strong>args</strong> &#8211; arguments</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Raises:</th><td class="field-body"><ul class="first last simple">
<li><strong>GrailCommandError</strong> &#8211; if the syntax is not correct an exception is raised</li>
<li><strong>FAdoGeneralError</strong> &#8211; if Grail fails to execute something</li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="method">
<dt id="grail.Grail.setExecPath">
<tt class="descname">setExecPath</tt><big>(</big><em>path</em><big>)</big><a class="reference internal" href="_modules/grail.html#Grail.setExecPath"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#grail.Grail.setExecPath" title="Permalink to this definition">¶</a></dt>
<dd><p>Sets the path to the Grail executables</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>path</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; the path to Grail executables</td>
</tr>
</tbody>
</table>
</dd></dl>

</dd></dl>

</div>
<div class="section" id="id8">
<h3>Functions<a class="headerlink" href="#id8" title="Permalink to this headline">¶</a></h3>
<dl class="function">
<dt id="grail.exportToGrail">
<tt class="descclassname">grail.</tt><tt class="descname">exportToGrail</tt><big>(</big><em>fileName</em>, <em>fa</em><big>)</big><a class="reference internal" href="_modules/grail.html#exportToGrail"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#grail.exportToGrail" title="Permalink to this definition">¶</a></dt>
<dd><p>Saves a finite automatom definition to a file using Grail format</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>fileName</strong> (<a class="reference external" href="http://docs.python.org/library/string.html#module-string" title="(in Python v2.7)"><em>string</em></a>) &#8211; file name</li>
<li><strong>fa</strong> (<em>FA</em>) &#8211; the FA</li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="grail.FAToGrail">
<tt class="descclassname">grail.</tt><tt class="descname">FAToGrail</tt><big>(</big><em>f</em>, <em>fa</em><big>)</big><a class="reference internal" href="_modules/grail.html#FAToGrail"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#grail.FAToGrail" title="Permalink to this definition">¶</a></dt>
<dd><p>Saves a finite automatom definition to an open file using Grail format</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>f</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#file" title="(in Python v2.7)"><em>file</em></a>) &#8211; opended file</li>
<li><strong>fa</strong> (<em>FA</em>) &#8211; the FA</li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="grail.importFromGrailFile">
<tt class="descclassname">grail.</tt><tt class="descname">importFromGrailFile</tt><big>(</big><em>fileName</em><big>)</big><a class="reference internal" href="_modules/grail.html#importFromGrailFile"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#grail.importFromGrailFile" title="Permalink to this definition">¶</a></dt>
<dd><p>Imports a finite automaton from a file in GRAIL format</p>
<p>The type of the object returned depends on the transition definiion red as well as the number of initial states
declared</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>fileName</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; file name</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">the automata red</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">FA</td>
</tr>
</tbody>
</table>
</dd></dl>

<dl class="function">
<dt id="grail.FAFromGrail">
<tt class="descclassname">grail.</tt><tt class="descname">FAFromGrail</tt><big>(</big><em>buffer</em><big>)</big><a class="reference internal" href="_modules/grail.html#FAFromGrail"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#grail.FAFromGrail" title="Permalink to this definition">¶</a></dt>
<dd><p>Imports a  finite automaton from a buffer in GRAIL format</p>
<p>The type of the object returned depends on the transition definiion red as well as the number of initial states
declared</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><strong>buffer</strong> (<a class="reference external" href="http://docs.python.org/library/functions.html#str" title="(in Python v2.7)"><em>str</em></a>) &#8211; buffer file</td>
</tr>
<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body">the automata red</td>
</tr>
<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body">FA</td>
</tr>
</tbody>
</table>
</dd></dl>

</div>
</div>
<div class="section" id="module-verso">
<span id="module-verso-language-verso"></span><h2>Module: Verso Language (<tt class="docutils literal"><span class="pre">verso</span></tt>)<a class="headerlink" href="#module-verso" title="Permalink to this headline">¶</a></h2>
<p><strong>FAdo interface language and slave manager</strong></p>
<p>Applications that want to use FAdo as a slave, just to process it objects should use
this language to interface with it.</p>
<div class="admonition note">
<p class="first admonition-title">Note</p>
<p>Every object that is supposed to be available through this language, should be defined
in objects and should have a method <tt class="docutils literal"><span class="pre">vDescription</span></tt>, returning the following list</p>
<ol class="arabic simple" start="0">
<li>A pair of descriptions, short and long, of the object</li>
<li>A list of pairs</li>
</ol>
<p>1.0. A name of a format <em>(names should be unique)</em></p>
<p>1.1. The function that returns the string representation of the object in that format</p>
<ol class="arabic simple" start="2">
<li>A tuple for each method provided</li>
</ol>
<p>2.0. Name of the command in verso</p>
<p>2.1. A pair, short/long, descriptions of the method</p>
<p>2.2. Number (n) of arguments of the method</p>
<p>2.2+i. The type of the ith argument</p>
<p>2.1+n. The return type <tt class="docutils literal"><span class="pre">None</span></tt> if does not return (in place transformation)</p>
<p>2.2+n. The function implementing the method having a list as arguments</p>
<ol class="last arabic simple" start="3">
<li>and so on...</li>
</ol>
</div>
<dl class="class">
<dt id="verso.ParserVerso">
<em class="property">class </em><tt class="descclassname">verso.</tt><tt class="descname">ParserVerso</tt><big>(</big><em>vsession</em>, <em>objects=None</em>, <em>no_table=0</em>, <em>table='.tableVerso'</em><big>)</big><a class="reference internal" href="_modules/verso.html#ParserVerso"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#verso.ParserVerso" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <tt class="xref py py-class docutils literal"><span class="pre">yappy_parser.Yappy</span></tt></p>
<p>A parser for FAdo standard automata descriptions</p>
<table class="docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">Variables:</th><td class="field-body"><ul class="first simple">
<li><strong>vi</strong> &#8211; virtual interaction session that knows how to communicate with the client</li>
<li><strong>objects</strong> &#8211; the list of objects known</li>
<li><strong>info</strong> &#8211; dictionary object -&gt; (longdescription, [list of commands])</li>
<li><strong>fun</strong> &#8211; dictionary command -&gt; (arity, return type, function)</li>
<li><a class="reference external" href="http://docs.python.org/library/functions.html#format" title="(in Python v2.7)"><strong>format</strong></a> &#8211; dictionary formatName -&gt; function</li>
</ul>
</td>
</tr>
<tr class="field-even field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first last simple">
<li><strong>no_table</strong> &#8211; ignore the table if it exists</li>
<li><strong>table</strong> &#8211; name of the table</li>
</ul>
</td>
</tr>
</tbody>
</table>
</dd></dl>

</div>
<div class="section" id="a-small-tutorial-for-fado">
<h2>A small tutorial for FAdo<a class="headerlink" href="#a-small-tutorial-for-fado" title="Permalink to this headline">¶</a></h2>
<p>FAdo system is a set  tools for regular languages manipulation.</p>
<p>Regular languages can be represented by regular expressions (regexp) or finite automata, among other formalisms. Finite automata may be deterministic (DFA) or non-deterministic (NFA). In FAdo these representations are implemented as Python classes. A full documentation of all classes and methods is here.</p>
<p>To work with FAdo, after installation, import the following modules on a Python interpreter:</p>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">FAdo.fa</span> <span class="kn">import</span> <span class="o">*</span>
<span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">FAdo.reex</span> <span class="kn">import</span> <span class="o">*</span>
<span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">FAdo.fio</span> <span class="kn">import</span> <span class="o">*</span>
</pre></div>
</div>
<p>The module fa implements the classes for finite automata and the module reex the classes for regular expressions. The module fio implements methods for IO of automata and related models.</p>
<p>General conventions</p>
<p>Methods which name ends in P test if the object verifies a given property and return True or False.</p>
<p>Finite Automata</p>
<p>The top class for finite automata is the class FA,which has two main subclasses: OFA for one way finite automata and the class TFA for two-way finite automata.
The class OFA implements the basic structure of a finite automaton shared by DFAs and NFAs. This class defines the following attributes:</p>
<blockquote>
<div><p>Sigma: the input alphabet (set)</p>
<p>States: the list of states.  It is a list such that each state is referred by its index whenever it is used (transitions, Final, etc).</p>
<p>Initial:the initial state (or a set of initial states for NFA).  It is an index or list of indexes.</p>
<p>Final: the set of final states. It is a list of indexes.</p>
</div></blockquote>
<p>In general, one should not create instances (objects) of class OFA. The class DFA and NFA implement DFAs and NFAs, respectively.  The class GFA implements generalized NFAs that are used in the conversion between finite automata and regular expressions. All three classes inherit from class OFA.</p>
<p>For each class there are special methods for add/delete/modify alphabet symbols, states and transitions.</p>
<p>DFAs</p>
<p>The following example shows how to build a DFA that accepts the words of {0,1}* that are multiples of 3.</p>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span><span class="o">=</span> <span class="n">DFA</span><span class="p">()</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span><span class="o">.</span><span class="n">setSigma</span><span class="p">([</span><span class="s">&#39;0&#39;</span><span class="p">,</span><span class="s">&#39;1&#39;</span><span class="p">])</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span><span class="o">.</span><span class="n">addState</span><span class="p">(</span><span class="s">&#39;s1&#39;</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span><span class="o">.</span><span class="n">addState</span><span class="p">(</span><span class="s">&#39;s2&#39;</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span><span class="o">.</span><span class="n">addState</span><span class="p">(</span><span class="s">&#39;s3&#39;</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span><span class="o">.</span><span class="n">setInitial</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="s">&#39;0&#39;</span><span class="p">,</span> <span class="mi">0</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="s">&#39;1&#39;</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="s">&#39;0&#39;</span><span class="p">,</span> <span class="mi">2</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="s">&#39;1&#39;</span><span class="p">,</span> <span class="mi">0</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="s">&#39;0&#39;</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="s">&#39;1&#39;</span><span class="p">,</span> <span class="mi">2</span><span class="p">)</span>
</pre></div>
</div>
<p>It is now possible, for instance, to see the structure of the automaton or to test if a word is accepted by it.</p>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span>
<span class="go">DFA(([&#39;s1&#39;, &#39;s2&#39;, &#39;s3&#39;], [&#39;1&#39;, &#39;0&#39;], &#39;s1&#39;, [&#39;s1&#39;], &quot;[(&#39;s1&#39;, &#39;1&#39;, &#39;s2&#39;), (&#39;s1&#39;, &#39;0&#39;, &#39;s1&#39;), (&#39;s2&#39;, &#39;1&#39;, &#39;s1&#39;), (&#39;s2&#39;, &#39;0&#39;, &#39;s3&#39;), (&#39;s3&#39;, &#39;1&#39;, &#39;s3&#39;), (&#39;s3&#39;, &#39;0&#39;, &#39;s2&#39;)]&quot;))</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span><span class="o">.</span><span class="n">evalWordP</span><span class="p">(</span><span class="s">&quot;011&quot;</span><span class="p">)</span>
<span class="go">True</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span><span class="o">.</span><span class="n">evalWordP</span><span class="p">(</span><span class="s">&quot;1011&quot;</span><span class="p">)</span>
<span class="go">False</span>
<span class="go">&gt;&gt;&gt;</span>
</pre></div>
</div>
<p>If graphviz is installed it is also possible to display the diagram of an automaton
as follows:</p>
<p>&gt;&gt;&gt;m3.display()</p>
<p>Instead of constructing the DFA directly we can load (and save) it in a simple text format. For the previous automaton the description will be:</p>
<div class="line-block">
<div class="line">&#64;DFA 0</div>
<div class="line">0 1 1</div>
<div class="line">0 0 0</div>
<div class="line">1 1 0</div>
<div class="line">1 0 2</div>
<div class="line">2 1 2</div>
<div class="line">2 0 1</div>
</div>
<p>Then, if this description is saved in file mul3.fa, we have</p>
<div class="highlight-python"><div class="highlight"><pre>&gt;&gt;&gt; m3=readFromFile(“mul3.fa”)[0]
</pre></div>
</div>
<p>As the set of states is represented by a Python list , the list method len can be used to determine the number of states of a FA:</p>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="nb">len</span><span class="p">(</span><span class="n">m3</span><span class="o">.</span><span class="n">States</span><span class="p">)</span>
<span class="go">3</span>
</pre></div>
</div>
<p>For the number of Transitions the countTransitions() method must be used</p>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span><span class="o">.</span><span class="n">countTransitions</span><span class="p">()</span>
<span class="go">6</span>
</pre></div>
</div>
<p>To minimize a DFA any of the minimization algorithms implemented can be used:</p>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="nb">min</span><span class="o">=</span><span class="n">m3</span><span class="o">.</span><span class="n">minimalHopcroft</span><span class="p">()</span>
</pre></div>
</div>
<p>In this case, the DFA was already minimal so min has the same number of states as m3.</p>
<p>Several (regularity preserving) operations of DFAs are implemented in FAdo:  boolean (union (| or __or__), intersection (&amp; or __and__) and complementation (~ or __invert__)),  concatenation (concat), reversal  (reversal) and star (star).</p>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="n">u</span> <span class="o">=</span> <span class="n">m3</span> <span class="o">|</span> <span class="o">~</span><span class="n">m3</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">u</span>
<span class="go">DFA(([(1, 1), (0, 0), (2, 2)], set([&#39;1&#39;, &#39;0&#39;]), 0,set([0, 1, 2]), {0: {&#39;1&#39;: 1, &#39;0&#39;: 0}, 1: {&#39;1&#39;: 0, &#39;0&#39;: 2}, 2:{&#39;1&#39;: 2, &#39;0&#39;: 1}}))</span>
</pre></div>
</div>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="n">m</span> <span class="o">=</span> <span class="n">u</span><span class="o">.</span><span class="n">minimal</span><span class="p">()</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">m</span>
<span class="go">DFA(([&#39;(1, 1)&#39;], [&#39;1&#39;, &#39;0&#39;], &#39;(1, 1)&#39;, [&#39;(1, 1)&#39;], &quot;[(&#39;(1, 1)&#39;, &#39;1&#39;, &#39;(1, 1)&#39;), (&#39;(1, 1)&#39;, &#39;0&#39;, &#39;(1, 1)&#39;)]&quot;))</span>
</pre></div>
</div>
<p>State names can be renamed in-place using:</p>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="n">m</span><span class="o">.</span><span class="n">renameStates</span><span class="p">(</span><span class="nb">range</span><span class="p">(</span><span class="nb">len</span><span class="p">(</span><span class="n">m</span><span class="p">)))</span>
</pre></div>
</div>
<p>DFA(([&#8216;0&#8217;], [&#8216;1&#8217;, &#8216;0&#8217;], &#8216;0&#8217;, [&#8216;0&#8217;], &#8220;[(0, &#8216;1&#8217;, 0), (0, &#8216;0&#8217;, 0)]&#8221;))</p>
<p>Notice that m recognize all words over the alphabet {0.1}.</p>
<blockquote>
<div>It is possible to generate a word recognisable by an automata (witness)</div></blockquote>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="n">u</span><span class="o">.</span><span class="n">witness</span><span class="p">()</span>
<span class="go">&#39;@epsilon&#39;</span>
</pre></div>
</div>
<p>In this case this allows to ensure that u recognizes the empty word.</p>
<p>This method is also useful for obtain a witness for the difference of two DFAs (witnessDiff).</p>
<p>To test if two DFAs  are equivalent the the operator == (equivalenceP) can be used.</p>
<p>NFAs</p>
<p>NFAs can be built and manipulated in a  similar way.  There is no distinction between NFAs with and without epsilon-transitions. But it is possible to test if a NFA has epsilon-transitions and convert between a NFA with epsilon-transitions to a (equivalent) NFA without them.</p>
<p>Converting between NFAs and DFAs</p>
<p>The method toDFA allows to convert a NFA to an equivalent DFA by the subset construction method. The method toNFA  migrates trivially a DFA to a NFA.</p>
<p>Regular Expressions</p>
<p>A regular expression can be a symbol of the alphabet, the empty set (&#64;epmtyset), the empty word (&#64;epsilon) or the concatenation or the union (+) or the Kleene star (*) of a regular expression. Examples of regular expressions are a+b, (a+ba)*, and (&#64;epsilon+ a)(<a class="reference external" href="mailto:ba+ab+&#37;&#52;&#48;emptyset">ba+ab+<span>&#64;</span>emptyset</a>).</p>
<p>The class regexp is the base class for regular expressions and is used to represent an alphabet symbol.  The classes epsilon and emptyset are the subclasses used for the empty set and empty word, respectively. Complex regular expressions are concat,  disj, and star.</p>
<p>As for DFAs (and NFAs) we can build directly a regular expressions as a Python class:</p>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="n">r</span> <span class="o">=</span> <span class="n">star</span><span class="p">(</span><span class="n">disj</span><span class="p">(</span><span class="n">regexp</span><span class="p">(</span><span class="s">&quot;a&quot;</span><span class="p">),</span><span class="n">concat</span><span class="p">(</span><span class="n">regexp</span><span class="p">(</span><span class="s">&quot;b&quot;</span><span class="p">),</span><span class="n">regexp</span><span class="p">(</span><span class="s">&quot;a&quot;</span><span class="p">))))</span>
<span class="gp">&gt;&gt;&gt; </span><span class="k">print</span> <span class="n">r</span>
<span class="go">(a + (b a))*</span>
</pre></div>
</div>
<p>But we can convert a string to a regexp class or subclass, using the method str2regexp.</p>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="n">r</span> <span class="o">=</span> <span class="n">str2regexp</span><span class="p">(</span><span class="s">&quot;(a+ba)*&quot;</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="k">print</span> <span class="n">r</span>
<span class="go">(a + (b a))*</span>
</pre></div>
</div>
<p>For regular expressions there are several measures available: alphabetic size, (parse) tree size, string length, number of epsilons and star height. It is also possible to explicitly associate an alphabet to regular expression (even if some symbols do not appear in it) (setSigma)</p>
<p>There are several algebraic properties that can be used to obtain equivalent regular expressions of a smaller size. The method reduced transforms a regular expression into one equivalent without some obvious unnecessary epsilons, emptysets or stars.</p>
<p>Several methods that allows the manipulation of derivatives  (or partial derivatives) by a symbol or by a word are implemented. However, the class regexp does not deal with regular expressions module ACI properties (associativity, commutativity and idempotence of the union) (see class xre) , a so it is not possible to obtain all  word derivatives of a given regular expression. This is not the case for partial derivatives.</p>
<p>To test if two regular expressions are equivalent the method compare can be used.</p>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="n">r</span><span class="o">.</span><span class="n">compare</span><span class="p">(</span><span class="n">str2regexp</span><span class="p">(</span>\<span class="s">&quot;(a*(ba)*a*)*</span><span class="se">\&quot;</span><span class="s">))</span>
<span class="go">True</span>
<span class="go">&gt;&gt;&gt;</span>
</pre></div>
</div>
<p>Converting Finite Automata to Regular Expressions</p>
<p>For pedagogical purposes, it is implemented a recursive method that constructs a regular expression equivalent to a given DFA (regexp).</p>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="k">print</span> <span class="n">m3</span><span class="o">.</span><span class="n">regexp</span><span class="p">()</span>
<span class="go">((0 + ((@epsilon + 0) (0* (@epsilon + 0)))) + ((1 +((@epsilon + 0) (0* 1))) ((1 (0* 1))* (1 + (1 (0*(@epsilon + 0))))))) + (((1 + ((@epsilon + 0) (0* 1)))((1 (0* 1))* 0)) ((1 + (0 ((1 (0* 1))* 0)))* (0 ((1(0* 1))* (1 + (1 (0* (@epsilon + 0))))))))</span>
</pre></div>
</div>
<p>Methods based on state elimination techniques are usually more efficient, and produces much smaller regular expressions. We have implemented several heuristics for the elimination order.</p>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="k">print</span> <span class="n">m3</span><span class="o">.</span><span class="n">reCG</span><span class="p">()</span>
<span class="go">((0 + (1 1)) + (((1 0) (1 + (0 0))*) (0 1)))*</span>
</pre></div>
</div>
<p>Converting Regular Expressions to Finite Automata</p>
<p>Several methods to convert between regular expressions and NFAs are implemented.  With the Thompson construction a NFA with epsilon transitions is obtained (nfaThompson). Epsilon free NFAs can be obtained by the Glushkov method (Position automata) (nfaPosition,) the partial derivatives method (nfaPD) or by the follow method (nfaFollow). The two last methods usually  allows to obtain smaller NFAs.</p>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span> <span class="n">r</span><span class="o">.</span><span class="n">nfaThompson</span><span class="p">()</span>
<span class="go">NFA(([&#39;&#39;, &#39;&#39;, &#39;&#39;, &#39;&#39;, &#39;0&#39;, &#39;1&#39;, &#39;2&#39;, &#39;3&#39;, &#39;8&#39;, &#39;9&#39;], [&#39;a&#39;, &#39;b&#39;], [&#39;8&#39;], [&#39;9&#39;], &quot;[(&#39;&#39;, &#39;@epsilon&#39;, &#39;&#39;), (&#39;&#39;, &#39;@epsilon&#39;, 0), (&#39;&#39;, &#39;@epsilon&#39;, &#39;9&#39;), (&#39;&#39;, &#39;a&#39;, &#39;&#39;), (&#39;&#39;, &#39;@epsilon&#39;, &#39;&#39;), (0, &#39;b&#39;, 1), (1, &#39;@epsilon&#39;, 2), (2, &#39;a&#39;, 3), (3, &#39;@epsilon&#39;, &#39;&#39;), (&#39;8&#39;, &#39;@epsilon&#39;, &#39;&#39;), (&#39;8&#39;, &#39;@epsilon&#39;, &#39;9&#39;), (&#39;9&#39;, &#39;@epsilon&#39;, &#39;8&#39;)]&quot;))</span>
</pre></div>
</div>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="n">r</span><span class="o">.</span><span class="n">nfaPosition</span><span class="p">()</span>
<span class="go">NFA(([&#39;Initial&#39;, &quot;(&#39;a&#39;, 1)&quot;, &quot;(&#39;b&#39;, 2)&quot;, &quot;(&#39;a&#39;, 3)&quot;], [&#39;a&#39;, &#39;b&#39;], [&#39;Initial&#39;], [&#39;Initial&#39;, &quot;(&#39;a&#39;, 1)&quot;, &quot;(&#39;a&#39;, 3)&quot;], &#39;[(\&#39;Initial\&#39;, \&#39;a\&#39;, &quot;(\&#39;a\&#39;, 1)&quot;), (\&#39;Initial\&#39;, \&#39;b\&#39;, &quot;(\&#39;b\&#39;, 2)&quot;), (&quot;(\&#39;a\&#39;, 1)&quot;, \&#39;a\&#39;, &quot;(\&#39;a\&#39;, 1)&quot;), (&quot;(\&#39;a\&#39;, 1)&quot;, \&#39;b\&#39;, &quot;(\&#39;b\&#39;, 2)&quot;), (&quot;(\&#39;b\&#39;, 2)&quot;, \&#39;a\&#39;, &quot;(\&#39;a\&#39;, 3)&quot;), (&quot;(\&#39;a\&#39;, 3)&quot;, \&#39;a\&#39;, &quot;(\&#39;a\&#39;, 1)&quot;), (&quot;(\&#39;a\&#39;, 3)&quot;, \&#39;b\&#39;, &quot;(\&#39;b\&#39;, 2)&quot;)]&#39;))</span>
</pre></div>
</div>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="n">r</span><span class="o">.</span><span class="n">nfaPD</span><span class="p">()</span>
<span class="go">NFA(([&#39;(a + (b a))*&#39;, &#39;a (a + (b a))*&#39;], [&#39;a&#39;, &#39;b&#39;], [&#39;(a + (b a))*&#39;], [&#39;(a + (b a))*&#39;], &quot;[(star(disj(regexp(a),concat(regexp(b),regexp(a)))), &#39;a&#39;, star(disj(regexp(a),concat(regexp(b),regexp(a))))), (star(disj(regexp(a),concat(regexp(b),regexp(a)))), &#39;b&#39;, concat(regexp(a),star(disj(regexp(a),concat(regexp(b),regexp(a)))))), (concat(regexp(a),star(disj(regexp(a),concat(regexp(b),regexp(a))))), &#39;a&#39;, star(disj(regexp(a),concat(regexp(b),regexp(a)))))]&quot;))</span>
</pre></div>
</div>
<p>General Example</p>
<p>Considering the several methods described before it is possible to convert between the different equivalent representations of regular languages, as well to perform several regularity preserving operations.</p>
<div class="highlight-python"><div class="highlight"><pre><span class="gp">&gt;&gt;&gt; </span><span class="n">r</span><span class="o">.</span><span class="n">nfaPosition</span><span class="p">()</span><span class="o">.</span><span class="n">toDFA</span><span class="p">()</span><span class="o">.</span><span class="n">minimal</span><span class="p">(</span><span class="n">complete</span><span class="o">=</span><span class="bp">False</span><span class="p">)</span>
<span class="go">DFA(([&#39;0&#39;, &#39;2&#39;], [&#39;a&#39;, &#39;b&#39;], &#39;0&#39;, [&#39;0&#39;], &quot;[(&#39;0&#39;, &#39;a&#39;, &#39;0&#39;), (&#39;0&#39;, &#39;b&#39;, &#39;2&#39;), (&#39;2&#39;, &#39;a&#39;, &#39;0&#39;)]&quot;))</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">m3</span> <span class="o">==</span> <span class="n">m3</span><span class="o">.</span><span class="n">reCG</span><span class="p">()</span><span class="o">.</span><span class="n">nfaPD</span><span class="p">()</span><span class="o">.</span><span class="n">toDFA</span><span class="p">()</span><span class="o">.</span><span class="n">minimal</span><span class="p">()</span>
<span class="go">True</span>
<span class="go">&gt;&gt;&gt;</span>
</pre></div>
</div>
<p>More classes and modules</p>
<p>Several other classes and modules are also available, including:</p>
<p>class ICDFArnd (module rndfa.py): Random DFA generation</p>
<p>class FL (module fl.py): special methods for finite languages</p>
<p>class xre (module xre.py): extended regular expressions</p>
<p>module comboperations.py:  implementation of several algorithms for several combined operations with DFAs and NFAs</p>
<p>module grail.py: compatibility with GRAIL</p>
<p>module transducers.py: several classes and methods for transducers</p>
</div>
<div class="section" id="indices-and-tables">
<h2>Indices and tables<a class="headerlink" href="#indices-and-tables" title="Permalink to this headline">¶</a></h2>
<ul class="simple">
<li><a class="reference internal" href="genindex.html"><em>Index</em></a></li>
<li><a class="reference internal" href="py-modindex.html"><em>Module Index</em></a></li>
<li><a class="reference internal" href="search.html"><em>Search Page</em></a></li>
</ul>
</div>
</div>


          </div>
        </div>
      </div>
      <div class="clearer"></div>
    </div>
    <div class="related">
      <h3>Navigation</h3>
      <ul>
        <li class="right" style="margin-right: 10px">
          <a href="genindex.html" title="General Index"
             >index</a></li>
        <li class="right" >
          <a href="py-modindex.html" title="Python Module Index"
             >modules</a> |</li>
        <li><a href="#">FAdo 1.2 documentation</a> &raquo;</li> 
      </ul>
    </div>
    <div class="footer">
        &copy; Copyright 1999-2014, Rogério Reis &amp; Nelma Moreira.
      Created using <a href="http://sphinx-doc.org/">Sphinx</a> 1.2.2.
    </div>
  </body>
</html>