<?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#V14" title="MONOID_0:attr.14">left-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> 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:22"/>
( <font color="Maroon" title="c1">G</font> is  <a href="monoid_0.html#V14" title="MONOID_0:attr.14">left-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> 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> 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#V14" title="MONOID_0:attr.14">left-cancelable</a>  )</span><div><a class="txt" onmouseover="tooltip.show('hs2',this)" onmouseout="tooltip.hide()" onclick="hs2(this)" href="javascript:()" title="22_1"><span class="kw">proof </span></a><div class="add">

<span class="kw">assume </span><a NAME="E1:22_1"/><span class="lab"><font color="Green" title="E14">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>) 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#D6" target="_self" onmouseover="rs('monoid_0/D6')" onmouseout="rh()">MONOID_0:def 6</a>,<a class="ref" href="monoid_0.html#D17" target="_self" onmouseover="rs('monoid_0/D17')" onmouseout="rh()">MONOID_0:def 17</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> 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> 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:22_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> 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:22_1"><span class="lab"><font color="Green" title="E14">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:22"/><span class="lab"><font color="Green" title="E14">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> 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#V14" title="MONOID_0:attr.14">left-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#D6" target="_self" onmouseover="rs('monoid_0/D6')" onmouseout="rh()">MONOID_0:def 6</a>,<a class="ref" href="monoid_0.html#D17" target="_self" onmouseover="rs('monoid_0/D17')" onmouseout="rh()">MONOID_0:def 17</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>) 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>) 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:22"/>
( <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="E4:22"/>
(  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>) 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:22"><span class="lab"><font color="Green" title="E14">A2</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>
