<!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>fl &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="../index.html" />
    <link rel="up" title="Module code" href="index.html" /> 
  </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="../index.html">FAdo 1.2 documentation</a> &raquo;</li>
          <li><a href="index.html" accesskey="U">Module code</a> &raquo;</li> 
      </ul>
    </div>
      <div class="sphinxsidebar">
        <div class="sphinxsidebarwrapper">
<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">
            
  <h1>Source code for fl</h1><div class="highlight"><pre>
<span class="c"># -*- coding: utf-8 -*-</span>
<span class="sd">&quot;&quot;&quot;Finite languages and related automata manipulation</span>

<span class="sd">Finite languages manipulation</span>

<span class="sd">.. *Authors:* Rogério Reis &amp; Nelma Moreira</span>

<span class="sd">.. *This is part of FAdo project*   &lt;http://fado.dcc.fc.up.pt</span>

<span class="sd">.. *Version:* 0.9.5</span>

<span class="sd">.. *Copyright*: 1999-2014 Rogério Reis &amp; Nelma Moreira {rvr,nam}@dcc.fc.up.pt</span>

<span class="sd">.. This program is free software; you can redistribute it and/or modify</span>
<span class="sd">   it under the terms of the GNU General Public License as published by</span>
<span class="sd">   the Free Software Foundation; either version 2 of the License, or</span>
<span class="sd">   (at your option) any later version.</span>

<span class="sd">   This program is distributed in the hope that it will be useful,</span>
<span class="sd">   but WITHOUT ANY WARRANTY; without even the implied warranty of</span>
<span class="sd">   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the</span>
<span class="sd">   GNU General Public License for more details.</span>

<span class="sd">   You should have received a copy of the GNU General Public License</span>
<span class="sd">   along with this program; if not, write to the Free Software</span>
<span class="sd">   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.&quot;&quot;&quot;</span>

<span class="kn">import</span> <span class="nn">fa</span>
<span class="kn">from</span> <span class="nn">copy</span> <span class="kn">import</span> <span class="n">copy</span>
<span class="kn">from</span> <span class="nn">common</span> <span class="kn">import</span> <span class="o">*</span>
<span class="kn">import</span> <span class="nn">random</span>


<div class="viewcode-block" id="FL"><a class="viewcode-back" href="../index.html#fl.FL">[docs]</a><span class="k">class</span> <span class="nc">FL</span><span class="p">(</span><span class="nb">object</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Finite Language Class</span>

<span class="sd">    :var Words: the elements of the language</span>
<span class="sd">    :var Sigma: the alphabet&quot;&quot;&quot;</span>
    <span class="k">def</span> <span class="nf">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">wordsList</span><span class="o">=</span><span class="bp">None</span><span class="p">,</span> <span class="n">Sigma</span><span class="o">=</span><span class="nb">set</span><span class="p">([])):</span>
        <span class="k">if</span> <span class="ow">not</span> <span class="n">wordsList</span><span class="p">:</span>
            <span class="n">wordsList</span> <span class="o">=</span> <span class="p">[]</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">Words</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">wordsList</span><span class="p">)</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">=</span> <span class="n">Sigma</span>
        <span class="k">for</span> <span class="n">w</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">Words</span><span class="p">:</span>
            <span class="k">if</span> <span class="n">w</span> <span class="o">!=</span> <span class="n">Epsilon</span><span class="p">:</span>
                <span class="k">for</span> <span class="n">l</span> <span class="ow">in</span> <span class="n">w</span><span class="p">:</span>
                    <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">l</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">__str__</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="k">return</span> <span class="s">&quot;(</span><span class="si">%s</span><span class="s">,</span><span class="si">%s</span><span class="s">)&quot;</span> <span class="o">%</span> <span class="p">(</span><span class="nb">list</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Words</span><span class="p">),</span> <span class="nb">list</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">))</span>

    <span class="k">def</span> <span class="nf">__repr__</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="k">return</span> <span class="s">&quot;FL</span><span class="si">%s</span><span class="s">&quot;</span> <span class="o">%</span> <span class="bp">self</span><span class="o">.</span><span class="n">__str__</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">__len__</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="k">return</span> <span class="nb">len</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Words</span><span class="p">)</span>

<div class="viewcode-block" id="FL.reunion"><a class="viewcode-back" href="../index.html#fl.FL.reunion">[docs]</a>    <span class="k">def</span> <span class="nf">reunion</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">other</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Reunion of FL:   a | b</span>

<span class="sd">        :param FL other: right hand operand</span>
<span class="sd">        :rtype: FL</span>
<span class="sd">        :raises FAdoGeneralError: if both arguments are not FL&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">__or__</span><span class="p">(</span><span class="n">other</span><span class="p">)</span>
</div>
    <span class="k">def</span> <span class="nf">__or__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">other</span><span class="p">):</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">other</span><span class="p">)</span> <span class="o">!=</span> <span class="nb">type</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
            <span class="k">raise</span> <span class="n">FAdoGeneralError</span><span class="p">(</span><span class="s">&quot;Incompatible objects&quot;</span><span class="p">)</span>
        <span class="n">new</span> <span class="o">=</span> <span class="n">FL</span><span class="p">()</span>
        <span class="n">new</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">|</span> <span class="n">other</span><span class="o">.</span><span class="n">Sigma</span>
        <span class="n">new</span><span class="o">.</span><span class="n">Words</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">Words</span> <span class="o">|</span> <span class="n">other</span><span class="o">.</span><span class="n">Words</span>
        <span class="k">return</span> <span class="n">new</span>

<div class="viewcode-block" id="FL.intersection"><a class="viewcode-back" href="../index.html#fl.FL.intersection">[docs]</a>    <span class="k">def</span> <span class="nf">intersection</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">other</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Intersection of FL: a &amp; b</span>

<span class="sd">        :param FL other: right hand operand</span>
<span class="sd">        :raises FAdoGeneralError: if both arguments are not FL&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">__and__</span><span class="p">(</span><span class="n">other</span><span class="p">)</span>
</div>
    <span class="k">def</span> <span class="nf">__and__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">other</span><span class="p">):</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">other</span><span class="p">)</span> <span class="o">!=</span> <span class="nb">type</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
            <span class="k">raise</span> <span class="n">FAdoGeneralError</span><span class="p">(</span><span class="s">&quot;Incompatible objects&quot;</span><span class="p">)</span>
        <span class="n">new</span> <span class="o">=</span> <span class="n">FL</span><span class="p">()</span>
        <span class="n">new</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">|</span> <span class="n">other</span><span class="o">.</span><span class="n">Sigma</span>
        <span class="n">new</span><span class="o">.</span><span class="n">Words</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">Words</span> <span class="o">&amp;</span> <span class="n">other</span><span class="o">.</span><span class="n">Words</span>
        <span class="k">return</span> <span class="n">new</span>

<div class="viewcode-block" id="FL.diff"><a class="viewcode-back" href="../index.html#fl.FL.diff">[docs]</a>    <span class="k">def</span> <span class="nf">diff</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">other</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Difference of FL: a - b</span>

<span class="sd">        :param FL other: right hand operand</span>
<span class="sd">        :rtype: FL</span>
<span class="sd">        :raises FAdoGeneralError: if both arguments are not FL&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">__sub__</span><span class="p">(</span><span class="n">other</span><span class="p">)</span>
</div>
    <span class="k">def</span> <span class="nf">__sub__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">other</span><span class="p">):</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">other</span><span class="p">)</span> <span class="o">!=</span> <span class="nb">type</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
            <span class="k">raise</span> <span class="n">FAdoGeneralError</span><span class="p">(</span><span class="s">&quot;Incompatible objects&quot;</span><span class="p">)</span>
        <span class="n">new</span> <span class="o">=</span> <span class="n">FL</span><span class="p">()</span>
        <span class="n">new</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">|</span> <span class="n">other</span><span class="o">.</span><span class="n">Sigma</span>
        <span class="n">new</span><span class="o">.</span><span class="n">Words</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">Words</span> <span class="o">-</span> <span class="n">other</span><span class="o">.</span><span class="n">Words</span>
        <span class="k">return</span> <span class="n">new</span>

<div class="viewcode-block" id="FL.setSigma"><a class="viewcode-back" href="../index.html#fl.FL.setSigma">[docs]</a>    <span class="k">def</span> <span class="nf">setSigma</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">Sigma</span><span class="p">,</span> <span class="n">Strict</span><span class="o">=</span><span class="bp">False</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Sets the alphabet of a FL</span>

<span class="sd">        :param set Sigma: alphabet</span>
<span class="sd">        :param bool Strict: behaviour</span>

<span class="sd">        .. attention::</span>
<span class="sd">           Unless Strict flag is set to True, alphabet can only be enlarged.  The resulting alphabet is  in fact the</span>
<span class="sd">           union of the former alphabet with the new one. If flag is set to True, the alphabet is simply replaced.&quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="n">Strict</span><span class="p">:</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">=</span> <span class="n">Sigma</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="o">.</span><span class="n">union</span><span class="p">(</span><span class="n">Sigma</span><span class="p">)</span>
</div>
<div class="viewcode-block" id="FL.addWords"><a class="viewcode-back" href="../index.html#fl.FL.addWords">[docs]</a>    <span class="k">def</span> <span class="nf">addWords</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">wList</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Adds a list of words to a FL</span>

<span class="sd">        :param list wList: words to add&quot;&quot;&quot;</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">Words</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">Words</span> <span class="o">|</span> <span class="nb">set</span><span class="p">(</span><span class="n">wList</span><span class="p">)</span>
        <span class="k">for</span> <span class="n">w</span> <span class="ow">in</span> <span class="n">wList</span><span class="p">:</span>
            <span class="k">for</span> <span class="n">c</span> <span class="ow">in</span> <span class="n">w</span><span class="p">:</span>
                <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">c</span><span class="p">)</span>
</div>
<div class="viewcode-block" id="FL.suffixClosedP"><a class="viewcode-back" href="../index.html#fl.FL.suffixClosedP">[docs]</a>    <span class="k">def</span> <span class="nf">suffixClosedP</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Tests if a language is suffix closed</span>

<span class="sd">        :rtype: bool&quot;&quot;&quot;</span>
        <span class="n">wrds</span> <span class="o">=</span> <span class="nb">list</span><span class="p">(</span><span class="n">copy</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Words</span><span class="p">))</span>
        <span class="k">if</span> <span class="n">Epsilon</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">wrds</span><span class="p">:</span>
            <span class="k">return</span> <span class="bp">False</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="n">wrds</span><span class="o">.</span><span class="n">remove</span><span class="p">(</span><span class="n">Epsilon</span><span class="p">)</span>
        <span class="n">wrds</span><span class="o">.</span><span class="n">sort</span><span class="p">(</span><span class="k">lambda</span> <span class="n">x</span><span class="p">,</span> <span class="n">y</span><span class="p">:</span> <span class="nb">len</span><span class="p">(</span><span class="n">x</span><span class="p">)</span> <span class="o">-</span> <span class="nb">len</span><span class="p">(</span><span class="n">y</span><span class="p">))</span>
        <span class="k">while</span> <span class="n">wrds</span><span class="p">:</span>
            <span class="n">w</span> <span class="o">=</span> <span class="n">wrds</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span>
            <span class="k">for</span> <span class="n">w1</span> <span class="ow">in</span> <span class="n">suffixes</span><span class="p">(</span><span class="n">w</span><span class="p">):</span>
                <span class="k">if</span> <span class="n">w1</span> <span class="ow">not</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">Words</span><span class="p">:</span>
                    <span class="k">return</span> <span class="bp">False</span>
                <span class="k">else</span><span class="p">:</span>
                    <span class="k">if</span> <span class="n">w1</span> <span class="ow">in</span> <span class="n">wrds</span><span class="p">:</span>
                        <span class="n">wrds</span><span class="o">.</span><span class="n">remove</span><span class="p">(</span><span class="n">w1</span><span class="p">)</span>
        <span class="k">return</span> <span class="bp">True</span>
</div>
<div class="viewcode-block" id="FL.filter"><a class="viewcode-back" href="../index.html#fl.FL.filter">[docs]</a>    <span class="k">def</span> <span class="nf">filter</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">automata</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Separates a language in two other using a DFA of NFA as a filter</span>

<span class="sd">        :param DFA|NFA automata: the automata to be used as a filter</span>
<span class="sd">        :returns: the accepted/unaccepted pair of languages</span>
<span class="sd">        :rtype: tuple of FL&quot;&quot;&quot;</span>
        <span class="n">a</span><span class="p">,</span> <span class="n">b</span> <span class="o">=</span> <span class="p">(</span><span class="n">FL</span><span class="p">(),</span> <span class="n">FL</span><span class="p">())</span>
        <span class="n">a</span><span class="o">.</span><span class="n">setSigma</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">)</span>
        <span class="n">b</span><span class="o">.</span><span class="n">setSigma</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">)</span>
        <span class="k">for</span> <span class="n">w</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">Words</span><span class="p">:</span>
            <span class="k">if</span> <span class="n">automata</span><span class="o">.</span><span class="n">evalWord</span><span class="p">(</span><span class="n">w</span><span class="p">):</span>
                <span class="n">a</span><span class="o">.</span><span class="n">addWords</span><span class="p">([</span><span class="n">w</span><span class="p">])</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="n">b</span><span class="o">.</span><span class="n">addWords</span><span class="p">([</span><span class="n">w</span><span class="p">])</span>
        <span class="k">return</span> <span class="n">a</span><span class="p">,</span> <span class="n">b</span>
</div>
<div class="viewcode-block" id="FL.trieFA"><a class="viewcode-back" href="../index.html#fl.FL.trieFA">[docs]</a>    <span class="k">def</span> <span class="nf">trieFA</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Generates the trie automaton that recognises this language</span>

