<!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>xre &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 xre</h1><div class="highlight"><pre>
<span class="c"># -*- coding: utf-8 -*-</span>
<span class="sd">&quot;&quot;&quot; **Extended regular expressions manipulation**</span>

<span class="sd">Extended regular expression classes and its manipulation</span>

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

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

<span class="sd">.. Contributions by</span>
<span class="sd">    - Rafaela Bastos</span>

<span class="sd">.. *This is part of FAdo project*   http://fado.dcc.fc.up.pt</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</span>
<span class="sd">   modify it under the terms of the GNU General Public License as</span>
<span class="sd">   published by the Free Software Foundation; either version 2 of</span>
<span class="sd">   the License, or (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.</span>
<span class="sd">   See the GNU General Public License for more details.</span>

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

<span class="kn">import</span> <span class="nn">copy</span>

<span class="kn">from</span> <span class="nn">yappy_parser</span> <span class="kn">import</span> <span class="o">*</span>
<span class="kn">import</span> <span class="nn">reex</span>
<span class="kn">import</span> <span class="nn">fa</span>
<span class="kn">from</span> <span class="nn">common</span> <span class="kn">import</span> <span class="o">*</span>


<div class="viewcode-block" id="xre"><a class="viewcode-back" href="../index.html#xre.xre">[docs]</a><span class="k">class</span> <span class="nc">xre</span><span class="p">(</span><span class="n">reex</span><span class="o">.</span><span class="n">regexp</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Base class for extended regular expressions, used directly to represent a symbol.</span>
<span class="sd">  </span>
<span class="sd">    :var val: the actual symbol&quot;&quot;&quot;</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="sd">&quot;&quot;&quot;Representation of the regular expression&#39;s syntactical tree.&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="s">&#39;xre({0:&gt;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="xre.unionSigma"><a class="viewcode-back" href="../index.html#xre.xre.unionSigma">[docs]</a>    <span class="k">def</span> <span class="nf">unionSigma</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">reg</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Returns the union of two alphabets</span>

<span class="sd">        :param reg: xre</span>
<span class="sd">        :rtype: set</span>
<span class="sd">        &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span> <span class="ow">is</span> <span class="bp">None</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">reg</span><span class="o">.</span><span class="n">Sigma</span>
        <span class="k">elif</span> <span class="n">reg</span><span class="o">.</span><span class="n">Sigma</span> <span class="ow">is</span> <span class="bp">None</span><span class="p">:</span>
            <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</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">reg</span><span class="o">.</span><span class="n">Sigma</span><span class="p">)</span>
</div>
<div class="viewcode-block" id="xre.derivative"><a class="viewcode-back" href="../index.html#xre.xre.derivative">[docs]</a>    <span class="k">def</span> <span class="nf">derivative</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="sd">&quot;&quot;&quot;Derivative of the regular expression in relation to the given symbol.</span>

<span class="sd">        :param sigma: an arbitrary symbol.</span>
<span class="sd">        :rtype: regular expression</span>

<span class="sd">        .. note:: whether the symbols belong to the expression&#39;s alphabet goes unchecked. The given symbol will be</span>
<span class="sd">           matched against the string representation of the regular expression&#39;s symbol.</span>

<span class="sd">        .. seealso::</span>
<span class="sd">            J. A. Brzozowski, Derivatives of Regular Expressions. J. ACM 11(4): 481-494 (1964)&quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="nb">str</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">)</span> <span class="o">==</span> <span class="nb">str</span><span class="p">(</span><span class="n">sigma</span><span class="p">):</span>
            <span class="k">return</span> <span class="n">xepsilon</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">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xempty</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">)</span>
</div>
<div class="viewcode-block" id="xre.partialDerivativeC"><a class="viewcode-back" href="../index.html#xre.xre.partialDerivativeC">[docs]</a>    <span class="k">def</span> <span class="nf">partialDerivativeC</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="sd">&quot;&quot;&quot;</span>

<span class="sd">        :param sigma:</span>
<span class="sd">        :rtype: xre&quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span> <span class="o">==</span> <span class="n">sigma</span><span class="p">:</span>
            <span class="k">return</span> <span class="p">{</span><span class="n">xsigmaP</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">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="p">{</span><span class="n">xsigmaS</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">)}</span>
</div>
<div class="viewcode-block" id="xre.linearForm"><a class="viewcode-back" href="../index.html#xre.xre.linearForm">[docs]</a>    <span class="k">def</span> <span class="nf">linearForm</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Linear form of the extended regular expression , as a mapping from heads to sets of tails,</span>
<span class="sd">            so that each pair (head,tail) is a monomial in the set of linear forms.</span>

<span class="sd">        :return: dictionary mapping heads to sets of tails</span>
<span class="sd">        :rtype: {symbol: set([regular expressions])}</span>

<span class="sd">        .. seealso:: Antimirov, 95&quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="ow">not</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">:</span>
            <span class="n">syms</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">setOfSymbols</span><span class="p">()</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">setSigma</span><span class="p">(</span><span class="n">syms</span><span class="p">)</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">_linearForm</span><span class="p">()</span>
