Kenneth E. Iverson

From Wikipedia, the free encyclopedia
Jump to: navigation, search
Kenneth Eugene Iverson
Born (1920-12-17)December 17, 1920
Camrose, Alberta, Canada
Died October 19, 2004(2004-10-19) (aged 83)
Toronto, Ontario, Canada
Citizenship Canadian
Fields Mathematics
Computer Science
Institutions Harvard University
IBM
I. P. Sharp Associates
Jsoftware Inc.
Alma mater Queen’s University
Harvard University
Thesis Machine Solutions of Linear Differential Equations — Applications to a Dynamic Economic Model (1954)
Doctoral advisor Howard Aiken
Wassily Leontief
Known for Programming languages: APL, J
Notable awards IBM Fellow
Harry H. Goode Memorial Award
Turing Award
Computer Pioneer Award

Kenneth Eugene Iverson (17 December 1920 – 19 October 2004) was a Canadian computer scientist noted for the development of the APL programming language. He was honored with the Turing Award in 1979 "for his pioneering effort in programming languages and mathematical notation resulting in what the computing field now knows as APL; for his contributions to the implementation of interactive systems, to educational uses of APL, and to programming language theory and practice".[1]

Life[edit]

Ken Iverson was born on December 17, 1920 near Camrose, a town in central Alberta, Canada. His parents were farmers who came to Alberta from North Dakota; his ancestors came from Trondheim, Norway.[2]

During World War II, he served first in the Canadian Army and then in the Royal Canadian Air Force.[2][3] He received a B.A. degree from Queen’s University and the M.Sc. and Ph.D. degrees from Harvard University. In his career, he worked for Harvard, IBM, I. P. Sharp Associates, and Jsoftware Inc. (née Iverson Software Inc.).

Iverson suffered a stroke while working at the computer on a new J lab on 16 October 2004, and died on 19 October 2004 at the age of 83.[4]

Education[edit]

Iverson started school on 1 April 1926 in a one-room school,[3] initially in Grade 1, promoted to Grade 2 after 3 months and to Grade 4 by the end of June 1927. He left school after Grade 9 because it was the depths of the Depression and there was work to do on the family farm, and because he thought further schooling only led to becoming a schoolteacher and he had no desire to become one. At age 17, while still out of school, he enrolled in a correspondence course on radios with De Forest Training in Chicago, and learned calculus by self-study from a textbook.[3][5] During World War II, while serving in the Royal Canadian Air Force, he took correspondence courses toward a high school diploma.

After the war, Iverson enrolled in Queen’s University in Kingston, Ontario, taking advantage of government support for ex-servicemen and under threat from an Air Force buddy who said he would "beat his brains out if he did not grasp the opportunity".[3] He graduated in 1950 as the top student with a Bachelor’s degree in Mathematics and Physics.[2]

Continuing his education at Harvard University, he started in the Department of Mathematics and received a Master’s degree in 1951. He then switched to the Department of Engineering and Applied Physics, working with Howard Aiken and Wassily Leontief.

Kenneth Iverson has recalled graduate study under Aiken as "like an apprenticeship" in which the student "learned the tools of the scholarship trade". Every topic was "used more as a focus for the development of skills such as clarity of thought and expression than as an end in itself". Once admitted to the program, a graduate student underwent a rite of "adoption into the fold". He was given a desk (or a share of a desk) among a group of other graduate students, the permanent staff, or visiting scholars, "most of whom were engaged in some aspect of the design and building of computers". A student was thus "made to feel part of a scholarly enterprise" and was provided, "often for the first time, with easy and intimate access to others more experienced in his chosen field".
I. Bernard Cohen, Howard Aiken: Portrait of a Computer Pioneer, MIT Press, 1999, page 215.[6]
When interviewing Aiken, I had asked him whether Tropp and I might see his lecture notes; Aiken replied that he had always destroyed his lecture notes at the end of each year, so that he would not be tempted to repeat his lectures.
I. Bernard Cohen and Gregory W. Welch, editors, Makin’ Numbers, MIT Press, 1999, page xvi.[7]

Howard Aiken had developed the Harvard Mark I, one of the first large-scale digital computers, while Wassily Leontief was an economist who was developing the input-output model of economic analysis, work for which he would later receive the Nobel prize. Leontief’s model required large matrices and Iverson worked on programs that could evaluate these matrices on the Harvard Mark IV computer. Iverson received a Ph.D. in Applied Mathematics in 1954 with a dissertation based on this work.[8][9]

At Harvard, Iverson met Eoin Whitney, a Putnam Fellow and fellow graduate student from Alberta.[10][11] This had future ramifications.

Work[edit]

Harvard (1955–1960)[edit]

Simplex algorithm in Iverson notation[12][13]

Iverson stayed on at Harvard as an assistant professor to implement the world’s first graduate program in "automatic data processing".[14][15]