<span class="sd">        :returns: the trie automaton</span>
<span class="sd">        :rtype: ADFA&quot;&quot;&quot;</span>
        <span class="n">new</span> <span class="o">=</span> <span class="n">ADFA</span><span class="p">()</span>
        <span class="n">new</span><span class="o">.</span><span class="n">setSigma</span><span class="p">(</span><span class="n">copy</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">))</span>
        <span class="n">i</span> <span class="o">=</span> <span class="n">new</span><span class="o">.</span><span class="n">addState</span><span class="p">()</span>
        <span class="n">new</span><span class="o">.</span><span class="n">setInitial</span><span class="p">(</span><span class="n">i</span><span class="p">)</span>
        <span class="k">for</span> <span class="n">w</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">Words</span><span class="p">:</span>
            <span class="k">if</span> <span class="n">w</span> <span class="o">==</span> <span class="n">Epsilon</span><span class="p">:</span>
                <span class="n">new</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">i</span><span class="p">)</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="n">s</span> <span class="o">=</span> <span class="n">i</span>
                <span class="k">for</span> <span class="n">c</span> <span class="ow">in</span> <span class="n">w</span><span class="p">:</span>
                    <span class="k">if</span> <span class="n">c</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">new</span><span class="o">.</span><span class="n">delta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="p">[]):</span>
                        <span class="n">sn</span> <span class="o">=</span> <span class="n">new</span><span class="o">.</span><span class="n">addState</span><span class="p">()</span>
                        <span class="n">new</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">c</span><span class="p">,</span> <span class="n">sn</span><span class="p">)</span>
                        <span class="n">s</span> <span class="o">=</span> <span class="n">sn</span>
                    <span class="k">else</span><span class="p">:</span>
                        <span class="n">s</span> <span class="o">=</span> <span class="n">new</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">s</span><span class="p">][</span><span class="n">c</span><span class="p">]</span>
                <span class="n">new</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">new</span>
</div>
<div class="viewcode-block" id="FL.toDFA"><a class="viewcode-back" href="../index.html#fl.FL.toDFA">[docs]</a>    <span class="k">def</span> <span class="nf">toDFA</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot; Generates a DFA recognizing the language</span>

<span class="sd">        :rtype: ADFA</span>

<span class="sd">        .. versionadded:: 1.2&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">trieFA</span><span class="p">()</span>
</div>
<div class="viewcode-block" id="FL.toNFA"><a class="viewcode-back" href="../index.html#fl.FL.toNFA">[docs]</a>    <span class="k">def</span> <span class="nf">toNFA</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Generates a NFA recognizing the language</span>

<span class="sd">        :rtype: ANFA</span>

<span class="sd">        .. versionadded:: 1.2&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">toDFA</span><span class="p">()</span><span class="o">.</span><span class="n">toANFA</span><span class="p">()</span>

    <span class="c"># noinspection PyUnboundLocalVariable</span></div>
<div class="viewcode-block" id="FL.multiLineAutomaton"><a class="viewcode-back" href="../index.html#fl.FL.multiLineAutomaton">[docs]</a>    <span class="k">def</span> <span class="nf">multiLineAutomaton</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Generates the trivial linear ANFA equivalent to this language</span>
<span class="sd">    </span>
<span class="sd">        :rtype: ANFA&quot;&quot;&quot;</span>
        <span class="n">new</span> <span class="o">=</span> <span class="n">ANFA</span><span class="p">()</span>
        <span class="n">new</span><span class="o">.</span><span class="n">setSigma</span><span class="p">(</span><span class="n">copy</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">))</span>
        <span class="k">for</span> <span class="n">w</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">Words</span><span class="p">:</span>
            <span class="n">s</span> <span class="o">=</span> <span class="n">new</span><span class="o">.</span><span class="n">addState</span><span class="p">()</span>
            <span class="n">new</span><span class="o">.</span><span class="n">addInitial</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
            <span class="k">for</span> <span class="n">c</span> <span class="ow">in</span> <span class="n">w</span><span class="p">:</span>
                <span class="n">s1</span> <span class="o">=</span> <span class="n">new</span><span class="o">.</span><span class="n">addState</span><span class="p">()</span>
                <span class="n">new</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">c</span><span class="p">,</span> <span class="n">s1</span><span class="p">)</span>
                <span class="n">s</span> <span class="o">=</span> <span class="n">s1</span>
            <span class="n">new</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">new</span>

</div></div>
<div class="viewcode-block" id="DCFA"><a class="viewcode-back" href="../index.html#fl.DCFA">[docs]</a><span class="k">class</span> <span class="nc">DCFA</span><span class="p">(</span><span class="n">fa</span><span class="o">.</span><span class="n">DFA</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Deterministic Cover Automata class</span>

<span class="sd">    .. inheritance-diagram:: DCFA&quot;&quot;&quot;</span>

    <span class="k">def</span> <span class="nf">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="nb">super</span><span class="p">(</span><span class="n">DCFA</span><span class="p">,</span> <span class="bp">self</span><span class="p">)</span><span class="o">.</span><span class="n">__init__</span><span class="p">()</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">length</span> <span class="o">=</span> <span class="bp">None</span>

    <span class="nd">@property</span>
    <span class="k">def</span> <span class="nf">length</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return: size of the longest word</span>
<span class="sd">        :rtype: int&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">length</span>

    <span class="nd">@length.setter</span>
    <span class="k">def</span> <span class="nf">length</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">value</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Setter</span>
<span class="sd">        :param int value: size&quot;&quot;&quot;</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">length</span> <span class="o">=</span> <span class="n">value</span>

    <span class="nd">@length.deleter</span>
<div class="viewcode-block" id="DCFA.length"><a class="viewcode-back" href="../index.html#fl.DCFA.length">[docs]</a>    <span class="k">def</span> <span class="nf">length</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Length deleter&quot;&quot;&quot;</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">length</span> <span class="o">=</span> <span class="bp">None</span>

</div></div>
<div class="viewcode-block" id="AFA"><a class="viewcode-back" href="../index.html#fl.AFA">[docs]</a><span class="k">class</span> <span class="nc">AFA</span><span class="p">(</span><span class="nb">object</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Base class for Acyclic Finite Automata</span>

<span class="sd">    .. inheritance-diagram:: AFA</span>

<span class="sd">    .. note::</span>
<span class="sd">       This is just a container for some common methods. **Not to be used directly!!**&quot;&quot;&quot;</span>
    <span class="k">def</span> <span class="nf">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">Dead</span> <span class="o">=</span> <span class="bp">None</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">delta</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">()</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">Initial</span> <span class="o">=</span> <span class="bp">None</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">States</span> <span class="o">=</span> <span class="p">[]</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">Final</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>

    <span class="nd">@abstractmethod</span>
<div class="viewcode-block" id="AFA.addState"><a class="viewcode-back" href="../index.html#fl.AFA.addState">[docs]</a>    <span class="k">def</span> <span class="nf">addState</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :rtype: int&quot;&quot;&quot;</span>
        <span class="k">pass</span>
</div>
<div class="viewcode-block" id="AFA.setDeadState"><a class="viewcode-back" href="../index.html#fl.AFA.setDeadState">[docs]</a>    <span class="k">def</span> <span class="nf">setDeadState</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">sti</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Identifies the dead state</span>

<span class="sd">        :param int sti: index of the dead state</span>

<span class="sd">        .. attention::</span>
<span class="sd">           nothing is done to ensure that the state given is legitimate</span>

<span class="sd">        .. note::</span>
<span class="sd">           without dead state identified, most of the methods for acyclic automata can not be applied&quot;&quot;&quot;</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">Dead</span> <span class="o">=</span> <span class="n">sti</span>
</div>
<div class="viewcode-block" id="AFA.ensureDead"><a class="viewcode-back" href="../index.html#fl.AFA.ensureDead">[docs]</a>    <span class="k">def</span> <span class="nf">ensureDead</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Ensures that a state is defined as dead&quot;&quot;&quot;</span>
        <span class="k">try</span><span class="p">:</span>
            <span class="n">_</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">Dead</span>
        <span class="k">except</span> <span class="ne">AttributeError</span><span class="p">:</span>
            <span class="n">x</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">addState</span><span class="p">()</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">setDeadState</span><span class="p">(</span><span class="n">x</span><span class="p">)</span>
</div>
<div class="viewcode-block" id="AFA.ordered"><a class="viewcode-back" href="../index.html#fl.AFA.ordered">[docs]</a>    <span class="k">def</span> <span class="nf">ordered</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Orders states names in its topological order</span>
<span class="sd">    </span>
<span class="sd">        :returns: ordered list of state indexes</span>
<span class="sd">        :rtype: list of int</span>

<span class="sd">        .. note::</span>
<span class="sd">           one could use the FA.toposort() method, but special care must be taken with the dead state for the</span>
<span class="sd">           algorithms related with cover automata.&quot;&quot;&quot;</span>

        <span class="k">def</span> <span class="nf">_dealS</span><span class="p">(</span><span class="n">st1</span><span class="p">):</span>
            <span class="k">if</span> <span class="n">st1</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">torder</span><span class="p">:</span>
                <span class="n">torder</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">st1</span><span class="p">)</span>
                <span class="k">if</span> <span class="n">st1</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="o">.</span><span class="n">keys</span><span class="p">():</span>
                    <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">st1</span><span class="p">]:</span>
                        <span class="k">for</span> <span class="n">dest</span> <span class="ow">in</span> <span class="n">forceIterable</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">st1</span><span class="p">][</span><span class="n">k</span><span class="p">]):</span>
                            <span class="k">if</span> <span class="n">dest</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">torder</span> <span class="ow">and</span> <span class="n">dest</span> <span class="o">!=</span> <span class="bp">self</span><span class="o">.</span><span class="n">Dead</span><span class="p">:</span>
                                <span class="n">queue</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">dest</span><span class="p">)</span>

        <span class="k">try</span><span class="p">:</span>
            <span class="n">dead</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">Dead</span>
        <span class="k">except</span> <span class="ne">AttributeError</span><span class="p">:</span>
            <span class="k">raise</span> <span class="n">FAdoGeneralError</span><span class="p">(</span><span class="s">&quot;ADFA has not dead state identified&quot;</span><span class="p">)</span>
        <span class="n">torder</span><span class="p">,</span> <span class="n">queue</span> <span class="o">=</span> <span class="p">[],</span> <span class="p">[]</span>
        <span class="n">_dealS</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Initial</span><span class="p">)</span>
        <span class="k">while</span> <span class="n">queue</span><span class="p">:</span>
            <span class="n">st</span> <span class="o">=</span> <span class="n">queue</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span>
            <span class="n">_dealS</span><span class="p">(</span><span class="n">st</span><span class="p">)</span>
        <span class="n">torder</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">dead</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">torder</span>
</div>
    <span class="k">def</span> <span class="nf">_getRdelta</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :returns: pair, map of number of sons map, of reverse conectivity</span>
<span class="sd">        :rtype: dict&quot;&quot;&quot;</span>
        <span class="n">done</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
        <span class="n">deltaC</span><span class="p">,</span> <span class="n">rdelta</span> <span class="o">=</span> <span class="p">{},</span> <span class="p">{}</span>
        <span class="n">notDone</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(</span><span class="n">forceIterable</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Initial</span><span class="p">))</span>
        <span class="k">while</span> <span class="n">notDone</span><span class="p">:</span>
            <span class="n">sts</span> <span class="o">=</span> <span class="n">uSet</span><span class="p">(</span><span class="n">notDone</span><span class="p">)</span>
            <span class="n">done</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">sts</span><span class="p">)</span>
            <span class="n">l</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
            <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">sts</span><span class="p">,</span> <span class="p">[]):</span>
                <span class="k">for</span> <span class="n">std</span> <span class="ow">in</span> <span class="n">forceIterable</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">sts</span><span class="p">][</span><span class="n">k</span><span class="p">]):</span>
                    <span class="n">l</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">std</span><span class="p">)</span>
                    <span class="n">rdelta</span><span class="o">.</span><span class="n">setdefault</span><span class="p">(</span><span class="n">std</span><span class="p">,</span> <span class="nb">set</span><span class="p">([]))</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">sts</span><span class="p">)</span>
                    <span class="k">if</span> <span class="n">std</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">done</span><span class="p">:</span>
                        <span class="n">notDone</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">std</span><span class="p">)</span>
            <span class="n">deltaC</span><span class="p">[</span><span class="n">sts</span><span class="p">]</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">l</span><span class="p">)</span>
            <span class="n">notDone</span><span class="o">.</span><span class="n">remove</span><span class="p">(</span><span class="n">sts</span><span class="p">)</span>
        <span class="k">for</span> <span class="n">s</span> <span class="ow">in</span> <span class="n">forceIterable</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Initial</span><span class="p">):</span>
            <span class="k">if</span> <span class="n">s</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">rdelta</span><span class="p">:</span>
                <span class="n">rdelta</span><span class="p">[</span><span class="n">s</span><span class="p">]</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
        <span class="k">return</span> <span class="n">deltaC</span><span class="p">,</span> <span class="n">rdelta</span>

<div class="viewcode-block" id="AFA.directRank"><a class="viewcode-back" href="../index.html#fl.AFA.directRank">[docs]</a>    <span class="k">def</span> <span class="nf">directRank</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Compute rank function</span>

<span class="sd">        :return: ranf map</span>
<span class="sd">        :rtype: dict&quot;&quot;&quot;</span>
        <span class="n">r</span><span class="p">,</span> <span class="n">_</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">evalRank</span><span class="p">()</span>
        <span class="n">n</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="n">r</span><span class="p">:</span>
            <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="n">r</span><span class="p">[</span><span class="n">x</span><span class="p">]:</span>
                <span class="n">n</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="n">x</span>
        <span class="k">return</span> <span class="n">n</span>
</div>
<div class="viewcode-block" id="AFA.evalRank"><a class="viewcode-back" href="../index.html#fl.AFA.evalRank">[docs]</a>    <span class="k">def</span> <span class="nf">evalRank</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Evaluates the rank map of a automaton</span>

<span class="sd">        :return: pair of sets of states by rank map, reverse delta accessability map</span>
<span class="sd">        :rtype: tuple&quot;&quot;&quot;</span>
        <span class="p">(</span><span class="n">deltaC</span><span class="p">,</span> <span class="n">rdelta</span><span class="p">)</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">_getRdelta</span><span class="p">()</span>
        <span class="n">rank</span><span class="p">,</span> <span class="n">deltai</span> <span class="o">=</span> <span class="p">{},</span> <span class="p">{}</span>
        <span class="k">for</span> <span class="n">s</span> <span class="ow">in</span> <span class="nb">xrange</span><span class="p">(</span><span class="nb">len</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">States</span><span class="p">)):</span>
            <span class="n">deltai</span><span class="o">.</span><span class="n">setdefault</span><span class="p">(</span><span class="n">deltaC</span><span class="p">[</span><span class="n">s</span><span class="p">],</span> <span class="nb">set</span><span class="p">([]))</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
        <span class="n">i</span> <span class="o">=</span> <span class="o">-</span><span class="mi">1</span>
        <span class="n">notDone</span> <span class="o">=</span> <span class="n">copy</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="bp">self</span><span class="o">.</span><span class="n">States</span><span class="p">)))</span>
        <span class="n">deltaC</span><span class="p">[</span><span class="bp">self</span><span class="o">.</span><span class="n">Dead</span><span class="p">]</span> <span class="o">=</span> <span class="mi">0</span>
        <span class="n">deltai</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span><span class="o">.</span><span class="n">remove</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Dead</span><span class="p">)</span>
        <span class="n">deltai</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="o">=</span> <span class="p">{</span><span class="bp">self</span><span class="o">.</span><span class="n">Dead</span><span class="p">}</span>
        <span class="n">rdelta</span><span class="p">[</span><span class="bp">self</span><span class="o">.</span><span class="n">Dead</span><span class="p">]</span><span class="o">.</span><span class="n">remove</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Dead</span><span class="p">)</span>
        <span class="k">while</span> <span class="n">notDone</span><span class="p">:</span>
            <span class="n">rank</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="n">deepcopy</span><span class="p">(</span><span class="n">deltai</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span>
            <span class="n">deltai</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
            <span class="k">for</span> <span class="n">s</span> <span class="ow">in</span> <span class="n">rank</span><span class="p">[</span><span class="n">i</span><span class="p">]:</span>
                <span class="k">for</span> <span class="n">s1</span> <span class="ow">in</span> <span class="n">rdelta</span><span class="p">[</span><span class="n">s</span><span class="p">]:</span>
                    <span class="n">l</span> <span class="o">=</span> <span class="n">deltaC</span><span class="p">[</span><span class="n">s1</span><span class="p">]</span>
                    <span class="n">deltaC</span><span class="p">[</span><span class="n">s1</span><span class="p">]</span> <span class="o">=</span> <span class="n">l</span> <span class="o">-</span> <span class="mi">1</span>
                    <span class="n">deltai</span><span class="p">[</span><span class="n">l</span><span class="p">]</span><span class="o">.</span><span class="n">remove</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
                    <span class="n">deltai</span><span class="o">.</span><span class="n">setdefault</span><span class="p">(</span><span class="n">l</span> <span class="o">-</span> <span class="mi">1</span><span class="p">,</span> <span class="nb">set</span><span class="p">())</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
                <span class="n">notDone</span><span class="o">.</span><span class="n">remove</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
            <span class="n">i</span> <span class="o">+=</span> <span class="mi">1</span>
        <span class="k">return</span> <span class="n">rank</span><span class="p">,</span> <span class="n">rdelta</span>
</div>
<div class="viewcode-block" id="AFA.getLeaves"><a class="viewcode-back" href="../index.html#fl.AFA.getLeaves">[docs]</a>    <span class="k">def</span> <span class="nf">getLeaves</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;The set of leaves, i.e. final states for last symbols of language words</span>

<span class="sd">        :return: set of leaves</span>
<span class="sd">        :rtype: set&quot;&quot;&quot;</span>

        <span class="c"># noinspection PyUnresolvedReferences</span>
        <span class="k">def</span> <span class="nf">_last</span><span class="p">(</span><span class="n">s1</span><span class="p">):</span>
            <span class="n">queue</span><span class="p">,</span> <span class="n">done</span> <span class="o">=</span> <span class="p">{</span><span class="n">s1</span><span class="p">},</span> <span class="nb">set</span><span class="p">()</span>
            <span class="k">while</span> <span class="n">queue</span><span class="p">:</span>
                <span class="n">q</span> <span class="o">=</span> <span class="n">queue</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span>
                <span class="n">done</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">q</span><span class="p">)</span>
                <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">q</span><span class="p">,</span> <span class="p">{}):</span>
                    <span class="k">for</span> <span class="n">s1</span> <span class="ow">in</span> <span class="n">forceIterable</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">q</span><span class="p">][</span><span class="n">k</span><span class="p">]):</span>
                        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">finalP</span><span class="p">(</span><span class="n">s1</span><span class="p">):</span>
                            <span class="k">return</span> <span class="bp">False</span>
                        <span class="k">elif</span> <span class="n">s1</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">done</span><span class="p">:</span>
                            <span class="n">queue</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
            <span class="k">return</span> <span class="bp">True</span>

        <span class="n">leaves</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
        <span class="k">for</span> <span class="n">s</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">Final</span><span class="p">:</span>
            <span class="k">if</span> <span class="n">_last</span><span class="p">(</span><span class="n">s</span><span class="p">):</span>
                <span class="n">leaves</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">States</span><span class="p">[</span><span class="n">s</span><span class="p">])</span>
        <span class="k">return</span> <span class="n">leaves</span>

</div></div>
<div class="viewcode-block" id="ADFA"><a class="viewcode-back" href="../index.html#fl.ADFA">[docs]</a><span class="k">class</span> <span class="nc">ADFA</span><span class="p">(</span><span class="n">fa</span><span class="o">.</span><span class="n">DFA</span><span class="p">,</span> <span class="n">AFA</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Acyclic Deterministic Finite Automata class</span>

<span class="sd">    .. inheritance-diagram:: ADFA&quot;&quot;&quot;</span>
    <span class="k">def</span> <span class="nf">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="n">fa</span><span class="o">.</span><span class="n">DFA</span><span class="o">.</span><span class="n">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">)</span>
        <span class="n">AFA</span><span class="o">.</span><span class="n">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">__repr__</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="k">return</span> <span class="s">&#39;ADFA({0:s})&#39;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">__str__</span><span class="p">())</span>

<div class="viewcode-block" id="ADFA.complete"><a class="viewcode-back" href="../index.html#fl.ADFA.complete">[docs]</a>    <span class="k">def</span> <span class="nf">complete</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">dead</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Make the ADFA complete</span>

<span class="sd">        :param int dead: a state to be identified as dead state if one was not identified yet</span>
<span class="sd">        :rtype: ADFA</span>

<span class="sd">        .. attention::</span>
<span class="sd">           The object is modified in place&quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="n">dead</span> <span class="ow">is</span> <span class="ow">not</span> <span class="bp">None</span><span class="p">:</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">Dead</span> <span class="o">=</span> <span class="n">dead</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">try</span><span class="p">:</span>
                <span class="n">_</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">Dead</span>
            <span class="k">except</span> <span class="ne">AttributeError</span><span class="p">:</span>
                <span class="n">foo</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">addState</span><span class="p">()</span>
                <span class="bp">self</span><span class="o">.</span><span class="n">Dead</span> <span class="o">=</span> <span class="n">foo</span>
        <span class="k">for</span> <span class="n">st</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="nb">len</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">States</span><span class="p">)):</span>
            <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">:</span>
                <span class="k">if</span> <span class="n">k</span> <span class="ow">not</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">st</span><span class="p">,</span> <span class="p">{})</span><span class="o">.</span><span class="n">keys</span><span class="p">():</span>
                    <span class="bp">self</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="n">st</span><span class="p">,</span> <span class="n">k</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">Dead</span><span class="p">)</span>
        <span class="k">return</span> <span class="bp">self</span>
</div>
<div class="viewcode-block" id="ADFA.dup"><a class="viewcode-back" href="../index.html#fl.ADFA.dup">[docs]</a>    <span class="k">def</span> <span class="nf">dup</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Duplicate the basic structure into a new ADFA. Basically a copy.deep.</span>

<span class="sd">        :rtype: ADFA&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="n">deepcopy</span><span class="p">(</span><span class="bp">self</span><span class="p">)</span>
</div>
<div class="viewcode-block" id="ADFA.minimalP"><a class="viewcode-back" href="../index.html#fl.ADFA.minimalP">[docs]</a>    <span class="k">def</span> <span class="nf">minimalP</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">method</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Tests if the DFA is minimal</span>

<span class="sd">        :param method: minimization algorithm (here void)</span>
<span class="sd">        :rtype: bool&quot;&quot;&quot;</span>
        <span class="n">foo</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">minimal</span><span class="p">()</span>
        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">completeP</span><span class="p">():</span>
            <span class="n">foo</span><span class="o">.</span><span class="n">complete</span><span class="p">()</span>
        <span class="k">return</span> <span class="nb">len</span><span class="p">(</span><span class="n">foo</span><span class="p">)</span> <span class="o">==</span> <span class="nb">len</span><span class="p">(</span><span class="bp">self</span><span class="p">)</span>
</div>
<div class="viewcode-block" id="ADFA.forceToDCFA"><a class="viewcode-back" href="../index.html#fl.ADFA.forceToDCFA">[docs]</a>    <span class="k">def</span> <span class="nf">forceToDCFA</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot; Conversion to DCFA</span>

<span class="sd">        :rtype: DFA&quot;&quot;&quot;</span>
        <span class="n">new</span> <span class="o">=</span> <span class="n">fa</span><span class="o">.</span><span class="n">DFA</span><span class="p">()</span>
        <span class="n">new</span><span class="o">.</span><span class="n">States</span> <span class="o">=</span> <span class="n">deepcopy</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">States</span><span class="p">)</span>
        <span class="n">new</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">=</span> <span class="n">deepcopy</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">)</span>
        <span class="n">new</span><span class="o">.</span><span class="n">Initial</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">Initial</span>
        <span class="n">new</span><span class="o">.</span><span class="n">Final</span> <span class="o">=</span> <span class="n">copy</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Final</span><span class="p">)</span>
        <span class="k">for</span> <span class="n">s</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">:</span>
            <span class="k">for</span> <span class="n">c</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">s</span><span class="p">]:</span>
                <span class="n">new</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">c</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">s</span><span class="p">][</span><span class="n">c</span><span class="p">])</span>
        <span class="k">return</span> <span class="n">new</span>
