In
last blog
we extended the superstar quantifier
*{c}
to a row
*{R}
of entries.
Today its entry separator ,
will turn into a structure
,[S]
of unique nested arrays.
This increases at half speed compared to
Bird nests.
Both systems reload empty arrays to maximal size
b
.
§1 Dimensional subarray
We start anew
and let the first nested index [c
count entries on a superstar row.
The next index ,d
counts such rows on a plane.
Further nested indices count multidimensional spaces
in the top array.
Show how to evaluate a top array that is planar,
where S
is the right part of that plane.
With rules for reload and elimination,
on two index levels.
- a*{,[c1,d]1S}b = a*{,[c,d]b,[c1,d]S}b
- a*{,[,d1]S}b = a*{,[b,d]S}b
- a*{,[,]S}b = a*{,[]S}b = a*{S}b
- a*{,[c,d],S}b = a*{,S}b
- a*{,[c,d]}b = a*{}b = ab
Arrays are filled by repeated application ==
of these rules, as they occur in practice in order of evaluation.
The resulting numbers can become just as big as Bird creates with his
angle brackets,
filling all spaces with series of the same array separators.
That is, provided we double our nesting depth.
The seps (separators) our system introduces during an evaluation
have a unique index array.
This is necessary to build expressions step by step.
We don't like the instant repetition that Bird & Bowers
(who continue from Knuth's arrows)
use in their Beaf.
By doubling the depth of a nested array with unique seps,
we occupy the same expression space as an array with multiple similar seps.
We've proved this for
fluid structures
before.
We don't recommend input expressions with more than one sentry,
because of details in the evaluation.
Like, when two seps with the same index array come next,
we cannot just adjoin them and add their entry values.
Reducing expressions ltr
a left subarray will cause reloads, that inflate a right subarray later.
Only single (usually inner) arrays with the same index,
can be merged like that in adjacent positions.
But given that reload by b
is dominant,
we can approximately adjoin similar sentries.
- ,[p,S]m <≈ ,[p,S]m,[q,S]n < ,[pq,S]mn <≈ ,[p,1S]m
Truly bigger numbers are obtained
as we continue to expand the dimensional subarray.
The planes in a cubic array are counted by the 3d nested entry,
the cubic subarrays by the 4th entry, etc.
Until our row of [m]
nested entries captures the level of
multidimensional
arrays in the Beaf project
(they use one nested entry {m} for this).
Note that in the input expression
the dominant last subarrays are quantified alone.
Before we evaluate the earlier subarrays,
the reload rule inflates them to big box size
b
.
§2 Arrays at any depth
Our system for the first nested arrays,
showing the nested depth on white.
Empty entries º
≡
0
can be matched by a lookahead to
,
or ]
in RegExp.
#
- a*{}b = ab (add)
- a*{T}1 = a (unity)
- a*{1T}b1 = a*{T}(a*{1T}b) (powers)
- ,[]1 = 1 (counter)
- ,[S]º = º (sep elim)
- a*{,[1S]1R}b = a*{,[S]b,[1S]R}b (reload to entry)
- a*{,[,[m1]1S]1R}b = a*{,[,[m]b,[m1]S]1R}b (reload to index)
The complete system for nested arrays follows easily,
by generalizing the last two rules.
Search the inner (_{e}
subexpression )_{e}
to work in,
or e=0
the outer expression when all is worked out.
Scan from the left, until some separator
,[S]
matches.
If it reads ,[]
or if an empty º
entry comes next, eliminate that sep.
Else subtract 1
from the next entry,
and insert a sentry formed by the preceding sep
and a big entry b copied from base.
General reload rule for our nested arrays,
at any depth or half level
.
#
- ( ,[1S]1n .b) => ,[S]b,[1S]n (reload)
- ( ,[1S]1º .b) => ,[S]b (reload with sep elim)
We can still write duplicate seps in the input expression,
but all the sep arrays our system inserts
during the evaluation of a single sentry are unique.
This variation could have been exploited to create bigger numbers,
but the comparison with Bird's serial arrays
suggests that wouldn't be a big help.
Our arrays are half nested
,
because at depth d*2
function speed is about equal
to Bird's nested arrays at level d.
This gap is bound to lose significance, once we express nesting depth
as a function of big b in the
next blog
on deeps.
When on a row without indexed seps, as defined in
last blog,
an entry is reduced to zero,
its left comma cannot be eliminated in between.
Only at an array's end can plain commas be dropped, if trailing,
because of their role in positioning right entries.
The arrayless comma that we reused above in
§1
is just a macro
,
≡
,[1]
substituting for the first sep between two innermost entries.
Extending this, the old subsystem can be supplanted here
to count off the deepest array level, when convenient.
We can also imagine array variations with plain sep followed by indexed sep,
where we count down a right sentry until its index is empty,
at last, to reload b
in the plain entry ,0
waiting on the left.
But it is better to avoid such mixed systems.
~~ Half Machine Lip Moves ~
out of Phlegethon,
Gerhart
art thou come forth out of Phlegethon?
with Buxtehude and Klages in your satchel, with the
Ständebuch of Sachs in yr
/ luggage
—
not of one bird but of many
……
Canto LXXV
No comments:
Post a Comment