Many people think that Aiken was interested only in scientific computers. This was simply not so. During one coffee hour, Aiken turned to Ken Iverson, who had just finished his Ph.D., and said: "These machines are going to be immensely important for business, and I want you prepare and teach a course in business data processing next fall." There had never been such a course anywhere in the world. Ken was qualified only because he was a mathematician. I was so excited by the prospect that I immediately volunteered to be Ken’s graduate teaching assistant.
Frederick Brooks Jr., Aiken and the Harvard "Comp Lab", in I. Bernard Cohen and Gregory W. Welch, editors, Makin’ Numbers, MIT Press, 1999, page 141.[7]

It was in this period that Iverson developed notation for describing and analyzing various topics in data processing, for teaching classes, and for writing (with Brooks) Automatic Data Processing.[16] He was "appalled" to find that conventional mathematical notation failed to fill his needs, and began work on extensions to the notation that were more suitable. In particular, he adopted the matrix algebra used in his thesis work, the systematic use of matrices and higher-dimensional arrays in tensor analysis, and operators in the sense of Heaviside in his treatment of Maxwell’s equations, higher-order functions on function argument(s) with a function result.[3] The notation was also field-tested in the business world in 1957 during a 6-month sabbatical spent at McKinsey & Company.[3][17] The first published paper using the notation was The Description of Finite Sequential Processes, initially Report Number 23 to Bell Labs and later revised and presented at the Fourth London Symposium on Information Theory in August 1960.[12][18]

Iverson stayed at Harvard for five years but failed to get tenure, because "[he hadn’t] published anything but the one little book".[2]

IBM (1960–1980)[edit]

Iverson joined IBM Research in 1960 (and doubled his salary).[3] He was preceded to IBM by Fred Brooks, who advised him to "stick to whatever [he] really wanted to do, because management was so starved for ideas that anything not clearly crazy would find support." In particular, he was allowed to finish and publish A Programming Language[18][19] and (with Brooks) Automatic Data Processing,[16] two books that described and used the notation developed at Harvard. (Automatic Data Processing and A Programming Language started as one book "but the material grew in both magnitude and level until a separation proved wise".[16][19])

At IBM, Iverson soon met Adin Falkoff, and they worked together for the next twenty years. Chapter 2 of A Programming Language used Iverson’s notation to describe the IBM 7090 computer.[18][19] In early 1963 Falkoff, later joined by Iverson and Ed Sussenguth, proceeded to use the notation to produce a formal description of the IBM System/360 computer then under design.[20] The result was published in 1964 in a double issue of the IBM Systems Journal,[21] thereafter known as the "grey book" or "grey manual". The book was used in a course on computer systems design at the IBM Systems Research Institute.[21] A consequence of the formal description was that it attracted the interest of bright young minds.[3][22] One hotbed of interest was at Stanford University which included Larry Breed, Phil Abrams, Roger Moore, Charles Brenner,[23] and Mike Jenkins,[24][25] all of whom later made contributions to APL. Donald McIntyre, head of geology at Pomona College which had the first general customer installation of a 360 system, used the formal description to become more expert than the IBM systems engineer assigned to Pomona.[3][26]

With the completion of the formal description Falkoff and Iverson turned their attention to implementation. This work was brought to rapid fruition in 1965 when Larry Breed and Phil Abrams joined the project. They produced a FORTRAN-based implementation on the 7090 called IVSYS by autumn 1965, first in batch mode and later (in early 1966) in time-shared interactive mode.[23][27][28] Subsequently, Breed, Dick Lathwell (ex University of Alberta), and Roger Moore (of I. P. Sharp Associates) produced the System/360 implementation;[29] the three received the Grace Murray Hopper Award in 1973 "for their work in the design and implementation of APL\360, setting new standards in simplicity, efficiency, reliability and response time for interactive systems."[30] While the 360 implementation work was underway "Iverson notation"[28][31] was renamed "APL", by Falkoff.[32] APL\360 first became available within IBM at 1966-11-27 22.53.58 UTC[22] and outside IBM in 1968.[27] Additional information on the implementation of APL\360 can be found in the Acknowledgements of the APL\360 User’s Manual[33] and in "Appendix. Chronology of APL development" of The Design of APL.[20]

APL expression for depth of parentheses nesting [34][35]

The formal description and especially the implementation drove the evolution of the language, a process of consolidation and regularization in typography, linearization, syntax, and function definition described in APL\360 History,[36] The Design of APL,[20] and The Evolution of APL.[17] Two treatises from this period, Conventions Governing the Order of Evaluation[37] and Algebra as a Language,[38] are apologias of APL notation.

The notation was used by Falkoff and Iverson to teach various topics at various universities and at the IBM Systems Research Institute.[20][36] In 1964 Iverson used the notation in a one-semester course for seniors at the Fox Lane High School,[32][39] and later in Swarthmore High School.[3] After APL became available its first application was to teach formal methods in systems design at NASA Goddard.[36][40] It was also used at the Hotchkiss School,[23] Lower Canada College,[41] Scotch Plains High School,[42] Atlanta public schools,[43][44] among others. In one school the students became so eager that they broke into the school after hours to get more APL computer time;[22][45] in another the APL enthusiasts steered newbies to BASIC so as to maximize their own APL time.[23]