</div>
<div class="viewcode-block" id="ADFA.wordGenerator"><a class="viewcode-back" href="../index.html#fl.ADFA.wordGenerator">[docs]</a>    <span class="k">def</span> <span class="nf">wordGenerator</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Creates a random word generator</span>

<span class="sd">        :return: the random word generator</span>
<span class="sd">        :rtype: RndWGen</span>

<span class="sd">        .. versionadded:: 1.2&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="n">RndWGen</span><span class="p">(</span><span class="bp">self</span><span class="p">)</span>
</div>
<div class="viewcode-block" id="ADFA.minimal"><a class="viewcode-back" href="../index.html#fl.ADFA.minimal">[docs]</a>    <span class="k">def</span> <span class="nf">minimal</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Finds the minimal equivalent ADFA</span>

<span class="sd">        .. seealso:: [TCS 92 pp 181-189] Minimisation of acyclic deterministic automata in linear time, Dominique Revuz</span>

<span class="sd">        :returns: the minimal equivalent ADFA</span>
<span class="sd">        :rtype: ADFA&quot;&quot;&quot;</span>

        <span class="k">def</span> <span class="nf">_getListDelta</span><span class="p">(</span><span class="n">ss</span><span class="p">):</span>
            <span class="sd">&quot;&quot;&quot;returns [([sons,final?],s) for s in ss].sort&quot;&quot;&quot;</span>
            <span class="n">l</span> <span class="o">=</span> <span class="p">[]</span>
            <span class="k">for</span> <span class="n">s</span> <span class="ow">in</span> <span class="n">ss</span><span class="p">:</span>
                <span class="n">dl</span> <span class="o">=</span> <span class="p">[</span><span class="n">new</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">s</span><span class="p">][</span><span class="n">k</span><span class="p">]</span> <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="n">new</span><span class="o">.</span><span class="n">Sigma</span><span class="p">]</span>
                <span class="n">dl</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">s</span> <span class="ow">in</span> <span class="n">new</span><span class="o">.</span><span class="n">Final</span><span class="p">)</span>
                <span class="n">l</span><span class="o">.</span><span class="n">append</span><span class="p">((</span><span class="n">dl</span><span class="p">,</span> <span class="n">s</span><span class="p">))</span>
            <span class="n">l</span><span class="o">.</span><span class="n">sort</span><span class="p">()</span>
            <span class="k">return</span> <span class="n">l</span>

        <span class="k">def</span> <span class="nf">_collapse</span><span class="p">(</span><span class="n">r1</span><span class="p">,</span> <span class="n">r2</span><span class="p">):</span>
            <span class="sd">&quot;&quot;&quot;redirects all transitions going to r2 to r1 and adds r2 to toBeDeleted&quot;&quot;&quot;</span>
            <span class="k">for</span> <span class="n">s</span> <span class="ow">in</span> <span class="n">rdelta</span><span class="p">[</span><span class="n">r2</span><span class="p">]:</span>
                <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="n">new</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">s</span><span class="p">]:</span>
                    <span class="k">if</span> <span class="n">new</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">s</span><span class="p">][</span><span class="n">k</span><span class="p">]</span> <span class="o">==</span> <span class="n">r2</span><span class="p">:</span>
                        <span class="n">new</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">s</span><span class="p">][</span><span class="n">k</span><span class="p">]</span> <span class="o">=</span> <span class="n">r1</span>
            <span class="n">toBeDeleted</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">r2</span><span class="p">)</span>

        <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">States</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
            <span class="k">return</span> <span class="bp">self</span>
        <span class="n">new</span> <span class="o">=</span> <span class="n">deepcopy</span><span class="p">(</span><span class="bp">self</span><span class="p">)</span>
        <span class="n">new</span><span class="o">.</span><span class="n">trim</span><span class="p">()</span>
        <span class="n">new</span><span class="o">.</span><span class="n">complete</span><span class="p">()</span>
        <span class="k">if</span> <span class="n">new</span><span class="o">.</span><span class="n">Dead</span> <span class="ow">is</span> <span class="bp">None</span><span class="p">:</span>
            <span class="n">deadName</span> <span class="o">=</span> <span class="bp">None</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="n">deadName</span> <span class="o">=</span> <span class="n">new</span><span class="o">.</span><span class="n">States</span><span class="p">[</span><span class="n">new</span><span class="o">.</span><span class="n">Dead</span><span class="p">]</span>
        <span class="p">(</span><span class="n">rank</span><span class="p">,</span> <span class="n">rdelta</span><span class="p">)</span> <span class="o">=</span> <span class="n">new</span><span class="o">.</span><span class="n">evalRank</span><span class="p">()</span>
        <span class="n">toBeDeleted</span> <span class="o">=</span> <span class="p">[]</span>
        <span class="n">maxr</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">rank</span><span class="p">)</span> <span class="o">-</span> <span class="mi">2</span>
        <span class="k">for</span> <span class="n">r</span> <span class="ow">in</span> <span class="nb">xrange</span><span class="p">(</span><span class="n">maxr</span> <span class="o">+</span> <span class="mi">1</span><span class="p">):</span>
            <span class="n">ls</span> <span class="o">=</span> <span class="n">_getListDelta</span><span class="p">(</span><span class="n">rank</span><span class="p">[</span><span class="n">r</span><span class="p">])</span>
            <span class="p">(</span><span class="n">d0</span><span class="p">,</span> <span class="n">s0</span><span class="p">)</span> <span class="o">=</span> <span class="n">ls</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span>
            <span class="n">j</span> <span class="o">=</span> <span class="mi">1</span>
            <span class="k">while</span> <span class="n">j</span> <span class="o">&lt;</span> <span class="nb">len</span><span class="p">(</span><span class="n">ls</span><span class="p">):</span>
                <span class="p">(</span><span class="n">d1</span><span class="p">,</span> <span class="n">s1</span><span class="p">)</span> <span class="o">=</span> <span class="n">ls</span><span class="p">[</span><span class="n">j</span><span class="p">]</span>
                <span class="k">if</span> <span class="n">d0</span> <span class="o">==</span> <span class="n">d1</span><span class="p">:</span>
                    <span class="n">_collapse</span><span class="p">(</span><span class="n">s0</span><span class="p">,</span> <span class="n">s1</span><span class="p">)</span>
                <span class="k">else</span><span class="p">:</span>
                    <span class="p">(</span><span class="n">d0</span><span class="p">,</span> <span class="n">s0</span><span class="p">)</span> <span class="o">=</span> <span class="p">(</span><span class="n">d1</span><span class="p">,</span> <span class="n">s1</span><span class="p">)</span>
                <span class="n">j</span> <span class="o">+=</span> <span class="mi">1</span>
        <span class="n">new</span><span class="o">.</span><span class="n">deleteStates</span><span class="p">(</span><span class="n">toBeDeleted</span><span class="p">)</span>
        <span class="k">if</span> <span class="n">deadName</span> <span class="ow">is</span> <span class="ow">not</span> <span class="bp">None</span><span class="p">:</span>
            <span class="n">new</span><span class="o">.</span><span class="n">Dead</span> <span class="o">=</span> <span class="n">new</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">deadName</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">new</span>
</div>
<div class="viewcode-block" id="ADFA.level"><a class="viewcode-back" href="../index.html#fl.ADFA.level">[docs]</a>    <span class="k">def</span> <span class="nf">level</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Computes the level  for each state</span>

<span class="sd">        :returns: levels of states</span>
<span class="sd">        :rtype: dict</span>

<span class="sd">        .. versionadded:: 0.9.8&quot;&quot;&quot;</span>
        <span class="n">lvl</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="n">done</span><span class="p">,</span> <span class="n">alvl</span> <span class="o">=</span> <span class="nb">set</span><span class="p">(),</span> <span class="p">[</span><span class="bp">self</span><span class="o">.</span><span class="n">Initial</span><span class="p">]</span>
        <span class="n">l</span> <span class="o">=</span> <span class="mi">0</span>
        <span class="k">while</span> <span class="n">alvl</span><span class="p">:</span>
            <span class="n">nlvl</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
            <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="n">alvl</span><span class="p">:</span>
                <span class="n">lvl</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="n">l</span>
                <span class="n">done</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">i</span><span class="p">)</span>
                <span class="k">for</span> <span class="n">c</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">i</span><span class="p">]:</span>
                    <span class="n">j</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">i</span><span class="p">][</span><span class="n">c</span><span class="p">]</span>
                    <span class="k">if</span> <span class="n">j</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">done</span> <span class="ow">and</span> <span class="n">j</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">alvl</span><span class="p">:</span>
                        <span class="n">nlvl</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">j</span><span class="p">)</span>
            <span class="n">l</span> <span class="o">+=</span> <span class="mi">1</span>
            <span class="n">alvl</span> <span class="o">=</span> <span class="n">copy</span><span class="p">(</span><span class="n">nlvl</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">lvl</span>
</div>
    <span class="k">def</span> <span class="nf">_gap</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">l</span><span class="p">,</span> <span class="n">lvl</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Computes the gap value for each pair of states.</span>

<span class="sd">        The automata is supposed to have its states named numerically in such way that the initial is zero</span>

<span class="sd">        :param int l: length of the longest word</span>
<span class="sd">        :param dict lvl: level of each state</span>
<span class="sd">        :returns: gap function</span>
<span class="sd">        :rtype: dict&quot;&quot;&quot;</span>
        <span class="k">def</span> <span class="nf">_range</span><span class="p">(</span><span class="n">r</span><span class="p">,</span> <span class="n">s</span><span class="p">):</span>
            <span class="k">return</span> <span class="n">l</span> <span class="o">-</span> <span class="nb">max</span><span class="p">(</span><span class="n">lvl</span><span class="p">[</span><span class="n">r</span><span class="p">],</span> <span class="n">lvl</span><span class="p">[</span><span class="n">s</span><span class="p">])</span>
        <span class="n">gp</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="n">n</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">States</span><span class="p">)</span> <span class="o">-</span> <span class="mi">1</span>
        <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n</span><span class="p">):</span>
            <span class="n">gp</span><span class="p">[(</span><span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">i</span><span class="p">),</span> <span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">n</span><span class="p">))]</span> <span class="o">=</span> <span class="n">l</span>
        <span class="k">if</span> <span class="n">lvl</span><span class="p">[</span><span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">n</span><span class="p">)]</span> <span class="o">&lt;=</span> <span class="n">l</span><span class="p">:</span>
            <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">Final</span><span class="p">:</span>
                <span class="n">gp</span><span class="p">[(</span><span class="n">i</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">n</span><span class="p">))]</span> <span class="o">=</span> <span class="mi">0</span>
        <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n</span><span class="p">):</span>
            <span class="k">for</span> <span class="n">j</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">i</span> <span class="o">+</span> <span class="mi">1</span><span class="p">,</span> <span class="n">n</span><span class="p">):</span>
                <span class="k">if</span> <span class="ow">not</span> <span class="bp">self</span><span class="o">.</span><span class="n">same_nullability</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">i</span><span class="p">),</span> <span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">j</span><span class="p">)):</span>
                    <span class="n">gp</span><span class="p">[(</span><span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">i</span><span class="p">),</span> <span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">j</span><span class="p">))]</span> <span class="o">=</span> <span class="mi">0</span>
                <span class="k">else</span><span class="p">:</span>
                    <span class="n">gp</span><span class="p">[(</span><span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">i</span><span class="p">),</span> <span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">j</span><span class="p">))]</span> <span class="o">=</span> <span class="n">l</span>
        <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n</span> <span class="o">-</span> <span class="mi">2</span><span class="p">,</span> <span class="o">-</span><span class="mi">1</span><span class="p">,</span> <span class="o">-</span><span class="mi">1</span><span class="p">):</span>
            <span class="k">for</span> <span class="n">j</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n</span><span class="p">,</span> <span class="n">i</span><span class="p">,</span> <span class="o">-</span><span class="mi">1</span><span class="p">):</span>
                <span class="k">for</span> <span class="n">c</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">:</span>
                    <span class="n">i1</span><span class="p">,</span> <span class="n">j1</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">i</span><span class="p">)][</span><span class="n">c</span><span class="p">],</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">j</span><span class="p">)][</span><span class="n">c</span><span class="p">]</span>
                    <span class="k">if</span> <span class="n">i1</span> <span class="o">!=</span> <span class="n">j1</span><span class="p">:</span>
                        <span class="k">if</span> <span class="nb">int</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">States</span><span class="p">[</span><span class="n">i1</span><span class="p">])</span> <span class="o">&lt;</span> <span class="nb">int</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">States</span><span class="p">[</span><span class="n">j1</span><span class="p">]):</span>
                            <span class="n">g</span> <span class="o">=</span> <span class="n">gp</span><span class="p">[(</span><span class="n">i1</span><span class="p">,</span> <span class="n">j1</span><span class="p">)]</span>
                        <span class="k">else</span><span class="p">:</span>
                            <span class="n">g</span> <span class="o">=</span> <span class="n">gp</span><span class="p">[(</span><span class="n">j1</span><span class="p">,</span> <span class="n">i1</span><span class="p">)]</span>
                        <span class="k">if</span> <span class="n">g</span> <span class="o">+</span> <span class="mi">1</span> <span class="o">&lt;=</span> <span class="n">_range</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">i</span><span class="p">),</span> <span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">j</span><span class="p">)):</span>
                            <span class="n">gp</span><span class="p">[(</span><span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">i</span><span class="p">),</span> <span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">j</span><span class="p">))]</span> <span class="o">=</span> <span class="nb">min</span><span class="p">(</span><span class="n">gp</span><span class="p">[(</span><span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">i</span><span class="p">),</span>
                                                                                   <span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">j</span><span class="p">))],</span> <span class="n">g</span> <span class="o">+</span> <span class="mi">1</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">gp</span>

<div class="viewcode-block" id="ADFA.minDFCA"><a class="viewcode-back" href="../index.html#fl.ADFA.minDFCA">[docs]</a>    <span class="k">def</span> <span class="nf">minDFCA</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Generates a minimal deterministic cover automata from a DFA</span>

<span class="sd">        :rtype: DCFA</span>

<span class="sd">        .. versionadded:: 0.9.8</span>

<span class="sd">        .. seealso::</span>
<span class="sd">            Cezar Campeanu, Andrei Päun, and Sheng Yu, An efficient algorithm for constructing minimal cover</span>
<span class="sd">            automata for finite languages, IJFCS&quot;&quot;&quot;</span>
        <span class="n">new</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">dup</span><span class="p">()</span>
        <span class="k">if</span> <span class="ow">not</span> <span class="bp">self</span><span class="o">.</span><span class="n">completeP</span><span class="p">():</span>
            <span class="n">new</span><span class="o">.</span><span class="n">complete</span><span class="p">()</span>
        <span class="n">rank</span> <span class="o">=</span> <span class="n">new</span><span class="o">.</span><span class="n">directRank</span><span class="p">()</span>
        <span class="n">irank</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">((</span><span class="n">v</span><span class="p">,</span> <span class="p">[</span><span class="n">k</span> <span class="k">for</span> <span class="p">(</span><span class="n">k</span><span class="p">,</span> <span class="n">xx</span><span class="p">)</span> <span class="ow">in</span> <span class="nb">filter</span><span class="p">(</span><span class="k">lambda</span> <span class="p">(</span><span class="n">key</span><span class="p">,</span> <span class="n">value</span><span class="p">):</span> <span class="n">value</span> <span class="o">==</span> <span class="n">v</span><span class="p">,</span> <span class="n">rank</span><span class="o">.</span><span class="n">items</span><span class="p">())])</span>
                     <span class="k">for</span> <span class="n">v</span> <span class="ow">in</span> <span class="nb">set</span><span class="p">(</span><span class="n">rank</span><span class="o">.</span><span class="n">values</span><span class="p">()))</span>
        <span class="n">l</span> <span class="o">=</span> <span class="n">rank</span><span class="p">[</span><span class="n">new</span><span class="o">.</span><span class="n">Initial</span><span class="p">]</span>
        <span class="n">lvl</span> <span class="o">=</span> <span class="n">new</span><span class="o">.</span><span class="n">level</span><span class="p">()</span>
        <span class="n">lnames</span> <span class="o">=</span> <span class="p">[]</span>
        <span class="n">foo</span> <span class="o">=</span> <span class="p">[</span><span class="n">x</span> <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="n">irank</span><span class="p">]</span>
        <span class="n">foo</span><span class="o">.</span><span class="n">sort</span><span class="p">(</span><span class="n">reverse</span><span class="o">=</span><span class="bp">True</span><span class="p">)</span>
        <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="n">foo</span><span class="p">:</span>
            <span class="k">for</span> <span class="n">j</span> <span class="ow">in</span> <span class="n">irank</span><span class="p">[</span><span class="n">i</span><span class="p">]:</span>
                <span class="n">lnames</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">j</span><span class="p">)</span>
        <span class="n">new</span><span class="o">.</span><span class="n">renameStates</span><span class="p">(</span><span class="n">lnames</span><span class="p">)</span>
        <span class="n">g</span> <span class="o">=</span> <span class="n">new</span><span class="o">.</span><span class="n">_gap</span><span class="p">(</span><span class="n">l</span><span class="p">,</span> <span class="n">lvl</span><span class="p">)</span>
        <span class="n">P</span> <span class="o">=</span> <span class="p">[</span><span class="bp">False</span> <span class="k">for</span> <span class="n">_</span> <span class="ow">in</span> <span class="n">new</span><span class="o">.</span><span class="n">States</span><span class="p">]</span>
        <span class="n">toMerge</span> <span class="o">=</span> <span class="p">[]</span>
        <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="nb">len</span><span class="p">(</span><span class="n">new</span><span class="o">.</span><span class="n">States</span><span class="p">)</span> <span class="o">-</span> <span class="mi">1</span><span class="p">):</span>
            <span class="k">if</span> <span class="ow">not</span> <span class="n">P</span><span class="p">[</span><span class="n">i</span><span class="p">]:</span>
                <span class="k">for</span> <span class="n">j</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">i</span> <span class="o">+</span> <span class="mi">1</span><span class="p">,</span> <span class="nb">len</span><span class="p">(</span><span class="n">new</span><span class="o">.</span><span class="n">States</span><span class="p">)):</span>
                    <span class="k">if</span> <span class="ow">not</span> <span class="n">P</span><span class="p">[</span><span class="n">j</span><span class="p">]</span> <span class="ow">and</span> <span class="n">g</span><span class="p">[(</span><span class="n">new</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">i</span><span class="p">),</span> <span class="n">new</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">j</span><span class="p">))]</span> <span class="o">==</span> <span class="n">l</span><span class="p">:</span>
                        <span class="n">toMerge</span><span class="o">.</span><span class="n">append</span><span class="p">((</span><span class="n">new</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">i</span><span class="p">),</span> <span class="n">new</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">j</span><span class="p">)))</span>
                        <span class="n">P</span><span class="p">[</span><span class="n">j</span><span class="p">]</span> <span class="o">=</span> <span class="bp">True</span>
        <span class="k">for</span> <span class="p">(</span><span class="n">a</span><span class="p">,</span> <span class="n">b</span><span class="p">)</span> <span class="ow">in</span> <span class="n">toMerge</span><span class="p">:</span>
            <span class="n">new</span><span class="o">.</span><span class="n">mergeStates</span><span class="p">(</span><span class="n">b</span><span class="p">,</span> <span class="n">a</span><span class="p">)</span>
        <span class="n">new</span><span class="o">.</span><span class="n">trim</span><span class="p">()</span>
        <span class="n">new</span> <span class="o">=</span> <span class="n">new</span><span class="o">.</span><span class="n">forceToDCFA</span><span class="p">()</span>
        <span class="n">new</span><span class="o">.</span><span class="n">Length</span> <span class="o">=</span> <span class="n">l</span>
        <span class="k">return</span> <span class="n">new</span>
