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

<span class="kw">let </span><font color="Maroon" title="c1">A</font> be   <a href="aofa_000.html#NM1" title="AOFA_000:NM.1">preIfWhileAlgebra</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">I</font> being   <a href="struct_0.html#NM1" title="STRUCT_0:NM.1">Element</a> of <font color="Maroon" title="c1">A</font><br/>  for <font color="Olive" title="b2">S</font> being   non  <a href="xboole_0.html#V1" title="XBOOLE_0:attr.1">empty</a>   <a href="hidden.html#M2" title="HIDDEN:mode.2">set</a> <br/>  for <font color="Olive" title="b3">T</font> being   <a href="subset_1.html#NM2" title="SUBSET_1:NM.2">Subset</a> of <font color="Olive" title="b2">S</font><br/>  for <font color="Olive" title="b4">s</font> being    <a href="subset_1.html#M1" title="SUBSET_1:mode.1">Element</a> of <font color="Olive" title="b2">S</font><br/>  for <font color="Olive" title="b5">f</font> being    <a href="aofa_000.html#M1" title="AOFA_000:mode.1">ExecutionFunction</a> of <font color="Maroon" title="c1">A</font>,<font color="Olive" title="b2">S</font>,<font color="Olive" title="b3">T</font> holds   <a href="aofa_000.html#K20" title="AOFA_000:func.20">iteration-degree</a> (<font color="Olive" title="b1">I</font>,<font color="Olive" title="b4">s</font>,<font color="Olive" title="b5">f</font>) <a href="xxreal_0.html#NR2" title="XXREAL_0:NR.2">&gt;=</a>  <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> </span><br/><span class="kw">let </span><font color="Maroon" title="c2">I</font> be   <a href="struct_0.html#NM1" title="STRUCT_0:NM.1">Element</a> of <font color="Maroon" title="c1">A</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   non  <a href="xboole_0.html#V1" title="XBOOLE_0:attr.1">empty</a>   <a href="hidden.html#M2" title="HIDDEN:mode.2">set</a> <br/>  for <font color="Olive" title="b2">T</font> being   <a href="subset_1.html#NM2" title="SUBSET_1:NM.2">Subset</a> of <font color="Olive" title="b1">S</font><br/>  for <font color="Olive" title="b3">s</font> being    <a href="subset_1.html#M1" title="SUBSET_1:mode.1">Element</a> of <font color="Olive" title="b1">S</font><br/>  for <font color="Olive" title="b4">f</font> being    <a href="aofa_000.html#M1" title="AOFA_000:mode.1">ExecutionFunction</a> of <font color="Maroon" title="c1">A</font>,<font color="Olive" title="b1">S</font>,<font color="Olive" title="b2">T</font> holds   <a href="aofa_000.html#K20" title="AOFA_000:func.20">iteration-degree</a> (<font color="Maroon" title="c2">I</font>,<font color="Olive" title="b3">s</font>,<font color="Olive" title="b4">f</font>) <a href="xxreal_0.html#NR2" title="XXREAL_0:NR.2">&gt;=</a>  <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> </span><br/><span class="kw">let </span><font color="Maroon" title="c3">S</font> be   non  <a href="xboole_0.html#V1" title="XBOOLE_0:attr.1">empty</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">T</font> being   <a href="subset_1.html#NM2" title="SUBSET_1:NM.2">Subset</a> of <font color="Maroon" title="c3">S</font><br/>  for <font color="Olive" title="b2">s</font> being    <a href="subset_1.html#M1" title="SUBSET_1:mode.1">Element</a> of <font color="Maroon" title="c3">S</font><br/>  for <font color="Olive" title="b3">f</font> being    <a href="aofa_000.html#M1" title="AOFA_000:mode.1">ExecutionFunction</a> of <font color="Maroon" title="c1">A</font>,<font color="Maroon" title="c3">S</font>,<font color="Olive" title="b1">T</font> holds   <a href="aofa_000.html#K20" title="AOFA_000:func.20">iteration-degree</a> (<font color="Maroon" title="c2">I</font>,<font color="Olive" title="b2">s</font>,<font color="Olive" title="b3">f</font>) <a href="xxreal_0.html#NR2" title="XXREAL_0:NR.2">&gt;=</a>  <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> </span><br/><span class="kw">let </span><font color="Maroon" title="c4">T</font> be   <a href="subset_1.html#NM2" title="SUBSET_1:NM.2">Subset</a> of <font color="Maroon" title="c3">S</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="subset_1.html#M1" title="SUBSET_1:mode.1">Element</a> of <font color="Maroon" title="c3">S</font><br/>  for <font color="Olive" title="b2">f</font> being    <a href="aofa_000.html#M1" title="AOFA_000:mode.1">ExecutionFunction</a> of <font color="Maroon" title="c1">A</font>,<font color="Maroon" title="c3">S</font>,<font color="Maroon" title="c4">T</font> holds   <a href="aofa_000.html#K20" title="AOFA_000:func.20">iteration-degree</a> (<font color="Maroon" title="c2">I</font>,<font color="Olive" title="b1">s</font>,<font color="Olive" title="b2">f</font>) <a href="xxreal_0.html#NR2" title="XXREAL_0:NR.2">&gt;=</a>  <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> </span><br/><span class="kw">let </span><font color="Maroon" title="c5">s</font> be    <a href="subset_1.html#M1" title="SUBSET_1:mode.1">Element</a> of <font color="Maroon" title="c3">S</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">f</font> being    <a href="aofa_000.html#M1" title="AOFA_000:mode.1">ExecutionFunction</a> of <font color="Maroon" title="c1">A</font>,<font color="Maroon" title="c3">S</font>,<font color="Maroon" title="c4">T</font> holds   <a href="aofa_000.html#K20" title="AOFA_000:func.20">iteration-degree</a> (<font color="Maroon" title="c2">I</font>,<font color="Maroon" title="c5">s</font>,<font color="Olive" title="b1">f</font>) <a href="xxreal_0.html#NR2" title="XXREAL_0:NR.2">&gt;=</a>  <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> </span><br/><span class="kw">let </span><font color="Maroon" title="c6">f</font> be    <a href="aofa_000.html#M1" title="AOFA_000:mode.1">ExecutionFunction</a> of <font color="Maroon" title="c1">A</font>,<font color="Maroon" title="c3">S</font>,<font color="Maroon" title="c4">T</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">  <a href="aofa_000.html#K20" title="AOFA_000:func.20">iteration-degree</a> (<font color="Maroon" title="c2">I</font>,<font color="Maroon" title="c5">s</font>,<font color="Maroon" title="c6">f</font>) <a href="xxreal_0.html#NR2" title="XXREAL_0:NR.2">&gt;=</a>  <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> </span><br/>