In 1969, Iverson and the APL group inaugurated the IBM Philadelphia Scientific Center.[27][36] In 1970 he was named IBM Fellow.[46] He used the funding that came with being an IBM Fellow to bring in visiting teachers and professors from various fields, including Donald McIntyre from Pomona[26] and Jeff Shallit as a summer student.[22] For a period of several months the visitors would start using APL for expositions in their own fields, and the hope was that later they would continue their use of APL at their home institutions.[47] Iverson’s work at this time centered in several disciplines, including collaborative projects in circuit theory, genetics, geology, and calculus.[48][49][50][51] When the PSC closed in 1974,[27][32] some of the group transferred to California while others including Iverson remained in the East, later transferring back to IBM Research. Iverson received the Turing Award in 1979.[1]

The following table lists the publications which Iverson authored or co-authored while he was at IBM. They reflect the two main strands of his work.

Education
  • Automatic Data Processing[16]
  • Elementary Functions: An Algorithmic Treatment[39]
  • The Use of APL in Teaching[52]
  • Using the Computer to Compute[53]
  • Algebra: An Algorithmic Treatment[54]
  • APL in Exposition[55]
  • An Introduction to APL for Scientists and Engineers[56]
  • Introducing APL to Teachers[57]
  • Elementary Analysis[58]
  • Programming Style in APL[59]
Language design & implementation
  • A Programming Language[19]
  • A Programming Language[60]
  • A Common Language for Hardware, Software, and Applications[61]
  • Programming Notation in System Design[62]
  • Formalism in Programming Languages[63]
  • A Formal Description of System/360[21]
  • APL\360 User’s Manual[33]
  • Communication in APL Systems[64]
  • APLSV User’s Manual[65]
  • APL Language[66]
  • The Design of APL[20]
  • Two Combinatoric Operators[67]
  • The Evolution of APL[17]
  • Operators and Functions[68]
  • The Role of Operators in APL[69]
  • The Derivative Operator[70]
  • Notation as a Tool of Thought[1]

I. P. Sharp Associates (1980–1987)[edit]

APL rank operator ⍤ [71][72]

In 1980, Iverson left IBM for I. P. Sharp Associates,[73] an APL timesharing company. He was preceded there by his IBM colleagues Paul Berry, Joey Tuttle, Dick Lathwell, and Eugene McDonnell. At IPSA, the APL language and systems group was managed by Eric Iverson (Ken Iverson’s son); Roger Moore, one of the APL\360 implementers, was a vice president.

Iverson worked to develop and extend APL on the lines presented in Operators and Functions.[68] The language work gained impetus in 1981 when Arthur Whitney and Iverson produced a model of APL written in APL[74][75] at the same time they were working on IPSA’s OAG database.[2][11][76] (Iverson introduced Arthur Whitney, son of Eoin Whitney, to APL when he was 11-years-old[11] and in 1974 recommended him for a summer student position at IPSA Calgary.[22]) In the model, the APL syntax was driven by an 11-by-5 table. Whitney also invented the rank operator in the process.[77] The language design was further simplified and extended in Rationalized APL[78] in January 1983, multiple editions of A Dictionary of the APL Language between 1984 and 1987, and A Dictionary of APL[79] in September 1987. Within IPSA, the phrase "dictionary APL" came into use to denote the APL specified by A Dictionary of APL, itself referred to as "the dictionary". In the dictionary, APL syntax is controlled by a 9-by-6 table and the parsing process was precisely and succinctly described in Table 2, and there is a primitive (monadic ⊥, modeled in APL) for word formation (lexing).

In the 1970s and 1980s, the main APL vendors were IBM, STSC, and IPSA, and all three were active in developing and extending the language. IBM had APL2, based on the work of Jim Brown.[80][81][82] Work on APL2 proceeded intermittently for 15 years,[27] with actual coding starting in 1971 and APL2 becoming available as an IUP (Installed User Program, an IBM product classification) in 1982. STSC had an experimental APL system called NARS, designed and implemented by Bob Smith.[83][84] NARS and APL2 differed in fundamental respects from dictionary APL,[85] and differed from each other.

I.P. Sharp implemented the new APL ideas in stages: complex numbers,[86] enclosed (boxed) arrays, match, and composition operators in 1981,[87] the determinant operator in 1982,[88] and the rank operator, link, and the left and right identity functions in 1983.[89] However, the domains of operators were still restricted to the primitive functions or subsets thereof. In 1986, IPSA developed SAX,[71][90] SHARP APL/Unix, written in C and based on an implementation by STSC. The language was as specified in the dictionary with no restrictions on the domains of operators. An alpha version of SAX became available within I.P. Sharp around December 1986 or early 1987.

In education, Iverson developed A SHARP APL Minicourse[91][92] used to teach IPSA clients in the use of APL, and Applied Mathematics for Programmers[93] and Mathematics and Programming[94] which were used in computer science courses at T.H. Twente.

Publications which Iverson authored or co-authored while he was at I. P. Sharp Associates:

Education
  • The Inductive Method of Introducing APL[91]
  • A SHARP APL Minicourse[92]
  • Applied Mathematics for Programmers[93]
  • Mathematics and Programming[94]
