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

<span class="kw">let </span><font color="Maroon" title="c1">n</font> be   <a href="ordinal1.html#NM6" title="ORDINAL1:NM.6">Nat</a>; <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">  for <font color="Olive" title="b1">X</font> being   non  <a href="xboole_0.html#V1" title="XBOOLE_0:attr.1">empty</a>   <a href="finset_1.html#V1" title="FINSET_1:attr.1">finite</a>   <a href="hidden.html#M2" title="HIDDEN:mode.2">set</a> <br/>  for <font color="Olive" title="b2">f</font> being   <a href="funct_2.html#NM1" title="FUNCT_2:NM.1">Function</a> of <span class="p1">(<span class="default"><font color="Maroon" title="c1">n</font> <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <font color="Olive" title="b1">X</font></span>)</span>,<font color="Olive" title="b1">X</font><br/>  for <font color="Olive" title="b3">p</font> being   <a href="circcomb.html#NM2" title="CIRCCOMB:NM.2">FinSeqLen</a> of <font color="Maroon" title="c1">n</font><br/>  for <font color="Olive" title="b4">s</font> being   <a href="circuit1.html#NM3" title="CIRCUIT1:NM.3">State</a> of <span class="p1">(<span class="default"><a href="circcomb.html#K7" title="CIRCCOMB:func.7">1GateCircuit</a> (<font color="Olive" title="b3">p</font>,<font color="Olive" title="b2">f</font>)</span>)</span> holds  <span class="p1">(<span class="default"><a href="circuit2.html#K6" title="CIRCUIT2:func.6">Following</a> <font color="Olive" title="b4">s</font></span>)</span> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1"><a href="tarski.html#K4" title="TARSKI:func.4">[</a><span class="default"><font color="Olive" title="b3">p</font>,<font color="Olive" title="b2">f</font></span><a href="tarski.html#K4" title="TARSKI:func.4">]</a></span> <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> <span class="p1">(<span class="default"><font color="Olive" title="b4">s</font> <a href="funct_1.html#NK3" title="FUNCT_1:NK.3">*</a> <font color="Olive" title="b3">p</font></span>)</span></span><br/><span class="kw">let </span><font color="Maroon" title="c2">X</font> be   non  <a href="xboole_0.html#V1" title="XBOOLE_0:attr.1">empty</a>   <a href="finset_1.html#V1" title="FINSET_1:attr.1">finite</a>   <a href="hidden.html#M2" title="HIDDEN:mode.2">set</a> ; <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">  for <font color="Olive" title="b1">f</font> being   <a href="funct_2.html#NM1" title="FUNCT_2:NM.1">Function</a> of <span class="p1">(<span class="default"><font color="Maroon" title="c1">n</font> <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <font color="Maroon" title="c2">X</font></span>)</span>,<font color="Maroon" title="c2">X</font><br/>  for <font color="Olive" title="b2">p</font> being   <a href="circcomb.html#NM2" title="CIRCCOMB:NM.2">FinSeqLen</a> of <font color="Maroon" title="c1">n</font><br/>  for <font color="Olive" title="b3">s</font> being   <a href="circuit1.html#NM3" title="CIRCUIT1:NM.3">State</a> of <span class="p1">(<span class="default"><a href="circcomb.html#K7" title="CIRCCOMB:func.7">1GateCircuit</a> (<font color="Olive" title="b2">p</font>,<font color="Olive" title="b1">f</font>)</span>)</span> holds  <span class="p1">(<span class="default"><a href="circuit2.html#K6" title="CIRCUIT2:func.6">Following</a> <font color="Olive" title="b3">s</font></span>)</span> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1"><a href="tarski.html#K4" title="TARSKI:func.4">[</a><span class="default"><font color="Olive" title="b2">p</font>,<font color="Olive" title="b1">f</font></span><a href="tarski.html#K4" title="TARSKI:func.4">]</a></span> <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> <span class="p1">(<span class="default"><font color="Olive" title="b3">s</font> <a href="funct_1.html#NK3" title="FUNCT_1:NK.3">*</a> <font color="Olive" title="b2">p</font></span>)</span></span><br/><span class="kw">let </span><font color="Maroon" title="c3">f</font> be   <a href="funct_2.html#NM1" title="FUNCT_2:NM.1">Function</a> of <span class="p1">(<span class="default"><font color="Maroon" title="c1">n</font> <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <font color="Maroon" title="c2">X</font></span>)</span>,<font color="Maroon" title="c2">X</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">  for <font color="Olive" title="b1">p</font> being   <a href="circcomb.html#NM2" title="CIRCCOMB:NM.2">FinSeqLen</a> of <font color="Maroon" title="c1">n</font><br/>  for <font color="Olive" title="b2">s</font> being   <a href="circuit1.html#NM3" title="CIRCUIT1:NM.3">State</a> of <span class="p1">(<span class="default"><a href="circcomb.html#K7" title="CIRCCOMB:func.7">1GateCircuit</a> (<font color="Olive" title="b1">p</font>,<font color="Maroon" title="c3">f</font>)</span>)</span> holds  <span class="p1">(<span class="default"><a href="circuit2.html#K6" title="CIRCUIT2:func.6">Following</a> <font color="Olive" title="b2">s</font></span>)</span> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1"><a href="tarski.html#K4" title="TARSKI:func.4">[</a><span class="default"><font color="Olive" title="b1">p</font>,<font color="Maroon" title="c3">f</font></span><a href="tarski.html#K4" title="TARSKI:func.4">]</a></span> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c3">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Olive" title="b2">s</font> <a href="funct_1.html#NK3" title="FUNCT_1:NK.3">*</a> <font color="Olive" title="b1">p</font></span>)</span></span><br/><span class="kw">let </span><font color="Maroon" title="c4">p</font> be   <a href="circcomb.html#NM2" title="CIRCCOMB:NM.2">FinSeqLen</a> of <font color="Maroon" title="c1">n</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">  for <font color="Olive" title="b1">s</font> being   <a href="circuit1.html#NM3" title="CIRCUIT1:NM.3">State</a> of <span class="p1">(<span class="default"><a href="circcomb.html#K7" title="CIRCCOMB:func.7">1GateCircuit</a> (<font color="Maroon" title="c4">p</font>,<font color="Maroon" title="c3">f</font>)</span>)</span> holds  <span class="p1">(<span class="default"><a href="circuit2.html#K6" title="CIRCUIT2:func.6">Following</a> <font color="Olive" title="b1">s</font></span>)</span> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1"><a href="tarski.html#K4" title="TARSKI:func.4">[</a><span class="default"><font color="Maroon" title="c4">p</font>,<font color="Maroon" title="c3">f</font></span><a href="tarski.html#K4" title="TARSKI:func.4">]</a></span> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c3">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Olive" title="b1">s</font> <a href="funct_1.html#NK3" title="FUNCT_1:NK.3">*</a> <font color="Maroon" title="c4">p</font></span>)</span></span><br/><span class="kw">let </span><font color="Maroon" title="c5">s</font> be   <a href="circuit1.html#NM3" title="CIRCUIT1:NM.3">State</a> of <span class="p1">(<span class="default"><a href="circcomb.html#K7" title="CIRCCOMB:func.7">1GateCircuit</a> (<font color="Maroon" title="c4">p</font>,<font color="Maroon" title="c3">f</font>)</span>)</span>; <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"> <span class="p1">(<span class="default"><a href="circuit2.html#K6" title="CIRCUIT2:func.6">Following</a> <font color="Maroon" title="c5">s</font></span>)</span> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1"><a href="tarski.html#K4" title="TARSKI:func.4">[</a><span class="default"><font color="Maroon" title="c4">p</font>,<font color="Maroon" title="c3">f</font></span><a href="tarski.html#K4" title="TARSKI:func.4">]</a></span> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c3">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Maroon" title="c5">s</font> <a href="funct_1.html#NK3" title="FUNCT_1:NK.3">*</a> <font color="Maroon" title="c4">p</font></span>)</span></span><br/>









