You are on page 1of 8

Kenneth E.

Iverson
From Wikipedia, the free encyclopedia
Jump to navigationJump to search
Kenneth Eugene Iverson
Kei younger.jpg
Born 17 December 1920
Camrose, Alberta, Canada
Died 19 October 2004 (aged 83)
Toronto, Ontario, Canada
Citizenship Canadian
Alma mater Queen's University
Harvard University
Known for Programming languages: APL, J
Awards IBM Fellow
Harry H. Goode Memorial Award
Turing Award
Computer Pioneer Award
Scientific career
Fields Mathematics
Computer science
Institutions Harvard University
IBM
I. P. Sharp Associates
Jsoftware Inc.
Thesis Machine Solutions of Linear Differential Equations – Applications to a
Dynamic Economic Model (1954)
Doctoral advisor Howard Aiken
Wassily Leontief
Kenneth Eugene Iverson (17 December 1920 – 19 October 2004) was a Canadian computer
scientist noted for the development of the programming language APL. 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]

Contents
1 Life
2 Education
3 Work
3.1 Harvard (1955–1960)
3.2 IBM (1960–1980)
3.3 I. P. Sharp Associates (1980–1987)
3.4 Jsoftware (1990–2004)
4 Awards and honors
5 See also
6 References
7 External links
Life
Ken Iverson was born on 17 December 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
Iverson began 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 Great 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 began 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 2-time Putnam Fellow and fellow graduate
student from Alberta.[10][11] This had future ramifications.

Work
Harvard (1955–1960)

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][16]

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 to 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.[17] 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][18] 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][19]

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)
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[19][20] and (with Brooks) Automatic Data Processing,[17] two books that
described and used the notation developed at Harvard. (Automatic Data Processing
and A Programming Language began as one book "but the material grew in both
magnitude and level until a separation proved wise".[17][20])

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.[19][20] 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.[21] The result was published in 1964 in
a double issue of the IBM Systems Journal,[22] 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.[22] A consequence of the formal description was
that it attracted the interest of bright young minds.[3][23] One hotbed of interest
was at Stanford University which included Larry Breed, Phil Abrams, Roger Moore,
Charles Brenner,[24] and Mike Jenkins,[25][26] 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][27]

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 (for Iverson system) by autumn 1965, first
in batch mode and later, in early 1966, in time-shared interactive mode.[24][28]
[29] Subsequently, Breed, Dick Lathwell (ex University of Alberta), and Roger Moore
(of I. P. Sharp Associates) produced the System/360 implementation;[30] 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."[31] While the 360
implementation work was underway "Iverson notation"[29][32] was renamed "APL", by
Falkoff.[33] The workspace "1 cleanspace" was saved at 1966-11-27 22.53.58 UTC.[23]
APL\360 service began within IBM several weeks before that[34] and outside IBM in
1968.[28] Additional information on the implementation of APL\360 can be found in
the Acknowledgements of the APL\360 User's Manual[35] and in "Appendix. Chronology
of APL development" of The Design of APL.[21]

APL expression for the depth of parentheses nesting[36][37]


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,[38]
The Design of APL,[21] and The Evolution of APL.[18] Two treatises from this
period, Conventions Governing the Order of Evaluation[39] and Algebra as a
Language,[40] 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.[21][38] In 1964 Iverson
used the notation in a one-semester course for seniors at the Fox Lane High School,
[33][41] 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.
[38][42] It was also used at the Hotchkiss School,[24] Lower Canada College,[43]
Scotch Plains High School,[44] Atlanta public schools,[45][46] among others. In one
school the students became so eager that they broke into the school after hours to
get more APL computer time;[23][47] in another the APL enthusiasts steered newbies
to BASIC so as to maximize their own APL time.[24]

In 1969, Iverson and the APL group inaugurated the IBM Philadelphia Scientific
Center.[28][38] In 1970 he was named IBM Fellow.[48] 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[27] and Jeff Shallit as a summer
student.[23] 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.[49] Iverson's work at this time
centered in several disciplines, including collaborative projects in circuit
theory, genetics, geology, and calculus.[50][51][52][53] When the PSC closed in
1974,[28][33] 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]