Language design & implementation
  • Operators and Enclosed Arrays[95]
  • A Function Definition Operator[96]
  • Practical Uses of a Model of APL[74]
  • Composition and Enclosure[87]
  • Determinant-Like Functions Produced by the Dot-Operator[88]
  • APL Syntax and Semantics[75]
  • Rationalized APL[78]
  • Language Extensions of May 1983[89]
  • An Operator Calculus[97]
  • APL87[98]
  • A Dictionary of APL[79]

Jsoftware (1990–2004)[edit]

J tacit verb for binomial coefficients[34][99]
Dyalog APL[100] equivalent computation

Iverson retired from I. P. Sharp Associates in 1987. He kept busy while "between jobs". Regarding language design, the most significant of his activities in this period was the invention of "fork" in 1988.[101] For years, he had struggled to find a way to write f+g as in calculus, from the "scalar operators" in 1978,[68] through the "til" operator in 1982,[74][78] the catenation and reshape operators in 1984,[97] the union and intersection operators in 1987,[79] "yoke" in 1988,[102] and finally forks in 1988. Forks are defined as follows:

      (f g h) y   ←→   (f y) g (h y)
    x (f g h) y   ←→   (x f y) g (x h y)

Moreover, (f g p q r) ←→ (f g (p q r)). Thus to write f+g as in calculus, one can write f+g in APL. Iverson and Eugene McDonnell worked out the details on the long plane ride back from the APL88 conference in Sydney, Australia, with Iverson coming up with the initial idea on waking up from a nap.[77]

Iverson presented the rationale for his work post 1987 as follows:[15]

When I retired from paid employment, I turned my attention back to this matter [the use of APL for teaching] and soon concluded that the essential tool required was a dialect of APL that:

• Is available as "shareware", and is inexpensive enough to be acquired by students as well as by schools
• Can be printed on standard printers
• Runs on a wide variety of computers
• Provides the simplicity and the generality of the latest thinking in APL

The result has been J, first reported in.[103]

Roger Hui described the final impetus that got J started in Appendix A of An Implementation of J:[104]

One summer weekend in 1989, Arthur Whitney visited Ken Iverson at Kiln Farm and produced—on one page and in one afternoon—an interpreter fragment on the AT&T 3B1 computer. I studied this interpreter for about a week for its organization and programming style; and on Sunday, August 27, 1989, at about four o’clock in the afternoon, wrote the first line of code that became the implementation described in this document. Arthur’s one-page interpreter fragment is as follows: ...

Hui, a classmate of Whitney at the University of Alberta, had studied A Dictionary of the APL Language when he was between jobs,[3] modelled the parsing process in at least two different ways,[77] and investigated uses of dictionary APL in diverse applications.[105] As well, from January 1987 to August 1989 he had access to SAX,[71] and in the later part of that period used it on a daily basis.[77]

J initially took A Dictionary of APL[79] as the specification, and the J interpreter was built around Table 2 of the dictionary. The C data and program structures were designed so that the parse table in C corresponded directly to the parse table in the dictionary.[77] In retrospect, Iverson’s APL87 paper APL87,[98] in five pages, prescribed all the essential steps in writing an APL interpreter, in particular the sections on word formation and parsing. Arthur Whitney, in addition to the "one-page thing", contributed to J development by suggesting that primitives be oriented on the leading axis, that agreement (a generalization of scalar extension) should be prefix instead of suffix,[106] and that a total array ordering be defined.[107]

One of the objectives was to implement fork. This turned out to be rather straightforward, by the inclusion of one additional row in the parse table. The choice to implement forks was fortuitous and fortunate. It was realized only later[108][109] that forks made tacit expressions (operator expressions) complete in the following sense: any sentence involving one or two arguments that did not use its arguments as an operand, can be written tacitly with fork, compose, the left and right identity functions, and constant functions.

Two obvious differences between J and other APL dialects are: (a) its use of terms from natural languages instead of from mathematics or computer science (the practice started with A Dictionary of APL): noun, verb, adverbs, alphabet, word formation, sentence, ... instead of array, function, operator, character set, lexing, expression, ...; and (b) its use of 7-bit ASCII characters instead of special symbols. Other differences between J and APL are described in J for the APL Programmer[110] and APL and J.[111]

The J source code is available from Jsoftware under the GPL3 license.[112]

Eric Iverson founded Iverson Software Inc. in February 1990 to provide an improved SHARP APL/PC product. It quickly became obvious that there were shared interests and goals, and in May 1990 Iverson and Hui joined Iverson Software Inc. (later joined by Chris Burke). The company soon became J only. The name was changed to Jsoftware Inc. in April 2000.[77]

Publications which Iverson authored or co-authored while he was at Iverson Software Inc. and Jsoftware Inc.:

Education
Language design & implementation
  • A Commentary on APL Development[102]
  • Phrasal Forms[101]
  • APL/?[103]
  • Tacit Definition[108]
  • A Personal View of APL[15]
  • J Introduction and Dictionary[122]
  • Revisiting Rough Spots[123]
  • Computers and Mathematical Notation[124]
  • APL in the New Millennium[125]

Awards and Honors[edit]

See also[edit]

