Donald Knuth

Donald Ervin Knuth

Donald Knuth at a reception for the Open Content Alliance, October 25, 2005
Born January 10, 1938
Milwaukee, Wisconsin, US
Nationality American
Fields Mathematics
Computer science
Institutions Stanford University
Alma mater Case Institute of Technology (B.S.; M.S., 1960 )
California Institute of Technology (Ph.D., 1963)
Thesis Finite Semifields and Projective Planes (1963)
Doctoral advisor Marshall Hall, Jr.
Doctoral students Leonidas J. Guibas
Michael Fredman
Scott Kim
Vaughan Pratt
Robert Sedgewick
Jeffrey Vitter
Andrei Broder
Known for The Art of Computer Programming
TeX, METAFONT
Knuth–Morris–Pratt algorithm
Knuth–Bendix completion algorithm
MMIX
Robinson–Schensted–Knuth correspondence
Notable awards Grace Murray Hopper Award (1971)
Turing Award (1974)
National Medal of Science (1979)
John von Neumann Medal (1995)
Harvey Prize (1995)
Kyoto Prize (1996)
Computer History Museum Fellow (1998) [1]
Faraday Medal (2011)
BBVA Foundation Frontiers of Knowledge Award (2010)
Website
Donald E. Knuth

Donald Ervin Knuth (/kəˈnθ/[2] kə-NOOTH; born January 10, 1938) is an American computer scientist, mathematician, and professor emeritus at Stanford University.[3]

He is the author of the multi-volume work The Art of Computer Programming.[4] Knuth has been called the "father of the analysis of algorithms".[5] He contributed to the development of the rigorous analysis of the computational complexity of algorithms and systematized formal mathematical techniques for it. In the process he also popularized the asymptotic notation. In addition to fundamental contributions in several branches of theoretical computer science, Knuth is the creator of the TeX computer typesetting system, the related METAFONT font definition language and rendering system, and the Computer Modern family of typefaces.

As a writer and scholar,[6] Knuth created the WEB and CWEB computer programming systems designed to encourage and facilitate literate programming, and designed the MIX/MMIX instruction set architectures. As a member of the academic and scientific community, Knuth is strongly opposed to the policy of granting software patents.[7] He has expressed his disagreement directly to both the United States Patent and Trademark Office and European Patent Organization.[8]

Early life

Knuth was born in Milwaukee, Wisconsin, where his father owned a small printing business and taught bookkeeping at Milwaukee Lutheran High School, where Donald enrolled, earning achievement awards. He applied his intelligence in unconventional ways, winning a contest when he was in eighth grade by finding over 4,500 words that could be formed from the letters in "Ziegler's Giant Bar"; the judges had only about 2,500 words on their master list. This won him a television set for his school and enough candy bars for his entire school.[9]

Education

Knuth had a difficult time choosing physics over music as his major at Case Institute of Technology (now part of Case Western Reserve University). He also joined Beta Nu Chapter of the Theta Chi fraternity. While studying physics at the Case Institute of Technology, Knuth was introduced to the IBM 650, one of the early mainframes. After reading the computer's manual, Knuth decided to rewrite the assembly and compiler code for the machine used in his school, because he believed he could do it better.[10] In 1958, Knuth constructed a program based on the value of each player that could help his school basketball team win the league. This was so novel a proposition at the time that it got picked up and published by Newsweek and also covered by Walter Cronkite on the CBS Evening News.[10] Knuth was one of the founding editors of the Engineering and Science Review, which won a national award as best technical magazine in 1959.[11] He then switched from physics to mathematics, and in 1960 he received his bachelor of science degree, simultaneously being given a master of science degree by a special award of the faculty who considered his work exceptionally outstanding.[10][12]

In 1963, he earned a PhD in mathematics (his advisor was Marshall Hall) from the California Institute of Technology.[13]

Early work

On receiving his PhD, Knuth joined Caltech's faculty as an associate professor.

He accepted a commission to write a book on computer programming language compilers. While working on this project, Knuth decided that he could not adequately treat the topic without first developing a fundamental theory of computer programming, which became The Art of Computer Programming. He originally planned to publish this as a single book. As Knuth developed his outline for the book, he concluded that he required six volumes, and then seven, to thoroughly cover the subject. He published the first volume in 1968.

Just before publishing the first volume of The Art of Computer Programming, Knuth left Caltech to accept employment with the Institute for Defense Analyses' Communications Research Division, then situated on the Princeton University campus, which was performing mathematical research in cryptography to support the National Security Agency.

Knuth then left this position to join the Stanford University faculty.

Writings

The Art of Computer Programming (TAOCP)

Computer science was then taking its first hesitant steps. "It was a totally new field," Knuth recalls, "with no real identity. And the standard of available publications was not that high. A lot of the papers coming out were quite simply wrong. [...] So one of my motivations was to put straight a story that had been very badly told."

