Can you explain what cases you have fixed? All the cases I showed seemed to
working correctly already in GNU APL.

Thanks,
Jay.

On 28 June 2016 at 19:09, Juergen Sauermann <juergen.sauerm...@t-online.de>
wrote:

> Hi,
>
> thanks, fixed in *SVN 620*.
>
> /// Jürgen
>
>
> On 06/28/2016 01:23 PM, Jay Foad wrote:
>
> The APL2 manual (p35) says "The right operand of a dyadic operator is the
> function or array to its immediate right." This is their way of saying that
> operator expressions are left-associative. For example, in ∘.∘.+ the right
> operand of the leftmost dot is ∘ (not ∘.+); so ∘.∘.+ is parsed as (∘.∘).+
>
> The fact that operator-operand expressions are left-associative while
> function-array expressions are right-associative is one of the beautiful
> symmetries of APL!
>
> Some more examples demonstrating the left-associativity of operator
> expressions:
>
>       ≡⊂⍣4⍣6⊢'hello'
> 25
>       ≡(⊂⍣4)⍣6⊢'hello'
> 25
>       ≡⊂⍣(4⍣6)⊢'hello'
> DOMAIN ERROR
>
>       ⎕FX'R←(F L G)Y' 'R←F Y'
> L
>       ⎕FX'R←(F R G)Y' 'R←G Y'
> R
>       + L × R - 33
> ¯33
>       (+ L ×) R - 33
> ¯33
>       + L (× R -) 33
> 33
>
> Jay.
>
> On 27 June 2016 at 12:37, Juergen Sauermann <juergen.sauerm...@t-online.de
> > wrote:
>
>> Hi,
>>
>> not sure. First of all, both IBM APL2 and GNU APL return the same result
>> in Alex's  example:
>>
>> *      5 ∘.∘.+ 9*
>> *14*
>> *      5 (∘.∘).+ 9*
>> *14*
>> *      5 ∘.(∘.+) 9*
>> *14*
>>
>> Then the IBM language reference says this (p. 35):
>>
>> *"For example, the function expression +.×/ is a reduction by a **+.×**
>>   inner product*
>> *because the **×** binds as right operand to the array product operator
>> (. ), and not as*
>> *left operand to the slash operator (/). The + binds as left operand to
>> the dot; then*
>> *the resulting product binds to the slash as its left operand.*
>>
>> *+.×/  ←→ (+.× )/ not + .(**×** /)*
>>
>>
>> *" *However, the binding strength resolves the ambiguity in the IBM
>> example only
>> because / is not a dyadic operator. In Alex's example the operator is
>> dyadic, and one
>> could either bind the middle ∘ to the left ∘ or the + to the middle ∘
>> without violating
>> the binding strengths. In this case I would argue that the "basic APL2
>> evaluation rule"
>> should be applied because ∘.+ can be evaluated (yielding a derived
>> function) because all arguments
>> of . are available before the . and ∘ on the left show up.
>>
>> What is missing in both the ISO standard and in the APL2 language
>> reference is a
>> statement about left-to-right or right-to-left associativity of APL
>> operators. I personally
>> would find it counter-intuitive if functions are evaluated left-to-right
>> while operators are
>> evaluated right-to-left.
>>
>> /// Jürgen
>>
>>
>> On 06/27/2016 11:48 AM, Jay Foad wrote:
>>
>> So it looks like GNU APL parses ∘.∘.+ as ∘.(∘.+).
>>
>> IBM APL2 and Dyalog appear to parse it as (∘.∘).+.
>>
>> Jay.
>>
>> On 15 June 2016 at 04:05, Xiao-Yong Jin <jinxiaoy...@gmail.com> wrote:
>>
>>> Hi Alex,
>>>
>>> It is correct.  You need nested vectors to see the effect.
>>>
>>> Try the following.
>>>
>>>       (⊂[2]2 3⍴⍳6)∘.{⍺∘.{⍺+⍵⊣⎕←⍺,'I',⍵}⍵⊣⎕←⍺,'O',⍵}(⊂[2]10×2 3⍴⍳6)
>>>
>>> Best,
>>> Xiao-Yong
>>>
>>> > On Jun 14, 2016, at 6:39 PM, Alex Weiner <alexwei...@alexweiner.com>
>>> wrote:
>>> >
>>> > Hi Bug-APL,
>>> >
>>> > Surely this is not correct:
>>> >
>>> >      5∘.∘.+9
>>> > 14
>>> >
>>> >
>>> > I would expect a syntax error.
>>> > If this is valid, then I stand corrected
>>> >
>>> > -Alex
>>> >
>>>
>>>
>>>
>>
>>
>
>

Reply via email to