<?xml version="1.0"?>
<div>:: <span class="kw">deftheorem </span><span class="lab"><font color="Green" title="E31">defENC</font></span>   defines <a href="aescip_1.html#K16" title="AESCIP_1:func.16">AES-ENC</a> <a onclick="hs(this)" href="javascript:()">AESCIP_1:def 14 : <br/></a><span> for <font color="Olive" title="b1">SBT</font> being   <a href="funct_2.html#NM2" title="FUNCT_2:NM.2">Permutation</a> of <span class="p1">(<span class="default">8 <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><br/>  for <font color="Olive" title="b2">MCFunc</font> being   <a href="funct_2.html#NM2" title="FUNCT_2:NM.2">Permutation</a> of <span class="p1">(<span class="default">4 <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <span class="p2">(<span class="default">4 <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <span class="p3">(<span class="default">8 <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></span>)</span></span>)</span><br/>  for <font color="Olive" title="b3">m</font> being   <a href="ordinal1.html#NM6" title="ORDINAL1:NM.6">Nat</a><br/>  for <font color="Olive" title="b4">text</font> being    <a href="finseq_2.html#M2" title="FINSEQ_2:mode.2">Element</a> of 4 <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <span class="p1">(<span class="default">4 <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <span class="p2">(<span class="default">8 <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></span>)</span><br/>  for <font color="Olive" title="b5">Key</font> being    <a href="finseq_2.html#M2" title="FINSEQ_2:mode.2">Element</a> of <font color="Olive" title="b3">m</font> <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <span class="p1">(<span class="default">4 <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <span class="p2">(<span class="default">8 <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></span>)</span><br/>  for <font color="Olive">b<sub>6</sub></font> being    <a href="finseq_2.html#M2" title="FINSEQ_2:mode.2">Element</a> of 4 <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <span class="p1">(<span class="default">4 <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <span class="p2">(<span class="default">8 <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></span>)</span> holds <br/> ( <font color="Olive">b<sub>6</sub></font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a>  <a href="aescip_1.html#K16" title="AESCIP_1:func.16">AES-ENC</a> (<font color="Olive" title="b1">SBT</font>,<font color="Olive" title="b2">MCFunc</font>,<font color="Olive" title="b4">text</font>,<font color="Olive" title="b5">Key</font>) iff  ex <font color="Olive" title="b7">seq</font> being    <a href="finseq_1.html#M2" title="FINSEQ_1:mode.2">FinSequence</a> of 4 <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <span class="p1">(<span class="default">4 <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <span class="p2">(<span class="default">8 <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></span>)</span> st <br/>(  <a href="finseq_1.html#K3" title="FINSEQ_1:func.3">len</a> <font color="Olive" title="b7">seq</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <span class="p1">(<span class="default">7 <a href="xcmplx_0.html#K2" title="XCMPLX_0:func.2">+</a> <font color="Olive" title="b3">m</font></span>)</span> <a href="xcmplx_0.html#K6" title="XCMPLX_0:func.6">-</a> 1 &amp;  ex <font color="Olive" title="b8">Keyi1</font> being    <a href="finseq_2.html#M2" title="FINSEQ_2:mode.2">Element</a> of 4 <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <span class="p1">(<span class="default">4 <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <span class="p2">(<span class="default">8 <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></span>)</span> st <br/>( <font color="Olive" title="b8">Keyi1</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <span class="p1">(<span class="default"><span class="p2">(<span class="default"><a href="aescip_1.html#K15" title="AESCIP_1:func.15">KeyExpansion</a> (<font color="Olive" title="b1">SBT</font>,<font color="Olive" title="b3">m</font>)</span>)</span> <a href="aescip_1.html#K1" title="AESCIP_1:func.1">.</a> <font color="Olive" title="b5">Key</font></span>)</span> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> 1 &amp; <font color="Olive" title="b7">seq</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> 1 <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <a href="aescip_1.html#K8" title="AESCIP_1:func.8">AddRoundKey</a> <a href="aescip_1.html#K2" title="AESCIP_1:func.2">.</a> (<font color="Olive" title="b4">text</font>,<font color="Olive" title="b8">Keyi1</font>) ) &amp; (  for <font color="Olive" title="b8">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="b8">i</font> &amp; <font color="Olive" title="b8">i</font> <a href="xxreal_0.html#NR3" title="XXREAL_0:NR.3">&lt;</a> <span class="p1">(<span class="default">7 <a href="xcmplx_0.html#K2" title="XCMPLX_0:func.2">+</a> <font color="Olive" title="b3">m</font></span>)</span> <a href="xcmplx_0.html#K6" title="XCMPLX_0:func.6">-</a> 1 holds <br/> ex <font color="Olive" title="b9">Keyi</font> being    <a href="finseq_2.html#M2" title="FINSEQ_2:mode.2">Element</a> of 4 <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <span class="p1">(<span class="default">4 <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <span class="p2">(<span class="default">8 <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></span>)</span> st <br/>( <font color="Olive" title="b9">Keyi</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <span class="p1">(<span class="default"><span class="p2">(<span class="default"><a href="aescip_1.html#K15" title="AESCIP_1:func.15">KeyExpansion</a> (<font color="Olive" title="b1">SBT</font>,<font color="Olive" title="b3">m</font>)</span>)</span> <a href="aescip_1.html#K1" title="AESCIP_1:func.1">.</a> <font color="Olive" title="b5">Key</font></span>)</span> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Olive" title="b8">i</font> <a href="nat_1.html#K1" title="NAT_1:func.1">+</a> 1</span>)</span> &amp; <font color="Olive" title="b7">seq</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default"><font color="Olive" title="b8">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> <a href="aescip_1.html#K8" title="AESCIP_1:func.8">AddRoundKey</a> <a href="binop_1.html#K1" title="BINOP_1:func.1">.</a> (<span class="p1">(<span class="default"><span class="p2">(<span class="default"><span class="p3">(<span class="default"><font color="Olive" title="b2">MCFunc</font> <a href="partfun1.html#K1" title="PARTFUN1:func.1">*</a> <a href="aescip_1.html#K6" title="AESCIP_1:func.6">ShiftRows</a></span>)</span> <a href="partfun1.html#K1" title="PARTFUN1:func.1">*</a> <span class="p3">(<span class="default"><a href="aescip_1.html#K4" title="AESCIP_1:func.4">SubBytes</a> <font color="Olive" title="b1">SBT</font></span>)</span></span>)</span> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p2">(<span class="default"><font color="Olive" title="b7">seq</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b8">i</font></span>)</span></span>)</span>,<font color="Olive" title="b9">Keyi</font>) ) ) &amp;  ex <font color="Olive" title="b8">KeyNr</font> being    <a href="finseq_2.html#M2" title="FINSEQ_2:mode.2">Element</a> of 4 <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <span class="p1">(<span class="default">4 <a href="finseq_2.html#K4" title="FINSEQ_2:func.4">-tuples_on</a> <span class="p2">(<span class="default">8 <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></span>)</span> st <br/>( <font color="Olive" title="b8">KeyNr</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <span class="p1">(<span class="default"><span class="p2">(<span class="default"><a href="aescip_1.html#K15" title="AESCIP_1:func.15">KeyExpansion</a> (<font color="Olive" title="b1">SBT</font>,<font color="Olive" title="b3">m</font>)</span>)</span> <a href="aescip_1.html#K1" title="AESCIP_1:func.1">.</a> <font color="Olive" title="b5">Key</font></span>)</span> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p1">(<span class="default">7 <a href="xcmplx_0.html#K2" title="XCMPLX_0:func.2">+</a> <font color="Olive" title="b3">m</font></span>)</span> &amp; <font color="Olive">b<sub>6</sub></font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <a href="aescip_1.html#K8" title="AESCIP_1:func.8">AddRoundKey</a> <a href="binop_1.html#K1" title="BINOP_1:func.1">.</a> (<span class="p1">(<span class="default"><span class="p2">(<span class="default"><a href="aescip_1.html#K6" title="AESCIP_1:func.6">ShiftRows</a> <a href="partfun1.html#K1" title="PARTFUN1:func.1">*</a> <span class="p3">(<span class="default"><a href="aescip_1.html#K4" title="AESCIP_1:func.4">SubBytes</a> <font color="Olive" title="b1">SBT</font></span>)</span></span>)</span> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p2">(<span class="default"><font color="Olive" title="b7">seq</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <span class="p3">(<span class="default"><span class="p4">(<span class="default">7 <a href="xcmplx_0.html#K2" title="XCMPLX_0:func.2">+</a> <font color="Olive" title="b3">m</font></span>)</span> <a href="xcmplx_0.html#K6" title="XCMPLX_0:func.6">-</a> 1</span>)</span></span>)</span></span>)</span>,<font color="Olive" title="b8">KeyNr</font>) ) ) );<br/></span></div>