After producing the third volume of his series in 1976, he expressed such frustration with the nascent state of the then newly developed electronic publishing tools (especially those that provided input to phototypesetters) that he took time out to work on typesetting and created the TeX and METAFONT tools.

As of 2013, the first three volumes and part one of volume four of his series have been published.[14] Concrete Mathematics: A Foundation for Computer Science 2nd ed., which originated with an expansion of the mathematical preliminaries section of Volume 1 of TAoCP, has also been published.

Other works

He is also the author of Surreal Numbers,[15] a mathematical novelette on John Conway's set theory construction of an alternate system of numbers. Instead of simply explaining the subject, the book seeks to show the development of the mathematics. Knuth wanted the book to prepare students for doing original, creative research.

In 1995, Knuth wrote the foreword to the book A=B by Marko Petkovsek, Herbert Wilf and Doron Zeilberger.[16] Knuth is also an occasional contributor of language puzzles to Word Ways: The Journal of Recreational Linguistics.

Religious beliefs and work

In addition to his writings on computer science, Knuth, a Lutheran,[17] is also the author of 3:16 Bible Texts Illuminated,[18] in which he examines the Bible by a process of systematic sampling, namely an analysis of chapter 3, verse 16 of each book. Each verse is accompanied by a rendering in calligraphic art, contributed by a group of calligraphers under the leadership of Hermann Zapf.

Subsequently he was invited to give a set of lectures on his 3:16 project, resulting in another book, Things a Computer Scientist Rarely Talks About, where he published the lectures "God and Computer Science".

Health concerns

In 2006, Knuth was diagnosed with prostate cancer. He underwent surgery in December that year and started "a little bit of radiation therapy... as a precaution but the prognosis looks pretty good", as he reported in his video autobiography.[19]

Computer musings

Knuth gives informal lectures a few times a year at Stanford University, which he called Computer Musings. He was also a visiting professor at the Oxford University Computing Laboratory (now the Oxford University Department of Computer Science) in the United Kingdom and an Honorary Fellow of Magdalen College.[20]

Humor

"Nested parens"—Donald Knuth and Jacob Appelbaum and Donald Knuth

Knuth used to pay a finder's fee of $2.56 for any typographical errors or mistakes discovered in his books, because "256 pennies is one hexadecimal dollar", and $0.32 for "valuable suggestions". According to an article in the Massachusetts Institute of Technology's Technology Review, these Knuth reward checks are "among computerdom's most prized trophies". Knuth had to stop sending real checks in 2008 due to bank fraud, and instead now gives each error finder a "certificate of deposit" from a publicly listed balance in his fictitious "Bank of San Serriffe".[21]

He once warned a correspondent, "Beware of bugs in the above code; I have only proved it correct, not tried it."[22]

Knuth published his first "scientific" article in a school magazine in 1957 under the title "Potrzebie System of Weights and Measures." In it, he defined the fundamental unit of length as the thickness of Mad No. 26, and named the fundamental unit of force "whatmeworry." Mad published the article in issue No. 33 (June 1957).[23]

To demonstrate the concept, Knuth intentionally referred "Circular definition" and "Definition, circular" to each other in the index of The Art of Computer Programming, Volume 1.

At the TUG 2010 Conference, Knuth announced an XML-based successor to TeX, titled "iTeX" (pronounced [iː˨˩˦tɛks˧˥], with a bell ringing), which would support features such as arbitrarily scaled irrational units, 3D printing, animation, and stereophonic sound.[24][25][26]

Awards

In 1971, Knuth was the recipient of the first ACM Grace Murray Hopper Award. He has received various other awards including the Turing Award, the National Medal of Science, the John von Neumann Medal, and the Kyoto Prize.

In recognition of Knuth's contributions to the field of computer science, in 1990 he was awarded the one-of-a-kind academic title of Professor of The Art of Computer Programming, which has since been revised to Professor Emeritus of The Art of Computer Programming.

Knuth was elected to the National Academy of Sciences in 1975. In 1992, he became an associate of the French Academy of Sciences. Also that year, he retired from regular research and teaching at Stanford University in order to finish The Art of Computer Programming. In 2003 he was elected as a foreign member of the Royal Society.

Knuth was elected as a Fellow (first class of Fellows) of the Society for Industrial and Applied Mathematics in 2009 for his outstanding contributions to mathematics.[27] He is a member of the Norwegian Academy of Science and Letters.[28] In 2012, he became a fellow of the American Mathematical Society.[29]

Honors bestowed on Knuth include:

Works

A short list of his works:[38]