<span class="kw">set </span><font color="Maroon" title="c6">S</font> =  <a href="circcomb.html#K5" title="CIRCCOMB:func.5">1GateCircStr</a> (<font color="Maroon" title="c4">p</font>,<font color="Maroon" title="c3">f</font>);<br/>
<span class="kw">set </span><font color="Maroon" title="c7">A</font> =  <a href="circcomb.html#K7" title="CIRCCOMB:func.7">1GateCircuit</a> (<font color="Maroon" title="c4">p</font>,<font color="Maroon" title="c3">f</font>);<br/>
<span class="kw">set </span><font color="Maroon" title="c8">IV</font> =  <a href="msafree2.html#K3" title="MSAFREE2:func.3">InnerVertices</a> <span class="p1">(<span class="default"><a href="circcomb.html#K5" title="CIRCCOMB:func.5">1GateCircStr</a> (<font color="Maroon" title="c4">p</font>,<font color="Maroon" title="c3">f</font>)</span>)</span>;<br/>
<a NAME="E1:90"/>
 <a href="msafree2.html#K3" title="MSAFREE2:func.3">InnerVertices</a> <span class="p1">(<span class="default"><a href="circcomb.html#K5" title="CIRCCOMB:func.5">1GateCircStr</a> (<font color="Maroon" title="c4">p</font>,<font color="Maroon" title="c3">f</font>)</span>)</span> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <span class="p1"><a href="tarski.html#K1" title="TARSKI:func.1">{</a><span class="default"><span class="p2"><a href="tarski.html#K4" title="TARSKI:func.4">[</a><span class="default"><font color="Maroon" title="c4">p</font>,<font color="Maroon" title="c3">f</font></span><a href="tarski.html#K4" title="TARSKI:func.4">]</a></span></span><a href="tarski.html#K1" title="TARSKI:func.1">}</a></span>
 