<div><a class="txt" onclick="hsNdiv(this)" href="javascript:()" title="139_1"><span class="kw">per </span></a><a class="txt" onmouseover="tooltip.show('hs',this)" onmouseout="tooltip.hide()" onclick="hs(this)" href="javascript:()"><span class="kw">cases </span></a><span class="hide"><a NAME="E1:139_1"/>
(  not <font color="Maroon" title="c6">f</font> <a href="aofa_000.html#R4" title="AOFA_000:pred.4">iteration_terminates_for</a> <font color="Maroon" title="c2">I</font>,<font color="Maroon" title="c5">s</font> or <font color="Maroon" title="c6">f</font> <a href="aofa_000.html#R4" title="AOFA_000:pred.4">iteration_terminates_for</a> <font color="Maroon" title="c2">I</font>,<font color="Maroon" title="c5">s</font> )
 </span>;<br/><div class="add"><div><a class="txt" onclick="hsNdiv(this)" href="javascript:()" title="139_1_1"><span class="kw">suppose </span></a><a NAME="E1:139_1_1"/>
 not <font color="Maroon" title="c6">f</font> <a href="aofa_000.html#R4" title="AOFA_000:pred.4">iteration_terminates_for</a> <font color="Maroon" title="c2">I</font>,<font color="Maroon" title="c5">s</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">  <a href="aofa_000.html#K20" title="AOFA_000:func.20">iteration-degree</a> (<font color="Maroon" title="c2">I</font>,<font color="Maroon" title="c5">s</font>,<font color="Maroon" title="c6">f</font>) <a href="xxreal_0.html#NR2" title="XXREAL_0:NR.2">&gt;=</a>  <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> </span><br/><div class="add"><span class="kw">hence </span><a NAME="E2:139_1_1"/>
 <a href="aofa_000.html#K20" title="AOFA_000:func.20">iteration-degree</a> (<font color="Maroon" title="c2">I</font>,<font color="Maroon" title="c5">s</font>,<font color="Maroon" title="c6">f</font>) <a href="xxreal_0.html#NR2" title="XXREAL_0:NR.2">&gt;=</a>  <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> 
 <span class="kw">by</span> <span class="lab"><a class="ref" href="aofa_000.html#D34" target="_self" onmouseover="rs('aofa_000/D34')" onmouseout="rh()">Def34</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><span class="kw">end;</span></div><div><a class="txt" onclick="hsNdiv(this)" href="javascript:()" title="139_1_2"><span class="kw">suppose </span></a><a NAME="E1:139_1_2"/>
