<?xml version="1.0"?>
<div class="add">

<span class="kw">set </span><font color="Maroon" title="c4">S0</font> =  <a href="circcomb.html#K5" title="CIRCCOMB:func.5">1GateCircStr</a> (<a href="facirc_2.html#NK3" title="FACIRC_2:NK.3">&lt;*&gt;</a>,<span class="p1">(<span class="default"><span class="p2">(<span class="default"><a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <a href="margrel1.html#K5" title="MARGREL1:func.5">BOOLEAN</a></span>)</span> <a href="funcop_1.html#K8" title="FUNCOP_1:func.8">--&gt;</a> <a href="margrel1.html#K6" title="MARGREL1:func.6">FALSE</a></span>)</span>);<br/>
<span class="kw">set </span><font color="Maroon" title="c5">A0</font> =  <a href="circcomb.html#K7" title="CIRCCOMB:func.7">1GateCircuit</a> (<a href="facirc_2.html#NK3" title="FACIRC_2:NK.3">&lt;*&gt;</a>,<span class="p1">(<span class="default"><span class="p2">(<span class="default"><a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <a href="margrel1.html#K5" title="MARGREL1:func.5">BOOLEAN</a></span>)</span> <a href="funcop_1.html#K8" title="FUNCOP_1:func.8">--&gt;</a> <a href="margrel1.html#K6" title="MARGREL1:func.6">FALSE</a></span>)</span>);<br/>
<span class="kw">set </span><font color="Maroon" title="c6">Sn</font> = <font color="Maroon" title="c1">n</font> <a href="gfacirc2.html#K1" title="GFACIRC2:func.1">-BitGFA0Str</a> (<font color="Maroon" title="c2">x</font>,<font color="Maroon" title="c3">y</font>);<br/>
<span class="kw">set </span><font color="Maroon" title="c7">o0</font> = <span class="p1"><a href="tarski.html#K4" title="TARSKI:func.4">[</a><span class="default"><a href="facirc_2.html#NK3" title="FACIRC_2:NK.3">&lt;*&gt;</a>,<span class="p2">(<span class="default"><span class="p3">(<span class="default"><a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <a href="margrel1.html#K5" title="MARGREL1:func.5">BOOLEAN</a></span>)</span> <a href="funcop_1.html#K8" title="FUNCOP_1:func.8">--&gt;</a> <a href="margrel1.html#K6" title="MARGREL1:func.6">FALSE</a></span>)</span></span><a href="tarski.html#K4" title="TARSKI:func.4">]</a></span>;<br/>
<span class="kw">deffunc </span><font color="Maroon">H<sub>1</sub></font>(  non  <a href="struct_0.html#V2" title="STRUCT_0:attr.2">empty</a>   <a href="msualg_1.html#L1" title="MSUALG_1:struct.1">ManySortedSign</a> ,   <a href="hidden.html#M2" title="HIDDEN:mode.2">set</a> ,  <a href="ordinal1.html#NM6" title="ORDINAL1:NM.6">Nat</a>) <span class="kw">-&gt; </span>   <a href="msualg_1.html#L1" title="MSUALG_1:struct.1">ManySortedSign</a>  = $1 <a href="circcomb.html#K2" title="CIRCCOMB:func.2">+*</a> <span class="p1">(<span class="default"><a href="gfacirc1.html#K13" title="GFACIRC1:func.13">BitGFA0Str</a> (<span class="p2">(<span class="default"><font color="Maroon" title="c2">x</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p3">(<span class="default">$3 <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,<span class="p2">(<span class="default"><font color="Maroon" title="c3">y</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p3">(<span class="default">$3 <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,$2)</span>)</span>;<br/>
<span class="kw">deffunc </span><font color="Maroon">H<sub>2</sub></font>(  non  <a href="struct_0.html#V2" title="STRUCT_0:attr.2">empty</a>   <a href="msualg_1.html#L1" title="MSUALG_1:struct.1">ManySortedSign</a> ,  <a href="msualg_1.html#V4" title="MSUALG_1:attr.4">non-empty</a>   <a href="msualg_1.html#L3" title="MSUALG_1:struct.3">MSAlgebra</a> over $1,   <a href="hidden.html#M2" title="HIDDEN:mode.2">set</a> ,  <a href="ordinal1.html#NM6" title="ORDINAL1:NM.6">Nat</a>) <span class="kw">-&gt; </span>   <a href="msualg_1.html#L3" title="MSUALG_1:struct.3">MSAlgebra</a> over $1 <a href="circcomb.html#K2" title="CIRCCOMB:func.2">+*</a> <span class="p1">(<span class="default"><a href="gfacirc1.html#K13" title="GFACIRC1:func.13">BitGFA0Str</a> (<span class="p2">(<span class="default"><font color="Maroon" title="c2">x</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p3">(<span class="default">$4 <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,<span class="p2">(<span class="default"><font color="Maroon" title="c3">y</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p3">(<span class="default">$4 <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,$3)</span>)</span> = $2 <a href="circcomb.html#K3" title="CIRCCOMB:func.3">+*</a> <span class="p1">(<span class="default"><a href="gfacirc1.html#K14" title="GFACIRC1:func.14">BitGFA0Circ</a> (<span class="p2">(<span class="default"><font color="Maroon" title="c2">x</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p3">(<span class="default">$4 <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,<span class="p2">(<span class="default"><font color="Maroon" title="c3">y</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p3">(<span class="default">$4 <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,$3)</span>)</span>;<br/>
<span class="kw">deffunc </span><font color="Maroon">H<sub>3</sub></font>(   <a href="hidden.html#M2" title="HIDDEN:mode.2">set</a> ,  <a href="ordinal1.html#NM6" title="ORDINAL1:NM.6">Nat</a>) <span class="kw">-&gt; </span>   <a href="subset_1.html#M2" title="SUBSET_1:mode.2">Element</a> of  <a href="msafree2.html#K3" title="MSAFREE2:func.3">InnerVertices</a> <span class="p1">(<span class="default"><a href="gfacirc1.html#K7" title="GFACIRC1:func.7">GFA0CarryStr</a> (<span class="p2">(<span class="default"><font color="Maroon" title="c2">x</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p3">(<span class="default">$2 <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,<span class="p2">(<span class="default"><font color="Maroon" title="c3">y</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p3">(<span class="default">$2 <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,$1)</span>)</span> =  <a href="gfacirc1.html#K9" title="GFACIRC1:func.9">GFA0CarryOutput</a> (<span class="p1">(<span class="default"><font color="Maroon" title="c2">x</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p2">(<span class="default">$2 <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,<span class="p1">(<span class="default"><font color="Maroon" title="c3">y</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p2">(<span class="default">$2 <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,$1);<br/>
<a NAME="E1:2_1_2"/><span class="lab"><font color="Green" title="E2">A2</font></span>: 
 for <font color="Olive" title="b1">S</font> being   non  <a href="struct_0.html#V2" title="STRUCT_0:attr.2">empty</a>   non  <a href="struct_0.html#V11" title="STRUCT_0:attr.11">void</a>   <a href="msualg_1.html#V1" title="MSUALG_1:attr.1">strict</a>   <a href="circcomb.html#V1" title="CIRCCOMB:attr.1">unsplit</a>   <a href="circcomb.html#V2" title="CIRCCOMB:attr.2">gate`1=arity</a>   <a href="circcomb.html#V3" title="CIRCCOMB:attr.3">gate`2isBoolean</a>   <a href="msualg_1.html#L1" title="MSUALG_1:struct.1">ManySortedSign</a> <br/>  for <font color="Olive" title="b2">x</font> being    <a href="hidden.html#M2" title="HIDDEN:mode.2">set</a> <br/>  for <font color="Olive" title="b3">n</font> being   <a href="ordinal1.html#NM6" title="ORDINAL1:NM.6">Nat</a> holds <br/> ( <font color="Maroon">H<sub>1</sub></font>(<font color="Olive" title="b1">S</font>,<font color="Olive" title="b2">x</font>,<font color="Olive" title="b3">n</font>) is  <a href="circcomb.html#V1" title="CIRCCOMB:attr.1">unsplit</a>  &amp; <font color="Maroon">H<sub>1</sub></font>(<font color="Olive" title="b1">S</font>,<font color="Olive" title="b2">x</font>,<font color="Olive" title="b3">n</font>) is  <a href="circcomb.html#V2" title="CIRCCOMB:attr.2">gate`1=arity</a>  &amp; <font color="Maroon">H<sub>1</sub></font>(<font color="Olive" title="b1">S</font>,<font color="Olive" title="b2">x</font>,<font color="Olive" title="b3">n</font>) is  <a href="circcomb.html#V3" title="CIRCCOMB:attr.3">gate`2isBoolean</a>  &amp;  not <font color="Maroon">H<sub>1</sub></font>(<font color="Olive" title="b1">S</font>,<font color="Olive" title="b2">x</font>,<font color="Olive" title="b3">n</font>) is  <a href="struct_0.html#V11" title="STRUCT_0:attr.11">void</a>  &amp; <font color="Maroon">H<sub>1</sub></font>(<font color="Olive" title="b1">S</font>,<font color="Olive" title="b2">x</font>,<font color="Olive" title="b3">n</font>) is  <a href="msualg_1.html#V1" title="MSUALG_1:attr.1">strict</a>  )
 
;<br/>
<a NAME="E2:2_1_2"/><span class="lab"><font color="Green" title="E3">A3</font></span>: 
 ex <font color="Olive" title="b1">f</font>, <font color="Olive" title="b2">h</font> being   <a href="pboole.html#NM1" title="PBOOLE:NM.1">ManySortedSet</a> of  <a href="numbers.html#NK1" title="NUMBERS:NK.1">NAT</a>  st <br/>( <font color="Maroon" title="c1">n</font> <a href="gfacirc2.html#K1" title="GFACIRC2:func.1">-BitGFA0Str</a> (<font color="Maroon" title="c2">x</font>,<font color="Maroon" title="c3">y</font>) <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b1">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c1">n</font> &amp; <font color="Olive" title="b1">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a>  <a href="circcomb.html#K5" title="CIRCCOMB:func.5">1GateCircStr</a> (<a href="facirc_2.html#NK3" title="FACIRC_2:NK.3">&lt;*&gt;</a>,<span class="p1">(<span class="default"><span class="p2">(<span class="default"><a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <a href="margrel1.html#K5" title="MARGREL1:func.5">BOOLEAN</a></span>)</span> <a href="funcop_1.html#K8" title="FUNCOP_1:func.8">--&gt;</a> <a href="margrel1.html#K6" title="MARGREL1:func.6">FALSE</a></span>)</span>) &amp; <font color="Olive" title="b2">h</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <span class="p1"><a href="tarski.html#K4" title="TARSKI:func.4">[</a><span class="default"><a href="facirc_2.html#NK3" title="FACIRC_2:NK.3">&lt;*&gt;</a>,<span class="p2">(<span class="default"><span class="p3">(<span class="default"><a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <a href="margrel1.html#K5" title="MARGREL1:func.5">BOOLEAN</a></span>)</span> <a href="funcop_1.html#K8" title="FUNCOP_1:func.8">--&gt;</a> <a href="margrel1.html#K6" title="MARGREL1:func.6">FALSE</a></span>)</span></span><a href="tarski.html#K4" title="TARSKI:func.4">]</a></span> &amp; (  for <font color="Olive" title="b3">n</font> being   <a href="ordinal1.html#NM6" title="ORDINAL1:NM.6">Nat</a><br/>  for <font color="Olive" title="b4">S</font> being   non  <a href="struct_0.html#V2" title="STRUCT_0:attr.2">empty</a>   <a href="msualg_1.html#L1" title="MSUALG_1:struct.1">ManySortedSign</a> <br/>  for <font color="Olive" title="b5">x</font> being    <a href="hidden.html#M2" title="HIDDEN:mode.2">set</a>   st <font color="Olive" title="b4">S</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b1">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b3">n</font> &amp; <font color="Olive" title="b5">x</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b2">h</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b3">n</font> holds <br/>( <font color="Olive" title="b1">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Olive" title="b3">n</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon">H<sub>1</sub></font>(<font color="Olive" title="b4">S</font>,<font color="Olive" title="b5">x</font>,<font color="Olive" title="b3">n</font>) &amp; <font color="Olive" title="b2">h</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Olive" title="b3">n</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon">H<sub>3</sub></font>(<font color="Olive" title="b5">x</font>,<font color="Olive" title="b3">n</font>) ) ) )
 
<span class="kw">by</span> <span class="lab"><a class="ref" href="gfacirc2.html#D1" target="_self" onmouseover="rs('gfacirc2/D1')" onmouseout="rh()">Def1</a></span>;<br/>
<a NAME="E3:2_1_2"/><span class="lab"><font color="Green" title="E4">A4</font></span>: 
 for <font color="Olive" title="b1">S</font> being   non  <a href="struct_0.html#V2" title="STRUCT_0:attr.2">empty</a>   <a href="msualg_1.html#L1" title="MSUALG_1:struct.1">ManySortedSign</a> <br/>  for <font color="Olive" title="b2">A</font> being   <a href="msualg_1.html#V4" title="MSUALG_1:attr.4">non-empty</a>   <a href="msualg_1.html#L3" title="MSUALG_1:struct.3">MSAlgebra</a> over <font color="Olive" title="b1">S</font><br/>  for <font color="Olive" title="b3">x</font> being    <a href="hidden.html#M2" title="HIDDEN:mode.2">set</a> <br/>  for <font color="Olive" title="b4">n</font> being   <a href="ordinal1.html#NM6" title="ORDINAL1:NM.6">Nat</a> holds  <font color="Maroon">H<sub>2</sub></font>(<font color="Olive" title="b1">S</font>,<font color="Olive" title="b2">A</font>,<font color="Olive" title="b3">x</font>,<font color="Olive" title="b4">n</font>) is   <a href="msualg_1.html#V4" title="MSUALG_1:attr.4">non-empty</a>   <a href="msualg_1.html#L3" title="MSUALG_1:struct.3">MSAlgebra</a> over <font color="Maroon">H<sub>1</sub></font>(<font color="Olive" title="b1">S</font>,<font color="Olive" title="b3">x</font>,<font color="Olive" title="b4">n</font>)
 
;<br/>
<a NAME="E4:2_1_2"/><span class="lab"><font color="Green" title="E5">A5</font></span>: 
 for <font color="Olive" title="b1">S</font>, <font color="Olive" title="b2">S1</font> being   non  <a href="struct_0.html#V2" title="STRUCT_0:attr.2">empty</a>   non  <a href="struct_0.html#V11" title="STRUCT_0:attr.11">void</a>   <a href="msualg_1.html#V1" title="MSUALG_1:attr.1">strict</a>   <a href="circcomb.html#V1" title="CIRCCOMB:attr.1">unsplit</a>   <a href="circcomb.html#V2" title="CIRCCOMB:attr.2">gate`1=arity</a>   <a href="circcomb.html#V3" title="CIRCCOMB:attr.3">gate`2isBoolean</a>   <a href="msualg_1.html#L1" title="MSUALG_1:struct.1">ManySortedSign</a> <br/>  for <font color="Olive" title="b3">A</font> being   <a href="msualg_1.html#V3" title="MSUALG_1:attr.3">strict</a>   <a href="circcomb.html#V4" title="CIRCCOMB:attr.4">gate`2=den</a>   <a href="circcomb.html#V6" title="CIRCCOMB:attr.6">Boolean</a>  <a href="circuit1.html#NM1" title="CIRCUIT1:NM.1">Circuit</a> of <font color="Olive" title="b1">S</font><br/>  for <font color="Olive" title="b4">x</font> being    <a href="hidden.html#M2" title="HIDDEN:mode.2">set</a> <br/>  for <font color="Olive" title="b5">n</font> being   <a href="ordinal1.html#NM6" title="ORDINAL1:NM.6">Nat</a>  st <font color="Olive" title="b2">S1</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon">H<sub>1</sub></font>(<font color="Olive" title="b1">S</font>,<font color="Olive" title="b4">x</font>,<font color="Olive" title="b5">n</font>) holds <br/><font color="Maroon">H<sub>2</sub></font>(<font color="Olive" title="b1">S</font>,<font color="Olive" title="b3">A</font>,<font color="Olive" title="b4">x</font>,<font color="Olive" title="b5">n</font>) is   <a href="msualg_1.html#V3" title="MSUALG_1:attr.3">strict</a>   <a href="circcomb.html#V4" title="CIRCCOMB:attr.4">gate`2=den</a>   <a href="circcomb.html#V6" title="CIRCCOMB:attr.6">Boolean</a>  <a href="circuit1.html#NM1" title="CIRCUIT1:NM.1">Circuit</a> of <font color="Olive" title="b2">S1</font>
 
;<br/>
<a NAME="E5:2_1_2"/>
 ex <font color="Olive" title="b1">A</font> being   <a href="msualg_1.html#V3" title="MSUALG_1:attr.3">strict</a>   <a href="circcomb.html#V4" title="CIRCCOMB:attr.4">gate`2=den</a>   <a href="circcomb.html#V6" title="CIRCCOMB:attr.6">Boolean</a>  <a href="circuit1.html#NM1" title="CIRCUIT1:NM.1">Circuit</a> of <font color="Maroon" title="c1">n</font> <a href="gfacirc2.html#K1" title="GFACIRC2:func.1">-BitGFA0Str</a> (<font color="Maroon" title="c2">x</font>,<font color="Maroon" title="c3">y</font>) ex <font color="Olive" title="b2">f</font>, <font color="Olive" title="b3">g</font>, <font color="Olive" title="b4">h</font> being   <a href="pboole.html#NM1" title="PBOOLE:NM.1">ManySortedSet</a> of  <a href="numbers.html#NK1" title="NUMBERS:NK.1">NAT</a>  st <br/>( <font color="Maroon" title="c1">n</font> <a href="gfacirc2.html#K1" title="GFACIRC2:func.1">-BitGFA0Str</a> (<font color="Maroon" title="c2">x</font>,<font color="Maroon" title="c3">y</font>) <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b2">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c1">n</font> &amp; <font color="Olive" title="b1">A</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b3">g</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c1">n</font> &amp; <font color="Olive" title="b2">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a>  <a href="circcomb.html#K5" title="CIRCCOMB:func.5">1GateCircStr</a> (<a href="facirc_2.html#NK3" title="FACIRC_2:NK.3">&lt;*&gt;</a>,<span class="p1">(<span class="default"><span class="p2">(<span class="default"><a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <a href="margrel1.html#K5" title="MARGREL1:func.5">BOOLEAN</a></span>)</span> <a href="funcop_1.html#K8" title="FUNCOP_1:func.8">--&gt;</a> <a href="margrel1.html#K6" title="MARGREL1:func.6">FALSE</a></span>)</span>) &amp; <font color="Olive" title="b3">g</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a>  <a href="circcomb.html#K7" title="CIRCCOMB:func.7">1GateCircuit</a> (<a href="facirc_2.html#NK3" title="FACIRC_2:NK.3">&lt;*&gt;</a>,<span class="p1">(<span class="default"><span class="p2">(<span class="default"><a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <a href="margrel1.html#K5" title="MARGREL1:func.5">BOOLEAN</a></span>)</span> <a href="funcop_1.html#K8" title="FUNCOP_1:func.8">--&gt;</a> <a href="margrel1.html#K6" title="MARGREL1:func.6">FALSE</a></span>)</span>) &amp; <font color="Olive" title="b4">h</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <span class="p1"><a href="tarski.html#K4" title="TARSKI:func.4">[</a><span class="default"><a href="facirc_2.html#NK3" title="FACIRC_2:NK.3">&lt;*&gt;</a>,<span class="p2">(<span class="default"><span class="p3">(<span class="default"><a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <a href="margrel1.html#K5" title="MARGREL1:func.5">BOOLEAN</a></span>)</span> <a href="funcop_1.html#K8" title="FUNCOP_1:func.8">--&gt;</a> <a href="margrel1.html#K6" title="MARGREL1:func.6">FALSE</a></span>)</span></span><a href="tarski.html#K4" title="TARSKI:func.4">]</a></span> &amp; (  for <font color="Olive" title="b5">n</font> being   <a href="ordinal1.html#NM6" title="ORDINAL1:NM.6">Nat</a><br/>  for <font color="Olive" title="b6">S</font> being   non  <a href="struct_0.html#V2" title="STRUCT_0:attr.2">empty</a>   <a href="msualg_1.html#L1" title="MSUALG_1:struct.1">ManySortedSign</a> <br/>  for <font color="Olive" title="b7">A</font> being   <a href="msualg_1.html#V4" title="MSUALG_1:attr.4">non-empty</a>   <a href="msualg_1.html#L3" title="MSUALG_1:struct.3">MSAlgebra</a> over <font color="Olive" title="b6">S</font><br/>  for <font color="Olive" title="b8">x</font> being    <a href="hidden.html#M2" title="HIDDEN:mode.2">set</a>   st <font color="Olive" title="b6">S</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b2">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b5">n</font> &amp; <font color="Olive" title="b7">A</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b3">g</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b5">n</font> &amp; <font color="Olive" title="b8">x</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b4">h</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b5">n</font> holds <br/>( <font color="Olive" title="b2">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Olive" title="b5">n</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon">H<sub>1</sub></font>(<font color="Olive" title="b6">S</font>,<font color="Olive" title="b8">x</font>,<font color="Olive" title="b5">n</font>) &amp; <font color="Olive" title="b3">g</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Olive" title="b5">n</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon">H<sub>2</sub></font>(<font color="Olive" title="b6">S</font>,<font color="Olive" title="b7">A</font>,<font color="Olive" title="b8">x</font>,<font color="Olive" title="b5">n</font>) &amp; <font color="Olive" title="b4">h</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Olive" title="b5">n</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon">H<sub>3</sub></font>(<font color="Olive" title="b8">x</font>,<font color="Olive" title="b5">n</font>) ) ) )
 
<span class="kw">from</span> <span class="lab"><a class="ref" href="circcmb2.html#S19" onmouseover="rs('circcmb2/S19')" onmouseout="rh()">CIRCCMB2:sch 19</a>(<a class="txt" href="#E1:2_1_2"><span class="lab"><font color="Green" title="E2">A2</font></span></a>, <a class="txt" href="#E2:2_1_2"><span class="lab"><font color="Green" title="E3">A3</font></span></a>, <a class="txt" href="#E3:2_1_2"><span class="lab"><font color="Green" title="E4">A4</font></span></a>, <a class="txt" href="#E4:2_1_2"><span class="lab"><font color="Green" title="E5">A5</font></span></a>);<br/></span>
<span class="kw">hence </span><a NAME="E6:2_1_2"/>
 ex <font color="Olive">b<sub>1</sub></font> being   <a href="msualg_1.html#V3" title="MSUALG_1:attr.3">strict</a>   <a href="circcomb.html#V4" title="CIRCCOMB:attr.4">gate`2=den</a>   <a href="circcomb.html#V6" title="CIRCCOMB:attr.6">Boolean</a>  <a href="circuit1.html#NM1" title="CIRCUIT1:NM.1">Circuit</a> of <font color="Maroon" title="c1">n</font> <a href="gfacirc2.html#K1" title="GFACIRC2:func.1">-BitGFA0Str</a> (<font color="Maroon" title="c2">x</font>,<font color="Maroon" title="c3">y</font>) ex <font color="Olive" title="b2">f</font>, <font color="Olive" title="b3">g</font>, <font color="Olive" title="b4">h</font> being   <a href="pboole.html#NM1" title="PBOOLE:NM.1">ManySortedSet</a> of  <a href="numbers.html#NK1" title="NUMBERS:NK.1">NAT</a>  st <br/>( <font color="Maroon" title="c1">n</font> <a href="gfacirc2.html#K1" title="GFACIRC2:func.1">-BitGFA0Str</a> (<font color="Maroon" title="c2">x</font>,<font color="Maroon" title="c3">y</font>) <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b2">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c1">n</font> &amp; <font color="Olive">b<sub>1</sub></font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b3">g</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c1">n</font> &amp; <font color="Olive" title="b2">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a>  <a href="circcomb.html#K5" title="CIRCCOMB:func.5">1GateCircStr</a> (<a href="facirc_2.html#NK3" title="FACIRC_2:NK.3">&lt;*&gt;</a>,<span class="p1">(<span class="default"><span class="p2">(<span class="default"><a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <a href="margrel1.html#K5" title="MARGREL1:func.5">BOOLEAN</a></span>)</span> <a href="funcop_1.html#K8" title="FUNCOP_1:func.8">--&gt;</a> <a href="margrel1.html#K6" title="MARGREL1:func.6">FALSE</a></span>)</span>) &amp; <font color="Olive" title="b3">g</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a>  <a href="circcomb.html#K7" title="CIRCCOMB:func.7">1GateCircuit</a> (<a href="facirc_2.html#NK3" title="FACIRC_2:NK.3">&lt;*&gt;</a>,<span class="p1">(<span class="default"><span class="p2">(<span class="default"><a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <a href="margrel1.html#K5" title="MARGREL1:func.5">BOOLEAN</a></span>)</span> <a href="funcop_1.html#K8" title="FUNCOP_1:func.8">--&gt;</a> <a href="margrel1.html#K6" title="MARGREL1:func.6">FALSE</a></span>)</span>) &amp; <font color="Olive" title="b4">h</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <span class="p1"><a href="tarski.html#K4" title="TARSKI:func.4">[</a><span class="default"><a href="facirc_2.html#NK3" title="FACIRC_2:NK.3">&lt;*&gt;</a>,<span class="p2">(<span class="default"><span class="p3">(<span class="default"><a href="numbers.html#K5" title="NUMBERS:func.5">0</a> <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <a href="margrel1.html#K5" title="MARGREL1:func.5">BOOLEAN</a></span>)</span> <a href="funcop_1.html#K8" title="FUNCOP_1:func.8">--&gt;</a> <a href="margrel1.html#K6" title="MARGREL1:func.6">FALSE</a></span>)</span></span><a href="tarski.html#K4" title="TARSKI:func.4">]</a></span> &amp; (  for <font color="Olive" title="b5">n</font> being   <a href="ordinal1.html#NM6" title="ORDINAL1:NM.6">Nat</a><br/>  for <font color="Olive" title="b6">S</font> being   non  <a href="struct_0.html#V2" title="STRUCT_0:attr.2">empty</a>   <a href="msualg_1.html#L1" title="MSUALG_1:struct.1">ManySortedSign</a> <br/>  for <font color="Olive" title="b7">A</font> being   <a href="msualg_1.html#V4" title="MSUALG_1:attr.4">non-empty</a>   <a href="msualg_1.html#L3" title="MSUALG_1:struct.3">MSAlgebra</a> over <font color="Olive" title="b6">S</font><br/>  for <font color="Olive" title="b8">z</font> being    <a href="hidden.html#M2" title="HIDDEN:mode.2">set</a>   st <font color="Olive" title="b6">S</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b2">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b5">n</font> &amp; <font color="Olive" title="b7">A</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b3">g</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b5">n</font> &amp; <font color="Olive" title="b8">z</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b4">h</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b5">n</font> holds <br/>( <font color="Olive" title="b2">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Olive" title="b5">n</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b6">S</font> <a href="circcomb.html#K2" title="CIRCCOMB:func.2">+*</a> <span class="p1">(<span class="default"><a href="gfacirc1.html#K13" title="GFACIRC1:func.13">BitGFA0Str</a> (<span class="p2">(<span class="default"><font color="Maroon" title="c2">x</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p3">(<span class="default"><font color="Olive" title="b5">n</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,<span class="p2">(<span class="default"><font color="Maroon" title="c3">y</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p3">(<span class="default"><font color="Olive" title="b5">n</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,<font color="Olive" title="b8">z</font>)</span>)</span> &amp; <font color="Olive" title="b3">g</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Olive" title="b5">n</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b7">A</font> <a href="circcomb.html#K3" title="CIRCCOMB:func.3">+*</a> <span class="p1">(<span class="default"><a href="gfacirc1.html#K14" title="GFACIRC1:func.14">BitGFA0Circ</a> (<span class="p2">(<span class="default"><font color="Maroon" title="c2">x</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p3">(<span class="default"><font color="Olive" title="b5">n</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,<span class="p2">(<span class="default"><font color="Maroon" title="c3">y</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p3">(<span class="default"><font color="Olive" title="b5">n</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,<font color="Olive" title="b8">z</font>)</span>)</span> &amp; <font color="Olive" title="b4">h</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Olive" title="b5">n</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a>  <a href="gfacirc1.html#K9" title="GFACIRC1:func.9">GFA0CarryOutput</a> (<span class="p1">(<span class="default"><font color="Maroon" title="c2">x</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p2">(<span class="default"><font color="Olive" title="b5">n</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,<span class="p1">(<span class="default"><font color="Maroon" title="c3">y</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p2">(<span class="default"><font color="Olive" title="b5">n</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,<font color="Olive" title="b8">z</font>) ) ) )
 ; <a class="txt" onmouseover="tooltip.show('hs',this)" onmouseout="tooltip.hide()" onclick="hs(this)" href="javascript:()"><span class="comment"><font color="firebrick">::  thesis: </font></span></a><span class="hide"> verum</span><br/>


</div>