(L to R) Dick Lathwell, Ken Iverson, Roger Moore, Adin Falkoff, Phil Abrams, and
Larry Breed. On the extreme left in the background: Jon McGrew. Taken in the I.P.
Sharp Associates hospitality suite during the 1978 APL Users Meeting in Toronto,
Ontario.
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[17]
Elementary Functions: An Algorithmic Treatment[41]
The Use of APL in Teaching[54]
Using the Computer to Compute[55]
Algebra: An Algorithmic Treatment[56]
APL in Exposition[57]
An Introduction to APL for Scientists and Engineers[58]
Introducing APL to Teachers[59]
Elementary Analysis[60]
Programming Style in APL[61]
Language design & implementation
A Programming Language[20]
A Programming Language[62]
A Common Language for Hardware, Software, and Applications[63]
Programming Notation in System Design[64]
Formalism in Programming Languages[65]
A Method of Syntax Specification[66]
A Formal Description of System/360[22]
APL\360 User's Manual[35]
Communication in APL Systems[67]
The Design of APL[21]
APL as an Analytic Notation[68]
APLSV User's Manual[69]
APL Language[70]
Two Combinatoric Operators[71]
The Evolution of APL[18]
Operators and Functions[72]
The Role of Operators in APL[73]
The Derivative Operator[74]
Operators[75]
Notation as a Tool of Thought[1]
I. P. Sharp Associates (1980–1987)

APL rank operator ⍤ [76][77]


In 1980, Iverson left IBM for I. P. Sharp Associates,[78][79] an APL time-sharing
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.[72][80] The language work gained impetus in 1981 when Arthur Whitney and
Iverson produced a model of APL written in APL[81][82] at the same time they were
working on IPSA's OAG database.[2][11][83] (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.[23]) In the model, the APL syntax
was driven by an 11-by-5 table. Whitney also invented the rank operator in the
process.[84] The language design was further simplified and extended in
Rationalized APL[85] in January 1983, multiple editions of A Dictionary of the APL
Language between 1984 and 1987, and A Dictionary of APL[86] 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.[87][88][89] Work on APL2 proceeded intermittently for 15
years,[28] 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.[90][91]
NARS and APL2 differed in fundamental respects from dictionary APL,[92] and
differed from each other.
I.P. Sharp implemented the new APL ideas in stages: complex numbers,[93] enclosed
(boxed) arrays, match, and composition operators in 1981,[94] the determinant
operator in 1982,[95] and the rank operator, link, and the left and right identity
functions in 1983.[96] However, the domains of operators were still restricted to
the primitive functions or subsets thereof. In 1986, IPSA developed SAX,[76][97]
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[98][99] used to teach IPSA


clients in the use of APL, and Applied Mathematics for Programmers[100] and
Mathematics and Programming[101] which were used in computer science courses at
T.H. Twente.

Ken Iverson and Arthur Whitney, 1989


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

Education
The Inductive Method of Introducing APL[98]
A SHARP APL Minicourse[99]
Applied Mathematics for Programmers[100]
Mathematics and Programming[101]
Language design & implementation
Operators and Enclosed Arrays[102]
Direct Definition[103]
Composition and Enclosure[94]
A Function Definition Operator[104]
Determinant-Like Functions Produced by the Dot-Operator[95]
Practical Uses of a Model of APL[81]
Rationalized APL[85]
APL Syntax and Semantics[82]
Language Extensions of May 1983[96]
An Operator Calculus[105]
APL87[106]
A Dictionary of APL[86]
Processing Natural Language: Syntactic and Semantic Mechanisms[107]
Jsoftware (1990–2004)

J tacit verb for binomial coefficients[36][108]

Dyalog APL[109] 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.[110] For years, he had struggled to
find a way to write f+g as in calculus, from the "scalar operators" in 1978,[72]
through the "til" operator in 1982,[81][85] the catenation and reshape operators in
1984,[105] the union and intersection operators in 1987,[86] "yoke" in 1988,[111]
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 rides to the APL88 conference in Sydney, Australia, with Iverson coming up
with the initial idea on waking up from a nap.[84][112][80]: 
§1.3, 
§3.8 
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 [the APL 90 Conference Proceedings].[113]

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

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,[84] and investigated uses of dictionary APL in diverse
applications.[115] As well, from January 1987 to August 1989 he had access to SAX,
[76] and in the later part of that period used it on a daily basis.[84]

J initially took A Dictionary of APL[86] 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.[84] In retrospect, Iverson's APL87 paper APL87,[106]
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,[116] and that a total array ordering
be defined.[117]

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[118][119] 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 began 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[120] and APL and J.[121]

The J source code is available from Jsoftware under the GNU General Public License
version 3 (GPL3), or a commercial alternative.[122]
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.[84]

Ken Iverson (right) and Roger Hui, 1996


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

Education
Tangible Math[123]
Programming in J[124]
Arithmetic[125]
Calculus[126]
Concrete Math Companion[127]
Exploring Math[128]
J Phrases[129]
ICFP '98 Contest Winners[130]
Math for the Layman[131]
Language design & implementation
A Commentary on APL Development[111]
Phrasal Forms[110]
APL/?[113]
Tacit Definition[118]
A Personal View of APL[15]
J Introduction and Dictionary[132]
Revisiting Rough Spots[133]
Computers and Mathematical Notation[134]
Mathematical Roots of J[135]
APL in the New Millennium[136]

You might also like