<font color="Maroon" title="c6">f</font> <a href="aofa_000.html#R4" title="AOFA_000:pred.4">iteration_terminates_for</a> <font color="Maroon" title="c2">I</font>,<font color="Maroon" title="c5">s</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">  <a href="aofa_000.html#K20" title="AOFA_000:func.20">iteration-degree</a> (<font color="Maroon" title="c2">I</font>,<font color="Maroon" title="c5">s</font>,<font color="Maroon" title="c6">f</font>) <a href="xxreal_0.html#NR2" title="XXREAL_0:NR.2">&gt;=</a>  <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> </span><br/><div class="add"><span class="kw">then </span><span class="kw">consider </span><font color="Maroon" title="c7">r</font> being   non  <a href="xboole_0.html#V1" title="XBOOLE_0:attr.1">empty</a>   <a href="finseq_1.html#M2" title="FINSEQ_1:mode.2">FinSequence</a> of <font color="Maroon" title="c3">S</font><span class="kw"> such that </span><br/><a NAME="E3:139_1_2"/><span class="lab"><font color="Green" title="E86">A1</font></span>: 
 <a href="aofa_000.html#K20" title="AOFA_000:func.20">iteration-degree</a> (<font color="Maroon" title="c2">I</font>,<font color="Maroon" title="c5">s</font>,<font color="Maroon" title="c6">f</font>) <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <span class="p1">(<span class="default"><a href="finseq_1.html#K3" title="FINSEQ_1:func.3">len</a> <font color="Maroon" title="c7">r</font></span>)</span> <a href="xcmplx_0.html#K6" title="XCMPLX_0:func.6">-</a> 1
 <span class="kw">and </span><br/><a NAME="E4:139_1_2"/>
<font color="Maroon" title="c7">r</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> 1 <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c5">s</font>
 <span class="kw">and </span><br/><a NAME="E5:139_1_2"/>
<font color="Maroon" title="c7">r</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><a href="finseq_1.html#K3" title="FINSEQ_1:func.3">len</a> <font color="Maroon" title="c7">r</font></span>)</span> <a href="aofa_000.html#NR1" title="AOFA_000:NR.1">nin</a> <font color="Maroon" title="c4">T</font>
 <span class="kw">and </span><br/><a NAME="E6:139_1_2"/>
 for <font color="Olive" title="b1">i</font> being   <a href="ordinal1.html#NM6" title="ORDINAL1:NM.6">Nat</a>  st 1 <a href="xxreal_0.html#R1" title="XXREAL_0:pred.1">&lt;=</a> <font color="Olive" title="b1">i</font> &amp; <font color="Olive" title="b1">i</font> <a href="xxreal_0.html#NR3" title="XXREAL_0:NR.3">&lt;</a>  <a href="finseq_1.html#K3" title="FINSEQ_1:func.3">len</a> <font color="Maroon" title="c7">r</font> holds <br/>( <font color="Maroon" title="c7">r</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b1">i</font> <a href="tarski.html#R2" title="TARSKI:pred.2">in</a> <font color="Maroon" title="c4">T</font> &amp; <font color="Maroon" title="c7">r</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Olive" title="b1">i</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" title="c6">f</font> <a href="binop_1.html#K1" title="BINOP_1:func.1">.</a> (<span class="p1">(<span class="default"><font color="Maroon" title="c7">r</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b1">i</font></span>)</span>,<font color="Maroon" title="c2">I</font>) )
 <span class="kw">by</span> <span class="lab"><a class="ref" href="aofa_000.html#D34" target="_self" onmouseover="rs('aofa_000/D34')" onmouseout="rh()">Def34</a></span>;<br/><a NAME="E7:139_1_2"/>
 ex <font color="Olive" title="b1">i</font> being   <a href="ordinal1.html#NM6" title="ORDINAL1:NM.6">Nat</a> st  <a href="finseq_1.html#K3" title="FINSEQ_1:func.3">len</a> <font color="Maroon" title="c7">r</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b1">i</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1
 <span class="kw">by</span> <span class="lab"><a class="ref" href="nat_1.html#T6" onmouseover="rs('nat_1/T6')" onmouseout="rh()">NAT_1:6</a></span>;<br/><span class="kw">hence </span><a NAME="E8:139_1_2"/>
 <a href="aofa_000.html#K20" title="AOFA_000:func.20">iteration-degree</a> (<font color="Maroon" title="c2">I</font>,<font color="Maroon" title="c5">s</font>,<font color="Maroon" title="c6">f</font>) <a href="xxreal_0.html#NR2" title="XXREAL_0:NR.2">&gt;=</a>  <a href="numbers.html#K5" title="NUMBERS:func.5">0</a> 
 <span class="kw">by</span> <span class="lab"><a class="txt" href="#E3:139_1_2"><span class="lab"><font color="Green" title="E86">A1</font></span></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><span class="kw">end;</span></div></div><span class="kw">end;</span></div>

</div>
