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

<span class="kw">let </span><font color="Maroon" title="c1">G</font> be   non  <a href="struct_0.html#V2" title="STRUCT_0:attr.2">empty</a>   <a href="algstr_0.html#L3" title="ALGSTR_0:struct.3">multMagma</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="c1">G</font> is  <a href="monoid_0.html#V16" title="MONOID_0:attr.16">cancelable</a>  iff  for <font color="Olive" title="b1">a</font>, <font color="Olive" title="b2">b</font>, <font color="Olive" title="b3">c</font> being   <a href="struct_0.html#NM1" title="STRUCT_0:NM.1">Element</a> of <font color="Maroon" title="c1">G</font>  st ( <font color="Olive" title="b1">a</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b2">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b1">a</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b3">c</font> or <font color="Olive" title="b2">b</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b1">a</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b3">c</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b1">a</font> ) holds <br/><font color="Olive" title="b2">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b3">c</font> )</span><br/>

<span class="kw">thus </span><a NAME="E1:24"/>
( <font color="Maroon" title="c1">G</font> is  <a href="monoid_0.html#V16" title="MONOID_0:attr.16">cancelable</a>  implies  for <font color="Olive" title="b1">a</font>, <font color="Olive" title="b2">b</font>, <font color="Olive" title="b3">c</font> being   <a href="struct_0.html#NM1" title="STRUCT_0:NM.1">Element</a> of <font color="Maroon" title="c1">G</font>  st ( <font color="Olive" title="b1">a</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b2">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b1">a</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b3">c</font> or <font color="Olive" title="b2">b</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b1">a</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b3">c</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b1">a</font> ) holds <br/><font color="Olive" title="b2">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b3">c</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">a</font>, <font color="Olive" title="b2">b</font>, <font color="Olive" title="b3">c</font> being   <a href="struct_0.html#NM1" title="STRUCT_0:NM.1">Element</a> of <font color="Maroon" title="c1">G</font>  st ( <font color="Olive" title="b1">a</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b2">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b1">a</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b3">c</font> or <font color="Olive" title="b2">b</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b1">a</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b3">c</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b1">a</font> ) holds <br/><font color="Olive" title="b2">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b3">c</font> ) implies <font color="Maroon" title="c1">G</font> is  <a href="monoid_0.html#V16" title="MONOID_0:attr.16">cancelable</a>  )</span><div><a class="txt" onmouseover="tooltip.show('hs2',this)" onmouseout="tooltip.hide()" onclick="hs2(this)" href="javascript:()" title="24_1"><span class="kw">proof </span></a><div class="add">

<span class="kw">assume </span><a NAME="E1:24_1"/><span class="lab"><font color="Green" title="E15">A1</font></span>: 
 for <font color="Olive" title="b1">a</font>, <font color="Olive" title="b2">b</font>, <font color="Olive" title="b3">c</font> being   <a href="struct_0.html#NM1" title="STRUCT_0:NM.1">Element</a> of <font color="Maroon" title="c1">G</font>  st ( <font color="Maroon">H<sub>2</sub></font>(<font color="Maroon" title="c1">G</font>) <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Olive" title="b1">a</font>,<font color="Olive" title="b2">b</font>) <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon">H<sub>2</sub></font>(<font color="Maroon" title="c1">G</font>) <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Olive" title="b1">a</font>,<font color="Olive" title="b3">c</font>) or <font color="Maroon">H<sub>2</sub></font>(<font color="Maroon" title="c1">G</font>) <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Olive" title="b2">b</font>,<font color="Olive" title="b1">a</font>) <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon">H<sub>2</sub></font>(<font color="Maroon" title="c1">G</font>) <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Olive" title="b3">c</font>,<font color="Olive" title="b1">a</font>) ) holds <br/><font color="Olive" title="b2">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b3">c</font>
 ; <span class="comment"><font color="firebrick">:: according to </font></span><a class="ref" href="monoid_0.html#D8" target="_self" onmouseover="rs('monoid_0/D8')" onmouseout="rh()">MONOID_0:def 8</a>,<a class="ref" href="monoid_0.html#D19" target="_self" onmouseover="rs('monoid_0/D19')" onmouseout="rh()">MONOID_0:def 19</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">a</font>, <font color="Olive" title="b2">b</font>, <font color="Olive" title="b3">c</font> being   <a href="struct_0.html#NM1" title="STRUCT_0:NM.1">Element</a> of <font color="Maroon" title="c1">G</font>  st ( <font color="Olive" title="b1">a</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b2">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b1">a</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b3">c</font> or <font color="Olive" title="b2">b</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b1">a</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b3">c</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b1">a</font> ) holds <br/><font color="Olive" title="b2">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b3">c</font></span><br/>