The Art of Computer Programming

  1. (1997), The Art of Computer Programming, 1: Fundamental Algorithms (3rd ed.), Addison-Wesley Professional, ISBN 0-201-89683-4.
  2. (1997), The Art of Computer Programming, 2: Seminumerical Algorithms (3rd ed.), Addison-Wesley Professional, ISBN 0-201-89684-2.
  3. (1998), The Art of Computer Programming, 3: Sorting and Searching (2nd ed.), Addison-Wesley Professional, ISBN 0-201-89685-0.
  4. (2011), The Art of Computer Programming, 4A: Combinatorial Algorithms, Addison-Wesley Professional, ISBN 0-201-03804-8.
  5. (2005), MMIX—A RISC Computer for the New Millennium, 1, Fascicle 1, ISBN 0-201-85392-2.
  6. (2008), The Art of Computer Programming, 4, Fascicle 0: Introduction to Combinatorial Algorithms and Boolean Functions, ISBN 0-321-53496-4.
  7. (2009), The Art of Computer Programming, 4, Fascicle 1: Bitwise Tricks & Techniques; Binary Decision Diagrams, ISBN 0-321-58050-8.
  8. (2005), The Art of Computer Programming, 4, Fascicle 2: Generating All Tuples and Permutations, ISBN 0-201-85393-0.
  9. (2005), The Art of Computer Programming, 4, Fascicle 3: Generating All Combinations and Partitions, ISBN 0-201-85394-9.
  10. (2006), The Art of Computer Programming, 4, Fascicle 4: Generating All Trees—History of Combinatorial Generation, ISBN 0-321-33570-8.

Computers & Typesetting

  1. (1984), Computers & Typesetting, A, The TeXbook, Reading, MA: Addison-Wesley, ISBN 0-201-13447-0, x+483pp.
  2. (1986), Computers & Typesetting, B, TeX: The Program, Reading, MA: Addison-Wesley, ISBN 0-201-13437-3, xviii+600pp.
  3. (1986), Computers & Typesetting, C, The METAFONTbook, Reading, MA: Addison-Wesley, ISBN 0-201-13445-4, xii+361pp.
  4. (1986), Computers & Typesetting, D, METAFONT: The Program, Reading, MA: Addison-Wesley, ISBN 0-201-13438-1, xviii+566pp.
  5. (1986), Computers & Typesetting, E, Computer Modern Typefaces, Reading, MA: Addison-Wesley, xvi+588pp.

Selected papers

  1. (1992), Literate Programming[39], Lecture Notes (27), Stanford, CA: Center for the Study of Language and Information—CSLI, ISBN 0-937073-80-6.
  2. (1996), Selected Papers on Computer Science[40], Lecture Notes (59), Stanford, CA: Center for the Study of Language and Information—CSLI, ISBN 1-881526-91-7.
  3. (1999), Digital Typography[41], Lecture Notes (78), Stanford, CA: Center for the Study of Language and Information—CSLI, ISBN 1-57586-010-4.
  4. (2000), Selected Papers on Analysis of Algorithms[42], Lecture Notes (102), Stanford, CA: Center for the Study of Language and Information—CSLI, ISBN 1-57586-212-3.
  5. (2003), Selected Papers on Computer Languages[43] (CLOTH), Lecture Notes (139), Stanford, CA: Center for the Study of Language and Information—CSLI, ISBN 1-57586-381-2, ISBN 1-57586-382-0 (paperback)
  6. (2003), Selected Papers on Discrete Mathematics[44] (CLOTH), Lecture Notes (106), Stanford, CA: Center for the Study of Language and Information—CSLI, ISBN 1-57586-249-2, ISBN 1-57586-248-4 (paperback).
  7. Donald E. Knuth, Selected Papers on Design of Algorithms[45] (Stanford, California: Center for the Study of Language and Information—CSLI Lecture Notes, no. 191), 2010. ISBN 1-57586-583-1 (cloth), ISBN 1-57586-582-3 (paperback)
  8. Donald E. Knuth, Selected Papers on Fun and Games[46] (Stanford, California: Center for the Study of Language and Information—CSLI Lecture Notes, no. 192), 2011. ISBN 978-1-57586-585-0 (cloth), ISBN 978-1-57586-584-3 (paperback)
  9. Donald E. Knuth, Companion to the Papers of Donald Knuth[47] (Stanford, California: Center for the Study of Language and Information—CSLI Lecture Notes, no. 202), 2011. ISBN 978-1-57586-635-2 (cloth), ISBN 978-1-57586-634-5 (paperback)

Gallery

See also

