there is always the ugliness that lr spits out
lr (1 ar)`+
(<(,'0');1),<,'+'
(but parenthesized in case it is bound to modifier)
> One solution would be to make an exception for noun ARs, i. e. those
beginning with (<'0'). Those could be left in boxed form, rather than
converted back to their value, when they appear as operands to (`).
This sounds promising, so
(<(,'0');1)`+
seems like there is a need for a new primitive say `.. (tie below)
ar =: 1 : '5!:1 <''u'''
isNoun_z_ =: (0 = 4!:0 ( :: 0:))@:<
isgerund =: 0:`(0 -.@e. 3 : ('y (5!:0)';'1')"0)@.(0 < L.) :: 0:
isgerundA =: 1 : ' if. isNoun ''u'' do. isgerund m else. 0 end.'
tie =: 2 : 'if. u isgerundA do. if. v isgerundA do. m ar , v ar else. m , v ar
end. else. if. v isgerundA do. u ar , n else. u ar , v ar end. end. '
so the above could be displayed (lr) and input as
1`..+
but
(<(,'0');1)`+
wouldn't break anything since its a valid lr that creates the valid gerund. I
can't imagine anyone was relying on buggy lr output that doesn't convert back
to ar form.
----- Original Message -----
From: Henry Rich <[email protected]>
To: [email protected]
Sent: Thursday, January 5, 2017 8:20 PM
Subject: Re: [Jprogramming] fixed tacit produces an error when reassigned
I understand this problem a little better now.
The trouble would be something like
v0`v1`n2`v3
where the n2 is a user-created AR. How should you convert this back to
linear rep?
There are no fingerprints to indicate that a gerund was created by (`)
turning a verb into an AR. So when the LR is generated, any AR that is
an operand to (`) is assumed to have been created by (`).
One solution would be to make an exception for noun ARs, i. e. those
beginning with (<'0'). Those could be left in boxed form, rather than
converted back to their value, when they appear as operands to (`).
Would that change break anything?
Henry Rich
On 1/3/2017 9:37 PM, Henry Rich wrote:
> Operands to modifiers such as m}, ^:n, m`, and `n are flagged if they
> are recognized as gerunds.
>
> This seems to me to be a mistake for m` and `n: they should not be
> flagged until the derived adverb has been executed. The problem you
> report is that m/n are interpreted as if they had come from converting
> a noun to an AR, rather than as a noun in themselves.
>
> But Roger said it was an error in 5!:5. When Roger diagnoses a
> problem differently from me, I assume I am wrong. I'll have to go
> think about it.
>
> In the meantime, you can consider whether there would be a problem
> with delaying the recognition of m` and `n until the derived verb is
> executed.
>
> Henry Rich
>
>
>
> On 1/3/2017 11:18 AM, Jose Mario Quintana wrote:
>> Sorry, I pressed the wrong button and my previous message was
>> incomplete;
>> this should have been the full message:
>>
>> I am afraid it is the superbug that has been discovered and
>> rediscovered a
>> few times; see [0, 1, 2 and 3].
>>
>> References
>>
>> [0] [Jprogramming] Table of Verbs, Jose Mario Quintana
>> http://www.jsoftware.com/pipermail/programming/2013-April/032358.html
>>
>> [1] [Jprogramming] tacit adverb, Dan Bron
>> http://www.jsoftware.com/pipermail/programming/2012-February/027341.html
>>
>> [2] [Jgeneral] Looks like a bug in "., Dan Bron
>> http://www.jsoftware.com/pipermail/general/2009-August/033231.html
>>
>> [3] [Jprogramming] Linear Representation Bug?, Roger Hui
>> http://www.jsoftware.com/pipermail/programming/2009-August/016011.html
>>
>>
>> On Tue, Jan 3, 2017 at 11:09 AM, Jose Mario Quintana <
>> [email protected]> wrote:
>>
>>> I am afraid it is the superbug that has been discovered and
>>> rediscovered a
>>> few times; see [0, 1, 2 and 3].
>>>
>>>
>>> References
>>>
>>> [0] [Jprogramming] Table of Verbs, Jose Mario Quintana
>>> http://www.jsoftware.com/pipermail/programming/2013-April/032358.html
>>>
>>> [1] [Jprogramming] tacit adverb, Dan Bron
>>> http://www.jsoftware.com/pipermail/programming/2012-February
>>> /027341.html
>>>
>>> [2] [Jgeneral] Looks like a bug in "., Dan Bron
>>> http://www.jsoftware.com/pipermail/general/2009-August/033231.html
>>>
>>>
>>> On Tue, Jan 3, 2017 at 10:12 AM, 'Pascal Jasmin' via Programming <
>>> [email protected]> wrote:
>>>
>>>> This file works j804 and j805, when copied and run with F8, you may
>>>> need
>>>> to fix newlines
>>>>
>>>>
>>>>
>>>>
>>>> NB.---------------------------------------------------------
>>>> -------------------
>>>> NB. Wicked Tacit Toolkit...
>>>> NB.---------------------------------------------------------
>>>> -------------------
>>>>
>>>> NB. Load it using 0!:0 or similar or
>>>> NB. paste it on an J editing window and use Crtl-A Crtl-E or
>>>> NB. of course, load it using a hot key (or replace '=.' by '=:' if you
>>>> must)
>>>>
>>>> NB. A word is a noun, verb, adverb or conjunction
>>>>
>>>>
>>>> (_ o=. @:) (c=. "_) (e=. &.>) (x=. @:[) (y=. @])
>>>>
>>>> an=. <@:((,'0') ,&< ]) NB. Atomizing words (monadic verb)
>>>>
>>>> Cloak=. (0:`)(,^:) NB. Cloaking (the atomic
>>>> representaions
>>>> of)
>>>> NB. adverbs or conjunctions as monadic or
>>>> NB. dyadic verbs (adv)
>>>> Cloak=. ((5!:1)@:<'Cloak')Cloak NB. Cloak verbing itself! (monadic
>>>> ver)
>>>>
>>>> 'amper at evoke fix rank tie'=. Cloak o < e o ;: '& @: `: f. " `'
>>>> NB. Verbing some adverbs and conjunctions
>>>>
>>>> train=. (evoke&6) :. an f. NB. (`:6) with a convinient obverse
>>>> NB. (monadic verb)
>>>> box=. (< o train "0) f. NB. Boxing primitives and pro-words
>>>> NB. (monadic verb)
>>>>
>>>> af=. an o fix
>>>>
>>>> (a0=. `'') (a1=. (@:[) ((<'&')`) (`:6)) (a2=. (`(<(":0);_)) (`:6))
>>>> av=. ((af'a0')`) (`(af'a1')) (`(af'a2') ) (`:6)
>>>> NB. Adverbing a monadic verb (adv)
>>>> assert 1 4 9 -: 1 2 3 *: adv
>>>>
>>>> aw=. < o ((0;1;0)&{::) NB. Fetching the atomic representation
>>>>
>>>> u (a3=. (o (train o aw f.)) ('av'f.)) (a4=. "_)
>>>>
>>>> adv=. train o ((af'a4') ; ] ; (af'a3')"_) f.av
>>>> assert 1 4 9 -: 1 2 3 *: adv
>>>> assert 6 -: * (,^:(0:`(<'/'))) adv 1 2 3
>>>> assert 0 1 3 -: (*:`(+/\)) (train f. o (0&{ , (<'-') , 1&{)) adv 1 2 3
>>>>
>>>> a3=. (o (aw f.)) ('av'f.)
>>>>
>>>> Adv=. (train f. @:) (train o ((af'a4') ; ] ; (af'a3')"_) f.av)
>>>> assert 1 4 9 -: 1 2 3 ((<'*:') ; ] ) Adv
>>>> assert 6 -: * (< , ((<'/')"_)) Adv 1
>>>> 2 3
>>>> assert 0 1 3 -: (*:`(+/\)) (0&{ , (<'-') , 1&{)@:(('';1)&{::) Adv 1
>>>> 2 3
>>>>
>>>> Ver=. Cloak o af f. NB. Verbing after fixing a pro-adverb or
>>>> pro-conjunction
>>>> NB. (monadic verb)
>>>> ver=. Cloak o an f. NB. Verbing after fixing an adverb or conjunction
>>>> NB. (monadic verb)
>>>>
>>>> NB. Defining cv in terms of itself...
>>>> cv=. ((rank&_) o < o train)f.adv (>@:) NB. First version
>>>> cv=. (train f. cv at (<x rank _ c)) f.adv NB. Constant verb
>>>> u ( cv=. ( >cv at (<x rank _ c)) f.adv )
>>>> NB. Constant word (adv)
>>>> NB. (cv is to words as c is to nouns)
>>>> assert (CRLF cv _) -: CRLF
>>>> assert (u cv _) <adv -: u <adv
>>>> assert (!@# cv _) <adv -: !@# <adv
>>>> assert (< o ((Ver'cv') o train <'/') _) -: ( < o train (<'/'))
>>>> assert (< o ((Ver'cv') o train <'"') _) -: ( < o train (<'"'))
>>>>
>>>>
>>>> NB. Fetch and From...
>>>> pointers=. (<: o - o i.)`i. @.(0<])
>>>>
>>>> Fetch=. (] amper {:: cv)e o pointers f.adv NB. Verbs mnemonics
>>>> pointers
>>>> NB. (e.g., ( 'u0 u1 u2 u3'=. 4 Fetch ) j ( 'v0 v1 v2 v3'=. _4 Fetch
>>>> ) )
>>>>
>>>> assert (< o train 3 Fetch) -: ( 0&({::) 1&({::) 2&({::)) (< adv)
>>>> assert (< o train _3 Fetch) -: (_3&({::) _2&({::) _1&({::)) (< adv)
>>>>
>>>> From=. (] amper { cv)e o pointers f.adv NB. Verbs mnemonics
>>>> pointers
>>>> NB. From=. (] ([ amper train y)(({ `'')c))e o i. f. adv
>>>> NB. (e.g., ( 'u0 u1 u2 u3'=. 4 From ) j ( 'v0 v1 v2 v3'=. _4 From ) )
>>>>
>>>> assert (< o train 3 From ) -: ( 0&{ 1&{ 2&{ ) (<adv)
>>>> assert (< o train _3 From ) -: (_3&{ _2&{ _1&{ ) (<adv)
>>>>
>>>> Left=. (at [cv)e f.adv
>>>> Right=. (at ]cv)e f.adv
>>>>
>>>> mRS=. (`'') (<&.:train f.av) (`,)(`]) (`:6) (train f. @:
>>>> )(&:(an f.))
>>>> NB. Monadic recursion scope
>>>> assert (1 + (1:`(* $:@<:)@.*) mRS 4) -: 25 NB. Factorial
>>>> fixed
>>>> dRS=. (`'') (<&.:train f.av) (`,) (`]) (,`) ([`) (`:6) (train f. @:
>>>> )(&:(an f.))
>>>> NB. Dyadic recursion scope
>>>> assert (3 (1 + (1:`(%~ * $:&:<:)@.(*@:[))dRS) 7) -: 36 NB.
>>>> Binomial fixed
>>>>
>>>>
>>>> mRS is properly assigned and works as intended from file,
>>>>
>>>>
>>>> mRS
>>>> ((((((`'')(((`'')(&(<&.:(,^:(0:``:)&6 :.(<@:((,'0') ,&<
>>>> ])))@:[)))((`_)(`:6))))(`,))(`]))(`:6))(,^:(0:``:)&6 :.(<@:((,'0') ,&<
>>>> ]))@:))(&:(<@:((,'0') ,&< ])))
>>>>
>>>> but trying to to assign it to this linear representation produces a
>>>> syntax error
>>>>
>>>> mRS =: ((((((`'')(((`'')(&(<&.:(,^:(0:``:)&6 :.(<@:((,'0') ,&<
>>>> ])))@:[)))((`_)(`:6))))(`,))(`]))(`:6))(,^:(0:``:)&6 :.(<@:((,'0') ,&<
>>>> ]))@:))(&:(<@:((,'0') ,&< ])))
>>>> |syntax error
>>>>
>>>>
>>>>
>>>> is this a bug in linear representation? is it directly assignable?
>>>> ----------------------------------------------------------------------
>>>> For information about J forums see http://www.jsoftware.com/forums.htm
>>>
>>>
>> ----------------------------------------------------------------------
>> For information about J forums see http://www.jsoftware.com/forums.htm
>
> ----------------------------------------------------------------------
> For information about J forums see http://www.jsoftware.com/forums.htm
----------------------------------------------------------------------
For information about J forums see http://www.jsoftware.com/forums.htm
----------------------------------------------------------------------
For information about J forums see http://www.jsoftware.com/forums.htm