</div>
<div class="viewcode-block" id="ADFA.trim"><a class="viewcode-back" href="../index.html#fl.ADFA.trim">[docs]</a>    <span class="k">def</span> <span class="nf">trim</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Remove states that do not lead to a final state, or, inclusively, that can&#39;t be reached from the initial</span>
<span class="sd">        state. Only useful states remain.</span>

<span class="sd">        .. attention:: in place transformation&quot;&quot;&quot;</span>
        <span class="n">fa</span><span class="o">.</span><span class="n">OFA</span><span class="o">.</span><span class="n">trim</span><span class="p">(</span><span class="bp">self</span><span class="p">)</span>
        <span class="k">try</span><span class="p">:</span>
            <span class="k">del</span> <span class="bp">self</span><span class="o">.</span><span class="n">Dead</span>
        <span class="k">except</span> <span class="ne">AttributeError</span><span class="p">:</span>
            <span class="k">pass</span>
        <span class="k">return</span> <span class="bp">self</span>
</div>
<div class="viewcode-block" id="ADFA.toANFA"><a class="viewcode-back" href="../index.html#fl.ADFA.toANFA">[docs]</a>    <span class="k">def</span> <span class="nf">toANFA</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Converts the ADFA in a equivalent ANFA</span>

<span class="sd">        :rtype: ANFA&quot;&quot;&quot;</span>
        <span class="n">new</span> <span class="o">=</span> <span class="n">ANFA</span><span class="p">()</span>
        <span class="n">new</span><span class="o">.</span><span class="n">setSigma</span><span class="p">(</span><span class="n">copy</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">))</span>
        <span class="n">new</span><span class="o">.</span><span class="n">States</span> <span class="o">=</span> <span class="n">copy</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">States</span><span class="p">)</span>
        <span class="k">for</span> <span class="n">s</span> <span class="ow">in</span> <span class="nb">xrange</span><span class="p">(</span><span class="nb">len</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">States</span><span class="p">)):</span>
            <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="p">{}):</span>
                <span class="n">new</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">k</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">s</span><span class="p">][</span><span class="n">k</span><span class="p">])</span>
        <span class="n">new</span><span class="o">.</span><span class="n">addInitial</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Initial</span><span class="p">)</span>
        <span class="k">for</span> <span class="n">s</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">Final</span><span class="p">:</span>
            <span class="n">new</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">new</span>
