Hi Louis, FYI NARS2000 overloads jot even more than Dyalog does: it is both a composition operator (f∘g, A∘g, f∘B) and a general null operand for any user-defined operator (not just dot).
I'm not convinced that it's a good idea to treat ∘. as a *monadic* operator taking an operand on the *right*! Jay. On 29 June 2016 at 02:14, Louis de Forcrand <ol...@bluewin.ch> wrote: > The reason Dyalog is doing weird stuff with the jot is that it uses jot to > bind left or right arguments (1 jot + = increment) AND for composition in > its tacit style. It must have very complicated parsing rules. > > What I would suggest is: > All operators have a long left scope, except jot dot, which takes as its > right (and only) argument the whole chain of jots and dots to its right up > to and including the first function: > > jot dot jot dot jot dot + / each > would parse as > ((jot dot (jot dot ( jot dot +))) /) each > > This would produce maximum compatibility, since (jot dot jot) doesn't mean > anything according to the standard anyway, and APL2 clearly states that > jot dot + / > is > (jot dot +)/ > not > jot dot (+/) . > > Louis > > > On 28 Jun 2016, at 18:20, Xiao-Yong Jin <jinxiaoy...@gmail.com> wrote: > > > > I agree that in terms of the . operator, f.g.h should parse as (f.g).h. > It seems more logical to treat ∘ as a function so ∘.∘.f parse as (∘.∘).f > too, but perhaps APL2 is doing something special with ∘. as one operator? > > > > Here is a session with Dyalog, > > ⎕ML←2 > > ⍝ Some high dimensional mind twist > > (⊂[1]⍳2 3)+.{⍺+⍵×.0001}.{⍺+⍵×0J1}⊂[1]10×⍳2 3 > > 3.00060006J30.0060006 2.00080012J20.0080012 > > (⊂[1]⍳2 3)(+.{⍺+⍵×.0001}).{⍺+⍵×0J1}⊂[1]10×⍳2 3 > > 3.00060006J30.0060006 2.00080012J20.0080012 > > (⊂[1]⍳2 3)+.({⍺+⍵×.0001}.{⍺+⍵×0J1})⊂[1]10×⍳2 3 > > 3.0006J30.006 6.0006J60.006 > > ⍝ ∘.∘ completely baffled me > > 1∘.∘.+2 > > 3 > > 1∘.∘.+2 3 > > SYNTAX ERROR: The function does not take a left argument > > 1∘.∘.+2 3 > > ∧ > > ∘.∘.+2 3 > > SYNTAX ERROR: The function requires a left argument > > ∘.∘.+2 3 > > ∧ > > > > Unfortunately, gnu apl fails at this f.g.h fun > > (⊂[1]⍳2 3)+.{⍺+⍵×.0001}.{⍺+⍵×0J1}⊂[1]10×⍳2 3 > > LENGTH ERROR > > μ-Z__A_LO_INNER_RO_B[5] (μ-IA μ-IB)←⊃μ-I[μ-N] > > ^ ^ > > )reset > > (⊂[1]⍳2 3)(+.{⍺+⍵×.0001}).{⍺+⍵×0J1}⊂[1]10×⍳2 3 > > LENGTH ERROR > > μ-Z__A_LO_INNER_RO_B[5] (μ-IA μ-IB)←⊃μ-I[μ-N] > > ^ ^ > > )reset > > (⊂[1]⍳2 3)+.({⍺+⍵×.0001}.{⍺+⍵×0J1})⊂[1]10×⍳2 3 > > LENGTH ERROR > > μ-Z__A_LO_INNER_RO_B[5] (μ-IA μ-IB)←⊃μ-I[μ-N] > > ^ ^ > > > > Best, > > Xiao-Yong > > > >> On Jun 28, 2016, at 10:26 AM, Louis de Forcrand <ol...@bluewin.ch> > wrote: > >> > >> Operators are evaluated from left to right in Dyalog, NARS2000, and J > at least. This seems logical: > >> +/{each} should parse as (+/){each}, not +(/{each}), and +/{rank}1 as > (+/){rank}1, as "tacit" operators aren't supported in GNU APL or the > standard (/{each} and /{rank}1 have no meaning). > >> The problem is that jot dot is not a usual operator since it is written > to the left of its argument. I believe this is because it was originally > perceived as similar to an inner product, but with no reduction, and jot > was the "null function" (this comes from the original APL book). Inner > products were written with the first function on top of the second, but to > adapt this to terminals, a dot was instead placed between the two functions. > >> Thus °| became º.| > >> I would imagine jot dot should parse just like and inner product, > except when the jot is read, an outer product is executed. So, as I see it > (with * as times), °.°.* should parse as (°.°).*, just as +.*.* should > parse as (+.*).* . > >> However, I don't see what (°.°) corresponds to. > >> > >> It seems to me that APL2 parses it as > >> °.(°.*) , in which case APL2 has some operators with a long left scope > and others with a long right scope. Then you encounter problems such as > °.*/; is that °.(*/) or (°.*)/ ? > >> > >> My point is that I am almost sure that functions have a long right > scope, and operators a long left scope; the exception here is jot dot, and > I don't know what it has. To illustrate what Iverson thought, in J x (jot > dot fun) y is written as x (fun/) y . > >> > >> Louis > >> > >> Sorry for the poor formatting! > >> > >>> On 27 Jun 2016, at 13: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 > > > > >