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

<span class="kw">defpred </span><font color="Maroon">S<sub>1</sub></font>[   <a href="hidden.html#M1" title="HIDDEN:mode.1">object</a> ,   <a href="hidden.html#M1" title="HIDDEN:mode.1">object</a> ] <span class="kw">means </span>$2 <a href="hidden.html#R2" title="HIDDEN:pred.2">in</a> <font color="Maroon" title="c2">B</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> $1;<br/>
<a NAME="E1:37_1_1"/><span class="lab"><font color="Green" title="E18">A1</font></span>: 
 for <font color="Olive" title="b1">x</font> being    <a href="hidden.html#M1" title="HIDDEN:mode.1">object</a>   st <font color="Olive" title="b1">x</font> <a href="hidden.html#R2" title="HIDDEN:pred.2">in</a> <font color="Maroon" title="c1">J</font> holds <br/> ex <font color="Olive" title="b2">y</font> being    <a href="hidden.html#M1" title="HIDDEN:mode.1">object</a>  st <font color="Maroon">S<sub>1</sub></font>[<font color="Olive" title="b1">x</font>,<font color="Olive" title="b2">y</font>]
 
<span class="kw">by</span> <span class="lab"><a class="ref" href="xboole_0.html#D1" onmouseover="rs('xboole_0/D1')" onmouseout="rh()">XBOOLE_0:def 1</a></span>;<br/>
<span class="kw">consider </span><font color="Maroon" title="c3">f</font> being   <a href="funct_1.html#NM1" title="FUNCT_1:NM.1">Function</a><span class="kw"> such that </span><br/><a NAME="E3:37_1_1"/><span class="lab"><font color="Green" title="E19">A2</font></span>: 
(  <a href="relat_1.html#NK1" title="RELAT_1:NK.1">dom</a> <font color="Maroon" title="c3">f</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c1">J</font> &amp; (  for <font color="Olive" title="b1">x</font> being    <a href="hidden.html#M1" title="HIDDEN:mode.1">object</a>   st <font color="Olive" title="b1">x</font> <a href="hidden.html#R2" title="HIDDEN:pred.2">in</a> <font color="Maroon" title="c1">J</font> holds <br/><font color="Maroon">S<sub>1</sub></font>[<font color="Olive" title="b1">x</font>,<font color="Maroon" title="c3">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b1">x</font>] ) )
 <span class="kw">from</span> <span class="lab"><a class="ref" href="classes1.html#S1" onmouseover="rs('classes1/S1')" onmouseout="rh()">CLASSES1:sch 1</a>(<a class="txt" href="#E1:37_1_1"><span class="lab"><font color="Green" title="E18">A1</font></span></a>);<br/></span>
<span class="kw">deffunc </span><font color="Maroon">H<sub>1</sub></font>(   <a href="hidden.html#M1" title="HIDDEN:mode.1">object</a> ) <span class="kw">-&gt; </span>   <a href="hidden.html#M2" title="HIDDEN:mode.2">set</a>  = <span class="p1">(<span class="default"><a href="finseq_1.html#K6" title="FINSEQ_1:func.6">&lt;*&gt;</a> <span class="p2">(<span class="default"><font color="Maroon" title="c2">B</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> $1</span>)</span></span>)</span> <a href="funcop_1.html#K17" title="FUNCOP_1:func.17">.--&gt;</a> <span class="p1">(<span class="default"><font color="Maroon" title="c3">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> $1</span>)</span>;<br/>
<span class="kw">consider </span><font color="Maroon" title="c4">F</font> being   <a href="funct_1.html#NM1" title="FUNCT_1:NM.1">Function</a><span class="kw"> such that </span><br/><a NAME="E5:37_1_1"/><span class="lab"><font color="Green" title="E20">A3</font></span>: 
(  <a href="relat_1.html#NK1" title="RELAT_1:NK.1">dom</a> <font color="Maroon" title="c4">F</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c1">J</font> &amp; (  for <font color="Olive" title="b1">x</font> being    <a href="hidden.html#M1" title="HIDDEN:mode.1">object</a>   st <font color="Olive" title="b1">x</font> <a href="hidden.html#R2" title="HIDDEN:pred.2">in</a> <font color="Maroon" title="c1">J</font> holds <br/><font color="Maroon" title="c4">F</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b1">x</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon">H<sub>1</sub></font>(<font color="Olive" title="b1">x</font>) ) )
 <span class="kw">from</span> <span class="lab"><a class="ref" href="funct_1.html#S3" onmouseover="rs('funct_1/S3')" onmouseout="rh()">FUNCT_1:sch 3</a>();<br/></span>
<span class="kw">reconsider </span><font color="Maroon" title="c5">F</font> = <font color="Maroon" title="c4">F</font> as   <a href="pboole.html#NM1" title="PBOOLE:NM.1">ManySortedSet</a> of <font color="Maroon" title="c1">J</font> <span class="kw">by</span> <span class="lab"><a class="txt" href="#E5:37_1_1"><span class="lab"><font color="Green" title="E20">A3</font></span></a>, <a class="ref" href="partfun1.html#D2" onmouseover="rs('partfun1/D2')" onmouseout="rh()">PARTFUN1:def 2</a>, <a class="ref" href="relat_1.html#D18" onmouseover="rs('relat_1/D18')" onmouseout="rh()">RELAT_1:def 18</a></span>;<br/>
<a NAME="E7:37_1_1"/>
 for <font color="Olive" title="b1">x</font> being    <a href="hidden.html#M1" title="HIDDEN:mode.1">object</a>   st <font color="Olive" title="b1">x</font> <a href="hidden.html#R2" title="HIDDEN:pred.2">in</a>  <a href="relat_1.html#NK1" title="RELAT_1:NK.1">dom</a> <font color="Maroon" title="c5">F</font> holds <br/><font color="Maroon" title="c5">F</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b1">x</font> is   <a href="funct_1.html#NM1" title="FUNCT_1:NM.1">Function</a>
 
<div><a class="txt" onmouseover="tooltip.show('hs2',this)" onmouseout="tooltip.hide()" onclick="hs2(this)" href="javascript:()" title="37_1_1_1"><span class="kw">proof </span></a><div class="add">

<span class="kw">let </span><font color="Maroon" title="c6">x</font> be    <a href="hidden.html#M1" title="HIDDEN:mode.1">object</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"> ( <font color="Maroon" title="c6">x</font> <a href="hidden.html#R2" title="HIDDEN:pred.2">in</a>  <a href="relat_1.html#NK1" title="RELAT_1:NK.1">dom</a> <font color="Maroon" title="c5">F</font> implies <font color="Maroon" title="c5">F</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c6">x</font> is   <a href="funct_1.html#NM1" title="FUNCT_1:NM.1">Function</a> )</span><br/>

<span class="kw">assume </span><a NAME="E1:37_1_1_1"/>
<font color="Maroon" title="c6">x</font> <a href="hidden.html#R2" title="HIDDEN:pred.2">in</a>  <a href="relat_1.html#NK1" title="RELAT_1:NK.1">dom</a> <font color="Maroon" title="c5">F</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"> <font color="Maroon" title="c5">F</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c6">x</font> is   <a href="funct_1.html#NM1" title="FUNCT_1:NM.1">Function</a></span><br/>

<a NAME="E2:37_1_1_1"/><span class="kw">then </span>
<font color="Maroon" title="c5">F</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c6">x</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <span class="p1">(<span class="default"><a href="finseq_1.html#K6" title="FINSEQ_1:func.6">&lt;*&gt;</a> <span class="p2">(<span class="default"><font color="Maroon" title="c2">B</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c6">x</font></span>)</span></span>)</span> <a href="funcop_1.html#K17" title="FUNCOP_1:func.17">.--&gt;</a> <span class="p1">(<span class="default"><font color="Maroon" title="c3">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c6">x</font></span>)</span>
 
<span class="kw">by</span> <span class="lab"><a class="txt" href="#E5:37_1_1"><span class="lab"><font color="Green" title="E20">A3</font></span></a></span>;<br/>
<span class="kw">hence </span><a NAME="E3:37_1_1_1"/>
<font color="Maroon" title="c5">F</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c6">x</font> is   <a href="funct_1.html#NM1" title="FUNCT_1:NM.1">Function</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"> verum</span><br/>


</div><span class="kw">end;</span></div>
<span class="kw">then </span><span class="kw">reconsider </span><font color="Maroon" title="c6">F</font> = <font color="Maroon" title="c5">F</font> as   <a href="pboole.html#NM2" title="PBOOLE:NM.2">ManySortedFunction</a> of <font color="Maroon" title="c1">J</font> <span class="kw">by</span> <span class="lab"><a class="ref" href="funcop_1.html#D6" onmouseover="rs('funcop_1/D6')" onmouseout="rh()">FUNCOP_1:def 6</a></span>;<br/>
<span class="kw">take </span>
<font color="Maroon" title="c6">F</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">j</font> being    <a href="subset_1.html#M1" title="SUBSET_1:mode.1">Element</a> of <font color="Maroon" title="c1">J</font> holds  <font color="Maroon" title="c6">F</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b1">j</font> is   non  <a href="xboole_0.html#V1" title="XBOOLE_0:attr.1">empty</a>   <a href="margrel1.html#V2" title="MARGREL1:attr.2">homogeneous</a>   <a href="margrel1.html#V3" title="MARGREL1:attr.3">quasi_total</a>  <a href="partfun1.html#NM1" title="PARTFUN1:NM.1">PartFunc</a> of <span class="p1">(<span class="default"><span class="p2">(<span class="default"><font color="Maroon" title="c2">B</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b1">j</font></span>)</span> <a href="finseq_2.html#K3" title="FINSEQ_2:func.3">*</a></span>)</span>,<span class="p1">(<span class="default"><font color="Maroon" title="c2">B</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Olive" title="b1">j</font></span>)</span></span><br/>

<span class="kw">let </span><font color="Maroon" title="c7">j</font> be    <a href="subset_1.html#M1" title="SUBSET_1:mode.1">Element</a> of <font color="Maroon" title="c1">J</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"> <font color="Maroon" title="c6">F</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c7">j</font> is   non  <a href="xboole_0.html#V1" title="XBOOLE_0:attr.1">empty</a>   <a href="margrel1.html#V2" title="MARGREL1:attr.2">homogeneous</a>   <a href="margrel1.html#V3" title="MARGREL1:attr.3">quasi_total</a>  <a href="partfun1.html#NM1" title="PARTFUN1:NM.1">PartFunc</a> of <span class="p1">(<span class="default"><span class="p2">(<span class="default"><font color="Maroon" title="c2">B</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c7">j</font></span>)</span> <a href="finseq_2.html#K3" title="FINSEQ_2:func.3">*</a></span>)</span>,<span class="p1">(<span class="default"><font color="Maroon" title="c2">B</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c7">j</font></span>)</span></span><br/>

<span class="kw">reconsider </span><font color="Maroon" title="c8">b</font> = <font color="Maroon" title="c3">f</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c7">j</font> as    <a href="subset_1.html#M1" title="SUBSET_1:mode.1">Element</a> of <font color="Maroon" title="c2">B</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c7">j</font> <span class="kw">by</span> <span class="lab"><a class="txt" href="#E3:37_1_1"><span class="lab"><font color="Green" title="E19">A2</font></span></a></span>;<br/>
<a NAME="E10:37_1_1"/>
<font color="Maroon" title="c6">F</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c7">j</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <span class="p1">(<span class="default"><a href="finseq_1.html#K6" title="FINSEQ_1:func.6">&lt;*&gt;</a> <span class="p2">(<span class="default"><font color="Maroon" title="c2">B</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c7">j</font></span>)</span></span>)</span> <a href="funcop_1.html#K17" title="FUNCOP_1:func.17">.--&gt;</a> <font color="Maroon" title="c8">b</font>
 
<span class="kw">by</span> <span class="lab"><a class="txt" href="#E5:37_1_1"><span class="lab"><font color="Green" title="E20">A3</font></span></a></span>;<br/>
<span class="kw">hence </span><a NAME="E11:37_1_1"/>
<font color="Maroon" title="c6">F</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c7">j</font> is   non  <a href="xboole_0.html#V1" title="XBOOLE_0:attr.1">empty</a>   <a href="margrel1.html#V2" title="MARGREL1:attr.2">homogeneous</a>   <a href="margrel1.html#V3" title="MARGREL1:attr.3">quasi_total</a>  <a href="partfun1.html#NM1" title="PARTFUN1:NM.1">PartFunc</a> of <span class="p1">(<span class="default"><span class="p2">(<span class="default"><font color="Maroon" title="c2">B</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c7">j</font></span>)</span> <a href="finseq_2.html#K3" title="FINSEQ_2:func.3">*</a></span>)</span>,<span class="p1">(<span class="default"><font color="Maroon" title="c2">B</font> <a href="funct_1.html#K1" title="FUNCT_1:func.1">.</a> <font color="Maroon" title="c7">j</font></span>)</span>
 <span class="kw">by</span> <span class="lab"><a class="ref" href="margrel1.html#T18" onmouseover="rs('margrel1/T18')" onmouseout="rh()">MARGREL1:18</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>