<span class="kw">by</span> <span class="lab"><a class="ref" href="circcomb.html#T42" target="_self" onmouseover="rs('circcomb/T42')" onmouseout="rh()">Th42</a></span>;<br/>
<span class="kw">then </span><span class="kw">reconsider </span><font color="Maroon" title="c9">v</font> = <span class="p1"><a href="tarski.html#K4" title="TARSKI:func.4">[</a><span class="default"><font color="Maroon" title="c4">p</font>,<font color="Maroon" title="c3">f</font></span><a href="tarski.html#K4" title="TARSKI:func.4">]</a></span> as    <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="circcomb.html#K5" title="CIRCCOMB:func.5">1GateCircStr</a> (<font color="Maroon" title="c4">p</font>,<font color="Maroon" title="c3">f</font>)</span>)</span> <span class="kw">by</span> <span class="lab"><a class="ref" href="tarski.html#D1" onmouseover="rs('tarski/D1')" onmouseout="rh()">TARSKI:def 1</a></span>;<br/>
<a NAME="E3:90"/>
 the <a href="struct_0.html#U4" title="STRUCT_0:sel.4">carrier'</a> of <span class="p1">(<span class="default"><a href="circcomb.html#K5" title="CIRCCOMB:func.5">1GateCircStr</a> (<font color="Maroon" title="c4">p</font>,<font color="Maroon" title="c3">f</font>)</span>)</span> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <span class="p1"><a href="tarski.html#K1" title="TARSKI:func.1">{</a><span class="default"><span class="p2"><a href="tarski.html#K4" title="TARSKI:func.4">[</a><span class="default"><font color="Maroon" title="c4">p</font>,<font color="Maroon" title="c3">f</font></span><a href="tarski.html#K4" title="TARSKI:func.4">]</a></span></span><a href="tarski.html#K1" title="TARSKI:func.1">}</a></span>
 
<span class="kw">by</span> <span class="lab"><a class="ref" href="circcomb.html#D6" target="_self" onmouseover="rs('circcomb/D6')" onmouseout="rh()">Def6</a></span>;<br/>
<span class="kw">then </span><span class="kw">reconsider </span><font color="Maroon" title="c10">o</font> = <span class="p1"><a href="tarski.html#K4" title="TARSKI:func.4">[</a><span class="default"><font color="Maroon" title="c4">p</font>,<font color="Maroon" title="c3">f</font></span><a href="tarski.html#K4" title="TARSKI:func.4">]</a></span> as   <a href="circcomb.html#NM1" title="CIRCCOMB:NM.1">Gate</a> of <span class="p1">(<span class="default"><a href="circcomb.html#K5" title="CIRCCOMB:func.5">1GateCircStr</a> (<font color="Maroon" title="c4">p</font>,<font color="Maroon" title="c3">f</font>)</span>)</span> <span class="kw">by</span> <span class="lab"><a class="ref" href="tarski.html#D1" onmouseover="rs('tarski/D1')" onmouseout="rh()">TARSKI:def 1</a></span>;<br/>
<a NAME="E5:90"/>
 <a href="msualg_1.html#K2" title="MSUALG_1:func.2">the_result_sort_of</a> <font color="Maroon" title="c10">o</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c9">v</font>
 