<span class="kw">let </span><font color="Maroon" title="c2">a</font>, <font color="Maroon" title="c3">b</font>, <font color="Maroon" title="c4">c</font> be   <a href="struct_0.html#NM1" title="STRUCT_0:NM.1">Element</a> of <font color="Maroon" title="c1">G</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="c2">a</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Maroon" title="c3">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c2">a</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Maroon" title="c4">c</font> or <font color="Maroon" title="c3">b</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Maroon" title="c2">a</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c4">c</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Maroon" title="c2">a</font> ) implies <font color="Maroon" title="c3">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c4">c</font> )</span><br/>





<span class="kw">thus </span><a NAME="E2:24_1"/>
( ( <font color="Maroon" title="c2">a</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Maroon" title="c3">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c2">a</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Maroon" title="c4">c</font> or <font color="Maroon" title="c3">b</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Maroon" title="c2">a</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c4">c</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Maroon" title="c2">a</font> ) implies <font color="Maroon" title="c3">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c4">c</font> )
 <span class="kw">by</span> <span class="lab"><a class="txt" href="#E1:24_1"><span class="lab"><font color="Green" title="E15">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>

<span class="kw">assume </span><a NAME="E2:24"/><span class="lab"><font color="Green" title="E15">A2</font></span>: 
 for <font color="Olive" title="b1">a</font>, <font color="Olive" title="b2">b</font>, <font color="Olive" title="b3">c</font> being   <a href="struct_0.html#NM1" title="STRUCT_0:NM.1">Element</a> of <font color="Maroon" title="c1">G</font>  st ( <font color="Olive" title="b1">a</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b2">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b1">a</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b3">c</font> or <font color="Olive" title="b2">b</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b1">a</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b3">c</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Olive" title="b1">a</font> ) holds <br/><font color="Olive" title="b2">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b3">c</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="c1">G</font> is  <a href="monoid_0.html#V16" title="MONOID_0:attr.16">cancelable</a> </span><br/>

<span class="kw">let </span><font color="Maroon" title="c2">a</font> be   <a href="struct_0.html#NM1" title="STRUCT_0:NM.1">Element</a> of <font color="Maroon" title="c1">G</font>; <span class="comment"><font color="firebrick">:: according to </font></span><a class="ref" href="monoid_0.html#D8" target="_self" onmouseover="rs('monoid_0/D8')" onmouseout="rh()">MONOID_0:def 8</a>,<a class="ref" href="monoid_0.html#D19" target="_self" onmouseover="rs('monoid_0/D19')" onmouseout="rh()">MONOID_0:def 19</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">b</font>, <font color="Olive" title="b2">c</font> being    <a href="subset_1.html#M1" title="SUBSET_1:mode.1">Element</a> of  the <a href="struct_0.html#U1" title="STRUCT_0:sel.1">carrier</a> of <font color="Maroon" title="c1">G</font>  st (  the <a href="algstr_0.html#U2" title="ALGSTR_0:sel.2">multF</a> of <font color="Maroon" title="c1">G</font> <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Maroon" title="c2">a</font>,<font color="Olive" title="b1">b</font>) <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a>  the <a href="algstr_0.html#U2" title="ALGSTR_0:sel.2">multF</a> of <font color="Maroon" title="c1">G</font> <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Maroon" title="c2">a</font>,<font color="Olive" title="b2">c</font>) or  the <a href="algstr_0.html#U2" title="ALGSTR_0:sel.2">multF</a> of <font color="Maroon" title="c1">G</font> <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Olive" title="b1">b</font>,<font color="Maroon" title="c2">a</font>) <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a>  the <a href="algstr_0.html#U2" title="ALGSTR_0:sel.2">multF</a> of <font color="Maroon" title="c1">G</font> <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Olive" title="b2">c</font>,<font color="Maroon" title="c2">a</font>) ) holds <br/><font color="Olive" title="b1">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Olive" title="b2">c</font></span><br/><span class="kw">let </span><font color="Maroon" title="c3">b</font>, <font color="Maroon" title="c4">c</font> be   <a href="struct_0.html#NM1" title="STRUCT_0:NM.1">Element</a> of <font color="Maroon" title="c1">G</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"> ( (  the <a href="algstr_0.html#U2" title="ALGSTR_0:sel.2">multF</a> of <font color="Maroon" title="c1">G</font> <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Maroon" title="c2">a</font>,<font color="Maroon" title="c3">b</font>) <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a>  the <a href="algstr_0.html#U2" title="ALGSTR_0:sel.2">multF</a> of <font color="Maroon" title="c1">G</font> <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Maroon" title="c2">a</font>,<font color="Maroon" title="c4">c</font>) or  the <a href="algstr_0.html#U2" title="ALGSTR_0:sel.2">multF</a> of <font color="Maroon" title="c1">G</font> <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Maroon" title="c3">b</font>,<font color="Maroon" title="c2">a</font>) <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a>  the <a href="algstr_0.html#U2" title="ALGSTR_0:sel.2">multF</a> of <font color="Maroon" title="c1">G</font> <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Maroon" title="c4">c</font>,<font color="Maroon" title="c2">a</font>) ) implies <font color="Maroon" title="c3">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c4">c</font> )</span><br/>





<a NAME="E3:24"/><span class="lab"><font color="Green" title="E16">A3</font></span>: 
( <font color="Maroon" title="c3">b</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Maroon" title="c2">a</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon">H<sub>2</sub></font>(<font color="Maroon" title="c1">G</font>) <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Maroon" title="c3">b</font>,<font color="Maroon" title="c2">a</font>) &amp; <font color="Maroon" title="c4">c</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Maroon" title="c2">a</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon">H<sub>2</sub></font>(<font color="Maroon" title="c1">G</font>) <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Maroon" title="c4">c</font>,<font color="Maroon" title="c2">a</font>) )
 