</div>
    <span class="k">def</span> <span class="nf">_linearForm</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot; &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="p">{</span><span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span> <span class="p">{</span><span class="n">xepsilon</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">_linearFormC</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot; &quot;&quot;&quot;</span>
        <span class="n">lf</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="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">:</span>
            <span class="k">if</span> <span class="n">i</span> <span class="o">==</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
                <span class="n">lf</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="p">{</span><span class="n">xsigmaP</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">else</span><span class="p">:</span>
                <span class="n">lf</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="p">{</span><span class="n">xsigmaS</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">return</span> <span class="n">lf</span>

<div class="viewcode-block" id="xre.PD"><a class="viewcode-back" href="../index.html#xre.xre.PD">[docs]</a>    <span class="k">def</span> <span class="nf">PD</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Closure of partial derivatives of the regular expression in relation to all words.</span>
<span class="sd">    </span>
<span class="sd">        .. Note: does not include the regular expression</span>

<span class="sd">        :return: set of regular expressions</span>
<span class="sd">        :rtype: set&quot;&quot;&quot;</span>
        <span class="n">stack</span> <span class="o">=</span> <span class="p">[</span><span class="bp">self</span><span class="p">]</span>
        <span class="n">s</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
        <span class="k">while</span> <span class="n">stack</span><span class="p">:</span>
            <span class="n">reg</span> <span class="o">=</span> <span class="n">stack</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span>
            <span class="n">lf</span> <span class="o">=</span> <span class="n">reg</span><span class="o">.</span><span class="n">linearForm</span><span class="p">()</span>
            <span class="k">for</span> <span class="n">head</span> <span class="ow">in</span> <span class="n">lf</span><span class="p">:</span>
                <span class="k">for</span> <span class="n">st</span> <span class="ow">in</span> <span class="n">lf</span><span class="p">[</span><span class="n">head</span><span class="p">]:</span>
                    <span class="k">if</span> <span class="ow">not</span> <span class="p">(</span><span class="n">st</span> <span class="ow">in</span> <span class="n">s</span><span class="p">):</span>
                        <span class="n">stack</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">st</span><span class="p">)</span>
                        <span class="n">s</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">st</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">s</span>
</div>
<div class="viewcode-block" id="xre.concatenation"><a class="viewcode-back" href="../index.html#xre.xre.concatenation">[docs]</a>    <span class="k">def</span> <span class="nf">concatenation</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">r</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Computes the concatenation of two regular expressions.</span>

<span class="sd">        :arg r: a regular expression</span>
<span class="sd">        :type r: xre</span>
<span class="sd">        :rtype: xre&quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">r</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xepsilon</span><span class="p">:</span>
            <span class="k">return</span> <span class="bp">self</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">r</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xempty</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">r</span>
        <span class="n">sig</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">unionSigma</span><span class="p">(</span><span class="n">r</span><span class="p">)</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">r</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xconcat</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconcat</span><span class="p">(</span><span class="n">copy</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="o">+</span> <span class="n">r</span><span class="o">.</span><span class="n">val</span><span class="p">),</span> <span class="n">sigma</span><span class="o">=</span><span class="n">sig</span><span class="p">)</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconcat</span><span class="p">(</span><span class="n">copy</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">r</span><span class="p">]),</span> <span class="n">sigma</span><span class="o">=</span><span class="n">sig</span><span class="p">)</span>
</div>
<div class="viewcode-block" id="xre.intersection"><a class="viewcode-back" href="../index.html#xre.xre.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">sx</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Computes the intersection of two regular expressions.</span>

<span class="sd">        :arg sx: a regular expression</span>
<span class="sd">        :type sx: xre</span>
<span class="sd">        :return type: xre&quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="n">sx</span> <span class="o">==</span> <span class="bp">self</span><span class="p">:</span>
            <span class="k">return</span> <span class="bp">self</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xconj</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconj</span><span class="p">(</span><span class="n">sx</span><span class="o">.</span><span class="n">val</span> <span class="o">|</span> <span class="p">{</span><span class="bp">self</span><span class="p">},</span> <span class="n">sigma</span><span class="o">=</span><span class="bp">self</span><span class="o">.</span><span class="n">unionSigma</span><span class="p">(</span><span class="n">sx</span><span class="p">))</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xstar</span><span class="p">:</span>
            <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="o">.</span><span class="n">val</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xre</span><span class="p">:</span>
                <span class="k">if</span> <span class="n">sx</span><span class="o">.</span><span class="n">val</span> <span class="o">==</span> <span class="bp">self</span><span class="p">:</span>
                    <span class="k">return</span> <span class="bp">self</span>
                <span class="k">else</span><span class="p">:</span>
                    <span class="k">return</span> <span class="n">xempty</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">else</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">xconj</span><span class="p">({</span><span class="bp">self</span><span class="p">,</span> <span class="n">sx</span><span class="p">},</span> <span class="n">sigma</span><span class="o">=</span><span class="bp">self</span><span class="o">.</span><span class="n">unionSigma</span><span class="p">(</span><span class="n">sx</span><span class="p">))</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xempty</span> <span class="ow">or</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xepsilon</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xempty</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">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xre</span><span class="p">:</span>
            <span class="k">if</span> <span class="n">sx</span> <span class="o">==</span> <span class="bp">self</span><span class="p">:</span>
                <span class="k">return</span> <span class="bp">self</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">xempty</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">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconj</span><span class="p">({</span><span class="bp">self</span><span class="p">,</span> <span class="n">sx</span><span class="p">},</span> <span class="n">sigma</span><span class="o">=</span><span class="bp">self</span><span class="o">.</span><span class="n">unionSigma</span><span class="p">(</span><span class="n">sx</span><span class="p">))</span>
</div>
    <span class="k">def</span> <span class="nf">_not</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot; &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="n">xnot</span><span class="p">(</span><span class="n">copy</span><span class="o">.</span><span class="n">deepcopy</span><span class="p">(</span><span class="bp">self</span><span class="p">))</span>

<div class="viewcode-block" id="xre.compare"><a class="viewcode-back" href="../index.html#xre.xre.compare">[docs]</a>    <span class="k">def</span> <span class="nf">compare</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">r</span><span class="p">,</span> <span class="n">cmp_method</span><span class="o">=</span><span class="s">&quot;equivP&quot;</span><span class="p">,</span> <span class="n">nfa_method</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Compare with another regular expression for equivalence.</span>
<span class="sd">        :param r:</span>
<span class="sd">        :param cmp_method:</span>
<span class="sd">        :param nfa_method: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="n">cmp_method</span> <span class="o">==</span> <span class="s">&quot;compareMinimalDFA&quot;</span><span class="p">:</span>
            <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">compareMinimalDFA</span><span class="p">(</span><span class="n">r</span><span class="p">,</span> <span class="n">nfa_method</span><span class="p">)</span>
        <span class="k">elif</span> <span class="n">cmp_method</span> <span class="o">==</span> <span class="s">&quot;equivP&quot;</span><span class="p">:</span>
            <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">equivP</span><span class="p">(</span><span class="n">r</span><span class="p">)</span>
</div>
<div class="viewcode-block" id="xre.support"><a class="viewcode-back" href="../index.html#xre.xre.support">[docs]</a>    <span class="k">def</span> <span class="nf">support</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;&#39;Support of a regular expression.</span>

<span class="sd">        :return: set of regular expressions</span>
<span class="sd">        :rtype: set</span>

<span class="sd">        .. seealso::</span>
<span class="sd">            Champarnaud, J.M., Ziadi, D.: From Mirkin&#39;s prebases to Antimirov&#39;s word partial derivative.</span>
<span class="sd">            Fundam. Inform. 45(3), 195-205 (2001)&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="p">{</span><span class="n">xepsilon</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">)}</span>
</div>
    <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="n">dfa_method</span><span class="o">=</span><span class="s">&quot;dfaDerivatives&quot;</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;DFA that accepts the regular expression&#39;s language.</span>
<span class="sd">        :param dfa_method: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">__getattribute__</span><span class="p">(</span><span class="n">dfa_method</span><span class="p">)()</span>

<div class="viewcode-block" id="xre.toNFA"><a class="viewcode-back" href="../index.html#xre.xre.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="n">nfa_method</span><span class="o">=</span><span class="s">&quot;nfaPD&quot;</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;NFA that accepts the regular expression&#39;s language.</span>
<span class="sd">        :param nfa_method: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">__getattribute__</span><span class="p">(</span><span class="n">nfa_method</span><span class="p">)()</span>
</div>
<div class="viewcode-block" id="xre.equivP"><a class="viewcode-back" href="../index.html#xre.xre.equivP">[docs]</a>    <span class="k">def</span> <span class="nf">equivP</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">reg</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Verifies if two regular expressions are equivalent.</span>
<span class="sd">    </span>
<span class="sd">        :param reg: regular expression</span>
<span class="sd">        :rtype: bool &quot;&quot;&quot;</span>
        <span class="n">s</span> <span class="o">=</span> <span class="p">{(</span><span class="bp">self</span><span class="p">,</span> <span class="n">reg</span><span class="p">)}</span>
        <span class="c"># h = {(self, reg)}</span>
        <span class="n">h</span> <span class="o">=</span> <span class="nb">set</span><span class="p">([])</span>
        <span class="n">sigma</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">setOfSymbols</span><span class="p">()</span><span class="o">.</span><span class="n">union</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">setOfSymbols</span><span class="p">())</span>
        <span class="k">while</span> <span class="n">s</span><span class="p">:</span>
            <span class="n">s1</span><span class="p">,</span> <span class="n">s2</span> <span class="o">=</span> <span class="n">s</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span>
            <span class="k">if</span> <span class="n">s1</span><span class="o">.</span><span class="n">ewp</span><span class="p">()</span> <span class="o">!=</span> <span class="n">s2</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
                <span class="k">return</span> <span class="bp">False</span>
            <span class="n">h</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">s2</span><span class="p">))</span>
            <span class="k">for</span> <span class="n">a</span> <span class="ow">in</span> <span class="n">sigma</span><span class="p">:</span>
                <span class="n">der1</span> <span class="o">=</span> <span class="n">s1</span><span class="o">.</span><span class="n">derivative</span><span class="p">(</span><span class="n">a</span><span class="p">)</span>
                <span class="n">der2</span> <span class="o">=</span> <span class="n">s2</span><span class="o">.</span><span class="n">derivative</span><span class="p">(</span><span class="n">a</span><span class="p">)</span>
                <span class="k">if</span> <span class="p">(</span><span class="n">der1</span><span class="p">,</span> <span class="n">der2</span><span class="p">)</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">h</span><span class="p">:</span>
                    <span class="c">#h.add((der1,der2))</span>
                    <span class="n">s</span><span class="o">.</span><span class="n">add</span><span class="p">((</span><span class="n">der1</span><span class="p">,</span> <span class="n">der2</span><span class="p">))</span>
        <span class="k">return</span> <span class="bp">True</span>
</div>
<div class="viewcode-block" id="xre.toDFA"><a class="viewcode-back" href="../index.html#xre.xre.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="n">dfa_method</span><span class="o">=</span><span class="s">&quot;dfaDerivatives&quot;</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;DFA that accepts the regular expression&#39;s language.</span>
<span class="sd">        :param dfa_method: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">__getattribute__</span><span class="p">(</span><span class="n">dfa_method</span><span class="p">)()</span>
</div>
<div class="viewcode-block" id="xre.dfs"><a class="viewcode-back" href="../index.html#xre.xre.dfs">[docs]</a>    <span class="k">def</span> <span class="nf">dfs</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot; Minimal DFA of an extended regular expression </span>
<span class="sd">        :return: minimal DFA</span>
<span class="sd">        :rtype: DFA</span>
<span class="sd">        &quot;&quot;&quot;</span>
        <span class="n">aut</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">initial</span> <span class="o">=</span> <span class="n">aut</span><span class="o">.</span><span class="n">addState</span><span class="p">(</span><span class="bp">self</span><span class="p">)</span>
        <span class="n">aut</span><span class="o">.</span><span class="n">setInitial</span><span class="p">(</span><span class="n">initial</span><span class="p">)</span>
        <span class="n">stack</span> <span class="o">=</span> <span class="p">[(</span><span class="bp">self</span><span class="p">,</span> <span class="n">initial</span><span class="p">)]</span>
        <span class="n">sigma</span> <span class="o">=</span> <span class="n">copy</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">setOfSymbols</span><span class="p">())</span>
        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span> <span class="ow">is</span> <span class="ow">not</span> <span class="bp">None</span><span class="p">:</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="n">aut</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="c"># equiv = {self:{self}}</span>
        <span class="n">equiv</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="k">while</span> <span class="n">stack</span><span class="p">:</span>
            <span class="n">state</span><span class="p">,</span> <span class="n">idx</span> <span class="o">=</span> <span class="n">stack</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span>
            <span class="n">state</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="k">for</span> <span class="n">symbol</span> <span class="ow">in</span> <span class="n">sigma</span><span class="p">:</span>
                <span class="n">d</span> <span class="o">=</span> <span class="n">state</span><span class="o">.</span><span class="n">derivative</span><span class="p">(</span><span class="n">symbol</span><span class="p">)</span>
                <span class="n">f</span> <span class="o">=</span> <span class="bp">True</span>
                <span class="k">if</span> <span class="n">d</span> <span class="ow">in</span> <span class="n">aut</span><span class="o">.</span><span class="n">States</span><span class="p">:</span>
                    <span class="n">i</span> <span class="o">=</span> <span class="n">aut</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">d</span><span class="p">)</span>
                <span class="k">elif</span> <span class="n">d</span> <span class="ow">in</span> <span class="n">equiv</span><span class="p">:</span>
                    <span class="n">i</span> <span class="o">=</span> <span class="n">aut</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">equiv</span><span class="p">[</span><span class="n">d</span><span class="p">])</span>
                <span class="k">else</span><span class="p">:</span>
                    <span class="k">for</span> <span class="n">st</span> <span class="ow">in</span> <span class="n">aut</span><span class="o">.</span><span class="n">States</span><span class="p">:</span>
                        <span class="k">if</span> <span class="n">d</span><span class="o">.</span><span class="n">equivP</span><span class="p">(</span><span class="n">st</span><span class="p">):</span>
                            <span class="n">i</span> <span class="o">=</span> <span class="n">aut</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">st</span><span class="p">)</span>
                            <span class="n">f</span> <span class="o">=</span> <span class="bp">False</span>
                            <span class="n">equiv</span><span class="p">[</span><span class="n">st</span><span class="p">]</span> <span class="o">=</span> <span class="n">d</span>
                            <span class="n">equiv</span><span class="p">[</span><span class="n">d</span><span class="p">]</span> <span class="o">=</span> <span class="n">st</span>
                    <span class="k">if</span> <span class="n">f</span><span class="p">:</span>
                        <span class="n">i</span> <span class="o">=</span> <span class="n">aut</span><span class="o">.</span><span class="n">addState</span><span class="p">(</span><span class="n">d</span><span class="p">)</span>
                        <span class="n">stack</span><span class="o">.</span><span class="n">append</span><span class="p">((</span><span class="n">d</span><span class="p">,</span> <span class="n">i</span><span class="p">))</span>
                <span class="n">aut</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="n">idx</span><span class="p">,</span> <span class="n">symbol</span><span class="p">,</span> <span class="n">i</span><span class="p">)</span>
            <span class="k">if</span> <span class="n">state</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
                <span class="n">aut</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">idx</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">aut</span>
</div>
<div class="viewcode-block" id="xre.dfaDerivatives"><a class="viewcode-back" href="../index.html#xre.xre.dfaDerivatives">[docs]</a>    <span class="k">def</span> <span class="nf">dfaDerivatives</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Word derivatives automaton of the regular expression</span>

<span class="sd">        :return: word derivatives automaton</span>
<span class="sd">        :rtype: DFA</span>

<span class="sd">        .. seealso::</span>
<span class="sd">            J. A. Brzozowski, Derivatives of Regular Expressions. J. ACM 11(4): 481-494 (1964)&quot;&quot;&quot;</span>
        <span class="n">aut</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">i</span> <span class="o">=</span> <span class="n">aut</span><span class="o">.</span><span class="n">addState</span><span class="p">(</span><span class="bp">self</span><span class="p">)</span>
        <span class="n">aut</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="n">stack</span> <span class="o">=</span> <span class="p">[(</span><span class="bp">self</span><span class="p">,</span> <span class="n">i</span><span class="p">)]</span>
        <span class="n">sigma</span> <span class="o">=</span> <span class="n">copy</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">setOfSymbols</span><span class="p">())</span>
        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span> <span class="ow">is</span> <span class="ow">not</span> <span class="bp">None</span><span class="p">:</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="n">aut</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="k">while</span> <span class="n">stack</span><span class="p">:</span>
            <span class="n">state</span><span class="p">,</span> <span class="n">idx</span> <span class="o">=</span> <span class="n">stack</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span>
            <span class="n">state</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="k">for</span> <span class="n">symbol</span> <span class="ow">in</span> <span class="n">sigma</span><span class="p">:</span>
                <span class="n">st</span> <span class="o">=</span> <span class="n">state</span><span class="o">.</span><span class="n">derivative</span><span class="p">(</span><span class="n">symbol</span><span class="p">)</span>
                <span class="k">if</span> <span class="n">st</span> <span class="ow">in</span> <span class="n">aut</span><span class="o">.</span><span class="n">States</span><span class="p">:</span>
                    <span class="n">i</span> <span class="o">=</span> <span class="n">aut</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">st</span><span class="p">)</span>
                <span class="k">else</span><span class="p">:</span>
                    <span class="n">i</span> <span class="o">=</span> <span class="n">aut</span><span class="o">.</span><span class="n">addState</span><span class="p">(</span><span class="n">st</span><span class="p">)</span>
                    <span class="n">stack</span><span class="o">.</span><span class="n">append</span><span class="p">((</span><span class="n">st</span><span class="p">,</span> <span class="n">i</span><span class="p">))</span>
                <span class="n">aut</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="n">idx</span><span class="p">,</span> <span class="n">symbol</span><span class="p">,</span> <span class="n">i</span><span class="p">)</span>
            <span class="k">if</span> <span class="n">state</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
                <span class="n">aut</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">idx</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">aut</span>
</div>
<div class="viewcode-block" id="xre.nfaPD"><a class="viewcode-back" href="../index.html#xre.xre.nfaPD">[docs]</a>    <span class="k">def</span> <span class="nf">nfaPD</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;NFA that accepts the regular expression&#39;s language, and which is constructed from the expression&#39;s partial</span>
<span class="sd">         derivatives.</span>

<span class="sd">        :return: partial derivatives [or equation] automaton</span>
<span class="sd">        :rtype: NFA</span>

<span class="sd">        .. seealso::</span>
<span class="sd">            V. M. Antimirov, Partial Derivatives of Regular Expressions and Finite Automaton Constructions.</span>
<span class="sd">            Theor. Comput. Sci.155(2): 291-319 (1996)</span>

<span class="sd">        ..attention why different from reex.nfaPD    &quot;&quot;&quot;</span>
        <span class="n">aut</span> <span class="o">=</span> <span class="n">fa</span><span class="o">.</span><span class="n">NFA</span><span class="p">()</span>
        <span class="n">i</span> <span class="o">=</span> <span class="n">aut</span><span class="o">.</span><span class="n">addState</span><span class="p">(</span><span class="bp">self</span><span class="p">)</span>
        <span class="n">aut</span><span class="o">.</span><span class="n">addInitial</span><span class="p">(</span><span class="n">i</span><span class="p">)</span>
        <span class="n">stack</span> <span class="o">=</span> <span class="p">[(</span><span class="bp">self</span><span class="p">,</span> <span class="n">i</span><span class="p">)]</span>
        <span class="n">sigma</span> <span class="o">=</span> <span class="n">copy</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">setOfSymbols</span><span class="p">())</span>
        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span> <span class="ow">is</span> <span class="ow">not</span> <span class="bp">None</span><span class="p">:</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="n">aut</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="k">while</span> <span class="n">stack</span><span class="p">:</span>
            <span class="n">state</span><span class="p">,</span> <span class="n">idx</span> <span class="o">=</span> <span class="n">stack</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span>
            <span class="n">state</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">lf</span> <span class="o">=</span> <span class="n">state</span><span class="o">.</span><span class="n">linearForm</span><span class="p">()</span>
            <span class="k">for</span> <span class="n">head</span> <span class="ow">in</span> <span class="n">lf</span><span class="o">.</span><span class="n">keys</span><span class="p">():</span>
                <span class="k">for</span> <span class="n">st</span> <span class="ow">in</span> <span class="n">lf</span><span class="p">[</span><span class="n">head</span><span class="p">]:</span>
                    <span class="k">if</span> <span class="n">st</span> <span class="ow">in</span> <span class="n">aut</span><span class="o">.</span><span class="n">States</span><span class="p">:</span>
                        <span class="n">i</span> <span class="o">=</span> <span class="n">aut</span><span class="o">.</span><span class="n">stateIndex</span><span class="p">(</span><span class="n">st</span><span class="p">)</span>
                    <span class="k">else</span><span class="p">:</span>
                        <span class="n">i</span> <span class="o">=</span> <span class="n">aut</span><span class="o">.</span><span class="n">addState</span><span class="p">(</span><span class="n">st</span><span class="p">)</span>
                        <span class="n">stack</span><span class="o">.</span><span class="n">append</span><span class="p">((</span><span class="n">st</span><span class="p">,</span> <span class="n">i</span><span class="p">))</span>
                    <span class="n">aut</span><span class="o">.</span><span class="n">addTransition</span><span class="p">(</span><span class="n">idx</span><span class="p">,</span> <span class="n">head</span><span class="p">,</span> <span class="n">i</span><span class="p">)</span>
            <span class="k">if</span> <span class="n">state</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
                <span class="n">aut</span><span class="o">.</span><span class="n">addFinal</span><span class="p">(</span><span class="n">idx</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">aut</span>
</div>
    <span class="k">def</span> <span class="nf">_cross</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lists</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lists: &quot;&quot;&quot;</span>
        <span class="n">rex</span> <span class="o">=</span> <span class="nb">list</span><span class="p">(</span><span class="n">copy</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">val</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">rex</span><span class="p">)):</span>
            <span class="n">re1</span> <span class="o">=</span> <span class="n">rex</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">rex</span><span class="p">)):</span>
                <span class="n">re2</span> <span class="o">=</span> <span class="n">rex</span><span class="p">[</span><span class="n">j</span><span class="p">]</span>
                <span class="k">for</span> <span class="n">symbol</span> <span class="ow">in</span> <span class="n">re1</span><span class="o">.</span><span class="n">last</span><span class="p">():</span>
                    <span class="k">if</span> <span class="ow">not</span> <span class="n">symbol</span> <span class="ow">in</span> <span class="n">lists</span><span class="p">:</span>
                        <span class="n">lists</span><span class="p">[</span><span class="n">symbol</span><span class="p">]</span> <span class="o">=</span> <span class="n">re2</span><span class="o">.</span><span class="n">first</span><span class="p">()</span>
                    <span class="k">else</span><span class="p">:</span>
                        <span class="n">lists</span><span class="p">[</span><span class="n">symbol</span><span class="p">]</span> <span class="o">+=</span> <span class="n">re2</span><span class="o">.</span><span class="n">first</span><span class="p">()</span>
                <span class="k">for</span> <span class="n">symbol</span> <span class="ow">in</span> <span class="n">re2</span><span class="o">.</span><span class="n">last</span><span class="p">():</span>
                    <span class="k">if</span> <span class="ow">not</span> <span class="n">symbol</span> <span class="ow">in</span> <span class="n">lists</span><span class="p">:</span>
                        <span class="n">lists</span><span class="p">[</span><span class="n">symbol</span><span class="p">]</span> <span class="o">=</span> <span class="n">re1</span><span class="o">.</span><span class="n">first</span><span class="p">()</span>
                    <span class="k">else</span><span class="p">:</span>
                        <span class="n">lists</span><span class="p">[</span><span class="n">symbol</span><span class="p">]</span> <span class="o">+=</span> <span class="n">re1</span><span class="o">.</span><span class="n">first</span><span class="p">()</span>
        <span class="k">return</span> <span class="n">lists</span>

    <span class="nd">@staticmethod</span>
    <span class="k">def</span> <span class="nf">_concat</span><span class="p">(</span><span class="n">der</span><span class="p">,</span> <span class="n">r</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Computes a set that contains the concatenation of a regular expression with all the regular expression</span>
<span class="sd">        within a set.</span>
<span class="sd">    </span>
<span class="sd">        :param der:</span>
<span class="sd">        :param r:</span>
<span class="sd">        :arg der: set of regular expressions</span>
<span class="sd">        :arg re: regular expression</span>
<span class="sd">        :rtype: set of regular expression&quot;&quot;&quot;</span>
        <span class="n">s</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">der</span><span class="p">:</span>
            <span class="n">ci</span> <span class="o">=</span> <span class="n">i</span><span class="o">.</span><span class="n">concatenation</span><span class="p">(</span><span class="n">r</span><span class="p">)</span>
            <span class="k">if</span> <span class="ow">not</span> <span class="p">(</span><span class="nb">type</span><span class="p">(</span><span class="n">ci</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xempty</span><span class="p">):</span>
                <span class="n">s</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">ci</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">s</span>

    <span class="nd">@staticmethod</span>
    <span class="k">def</span> <span class="nf">_intersection</span><span class="p">(</span><span class="n">a1</span><span class="p">,</span> <span class="n">a2</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param a1:</span>
<span class="sd">        :param a2:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="n">s</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">a1</span><span class="p">:</span>
            <span class="k">for</span> <span class="n">j</span> <span class="ow">in</span> <span class="n">a2</span><span class="p">:</span>
                <span class="n">res</span> <span class="o">=</span> <span class="n">i</span><span class="o">.</span><span class="n">intersection</span><span class="p">(</span><span class="n">j</span><span class="p">)</span>
                <span class="k">if</span> <span class="ow">not</span> <span class="p">(</span><span class="nb">type</span><span class="p">(</span><span class="n">res</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xempty</span><span class="p">):</span>
                    <span class="n">s</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">res</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">s</span>

</div>
<span class="k">class</span> <span class="nc">xspecialConst</span><span class="p">(</span><span class="n">xre</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Base class for xepsilon and xempty.&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">sigma</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma: &quot;&quot;&quot;</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">def</span> <span class="nf">__copy__</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span>

    <span class="k">def</span> <span class="nf">__eq__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">re</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param re: the other re &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="bp">self</span><span class="p">)</span> <span class="o">==</span> <span class="nb">type</span><span class="p">(</span><span class="n">re</span><span class="p">):</span>
            <span class="k">return</span> <span class="bp">True</span>

    <span class="k">def</span> <span class="nf">setOfSymbols</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:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="nb">set</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">alphabeticLength</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:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="mi">0</span>

    <span class="k">def</span> <span class="nf">_marked</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">pos</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param pos:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="p">,</span> <span class="n">pos</span>

    <span class="k">def</span> <span class="nf">unmarked</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;The unmarked form of the regular expression. Each leaf in its syntactical tree becomes a regexp(),</span>
<span class="sd">        the epsilon() or the emptyset().</span>

<span class="sd">        :rtype: (general) regular expression&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span>

    <span class="k">def</span> <span class="nf">first</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="p">[]</span>

    <span class="k">def</span> <span class="nf">last</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:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="p">[]</span>

    <span class="k">def</span> <span class="nf">followLists</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lists</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lists:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="n">lists</span> <span class="ow">is</span> <span class="bp">None</span><span class="p">:</span>
            <span class="k">return</span> <span class="p">{}</span>
        <span class="k">return</span> <span class="n">lists</span>

    <span class="k">def</span> <span class="nf">followListsStar</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lists</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lists:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="n">lists</span> <span class="ow">is</span> <span class="bp">None</span><span class="p">:</span>
            <span class="k">return</span> <span class="p">{}</span>
        <span class="k">return</span> <span class="n">lists</span>


    <span class="k">def</span> <span class="nf">partialDerivatives</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="nb">set</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">partialDerivativeC</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="p">{</span><span class="n">xsigmaS</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">linearForm</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: dictionary mapping heads to sets of tails</span>
<span class="sd">        :rtype: {symbol: set([regular expressions])}</span>

<span class="sd">        .. seealso:: Antimirov, 95&quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="ow">not</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span><span class="p">:</span>
            <span class="n">syms</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">setOfSymbols</span><span class="p">()</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">setSigma</span><span class="p">(</span><span class="n">syms</span><span class="p">)</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">_linearForm</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">_linearForm</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:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="p">{}</span>

    <span class="k">def</span> <span class="nf">_linearFormC</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:&quot;&quot;&quot;</span>
        <span class="n">lf</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="k">for</span> <span class="n">sigma</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">lf</span><span class="p">[</span><span class="n">sigma</span><span class="p">]</span> <span class="o">=</span> <span class="p">{</span><span class="n">xsigmaS</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">return</span> <span class="n">lf</span>

    <span class="k">def</span> <span class="nf">derivative</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="n">xempty</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">support</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:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="p">{}</span>


<span class="k">class</span> <span class="nc">xempty</span><span class="p">(</span><span class="n">xspecialConst</span><span class="p">,</span> <span class="n">reex</span><span class="o">.</span><span class="n">emptyset</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Class that represents the empty set.&quot;&quot;&quot;</span>

    <span class="k">def</span> <span class="nf">concatenation</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">r</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param r:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="n">xempty</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">intersection</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">sx</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sx:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="n">xempty</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">_not</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:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="n">xsigmaS</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">class</span> <span class="nc">xepsilon</span><span class="p">(</span><span class="n">xspecialConst</span><span class="p">,</span> <span class="n">reex</span><span class="o">.</span><span class="n">epsilon</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Class that represents the empty word.&quot;&quot;&quot;</span>

    <span class="k">def</span> <span class="nf">concatenation</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">r</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param r:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="n">r</span>

    <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">sx</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sx:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="n">sx</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
            <span class="k">return</span> <span class="n">xepsilon</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">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xempty</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">_not</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="k">return</span> <span class="n">xsigmaP</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">class</span> <span class="nc">xsigmaS</span><span class="p">(</span><span class="n">xspecialConst</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Class that represents the complement of the empty set&quot;&quot;&quot;</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="s">&quot;xsigmaS()&quot;</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="s">&quot;xsigmaS&quot;</span>

    <span class="k">def</span> <span class="nf">ewp</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:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">True</span>

    <span class="k">def</span> <span class="nf">_linearForm</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:&quot;&quot;&quot;</span>
        <span class="n">lf</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="k">for</span> <span class="n">sigma</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">lf</span><span class="p">[</span><span class="n">sigma</span><span class="p">]</span> <span class="o">=</span> <span class="p">{</span><span class="n">xsigmaS</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">return</span> <span class="n">lf</span>

    <span class="k">def</span> <span class="nf">_linearFormC</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:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="p">{}</span>

    <span class="k">def</span> <span class="nf">derivative</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span> <span class="ow">is</span> <span class="ow">not</span> <span class="bp">None</span> <span class="ow">and</span> <span class="n">sigma</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">return</span> <span class="n">xsigmaS</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">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xempty</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">partialDerivatives</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">if</span>  <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span> <span class="ow">is</span> <span class="ow">not</span> <span class="bp">None</span> <span class="ow">and</span> <span class="n">sigma</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">return</span> <span class="p">{</span><span class="n">xsigmaS</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">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="nb">set</span><span class="p">([])</span>

    <span class="k">def</span> <span class="nf">partialDerivativeC</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="nb">set</span><span class="p">([])</span>

    <span class="k">def</span> <span class="nf">support</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="p">{</span><span class="n">xsigmaS</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">_not</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="n">xempty</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">class</span> <span class="nc">xsigmaP</span><span class="p">(</span><span class="n">xspecialConst</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Class that represents the complement of the empty word&quot;&quot;&quot;</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="s">&quot;xsigmaP()&quot;</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="s">&quot;xsigmaP&quot;</span>

    <span class="k">def</span> <span class="nf">ewp</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">False</span>

    <span class="k">def</span> <span class="nf">derivative</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span> <span class="ow">is</span> <span class="ow">not</span> <span class="bp">None</span> <span class="ow">and</span> <span class="n">sigma</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">return</span> <span class="n">xsigmaS</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">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xempty</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">partialDerivatives</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">Sigma</span> <span class="ow">is</span> <span class="ow">not</span> <span class="bp">None</span> <span class="ow">and</span> <span class="n">sigma</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">return</span> <span class="p">{</span><span class="n">xsigmaS</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">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="nb">set</span><span class="p">([])</span>

    <span class="k">def</span> <span class="nf">partialDerivativeC</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="nb">set</span><span class="p">([])</span>

    <span class="k">def</span> <span class="nf">_linearForm</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:&quot;&quot;&quot;</span>
        <span class="n">lf</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="k">for</span> <span class="n">sigma</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">lf</span><span class="p">[</span><span class="n">sigma</span><span class="p">]</span> <span class="o">=</span> <span class="p">{</span><span class="n">xsigmaS</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">return</span> <span class="n">lf</span>

    <span class="k">def</span> <span class="nf">_linearFormC</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="p">{}</span>

    <span class="k">def</span> <span class="nf">support</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="p">{</span><span class="n">xsigmaS</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">_not</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="n">xepsilon</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">class</span> <span class="nc">xconnective</span><span class="p">(</span><span class="n">xre</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Base class for xdisj, xconcat and xconj.&quot;&quot;&quot;</span>

    <span class="k">def</span> <span class="nf">__hash__</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="nb">hash</span><span class="p">((</span><span class="nb">frozenset</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">),</span> <span class="nb">type</span><span class="p">(</span><span class="bp">self</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return: &quot;&quot;&quot;</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">val</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">alphabeticLength</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: &quot;&quot;&quot;</span>
        <span class="n">length</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="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">length</span> <span class="o">+=</span> <span class="n">i</span><span class="o">.</span><span class="n">alphabeticLength</span><span class="p">()</span>
        <span class="k">return</span> <span class="n">length</span>

    <span class="k">def</span> <span class="nf">epsilonLength</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: &quot;&quot;&quot;</span>
        <span class="n">length</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="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">length</span> <span class="o">+=</span> <span class="n">i</span><span class="o">.</span><span class="n">epsilonLength</span><span class="p">()</span>
        <span class="k">return</span> <span class="n">length</span>

    <span class="k">def</span> <span class="nf">treeLength</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: &quot;&quot;&quot;</span>
        <span class="n">length</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="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">length</span> <span class="o">+=</span> <span class="n">i</span><span class="o">.</span><span class="n">treeLength</span><span class="p">()</span>
        <span class="k">return</span> <span class="n">length</span> <span class="o">+</span> <span class="mi">1</span>

    <span class="k">def</span> <span class="nf">syntacticLength</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: &quot;&quot;&quot;</span>
        <span class="n">length</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">val</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="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">length</span> <span class="o">+=</span> <span class="n">i</span><span class="o">.</span><span class="n">syntacticLength</span><span class="p">()</span>
        <span class="k">return</span> <span class="n">length</span>

    <span class="k">def</span> <span class="nf">setOfSymbols</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: &quot;&quot;&quot;</span>
        <span class="n">s</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="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">s</span> <span class="o">=</span> <span class="n">s</span> <span class="o">|</span> <span class="n">i</span><span class="o">.</span><span class="n">setOfSymbols</span><span class="p">()</span>
        <span class="k">return</span> <span class="n">s</span>

    <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">s</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return: &quot;&quot;&quot;</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">val</span><span class="p">:</span>
            <span class="n">i</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">s</span><span class="p">)</span>



<span class="k">class</span> <span class="nc">xdisj</span><span class="p">(</span><span class="n">xconnective</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Class that represents the disjunction operation.&quot;&quot;&quot;</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="s">&quot;xdisj({0:s})&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="nb">repr</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">val</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="s">&quot;({0:s})&quot;</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">_strP</span><span class="p">())</span>

    <span class="k">def</span> <span class="nf">_strP</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="s">&quot; + &quot;</span><span class="o">.</span><span class="n">join</span><span class="p">([</span><span class="nb">str</span><span class="p">(</span><span class="n">i</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">val</span><span class="p">])</span>

    <span class="k">def</span> <span class="nf">ewp</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: &quot;&quot;&quot;</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">val</span><span class="p">:</span>
            <span class="k">if</span> <span class="n">i</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
                <span class="k">return</span> <span class="bp">True</span>
        <span class="k">return</span> <span class="bp">False</span>

    <span class="k">def</span> <span class="nf">_marked</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">pos</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param pos:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="n">s</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="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">mark</span><span class="p">,</span> <span class="n">pos</span> <span class="o">=</span> <span class="n">i</span><span class="o">.</span><span class="n">_marked</span><span class="p">(</span><span class="n">pos</span><span class="p">)</span>
            <span class="n">s</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">mark</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">xdisj</span><span class="p">(</span><span class="n">s</span><span class="p">),</span> <span class="n">pos</span>

    <span class="k">def</span> <span class="nf">first</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: &quot;&quot;&quot;</span>
        <span class="n">lfst</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="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">fst</span> <span class="o">=</span> <span class="n">i</span><span class="o">.</span><span class="n">first</span><span class="p">()</span>
            <span class="n">lfst</span> <span class="o">+=</span> <span class="n">fst</span>
        <span class="k">return</span> <span class="n">lfst</span>

    <span class="k">def</span> <span class="nf">last</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: &quot;&quot;&quot;</span>
        <span class="n">llst</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="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">lst</span> <span class="o">=</span> <span class="n">i</span><span class="o">.</span><span class="n">last</span><span class="p">()</span>
            <span class="n">llst</span> <span class="o">+=</span> <span class="n">lst</span>
        <span class="k">return</span> <span class="n">llst</span>

    <span class="k">def</span> <span class="nf">followLists</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lists</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lists:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="n">lists</span> <span class="ow">is</span> <span class="bp">None</span><span class="p">:</span>
            <span class="n">lists</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="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">i</span><span class="o">.</span><span class="n">followLists</span><span class="p">(</span><span class="n">lists</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">lists</span>

    <span class="k">def</span> <span class="nf">followListsStar</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lists</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lists:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="n">lists</span> <span class="ow">is</span> <span class="bp">None</span><span class="p">:</span>
            <span class="n">lists</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="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">i</span><span class="o">.</span><span class="n">followListsStar</span><span class="p">(</span><span class="n">lists</span><span class="p">)</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">_cross</span><span class="p">(</span><span class="n">lists</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">lists</span>

    <span class="k">def</span> <span class="nf">derivative</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="n">s</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="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">der</span> <span class="o">=</span> <span class="n">i</span><span class="o">.</span><span class="n">derivative</span><span class="p">(</span><span class="n">sigma</span><span class="p">)</span>
            <span class="k">if</span> <span class="ow">not</span> <span class="p">(</span><span class="nb">type</span><span class="p">(</span><span class="n">der</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xempty</span><span class="p">):</span>
                <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">der</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xdisj</span><span class="p">:</span>
                    <span class="n">s</span><span class="o">.</span><span class="n">update</span><span class="p">(</span><span class="n">der</span><span class="o">.</span><span class="n">val</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">add</span><span class="p">(</span><span class="n">der</span><span class="p">)</span>
        <span class="k">if</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">0</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xempty</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">elif</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">s</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="k">return</span> <span class="n">xdisj</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="k">def</span> <span class="nf">partialDerivatives</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="n">s</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="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">der</span> <span class="o">=</span> <span class="n">i</span><span class="o">.</span><span class="n">partialDerivatives</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">update</span><span class="p">(</span><span class="n">der</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">s</span>

    <span class="k">def</span> <span class="nf">partialDerivativeC</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="n">pd</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">partialDerivatives</span><span class="p">(</span><span class="n">sigma</span><span class="p">)</span>
        <span class="n">pdc</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
        <span class="k">for</span> <span class="n">di</span> <span class="ow">in</span> <span class="n">pd</span><span class="p">:</span>
            <span class="n">pdc</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">di</span><span class="o">.</span><span class="n">_not</span><span class="p">())</span>
        <span class="k">if</span> <span class="n">pdc</span><span class="p">:</span>
            <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">pdc</span><span class="p">)</span> <span class="o">!=</span> <span class="mi">1</span><span class="p">:</span>
                <span class="n">pdc</span> <span class="o">=</span> <span class="p">{</span><span class="n">xconj</span><span class="p">(</span><span class="n">pdc</span><span class="p">)}</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="n">pdc</span> <span class="o">=</span> <span class="p">{</span><span class="n">xsigmaS</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">return</span> <span class="n">pdc</span>

    <span class="c"># noinspection PyUnusedLocal</span>
    <span class="k">def</span> <span class="nf">_linearForm</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: &quot;&quot;&quot;</span>
        <span class="n">lf</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="n">sigma</span> <span class="o">=</span> <span class="n">copy</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="k">for</span> <span class="n">reg</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">reg</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">=</span> <span class="n">sigma</span>
            <span class="n">l</span> <span class="o">=</span> <span class="n">reg</span><span class="o">.</span><span class="n">linearForm</span><span class="p">()</span>
            <span class="n">tails</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
            <span class="k">for</span> <span class="n">head</span> <span class="ow">in</span> <span class="p">(</span><span class="n">lf</span><span class="o">.</span><span class="n">keys</span><span class="p">()</span> <span class="o">+</span> <span class="n">l</span><span class="o">.</span><span class="n">keys</span><span class="p">()):</span>
                <span class="n">tails</span> <span class="o">=</span> <span class="n">lf</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">head</span><span class="p">,</span> <span class="nb">set</span><span class="p">())</span> <span class="o">|</span> <span class="n">l</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">head</span><span class="p">,</span> <span class="nb">set</span><span class="p">())</span>
                <span class="k">if</span> <span class="n">tails</span><span class="p">:</span>
                    <span class="n">lf</span><span class="p">[</span><span class="n">head</span><span class="p">]</span> <span class="o">=</span> <span class="n">tails</span>
        <span class="k">return</span> <span class="n">lf</span>

    <span class="k">def</span> <span class="nf">_linearFormC</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: &quot;&quot;&quot;</span>
        <span class="n">lf</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">_linearForm</span><span class="p">()</span>
        <span class="n">lfc</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="k">for</span> <span class="n">head</span> <span class="ow">in</span> <span class="p">(</span><span class="n">lf</span><span class="o">.</span><span class="n">keys</span><span class="p">()):</span>
            <span class="n">pdc</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
            <span class="k">for</span> <span class="n">di</span> <span class="ow">in</span> <span class="n">lf</span><span class="p">[</span><span class="n">head</span><span class="p">]:</span>
                <span class="n">pdc</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">di</span><span class="o">.</span><span class="n">_not</span><span class="p">())</span>
            <span class="k">if</span> <span class="n">pdc</span><span class="p">:</span>
                <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">pdc</span><span class="p">)</span> <span class="o">!=</span> <span class="mi">1</span><span class="p">:</span>
                    <span class="n">pdc</span> <span class="o">=</span> <span class="p">{</span><span class="n">xconj</span><span class="p">(</span><span class="n">pdc</span><span class="p">)}</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="n">pdc</span> <span class="o">=</span> <span class="p">{</span><span class="n">xsigmaS</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">lfc</span><span class="p">[</span><span class="n">head</span><span class="p">]</span> <span class="o">=</span> <span class="n">pdc</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">Sigma</span><span class="p">:</span>
            <span class="k">if</span> <span class="ow">not</span> <span class="n">s</span> <span class="ow">in</span> <span class="n">lfc</span><span class="p">:</span>
                <span class="n">lfc</span><span class="p">[</span><span class="n">s</span><span class="p">]</span> <span class="o">=</span> <span class="p">{</span><span class="n">xsigmaS</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">return</span> <span class="n">lfc</span>

    <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">sx</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sx:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xconj</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconj</span><span class="p">(</span><span class="n">sx</span><span class="o">.</span><span class="n">val</span> <span class="o">|</span> <span class="p">{</span><span class="bp">self</span><span class="p">},</span> <span class="n">sigma</span><span class="o">=</span><span class="bp">self</span><span class="o">.</span><span class="n">unionSigma</span><span class="p">(</span><span class="n">sx</span><span class="p">))</span>
        <span class="k">elif</span> <span class="n">sx</span> <span class="o">==</span> <span class="bp">self</span><span class="p">:</span>
            <span class="k">return</span> <span class="bp">self</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xempty</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xempty</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">unionSigma</span><span class="p">(</span><span class="n">sx</span><span class="p">))</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xepsilon</span><span class="p">:</span>
            <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
                <span class="k">return</span> <span class="n">xepsilon</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">else</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">xempty</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">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconj</span><span class="p">({</span><span class="bp">self</span><span class="p">,</span> <span class="n">sx</span><span class="p">},</span> <span class="n">sigma</span><span class="o">=</span><span class="bp">self</span><span class="o">.</span><span class="n">unionSigma</span><span class="p">(</span><span class="n">sx</span><span class="p">))</span>

    <span class="k">def</span> <span class="nf">support</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: &quot;&quot;&quot;</span>
        <span class="n">s</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="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">p</span> <span class="o">=</span> <span class="n">i</span><span class="o">.</span><span class="n">support</span><span class="p">()</span>
            <span class="n">s</span><span class="o">.</span><span class="n">update</span><span class="p">(</span><span class="n">p</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">s</span>


<span class="k">class</span> <span class="nc">xconcat</span><span class="p">(</span><span class="n">xconnective</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Class that represents the concatenation operation.&quot;&quot;&quot;</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="s">&quot;{0:s}&quot;</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">_strP</span><span class="p">())</span>

    <span class="k">def</span> <span class="nf">_strP</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: &quot;&quot;&quot;</span>
        <span class="n">rep</span> <span class="o">=</span> <span class="s">&quot;&quot;</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">val</span><span class="p">:</span>
            <span class="n">rep</span> <span class="o">+=</span> <span class="s">&quot;{0:s}&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="nb">str</span><span class="p">(</span><span class="n">i</span><span class="p">))</span>
        <span class="k">return</span> <span class="n">rep</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="s">&quot;xconcat({0:s})&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="nb">repr</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">))</span>

    <span class="k">def</span> <span class="nf">head</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="n">copy</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">val</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span>

    <span class="k">def</span> <span class="nf">tail</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: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="bp">self</span><span class="p">)</span> <span class="o">==</span> <span class="mi">2</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">copy</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">val</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="k">return</span> <span class="n">xconcat</span><span class="p">(</span><span class="n">copy</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">val</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">Sigma</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">headrev</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="n">copy</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">val</span><span class="p">[</span><span class="o">-</span><span class="mi">1</span><span class="p">])</span>

    <span class="k">def</span> <span class="nf">tailrev</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: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="bp">self</span><span class="p">)</span> <span class="o">==</span> <span class="mi">2</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">copy</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">val</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconcat</span><span class="p">(</span><span class="n">copy</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">val</span><span class="p">[:</span><span class="o">-</span><span class="mi">1</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">ewp</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: &quot;&quot;&quot;</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">val</span><span class="p">:</span>
            <span class="k">if</span> <span class="ow">not</span> <span class="p">(</span><span class="n">i</span><span class="o">.</span><span class="n">ewp</span><span class="p">()):</span>
                <span class="k">return</span> <span class="bp">False</span>
        <span class="k">return</span> <span class="bp">True</span>

    <span class="k">def</span> <span class="nf">_marked</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">pos</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param pos:</span>
<span class="sd">        :return: &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">i</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">mark</span><span class="p">,</span> <span class="n">pos</span> <span class="o">=</span> <span class="n">i</span><span class="o">.</span><span class="n">_marked</span><span class="p">(</span><span class="n">pos</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">mark</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">xconcat</span><span class="p">(</span><span class="n">l</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">pos</span>

    <span class="k">def</span> <span class="nf">first</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: &quot;&quot;&quot;</span>
        <span class="n">lfst</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">head</span><span class="p">()</span><span class="o">.</span><span class="n">first</span><span class="p">()</span>
        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">head</span><span class="p">()</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
            <span class="n">fst</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">()</span><span class="o">.</span><span class="n">first</span><span class="p">()</span>
            <span class="n">lfst</span> <span class="o">+=</span> <span class="n">fst</span>
        <span class="k">return</span> <span class="n">lfst</span>

    <span class="k">def</span> <span class="nf">last</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: &quot;&quot;&quot;</span>
        <span class="n">llst</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">headrev</span><span class="p">()</span><span class="o">.</span><span class="n">last</span><span class="p">()</span>
        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">headrev</span><span class="p">()</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
            <span class="n">lst</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">tailrev</span><span class="p">()</span><span class="o">.</span><span class="n">last</span><span class="p">()</span>
            <span class="n">llst</span> <span class="o">+=</span> <span class="n">lst</span>
        <span class="k">return</span> <span class="n">llst</span>

    <span class="k">def</span> <span class="nf">followLists</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lists</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lists:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="n">lists</span> <span class="ow">is</span> <span class="bp">None</span><span class="p">:</span>
            <span class="n">lists</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">head</span><span class="p">()</span><span class="o">.</span><span class="n">followLists</span><span class="p">(</span><span class="n">lists</span><span class="p">)</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">()</span><span class="o">.</span><span class="n">followLists</span><span class="p">(</span><span class="n">lists</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">head</span><span class="p">()</span><span class="o">.</span><span class="n">last</span><span class="p">():</span>
            <span class="k">if</span> <span class="n">i</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">lists</span><span class="p">:</span>
                <span class="n">lists</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">()</span><span class="o">.</span><span class="n">first</span><span class="p">()</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="n">lists</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">+=</span> <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">()</span><span class="o">.</span><span class="n">first</span><span class="p">()</span>
        <span class="k">return</span> <span class="n">lists</span>

    <span class="k">def</span> <span class="nf">followListsStar</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lists</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lists:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="n">lists</span> <span class="ow">is</span> <span class="bp">None</span><span class="p">:</span>
            <span class="n">lists</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">head</span><span class="p">()</span><span class="o">.</span><span class="n">ewp</span><span class="p">()</span> <span class="ow">and</span> <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">():</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">head</span><span class="p">()</span><span class="o">.</span><span class="n">followListsStar</span><span class="p">(</span><span class="n">lists</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">()</span><span class="o">.</span><span class="n">followListsStar</span><span class="p">(</span><span class="n">lists</span><span class="p">)</span>
        <span class="k">elif</span> <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">()</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">head</span><span class="p">()</span><span class="o">.</span><span class="n">followListsStar</span><span class="p">(</span><span class="n">lists</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">()</span><span class="o">.</span><span class="n">followLists</span><span class="p">(</span><span class="n">lists</span><span class="p">)</span>
        <span class="k">elif</span> <span class="bp">self</span><span class="o">.</span><span class="n">head</span><span class="p">()</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">head</span><span class="p">()</span><span class="o">.</span><span class="n">followLists</span><span class="p">(</span><span class="n">lists</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">()</span><span class="o">.</span><span class="n">followListsStar</span><span class="p">(</span><span class="n">lists</span><span class="p">)</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">head</span><span class="p">()</span><span class="o">.</span><span class="n">followLists</span><span class="p">(</span><span class="n">lists</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">()</span><span class="o">.</span><span class="n">followLists</span><span class="p">(</span><span class="n">lists</span><span class="p">)</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">_cross</span><span class="p">(</span><span class="n">lists</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">lists</span>

    <span class="k">def</span> <span class="nf">derivative</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="n">ader</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">head</span><span class="p">()</span><span class="o">.</span><span class="n">derivative</span><span class="p">(</span><span class="n">sigma</span><span class="p">)</span>
        <span class="n">der</span> <span class="o">=</span> <span class="n">ader</span><span class="o">.</span><span class="n">concatenation</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">())</span>
        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">head</span><span class="p">()</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
            <span class="n">bder</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">()</span><span class="o">.</span><span class="n">derivative</span><span class="p">(</span><span class="n">sigma</span><span class="p">)</span>
            <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">bder</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xempty</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">der</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">bder</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xdisj</span><span class="p">:</span>
                    <span class="n">bder</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">der</span><span class="p">)</span>
                    <span class="k">return</span> <span class="n">bder</span>
                <span class="k">else</span><span class="p">:</span>
                    <span class="k">return</span> <span class="n">xdisj</span><span class="p">({</span><span class="n">der</span><span class="p">,</span> <span class="n">bder</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">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">der</span>

    <span class="k">def</span> <span class="nf">partialDerivatives</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="n">s</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
        <span class="n">ader</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">head</span><span class="p">()</span><span class="o">.</span><span class="n">partialDerivatives</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">update</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">_concat</span><span class="p">(</span><span class="n">ader</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">()))</span>
        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">head</span><span class="p">()</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
            <span class="n">bder</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">()</span><span class="o">.</span><span class="n">partialDerivatives</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">update</span><span class="p">(</span><span class="n">bder</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">s</span>

    <span class="k">def</span> <span class="nf">partialDerivativeC</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="n">pd</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">partialDerivatives</span><span class="p">(</span><span class="n">sigma</span><span class="p">)</span>
        <span class="n">pdc</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
        <span class="k">for</span> <span class="n">di</span> <span class="ow">in</span> <span class="n">pd</span><span class="p">:</span>
            <span class="n">pdc</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">di</span><span class="o">.</span><span class="n">_not</span><span class="p">())</span>
        <span class="k">if</span> <span class="n">pdc</span><span class="p">:</span>
            <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">pdc</span><span class="p">)</span> <span class="o">!=</span> <span class="mi">1</span><span class="p">:</span>
                <span class="n">pdc</span> <span class="o">=</span> <span class="p">{</span><span class="n">xconj</span><span class="p">(</span><span class="n">pdc</span><span class="p">)}</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="n">pdc</span> <span class="o">=</span> <span class="p">{</span><span class="n">xsigmaS</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">return</span> <span class="n">pdc</span>

    <span class="k">def</span> <span class="nf">_linearForm</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: &quot;&quot;&quot;</span>
        <span class="n">sigma</span> <span class="o">=</span> <span class="n">copy</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">arg1</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">head</span><span class="p">()</span>
        <span class="n">arg1</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">=</span> <span class="n">sigma</span>
        <span class="n">arg2n</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">()</span>
        <span class="n">arg2n</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">=</span> <span class="n">sigma</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">arg1</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xre</span><span class="p">:</span>
            <span class="k">return</span> <span class="p">{</span><span class="n">arg1</span><span class="o">.</span><span class="n">val</span><span class="p">:</span> <span class="p">{</span><span class="n">arg2n</span><span class="p">}}</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="n">lf</span> <span class="o">=</span> <span class="p">{}</span>
            <span class="n">lf2</span> <span class="o">=</span> <span class="p">{}</span>
            <span class="n">lf1</span> <span class="o">=</span> <span class="n">arg1</span><span class="o">.</span><span class="n">linearForm</span><span class="p">()</span>
            <span class="k">if</span> <span class="n">arg1</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
                <span class="n">lf2</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">()</span><span class="o">.</span><span class="n">linearForm</span><span class="p">()</span>
            <span class="k">for</span> <span class="n">head</span> <span class="ow">in</span> <span class="n">lf1</span><span class="o">.</span><span class="n">keys</span><span class="p">():</span>
                <span class="n">lf</span><span class="p">[</span><span class="n">head</span><span class="p">]</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">_concat</span><span class="p">(</span><span class="n">lf1</span><span class="p">[</span><span class="n">head</span><span class="p">],</span> <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">())</span>
            <span class="k">if</span> <span class="n">lf2</span><span class="p">:</span>
                <span class="k">for</span> <span class="n">head</span> <span class="ow">in</span> <span class="p">(</span><span class="n">lf</span><span class="o">.</span><span class="n">keys</span><span class="p">()</span> <span class="o">+</span> <span class="n">lf2</span><span class="o">.</span><span class="n">keys</span><span class="p">()):</span>
                    <span class="n">tails</span> <span class="o">=</span> <span class="n">lf</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">head</span><span class="p">,</span> <span class="nb">set</span><span class="p">())</span> <span class="o">|</span> <span class="n">lf2</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">head</span><span class="p">,</span> <span class="nb">set</span><span class="p">())</span>
                    <span class="k">if</span> <span class="n">tails</span><span class="p">:</span>
                        <span class="n">lf</span><span class="p">[</span><span class="n">head</span><span class="p">]</span> <span class="o">=</span> <span class="n">tails</span>
            <span class="k">return</span> <span class="n">lf</span>

    <span class="k">def</span> <span class="nf">_linearFormC</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: &quot;&quot;&quot;</span>
        <span class="n">lf</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">_linearForm</span><span class="p">()</span>
        <span class="n">lfc</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="k">for</span> <span class="n">head</span> <span class="ow">in</span> <span class="p">(</span><span class="n">lf</span><span class="o">.</span><span class="n">keys</span><span class="p">()):</span>
            <span class="n">pdc</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
            <span class="k">for</span> <span class="n">di</span> <span class="ow">in</span> <span class="n">lf</span><span class="p">[</span><span class="n">head</span><span class="p">]:</span>
                <span class="n">pdc</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">di</span><span class="o">.</span><span class="n">_not</span><span class="p">())</span>
            <span class="k">if</span> <span class="n">pdc</span><span class="p">:</span>
                <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">pdc</span><span class="p">)</span> <span class="o">!=</span> <span class="mi">1</span><span class="p">:</span>
                    <span class="n">pdc</span> <span class="o">=</span> <span class="p">{</span><span class="n">xconj</span><span class="p">(</span><span class="n">pdc</span><span class="p">)}</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="n">pdc</span> <span class="o">=</span> <span class="p">{</span><span class="n">xsigmaS</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">lfc</span><span class="p">[</span><span class="n">head</span><span class="p">]</span> <span class="o">=</span> <span class="n">pdc</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">Sigma</span><span class="p">:</span>
            <span class="k">if</span> <span class="ow">not</span> <span class="n">s</span> <span class="ow">in</span> <span class="n">lfc</span><span class="p">:</span>
                <span class="n">lfc</span><span class="p">[</span><span class="n">s</span><span class="p">]</span> <span class="o">=</span> <span class="p">{</span><span class="n">xsigmaS</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">return</span> <span class="n">lfc</span>

    <span class="k">def</span> <span class="nf">support</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: &quot;&quot;&quot;</span>
        <span class="n">s</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
        <span class="n">ap</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">head</span><span class="p">()</span><span class="o">.</span><span class="n">support</span><span class="p">()</span>
        <span class="n">s</span><span class="o">.</span><span class="n">update</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">_concat</span><span class="p">(</span><span class="n">ap</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">()))</span>
        <span class="n">bp</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">tail</span><span class="p">()</span><span class="o">.</span><span class="n">support</span><span class="p">()</span>
        <span class="n">s</span><span class="o">.</span><span class="n">update</span><span class="p">(</span><span class="n">bp</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">s</span>

    <span class="k">def</span> <span class="nf">concatenation</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">r</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param r:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">r</span><span class="p">)</span> <span class="o">==</span> <span class="n">xepsilon</span><span class="p">:</span>
            <span class="k">return</span> <span class="bp">self</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">r</span><span class="p">)</span> <span class="o">==</span> <span class="n">xempty</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xempty</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">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">r</span><span class="p">)</span> <span class="o">==</span> <span class="n">xconcat</span><span class="p">:</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">extend</span><span class="p">(</span><span class="n">copy</span><span class="o">.</span><span class="n">deepcopy</span><span class="p">(</span><span class="n">r</span><span class="o">.</span><span class="n">val</span><span class="p">))</span>
            <span class="k">return</span> <span class="bp">self</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">copy</span><span class="o">.</span><span class="n">deepcopy</span><span class="p">(</span><span class="n">r</span><span class="p">))</span>
            <span class="k">return</span> <span class="bp">self</span>

    <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">sx</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sx:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xconj</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconj</span><span class="p">(</span><span class="n">sx</span><span class="o">.</span><span class="n">val</span> <span class="o">|</span> <span class="p">{</span><span class="bp">self</span><span class="p">},</span> <span class="n">sigma</span><span class="o">=</span><span class="bp">self</span><span class="o">.</span><span class="n">unionSigma</span><span class="p">(</span><span class="n">sx</span><span class="p">))</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">if</span> <span class="n">sx</span> <span class="o">==</span> <span class="bp">self</span><span class="p">:</span>
                <span class="k">return</span> <span class="bp">self</span>
            <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xepsilon</span><span class="p">:</span>
                <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
                    <span class="k">return</span> <span class="n">xepsilon</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">else</span><span class="p">:</span>
                    <span class="k">return</span> <span class="n">xempty</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">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xempty</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">xempty</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">else</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">xconj</span><span class="p">({</span><span class="bp">self</span><span class="p">,</span> <span class="n">sx</span><span class="p">},</span> <span class="n">sigma</span><span class="o">=</span><span class="bp">self</span><span class="o">.</span><span class="n">unionSigma</span><span class="p">(</span><span class="n">sx</span><span class="p">))</span>


<span class="k">class</span> <span class="nc">xconj</span><span class="p">(</span><span class="n">xconnective</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Class that represents the conjunction operation.&quot;&quot;&quot;</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="s">&quot;({0:s})&quot;</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">_strP</span><span class="p">())</span>

    <span class="k">def</span> <span class="nf">_strP</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:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="s">&quot;&amp;&quot;</span><span class="o">.</span><span class="n">join</span><span class="p">([</span><span class="nb">str</span><span class="p">(</span><span class="n">i</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">val</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="s">&quot;xconj({0:s})&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="nb">repr</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">))</span>

    <span class="k">def</span> <span class="nf">_marked</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">pos</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param pos:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="n">s</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="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">mark</span><span class="p">,</span> <span class="n">pos</span> <span class="o">=</span> <span class="n">i</span><span class="o">.</span><span class="n">_marked</span><span class="p">(</span><span class="n">pos</span><span class="p">)</span>
            <span class="n">s</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">mark</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">xconj</span><span class="p">(</span><span class="n">s</span><span class="p">),</span> <span class="n">pos</span>

    <span class="k">def</span> <span class="nf">ewp</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: &quot;&quot;&quot;</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">val</span><span class="p">:</span>
            <span class="k">if</span> <span class="ow">not</span> <span class="n">i</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
                <span class="k">return</span> <span class="bp">False</span>
        <span class="k">return</span> <span class="bp">True</span>

    <span class="k">def</span> <span class="nf">derivative</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="n">arg</span> <span class="o">=</span> <span class="n">copy</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">val</span><span class="p">)</span>
        <span class="n">der</span> <span class="o">=</span> <span class="n">arg</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span><span class="o">.</span><span class="n">derivative</span><span class="p">(</span><span class="n">sigma</span><span class="p">)</span>
        <span class="k">while</span> <span class="n">arg</span><span class="p">:</span>
            <span class="n">di</span> <span class="o">=</span> <span class="n">arg</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span><span class="o">.</span><span class="n">derivative</span><span class="p">(</span><span class="n">sigma</span><span class="p">)</span>
            <span class="n">der</span> <span class="o">=</span> <span class="n">di</span><span class="o">.</span><span class="n">intersection</span><span class="p">(</span><span class="n">der</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">der</span>

    <span class="k">def</span> <span class="nf">partialDerivatives</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="n">arg</span> <span class="o">=</span> <span class="n">copy</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">val</span><span class="p">)</span>
        <span class="n">s</span> <span class="o">=</span> <span class="n">arg</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span><span class="o">.</span><span class="n">partialDerivatives</span><span class="p">(</span><span class="n">sigma</span><span class="p">)</span>
        <span class="k">while</span> <span class="n">arg</span><span class="p">:</span>
            <span class="n">der</span> <span class="o">=</span> <span class="n">arg</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span><span class="o">.</span><span class="n">partialDerivatives</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="bp">self</span><span class="o">.</span><span class="n">_intersection</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">der</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">s</span>

    <span class="k">def</span> <span class="nf">partialDerivativeC</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="n">pdc</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="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">pdi</span> <span class="o">=</span> <span class="n">i</span><span class="o">.</span><span class="n">partialDerivatives</span><span class="p">(</span><span class="n">sigma</span><span class="p">)</span>
            <span class="k">if</span> <span class="n">pdi</span><span class="p">:</span>
                <span class="n">dic</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
                <span class="k">for</span> <span class="n">di</span> <span class="ow">in</span> <span class="n">pdi</span><span class="p">:</span>
                    <span class="n">dic</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">di</span><span class="o">.</span><span class="n">_not</span><span class="p">())</span>
                <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">dic</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
                    <span class="n">pdc</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">dic</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">pdc</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">xconj</span><span class="p">(</span><span class="n">dic</span><span class="p">))</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="n">pdc</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">xsigmaS</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">return</span> <span class="n">pdc</span>

    <span class="c"># noinspection PyUnusedLocal</span>
    <span class="k">def</span> <span class="nf">_linearForm</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:&quot;&quot;&quot;</span>
        <span class="n">lf</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="n">sigma</span> <span class="o">=</span> <span class="n">copy</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">arg</span> <span class="o">=</span> <span class="n">copy</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">val</span><span class="p">)</span>
        <span class="n">r</span> <span class="o">=</span> <span class="n">arg</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span>
        <span class="n">r</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">=</span> <span class="n">sigma</span>
        <span class="n">lf</span> <span class="o">=</span> <span class="n">r</span><span class="o">.</span><span class="n">linearForm</span><span class="p">()</span>
        <span class="k">while</span> <span class="n">arg</span><span class="p">:</span>
            <span class="n">ri</span> <span class="o">=</span> <span class="n">arg</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span>
            <span class="n">ri</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">=</span> <span class="n">sigma</span>
            <span class="n">l</span> <span class="o">=</span> <span class="n">ri</span><span class="o">.</span><span class="n">linearForm</span><span class="p">()</span>
            <span class="n">heads</span> <span class="o">=</span> <span class="n">lf</span><span class="o">.</span><span class="n">keys</span><span class="p">()</span>
            <span class="k">for</span> <span class="n">head</span> <span class="ow">in</span> <span class="n">heads</span><span class="p">:</span>
                <span class="n">tails</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">_intersection</span><span class="p">(</span><span class="n">l</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">head</span><span class="p">,</span> <span class="nb">set</span><span class="p">()),</span> <span class="n">lf</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">head</span><span class="p">,</span> <span class="nb">set</span><span class="p">()))</span>
                <span class="k">if</span> <span class="n">tails</span> <span class="o">==</span> <span class="nb">set</span><span class="p">():</span>
                    <span class="k">del</span> <span class="p">(</span><span class="n">lf</span><span class="p">[</span><span class="n">head</span><span class="p">])</span>
                <span class="k">else</span><span class="p">:</span>
                    <span class="n">lf</span><span class="p">[</span><span class="n">head</span><span class="p">]</span> <span class="o">=</span> <span class="n">tails</span>
        <span class="k">return</span> <span class="n">lf</span>

    <span class="k">def</span> <span class="nf">_linearFormC</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: &quot;&quot;&quot;</span>
        <span class="n">lfc</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="k">for</span> <span class="n">ri</span> <span class="ow">in</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">:</span>
            <span class="n">ri</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">lfi</span> <span class="o">=</span> <span class="n">ri</span><span class="o">.</span><span class="n">linearForm</span><span class="p">()</span>
            <span class="k">for</span> <span class="n">head</span> <span class="ow">in</span> <span class="p">(</span><span class="n">lfi</span><span class="o">.</span><span class="n">keys</span><span class="p">()):</span>
                <span class="n">pdi</span> <span class="o">=</span> <span class="n">lfi</span><span class="p">[</span><span class="n">head</span><span class="p">]</span>
                <span class="n">pdc</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
                <span class="k">if</span> <span class="n">pdi</span><span class="p">:</span>
                    <span class="n">dic</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
                    <span class="k">for</span> <span class="n">di</span> <span class="ow">in</span> <span class="n">pdi</span><span class="p">:</span>
                        <span class="n">dic</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">di</span><span class="o">.</span><span class="n">_not</span><span class="p">())</span>
                    <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">dic</span><span class="p">)</span> <span class="o">==</span> <span class="mi">1</span><span class="p">:</span>
                        <span class="n">pdc</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">dic</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">pdc</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">xconj</span><span class="p">(</span><span class="n">dic</span><span class="p">))</span>
                <span class="k">else</span><span class="p">:</span>
                    <span class="n">pdc</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">xsigmaS</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">if</span> <span class="n">head</span> <span class="ow">in</span> <span class="n">lfc</span><span class="p">:</span>
                    <span class="n">lfc</span><span class="p">[</span><span class="n">head</span><span class="p">]</span><span class="o">.</span><span class="n">update</span><span class="p">(</span><span class="n">pdc</span><span class="p">)</span>
                <span class="k">else</span><span class="p">:</span>
                    <span class="n">lfc</span><span class="p">[</span><span class="n">head</span><span class="p">]</span> <span class="o">=</span> <span class="n">pdc</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">Sigma</span><span class="p">:</span>
            <span class="k">if</span> <span class="ow">not</span> <span class="n">s</span> <span class="ow">in</span> <span class="n">lfc</span><span class="p">:</span>
                <span class="n">lfc</span><span class="p">[</span><span class="n">s</span><span class="p">]</span> <span class="o">=</span> <span class="p">{</span><span class="n">xsigmaS</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">return</span> <span class="n">lfc</span>

    <span class="k">def</span> <span class="nf">support</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: &quot;&quot;&quot;</span>
        <span class="n">arg</span> <span class="o">=</span> <span class="n">copy</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">val</span><span class="p">)</span>
        <span class="n">x</span> <span class="o">=</span> <span class="n">arg</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span>
        <span class="n">s</span> <span class="o">=</span> <span class="n">x</span><span class="o">.</span><span class="n">support</span><span class="p">()</span>
        <span class="k">while</span> <span class="n">arg</span><span class="p">:</span>
            <span class="n">x</span> <span class="o">=</span> <span class="n">arg</span><span class="o">.</span><span class="n">pop</span><span class="p">()</span>
            <span class="n">p</span> <span class="o">=</span> <span class="n">x</span><span class="o">.</span><span class="n">support</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">_intersection</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">p</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">s</span>

    <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">sx</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sx:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xconj</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconj</span><span class="p">(</span><span class="n">sx</span><span class="o">.</span><span class="n">val</span> <span class="o">|</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">)</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xepsilon</span><span class="p">:</span>
                <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
                    <span class="k">return</span> <span class="n">xepsilon</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">else</span><span class="p">:</span>
                    <span class="k">return</span> <span class="n">xempty</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">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xempty</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">xempty</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">else</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">xconj</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">val</span> <span class="o">|</span> <span class="p">{</span><span class="n">sx</span><span class="p">})</span>


<span class="k">class</span> <span class="nc">xstar</span><span class="p">(</span><span class="n">xre</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Class that represents the Kleene closure.&quot;&quot;&quot;</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xconcat</span> <span class="ow">or</span> <span class="nb">type</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xnot</span><span class="p">:</span>
            <span class="k">return</span> <span class="s">&quot;({0:s})*&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="nb">str</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">))</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="s">&quot;{0:s}*&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="nb">str</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">val</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="s">&quot;xstar({0:s})&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="nb">repr</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">))</span>

    <span class="k">def</span> <span class="nf">ewp</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:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">True</span>

    <span class="k">def</span> <span class="nf">setOfSymbols</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">setOfSymbols</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">alphabeticLength</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:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">alphabeticLength</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">epsilonLength</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">epsilonLength</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">syntacticLength</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:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="mi">1</span> <span class="o">+</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">syntacticLength</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">treeLength</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="mi">1</span> <span class="o">+</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">treeLength</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">_marked</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">pos</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param pos:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="n">mark</span><span class="p">,</span> <span class="n">pos</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">_marked</span><span class="p">(</span><span class="n">pos</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">xstar</span><span class="p">(</span><span class="n">mark</span><span class="p">),</span> <span class="n">pos</span>

    <span class="k">def</span> <span class="nf">first</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">first</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">last</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">last</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">followLists</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lists</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lists:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">followListsStar</span><span class="p">(</span><span class="n">lists</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">followListsStar</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lists</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lists:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">followListsStar</span><span class="p">(</span><span class="n">lists</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">derivative</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="n">der</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">derivative</span><span class="p">(</span><span class="n">sigma</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">der</span><span class="o">.</span><span class="n">concatenation</span><span class="p">(</span><span class="bp">self</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">partialDerivatives</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="n">der</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">partialDerivatives</span><span class="p">(</span><span class="n">sigma</span><span class="p">)</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">_concat</span><span class="p">(</span><span class="n">der</span><span class="p">,</span> <span class="bp">self</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">partialDerivativeC</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="n">pd</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">partialDerivatives</span><span class="p">(</span><span class="n">sigma</span><span class="p">)</span>
        <span class="n">pdc</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
        <span class="k">for</span> <span class="n">di</span> <span class="ow">in</span> <span class="n">pd</span><span class="p">:</span>
            <span class="n">pdc</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">di</span><span class="o">.</span><span class="n">_not</span><span class="p">())</span>
        <span class="k">if</span> <span class="n">pdc</span><span class="p">:</span>
            <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">pdc</span><span class="p">)</span> <span class="o">!=</span> <span class="mi">1</span><span class="p">:</span>
                <span class="n">pdc</span> <span class="o">=</span> <span class="p">{</span><span class="n">xconj</span><span class="p">(</span><span class="n">pdc</span><span class="p">)}</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="n">pdc</span> <span class="o">=</span> <span class="p">{</span><span class="n">xsigmaS</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">return</span> <span class="n">pdc</span>

    <span class="k">def</span> <span class="nf">_linearForm</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:&quot;&quot;&quot;</span>
        <span class="n">lf</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="n">reg</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span>
        <span class="n">reg</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">=</span> <span class="n">copy</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">lf1</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">linearForm</span><span class="p">()</span>
        <span class="k">for</span> <span class="n">head</span> <span class="ow">in</span> <span class="n">lf1</span><span class="o">.</span><span class="n">keys</span><span class="p">():</span>
            <span class="n">lf</span><span class="p">[</span><span class="n">head</span><span class="p">]</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">_concat</span><span class="p">(</span><span class="n">lf1</span><span class="p">[</span><span class="n">head</span><span class="p">],</span> <span class="bp">self</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">lf</span>

    <span class="k">def</span> <span class="nf">_linearFormC</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:&quot;&quot;&quot;</span>
        <span class="n">lf</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">_linearForm</span><span class="p">()</span>
        <span class="n">lfc</span> <span class="o">=</span> <span class="p">{}</span>
        <span class="k">for</span> <span class="n">head</span> <span class="ow">in</span> <span class="p">(</span><span class="n">lf</span><span class="o">.</span><span class="n">keys</span><span class="p">()):</span>
            <span class="n">pdc</span> <span class="o">=</span> <span class="nb">set</span><span class="p">()</span>
            <span class="k">for</span> <span class="n">di</span> <span class="ow">in</span> <span class="n">lf</span><span class="p">[</span><span class="n">head</span><span class="p">]:</span>
                <span class="n">pdc</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">di</span><span class="o">.</span><span class="n">_not</span><span class="p">())</span>
            <span class="k">if</span> <span class="n">pdc</span><span class="p">:</span>
                <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">pdc</span><span class="p">)</span> <span class="o">!=</span> <span class="mi">1</span><span class="p">:</span>
                    <span class="n">pdc</span> <span class="o">=</span> <span class="p">{</span><span class="n">xconj</span><span class="p">(</span><span class="n">pdc</span><span class="p">)}</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="n">pdc</span> <span class="o">=</span> <span class="p">{</span><span class="n">xsigmaS</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">lfc</span><span class="p">[</span><span class="n">head</span><span class="p">]</span> <span class="o">=</span> <span class="n">pdc</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">Sigma</span><span class="p">:</span>
            <span class="k">if</span> <span class="ow">not</span> <span class="n">s</span> <span class="ow">in</span> <span class="n">lfc</span><span class="p">:</span>
                <span class="n">lfc</span><span class="p">[</span><span class="n">s</span><span class="p">]</span> <span class="o">=</span> <span class="p">{</span><span class="n">xsigmaS</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">return</span> <span class="n">lfc</span>

    <span class="k">def</span> <span class="nf">support</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: &quot;&quot;&quot;</span>
        <span class="n">p</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">support</span><span class="p">()</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">_concat</span><span class="p">(</span><span class="n">p</span><span class="p">,</span> <span class="bp">self</span><span class="p">)</span>

    <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">sx</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sx:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xconj</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconj</span><span class="p">(</span><span class="n">sx</span><span class="o">.</span><span class="n">val</span> <span class="o">|</span> <span class="p">{</span><span class="bp">self</span><span class="p">})</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">if</span> <span class="n">sx</span> <span class="o">==</span> <span class="bp">self</span><span class="p">:</span>
                <span class="k">return</span> <span class="bp">self</span>
            <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xepsilon</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">xepsilon</span><span class="p">()</span>
            <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xempty</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">xempty</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">elif</span> <span class="nb">type</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xre</span> <span class="ow">and</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xre</span><span class="p">:</span>
                <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span> <span class="o">==</span> <span class="n">sx</span><span class="p">:</span>
                    <span class="k">return</span> <span class="n">sx</span>
                <span class="k">else</span><span class="p">:</span>
                    <span class="k">return</span> <span class="n">xempty</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">else</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">xconj</span><span class="p">({</span><span class="bp">self</span><span class="p">,</span> <span class="n">sx</span><span class="p">})</span>

    <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">s</span><span class="p">):</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">val</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">s</span><span class="p">)</span>

<span class="k">class</span> <span class="nc">xnot</span><span class="p">(</span><span class="n">xre</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot; xnot class &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">val</span><span class="p">,</span> <span class="n">sigma</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="nb">super</span><span class="p">(</span><span class="n">xnot</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="n">val</span><span class="p">,</span> <span class="n">sigma</span><span class="p">)</span>
        <span class="bp">self</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">val</span><span class="o">.</span><span class="n">Sigma</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xconcat</span> <span class="ow">or</span> <span class="nb">type</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xstar</span><span class="p">:</span>
            <span class="k">return</span> <span class="s">&quot;~(</span><span class="si">%s</span><span class="s">)&quot;</span> <span class="o">%</span> <span class="p">(</span><span class="nb">str</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">))</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="s">&quot;~</span><span class="si">%s</span><span class="s">&quot;</span> <span class="o">%</span> <span class="p">(</span><span class="nb">str</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">val</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="s">&quot;xnot(</span><span class="si">%s</span><span class="s">)&quot;</span> <span class="o">%</span> <span class="nb">repr</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">ewp</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:&quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">ewp</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">def</span> <span class="nf">alphabeticLength</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:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">alphabeticLength</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">epsilonLength</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:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">epsilonLength</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">syntacticLength</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:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="mi">1</span> <span class="o">+</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">syntacticLength</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">treeLength</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:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="mi">1</span> <span class="o">+</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">treeLength</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">setOfSymbols</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:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">setOfSymbols</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">derivative</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="n">der</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">derivative</span><span class="p">(</span><span class="n">sigma</span><span class="p">)</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">der</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xnot</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">der</span><span class="o">.</span><span class="n">val</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">der</span><span class="o">.</span><span class="n">_not</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">partialDerivatives</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">partialDerivativeC</span><span class="p">(</span><span class="n">sigma</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">partialDerivativeC</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sigma:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span><span class="o">.</span><span class="n">partialDerivatives</span><span class="p">(</span><span class="n">sigma</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">_linearForm</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: &quot;&quot;&quot;</span>
        <span class="n">reg</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span>
        <span class="n">reg</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">=</span> <span class="n">copy</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="k">return</span> <span class="n">reg</span><span class="o">.</span><span class="n">_linearFormC</span><span class="p">()</span>

    <span class="k">def</span> <span class="nf">_linearFormC</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="n">rex</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">val</span>
        <span class="n">rex</span><span class="o">.</span><span class="n">Sigma</span> <span class="o">=</span> <span class="n">copy</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="k">return</span> <span class="n">rex</span><span class="o">.</span><span class="n">_linearForm</span><span class="p">()</span>

    <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">sx</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param sx:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xconj</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconj</span><span class="p">(</span><span class="n">sx</span><span class="o">.</span><span class="n">val</span> <span class="o">|</span> <span class="p">{</span><span class="bp">self</span><span class="p">})</span>
        <span class="k">elif</span> <span class="n">sx</span> <span class="o">==</span> <span class="bp">self</span><span class="p">:</span>
            <span class="k">return</span> <span class="bp">self</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xepsilon</span><span class="p">:</span>
            <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
                <span class="k">return</span> <span class="n">xepsilon</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">else</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">xempty</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">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">sx</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xempty</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xempty</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">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconj</span><span class="p">({</span><span class="bp">self</span><span class="p">,</span> <span class="n">sx</span><span class="p">})</span>

    <span class="k">def</span> <span class="nf">_not</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
        <span class="k">return</span> <span class="n">copy</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">val</span><span class="p">)</span>

    <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">s</span><span class="p">):</span>
        <span class="bp">self</span><span class="o">.</span><span class="n">val</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">s</span><span class="p">)</span>

<span class="n">rpn</span> <span class="o">=</span> <span class="p">[</span><span class="s">&quot;x -&gt; {0:s} | i | +  x  x  | &amp; x x | . x x  | ~ x | * x&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">Epsilon</span><span class="p">)]</span>


<span class="k">def</span> <span class="nf">rpn2xre</span><span class="p">(</span><span class="n">s</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Reads xre from RPN representation.</span>
<span class="sd">  </span>
<span class="sd">    :param s: the RPN representation of the regular expression</span>
<span class="sd">    :type s: string</span>
<span class="sd">    :rtype: xre&quot;&quot;&quot;</span>
    <span class="p">(</span><span class="n">nf</span><span class="p">,</span> <span class="n">reg</span><span class="p">)</span> <span class="o">=</span> <span class="n">_rpn2xre</span><span class="p">(</span><span class="n">re</span><span class="o">.</span><span class="n">sub</span><span class="p">(</span><span class="s">&quot;@epsilon&quot;</span><span class="p">,</span> <span class="s">&quot;@&quot;</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="k">return</span> <span class="n">reg</span>


<span class="k">def</span> <span class="nf">_rpn2xre</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">i</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">    :param s:</span>
<span class="sd">    :param i:</span>
<span class="sd">    :return:&quot;&quot;&quot;</span>
    <span class="k">if</span> <span class="n">s</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="ow">in</span> <span class="s">&quot;+.&quot;</span><span class="p">:</span>
        <span class="p">(</span><span class="n">i1</span><span class="p">,</span> <span class="n">arg1</span><span class="p">)</span> <span class="o">=</span> <span class="n">_rpn2xre</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="p">)</span>
        <span class="p">(</span><span class="n">i2</span><span class="p">,</span> <span class="n">arg2</span><span class="p">)</span> <span class="o">=</span> <span class="n">_rpn2xre</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">i1</span><span class="p">)</span>
        <span class="k">if</span> <span class="n">s</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">==</span> <span class="s">&quot;.&quot;</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">i2</span><span class="p">,</span> <span class="n">_concatrpn</span><span class="p">(</span><span class="n">arg1</span><span class="p">,</span> <span class="n">arg2</span><span class="p">)</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">i2</span><span class="p">,</span> <span class="n">_disjrpn</span><span class="p">(</span><span class="n">arg1</span><span class="p">,</span> <span class="n">arg2</span><span class="p">)</span>
    <span class="k">elif</span> <span class="n">s</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="ow">in</span> <span class="s">&quot;&amp;.&quot;</span><span class="p">:</span>
        <span class="p">(</span><span class="n">i1</span><span class="p">,</span> <span class="n">arg1</span><span class="p">)</span> <span class="o">=</span> <span class="n">_rpn2xre</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="p">)</span>
        <span class="p">(</span><span class="n">i2</span><span class="p">,</span> <span class="n">arg2</span><span class="p">)</span> <span class="o">=</span> <span class="n">_rpn2xre</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">i1</span><span class="p">)</span>
        <span class="k">if</span> <span class="n">s</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">==</span> <span class="s">&quot;.&quot;</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">i2</span><span class="p">,</span> <span class="n">_concatrpn</span><span class="p">(</span><span class="n">arg1</span><span class="p">,</span> <span class="n">arg2</span><span class="p">)</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">i2</span><span class="p">,</span> <span class="n">_conjrpn</span><span class="p">(</span><span class="n">arg1</span><span class="p">,</span> <span class="n">arg2</span><span class="p">)</span>
    <span class="k">elif</span> <span class="n">s</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="ow">in</span> <span class="s">&quot;&amp;+&quot;</span><span class="p">:</span>
        <span class="p">(</span><span class="n">i1</span><span class="p">,</span> <span class="n">arg1</span><span class="p">)</span> <span class="o">=</span> <span class="n">_rpn2xre</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="p">)</span>
        <span class="p">(</span><span class="n">i2</span><span class="p">,</span> <span class="n">arg2</span><span class="p">)</span> <span class="o">=</span> <span class="n">_rpn2xre</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">i1</span><span class="p">)</span>
        <span class="k">if</span> <span class="n">s</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">==</span> <span class="s">&quot;+&quot;</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">i2</span><span class="p">,</span> <span class="n">_disjrpn</span><span class="p">(</span><span class="n">arg1</span><span class="p">,</span> <span class="n">arg2</span><span class="p">)</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">i2</span><span class="p">,</span> <span class="n">_conjrpn</span><span class="p">(</span><span class="n">arg1</span><span class="p">,</span> <span class="n">arg2</span><span class="p">)</span>
    <span class="k">if</span> <span class="n">s</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">==</span> <span class="s">&quot;~&quot;</span><span class="p">:</span>
        <span class="p">(</span><span class="n">i1</span><span class="p">,</span> <span class="n">arg1</span><span class="p">)</span> <span class="o">=</span> <span class="n">_rpn2xre</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="p">)</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">arg1</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xnot</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">i1</span><span class="p">,</span> <span class="n">xnot</span><span class="p">(</span><span class="n">arg1</span><span class="p">)</span>
    <span class="k">if</span> <span class="n">s</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">==</span> <span class="s">&quot;*&quot;</span><span class="p">:</span>
        <span class="p">(</span><span class="n">i1</span><span class="p">,</span> <span class="n">arg1</span><span class="p">)</span> <span class="o">=</span> <span class="n">_rpn2xre</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="p">)</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">arg1</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xstar</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">i1</span><span class="p">,</span> <span class="n">arg1</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">i1</span><span class="p">,</span> <span class="n">xstar</span><span class="p">(</span><span class="n">arg1</span><span class="p">)</span>
    <span class="k">if</span> <span class="n">s</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">==</span> <span class="s">&quot;@&quot;</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">i</span> <span class="o">+</span> <span class="mi">1</span><span class="p">,</span> <span class="n">xepsilon</span><span class="p">()</span>
    <span class="k">else</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">i</span> <span class="o">+</span> <span class="mi">1</span><span class="p">,</span> <span class="n">xre</span><span class="p">(</span><span class="n">s</span><span class="p">[</span><span class="n">i</span><span class="p">])</span>


<span class="k">def</span> <span class="nf">_concatrpn</span><span class="p">(</span><span class="n">arg1</span><span class="p">,</span> <span class="n">arg2</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">    :param arg1:</span>
<span class="sd">    :param arg2:</span>
<span class="sd">    :return:&quot;&quot;&quot;</span>
    <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">arg1</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xepsilon</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">arg2</span>
    <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">arg2</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xepsilon</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">arg1</span>
    <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">arg1</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xconcat</span><span class="p">:</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">arg2</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xconcat</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconcat</span><span class="p">(</span><span class="n">arg1</span><span class="o">.</span><span class="n">val</span> <span class="o">+</span> <span class="n">arg2</span><span class="o">.</span><span class="n">val</span><span class="p">)</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconcat</span><span class="p">(</span><span class="n">arg1</span><span class="o">.</span><span class="n">val</span> <span class="o">+</span> <span class="p">[</span><span class="n">arg2</span><span class="p">])</span>
    <span class="k">else</span><span class="p">:</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">arg2</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xconcat</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconcat</span><span class="p">([</span><span class="n">arg1</span><span class="p">]</span> <span class="o">+</span> <span class="n">arg2</span><span class="o">.</span><span class="n">val</span><span class="p">)</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconcat</span><span class="p">([</span><span class="n">arg1</span><span class="p">,</span> <span class="n">arg2</span><span class="p">])</span>


<span class="k">def</span> <span class="nf">_disjrpn</span><span class="p">(</span><span class="n">arg1</span><span class="p">,</span> <span class="n">arg2</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">    :param arg1:</span>
<span class="sd">    :param arg2:</span>
<span class="sd">    :return:&quot;&quot;&quot;</span>
    <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">arg1</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xdisj</span><span class="p">:</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">arg2</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xdisj</span><span class="p">:</span>
            <span class="n">s</span> <span class="o">=</span> <span class="n">arg1</span><span class="o">.</span><span class="n">val</span> <span class="o">|</span> <span class="n">arg2</span><span class="o">.</span><span class="n">val</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="n">s</span> <span class="o">=</span> <span class="n">arg1</span><span class="o">.</span><span class="n">val</span> <span class="o">|</span> <span class="p">{</span><span class="n">arg2</span><span class="p">}</span>
    <span class="k">else</span><span class="p">:</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">arg2</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xdisj</span><span class="p">:</span>
            <span class="n">s</span> <span class="o">=</span> <span class="p">{</span><span class="n">arg1</span><span class="p">}</span> <span class="o">|</span> <span class="n">arg2</span><span class="o">.</span><span class="n">val</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="n">s</span> <span class="o">=</span> <span class="p">{</span><span class="n">arg1</span><span class="p">,</span> <span class="n">arg2</span><span class="p">}</span>
    <span class="k">if</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">0</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">xempty</span><span class="p">()</span>
    <span class="k">if</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">s</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="k">return</span> <span class="n">xdisj</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="k">def</span> <span class="nf">_conjrpn</span><span class="p">(</span><span class="n">arg1</span><span class="p">,</span> <span class="n">arg2</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">    :param arg1:</span>
<span class="sd">    :param arg2:</span>
<span class="sd">    :return:&quot;&quot;&quot;</span>
    <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">arg1</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xconj</span><span class="p">:</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">arg2</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xconj</span><span class="p">:</span>
            <span class="n">s</span> <span class="o">=</span> <span class="n">arg1</span><span class="o">.</span><span class="n">val</span> <span class="o">|</span> <span class="n">arg2</span><span class="o">.</span><span class="n">val</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="n">s</span> <span class="o">=</span> <span class="n">arg1</span><span class="o">.</span><span class="n">val</span> <span class="o">|</span> <span class="p">{</span><span class="n">arg2</span><span class="p">}</span>
    <span class="k">else</span><span class="p">:</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">arg2</span><span class="p">)</span> <span class="ow">is</span> <span class="n">xconj</span><span class="p">:</span>
            <span class="n">s</span> <span class="o">=</span> <span class="p">{</span><span class="n">arg1</span><span class="p">}</span> <span class="o">|</span> <span class="n">arg2</span><span class="o">.</span><span class="n">val</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="n">s</span> <span class="o">=</span> <span class="p">{</span><span class="n">arg1</span><span class="p">,</span> <span class="n">arg2</span><span class="p">}</span>
    <span class="k">if</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">0</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">xempty</span><span class="p">()</span>
    <span class="k">if</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">s</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="k">return</span> <span class="n">xconj</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>


<span class="k">class</span> <span class="nc">ParseXRE</span><span class="p">(</span><span class="n">Yappy</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Parser for xre &quot;&quot;&quot;</span>
    <span class="c"># TODO: FALTA O SIGMAP E SIGMAS no common!&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">no_table</span><span class="o">=</span><span class="mi">0</span><span class="p">,</span> <span class="n">table</span><span class="o">=</span><span class="s">&#39;.tablexreg&#39;</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param no_table:</span>
<span class="sd">        :param table:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="n">grammar</span> <span class="o">=</span> <span class="p">[(</span><span class="s">&quot;r&quot;</span><span class="p">,</span> <span class="p">[</span><span class="s">&quot;r&quot;</span><span class="p">,</span> <span class="s">&quot;|&quot;</span><span class="p">,</span> <span class="s">&quot;c1&quot;</span><span class="p">],</span> <span class="bp">self</span><span class="o">.</span><span class="n">DisjRule</span><span class="p">),</span>
                   <span class="p">(</span><span class="s">&quot;r&quot;</span><span class="p">,</span> <span class="p">[</span><span class="s">&quot;c1&quot;</span><span class="p">],</span> <span class="bp">self</span><span class="o">.</span><span class="n">DefaultRule</span><span class="p">),</span>
                   <span class="p">(</span><span class="s">&quot;c1&quot;</span><span class="p">,</span> <span class="p">[</span><span class="s">&quot;c1&quot;</span><span class="p">,</span> <span class="s">&quot;&amp;&quot;</span><span class="p">,</span> <span class="s">&quot;c&quot;</span><span class="p">],</span> <span class="bp">self</span><span class="o">.</span><span class="n">ConjRule</span><span class="p">),</span>
                   <span class="p">(</span><span class="s">&quot;c1&quot;</span><span class="p">,</span> <span class="p">[</span><span class="s">&quot;c&quot;</span><span class="p">],</span> <span class="bp">self</span><span class="o">.</span><span class="n">DefaultRule</span><span class="p">),</span>
                   <span class="p">(</span><span class="s">&quot;c&quot;</span><span class="p">,</span> <span class="p">[</span><span class="s">&quot;c&quot;</span><span class="p">,</span> <span class="s">&quot;s&quot;</span><span class="p">],</span> <span class="bp">self</span><span class="o">.</span><span class="n">ConcatRule</span><span class="p">),</span>
                   <span class="p">(</span><span class="s">&quot;c&quot;</span><span class="p">,</span> <span class="p">[</span><span class="s">&quot;s&quot;</span><span class="p">],</span> <span class="bp">self</span><span class="o">.</span><span class="n">DefaultRule</span><span class="p">),</span>
                   <span class="p">(</span><span class="s">&quot;s&quot;</span><span class="p">,</span> <span class="p">[</span><span class="s">&quot;s&quot;</span><span class="p">,</span> <span class="s">&quot;*&quot;</span><span class="p">],</span> <span class="bp">self</span><span class="o">.</span><span class="n">StarRule</span><span class="p">),</span>
                   <span class="p">(</span><span class="s">&quot;s&quot;</span><span class="p">,</span> <span class="p">[</span><span class="s">&quot;f1&quot;</span><span class="p">],</span> <span class="bp">self</span><span class="o">.</span><span class="n">DefaultRule</span><span class="p">),</span>
                   <span class="p">(</span><span class="s">&quot;f1&quot;</span><span class="p">,</span> <span class="p">[</span><span class="s">&quot;~&quot;</span><span class="p">,</span> <span class="s">&quot;f&quot;</span><span class="p">],</span> <span class="bp">self</span><span class="o">.</span><span class="n">NotRule</span><span class="p">),</span>
                   <span class="p">(</span><span class="s">&quot;f1&quot;</span><span class="p">,</span> <span class="p">[</span><span class="s">&quot;f&quot;</span><span class="p">],</span> <span class="bp">self</span><span class="o">.</span><span class="n">DefaultRule</span><span class="p">),</span>
                   <span class="p">(</span><span class="s">&quot;f&quot;</span><span class="p">,</span> <span class="p">[</span><span class="s">&quot;b&quot;</span><span class="p">],</span> <span class="bp">self</span><span class="o">.</span><span class="n">DefaultRule</span><span class="p">),</span>
                   <span class="p">(</span><span class="s">&quot;f&quot;</span><span class="p">,</span> <span class="p">[</span><span class="s">&quot;(&quot;</span><span class="p">,</span> <span class="s">&quot;r&quot;</span><span class="p">,</span> <span class="s">&quot;)&quot;</span><span class="p">],</span> <span class="bp">self</span><span class="o">.</span><span class="n">ParRule</span><span class="p">),</span>
                   <span class="p">(</span><span class="s">&quot;b&quot;</span><span class="p">,</span> <span class="p">[</span><span class="s">&quot;id&quot;</span><span class="p">],</span> <span class="bp">self</span><span class="o">.</span><span class="n">BaseRule</span><span class="p">),</span>
                   <span class="p">(</span><span class="s">&quot;b&quot;</span><span class="p">,</span> <span class="p">[</span><span class="n">EmptySet</span><span class="p">],</span> <span class="bp">self</span><span class="o">.</span><span class="n">BaseRule</span><span class="p">),</span>
                   <span class="p">(</span><span class="s">&quot;b&quot;</span><span class="p">,</span> <span class="p">[</span><span class="n">Epsilon</span><span class="p">],</span> <span class="bp">self</span><span class="o">.</span><span class="n">BaseRule</span><span class="p">)]</span>
        <span class="n">tokenize</span> <span class="o">=</span> <span class="p">[(</span><span class="s">&quot;\s+&quot;</span><span class="p">,</span> <span class="s">&quot;&quot;</span><span class="p">),</span>
                    <span class="p">(</span><span class="n">Epsilon</span><span class="p">,</span> <span class="k">lambda</span> <span class="n">x</span><span class="p">:</span> <span class="p">(</span><span class="n">x</span><span class="p">,</span> <span class="n">x</span><span class="p">)),</span>
                    <span class="p">(</span><span class="n">EmptySet</span><span class="p">,</span> <span class="k">lambda</span> <span class="n">x</span><span class="p">:</span> <span class="p">(</span><span class="n">x</span><span class="p">,</span> <span class="n">x</span><span class="p">)),</span>
                    <span class="c">#(common.SigmaS, lambda x: (x,x)),</span>
                    <span class="c">#(common.SigmaP,lambda x: (x,x)),</span>
                    <span class="p">(</span><span class="s">&quot;[A-Za-z0-9]&quot;</span><span class="p">,</span> <span class="k">lambda</span> <span class="n">x</span><span class="p">:</span> <span class="p">(</span><span class="s">&quot;id&quot;</span><span class="p">,</span> <span class="n">x</span><span class="p">)),</span>
                    <span class="p">(</span><span class="s">&quot;\|&quot;</span><span class="p">,</span> <span class="k">lambda</span> <span class="n">x</span><span class="p">:</span> <span class="p">(</span><span class="n">x</span><span class="p">,</span> <span class="n">x</span><span class="p">)),</span>
                    <span class="p">(</span><span class="s">&quot;\+&quot;</span><span class="p">,</span> <span class="k">lambda</span> <span class="n">x</span><span class="p">:</span> <span class="p">(</span><span class="s">&quot;|&quot;</span><span class="p">,</span> <span class="n">x</span><span class="p">)),</span>
                    <span class="p">(</span><span class="s">&quot;\*&quot;</span><span class="p">,</span> <span class="k">lambda</span> <span class="n">x</span><span class="p">:</span> <span class="p">(</span><span class="n">x</span><span class="p">,</span> <span class="n">x</span><span class="p">)),</span>
                    <span class="p">(</span><span class="s">&quot;\&amp;&quot;</span><span class="p">,</span> <span class="k">lambda</span> <span class="n">x</span><span class="p">:</span> <span class="p">(</span><span class="n">x</span><span class="p">,</span> <span class="n">x</span><span class="p">)),</span>
                    <span class="p">(</span><span class="s">&quot;\(|\)&quot;</span><span class="p">,</span> <span class="k">lambda</span> <span class="n">x</span><span class="p">:</span> <span class="p">(</span><span class="n">x</span><span class="p">,</span> <span class="n">x</span><span class="p">)),</span>
                    <span class="p">(</span><span class="s">&quot;~&quot;</span><span class="p">,</span> <span class="k">lambda</span> <span class="n">x</span><span class="p">:</span> <span class="p">(</span><span class="n">x</span><span class="p">,</span> <span class="n">x</span><span class="p">))]</span>

        <span class="n">Yappy</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">tokenize</span><span class="p">,</span> <span class="n">grammar</span><span class="p">,</span> <span class="n">table</span><span class="p">,</span> <span class="n">no_table</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">DefaultRule</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lst</span><span class="p">,</span> <span class="n">context</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lst:</span>
<span class="sd">        :param context:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span>

    <span class="k">def</span> <span class="nf">BaseRule</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lst</span><span class="p">,</span> <span class="n">context</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lst:</span>
<span class="sd">        :param context:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="o">==</span> <span class="n">Epsilon</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xepsilon</span><span class="p">()</span>
        <span class="k">if</span> <span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="o">==</span> <span class="n">EmptySet</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xempty</span><span class="p">()</span>
            <span class="c">#if lst[0] == common.SigmaS:</span>
        <span class="c">#  return xsigmaS()</span>
        <span class="c">#if lst[0] == common.SigmaP:</span>
        <span class="c">#  return xsigmaP()</span>
        <span class="k">return</span> <span class="n">xre</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span>

    <span class="k">def</span> <span class="nf">ParRule</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lst</span><span class="p">,</span> <span class="n">context</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lst:</span>
<span class="sd">        :param context:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="n">lst</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span>

    <span class="k">def</span> <span class="nf">DisjRule</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lst</span><span class="p">,</span> <span class="n">context</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lst:</span>
<span class="sd">        :param context:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">_disj</span><span class="p">(</span><span class="n">lst</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">_disj</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lst</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lst:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">2</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xempty</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xempty</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">lst</span><span class="p">[</span><span class="mi">2</span><span class="p">]</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">2</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xdisj</span> <span class="ow">and</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xdisj</span><span class="p">:</span>
                <span class="n">s</span> <span class="o">=</span> <span class="n">lst</span><span class="p">[</span><span class="mi">2</span><span class="p">]</span><span class="o">.</span><span class="n">val</span> <span class="o">|</span> <span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">val</span>
            <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xdisj</span><span class="p">:</span>
                <span class="n">s</span> <span class="o">=</span> <span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">val</span> <span class="o">|</span> <span class="p">{</span><span class="n">lst</span><span class="p">[</span><span class="mi">2</span><span class="p">]}</span>
            <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">2</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xdisj</span><span class="p">:</span>
                <span class="n">s</span> <span class="o">=</span> <span class="n">lst</span><span class="p">[</span><span class="mi">2</span><span class="p">]</span><span class="o">.</span><span class="n">val</span> <span class="o">|</span> <span class="p">{</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</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="p">{</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">],</span> <span class="n">lst</span><span class="p">[</span><span class="mi">2</span><span class="p">]}</span>
            <span class="k">if</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">0</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">xempty</span><span class="p">()</span>
            <span class="k">if</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">s</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="k">return</span> <span class="n">xdisj</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">ConcatRule</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lst</span><span class="p">,</span> <span class="n">context</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lst:</span>
<span class="sd">        :param context:</span>
<span class="sd">        :return:&quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">_concat</span><span class="p">(</span><span class="n">lst</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">_concat</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lst</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lst:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">1</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xepsilon</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xepsilon</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">lst</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">1</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xempty</span> <span class="ow">or</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xempty</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xempty</span><span class="p">()</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">1</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xconcat</span> <span class="ow">and</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xconcat</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconcat</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">val</span> <span class="o">+</span> <span class="n">lst</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span><span class="o">.</span><span class="n">val</span><span class="p">)</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xconcat</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconcat</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">val</span> <span class="o">+</span> <span class="p">[</span><span class="n">lst</span><span class="p">[</span><span class="mi">1</span><span class="p">]])</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">1</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xconcat</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconcat</span><span class="p">([</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">]]</span> <span class="o">+</span> <span class="n">lst</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span><span class="o">.</span><span class="n">val</span><span class="p">)</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xconcat</span><span class="p">(</span><span class="n">lst</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">ConjRule</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lst</span><span class="p">,</span> <span class="n">context</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lst:</span>
<span class="sd">        :param context:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">_conj</span><span class="p">(</span><span class="n">lst</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">_conj</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lst</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lst:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xepsilon</span><span class="p">:</span>
            <span class="k">if</span> <span class="n">lst</span><span class="p">[</span><span class="mi">2</span><span class="p">]</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
                <span class="k">return</span> <span class="n">xepsilon</span><span class="p">()</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">xempty</span><span class="p">()</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">2</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xepsilon</span><span class="p">:</span>
            <span class="k">if</span> <span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">ewp</span><span class="p">():</span>
                <span class="k">return</span> <span class="n">xepsilon</span><span class="p">()</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">xempty</span><span class="p">()</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xempty</span> <span class="ow">or</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">2</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xempty</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">xempty</span><span class="p">()</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">2</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xconj</span> <span class="ow">and</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xconj</span><span class="p">:</span>
                <span class="n">s</span> <span class="o">=</span> <span class="n">lst</span><span class="p">[</span><span class="mi">2</span><span class="p">]</span><span class="o">.</span><span class="n">val</span> <span class="o">|</span> <span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">val</span>
            <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xconj</span><span class="p">:</span>
                <span class="n">s</span> <span class="o">=</span> <span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">val</span> <span class="o">|</span> <span class="p">{</span><span class="n">lst</span><span class="p">[</span><span class="mi">2</span><span class="p">]}</span>
            <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">2</span><span class="p">])</span> <span class="ow">is</span> <span class="n">xconj</span><span class="p">:</span>
                <span class="n">s</span> <span class="o">=</span> <span class="n">lst</span><span class="p">[</span><span class="mi">2</span><span class="p">]</span><span class="o">.</span><span class="n">val</span> <span class="o">|</span> <span class="p">{</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</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="p">{</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">],</span> <span class="n">lst</span><span class="p">[</span><span class="mi">2</span><span class="p">]}</span>
            <span class="k">if</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">0</span><span class="p">:</span>
                <span class="k">return</span> <span class="n">xempty</span><span class="p">()</span>
            <span class="k">if</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">s</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="k">return</span> <span class="n">xconj</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>

    <span class="k">def</span> <span class="nf">StarRule</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lst</span><span class="p">,</span> <span class="n">context</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lst:</span>
<span class="sd">        :param context:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="n">xstar</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span>

    <span class="k">def</span> <span class="nf">NotRule</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">lst</span><span class="p">,</span> <span class="n">context</span><span class="o">=</span><span class="bp">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">        :param lst:</span>
<span class="sd">        :param context:</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="n">xnot</span><span class="p">(</span><span class="n">lst</span><span class="p">[</span><span class="mi">1</span><span class="p">])</span>


<span class="k">def</span> <span class="nf">str2xre</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="n">parser</span><span class="o">=</span><span class="n">ParseXRE</span><span class="p">,</span> <span class="n">no_table</span><span class="o">=</span><span class="mi">1</span><span class="p">,</span> <span class="n">sigma</span><span class="o">=</span><span class="bp">None</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; Reads a xre from string.</span>

<span class="sd">    :param str s:  the string representation of the regular expression</span>
<span class="sd">    :param parser: a parser generator for regexps</span>
<span class="sd">    :type parser: Yappy</span>
<span class="sd">    :param int  no_table:</span>
<span class="sd">    :param sigma: alphabet of the regular expression</span>
<span class="sd">    :type sigma: list or set of symbols</span>
<span class="sd">    :param bool  strict: if True tests if the symbols of the regular expression are included in the sigma</span>
<span class="sd">    :rtype: xre&quot;&quot;&quot;</span>
    <span class="n">s</span> <span class="o">=</span> <span class="n">re</span><span class="o">.</span><span class="n">sub</span><span class="p">(</span><span class="s">&quot;\s+&quot;</span><span class="p">,</span> <span class="s">&quot;&quot;</span><span class="p">,</span> <span class="n">s</span><span class="p">)</span>
    <span class="n">d</span> <span class="o">=</span> <span class="n">parser</span><span class="p">(</span><span class="n">no_table</span><span class="p">)</span>
    <span class="k">try</span><span class="p">:</span>
        <span class="n">reg</span> <span class="o">=</span> <span class="n">d</span><span class="o">.</span><span class="n">input</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
    <span class="k">except</span> <span class="n">LRParserError</span><span class="p">:</span>
        <span class="k">raise</span> <span class="n">regexpInvalid</span><span class="p">(</span><span class="n">s</span><span class="p">)</span>
    <span class="k">if</span> <span class="n">sigma</span> <span class="ow">is</span> <span class="ow">not</span> <span class="bp">None</span><span class="p">:</span>
        <span class="n">reg</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">strict</span><span class="p">)</span>
    <span class="k">elif</span> <span class="n">strict</span><span class="p">:</span>
        <span class="n">reg</span><span class="o">.</span><span class="n">setSigma</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">setOfSymbols</span><span class="p">())</span>
    <span class="k">return</span> <span class="n">reg</span>


<div class="viewcode-block" id="to_x"><a class="viewcode-back" href="../index.html#xre.to_x">[docs]</a><span class="k">def</span> <span class="nf">to_x</span><span class="p">(</span><span class="n">reg</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;Reads xre from FAdo regexp.</span>
<span class="sd">  </span>
<span class="sd">    :param reg:</span>
<span class="sd">    :arg re: the FAdo representation regexp for a regular expression.</span>
<span class="sd">    :type reg: regexp</span>
<span class="sd">    :rtype: xre&quot;&quot;&quot;</span>
    <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">regexp</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">to_xregexp</span><span class="p">(</span><span class="n">reg</span><span class="p">)</span>
    <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">emptyset</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">to_xempty</span><span class="p">(</span><span class="n">reg</span><span class="p">)</span>
    <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">epsilon</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">to_xepsilon</span><span class="p">(</span><span class="n">reg</span><span class="p">)</span>
    <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">disj</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">to_xdisj</span><span class="p">(</span><span class="n">reg</span><span class="p">)</span>
    <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">concat</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">to_xconcat</span><span class="p">(</span><span class="n">reg</span><span class="p">)</span>
    <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">star</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">to_xstar</span><span class="p">(</span><span class="n">reg</span><span class="p">)</span>
    <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="p">)</span> <span class="ow">is</span> <span class="n">conj</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">to_xconj</span><span class="p">(</span><span class="n">reg</span><span class="p">)</span>

</div>
<span class="k">def</span> <span class="nf">to_xregexp</span><span class="p">(</span><span class="n">reg</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">    :param reg:</span>
<span class="sd">    :return:&quot;&quot;&quot;</span>
    <span class="k">return</span> <span class="n">xre</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">val</span><span class="p">)</span>


<span class="k">def</span> <span class="nf">to_xempty</span><span class="p">(</span><span class="n">_</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">    :param _:</span>
<span class="sd">    :return: &quot;&quot;&quot;</span>
    <span class="k">return</span> <span class="n">xempty</span><span class="p">()</span>


<span class="k">def</span> <span class="nf">to_xepsilon</span><span class="p">(</span><span class="n">_</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">    :param _:</span>
<span class="sd">    :return: &quot;&quot;&quot;</span>
    <span class="k">return</span> <span class="n">xepsilon</span><span class="p">()</span>


<span class="k">def</span> <span class="nf">to_xdisj</span><span class="p">(</span><span class="n">reg</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">    :param reg:</span>
<span class="sd">    :return:&quot;&quot;&quot;</span>
    <span class="k">return</span> <span class="n">xdisj</span><span class="p">(</span><span class="n">_to_xdisj</span><span class="p">(</span><span class="n">reg</span><span class="p">))</span>


<span class="k">def</span> <span class="nf">_to_xdisj</span><span class="p">(</span><span class="n">reg</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">    :param reg:</span>
<span class="sd">    :return: &quot;&quot;&quot;</span>
    <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">disj</span><span class="p">:</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">disj</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">_to_xdisj</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)</span> <span class="o">|</span> <span class="n">_to_xdisj</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">_to_xdisj</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)</span> <span class="o">|</span> <span class="p">{</span><span class="n">to_x</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)}</span>
    <span class="k">else</span><span class="p">:</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">disj</span><span class="p">:</span>
            <span class="k">return</span> <span class="p">{</span><span class="n">to_x</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)}</span> <span class="o">|</span> <span class="n">_to_xdisj</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="p">{</span><span class="n">to_x</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)}</span> <span class="o">|</span> <span class="p">{</span><span class="n">to_x</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)}</span>


<span class="k">def</span> <span class="nf">to_xconcat</span><span class="p">(</span><span class="n">reg</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">    :param reg:</span>
<span class="sd">    :return: &quot;&quot;&quot;</span>
    <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">epsilon</span> <span class="ow">and</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">epsilon</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">xepsilon</span><span class="p">()</span>
    <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">epsilon</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">to_x</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)</span>
    <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">epsilon</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">to_x</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)</span>
    <span class="k">else</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">xconcat</span><span class="p">(</span><span class="n">_to_xconcat</span><span class="p">(</span><span class="n">reg</span><span class="p">))</span>


<span class="k">def</span> <span class="nf">_to_xconcat</span><span class="p">(</span><span class="n">reg</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;</span>

<span class="sd">    :param reg:</span>
<span class="sd">    :return: &quot;&quot;&quot;</span>
    <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">concat</span><span class="p">:</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">concat</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">_to_xconcat</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)</span> <span class="o">+</span> <span class="n">_to_xconcat</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">epsilon</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">_to_xconcat</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">_to_xconcat</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)</span> <span class="o">+</span> <span class="p">[</span><span class="n">to_x</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)]</span>
    <span class="k">else</span><span class="p">:</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">concat</span><span class="p">:</span>
            <span class="k">return</span> <span class="p">[</span><span class="n">to_x</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)]</span> <span class="o">+</span> <span class="n">_to_xconcat</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)</span>
        <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)</span> <span class="ow">is</span> <span class="n">reex</span><span class="o">.</span><span class="n">epsilon</span><span class="p">:</span>
            <span class="k">return</span> <span class="p">[</span><span class="n">to_x</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)]</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="p">[</span><span class="n">to_x</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)]</span> <span class="o">+</span> <span class="p">[</span><span class="n">to_x</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)]</span>


<span class="k">def</span> <span class="nf">to_xconj</span><span class="p">(</span><span class="n">reg</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;</span>

<span class="sd">    :param reg:</span>
<span class="sd">    :return: &quot;&quot;&quot;</span>
    <span class="k">return</span> <span class="n">xconj</span><span class="p">(</span><span class="n">_to_xconj</span><span class="p">(</span><span class="n">reg</span><span class="p">))</span>


<span class="k">def</span> <span class="nf">_to_xconj</span><span class="p">(</span><span class="n">reg</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">    :param reg:</span>
<span class="sd">    :return:&quot;&quot;&quot;</span>
    <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)</span> <span class="ow">is</span> <span class="n">conj</span><span class="p">:</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)</span> <span class="ow">is</span> <span class="n">conj</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">_to_xconj</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)</span> <span class="o">|</span> <span class="n">_to_xconj</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="n">_to_xconj</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)</span> <span class="o">|</span> <span class="p">{</span><span class="n">to_x</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)}</span>
    <span class="k">else</span><span class="p">:</span>
        <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)</span> <span class="ow">is</span> <span class="n">conj</span><span class="p">:</span>
            <span class="k">return</span> <span class="p">{</span><span class="n">to_x</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)}</span> <span class="o">|</span> <span class="n">_to_xconj</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)</span>
        <span class="k">else</span><span class="p">:</span>
            <span class="k">return</span> <span class="p">{</span><span class="n">to_x</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg1</span><span class="p">)}</span> <span class="o">|</span> <span class="p">{</span><span class="n">to_x</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg2</span><span class="p">)}</span>


<span class="k">def</span> <span class="nf">to_xstar</span><span class="p">(</span><span class="n">reg</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;</span>
<span class="sd">    :param reg:</span>
<span class="sd">    :return:&quot;&quot;&quot;</span>
    <span class="n">r</span> <span class="o">=</span> <span class="n">to_x</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg</span><span class="p">)</span>
    <span class="k">if</span> <span class="nb">type</span><span class="p">(</span><span class="n">r</span><span class="p">)</span> <span class="o">==</span> <span class="n">xepsilon</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">r</span>
    <span class="k">elif</span> <span class="nb">type</span><span class="p">(</span><span class="n">r</span><span class="p">)</span> <span class="o">==</span> <span class="n">xstar</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">r</span>
    <span class="k">else</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">xstar</span><span class="p">(</span><span class="n">to_x</span><span class="p">(</span><span class="n">reg</span><span class="o">.</span><span class="n">arg</span><span class="p">))</span>


<span class="k">class</span> <span class="nc">conj</span><span class="p">(</span><span class="n">reex</span><span class="o">.</span><span class="n">connective</span><span class="p">):</span>
    <span class="sd">&quot;&quot;&quot;FAdo regexp class that represents the conjunction operation.&quot;&quot;&quot;</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="sd">&quot;&quot;&quot;</span>
<span class="sd">        :return: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="s">&quot;{0:s} &amp; {1:s}&quot;</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">arg1</span><span class="o">.</span><span class="n">_strP</span><span class="p">(),</span> <span class="bp">self</span><span class="o">.</span><span class="n">arg2</span><span class="o">.</span><span class="n">_strP</span><span class="p">())</span>

    <span class="k">def</span> <span class="nf">_strP</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: &quot;&quot;&quot;</span>
        <span class="k">return</span> <span class="s">&quot;({0:s} &amp; {1:s})&quot;</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">arg1</span><span class="o">.</span><span class="n">_strP</span><span class="p">(),</span> <span class="bp">self</span><span class="o">.</span><span class="n">arg2</span><span class="o">.</span><span class="n">_strP</span><span class="p">())</span>
</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>