<span class="kw">by</span> <span class="lab"><a class="ref" href="circcomb.html#D6" target="_self" onmouseover="rs('circcomb/D6')" onmouseout="rh()">Def6</a></span>;<br/>
<a NAME="E6:90"/><span class="kw">then </span><span class="lab"><font color="Green" title="E46">A1</font></span>: 
 <a href="msafree2.html#K4" title="MSAFREE2:func.4">action_at</a> <font color="Maroon" title="c9">v</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c10">o</font>
 
<span class="kw">by</span> <span class="lab"><a class="ref" href="msafree2.html#D7" onmouseover="rs('msafree2/D7')" onmouseout="rh()">MSAFREE2:def 7</a></span>;<br/>
<a NAME="E7:90"/>
 <a href="msualg_1.html#K1" title="MSUALG_1:func.1">the_arity_of</a> <font color="Maroon" title="c10">o</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c4">p</font>
 
<span class="kw">by</span> <span class="lab"><a class="ref" href="circcomb.html#D6" target="_self" onmouseover="rs('circcomb/D6')" onmouseout="rh()">Def6</a></span>;<br/>
<a NAME="E8:90"/><span class="kw">then </span><span class="lab"><font color="Green" title="E47">A2</font></span>: 
<font color="Maroon" title="c10">o</font> <a href="circuit1.html#K3" title="CIRCUIT1:func.3">depends_on_in</a> <font color="Maroon" title="c5">s</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c5">s</font> <a href="funct_1.html#NK3" title="FUNCT_1:NK.3">*</a> <font color="Maroon" title="c4">p</font>
 
<span class="kw">by</span> <span class="lab"><a class="ref" href="circuit1.html#D3" onmouseover="rs('circuit1/D3')" onmouseout="rh()">CIRCUIT1:def 3</a></span>;<br/>
<a NAME="E9:90"/>
<span class="p1">(<span class="default"><a href="circuit2.html#K6" title="CIRCUIT2:func.6">Following</a> <font color="Maroon" title="c5">s</font></span>)</span> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c9">v</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <span class="p1">(<span class="default"><a href="msualg_1.html#K5" title="MSUALG_1:func.5">Den</a> (<span class="p2">(<span class="default"><a href="msafree2.html#K4" title="MSAFREE2:func.4">action_at</a> <font color="Maroon" title="c9">v</font></span>)</span>,<span class="p2">(<span class="default"><a href="circcomb.html#K7" title="CIRCCOMB:func.7">1GateCircuit</a> (<font color="Maroon" title="c4">p</font>,<font color="Maroon" title="c3">f</font>)</span>)</span>)</span>)</span> <a href="funct_2.html#K3" title="FUNCT_2:func.3">.</a> <span class="p1">(<span class="default"><span class="p2">(<span class="default"><a href="msafree2.html#K4" title="MSAFREE2:func.4">action_at</a> <font color="Maroon" title="c9">v</font></span>)</span> <a href="circuit1.html#K3" title="CIRCUIT1:func.3">depends_on_in</a> <font color="Maroon" title="c5">s</font></span>)</span>
 
<span class="kw">by</span> <span class="lab"><a class="ref" href="circuit2.html#D5" onmouseover="rs('circuit2/D5')" onmouseout="rh()">CIRCUIT2:def 5</a></span>;<br/>
<span class="kw">hence </span><a NAME="E10:90"/>
<span class="p1">(<span class="default"><a href="circuit2.html#K6" title="CIRCUIT2:func.6">Following</a> <font color="Maroon" title="c5">s</font></span>)</span> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1"><a href="tarski.html#K4" title="TARSKI:func.4">[</a><span class="default"><font color="Maroon" title="c4">p</font>,<font color="Maroon" title="c3">f</font></span><a href="tarski.html#K4" title="TARSKI:func.4">]</a></span> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c3">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Maroon" title="c5">s</font> <a href="funct_1.html#NK3" title="FUNCT_1:NK.3">*</a> <font color="Maroon" title="c4">p</font></span>)</span>
 <span class="kw">by</span> <span class="lab"><a class="txt" href="#E6:90"><span class="lab"><font color="Green" title="E46">A1</font></span></a>, <a class="txt" href="#E8:90"><span class="lab"><font color="Green" title="E47">A2</font></span></a>, <a class="ref" href="circcomb.html#D13" target="_self" onmouseover="rs('circcomb/D13')" onmouseout="rh()">Def13</a></span>; <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>