References[edit]

  1. ^ a b c d e Kenneth E. Iverson (August 1980). "Notation as a Tool of Thought". Communications of the ACM. 23 (8). Retrieved 8 April 2016. 
  2. ^ a b c d e Roger Hui, ed. (30 September 2005), Ken Iverson Quotations and Anecdotes, retrieved 5 April 2016 
  3. ^ a b c d e f g h i j k Kenneth E. Iverson with Donald E. McIntyre (2008), Kenneth E. Iverson (Autobiography), retrieved 8 April 2016 
  4. ^ Eric B. Iverson (21 October 2004), Dr. Kenneth E. Iverson (J Forum message), retrieved 8 April 2016 
  5. ^ Herman W. March and Henry C. Wolff (1917). Calculus. McGraw-Hill. 
  6. ^ I. Bernard Cohen (1999). Howard Aiken: Portrait of a Computer Pioneer. MIT Press. ISBN 0-262-03262-7. 
  7. ^ a b I. Bernard Cohen and Gregory W. Welch, eds. (1999). Makin’ Numbers. MIT Press. ISBN 0-262-03263-5. 
  8. ^ Kenneth E. Iverson (1954). Machine Solutions of Linear Differential Equations — Applications to a Dynamic Economic Model (Ph.D. thesis). Harvard University. Retrieved 7 April 2016. 
  9. ^ Roger Hui (August 2012), "MSLDE", Jwiki Essay, retrieved 22 April 2016 
  10. ^ Arthur Whitney (August 2006), "Memories of Ken", Vector, 22 (3), retrieved 25 April 2016 
  11. ^ a b c Bryan Cantrill (February 2009). "A Conversation with Arthur Whitney". ACM Queue. 7 (2). Retrieved 7 April 2016. 
  12. ^ a b Kenneth E. Iverson (August 1960), "The Description of Finite Sequential Processes", Symposium on Information Theory, Royal Institution, London, retrieved 9 April 2016 
  13. ^ Michael S. Montalbano (October 1982), A Personal History of APL, retrieved 10 April 2016 
  14. ^ Kenneth E. Iverson E. (June 1954). Arvid W. Jacobson, ed. "Graduate Instruction and Research". Proceedings of the First Conference on Training Personnel for the Computing Machine Field. Wayne State University. Retrieved 9 April 2016. 
  15. ^ a b c Kenneth E. Iverson (December 1991). "A Personal View of APL". IBM Systems Journal. 30 (4). Retrieved 9 April 2016. 
  16. ^ a b c d Frederick P. Brooks Jr., and Kenneth E. Iverson (1963). Automatic Data Processing. Wiley. ISBN 0-471-10599-6. 
  17. ^ a b c Adin D. Falkoff, and Kenneth E. Iverson (August 1978). "The Evolution of APL". ACM SIGPLAN Notices. 13. Retrieved 9 April 2016. 
  18. ^ a b c Kenneth E. Iverson (14 December 1983), Letter to J.K. Tuttle, retrieved 16 April 2016 
  19. ^ a b c d Kenneth E. Iverson (1962). A Programming Language. John Wiley & Sons. ISBN 0-471-43014-5. Retrieved 9 April 2016. 
  20. ^ a b c d e Adin D. Falkoff, and Kenneth E. Iverson (July 1973). "The Design of APL". IBM Journal of Research and Development. 17 (4). Retrieved 9 April 2016. 
  21. ^ a b c Adin D. Falkoff, Kenneth E. Iverson, and Edward H. Sussenguth (1964). "A Formal Description of System/360". IBM Systems Journal. 3 (3). 
  22. ^ a b c d e Roger Hui, ed. (September 2010), APL Quotations and Anecdotes, retrieved 9 April 2016 
  23. ^ a b c d Larry Breed (August 2006). "How We Got to APL\1130". Vector. 22 (3). Retrieved 13 April 2016. 
  24. ^ Michael A. Jenkins (June 1970), "The Solution of Linear Systems of Equations and Linear Least Squares Problems in APL", Technical Report Number 320-2989, IBM Corp. 
  25. ^ Michael A. Jenkins (10 February 1972), "Domino — An APL Primitive Function for Matrix Inverse — Its Implementation and Applications", APL Quote Quad, 3 (4) 
  26. ^ a b Donald B. McIntyre (August 2006), "A Tribute to Ken Iverson", Vector, 22 (3), retrieved 25 April 2016 
  27. ^ a b c d e Adin D. Falkoff (December 1991). "The IBM Family of APL Systems". IBM Systems Journal. 30 (4). 
  28. ^ a b Philip S. Abrams (17 August 1966), "An Interpreter for "Iverson Notation"" (PDF), Technical Report: CS-TR-66-47, Department of Computer Science, Stanford University, retrieved 17 April 2016 
  29. ^ Adin D. Falkoff, and Kenneth E. Iverson (16 October 1967), "The APL\360 Terminal System", Research Report RC-1922, IBM, retrieved 9 April 2016 
  30. ^ ACM Grace Murray Hopper Award (1973): Breed, Lathwell, and Moore; retrieved 14 April 2016.
  31. ^ Robert W. Horvath (August 1966). Introduction to Iverson Notation. IBM Systems Development Division, Poughkeepsie, NY. 
  32. ^ a b c Eugene McDonnell, ed. (1981), A Source Book in APL, Introduction, APL Press, retrieved 19 April 2016 
  33. ^ a b Adin D. Falkoff, and Kenneth E. Iverson (1968). APL\360 User’s Manual (PDF). IBM. Retrieved 11 April 2016. 
  34. ^ a b Roger Hui (11 October 2014), Sixteen APL Amuse-Bouches, retrieved 12 April 2016 
  35. ^ Alan J. Perlis (29 March 1978), "Almost Perfect Artifacts Improve only in Small Ways: APL is more French than English", APL 78 Conference Proceedings, retrieved 12 April 2016 
  36. ^ a b c d Adin D. Falkoff (July 1969), "APL\360 History", Proceedings of the APL Users Conference at SUNY Binghamton, retrieved 9 April 2016 
  37. ^ Kenneth E. Iverson (1966), Conventions Governing Order of Evaluation (Appendix A of Elementary Functions: An Algorithmic Treatment), Science Research Associates, retrieved 16 April 2016 
  38. ^ Kenneth E. Iverson (1972), Algebra as a Language (Appendix A of Algebra: An Algorithmic Treatment), Addison-Wesley, retrieved 16 April 2016 
  39. ^ a b Kenneth E. Iverson (March 1966). Elementary Functions: An Algorithmic Treatment. Science Research Associates. 
  40. ^ Eugene McDonnell (December 1979), "The Socio-Technical Beginnings of APL", APL Quote Quad, 10 (2), retrieved 24 April 2016 
  41. ^ Leslie H. Goldsmith, Roger Hui, ed., APL Quotations and Anecdotes, retrieved 13 April 2016 
  42. ^ Eugene McDonnell (September 1980). "Recreational APL, Pyramigram". APL Quote Quad. 11 (1). Retrieved 13 April 2016. 
  43. ^ Anon (October 1969), "APL in the Atlanta Public Schools", SHARE*APL\360 Newsletter (3) 
  44. ^ APL IV: Fourth International APL Conference, June 1972, retrieved 29 April 2016 
  45. ^ Federico Biancuzzi; Shane Warden (March 2009). Masterminds of Programming. O’Reilly Media. Retrieved 13 April 2016. 
  46. ^ a b c Anon (June 1975). "Iverson Receives Harry Goode Award". APL Quote Quad. 6 (2). Retrieved 8 April 2016. 
  47. ^ Paul Berry (August 2006), "Expository Programming", Vector, 22 (3), retrieved 25 April 2015 
  48. ^ Paul Berry; G. Bartoli; C. Dell’Aquila; V. Spadavecchia (March 1973). APL and Insight. TR No. CRB 002/513-3502. IBM Corp. 
  49. ^ Robert Spence (March 1973). Resistive Circuit Theory. IBM. 
  50. ^ Donald L. Orth (1976). Calculus in a New Key. APL Press. ISBN 0-917-32605-9. 
  51. ^ Paul Berry; John Thorstensen (1973). Starmap. TR No. 02.665. IBM Corp. 
  52. ^ Kenneth E. Iverson (1969), The Use of APL in Teaching, IBM Pub. No. G320-0996, retrieved 15 April 2016 
  53. ^ Paul Berry, Adin D. Falkoff, Kenneth E. Iverson (24 August 1970). "Using the Computer to Compute: A Direct but Neglected Approach to Teaching Mathematics". IFIP World Conference on Computer Education. 
  54. ^ Kenneth E. Iverson (1972), Algebra: An Algorithmic Treatment, Addison-Wesley 
  55. ^ Kenneth E. Iverson (January 1972), "APL in Exposition" (PDF), Technical Report Number RC 320-3010, IBM Philadelphia Scientific Center, retrieved 9 April 2016 
  56. ^ Kenneth E. Iverson (March 1973), "An Introduction to APL for Scientists and Engineers" (PDF), Technical Report Number RC 320-3019, IBM Philadelphia Scientific Center, retrieved 9 April 2016 
  57. ^ Kenneth E. Iverson (July 1972), "Introducing APL to Teachers" (PDF), Technical Report Number RC 320-3014, IBM Philadelphia Scientific Center, retrieved 9 April 2016 
  58. ^ Kenneth E. Iverson (1976), Elementary Analysis, APL Press 
  59. ^ Kenneth E. Iverson (September 1978). "Programming Style in APL". Proceedings of An APL Users Meeting. I. P. Sharp Associates. Retrieved 9 April 2016. 
  60. ^ Kenneth E. Iverson (May 1962). "A Programming Language". Proceedings of the AFIPS Spring Joint Computer Conference, San Francisco. Retrieved 13 April 2016. 
  61. ^ Kenneth E. Iverson (December 1962). "A Common Language for Hardware, Software, and Applications". Proceedings of the AFIPS Fall Joint Computer Conference, Philadelphia. Retrieved 13 April 2016. 
  62. ^ Kenneth E. Iverson (June 1963). "Programming Notation in System Design". IBM Systems Journal. 2 (2). Retrieved 13 April 2016. 
  63. ^ Kenneth E. Iverson (February 1964). "Formalism in Programming Languages". Communications of the ACM. 7 (2). Retrieved 13 April 2016. 
  64. ^ Adin D. Falkoff, and Kenneth E. Iverson (1973). Communication in APL Systems. Technical Report 320-3022. IBM Philadelphia Scientific Center. 
  65. ^ Adin D. Falkoff, and Kenneth E. Iverson (1973). APLSV User’s Manual (PDF). SH20-1460. IBM Philadelphia Scientific Center. Retrieved 16 April 2016. 
  66. ^ Adin D. Falkoff, and Kenneth E. Iverson (1975). APL Language (Form No. GC26-3847). IBM. 
  67. ^ Kenneth E. Iverson (September 1976), "Two Combinatoric Operators", APL 76 Conference Proceedings 
  68. ^ a b c Kenneth E. Iverson (26 April 1978), "Operators and Functions", Research Report #RC7091, IBM, retrieved 9 April 2016 
  69. ^ Kenneth E. Iverson (June 1979), "The Role of Operators in APL", APL 79 Conference Proceedings, retrieved 10 April 2016 
  70. ^ Kenneth E. Iverson (June 1979), "The Derivative Operator", APL 79 Conference Proceedings 
  71. ^ a b c David H. Steinbrook (1986). SAX Reference. I. P. Sharp Associates. 
  72. ^ Roger Hui (August 2010). "On Average". Vector. 22 (4). Retrieved 12 April 2016. 
  73. ^ Roger Hui, ed. (14 May 2009), Eugene McDonnell Quotations and Anecdotes, retrieved 5 April 2016 
  74. ^ a b c Kenneth E. Iverson and Arthur T. Whitney (September 1982), "Practical Uses of a Model of APL", APL 82 Conference Proceedings, retrieved 10 April 2016 
  75. ^ a b Kenneth E. Iverson (March 1983), "APL Syntax and Semantics", APL 83 Conference Proceedings, retrieved 10 April 2016 
  76. ^ Computer History Museum (30 November 2004), A Celebration of Kenneth Iverson, retrieved 17 April 2016 
  77. ^ a b c d e f Roger Hui (November 2014), Remembering Ken Iverson, retrieved 10 April 2016 
  78. ^ a b c Kenneth E. Iverson (6 January 1983), Rationalized APL, I. P. Sharp Associates, retrieved 10 April 2016 
  79. ^ a b c d Kenneth E. Iverson (September 1987), "A Dictionary of APL", APL Quote Quad, 18 (1), retrieved 10 April 2016 
  80. ^ James A. Brown (1971). A Generalization of APL (Ph.D. thesis). Department of Computer and Information Sciences, Syracuse University. 
  81. ^ James A. Brown (1984), "The Principles of APL2", Technical Report 03.247, IBM Santa Teresa Laboratory 
  82. ^ James A. Brown (1988), "APL2 Programming: Language Reference", SH20-9227, IBM Corporation 
  83. ^ Robert A. Smith (September 1981). "Nested Arrays, Operators, and Functions". APL 81 Conference Proceedings. 
  84. ^ Carl M. Cheney (1981), APL*PLUS Nested Array System (PDF), STSC, retrieved 19 April 2016 
  85. ^ Donald L. Orth (December 1981). "A Comparison of the IPSA and STSC Implementations of Operators and General Arrays". APL Quote Quad. 12 (2). Retrieved 13 April 2016. 
  86. ^ Eugene McDonnell (20 June 1981). "Complex Numbers". SATN 40, I. P. Sharp Associates. Retrieved 11 April 2016. 
  87. ^ a b Kenneth E. Iverson (20 June 1981). "Composition and Enclosure". SATN 41, I. P. Sharp Associates. Retrieved 11 April 2016. 
  88. ^ a b Kenneth E. Iverson (1 April 1982). "Determinant-Like Functions Produced by the Dot-Operator". SATN 42, I. P. Sharp Associates. Retrieved 11 April 2016. 
  89. ^ a b Robert Bernecky, Kenneth E. Iverson, Eugene McDonnell, Robert Metzger, and J. Henri Schueler (2 May 1983). "Language Extensions of May 1983". SATN 45, I. P. Sharp Associates. Retrieved 11 April 2016. 
  90. ^ Joey K. Tuttle (August 2006), "What's Wrong with My Programming?", Vector, 22 (3), retrieved 25 April 2016 
  91. ^ a b Kenneth E. Iverson (6 October 1980), "The Inductive Method of Introducing APL", 1980 APL Users Meeting Proceedings, retrieved 10 April 2016 
  92. ^ a b Kenneth E. Iverson (January 1981). A SHARP APL Minicourse. I. P. Sharp Associates. 
  93. ^ a b Kenneth E. Iverson (1984). Applied Mathematics for Programmers. I. P. Sharp Associates. 
  94. ^ a b Kenneth E. Iverson (1986). Mathematics and Programming. I. P. Sharp Associates. 
  95. ^ Robert Bernecky; Kenneth E. Iverson (6 October 1980), "Operators and Enclosed Arrays", 1980 APL Users Meeting Proceedings, retrieved 10 April 2016 
  96. ^ Kenneth E. Iverson; Peter K. Wooster (September 1981), "A Function Definition Operator", APL 81 Conference Proceedings 
  97. ^ a b Kenneth E. Iverson; Roland H. Pesch; J. Henri Schueler (June 1984), "An Operator Calculus", APL 84 Conference Proceedings, retrieved 10 April 2016 
  98. ^ a b Kenneth E. Iverson (May 1987), "APL87", APL 87 Conference Proceedings, retrieved 10 April 2016 
  99. ^ Roger Hui (3 December 2014). "Ken Iverson's Favorite APL Expression?". Dyalog Blog. Retrieved 12 April 2016. 
  100. ^ Dyalog (2014), Dyalog APL Language Reference (version 14.0 or later) (PDF), Dyalog Limited, retrieved 16 April 2016 
  101. ^ a b Kenneth E. Iverson and Eugene McDonnell (August 1989), "Phrasal Forms", APL 89 Conference Proceedings, retrieved 10 April 2016 
  102. ^ a b Kenneth E. Iverson (September 1988). "A Commentary on APL Development". APL Quote Quad. 19 (1). Retrieved 13 April 2016. 
  103. ^ a b Roger Hui, Kenneth E. Iverson, Eugene McDonnell, and Arthur Whitney (July 1990), "APL/?", APL 90 Conference Proceedings, retrieved 10 April 2016 
  104. ^ Roger Hui (27 January 1992). An Implementation of J (PDF). Iverson Software Inc. Retrieved 10 April 2016. 
  105. ^ Roger Hui (May 1987). "Some Uses of { and }". APL 87 Conference Proceedings. Retrieved 15 April 2016. 
  106. ^ Roger Hui (June 1995). "Rank and Uniformity". APL 95 Conference Proceedings. Retrieved 15 April 2016. 
  107. ^ Roger Hui (27 January 2006), "The TAO of J", J Wiki Essay, retrieved 24 May 2016 
  108. ^ a b Roger Hui, Kenneth E. Iverson, and Eugene McDonnell (August 1991), "Tacit Definition", APL 91 Conference Proceedings, retrieved 10 April 2016 
  109. ^ Edward Cherlin (August 1991). "Pure Functions in APL and J". APL 91 Conference Proceedings. 
  110. ^ Chris Burke and Roger Hui (September 1996). "J for the APL Programmer". APL Quote Quad. 27 (1). Retrieved 14 April 2016. 
  111. ^ Chris Burke (2 March 2005), APL and J (PDF), retrieved 16 April 2016 
  112. ^ Jsoftware, J Source, retrieved 15 April 2016 
  113. ^ Kenneth E. Iverson (1991). Tangible Math. Iverson Software Inc. 
  114. ^ Kenneth E. Iverson (1991). Programming in J. Iverson Software Inc. 
  115. ^ Kenneth E. Iverson (1991). Arithmetic (PDF). Iverson Software Inc. Retrieved 10 April 2016. 
  116. ^ Kenneth E. Iverson (1993). Calculus (PDF). Iverson Software Inc. Retrieved 10 April 2016. 
  117. ^ Kenneth E. Iverson (1995). Concrete Math Companion (PDF). Iverson Software Inc. Retrieved 10 April 2016. 
  118. ^ Kenneth E. Iverson (1996). Exploring Math (PDF). Iverson Software Inc. Retrieved 10 April 2016. 
  119. ^ Chris Burke, Roger Hui, Kenneth E. Iverson, Eugene McDonnell, and Donald B. McIntyre (1996). J Phrases. Iverson Software Inc. Retrieved 10 April 2016. 
  120. ^ Chris Burke, Roger Hui, Eric Iverson, Kenneth E. Iverson, and Kirk Iverson (1998), ICFP ’98 Contest Winners, retrieved 15 April 2016 
  121. ^ Kenneth E. Iverson (1999). Math for the Layman. JSoftware Inc. Retrieved 10 April 2016. 
  122. ^ Roger Hui and Kenneth E. Iverson (1991). "J Introduction and Dictionary". Jsoftware Inc. Retrieved 9 April 2016. 
  123. ^ Kenneth E. Iverson (March 1994). "Revisiting Rough Spots". APL Quote Quad. 24 (3). Retrieved 13 April 2016. 
  124. ^ Kenneth E. Iverson (1996), Computers and Mathematical Notation, Iverson Software Inc., retrieved 10 April 2016 
  125. ^ Kenneth E. Iverson (August 2006), "APL in the New Millennium", Vector, 22 (3), retrieved 25 April 2016 
  126. ^ National Academy of Engineering, NAE Members Directory, retrieved 22 April 2016 
  127. ^ IEEE Computer Society (1982), Computer Pioneer Award (Charter Recipient), retrieved 8 April 2016 
  128. ^ B. Drummond (11 June 1998), Citation for Dr. Kenneth Iverson, York University, retrieved 8 April 2016 

External links[edit]