</div>
<div class="viewcode-block" id="ADFA.toNFA"><a class="viewcode-back" href="../index.html#fl.ADFA.toNFA">[docs]</a>    <span class="k">def</span> <span class="nf">toNFA</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Converts the ADFA in a equivalent NFA</span>

<span class="sd">        :rtype: ANFA</span>

<span class="sd">        .. versionadded:: 1.2&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">toANFA</span><span class="p">()</span>

</div></div>
<div class="viewcode-block" id="RndWGen"><a class="viewcode-back" href="../index.html#fl.RndWGen">[docs]</a><span class="k">class</span> <span class="nc">RndWGen</span><span class="p">(</span><span class="nb">object</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Word random generator class</span>

<span class="sd">    .. versionadded:: 1.2&quot;&quot;&quot;</span>
    <span class="k">def</span> <span class="nf">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">aut</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param aut: automata recognizing the language</span>
<span class="sd">        :type aut: ADFA &quot;&quot;&quot;</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">=</span> <span class="nb">list</span><span class="p">(</span><span class="n">aut</span><span class="o">.</span><span class="n">Sigma</span><span class="p">)</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">table</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">()</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">aut</span> <span class="o">=</span> <span class="n">aut</span><span class="o">.</span><span class="n">minimal</span><span class="p">()</span>
        <span class="n">rank</span><span class="p">,</span> <span class="n">_</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">aut</span><span class="o">.</span><span class="n">evalRank</span><span class="p">()</span>
        <span class="n">deltai</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">aut</span><span class="o">.</span><span class="n">deltaR</span><span class="p">()</span>
        <span class="n">mrank</span> <span class="o">=</span> <span class="nb">max</span><span class="p">(</span><span class="n">rank</span><span class="p">)</span>
        <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="n">mrank</span> <span class="o">+</span> <span class="mi">1</span><span class="p">):</span>
            <span class="k">for</span> <span class="n">s</span> <span class="ow">in</span> <span class="n">rank</span><span class="p">[</span><span class="n">i</span><span class="p">]:</span>
                <span class="bp">self</span><span class="o">.</span><span class="n">table</span><span class="o">.</span><span class="n">setdefault</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="p">{})</span>
                <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">aut</span><span class="o">.</span><span class="n">finalP</span><span class="p">(</span><span class="n">s</span><span class="p">):</span>
                    <span class="n">final</span> <span class="o">=</span> <span class="mi">1</span>
                <span class="k">else</span><span class="p">:</span>
                    <span class="n">final</span> <span class="o">=</span> <span class="mi">0</span>
                <span class="bp">self</span><span class="o">.</span><span class="n">table</span><span class="p">[</span><span class="n">s</span><span class="p">][</span><span class="bp">None</span><span class="p">]</span> <span class="o">=</span> <span class="nb">sum</span><span class="p">([</span><span class="bp">self</span><span class="o">.</span><span class="n">table</span><span class="p">[</span><span class="n">s</span><span class="p">]</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">c</span><span class="p">,</span> <span class="mi">0</span><span class="p">)</span> <span class="k">for</span> <span class="n">c</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">])</span>
                <span class="k">for</span> <span class="n">c</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">:</span>
                    <span class="n">rs</span> <span class="o">=</span> <span class="n">deltai</span><span class="p">[</span><span class="n">s</span><span class="p">]</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">c</span><span class="p">,</span> <span class="p">[])</span>
                    <span class="k">for</span> <span class="n">r</span> <span class="ow">in</span> <span class="n">rs</span><span class="p">:</span>
                        <span class="bp">self</span><span class="o">.</span><span class="n">table</span><span class="o">.</span><span class="n">setdefault</span><span class="p">(</span><span class="n">r</span><span class="p">,</span> <span class="p">{})</span>
                        <span class="bp">self</span><span class="o">.</span><span class="n">table</span><span class="p">[</span><span class="n">r</span><span class="p">][</span><span class="n">c</span><span class="p">]</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">table</span><span class="p">[</span><span class="n">s</span><span class="p">][</span><span class="bp">None</span><span class="p">]</span> <span class="o">+</span> <span class="n">final</span>

    <span class="nd">@staticmethod</span>
    <span class="k">def</span> <span class="nf">_rndChoose</span><span class="p">(</span><span class="n">l</span><span class="p">):</span>
        <span class="n">sm</span> <span class="o">=</span> <span class="nb">sum</span><span class="p">(</span><span class="n">l</span><span class="p">)</span>
        <span class="n">r</span> <span class="o">=</span> <span class="n">random</span><span class="o">.</span><span class="n">randint</span><span class="p">(</span><span class="mi">1</span><span class="p">,</span><span class="n">sm</span><span class="p">)</span>
        <span class="k">for</span> <span class="n">i</span><span class="p">,</span> <span class="n">j</span> <span class="ow">in</span> <span class="nb">enumerate</span><span class="p">(</span><span class="n">l</span><span class="p">):</span>
            <span class="k">if</span> <span class="n">r</span> <span class="o">&lt;=</span> <span class="n">j</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">i</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="n">r</span> <span class="o">-=</span> <span class="n">j</span>

<div class="viewcode-block" id="RndWGen.next"><a class="viewcode-back" href="../index.html#fl.RndWGen.next">[docs]</a>    <span class="k">def</span> <span class="nf">next</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Next word</span>

