<?xml version="1.0"?>
<div><span class="kw">theorem </span><span class="lab"><font color="Green" title="E80">Th94</font></span>: <a NAME="T94"><span class="comment"><font color="firebrick">:: AOFA_A01:94</font></span><br/></a><div class="add"> 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="aofa_a00.html#V13" title="AOFA_A00:attr.13">1-1-connectives</a>   <a href="aofa_a00.html#V16" title="AOFA_A00:attr.16">bool-correct</a>  4,1 <a href="aofa_a00.html#V18" title="AOFA_A00:attr.18">integer</a>  11,1,1 <a href="aofa_a00.html#V21" title="AOFA_A00:attr.21">-array</a>  11 <a href="aofa_a00.html#V23" title="AOFA_A00:attr.23">array-correct</a>   <a href="aofa_a00.html#L6" title="AOFA_A00:struct.6">BoolSignature</a> <br/>  for <font color="Olive" title="b2">X</font> being  <a href="relat_1.html#V2" title="RELAT_1:attr.2">V3</a>() <a href="pboole.html#NM1" title="PBOOLE:NM.1">ManySortedSet</a> of  the <a href="struct_0.html#U1" title="STRUCT_0:sel.1">carrier</a> of <font color="Olive" title="b1">S</font><br/>  for <font color="Olive" title="b3">T</font> being   <a href="msualg_1.html#V4" title="MSUALG_1:attr.4">non-empty</a>  <font color="Olive">b<sub>2</sub></font>,<font color="Olive">b<sub>1</sub></font> <a href="msafree4.html#V5" title="MSAFREE4:attr.5">-terms</a>   <a href="msafree4.html#V6" title="MSAFREE4:attr.6">all_vars_including</a>   <a href="msafree4.html#V7" title="MSAFREE4:attr.7">inheriting_operations</a>   <a href="msafree4.html#V8" title="MSAFREE4:attr.8">free_in_itself</a>   <a href="aofa_a00.html#V3" title="AOFA_A00:attr.3">vf-free</a>   <a href="aofa_a01.html#V6" title="AOFA_A01:attr.6">integer-array</a>   <a href="aofa_a00.html#L1" title="AOFA_A00:struct.1">VarMSAlgebra</a> over <font color="Olive" title="b1">S</font><br/>  for <font color="Olive" title="b4">C</font> being   <a href="aofa_a00.html#V17" title="AOFA_A00:attr.17">bool-correct</a>  4,1 <a href="aofa_a00.html#V20" title="AOFA_A00:attr.20">integer</a>  11,1,1 <a href="aofa_a00.html#V22" title="AOFA_A00:attr.22">-array</a>  <a href="msafree4.html#NM2" title="MSAFREE4:NM.2">image</a> of <font color="Olive" title="b3">T</font><br/>  for <font color="Olive" title="b5">G</font> being   <a href="aofa_a01.html#V4" title="AOFA_A01:attr.4">basic</a>   <a href="aofa_a00.html#L4" title="AOFA_A00:struct.4">GeneratorSystem</a> over <font color="Olive" title="b1">S</font>,<font color="Olive" title="b2">X</font>,<font color="Olive" title="b3">T</font><br/>  for <font color="Olive" title="b6">I</font> being   <a href="aofa_a00.html#V19" title="AOFA_A00:attr.19">integer</a>  <a href="msualg_1.html#NM1" title="MSUALG_1:NM.1">SortSymbol</a> of <font color="Olive" title="b1">S</font><br/>  for <font color="Olive" title="b7">i</font> being   <a href="aofa_a01.html#V3" title="AOFA_A01:attr.3">pure</a>   <a href="msafree4.html#M1" title="MSAFREE4:mode.1">Element</a> of  the <a href="aofa_a00.html#U4" title="AOFA_A00:sel.4">generators</a> of <font color="Olive" title="b5">G</font> <a href="msafree4.html#K1" title="MSAFREE4:func.1">.</a> <font color="Olive" title="b6">I</font><br/>  for <font color="Olive" title="b8">b</font> being   <a href="aofa_a01.html#V3" title="AOFA_A01:attr.3">pure</a>   <a href="msafree4.html#M1" title="MSAFREE4:mode.1">Element</a> of  the <a href="aofa_a00.html#U4" title="AOFA_A00:sel.4">generators</a> of <font color="Olive" title="b5">G</font> <a href="msafree4.html#K1" title="MSAFREE4:func.1">.</a>  the <a href="aofa_a00.html#U8" title="AOFA_A00:sel.8">bool-sort</a> of <font color="Olive" title="b1">S</font><br/>  for <font color="Olive" title="b9">A</font> being   <a href="aofa_a01.html#V5" title="AOFA_A01:attr.5">elementary</a>  <a href="aofa_a00.html#NM5" title="AOFA_A00:NM.5">IfWhileAlgebra</a> of  the <a href="aofa_a00.html#U4" title="AOFA_A00:sel.4">generators</a> of <font color="Olive" title="b5">G</font><br/>  for <font color="Olive" title="b10">f</font> being    <a href="aofa_000.html#M1" title="AOFA_000:mode.1">ExecutionFunction</a> of <font color="Olive" title="b9">A</font>,<font color="Olive" title="b4">C</font> <a href="aofa_a00.html#K12" title="AOFA_A00:func.12">-States</a>  the <a href="aofa_a00.html#U4" title="AOFA_A00:sel.4">generators</a> of <font color="Olive" title="b5">G</font>,<span class="p1">(<span class="default"><a href="aofa_a01.html#K2" title="AOFA_A01:func.2">\false</a> <font color="Olive" title="b4">C</font></span>)</span> <a href="aofa_a00.html#K13" title="AOFA_A00:func.13">-States</a> ( the <a href="aofa_a00.html#U4" title="AOFA_A00:sel.4">generators</a> of <font color="Olive" title="b5">G</font>,<font color="Olive" title="b8">b</font>)  st <font color="Olive" title="b10">f</font> <a href="tarski.html#R2" title="TARSKI:pred.2">in</a> <font color="Olive" title="b4">C</font> <a href="aofa_a00.html#K19" title="AOFA_A00:func.19">-Execution</a> (<font color="Olive" title="b9">A</font>,<font color="Olive" title="b8">b</font>,<span class="p1">(<span class="default"><a href="aofa_a01.html#K2" title="AOFA_A01:func.2">\false</a> <font color="Olive" title="b4">C</font></span>)</span>) &amp; <font color="Olive" title="b5">G</font> is <font color="Olive" title="b4">C</font> <a href="aofa_a00.html#V11" title="AOFA_A00:attr.11">-supported</a>  holds <br/> for <font color="Olive" title="b11">t0</font>, <font color="Olive" title="b12">t1</font> being   <a href="msualg_6.html#NM1" title="MSUALG_6:NM.1">Element</a> of <font color="Olive" title="b3">T</font>,<font color="Olive" title="b6">I</font><br/>  for <font color="Olive" title="b13">J</font> being   <a href="aofa_000.html#NM2" title="AOFA_000:NM.2">Algorithm</a> of <font color="Olive" title="b9">A</font><br/>  for <font color="Olive" title="b14">P</font> being    <a href="hidden.html#M2" title="HIDDEN:mode.2">set</a>   st <font color="Olive" title="b14">P</font> <a href="aofa_000.html#R7" title="AOFA_000:pred.7">is_invariant_wrt</a> <font color="Olive" title="b7">i</font> <a href="aofa_a00.html#K11" title="AOFA_A00:func.11">:=</a> (<font color="Olive" title="b11">t0</font>,<font color="Olive" title="b9">A</font>),<font color="Olive" title="b10">f</font> &amp; <font color="Olive" title="b14">P</font> <a href="aofa_000.html#R7" title="AOFA_000:pred.7">is_invariant_wrt</a> <font color="Olive" title="b8">b</font> <a href="aofa_a01.html#K6" title="AOFA_A01:func.6">gt</a> (<font color="Olive" title="b12">t1</font>,<span class="p1">(<span class="default"><a href="aofa_a01.html#K4" title="AOFA_A01:func.4">@</a> <font color="Olive" title="b7">i</font></span>)</span>,<font color="Olive" title="b9">A</font>),<font color="Olive" title="b10">f</font> &amp; <font color="Olive" title="b14">P</font> <a href="aofa_000.html#R7" title="AOFA_000:pred.7">is_invariant_wrt</a> <font color="Olive" title="b7">i</font> <a href="aofa_a00.html#K11" title="AOFA_A00:func.11">:=</a> (<span class="p1">(<span class="default"><span class="p2">(<span class="default"><a href="aofa_a01.html#K4" title="AOFA_A01:func.4">@</a> <font color="Olive" title="b7">i</font></span>)</span> <a href="aofa_a00.html#K29" title="AOFA_A00:func.29">+</a> <span class="p2">(<span class="default"><a href="aofa_a00.html#K27" title="AOFA_A00:func.27">\1</a> (<font color="Olive" title="b3">T</font>,<font color="Olive" title="b6">I</font>)</span>)</span></span>)</span>,<font color="Olive" title="b9">A</font>),<font color="Olive" title="b10">f</font> &amp; <font color="Olive" title="b14">P</font> <a href="aofa_000.html#R7" title="AOFA_000:pred.7">is_invariant_wrt</a> <font color="Olive" title="b13">J</font>,<font color="Olive" title="b10">f</font> &amp; <font color="Olive" title="b13">J</font> <a href="aofa_000.html#R6" title="AOFA_000:pred.6">is_terminating_wrt</a> <font color="Olive" title="b10">f</font>,<font color="Olive" title="b14">P</font> &amp; (  for <font color="Olive" title="b15">s</font> being    <a href="subset_1.html#M2" title="SUBSET_1:mode.2">Element</a> of <font color="Olive" title="b4">C</font> <a href="aofa_a00.html#K12" title="AOFA_A00:func.12">-States</a>  the <a href="aofa_a00.html#U4" title="AOFA_A00:sel.4">generators</a> of <font color="Olive" title="b5">G</font> holds <br/> ( <span class="p1">(<span class="default"><span class="p2">(<span class="default"><font color="Olive" title="b10">f</font> <a href="aofa_a01.html#K3" title="AOFA_A01:func.3">.</a> (<font color="Olive" title="b15">s</font>,<font color="Olive" title="b13">J</font>)</span>)</span> <a href="msafree4.html#K1" title="MSAFREE4:func.1">.</a> <font color="Olive" title="b6">I</font></span>)</span> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b7">i</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <span class="p1">(<span class="default"><font color="Olive" title="b15">s</font> <a href="msafree4.html#K1" title="MSAFREE4:func.1">.</a> <font color="Olive" title="b6">I</font></span>)</span> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b7">i</font> &amp; <span class="p1">(<span class="default"><span class="p2">(<span class="default"><font color="Olive" title="b10">f</font> <a href="aofa_a01.html#K3" title="AOFA_A01:func.3">.</a> (<font color="Olive" title="b15">s</font>,<span class="p3">(<span class="default"><font color="Olive" title="b8">b</font> <a href="aofa_a01.html#K6" title="AOFA_A01:func.6">gt</a> (<font color="Olive" title="b12">t1</font>,<span class="p4">(<span class="default"><a href="aofa_a01.html#K4" title="AOFA_A01:func.4">@</a> <font color="Olive" title="b7">i</font></span>)</span>,<font color="Olive" title="b9">A</font>)</span>)</span>)</span>)</span> <a href="msafree4.html#K1" title="MSAFREE4:func.1">.</a> <font color="Olive" title="b6">I</font></span>)</span> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b7">i</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <span class="p1">(<span class="default"><font color="Olive" title="b15">s</font> <a href="msafree4.html#K1" title="MSAFREE4:func.1">.</a> <font color="Olive" title="b6">I</font></span>)</span> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b7">i</font> &amp; <font color="Olive" title="b12">t1</font> <a href="aofa_a00.html#K14" title="AOFA_A00:func.14">value_at</a> (<font color="Olive" title="b4">C</font>,<span class="p1">(<span class="default"><font color="Olive" title="b10">f</font> <a href="aofa_a01.html#K3" title="AOFA_A01:func.3">.</a> (<font color="Olive" title="b15">s</font>,<span class="p2">(<span class="default"><font color="Olive" title="b8">b</font> <a href="aofa_a01.html#K6" title="AOFA_A01:func.6">gt</a> (<font color="Olive" title="b12">t1</font>,<span class="p3">(<span class="default"><a href="aofa_a01.html#K4" title="AOFA_A01:func.4">@</a> <font color="Olive" title="b7">i</font></span>)</span>,<font color="Olive" title="b9">A</font>)</span>)</span>)</span>)</span>) <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b12">t1</font> <a href="aofa_a00.html#K14" title="AOFA_A00:func.14">value_at</a> (<font color="Olive" title="b4">C</font>,<font color="Olive" title="b15">s</font>) &amp; <font color="Olive" title="b12">t1</font> <a href="aofa_a00.html#K14" title="AOFA_A00:func.14">value_at</a> (<font color="Olive" title="b4">C</font>,<span class="p1">(<span class="default"><font color="Olive" title="b10">f</font> <a href="aofa_a01.html#K3" title="AOFA_A01:func.3">.</a> (<font color="Olive" title="b15">s</font>,<span class="p2">(<span class="default"><font color="Olive" title="b13">J</font> <a href="aofa_000.html#K13" title="AOFA_000:func.13">\;</a> <span class="p3">(<span class="default"><font color="Olive" title="b7">i</font> <a href="aofa_a00.html#K11" title="AOFA_A00:func.11">:=</a> (<span class="p4">(<span class="default"><span class="p5">(<span class="default"><a href="aofa_a01.html#K4" title="AOFA_A01:func.4">@</a> <font color="Olive" title="b7">i</font></span>)</span> <a href="aofa_a00.html#K29" title="AOFA_A00:func.29">+</a> <span class="p5">(<span class="default"><a href="aofa_a00.html#K27" title="AOFA_A00:func.27">\1</a> (<font color="Olive" title="b3">T</font>,<font color="Olive" title="b6">I</font>)</span>)</span></span>)</span>,<font color="Olive" title="b9">A</font>)</span>)</span></span>)</span>)</span>)</span>) <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b12">t1</font> <a href="aofa_a00.html#K14" title="AOFA_A00:func.14">value_at</a> (<font color="Olive" title="b4">C</font>,<font color="Olive" title="b15">s</font>) ) ) holds <br/> <a href="aofa_000.html#K17" title="AOFA_000:func.17">for-do</a> (<span class="p1">(<span class="default"><font color="Olive" title="b7">i</font> <a href="aofa_a00.html#K11" title="AOFA_A00:func.11">:=</a> (<font color="Olive" title="b11">t0</font>,<font color="Olive" title="b9">A</font>)</span>)</span>,<span class="p1">(<span class="default"><font color="Olive" title="b8">b</font> <a href="aofa_a01.html#K6" title="AOFA_A01:func.6">gt</a> (<font color="Olive" title="b12">t1</font>,<span class="p2">(<span class="default"><a href="aofa_a01.html#K4" title="AOFA_A01:func.4">@</a> <font color="Olive" title="b7">i</font></span>)</span>,<font color="Olive" title="b9">A</font>)</span>)</span>,<span class="p1">(<span class="default"><font color="Olive" title="b7">i</font> <a href="aofa_a00.html#K11" title="AOFA_A00:func.11">:=</a> (<span class="p2">(<span class="default"><span class="p3">(<span class="default"><a href="aofa_a01.html#K4" title="AOFA_A01:func.4">@</a> <font color="Olive" title="b7">i</font></span>)</span> <a href="aofa_a00.html#K29" title="AOFA_A00:func.29">+</a> <span class="p3">(<span class="default"><a href="aofa_a00.html#K27" title="AOFA_A00:func.27">\1</a> (<font color="Olive" title="b3">T</font>,<font color="Olive" title="b6">I</font>)</span>)</span></span>)</span>,<font color="Olive" title="b9">A</font>)</span>)</span>,<font color="Olive" title="b13">J</font>) <a href="aofa_000.html#R6" title="AOFA_000:pred.6">is_terminating_wrt</a> <font color="Olive" title="b10">f</font>,<font color="Olive" title="b14">P</font></div></div>