References

  1. 1.0 1.1 "Donald Knuth: 1998 Fellow". Computer History Museum. 2015. Retrieved March 30, 2015.
  2. Knuth, Donald Ervin. "Frequently Asked Questions". Home page. Stanford University. Retrieved November 2, 2010. How do you pronounce your last name? Ka-NOOTH.
  3. Knuth, Donald Ervin, Home page, Stanford University.
  4. The Art of Computer Programming, Stanford University.
  5. Karp, Richard M. (February 1986), "Combinatorics, Complexity, and Randomness", Communications of the ACM (New York, NY, USA: ACM) 29 (2): 98–109, doi:10.1145/5657.5658
  6. Knuth, Donald Ervin, Curriculum vitae, Stanford University.
  7. "Professor Donald Knuth's Thinking Against Software Patents" (PDF), Notices (article) (The American Mathematical Society), March 2002.
  8. Knuth, Donald Ervin, Against software patents (PDF) (Letters) to the patent offices in the USA and Europe.
  9. Shasha, Dennis Elliott; Lazere, Cathy A (1998), Out of their minds: the lives and discoveries of 15 great computer scientists, Springer, p. 90, ISBN 978-0-387-98269-4
  10. 10.0 10.1 10.2 Koshy, Thomas (2004), Discrete mathematics with applications, Academic Press, p. 244, ISBN 978-0-12-421180-3, retrieved July 30, 2011
  11. "History of Beta Nu Chapter", The Tachi, CWRU.
  12. A.M. Turing Award; Donald ("Don") Erwin Knuth, ACM, 1974.
  13. Knuth, Donald Ervin (1963), Finite Semifields and Projective Planes (PDF) (PhD dissertation), Caltech.
  14. Knuth, Donald Ervin. "The Art of Computer Programming (TAOCP)". Retrieved May 20, 2012.
  15. Knuth 1974.
  16. Zeilberg, DEK, Rutgers.
  17. Platoni 2006.
  18. Knuth, Donald Ervin (1991), 3:16 : Bible texts illuminated, Madison, WI: A-R Eds, ISBN 978-0-89579-252-5
  19. "Donald Knuth: 85 – Coping with cancer". Web of Stories. April 2006. Retrieved May 2, 2012.
  20. "Professor Donald Knuth". Magdalen College. Retrieved December 6, 2010.
  21. "Rewriting the Bible in 0s and 1s", Technology Review (Massachusetts Institute of Technology).
  22. Knuth, Donald Ervin. "Frequently Asked Questions". Home page. Stanford University. Retrieved November 2, 2010.
  23. Knuth, Donald Ervin (June 1957), "Potrzebie System of Weights & Measures", Mad Magazine (33).
  24. "Don Knuth", TUG (conference), Zeeba TV, 2010.
  25. Knuth, Donald Ervin, An Earth‐shaking announcement (VIDEO) (recording), Zeeba TV.
  26. Knuth, Donald Ervin (2010), "An Earthshaking Announcement" (PDF), TUGboat 31 (2): 121–24, ISSN 0896-3207
  27. Fellows, Siam, 2009.
  28. "Gruppe 1: Matematiske fag" (in Norwegian). Norwegian Academy of Science and Letters. Retrieved October 7, 2010.
  29. List of Fellows of the American Mathematical Society, retrieved 2013-01-27.
  30. Knuth, D. E. (1974). "Computer science and its relation to mathematics". Amer. Math. Monthly 81: 323–343. doi:10.2307/2318994.
  31. Knuth, D. E. (1992). "Two notes on notation". Amer. Math. Monthly 99: 403–422. doi:10.2307/2325085.
  32. Josiah Willard Gibbs Lectures
  33. Knuth, Donald E. (1979). "Mathematical typography". Bull. Amer. Math. Soc. (N.S.) 1 (2): 337–372. doi:10.1090/s0273-0979-1979-14598-1. MR 520078.
  34. Harvey, IL: Technion, 1995.
  35. Katayanagi, CMU.
  36. "Galardonados", Fronteras (in Spanish), ES: FBBVA, 2010.
  37. Myers, Andrew (June 1, 2001). "Stanford's Don Knuth, a pioneering hero of computer programming". Stanford Report. Retrieved June 27, 2011.
  38. Knuth, Donald Ervin, "Books", Home page (list).
  39. Knuth, Donald Ervin, "Literate Programming", Home page.
  40. Knuth, Donald Ervin, "Selected Papers on Computer Science", Home page.
  41. Knuth, Donald Ervin, "Digital Typography", Home page.
  42. Knuth, Donald Ervin, "Selected Papers on Analysis of Algorithms", Home page.
  43. Knuth, Donald Ervin, "Selected Papers on Computer Languages", Home page.
  44. Knuth, Donald Ervin, "Selected Papers on Discrete Mathematics", Home page.
  45. Knuth, Donald Ervin, "Selected Papers on Design of Algorithms", Home page.
  46. Knuth, Donald Ervin, "Selected Papers on Fun and Games", Home page.
  47. Knuth, Donald Ervin, "Companion to the Papers of Donald Knuth"]", Home page
  48. Knuth, Donald Ervin, "Surreal numbers", Home page.

Bibliography

External links

Wikiquote has quotations related to: Donald Knuth
Wikimedia Commons has media related to Donald Ervin Knuth.