<span class="sd">        :return: a new random word&quot;&quot;&quot;</span>
        <span class="n">word</span> <span class="o">=</span> <span class="n">Word</span><span class="p">()</span>
        <span class="n">s</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">aut</span><span class="o">.</span><span class="n">Initial</span>
        <span class="k">while</span> <span class="bp">True</span><span class="p">:</span>
            <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">aut</span><span class="o">.</span><span class="n">finalP</span><span class="p">(</span><span class="n">s</span><span class="p">)</span> <span class="ow">and</span> <span class="n">random</span><span class="o">.</span><span class="n">randint</span><span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">table</span><span class="p">[</span><span class="n">s</span><span class="p">][</span><span class="bp">None</span><span class="p">]</span> <span class="o">+</span> <span class="mi">1</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">word</span>
            <span class="n">i</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">_rndChoose</span><span class="p">([</span><span class="bp">self</span><span class="o">.</span><span class="n">table</span><span class="p">[</span><span class="n">s</span><span class="p">]</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">c</span><span class="p">,</span> <span class="mi">0</span><span class="p">)</span> <span class="k">for</span> <span class="n">c</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">])</span>
            <span class="n">word</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">[</span><span class="n">i</span><span class="p">])</span>
            <span class="n">s</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">aut</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">s</span><span class="p">][</span><span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">[</span><span class="n">i</span><span class="p">]]</span>


<span class="c"># noinspection PyUnresolvedReferences</span></div></div>
<div class="viewcode-block" id="ANFA"><a class="viewcode-back" href="../index.html#fl.ANFA">[docs]</a><span class="k">class</span> <span class="nc">ANFA</span><span class="p">(</span><span class="n">fa</span><span class="o">.</span><span class="n">NFA</span><span class="p">,</span> <span class="n">AFA</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Acyclic Nondeterministic Finite Automata class</span>

<span class="sd">    .. inheritance-diagram:: ANFA&quot;&quot;&quot;</span>

<div class="viewcode-block" id="ANFA.moveFinal"><a class="viewcode-back" href="../index.html#fl.ANFA.moveFinal">[docs]</a>    <span class="k">def</span> <span class="nf">moveFinal</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">st</span><span class="p">,</span> <span class="n">stf</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Unsets a set as final transfering transition to another final</span>
<span class="sd">        :param int st: the state to be &#39;moved&#39;</span>
<span class="sd">        :param int stf: the destination final state</span>

<span class="sd">        .. note::</span>
<span class="sd">           stf must be a &#39;last&#39; final state, i.e., must have no out transitions to anywhere but to a possible dead</span>
<span class="sd">           state</span>

<span class="sd">        .. attention:: the object is modified in place&quot;&quot;&quot;</span>
        <span class="p">(</span><span class="n">rdelta</span><span class="p">,</span> <span class="n">_</span><span class="p">)</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">_getRdelta</span><span class="p">()</span>
        <span class="k">for</span> <span class="n">s</span> <span class="ow">in</span> <span class="n">rdelta</span><span class="p">[</span><span class="n">st</span><span class="p">]:</span>
            <span class="n">l</span> <span class="o">=</span> <span class="p">[]</span>
            <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">s</span><span class="p">]:</span>
                <span class="k">if</span> <span class="n">st</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">s</span><span class="p">][</span><span class="n">k</span><span class="p">]:</span>
                    <span class="n">l</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">k</span><span class="p">)</span>
            <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="n">l</span><span class="p">:</span>
                <span class="bp">self</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">k</span><span class="p">,</span> <span class="n">stf</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">delFinal</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
</div>
<div class="viewcode-block" id="ANFA.mergeStates"><a class="viewcode-back" href="../index.html#fl.ANFA.mergeStates">[docs]</a>    <span class="k">def</span> <span class="nf">mergeStates</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">s1</span><span class="p">,</span> <span class="n">s2</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Merge state s2 into state s1</span>

<span class="sd">        :param int s1: state</span>
<span class="sd">        :param int s2: state</span>

<span class="sd">        .. note::</span>
<span class="sd">           no attempt is made to check if the merging preserves the language of teh automaton</span>

<span class="sd">        .. attention:: the object is modified in place&quot;&quot;&quot;</span>
        <span class="p">(</span><span class="n">_</span><span class="p">,</span> <span class="n">rdelta</span><span class="p">)</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">_getRdelta</span><span class="p">()</span>
        <span class="k">for</span> <span class="n">s</span> <span class="ow">in</span> <span class="n">rdelta</span><span class="p">[</span><span class="n">s2</span><span class="p">]:</span>
            <span class="n">l</span> <span class="o">=</span> <span class="p">[]</span>
            <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">s</span><span class="p">]:</span>
                <span class="k">if</span> <span class="n">s2</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">s</span><span class="p">][</span><span class="n">k</span><span class="p">]:</span>
                    <span class="n">l</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">k</span><span class="p">)</span>
            <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="n">l</span><span class="p">:</span>
                <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">s</span><span class="p">][</span><span class="n">k</span><span class="p">]</span><span class="o">.</span><span class="n">remove</span><span class="p">(</span><span class="n">s2</span><span class="p">)</span>
                <span class="bp">self</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">k</span><span class="p">,</span> <span class="n">s1</span><span class="p">)</span>
        <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">s2</span><span class="p">,</span> <span class="p">{}):</span>
            <span class="k">for</span> <span class="n">ss</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="p">[</span><span class="n">s2</span><span class="p">][</span><span class="n">k</span><span class="p">]:</span>
                <span class="bp">self</span><span class="o">.</span><span class="n">delta</span><span class="o">.</span><span class="n">setdefault</span><span class="p">(</span><span class="n">s1</span><span class="p">,</span> <span class="p">{})</span><span class="o">.</span><span class="n">setdefault</span><span class="p">(</span><span class="n">k</span><span class="p">,</span> <span class="nb">set</span><span class="p">())</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">ss</span><span class="p">)</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">deleteState</span><span class="p">(</span><span class="n">s2</span><span class="p">)</span>
</div>
<div class="viewcode-block" id="ANFA.mergeLeaves"><a class="viewcode-back" href="../index.html#fl.ANFA.mergeLeaves">[docs]</a>    <span class="k">def</span> <span class="nf">mergeLeaves</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Merge leaves</span>

<span class="sd">        .. attention:: object is modified in place&quot;&quot;&quot;</span>
        <span class="n">l</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">getLeaves</span><span class="p">()</span>
        <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">l</span><span class="p">):</span>
            <span class="n">s0n</span> <span class="o">=</span> <span class="n">l</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span>
            <span class="k">while</span> <span class="n">l</span><span class="p">:</span>
                <span class="n">s0</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">s0n</span><span class="p">)</span>
                <span class="n">s</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">l</span><span class="o">.</span><span class="n">pop</span><span class="p">())</span>
                <span class="bp">self</span><span class="o">.</span><span class="n">mergeStates</span><span class="p">(</span><span class="n">s0</span><span class="p">,</span> <span class="n">s</span><span class="p">)</span>
</div>
<div class="viewcode-block" id="ANFA.mergeInitial"><a class="viewcode-back" href="../index.html#fl.ANFA.mergeInitial">[docs]</a>    <span class="k">def</span> <span class="nf">mergeInitial</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Merge initial states</span>

<span class="sd">        .. attention:: object is modified in place&quot;&quot;&quot;</span>
        <span class="n">l</span> <span class="o">=</span> <span class="n">copy</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Initial</span><span class="p">)</span>
        <span class="n">s0</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">StateName</span><span class="p">(</span><span class="n">l</span><span class="o">.</span><span class="n">pop</span><span class="p">())</span>
        <span class="k">while</span> <span class="n">l</span><span class="p">:</span>
            <span class="n">s</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">l</span><span class="o">.</span><span class="n">pop</span><span class="p">())</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">mergeStates</span><span class="p">(</span><span class="n">s0</span><span class="p">,</span> <span class="n">s</span><span class="p">)</span>

</div></div>
<div class="viewcode-block" id="sigmaInitialSegment"><a class="viewcode-back" href="../index.html#fl.sigmaInitialSegment">[docs]</a><span class="k">def</span> <span class="nf">sigmaInitialSegment</span><span class="p">(</span><span class="n">Sigma</span><span class="p">,</span> <span class="n">l</span><span class="p">,</span> <span class="n">exact</span><span class="o">=</span><span class="bp">False</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Generates the ADFA recognizing Sigma^i for i&lt;=l</span>
<span class="sd">    :param set Sigma: the alphabet</span>
<span class="sd">    :param int l: length</span>
<span class="sd">    :param bool exact: only the words with exactly that length?</span>
<span class="sd">    :returns: the automaton</span>
<span class="sd">    :rtype: ADFA&quot;&quot;&quot;</span>
    <span class="n">new</span> <span class="o">=</span> <span class="n">ADFA</span><span class="p">()</span>
    <span class="n">new</span><span class="o">.</span><span class="n">setSigma</span><span class="p">(</span><span class="n">Sigma</span><span class="p">)</span>
    <span class="n">s</span> <span class="o">=</span> <span class="n">new</span><span class="o">.</span><span class="n">addState</span><span class="p">()</span>
    <span class="k">if</span> <span class="ow">not</span> <span class="n">exact</span><span class="p">:</span>
        <span class="n">new</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
    <span class="n">new</span><span class="o">.</span><span class="n">setInitial</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
    <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">l</span><span class="p">):</span>
        <span class="n">s1</span> <span class="o">=</span> <span class="n">new</span><span class="o">.</span><span class="n">addState</span><span class="p">()</span>
        <span class="k">if</span> <span class="ow">not</span> <span class="n">exact</span> <span class="ow">or</span> <span class="n">i</span> <span class="o">==</span> <span class="n">l</span> <span class="o">-</span> <span class="mi">1</span><span class="p">:</span>
            <span class="n">new</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
        <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="n">Sigma</span><span class="p">:</span>
            <span class="n">new</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">k</span><span class="p">,</span> <span class="n">s1</span><span class="p">)</span>
        <span class="n">s</span> <span class="o">=</span> <span class="n">s1</span>
    <span class="k">return</span> <span class="n">new</span>


<span class="c"># noinspection PyUnboundLocalVariable</span></div>
<div class="viewcode-block" id="genRndTrieBalanced"><a class="viewcode-back" href="../index.html#fl.genRndTrieBalanced">[docs]</a><span class="k">def</span> <span class="nf">genRndTrieBalanced</span><span class="p">(</span><span class="n">maxL</span><span class="p">,</span> <span class="n">Sigma</span><span class="p">,</span> <span class="n">safe</span><span class="o">=</span><span class="bp">True</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Generates a random trie automaton for a binary language of balanced words of a given leght for max word</span>
<span class="sd">    :param int maxL: length of the max word</span>
<span class="sd">    :param set Sigma: alphabet to be used</span>
<span class="sd">    :param bool safe: should a word of size maxl be present in every language?</span>
<span class="sd">    :return: the generated trie automaton</span>
<span class="sd">    :rtype: ADFA&quot;&quot;&quot;</span>

    <span class="k">def</span> <span class="nf">_genEnsurance</span><span class="p">(</span><span class="n">m</span><span class="p">,</span> <span class="n">alphabet</span><span class="p">):</span>
        <span class="n">l</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">alphabet</span><span class="p">)</span>
        <span class="n">fair</span> <span class="o">=</span> <span class="n">m</span> <span class="o">/</span> <span class="n">l</span>
        <span class="k">if</span> <span class="n">m</span> <span class="o">%</span> <span class="n">l</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span>
            <span class="n">odd</span> <span class="o">=</span> <span class="mi">0</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="n">odd</span> <span class="o">=</span> <span class="mi">1</span>
        <span class="n">pool</span> <span class="o">=</span> <span class="n">copy</span><span class="p">(</span><span class="n">alphabet</span><span class="p">)</span>
        <span class="n">c</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="n">sl</span> <span class="o">=</span> <span class="p">[]</span>
        <span class="k">while</span> <span class="nb">len</span><span class="p">(</span><span class="n">sl</span><span class="p">)</span> <span class="o">&lt;</span> <span class="n">m</span><span class="p">:</span>
            <span class="n">s1</span> <span class="o">=</span> <span class="n">random</span><span class="o">.</span><span class="n">choice</span><span class="p">(</span><span class="n">pool</span><span class="p">)</span>
            <span class="n">c</span><span class="p">[</span><span class="n">s1</span><span class="p">]</span> <span class="o">=</span> <span class="n">c</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">s1</span><span class="p">,</span> <span class="mi">0</span><span class="p">)</span> <span class="o">+</span> <span class="mi">1</span>
            <span class="k">if</span> <span class="n">c</span><span class="p">[</span><span class="n">s1</span><span class="p">]</span> <span class="o">==</span> <span class="n">fair</span> <span class="o">+</span> <span class="n">odd</span><span class="p">:</span>
                <span class="n">pool</span><span class="o">.</span><span class="n">remove</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
            <span class="n">sl</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">sl</span>

    <span class="k">def</span> <span class="nf">_legal</span><span class="p">(</span><span class="n">cont</span><span class="p">):</span>
        <span class="n">l</span> <span class="o">=</span> <span class="p">[</span><span class="n">cont</span><span class="p">[</span><span class="n">k1</span><span class="p">]</span> <span class="k">for</span> <span class="n">k1</span> <span class="ow">in</span> <span class="n">cont</span><span class="p">]</span>
        <span class="k">return</span> <span class="nb">max</span><span class="p">(</span><span class="n">l</span><span class="p">)</span> <span class="o">-</span> <span class="nb">min</span><span class="p">(</span><span class="n">l</span><span class="p">)</span> <span class="o">&lt;=</span> <span class="mi">1</span>

    <span class="k">def</span> <span class="nf">_descend</span><span class="p">(</span><span class="n">s1</span><span class="p">,</span> <span class="n">ens</span><span class="p">,</span> <span class="n">safe1</span><span class="p">,</span> <span class="n">m</span><span class="p">,</span> <span class="n">cont</span><span class="p">):</span>
        <span class="n">sons</span> <span class="o">=</span> <span class="mi">0</span>
        <span class="k">if</span> <span class="ow">not</span> <span class="n">safe1</span><span class="p">:</span>
            <span class="k">if</span> <span class="n">_legal</span><span class="p">(</span><span class="n">cont</span><span class="p">):</span>
                <span class="n">final</span> <span class="o">=</span> <span class="n">random</span><span class="o">.</span><span class="n">randint</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="n">final</span> <span class="o">=</span> <span class="mi">0</span>
        <span class="c"># noinspection PyUnboundLocalVariable</span>
        <span class="k">if</span> <span class="n">safe1</span><span class="p">:</span>
            <span class="n">trie</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
            <span class="n">final</span> <span class="o">=</span> <span class="mi">1</span>
        <span class="k">elif</span> <span class="n">final</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
            <span class="n">trie</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
        <span class="k">if</span> <span class="n">m</span> <span class="o">!=</span> <span class="mi">0</span><span class="p">:</span>
            <span class="k">if</span> <span class="n">safe1</span><span class="p">:</span>
                <span class="n">ks</span> <span class="o">=</span> <span class="n">ens</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="n">ks</span> <span class="o">=</span> <span class="bp">None</span>
            <span class="k">for</span> <span class="n">k1</span> <span class="ow">in</span> <span class="n">trie</span><span class="o">.</span><span class="n">Sigma</span><span class="p">:</span>
                <span class="n">ss</span> <span class="o">=</span> <span class="n">trie</span><span class="o">.</span><span class="n">addState</span><span class="p">()</span>
                <span class="n">trie</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="n">s1</span><span class="p">,</span> <span class="n">k1</span><span class="p">,</span> <span class="n">ss</span><span class="p">)</span>
                <span class="n">cont</span><span class="p">[</span><span class="n">k1</span><span class="p">]</span> <span class="o">=</span> <span class="n">cont</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">k1</span><span class="p">,</span> <span class="mi">0</span><span class="p">)</span> <span class="o">+</span> <span class="mi">1</span>
                <span class="k">if</span> <span class="n">_descend</span><span class="p">(</span><span class="n">ss</span><span class="p">,</span> <span class="n">ens</span><span class="p">,</span> <span class="n">k1</span> <span class="o">==</span> <span class="n">ks</span><span class="p">,</span> <span class="n">m</span> <span class="o">-</span> <span class="mi">1</span><span class="p">,</span> <span class="n">cont</span><span class="p">):</span>
                    <span class="n">sons</span> <span class="o">+=</span> <span class="mi">1</span>
                <span class="n">cont</span><span class="p">[</span><span class="n">k1</span><span class="p">]</span> <span class="o">-=</span> <span class="mi">1</span>
        <span class="k">if</span> <span class="n">sons</span> <span class="o">==</span> <span class="mi">0</span> <span class="ow">and</span> <span class="n">final</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span>
            <span class="n">trie</span><span class="o">.</span><span class="n">deleteState</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
            <span class="k">return</span> <span class="bp">False</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="bp">True</span>

    <span class="k">if</span> <span class="n">safe</span><span class="p">:</span>
        <span class="n">ensurance</span> <span class="o">=</span> <span class="n">_genEnsurance</span><span class="p">(</span><span class="n">maxL</span><span class="p">,</span> <span class="n">Sigma</span><span class="p">)</span>
    <span class="k">else</span><span class="p">:</span>
        <span class="n">ensurance</span> <span class="o">=</span> <span class="bp">None</span>
    <span class="n">trie</span> <span class="o">=</span> <span class="n">ADFA</span><span class="p">()</span>
    <span class="n">trie</span><span class="o">.</span><span class="n">setSigma</span><span class="p">(</span><span class="n">Sigma</span><span class="p">)</span>
    <span class="n">s</span> <span class="o">=</span> <span class="n">trie</span><span class="o">.</span><span class="n">addState</span><span class="p">()</span>
    <span class="n">trie</span><span class="o">.</span><span class="n">setInitial</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
    <span class="n">contab</span> <span class="o">=</span> <span class="p">{}</span>
    <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="n">Sigma</span><span class="p">:</span>
        <span class="n">contab</span><span class="p">[</span><span class="n">k</span><span class="p">]</span> <span class="o">=</span> <span class="mi">0</span>
    <span class="n">_descend</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">ensurance</span><span class="p">,</span> <span class="n">safe</span><span class="p">,</span> <span class="n">maxL</span><span class="p">,</span> <span class="n">contab</span><span class="p">)</span>
    <span class="k">if</span> <span class="n">random</span><span class="o">.</span><span class="n">randint</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
        <span class="n">trie</span><span class="o">.</span><span class="n">delFinal</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
    <span class="k">return</span> <span class="n">trie</span>


<span class="c"># noinspection PyUnboundLocalVariable</span></div>
<div class="viewcode-block" id="genRndTrieUnbalanced"><a class="viewcode-back" href="../index.html#fl.genRndTrieUnbalanced">[docs]</a><span class="k">def</span> <span class="nf">genRndTrieUnbalanced</span><span class="p">(</span><span class="n">maxL</span><span class="p">,</span> <span class="n">Sigma</span><span class="p">,</span> <span class="n">ratio</span><span class="p">,</span> <span class="n">safe</span><span class="o">=</span><span class="bp">True</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Generates a random trie automaton for a binary language of balanced words of a given length for max word</span>

<span class="sd">    :param int maxL: length of the max word</span>
<span class="sd">    :param set Sigma: alphabet to be used</span>
<span class="sd">    :param int ratio: the ratio of the unbalance</span>
<span class="sd">    :param bool safe: should a word of size maxl be present in every language?</span>
<span class="sd">    :return: the generated trie automaton</span>
<span class="sd">    :rtype: ADFA&quot;&quot;&quot;</span>

    <span class="k">def</span> <span class="nf">_genEnsurance</span><span class="p">(</span><span class="n">m</span><span class="p">,</span> <span class="n">alphabet</span><span class="p">):</span>
        <span class="n">chief</span> <span class="o">=</span> <span class="n">uSet</span><span class="p">(</span><span class="n">alphabet</span><span class="p">)</span>
        <span class="n">fair</span> <span class="o">=</span> <span class="n">m</span> <span class="o">/</span> <span class="p">(</span><span class="n">ratio</span> <span class="o">+</span> <span class="mi">1</span><span class="p">)</span>
        <span class="n">pool</span> <span class="o">=</span> <span class="nb">list</span><span class="p">(</span><span class="n">copy</span><span class="p">(</span><span class="n">alphabet</span><span class="p">))</span>
        <span class="n">c</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="n">sl</span> <span class="o">=</span> <span class="p">[]</span>
        <span class="k">while</span> <span class="nb">len</span><span class="p">(</span><span class="n">sl</span><span class="p">)</span> <span class="o">&lt;</span> <span class="n">m</span><span class="p">:</span>
            <span class="n">s1</span> <span class="o">=</span> <span class="n">random</span><span class="o">.</span><span class="n">choice</span><span class="p">(</span><span class="n">pool</span><span class="p">)</span>
            <span class="n">c</span><span class="p">[</span><span class="n">s1</span><span class="p">]</span> <span class="o">=</span> <span class="n">c</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">s1</span><span class="p">,</span> <span class="mi">0</span><span class="p">)</span> <span class="o">+</span> <span class="mi">1</span>
            <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">sl</span><span class="p">)</span> <span class="o">-</span> <span class="n">c</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">chief</span><span class="p">,</span> <span class="mi">0</span><span class="p">)</span> <span class="o">==</span> <span class="n">fair</span><span class="p">:</span>
                <span class="n">pool</span> <span class="o">=</span> <span class="p">[</span><span class="n">chief</span><span class="p">]</span>
            <span class="n">sl</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">sl</span>

    <span class="k">def</span> <span class="nf">_legal</span><span class="p">(</span><span class="n">cont</span><span class="p">):</span>
        <span class="n">l</span> <span class="o">=</span> <span class="p">[</span><span class="n">cont</span><span class="p">[</span><span class="n">k1</span><span class="p">]</span> <span class="k">for</span> <span class="n">k1</span> <span class="ow">in</span> <span class="n">cont</span><span class="p">]</span>
        <span class="k">return</span> <span class="p">(</span><span class="n">ratio</span> <span class="o">+</span> <span class="mi">1</span><span class="p">)</span> <span class="o">*</span> <span class="n">cont</span><span class="p">[</span><span class="n">uSet</span><span class="p">(</span><span class="n">Sigma</span><span class="p">)]</span> <span class="o">&gt;=</span> <span class="nb">sum</span><span class="p">(</span><span class="n">l</span><span class="p">)</span>

    <span class="c"># noinspection PyUnboundLocalVariable</span>
    <span class="k">def</span> <span class="nf">_descend</span><span class="p">(</span><span class="n">s1</span><span class="p">,</span> <span class="n">ens</span><span class="p">,</span> <span class="n">safe1</span><span class="p">,</span> <span class="n">m</span><span class="p">,</span> <span class="n">cont</span><span class="p">):</span>
        <span class="n">sons</span> <span class="o">=</span> <span class="mi">0</span>
        <span class="k">if</span> <span class="ow">not</span> <span class="n">safe1</span><span class="p">:</span>
            <span class="k">if</span> <span class="n">_legal</span><span class="p">(</span><span class="n">cont</span><span class="p">):</span>
                <span class="n">final</span> <span class="o">=</span> <span class="n">random</span><span class="o">.</span><span class="n">randint</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="n">final</span> <span class="o">=</span> <span class="mi">0</span>
        <span class="k">if</span> <span class="n">safe1</span><span class="p">:</span>
            <span class="n">trie</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
            <span class="n">final</span> <span class="o">=</span> <span class="mi">1</span>
        <span class="k">elif</span> <span class="n">final</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
            <span class="n">trie</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
        <span class="k">if</span> <span class="n">m</span><span class="p">:</span>
            <span class="k">if</span> <span class="n">safe1</span><span class="p">:</span>
                <span class="n">ks</span> <span class="o">=</span> <span class="n">ens</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="n">ks</span> <span class="o">=</span> <span class="bp">None</span>
            <span class="k">for</span> <span class="n">k1</span> <span class="ow">in</span> <span class="n">trie</span><span class="o">.</span><span class="n">Sigma</span><span class="p">:</span>
                <span class="n">ss</span> <span class="o">=</span> <span class="n">trie</span><span class="o">.</span><span class="n">addState</span><span class="p">()</span>
                <span class="n">trie</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="n">s1</span><span class="p">,</span> <span class="n">k1</span><span class="p">,</span> <span class="n">ss</span><span class="p">)</span>
                <span class="n">cont</span><span class="p">[</span><span class="n">k1</span><span class="p">]</span> <span class="o">=</span> <span class="n">cont</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">k1</span><span class="p">,</span> <span class="mi">0</span><span class="p">)</span> <span class="o">+</span> <span class="mi">1</span>
                <span class="k">if</span> <span class="n">_descend</span><span class="p">(</span><span class="n">ss</span><span class="p">,</span> <span class="n">ens</span><span class="p">,</span> <span class="n">k1</span> <span class="o">==</span> <span class="n">ks</span><span class="p">,</span> <span class="n">m</span> <span class="o">-</span> <span class="mi">1</span><span class="p">,</span> <span class="n">cont</span><span class="p">):</span>
                    <span class="n">sons</span> <span class="o">+=</span> <span class="mi">1</span>
                <span class="n">cont</span><span class="p">[</span><span class="n">k1</span><span class="p">]</span> <span class="o">-=</span> <span class="mi">1</span>
        <span class="k">if</span> <span class="n">sons</span> <span class="o">==</span> <span class="mi">0</span> <span class="ow">and</span> <span class="n">final</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span>
            <span class="n">trie</span><span class="o">.</span><span class="n">deleteState</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
            <span class="k">return</span> <span class="bp">False</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="bp">True</span>

    <span class="k">if</span> <span class="n">safe</span><span class="p">:</span>
        <span class="n">ensurance</span> <span class="o">=</span> <span class="n">_genEnsurance</span><span class="p">(</span><span class="n">maxL</span><span class="p">,</span> <span class="n">Sigma</span><span class="p">)</span>
    <span class="k">else</span><span class="p">:</span>
        <span class="n">ensurance</span> <span class="o">=</span> <span class="bp">None</span>
    <span class="n">trie</span> <span class="o">=</span> <span class="n">ADFA</span><span class="p">()</span>
    <span class="n">trie</span><span class="o">.</span><span class="n">setSigma</span><span class="p">(</span><span class="n">Sigma</span><span class="p">)</span>
    <span class="n">s</span> <span class="o">=</span> <span class="n">trie</span><span class="o">.</span><span class="n">addState</span><span class="p">()</span>
    <span class="n">trie</span><span class="o">.</span><span class="n">setInitial</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
    <span class="n">contab</span> <span class="o">=</span> <span class="p">{}</span>
    <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="n">Sigma</span><span class="p">:</span>
        <span class="n">contab</span><span class="p">[</span><span class="n">k</span><span class="p">]</span> <span class="o">=</span> <span class="mi">0</span>
    <span class="n">_descend</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">ensurance</span><span class="p">,</span> <span class="n">safe</span><span class="p">,</span> <span class="n">maxL</span><span class="p">,</span> <span class="n">contab</span><span class="p">)</span>
    <span class="k">if</span> <span class="n">random</span><span class="o">.</span><span class="n">randint</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
        <span class="n">trie</span><span class="o">.</span><span class="n">delFinal</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
    <span class="k">return</span> <span class="n">trie</span>


<span class="c"># noinspection PyUnboundLocalVariable</span></div>
<div class="viewcode-block" id="genRandomTrie"><a class="viewcode-back" href="../index.html#fl.genRandomTrie">[docs]</a><span class="k">def</span> <span class="nf">genRandomTrie</span><span class="p">(</span><span class="n">maxL</span><span class="p">,</span> <span class="n">Sigma</span><span class="p">,</span> <span class="n">safe</span><span class="o">=</span><span class="bp">True</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Generates a random trie automaton for a finite language with a given length for max word</span>
<span class="sd">    :param int maxL: length of the max word</span>
<span class="sd">    :param set Sigma: alphabet to be used</span>
<span class="sd">    :param bool safe: should a word of size maxl be present in every language?</span>
<span class="sd">    :return: the generated trie automaton</span>
<span class="sd">    :rtype: ADFA&quot;&quot;&quot;</span>

    <span class="k">def</span> <span class="nf">_genEnsurance</span><span class="p">(</span><span class="n">m</span><span class="p">,</span> <span class="n">alphabet</span><span class="p">):</span>
        <span class="n">l</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">alphabet</span><span class="p">)</span>
        <span class="n">sl</span> <span class="o">=</span> <span class="nb">list</span><span class="p">(</span><span class="n">alphabet</span><span class="p">)</span>
        <span class="k">return</span> <span class="p">[</span><span class="n">sl</span><span class="p">[</span><span class="n">random</span><span class="o">.</span><span class="n">randint</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="n">l</span> <span class="o">-</span> <span class="mi">1</span><span class="p">)]</span> <span class="k">for</span> <span class="n">_</span> <span class="ow">in</span> <span class="nb">xrange</span><span class="p">(</span><span class="n">m</span><span class="p">)]</span>

    <span class="c"># noinspection PyUnboundLocalVariable</span>
    <span class="k">def</span> <span class="nf">_descend</span><span class="p">(</span><span class="n">s1</span><span class="p">,</span> <span class="n">ens</span><span class="p">,</span> <span class="n">safe1</span><span class="p">,</span> <span class="n">m</span><span class="p">):</span>
        <span class="n">sons</span> <span class="o">=</span> <span class="mi">0</span>
        <span class="k">if</span> <span class="ow">not</span> <span class="n">safe1</span><span class="p">:</span>
            <span class="n">final</span> <span class="o">=</span> <span class="n">random</span><span class="o">.</span><span class="n">randint</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span>
        <span class="k">if</span> <span class="n">safe1</span><span class="p">:</span>
            <span class="n">trie</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
            <span class="n">final</span> <span class="o">=</span> <span class="mi">1</span>
        <span class="k">elif</span> <span class="n">final</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
            <span class="n">trie</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
        <span class="k">if</span> <span class="n">m</span><span class="p">:</span>
            <span class="k">if</span> <span class="n">safe1</span><span class="p">:</span>
                <span class="n">ks</span> <span class="o">=</span> <span class="n">ens</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="n">ks</span> <span class="o">=</span> <span class="bp">None</span>
            <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="n">trie</span><span class="o">.</span><span class="n">Sigma</span><span class="p">:</span>
                <span class="n">ss</span> <span class="o">=</span> <span class="n">trie</span><span class="o">.</span><span class="n">addState</span><span class="p">()</span>
                <span class="n">trie</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="n">s1</span><span class="p">,</span> <span class="n">k</span><span class="p">,</span> <span class="n">ss</span><span class="p">)</span>
                <span class="k">if</span> <span class="n">_descend</span><span class="p">(</span><span class="n">ss</span><span class="p">,</span> <span class="n">ens</span><span class="p">,</span> <span class="n">k</span> <span class="o">==</span> <span class="n">ks</span><span class="p">,</span> <span class="n">m</span> <span class="o">-</span> <span class="mi">1</span><span class="p">):</span>
                    <span class="n">sons</span> <span class="o">+=</span> <span class="mi">1</span>
        <span class="k">if</span> <span class="n">sons</span> <span class="o">==</span> <span class="mi">0</span> <span class="ow">and</span> <span class="n">final</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span>
            <span class="n">trie</span><span class="o">.</span><span class="n">deleteState</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
            <span class="k">return</span> <span class="bp">False</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="bp">True</span>

    <span class="k">if</span> <span class="n">safe</span><span class="p">:</span>
        <span class="n">ensurance</span> <span class="o">=</span> <span class="n">_genEnsurance</span><span class="p">(</span><span class="n">maxL</span><span class="p">,</span> <span class="n">Sigma</span><span class="p">)</span>
    <span class="k">else</span><span class="p">:</span>
        <span class="n">ensurance</span> <span class="o">=</span> <span class="bp">None</span>
    <span class="n">trie</span> <span class="o">=</span> <span class="n">ADFA</span><span class="p">()</span>
    <span class="n">trie</span><span class="o">.</span><span class="n">setSigma</span><span class="p">(</span><span class="n">Sigma</span><span class="p">)</span>
    <span class="n">s</span> <span class="o">=</span> <span class="n">trie</span><span class="o">.</span><span class="n">addState</span><span class="p">()</span>
    <span class="n">trie</span><span class="o">.</span><span class="n">setInitial</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
    <span class="n">_descend</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">ensurance</span><span class="p">,</span> <span class="n">safe</span><span class="p">,</span> <span class="n">maxL</span><span class="p">)</span>
    <span class="k">if</span> <span class="n">random</span><span class="o">.</span><span class="n">randint</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
        <span class="n">trie</span><span class="o">.</span><span class="n">delFinal</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
    <span class="k">return</span> <span class="n">trie</span>


