<?xml version="1.0"?>
<div>:: <span class="kw">deftheorem </span><span class="lab"><font color="Green" title="E2">Def2</font></span>   defines <a href="gfacirc2.html#K2" title="GFACIRC2:func.2">-BitGFA0Circ</a> <a onclick="hs(this)" href="javascript:()">GFACIRC2:def 2 : <br/></a><span> for <font color="Olive" title="b1">n</font> being   <a href="ordinal1.html#NM6" title="ORDINAL1:NM.6">Nat</a><br/>  for <font color="Olive" title="b2">x</font>, <font color="Olive" title="b3">y</font> being   <a href="finseq_1.html#NM1" title="FINSEQ_1:NM.1">FinSequence</a><br/>  for <font color="Olive">b<sub>4</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="Olive" title="b1">n</font> <a href="gfacirc2.html#K1" title="GFACIRC2:func.1">-BitGFA0Str</a> (<font color="Olive" title="b2">x</font>,<font color="Olive" title="b3">y</font>) holds <br/> ( <font color="Olive">b<sub>4</sub></font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b1">n</font> <a href="gfacirc2.html#K2" title="GFACIRC2:func.2">-BitGFA0Circ</a> (<font color="Olive" title="b2">x</font>,<font color="Olive" title="b3">y</font>) iff  ex <font color="Olive" title="b5">f</font>, <font color="Olive" title="b6">g</font>, <font color="Olive" title="b7">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="Olive" title="b1">n</font> <a href="gfacirc2.html#K1" title="GFACIRC2:func.1">-BitGFA0Str</a> (<font color="Olive" title="b2">x</font>,<font color="Olive" title="b3">y</font>) <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b5">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b1">n</font> &amp; <font color="Olive">b<sub>4</sub></font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b6">g</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b1">n</font> &amp; <font color="Olive" title="b5">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="b6">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="b7">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="b8">n</font> being   <a href="ordinal1.html#NM6" title="ORDINAL1:NM.6">Nat</a><br/>  for <font color="Olive" title="b9">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="b10">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="b9">S</font><br/>  for <font color="Olive" title="b11">z</font> being    <a href="hidden.html#M2" title="HIDDEN:mode.2">set</a>   st <font color="Olive" title="b9">S</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b5">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b8">n</font> &amp; <font color="Olive" title="b10">A</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b6">g</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b8">n</font> &amp; <font color="Olive" title="b11">z</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b7">h</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b8">n</font> holds <br/>( <font color="Olive" title="b5">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Olive" title="b8">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="b9">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="Olive" title="b2">x</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p3">(<span class="default"><font color="Olive" title="b8">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="Olive" title="b3">y</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p3">(<span class="default"><font color="Olive" title="b8">n</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,<font color="Olive" title="b11">z</font>)</span>)</span> &amp; <font color="Olive" title="b6">g</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Olive" title="b8">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="b10">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="Olive" title="b2">x</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p3">(<span class="default"><font color="Olive" title="b8">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="Olive" title="b3">y</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p3">(<span class="default"><font color="Olive" title="b8">n</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,<font color="Olive" title="b11">z</font>)</span>)</span> &amp; <font color="Olive" title="b7">h</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Olive" title="b8">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="Olive" title="b2">x</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p2">(<span class="default"><font color="Olive" title="b8">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="Olive" title="b3">y</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p2">(<span class="default"><font color="Olive" title="b8">n</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span></span>)</span>,<font color="Olive" title="b11">z</font>) ) ) ) );<br/></span></div>