;<br/>
<a NAME="E4:24"/>
( <font color="Maroon" title="c2">a</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Maroon" title="c3">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon">H<sub>2</sub></font>(<font color="Maroon" title="c1">G</font>) <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Maroon" title="c2">a</font>,<font color="Maroon" title="c3">b</font>) &amp; <font color="Maroon" title="c2">a</font> <a href="algstr_0.html#K6" title="ALGSTR_0:func.6">*</a> <font color="Maroon" title="c4">c</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon">H<sub>2</sub></font>(<font color="Maroon" title="c1">G</font>) <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Maroon" title="c2">a</font>,<font color="Maroon" title="c4">c</font>) )
 
;<br/>
<span class="kw">hence </span><a NAME="E5:24"/>
( (  the <a href="algstr_0.html#U2" title="ALGSTR_0:sel.2">multF</a> of <font color="Maroon" title="c1">G</font> <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Maroon" title="c2">a</font>,<font color="Maroon" title="c3">b</font>) <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a>  the <a href="algstr_0.html#U2" title="ALGSTR_0:sel.2">multF</a> of <font color="Maroon" title="c1">G</font> <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Maroon" title="c2">a</font>,<font color="Maroon" title="c4">c</font>) or  the <a href="algstr_0.html#U2" title="ALGSTR_0:sel.2">multF</a> of <font color="Maroon" title="c1">G</font> <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Maroon" title="c3">b</font>,<font color="Maroon" title="c2">a</font>) <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a>  the <a href="algstr_0.html#U2" title="ALGSTR_0:sel.2">multF</a> of <font color="Maroon" title="c1">G</font> <a href="binop_1.html#K4" title="BINOP_1:func.4">.</a> (<font color="Maroon" title="c4">c</font>,<font color="Maroon" title="c2">a</font>) ) implies <font color="Maroon" title="c3">b</font> <a href="hidden.html#R1" title="HIDDEN:pred.1">=</a> <font color="Maroon" title="c4">c</font> )
 <span class="kw">by</span> <span class="lab"><a class="txt" href="#E2:24"><span class="lab"><font color="Green" title="E15">A2</font></span></a>, <a class="txt" href="#E3:24"><span class="lab"><font color="Green" title="E16">A3</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>