<span class="c"># noinspection PyUnboundLocalVariable</span></div>
<div class="viewcode-block" id="genRndTriePrefix"><a class="viewcode-back" href="../index.html#fl.genRndTriePrefix">[docs]</a><span class="k">def</span> <span class="nf">genRndTriePrefix</span><span class="p">(</span><span class="n">maxL</span><span class="p">,</span> <span class="n">Sigma</span><span class="p">,</span> <span class="n">ClosedP</span><span class="o">=</span><span class="bp">False</span><span class="p">,</span> <span class="n">safe</span><span class="o">=</span><span class="bp">True</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Generates a random trie automaton for a finite (either prefix free or prefix closed) language with a given</span>
<span class="sd">    length for max word</span>
<span class="sd">    :param int maxL: length of the max word</span>
<span class="sd">    :param set Sigma: alphabet to be used</span>
<span class="sd">    :param bool ClosedP: should it be a prefix closed language?</span>
<span class="sd">    :param bool safe: should a word of size maxl be present in every language?</span>
<span class="sd">    :return: the generated trie automaton</span>
<span class="sd">    :rtype: ADFA&quot;&quot;&quot;</span>

    <span class="k">def</span> <span class="nf">_genEnsurance</span><span class="p">(</span><span class="n">m</span><span class="p">,</span> <span class="n">alphabet</span><span class="p">):</span>
        <span class="n">l</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">alphabet</span><span class="p">)</span>
        <span class="n">sl</span> <span class="o">=</span> <span class="nb">list</span><span class="p">(</span><span class="n">alphabet</span><span class="p">)</span>
        <span class="k">return</span> <span class="p">[</span><span class="n">sl</span><span class="p">[</span><span class="n">random</span><span class="o">.</span><span class="n">randint</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="n">l</span> <span class="o">-</span> <span class="mi">1</span><span class="p">)]</span> <span class="k">for</span> <span class="n">_</span> <span class="ow">in</span> <span class="nb">xrange</span><span class="p">(</span><span class="n">m</span><span class="p">)]</span>

    <span class="k">def</span> <span class="nf">_descend</span><span class="p">(</span><span class="n">s1</span><span class="p">,</span> <span class="n">ens</span><span class="p">,</span> <span class="n">saf</span><span class="p">,</span> <span class="n">m</span><span class="p">):</span>
        <span class="n">sons</span> <span class="o">=</span> <span class="n">ClosedP</span>
        <span class="k">if</span> <span class="n">m</span> <span class="ow">is</span> <span class="mi">0</span><span class="p">:</span>
            <span class="n">final</span> <span class="o">=</span> <span class="n">random</span><span class="o">.</span><span class="n">randint</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span>
            <span class="k">if</span> <span class="n">saf</span> <span class="ow">or</span> <span class="n">final</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
                <span class="n">trie</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
                <span class="k">return</span> <span class="bp">True</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="k">return</span> <span class="bp">False</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">if</span> <span class="n">saf</span> <span class="ow">is</span> <span class="bp">True</span><span class="p">:</span>
                <span class="n">ks</span> <span class="o">=</span> <span class="n">ens</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="n">ks</span> <span class="o">=</span> <span class="bp">None</span>
            <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="n">trie</span><span class="o">.</span><span class="n">Sigma</span><span class="p">:</span>
                <span class="n">ss</span> <span class="o">=</span> <span class="n">trie</span><span class="o">.</span><span class="n">addState</span><span class="p">()</span>
                <span class="n">trie</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="n">s1</span><span class="p">,</span> <span class="n">k</span><span class="p">,</span> <span class="n">ss</span><span class="p">)</span>
                <span class="n">r</span> <span class="o">=</span> <span class="n">_descend</span><span class="p">(</span><span class="n">ss</span><span class="p">,</span> <span class="n">ens</span><span class="p">,</span> <span class="n">k</span> <span class="o">==</span> <span class="n">ks</span><span class="p">,</span> <span class="n">m</span> <span class="o">-</span> <span class="mi">1</span><span class="p">)</span>
                <span class="k">if</span> <span class="ow">not</span> <span class="n">ClosedP</span><span class="p">:</span>
                    <span class="n">sons</span> <span class="o">|=</span> <span class="n">r</span>
                <span class="k">else</span><span class="p">:</span>
                    <span class="n">sons</span> <span class="o">&amp;=</span> <span class="mi">1</span>
            <span class="k">if</span> <span class="ow">not</span> <span class="n">ClosedP</span><span class="p">:</span>
                <span class="k">if</span> <span class="ow">not</span> <span class="n">sons</span><span class="p">:</span>
                    <span class="n">final</span> <span class="o">=</span> <span class="n">random</span><span class="o">.</span><span class="n">randint</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span>
                    <span class="k">if</span> <span class="n">final</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
                        <span class="n">trie</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
                        <span class="k">return</span> <span class="bp">True</span>
                    <span class="k">else</span><span class="p">:</span>
                        <span class="k">return</span> <span class="bp">False</span>
                <span class="k">else</span><span class="p">:</span>
                    <span class="k">return</span> <span class="bp">True</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="k">if</span> <span class="ow">not</span> <span class="n">sons</span><span class="p">:</span>
                    <span class="n">final</span> <span class="o">=</span> <span class="n">random</span><span class="o">.</span><span class="n">randint</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span>
                    <span class="k">if</span> <span class="n">final</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
                        <span class="n">trie</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
                        <span class="k">return</span> <span class="bp">True</span>
                    <span class="k">else</span><span class="p">:</span>
                        <span class="k">return</span> <span class="bp">False</span>
                <span class="k">else</span><span class="p">:</span>
                    <span class="n">trie</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">s1</span><span class="p">)</span>
                    <span class="k">return</span> <span class="bp">True</span>

    <span class="k">if</span> <span class="n">safe</span><span class="p">:</span>
        <span class="n">ensurance</span> <span class="o">=</span> <span class="n">_genEnsurance</span><span class="p">(</span><span class="n">maxL</span><span class="p">,</span> <span class="n">Sigma</span><span class="p">)</span>
    <span class="n">trie</span> <span class="o">=</span> <span class="n">ADFA</span><span class="p">()</span>
    <span class="n">trie</span><span class="o">.</span><span class="n">setSigma</span><span class="p">(</span><span class="n">Sigma</span><span class="p">)</span>
    <span class="n">s</span> <span class="o">=</span> <span class="n">trie</span><span class="o">.</span><span class="n">addState</span><span class="p">()</span>
    <span class="n">trie</span><span class="o">.</span><span class="n">setInitial</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
    <span class="n">_descend</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">ensurance</span><span class="p">,</span> <span class="n">safe</span><span class="p">,</span> <span class="n">maxL</span><span class="p">)</span>
    <span class="k">return</span> <span class="n">trie</span>

