SHARP APL: Difference between revisions

Jump to navigation Jump to search
→‎Releases: Add Table to release 19
Miraheze>Marshall
(Primitive function tables)
 
(→‎Releases: Add Table to release 19)
(54 intermediate revisions by 6 users not shown)
Line 1: Line 1:
{{Infobox array language
| logo                    = [[File:Sharp APL logo.png]]
| array model              = [[Flat array model|flat]] with [[Box|boxes]]
| index origin            = 0 or 1
| function styles          = [[defined function]]s
| numeric types            = [[complex]] floats
| unicode support          = none
| released                = 1976 via [[time-sharing]]; around 1979 as a product
| withdrawn                = around 1993
| latest release version  = 20 / 1989
| platforms                = S/370, x86
| operating systems        = DOS/390, DOS, UNIX (AIX, Solaris), Linux
| license                  = Free for personal use / Proprietary commercial software
| developer                = [[I.P. Sharp Associates]]
| influenced by            = [[APL\360]]
| influenced              = [[SAX]], [[J]], [[A+]], [[K]], [[Dyalog APL]], [[SHARP APL/HP]]
| file ext                = .saw, .saf, .sam
| download                = [http://www.sigapl.org/Archives/waterloo_archive/apl/sharp.apl/index.html SIGAPL]
}}
[[File:Old SHARP APL.png|thumb|right|SHARP APL running under DOSBox]]
'''SHARP APL''' was an APL implementation offered by [[I.P. Sharp Associates]] (IPSA), originally as part of its [[time-sharing]] service and later as a stand-alone product. It was split off from [[STSC]]'s [[APL*PLUS]], which until then had been sold jointly by the two companies. SHARP APL was the source of many developments in [[flat array theory]], driven by [[Ken Iverson]] and other APL designers at IPSA.
== Releases ==
A partial list of SHARP's major releases is shown.
{|class=wikitable
! Number !! Released !! Features
|-
|        || 1980    || Compress extended to [[Replicate]]; [[LCM]] and [[GCD]]; [[Grade]] on rank >1<ref>IPSA. [https://www.softwarepreservation.org/projects/apl/Manuals/SharpAPLManualCorrections/view SHARP APL Reference Manual Additions and Corrections, June 1981]</ref>
|-
|        || 1981-05  || Enclosed arrays; [[Enclose]] (<syntaxhighlight lang=apl inline><</syntaxhighlight>), [[Mix|Disclose]] (<syntaxhighlight lang=apl inline>></syntaxhighlight>), [[Match]] (<syntaxhighlight lang=apl inline>≡</syntaxhighlight>); operators [[Atop|Over]] (<syntaxhighlight lang=apl inline>⍥</syntaxhighlight>), [[Over|On]] (<syntaxhighlight lang=apl inline>⍤</syntaxhighlight>), [[Under|With]] (<syntaxhighlight lang=apl inline>¨</syntaxhighlight>); [[complex number]]s<ref>IPSA Newsletter July/August 1981 ([https://www.snakeisland.com/IPSANewsletter_1981_07_08.pdf pdf])</ref>
|-
|        || 1982-05  || Generalized [[determinant]] (<syntaxhighlight lang=apl inline>.</syntaxhighlight>); debugging and formatting improvements<ref>IPSA Newsletter July/August 1982 ([https://www.snakeisland.com/IPSANewsletter_1982_07_08.pdf pdf])</ref>
|-
|        || 1982-11  || [[Complex Floor]], Ceiling, and Residue; reference-counted implementation<ref>IPSA Newsletter November/December 1982 ([https://www.snakeisland.com/IPSANewsletter_1982_11_12.pdf pdf])</ref>
|-
| 15    || 1983-05  || [[Rank operator]] and [[Function rank]]; [[Left|Lev]] (<syntaxhighlight lang=apl inline>⊣</syntaxhighlight>), [[Right|Dex]] (<syntaxhighlight lang=apl inline>⊢</syntaxhighlight>), [[Link]] (<syntaxhighlight lang=apl inline>⊃</syntaxhighlight>)<ref>[https://www.jsoftware.com/papers/satn45.htm "Language Extensions of May 1983"]. SATN-45, 1983-05-02.</ref>
|-
| 17    || 1985-01<ref>York University Computer Museum. [http://www.cse.yorku.ca/museum/collections/IPSA/ipsa_col.html SHARP APL collection catalogue].</ref>  ||
|-
| 19    || 1987-03  || Short left argument for [[Take]]/[[Drop]]; [[Table]] (<syntaxhighlight lang=apl inline>⍪</syntaxhighlight>)<ref>[[Robert Bernecky]]. [https://dl.acm.org/citation.cfm?id=55632 An Introduction to Function Rank] at [[APL88]]. [[APL Quote Quad]], Volume 18, Issue 2. December 1987.</ref>
|-
| 20    || 1989-09  || [[Find|In]] (<syntaxhighlight lang=apl inline>⍷</syntaxhighlight>), [[Nubsieve]] (<syntaxhighlight lang=apl inline>≠</syntaxhighlight>), [[Raze]] (<syntaxhighlight lang=apl inline>↓</syntaxhighlight>); padding for [[Mix|Disclose]] (<syntaxhighlight lang=apl inline>></syntaxhighlight>)<ref>[[IPSA]]. [https://archive.org/details/sharp-apl-release-20.0-guide-for-apl-programmers "SHARP APL Release 20.0: Guide for APL Programmers"].</ref>
|}
== Primitive functions ==
== Primitive functions ==


=== Arithmetic ===
The primitives shown here are those for SHARP APL around 1987, near the end of the decline of [[time-sharing]] APL. Some primitives from [[A Dictionary of APL]] were added after this, including [[Find|In]] (<syntaxhighlight lang=apl inline>⍷</syntaxhighlight>), [[Nubsieve]] (<syntaxhighlight lang=apl inline>≠</syntaxhighlight>), and [[Raze]] (<syntaxhighlight lang=apl inline>↓</syntaxhighlight>), and these appear in [[SAX]].


==== Scalar ====
=== Scalar ===


All scalar functions have rank zero.
All scalar functions have rank zero.
Line 10: Line 56:
! Glyph                              !! Monadic                !! Dyadic
! Glyph                              !! Monadic                !! Dyadic
|-
|-
| <source lang=apl inline>+</source> || [[Conjugate]]/Identity || [[Addition]]
| <syntaxhighlight lang=apl inline>+</syntaxhighlight> || [[Conjugate]]                 || [[Addition]]
|-
| <syntaxhighlight lang=apl inline>-</syntaxhighlight> || [[Negate]]                    || [[Subtraction]]
|-
| <syntaxhighlight lang=apl inline>×</syntaxhighlight> || [[Signum]]                    || [[Multiplication]]
|-
| <syntaxhighlight lang=apl inline>÷</syntaxhighlight> || [[Reciprocal]]                || [[Division]]
|-
| <syntaxhighlight lang=apl inline>*</syntaxhighlight> || [[Exponential]]                || [[Power (function)|Power]]
|-
|-
| <source lang=apl inline>-</source> || [[Negate]]             || [[Subtraction]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> || [[Natural Logarithm]]         || [[Logarithm|Base-⍺ Logarithm]]
|-
|-
| <source lang=apl inline>×</source> || [[Signum]]             || [[Multiplication]]
| <syntaxhighlight lang=apl inline>|</syntaxhighlight> || [[Magnitude]]                 || [[Residue]]
|-
|-
| <source lang=apl inline>÷</source> || [[Reciprocal]]         || [[Division]]
| <syntaxhighlight lang=apl inline>!</syntaxhighlight> || [[Factorial]]                 || [[Binomial]]
|-
|-
| <source lang=apl inline>*</source> || [[Exponential]]       || [[Power function|Power]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> || [[Floor]]                     || [[Minimum]]
|-
|-
| <source lang=apl inline></source> || [[Natural Logarithm]] || [[Logarithm|Base-⍺ Logarithm]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> || [[Ceiling]]                   || [[Maximum]]
|-
|-
| <source lang=apl inline>|</source> || [[Magnitude]]         || [[Residue]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> || [[Pi Times]]                   || [[Circle functions]]
|-
|-
| <source lang=apl inline>!</source> || [[Factorial]]         || Out-Of/[[Combinations]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> ||                                || [[And]]/[[LCM]]
|-
|-
| <source lang=apl inline></source> || [[Floor]]             || [[Minimum]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> ||                                || [[Or]]/[[GCD]]
|-
|-
| <source lang=apl inline></source> || [[Ceiling]]            || [[Maximum]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> ||                               || [[Nand]]
|-
|-
| <source lang=apl inline></source> || [[Pi Times]]          || [[Circle functions]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> ||                               || [[Nor]]
|-
|-
| <source lang=apl inline></source> ||                        || [[And]]/Least Common Multiple (LCM)
| <syntaxhighlight lang=apl inline>~</syntaxhighlight> || [[Not]]                       ||
|-
|-
| <source lang=apl inline></source> ||                       || [[Or]]/Greatest Common Divisor (GCD)
| <syntaxhighlight lang=apl inline>?</syntaxhighlight> || [[Roll]]                      || See [[#Non-scalar|Non-scalar]]
|-
|-
| <source lang=apl inline></source> ||                       || [[Nand]]
| <syntaxhighlight lang=apl inline>=</syntaxhighlight> ||                               || [[Equals]]
|-
|-
| <source lang=apl inline></source> ||                       || [[Nor]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> ||                               || [[Not Equals]]
|-
|-
| <source lang=apl inline>~</source> || [[Not]]               || See [[#Miscellaneous|Miscellaneous]]
| <syntaxhighlight lang=apl inline><</syntaxhighlight> || See [[#Non-scalar|Non-scalar]] || [[Less Than]]
|-
|-
| <source lang=apl inline>?</source> || [[Roll]]               || See [[#Non-Scalar|Non-scalar]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> ||                                || [[Less Than or Equal]]
|-
| <syntaxhighlight lang=apl inline>≥</syntaxhighlight> ||                                || [[Greater Than or Equal]]
|-
| <syntaxhighlight lang=apl inline>></syntaxhighlight> || See [[#Non-scalar|Non-scalar]] || [[Greater Than]]
|}
|}


==== Non-scalar ====
=== Non-scalar ===


{| class=wikitable
{| class=wikitable
! Glyph                          !! Rank !! Monadic              !! Ranks !! Dyadic
! Glyph                          !! Rank !! Monadic              !! Ranks !! Dyadic
|-
|-
| <source lang=apl inline>⌹</source> || 2 || [[Matrix inverse]]     || ∞ 2 || [[Matrix divide]]
| <syntaxhighlight lang=apl inline>⌹</syntaxhighlight> || 2 || [[Matrix inverse]]             || ∞ 2 || [[Matrix divide]]
|-
| <syntaxhighlight lang=apl inline>?</syntaxhighlight> ||  || See [[#Scalar|Scalar]]          || * * || [[Deal]]
|-
| <syntaxhighlight lang=apl inline>⊤</syntaxhighlight> ||  ||                                || ∞ ∞ || [[Encode]]
|-
| <syntaxhighlight lang=apl inline>⊥</syntaxhighlight> ||  ||                                || ∞ ∞ || [[Decode]]
|-
| <syntaxhighlight lang=apl inline>≡</syntaxhighlight> ||  ||                                || ∞ ∞ || [[Match]]
|-
| <syntaxhighlight lang=apl inline>∊</syntaxhighlight> ||  ||                                || 0 ∞ || [[Membership]]
|-
| <syntaxhighlight lang=apl inline>⍳</syntaxhighlight> || 1 || [[Index Generator|Count]]      || 1 0 || [[Index Of]]
|-
|-
| <source lang=apl inline>?</source> ||   || See [[#Scalar|Scalar]] || * * || [[Deal]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> || || Numeric [[Grade up]]           || ∞ ∞ || Character [[Grade up]]
|-
|-
| <source lang=apl inline></source> ||   ||                       || ∞ ∞ || [[Encode]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> || || Numeric [[Grade down]]          || ∞ ∞ || Character [[Grade down]]
|-
|-
| <source lang=apl inline></source> ||  ||                        || ∞ ∞ || [[Decode]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> || ∞ || [[Shape|Shape of]]              || 1 ∞ || [[Reshape]]
|-
| <syntaxhighlight lang=apl inline>↑</syntaxhighlight> ||  ||                                || 1 ∞ || [[Take]]
|-
| <syntaxhighlight lang=apl inline>↓</syntaxhighlight> ||  ||                                 || 1 ∞ || [[Drop]]
|-
| <syntaxhighlight lang=apl inline><</syntaxhighlight> || ∞ || [[Enclose]]                    ||    || See [[#Scalar|Scalar]]
|-
| <syntaxhighlight lang=apl inline>⊃</syntaxhighlight> || ∞ || [[Conditional enclose]]        || ∞ ∞ || [[Link]]
|-
| <syntaxhighlight lang=apl inline>></syntaxhighlight> || 0 || [[Mix|Disclose]]                    ||    || See [[#Scalar|Scalar]]
|-
| <syntaxhighlight lang=apl inline>,</syntaxhighlight> || ∞ || [[Ravel]]                      || ∞ ∞ || [[Catenate]]
|-
| <syntaxhighlight lang=apl inline>⍪</syntaxhighlight> || ∞ || [[Table]]                      || ∞ ∞ || [[Catenate First]]
|-
| <syntaxhighlight lang=apl inline>⌽</syntaxhighlight> || 1 || [[Reverse]]                    || 0 1 || [[Rotate]]
|-
| <syntaxhighlight lang=apl inline>⊖</syntaxhighlight> || ∞ || [[Reverse First]]              || ∞ ∞ || [[Rotate First]]
|-
| <syntaxhighlight lang=apl inline>⍉</syntaxhighlight> || ∞ || Monadic [[Transpose]]          || 0 ∞ || Dyadic [[Transpose]]
|-
| <syntaxhighlight lang=apl inline>⊣</syntaxhighlight> || ∞ || [[Stop]]                       || ∞ ∞ || [[Left Identity|Left]]
|-
| <syntaxhighlight lang=apl inline>⊢</syntaxhighlight> || ∞ || [[Identity|Pass]]              || ∞ ∞ || [[Right Identity|Right]]
|-
| <syntaxhighlight lang=apl inline>⍕</syntaxhighlight> || ∞ || [[Monadic Format]]              || * ∞ || [[Dyadic Format]]
|-
| <syntaxhighlight lang=apl inline>⍎</syntaxhighlight> || * || [[Execute]]                    ||    ||
|}
|}


=== Relational ===
== Primitive Operators ==


{| class=wikitable
{| class=wikitable
! Glyph                           !! Rank !! Monadic                            !! Ranks !! Dyadic
! Glyph !!colspan=2|Operands !!colspan=2|Ranks !! Monadic Call  !! Dyadic Call
|-
| <syntaxhighlight lang=apl inline>/</syntaxhighlight> ||                                    || <syntaxhighlight lang=apl inline>f</syntaxhighlight> || <syntaxhighlight lang=apl inline>∞</syntaxhighlight>  ||                                        || [[Reduce]]                      ||
|-
| <syntaxhighlight lang=apl inline>⌿</syntaxhighlight> ||                                    || <syntaxhighlight lang=apl inline>f</syntaxhighlight> || <syntaxhighlight lang=apl inline>∞</syntaxhighlight>  ||                                        || [[Reduce First]]                ||
|-
| <syntaxhighlight lang=apl inline>\</syntaxhighlight> ||                                    || <syntaxhighlight lang=apl inline>f</syntaxhighlight> || <syntaxhighlight lang=apl inline>∞</syntaxhighlight>  ||                                        || [[Scan]]                        ||
|-
| <syntaxhighlight lang=apl inline>⍀</syntaxhighlight> ||                                    || <syntaxhighlight lang=apl inline>f</syntaxhighlight> || <syntaxhighlight lang=apl inline>∞</syntaxhighlight>  ||                                        || [[Scan First]]                  ||
|-
| <syntaxhighlight lang=apl inline>/</syntaxhighlight> ||                                    || <syntaxhighlight lang=apl inline>m</syntaxhighlight> || <syntaxhighlight lang=apl inline>∞</syntaxhighlight>  ||                                        || [[Replicate]]                  ||
|-
| <syntaxhighlight lang=apl inline>⌿</syntaxhighlight> ||                                    || <syntaxhighlight lang=apl inline>m</syntaxhighlight> || <syntaxhighlight lang=apl inline>∞</syntaxhighlight>  ||                                        || [[Replicate First]]            ||
|-
| <syntaxhighlight lang=apl inline>\</syntaxhighlight> ||                                    || <syntaxhighlight lang=apl inline>m</syntaxhighlight> || <syntaxhighlight lang=apl inline>∞</syntaxhighlight>  ||                                        || [[Expand]]                      ||
|-
|-
| <source lang=apl inline>=</source> ||   || See [[#Miscellaneous|Miscellaneous]] || 0 0 || [[Equals]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> ||                                   || <syntaxhighlight lang=apl inline>m</syntaxhighlight> || <syntaxhighlight lang=apl inline>∞</syntaxhighlight>  ||                                       || [[Expand First]]               ||
|-
|-
| <source lang=apl inline></source> ||   || See [[#Miscellaneous|Miscellaneous]] || 0 0 || [[Not Equals]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> || <syntaxhighlight lang=apl inline>f</syntaxhighlight> || <syntaxhighlight lang=apl inline>g</syntaxhighlight> || <syntaxhighlight lang=apl inline>mg</syntaxhighlight> || <syntaxhighlight lang=apl inline>mg mg</syntaxhighlight> ||colspan=2| On ([[close Over]])
|-
|-
| <source lang=apl inline><</source> ||   || See [[#Structural|Structural]]      || 0 0 || [[Less Than]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> || <syntaxhighlight lang=apl inline>f</syntaxhighlight> || <syntaxhighlight lang=apl inline>n</syntaxhighlight> || <syntaxhighlight lang=apl inline>n</syntaxhighlight>  || <syntaxhighlight lang=apl inline>n  n</syntaxhighlight>  ||colspan=2| [[Rank operator|Rank]]
|-
|-
| <source lang=apl inline></source> ||   ||                                     || 0 0 || [[Less Than or Equal]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> || <syntaxhighlight lang=apl inline>m</syntaxhighlight> || <syntaxhighlight lang=apl inline>g</syntaxhighlight> || <syntaxhighlight lang=apl inline>mg</syntaxhighlight> || <syntaxhighlight lang=apl inline>mg mg</syntaxhighlight> ||colspan=2| [[Cut]]
|-
|-
| <source lang=apl inline></source> ||   ||                                     || 0 0 || [[Greater Than or Equal]]
| <syntaxhighlight lang=apl inline></syntaxhighlight> || <syntaxhighlight lang=apl inline>f</syntaxhighlight> || <syntaxhighlight lang=apl inline>g</syntaxhighlight> || <syntaxhighlight lang=apl inline>mg</syntaxhighlight> || <syntaxhighlight lang=apl inline>mg mg</syntaxhighlight> ||colspan=2| Upon ([[close Atop]])
|-
|-
| <source lang=apl inline>></source> ||   || See [[#Structural|Structural]]      || 0 0 || [[Greater Than]]
| <syntaxhighlight lang=apl inline>¨</syntaxhighlight> || <syntaxhighlight lang=apl inline>f</syntaxhighlight> || <syntaxhighlight lang=apl inline>g</syntaxhighlight> || <syntaxhighlight lang=apl inline>mg</syntaxhighlight> || <syntaxhighlight lang=apl inline>mg mg</syntaxhighlight> ||colspan=2| [[close Under|Dual]]
|-
|-
| <source lang=apl inline></source> ||   ||                                     || ∞ ∞ || [[Match]]
| <syntaxhighlight lang=apl inline>¨</syntaxhighlight> || <syntaxhighlight lang=apl inline>m</syntaxhighlight> || <syntaxhighlight lang=apl inline>g</syntaxhighlight> || <syntaxhighlight lang=apl inline>mg</syntaxhighlight> ||                                       ||rowspan="2"|With ([[Bind]])    ||
|-
|-
| <source lang=apl inline></source> ||   ||                                     || 0 ∞ || [[Membership]]
| <syntaxhighlight lang=apl inline>¨</syntaxhighlight> || <syntaxhighlight lang=apl inline>f</syntaxhighlight> || <syntaxhighlight lang=apl inline>n</syntaxhighlight> || <syntaxhighlight lang=apl inline>mf</syntaxhighlight> ||                                       ||
|-
|-
| <source lang=apl inline></source> ||   ||                                     || ∞ ∞ || [[Find]]
| <syntaxhighlight lang=apl inline>.</syntaxhighlight> || <syntaxhighlight lang=apl inline>f</syntaxhighlight> || <syntaxhighlight lang=apl inline>g</syntaxhighlight> || <syntaxhighlight lang=apl inline>2</syntaxhighlight>  || <syntaxhighlight lang=apl inline>∞  ∞</syntaxhighlight>  || [[Determinant]]                || [[Inner Product]]
|-
| <syntaxhighlight lang=apl inline>.</syntaxhighlight> || <syntaxhighlight lang=apl inline>m</syntaxhighlight> || <syntaxhighlight lang=apl inline>g</syntaxhighlight> ||                                     || <syntaxhighlight lang=apl inline> </syntaxhighlight>  ||                                || [[Outer Product]]
|}
|}


=== Indexing ===
== Implementation ==


{| class=wikitable
=== Numeric types ===
! Glyph                          !! Rank !! Monadic                            !! Ranks !! Dyadic
 
SHARP originally supported only real numbers using double (8-byte) precision. Numbers were stored in one of three types:
* Boolean, with one bit per value
* Integer, with four bytes per value
* Floating, with eight bytes per value
 
[https://www.jsoftware.com/papers/satn40.htm SATN-40] describes the addition of complex numbers to SHARP APL.
 
== SHARP APL Technical Notes ==
 
Features of SHARP APL were documented in "technical notes" issued by IPSA. These notes are numbered following the scheme "SATN-0". Earlier notes typically had no author listed. A [https://www.jsoftware.com/papers/SATN.pdf pdf collection] of SHARP APL Technical Notes is hosted at jsoftware.com, as are html transcriptions of some notes, linked in the table below.
 
{|class=wikitable
! Number !! Issued !!colspan=2| Revised !! Author            !! Title
|-
|  0 || 1976-01-01 ||  ||            ||                      || SATN Introduction
|-
|  1 || 1976-01-01 ||  ||            ||                      || TASKID
|-
|  2 ||            || 5 || 1979-02-14 ||                      || Control Messages
|-
|  3 || 1976-01-01 ||  ||            ||                      || ⎕OUT
|-
|  4 ||            || 2 || 1978-04-01 ||                      || N-tasks and B-tasks
|-
|  5 ||            || 2 || 1978-08-01 ||                      || Batch APL
|-
|  6 || 1976-01-01 ||  ||            ||                      || [[Execute]]
|-
|  7 || 1976-01-01 ||  ||            ||                      || Latent Expression
|-
|  8 ||            || 2 || 1978-03-01 ||                      || HSPRINT
|-
|  9 ||            || 1 || 1979-08-01 || John D. Burger      || Usage Inquiry System
|-
| 10 ||            || 2 || 1978-06-01 ||                      || SORTREQ
|-
| 11 || 1976-01-01 ||  ||            ||                      || )RESET
|-
| 12 || 1976-01-01 ||  ||            ||                      || )COPY
|-
| 13 || 1978-03-10 ||  ||            ||                      || Early Warnings
|-
| 14 ||            || 2 || 1978-08-15 ||                      || Package - A New Variable Type
|-
| 15 ||            ||  ||            ||                      || Index
|-
| 16 || 1976-04-20 ||  ||            ||                      || File System Must-Write Buffers
|-
| 17 || 1976-06-01 ||  ||            ||                      || Formatting Primitive
|-
| 18 || 1976-07-01 ||  ||            ||                      || ⎕FMT
|-
| 19 || 1977-01-01 ||  ||            ||                      || Fileprint
|-
| 20 ||            || 4 || 1978-06-01 ||                      || System Variables, Session Variables and System Functions
|-
| 21 ||            || 1 || 1978-06-01 ||                      || ⎕WS and ⎕FD
|-
|-
| <source lang=apl inline>@</source> ||   || See [[#Miscellaneous|Miscellaneous]] || 0 ∞ || [[Squad Index|From]]
| 22 ||           || 2 || 1979-01-01 || [[Bob Bernecky]] and Mike Symes || APL Worspace Transfer
|-
|-
| <source lang=apl inline>⍳</source> || 1 || [[Iota|Count]]                       || 1 0 || [[Index Of]]
| 23 || 1977-06-10 || 1 || 1978-07-15 || [[Bob Bernecky]]     || [[Comparison tolerance|Comparison Tolerance]] ([https://www.jsoftware.com/papers/satn23.htm web])
|-
|-
| <source lang=apl inline>⍸</source> ||  ||                                     || ∞ ∞ || [[Indices of Match|Index]]
| 24 || 1977-03-23 ||  ||           ||                     || Symbol Table
|-
|-
| <source lang=apl inline>⍋</source> || || Numeric [[Grade up]]                || ∞ ∞ || Character [[Grade up]]
| 25 || 1977-05-15 ||   ||           ||                     || Extensions to Argument Passing
|-
|-
| <source lang=apl inline>⍒</source> || || Numeric [[Grade down]]              || ∞ ∞ || Character [[Grade down]]
| 26 || 1977-09-10 ||   ||           ||                     || Enhancements to the File System
|}
 
=== Structural ===
 
{| class=wikitable
! Glyph                          !! Rank !! Monadic                                !! Ranks !! Dyadic
|-
|-
| <source lang=apl inline>⍴</source> || || [[Shape|Shape of]]                        || 1 ∞ || [[Reshape]]
| 28 || 1977-07-11 ||   ||           ||                     || Terminal Control
|-
|-
| <source lang=apl inline>↑</source> ||  || See [[#Miscellaneous|Miscellaneous]]      || 1 ∞ || [[Take]]
| 29 || 1978-06-15 ||  ||           ||                     || System Time and Timestamps
|-
|-
| <source lang=apl inline>↓</source> || || [[Raze]]                                  || 1 ∞ || [[Drop]]
| 30 || 1979-01-01 ||   ||           ||                     || Numeric Display
|-
|-
| <source lang=apl inline><</source> || || [[Enclose]]/Box                          ||     || See [[#Relational|Relational]]
| 31 || 1979-02-01 ||   ||            ||                     || [[Line editor|Line Editing]] in SHARP APL
|-
|-
| <source lang=apl inline>⊃</source> || || [[Enclose if simple|Conditional Enclose]] || ∞ ∞ || [[Link]]
| 32 || 1979-03-30 ||   ||           ||                     || Shared Variables
|-
|-
| <source lang=apl inline>></source> || 0 || [[Disclose]]/Open                        ||     || See [[#Relational|Relational]]
| 33 || 1979-03-26 ||   ||           ||                     || Event Trapping
|-
|-
| <source lang=apl inline>,</source> || || [[Ravel]]                                 || ∞ ∞ || [[Catenate]]
| 34 || 1980-08-15 ||  ||            || [[Bob Bernecky]]     || [[Replicate|Replication]]
|-
|-
| <source lang=apl inline>⍪</source> || || [[Table]]                                || ∞ ∞ || [[Catenate First|Catenate-Down]]
| 35 || 1980-08-15 ||   ||            || Peter Wooster        || Extended [[Grade|Upgrade and Downgrade]]
|-
|-
| <source lang=apl inline>⌽</source> || 1 || [[Reverse]]                               || 0 1 || [[Rotate]]
| 36 || 1980-04-20 ||  ||            || [[Ken Iverson]]     || [[Direct definition (notation)|Direct Definition]]
|-
|-
| <source lang=apl inline>⊖</source> || || [[Reverse First|Reverse-Down]]            || ∞ ∞ || [[Rotate First|Rotate-Down]]
| 37 ||           || 1 || 1982-06-01 || John D. Burger      || IBM 3270 User Guide
|-
|-
| <source lang=apl inline>⍉</source> || || Monadic [[Transpose]]                    || 0 ∞ || Dyadic [[Transpose]]
| 39 || 1981-06-01 ||   ||           || [[Richard Lathwell]] || [https://www.jsoftware.com/papers/satn39.htm The SHARP APL S-task Interface]
|}
 
=== Miscellaneous ===
 
{| class=wikitable
! Glyph                          !! Rank !! Monadic                !! Ranks !! Dyadic
|-
|-
| <source lang=apl inline>⊣</source> || || [[Stop]]                 || ∞ ∞ || [[Left Identity|Left]]
| 40 || 1981-06-20 ||  ||           || [[Eugene McDonnell]] || [[Complex number|Complex Numbers]] ([https://www.jsoftware.com/papers/satn40.htm web])
|-
|-
| <source lang=apl inline>⊢</source> || || [[Identity|Pass]]         || ∞ ∞ || [[Right Identity|Right]]
| 41 || 1981-06-20 ||  ||           || [[Ken Iverson]]     || [[Close composition|Composition]] and [[Box function|Enclosure]] ([https://www.jsoftware.com/papers/satn41.htm web])
|-
|-
| <source lang=apl inline>≠</source> || || [[Nubsieve]]             ||    || See [[#Relational|Relational]]
| 42 || 1982-04-01 ||  ||           || [[Ken Iverson]]     || [[Determinant]]-Like Functions Produced by the Dot-Operator ([https://www.jsoftware.com/papers/satn42.htm web])
|-
|-
| <source lang=apl inline>↑</source> || || [[Nub]]                  ||     || See [[#Structural|Structural]]
| 43 || 1982-11-05 ||   ||           || Peter Wooster        || Improved Display for Enclosed Arrays and a New System Variable ⎕PS
|-
|-
| <source lang=apl inline>=</source> || || [[Nubin]]                ||     || See [[#Relational|Relational]]
| 44 || 1983-04-02 ||   ||           || Robert C. Metzger    || Enhancements to Event Handling
|-
|-
| <source lang=apl inline>~</source> ||  || See [[#Scalar|Scalar]]    || ∞ ∞ || [[Without|Less]]
| 45 || 1983-05-02 ||  ||           || Various              || [https://www.jsoftware.com/papers/satn45.htm Language Extensions of May 1983]
|-
|-
| <source lang=apl inline>@</source> || 1 || [[Cartesian Product|All]] ||     || See [[#Indexing|Indexing]]
| 46 || 1983-08-05 ||  ||            || [[Eric Iverson]]    || Enhancements Provided in Update #1 to the May 1983 Release of SHARP APL
|-
|-
| <source lang=apl inline>⍕</source> || || [[Monadic Format]]        || * ∞ || [[Dyadic Format]]
| 47 || 1983-10-01 ||   ||           || Mike Symes          || IBM 3270 User Guide (IDSH)
|-
|-
| <source lang=apl inline>⍎</source> || * || [[Execute]]              ||     ||
| 48 || 1983-11-30 ||   ||           || John D. Burger      || Workspace 1 HCPRINT
|}
|}
== References ==
<references/>
{{APL dialects}}[[Category:APL dialects]][[Category:Flat array languages]][[Category:Leading axis languages]]

Navigation menu