<div dir="ltr"><div><div>All,<br><br></div>The blog post I promised: <a href="http://serendependy.blogspot.com/2014/11/with-great-power-great-intractibility.html">http://serendependy.blogspot.com/2014/11/with-great-power-great-intractibility.html</a><br><br></div>Feel free to add comments or suggestions on the blog itself or here.<br></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Nov 6, 2014 at 3:39 PM, Andreas Abel <span dir="ltr">&lt;<a href="mailto:andreas.abel@ifi.lmu.de" target="_blank">andreas.abel@ifi.lmu.de</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Note that I am in the process of outlawing `with` on variables bound by module telescopes (because of the issue 1342 that came up during this discussion).<br>
<br>
Cheers,<br>
Andreas<span class=""><br>
<br>
On 05.11.2014 23:53, Christopher Jenkins wrote:<br>
</span><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">
Alright, two people is enough to motivate me. I will try to have a first<br>
blog post out this weekend, mostly dealing with pattern-matching after a<br>
rewrite and the basic concept of `with&#39;, with more to follow.<br>
<br>
On Wed, Nov 5, 2014 at 2:21 AM, Arseniy Alekseyev<br></span><span class="">
&lt;<a href="mailto:arseniy.alekseyev@gmail.com" target="_blank">arseniy.alekseyev@gmail.com</a> &lt;mailto:<a href="mailto:arseniy.alekseyev@gmail.com" target="_blank">arseniy.alekseyev@<u></u>gmail.com</a>&gt;&gt; wrote:<br>
<br>
    Oh wow, I should have tried that. I don&#39;t understand why this works at<br>
    all. Note that none of these compile for me:<br>
<br>
       y | true   = id {A = (q : Bool) → x ≡ z q} (λ { true → refl ; false<br>
    → refl }) -- x != true of type Bool<br>
<br>
       y | true   = id {A = (q : Bool) → true ≡ z q} (λ { true → refl ;<br>
    false → refl }) -- true != x of type Bool<br>
<br>
    However, even more confusingly, this one does work:<br>
<br>
       y | true   = id {A = _} (λ { true → refl ; false → refl })<br>
<br>
    So what&#39;s the value of underscore it infers then?<br>
    Can anybody explain what&#39;s going on?<br>
<br>
    As for the code smell part, I think you can only smell it on toy<br>
    examples, not on the &quot;real&quot; ones.<br>
<br>
    On 5 November 2014 01:28, Christopher Jenkins &lt;<a href="mailto:cjenkin1@trinity.edu" target="_blank">cjenkin1@trinity.edu</a><br></span><span class="">
    &lt;mailto:<a href="mailto:cjenkin1@trinity.edu" target="_blank">cjenkin1@trinity.edu</a>&gt;&gt; wrote:<br>
     &gt;<br>
     &gt;<br>
     &gt; On Tue, Nov 4, 2014 at 5:18 PM, Arseniy Alekseyev<br>
     &gt; &lt;<a href="mailto:arseniy.alekseyev@gmail.com" target="_blank">arseniy.alekseyev@gmail.com</a><br></span><span class="">
    &lt;mailto:<a href="mailto:arseniy.alekseyev@gmail.com" target="_blank">arseniy.alekseyev@<u></u>gmail.com</a>&gt;&gt; wrote:<br>
     &gt;&gt;<br>
     &gt;&gt; That was not a genuine attempt to prove `y : ∀ q → x ≡ z q`. Instead<br>
     &gt;&gt; that was an example of `with` rewriting the goal from (as you<br>
     &gt;&gt; demonstrated!) provable one into (as I assert) non-provable one. I<br>
     &gt;&gt; think that&#39;s the property of `with` that&#39;s causing you grief<br>
    when you<br>
     &gt;&gt; re-order or nest them in a bad way.<br>
     &gt;&gt;<br>
     &gt; Ah, makes sense. Though of course you could probably continue on<br>
    to prove<br>
     &gt; the goal by pattern-matching on a lambda argument introduced in<br>
    both cases,<br>
     &gt; but by that point hopefully someone would see the code smell.<br>
     &gt;<br>
     &gt; Actually, decided to include it anyway, so you could smell the<br>
    smelly code<br>
     &gt; smell:<br>
     &gt;<br>
     &gt;   y : ∀ q → x ≡ z q<br>
     &gt;   y with x<br>
     &gt;   y | true   = λ { true → refl ; false → refl }<br>
     &gt;   y | false  = λ { true → refl ; false → refl }<br>
     &gt;<br>
     &gt;&gt;<br>
     &gt;&gt; On 4 November 2014 22:43, Christopher Jenkins<br></span>
    &lt;<a href="mailto:cjenkin1@trinity.edu" target="_blank">cjenkin1@trinity.edu</a> &lt;mailto:<a href="mailto:cjenkin1@trinity.edu" target="_blank">cjenkin1@trinity.edu</a>&gt;&gt;<span class=""><br>
     &gt;&gt; wrote:<br>
     &gt;&gt; &gt;<br>
     &gt;&gt; &gt;<br>
     &gt;&gt; &gt; On Mon, Nov 3, 2014 at 2:38 PM, Arseniy Alekseyev<br>
     &gt;&gt; &gt; &lt;<a href="mailto:arseniy.alekseyev@gmail.com" target="_blank">arseniy.alekseyev@gmail.com</a><br></span><div><div class="h5">
    &lt;mailto:<a href="mailto:arseniy.alekseyev@gmail.com" target="_blank">arseniy.alekseyev@<u></u>gmail.com</a>&gt;&gt; wrote:<br>
     &gt;&gt; &gt;&gt;<br>
     &gt;&gt; &gt;&gt; You are right, there is not much point. I was trying to point<br>
    out that<br>
     &gt;&gt; &gt;&gt; it&#39;s the &quot;proper expression&quot; part that makes `with` complicated.<br>
     &gt;&gt; &gt;&gt;<br>
     &gt;&gt; &gt;&gt; Unfortunately, that&#39;s not even true. In the following<br>
    example, I don&#39;t<br>
     &gt;&gt; &gt;&gt; think you can fill the holes.<br>
     &gt;&gt; &gt;&gt;<br>
     &gt;&gt; &gt;&gt; f : Bool → Bool<br>
     &gt;&gt; &gt;&gt; f x = true where<br>
     &gt;&gt; &gt;&gt;<br>
     &gt;&gt; &gt;&gt;   z : Bool → Bool<br>
     &gt;&gt; &gt;&gt;   z true = x<br>
     &gt;&gt; &gt;&gt;   z false = x<br>
     &gt;&gt; &gt;&gt;<br>
     &gt;&gt; &gt;&gt;   y : ∀ q → x ≡ z q<br>
     &gt;&gt; &gt;&gt;   y with x<br>
     &gt;&gt; &gt;&gt;   y | true = {!!}<br>
     &gt;&gt; &gt;&gt;   y | false = {!!}<br>
     &gt;&gt; &gt;&gt;<br>
     &gt;&gt; &gt;&gt;<br>
     &gt;&gt; &gt;<br>
     &gt;&gt; &gt; I&#39;m not entirely sure why you would expect that approach to be<br>
    fruitful.<br>
     &gt;&gt; &gt; Essentially, what you&#39;re trying to do is unwind the<br>
    computational nature<br>
     &gt;&gt; &gt; of<br>
     &gt;&gt; &gt; `z&#39;, which is defined by case analysis on its argument (in<br>
    this case q).<br>
     &gt;&gt; &gt; To<br>
     &gt;&gt; &gt; trigger the rules, you would have to bring q into scope and<br>
    inspect q,<br>
     &gt;&gt; &gt; which<br>
     &gt;&gt; &gt; would then lead to `z true&#39; and `z false&#39; in the equations,<br>
     &gt;&gt; &gt; respectively,<br>
     &gt;&gt; &gt; and Agda will then go on to normalize the goals as `x \== x&#39;<br>
     &gt;&gt; &gt;<br>
     &gt;&gt; &gt; f : Bool → Bool<br>
     &gt;&gt; &gt; f x = true where<br>
     &gt;&gt; &gt;   z : Bool → Bool<br>
     &gt;&gt; &gt;   z true = x<br>
     &gt;&gt; &gt;   z false = x<br>
     &gt;&gt; &gt;<br>
     &gt;&gt; &gt;   y : ∀ q → x ≡ z q<br>
     &gt;&gt; &gt;   y true = {!!} -- Goal: x ≡ x<br>
     &gt;&gt; &gt;   y false = {!!} -- Goal: x ≡ x<br>
     &gt;&gt; &gt;<br>
     &gt;&gt; &gt; I have actually been thinking about writing a blog post<br>
    targeted at<br>
     &gt;&gt; &gt; newbies<br>
     &gt;&gt; &gt; (such as myself) on the sometimes unintuitive behaviour of<br>
    `with&#39; (and<br>
     &gt;&gt; &gt; in<br>
     &gt;&gt; &gt; particular, `rewrite&#39;). Should anyone be interested I can send<br>
    a link on<br>
     &gt;&gt; &gt; this email chain once I have written it.<br>
     &gt;&gt; &gt;<br>
     &gt;&gt; &gt;<br>
     &gt;&gt; &gt;&gt;<br>
     &gt;&gt; &gt;&gt; On 3 November 2014 10:59, Andreas Abel<br></div></div><div><div class="h5">
    &lt;<a href="mailto:andreas.abel@ifi.lmu.de" target="_blank">andreas.abel@ifi.lmu.de</a> &lt;mailto:<a href="mailto:andreas.abel@ifi.lmu.de" target="_blank">andreas.abel@ifi.lmu.<u></u>de</a>&gt;&gt; wrote:<br>
     &gt;&gt; &gt;&gt; &gt; On 03.11.2014 09:47, Arseniy Alekseyev wrote:<br>
     &gt;&gt; &gt;&gt; &gt;&gt; I think the problem goes away if you<br>
     &gt;&gt; &gt;&gt; &gt;&gt; only use `with x` where `x` is a variable.<br>
     &gt;&gt; &gt;&gt; &gt;<br>
     &gt;&gt; &gt;&gt; &gt; Mmh, why use `with` at all then?  You could directly split<br>
    on the<br>
     &gt;&gt; &gt;&gt; &gt; variable<br>
     &gt;&gt; &gt;&gt; &gt; `x`.  I thought the only reason to use `with` was when you<br>
    wanted to<br>
     &gt;&gt; &gt;&gt; &gt; case on<br>
     &gt;&gt; &gt;&gt; &gt; a proper expression and refine your type in the<br>
    with-branches...<br>
     &gt;&gt; &gt;&gt; &gt;<br>
     &gt;&gt; &gt;&gt; &gt;<br>
     &gt;&gt; &gt;&gt; &gt;<br>
     &gt;&gt; &gt;&gt; &gt; On 03.11.2014 09:47, Arseniy Alekseyev wrote:<br>
     &gt;&gt; &gt;&gt; &gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt; Indeed that&#39;s the usual Agda behaviour.<br>
     &gt;&gt; &gt;&gt; &gt;&gt; Here the reason seems to be an additional occurrence of<br>
    `lookup k<br>
     &gt;&gt; &gt;&gt; &gt;&gt; ps`<br>
     &gt;&gt; &gt;&gt; &gt;&gt; in the context produced by pattern-match on `no`.<br>
     &gt;&gt; &gt;&gt; &gt;&gt; You see, `with expr` only rewrites the occurrences of<br>
    `expr` present<br>
     &gt;&gt; &gt;&gt; &gt;&gt; in the enclosing context, so the new occurrences inside<br>
    the body of<br>
     &gt;&gt; &gt;&gt; &gt;&gt; `with` don&#39;t get rewritten (and you do want it rewritten<br>
    in this<br>
     &gt;&gt; &gt;&gt; &gt;&gt; case).<br>
     &gt;&gt; &gt;&gt; &gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt; I do agree this is confusing. I think the problem goes<br>
    away if you<br>
     &gt;&gt; &gt;&gt; &gt;&gt; only use `with x` where `x` is a variable. That makes<br>
    `with` much<br>
     &gt;&gt; &gt;&gt; &gt;&gt; less<br>
     &gt;&gt; &gt;&gt; &gt;&gt; useful though. You can also avoid `with` altogether and<br>
    write the<br>
     &gt;&gt; &gt;&gt; &gt;&gt; helper functions by hand (that&#39;s what `with` is doing<br>
    after all!).<br>
     &gt;&gt; &gt;&gt; &gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt; On 2 November 2014 17:14,  &lt;<a href="mailto:mechvel@scico.botik.ru" target="_blank">mechvel@scico.botik.ru</a><br></div></div><div><div class="h5">
    &lt;mailto:<a href="mailto:mechvel@scico.botik.ru" target="_blank">mechvel@scico.botik.ru</a><u></u>&gt;&gt; wrote:<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; People,<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; Having the proof<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;    prove : (k∈ks : k ∈ ks) → proj₂ (lookupIf∈ k (p ∷ ps)<br>
    k∈k&#39;:ks) ≡<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;                              proj₂ (lookupIf∈ k ps k∈ks)<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;    prove k∈ks  with  k ≟ k&#39;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; --<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; (I)<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;    ... | yes k≡k&#39; =  ⊥-elim $ k≉k&#39; k≡k&#39;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;    ... | no _     with  lookup k ps<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;    ...                | inj₁ _    =  PE.refl<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;    ...                | inj₂ k∉ks =  ⊥-elim $ k∉ks k∈ks<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; (I do not give the complete code),<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; I try to rewrite it in a bit simpler way by joining it<br>
    into one<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; `with&#39;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; clause:<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;    prove k∈ks  with  k ≟ k&#39; | lookup k ps<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; --<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; (II)<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;    ... | yes k≡k&#39; | _         =  ⊥-elim $ k≉k&#39; k≡k&#39;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;    ... | no _     | inj₁ _    =  PE.refl<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;    ... | no _     | inj₂ k∉ks =  ⊥-elim $ k∉ks k∈ks<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; (I) is type-checked, and (II) is not.<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; Is this natural for Agda to decide so?<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; (I have spent 4 hours trying to prove a similar real and<br>
    evident<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; example.<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; Then tried to split `with&#39; into two, and this has succeeded).<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; Thanks,<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; ------<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; Sergei<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; ______________________________<u></u>_________________<br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; Agda mailing list<br></div></div>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; <a href="mailto:Agda@lists.chalmers.se" target="_blank">Agda@lists.chalmers.se</a> &lt;mailto:<a href="mailto:Agda@lists.chalmers.se" target="_blank">Agda@lists.chalmers.se</a><u></u>&gt;<span class=""><br>
     &gt;&gt; &gt;&gt; &gt;&gt;&gt; <a href="https://lists.chalmers.se/mailman/listinfo/agda" target="_blank">https://lists.chalmers.se/<u></u>mailman/listinfo/agda</a><br>
     &gt;&gt; &gt;&gt; &gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;&gt; ______________________________<u></u>_________________<br>
     &gt;&gt; &gt;&gt; &gt;&gt; Agda mailing list<br></span>
     &gt;&gt; &gt;&gt; &gt;&gt; <a href="mailto:Agda@lists.chalmers.se" target="_blank">Agda@lists.chalmers.se</a> &lt;mailto:<a href="mailto:Agda@lists.chalmers.se" target="_blank">Agda@lists.chalmers.se</a><u></u>&gt;<span class=""><br>
     &gt;&gt; &gt;&gt; &gt;&gt; <a href="https://lists.chalmers.se/mailman/listinfo/agda" target="_blank">https://lists.chalmers.se/<u></u>mailman/listinfo/agda</a><br>
     &gt;&gt; &gt;&gt; &gt;&gt;<br>
     &gt;&gt; &gt;&gt; &gt;<br>
     &gt;&gt; &gt;&gt; &gt;<br>
     &gt;&gt; &gt;&gt; &gt; --<br>
     &gt;&gt; &gt;&gt; &gt; Andreas Abel  &lt;&gt;&lt;      Du bist der geliebte Mensch.<br>
     &gt;&gt; &gt;&gt; &gt;<br>
     &gt;&gt; &gt;&gt; &gt; Department of Computer Science and Engineering<br>
     &gt;&gt; &gt;&gt; &gt; Chalmers and Gothenburg University, Sweden<br>
     &gt;&gt; &gt;&gt; &gt;<br></span>
     &gt;&gt; &gt;&gt; &gt; <a href="mailto:andreas.abel@gu.se" target="_blank">andreas.abel@gu.se</a> &lt;mailto:<a href="mailto:andreas.abel@gu.se" target="_blank">andreas.abel@gu.se</a>&gt;<span class=""><br>
     &gt;&gt; &gt;&gt; &gt; <a href="http://www2.tcs.ifi.lmu.de/~abel/" target="_blank">http://www2.tcs.ifi.lmu.de/~<u></u>abel/</a><br>
     &gt;&gt; &gt;&gt; ______________________________<u></u>_________________<br>
     &gt;&gt; &gt;&gt; Agda mailing list<br></span>
     &gt;&gt; &gt;&gt; <a href="mailto:Agda@lists.chalmers.se" target="_blank">Agda@lists.chalmers.se</a> &lt;mailto:<a href="mailto:Agda@lists.chalmers.se" target="_blank">Agda@lists.chalmers.se</a><u></u>&gt;<span class=""><br>
     &gt;&gt; &gt;&gt; <a href="https://lists.chalmers.se/mailman/listinfo/agda" target="_blank">https://lists.chalmers.se/<u></u>mailman/listinfo/agda</a><br>
     &gt;&gt; &gt;<br>
     &gt;&gt; &gt;<br>
     &gt;&gt; &gt;<br>
     &gt;&gt; &gt;<br>
     &gt;&gt; &gt; --<br>
     &gt;&gt; &gt; Christopher Jenkins<br>
     &gt;&gt; &gt; Computer Science 2013<br>
     &gt;&gt; &gt; Trinity University<br>
     &gt;<br>
     &gt;<br>
     &gt;<br>
     &gt;<br>
     &gt; --<br>
     &gt; Christopher Jenkins<br>
     &gt; Computer Science 2013<br>
     &gt; Trinity University<br>
<br>
<br>
<br>
<br>
--<br>
Christopher Jenkins<br>
Computer Science 2013<br>
Trinity University<br>
</span></blockquote>
<br><div class="HOEnZb"><div class="h5">
<br>
-- <br>
Andreas Abel  &lt;&gt;&lt;      Du bist der geliebte Mensch.<br>
<br>
Department of Computer Science and Engineering<br>
Chalmers and Gothenburg University, Sweden<br>
<br>
<a href="mailto:andreas.abel@gu.se" target="_blank">andreas.abel@gu.se</a><br>
<a href="http://www2.tcs.ifi.lmu.de/~abel/" target="_blank">http://www2.tcs.ifi.lmu.de/~<u></u>abel/</a><br>
</div></div></blockquote></div><br><br clear="all"><br>-- <br><div class="gmail_signature"><div dir="ltr"><div>Christopher Jenkins<br>Computer Science 2013<br>Trinity University</div></div></div>
</div>