</div>
<div class="viewcode-block" id="DFAtoADFA"><a class="viewcode-back" href="../index.html#fl.DFAtoADFA">[docs]</a><span class="k">def</span> <span class="nf">DFAtoADFA</span><span class="p">(</span><span class="n">aut</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Transforms an acyclic DFA into a ADFA</span>

<span class="sd">    :param DFA aut: the automaton to be transformed</span>
<span class="sd">    :raises notAcyclic: if the DFA is not acyclic</span>
<span class="sd">    :returns: the converted automaton</span>
<span class="sd">    :rtype: ADFA&quot;&quot;&quot;</span>
    <span class="n">new</span> <span class="o">=</span> <span class="n">deepcopy</span><span class="p">(</span><span class="n">aut</span><span class="p">)</span>
    <span class="n">new</span><span class="o">.</span><span class="n">trim</span><span class="p">()</span>
    <span class="k">if</span> <span class="ow">not</span> <span class="n">new</span><span class="o">.</span><span class="n">acyclicP</span><span class="p">(</span><span class="bp">True</span><span class="p">):</span>
        <span class="k">raise</span> <span class="n">notAcyclic</span><span class="p">()</span>
    <span class="n">afa</span> <span class="o">=</span> <span class="n">ADFA</span><span class="p">()</span>
    <span class="n">afa</span><span class="o">.</span><span class="n">States</span> <span class="o">=</span> <span class="n">copy</span><span class="p">(</span><span class="n">new</span><span class="o">.</span><span class="n">States</span><span class="p">)</span>
    <span class="n">afa</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">=</span> <span class="n">copy</span><span class="p">(</span><span class="n">new</span><span class="o">.</span><span class="n">Sigma</span><span class="p">)</span>
    <span class="n">afa</span><span class="o">.</span><span class="n">Initial</span> <span class="o">=</span> <span class="n">new</span><span class="o">.</span><span class="n">Initial</span>
    <span class="n">afa</span><span class="o">.</span><span class="n">delta</span> <span class="o">=</span> <span class="n">copy</span><span class="p">(</span><span class="n">new</span><span class="o">.</span><span class="n">delta</span><span class="p">)</span>
    <span class="n">afa</span><span class="o">.</span><span class="n">Final</span> <span class="o">=</span> <span class="n">copy</span><span class="p">(</span><span class="n">new</span><span class="o">.</span><span class="n">Final</span><span class="p">)</span>
    <span class="n">afa</span><span class="o">.</span><span class="n">complete</span><span class="p">()</span>
    <span class="k">return</span> <span class="n">afa</span>

</div>
<div class="viewcode-block" id="stringToADFA"><a class="viewcode-back" href="../index.html#fl.stringToADFA">[docs]</a><span class="k">def</span> <span class="nf">stringToADFA</span><span class="p">(</span><span class="n">s</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Convert a canonical string representation of a ADFA to a ADFA</span>
<span class="sd">    :param list s: the string in its canonical order</span>
<span class="sd">    :returns: the ADFA</span>
<span class="sd">    :rtype: ADFA</span>

<span class="sd">    .. seealso::</span>
<span class="sd">        Marco Almeida, Nelma Moreira, and Rogério Reis. Exact generation of minimal acyclic deterministic finite</span>
<span class="sd">        automata. International Journal of Foundations of Computer Science, 19(4):751-765, August 2008.</span>
<span class="sd">    &quot;&quot;&quot;</span>
    <span class="n">k</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">s</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span> <span class="o">-</span> <span class="mi">1</span>
    <span class="n">new</span> <span class="o">=</span> <span class="n">ADFA</span><span class="p">()</span>
    <span class="n">new</span><span class="o">.</span><span class="n">setSigma</span><span class="p">([</span><span class="nb">str</span><span class="p">(</span><span class="n">c</span><span class="p">)</span> <span class="k">for</span> <span class="n">c</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">k</span><span class="p">)])</span>
    <span class="k">for</span> <span class="n">st</span><span class="p">,</span> <span class="n">sts</span> <span class="ow">in</span> <span class="nb">enumerate</span><span class="p">(</span><span class="n">s</span><span class="p">):</span>
        <span class="n">new</span><span class="o">.</span><span class="n">addState</span><span class="p">(</span><span class="nb">str</span><span class="p">(</span><span class="n">st</span><span class="p">))</span>
        <span class="k">for</span> <span class="n">c</span><span class="p">,</span> <span class="n">s1</span> <span class="ow">in</span> <span class="nb">enumerate</span><span class="p">(</span><span class="n">sts</span><span class="p">[:</span><span class="o">-</span><span class="mi">1</span><span class="p">]):</span>
            <span class="n">new</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="n">st</span><span class="p">,</span> <span class="nb">str</span><span class="p">(</span><span class="n">c</span><span class="p">),</span> <span class="n">s1</span><span class="p">)</span>
        <span class="k">if</span> <span class="n">sts</span><span class="p">[</span><span class="o">-</span><span class="mi">1</span><span class="p">]:</span>
            <span class="n">new</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">st</span><span class="p">)</span>
    <span class="n">new</span><span class="o">.</span><span class="n">setInitial</span><span class="p">(</span><span class="nb">len</span><span class="p">(</span><span class="n">s</span><span class="p">)</span> <span class="o">-</span> <span class="mi">1</span><span class="p">)</span>
    <span class="k">return</span> <span class="n">new</span></div>
</pre></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="../index.html">FAdo 1.2 documentation</a> &raquo;</li>
          <li><a href="index.html" >Module code</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>