Niklaus Wirth
Niklaus Wirth | |
|---|---|
| File:Niklaus Wirth, UrGU.jpg Wirth in 2005 | |
| Born | Niklaus Emil Wirth 15 February 1934 Winterthur, Switzerland |
| Died | 1 January 2024 (aged 89) Zürich, Switzerland |
| Education | |
| Known for | |
| Children | 3[3] |
| Awards |
|
| Scientific career | |
| Fields | Computer science |
| Institutions | |
| Thesis | A Generalization of Algol (1963) |
| Doctoral advisor | |
| Doctoral students | |
| Signature | |
| Signature of Niklaus Wirth | |
Niklaus Emil Wirth (IPA: /vɛrt/) (15 February 1934 – 1 January 2024) was a Swiss computer scientist. He designed several programming languages, including Pascal, and pioneered several classic topics in software engineering. In 1984, he won the Turing Award, generally recognized as the highest distinction in computer science, "for developing a sequence of innovative computer languages".[4]
Early life and education
[edit | edit source]Niklaus Emil Wirth was born in Winterthur, Switzerland, on 15 February 1934.[5] He was the son of Hedwig (née Keller) and Walter Wirth, a high school teacher.[6] Wirth studied electronic engineering at the Federal Institute of Technology, Zürich (ETH Zürich) from 1954 to 1958, graduating with a Bachelor of Science (B.S.) degree.[6] In 1960, he earned a Master of Science (M.Sc.) from Université Laval in Quebec.[6] Then in 1963, he was awarded a PhD in electrical engineering and computer science (EECS) from the University of California, Berkeley, supervised by computer design pioneer Harry Huskey.[7]
Career
[edit | edit source]From 1963 to 1967, Wirth served as assistant professor of computer science at Stanford University and again at the University of Zürich.[6] In 1968, he became a professor of informatics at ETH Zürich, taking two one-year sabbaticals at Xerox PARC in California (1976–1977 and 1984–1985). He retired in 1999.[7]
Although Wirth was involved with developing international standards in programming and informatics, as a member of the International Federation for Information Processing (IFIP) Working Group 2.1 on Algorithmic Languages and Calculi,[8] which specified, maintains, and supports the programming languages ALGOL 60 and ALGOL 68,[9] he got frustrated by the discussions in the standards groups and published his languages later on as personal work, mainly Pascal, Modula-2 and Oberon.
In 2004, he was made a Fellow of the Computer History Museum "for seminal work in programming languages and algorithms, including Euler, Algol-W, Pascal, Modula, and Oberon."[10]
Programming languages
[edit | edit source]Wirth was the chief designer of the programming languages Euler (1965), PL360 (1966), ALGOL W (1966), Pascal (1970),[11] Modula (1975), Modula-2 (1978),[7] Oberon (1987), Oberon-2 (1991), and Oberon-07 (2007).[12] He was also a major part of the design and implementation team for the operating systems Medos-2 (1983, for the Lilith workstation),[13] and Oberon (1987, for the Ceres workstation),[14][15] and for the Lola (1995) digital hardware design and simulation system.[16][17]
In 1984, Wirth received the Association for Computing Machinery (ACM) Turing Award for the development of these languages.[18] In 1994, he was inducted as a Fellow of the ACM.[19]
In 1999, he received the ACM SIGSOFT Outstanding Research Award[20]
Wirth's law
[edit | edit source]In 1995, he popularized the adage now named Wirth's law. In his 1995 paper "A Plea for Lean Software" he attributed the following to Martin Reiser phrasing it as, "Software is getting slower more rapidly than hardware becomes faster."[21]
Publications
[edit | edit source]The April 1971 Communications of the ACM article "Program Development by Stepwise Refinement",[22][23] concerning the teaching of programming, is considered to be a classic text in software engineering.[24] The paper is considered to be the earliest work to formally outline the top-down method for designing programs.[25][26] The article was discussed by Fred Brooks in his influential book The Mythical Man-Month and was described as "seminal" in the ACM's brief biography of Wirth published in connection to his Turing Award.[27][28]
The 1973 textbook, Systematic Programming: An Introduction,[29] was described as a quality source for mathematicians desiring to understand the nature of programming in a 1974 review.[30] The cover flap, of the 1973 edition, stated the book "... is tailored to the needs of people who view a course on systematic construction of algorithms as part of their basic mathematical training, rather than to the immediate needs of those who wish to be able to occasionally encode a problem and hand it over to their computer for instant solution."[31] Described in the review as a challenging text to work through, it was nevertheless recommended as useful reading for those interested in numerical mathematics.[32]
In 1974, The Pascal User Manual and Report,[33] jointly written[i] with Kathleen Jensen,[36] served as the basis of many language implementation efforts in the 1970s (BSD Pascal[37]), and 1980s in the United States and across Europe.[38][39]
In 1975, he wrote the book Algorithms + Data Structures = Programs, which gained wide recognition.[40] Major revisions of this book with the new title Algorithms & Data Structures were published in 1986 and 2004.[41][42] The examples in the first edition were written in Pascal. These were replaced in the later editions with examples written in Modula-2 and Oberon, respectively.[41][42]
In 1992, Wirth and Jürg Gutknecht published the full documentation of the Oberon operating system.[43] A second book, with Martin Reiser, was intended as a programming guide.[44]
Death
[edit | edit source]Wirth died in Zürich on New Year's Day 2024, at age 89.[6][45]
See also
[edit | edit source]- 21655 Niklauswirth asteroid
- Extended Backus–Naur form
- Wirth syntax notation
- Bucky bit
- Wirth–Weber precedence relationship
- List of pioneers in computer science
Notes
[edit | edit source]References
[edit | edit source]- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ a b c d e Zehnder, Carl August: "Wirth, Niklaus" in German, French and Italian in the online Historical Dictionary of Switzerland, 13 February 2024.
- ^ a b c Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Wirth, Program development by stepwise refinement, Communications of the ACM,. 14:221–227, ACM Press, 1971
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ * https://www.researchgate.net/scientific-contributions/Kathleen-Jensen-2058521472 Archived 6 January 2024 at the Wayback Machine
- https://dl.acm.org/profile/81334487416 Archived 6 January 2024 at the Wayback Machine
- https://dblp.org/pid/06/5848.html Archived 6 January 2024 at the Wayback Machine
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Citations collected by the Association for Computing Machinery (ACM)
- ^ a b Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ a b Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value). Out of print. Online version of a 2nd edition Archived 5 April 2014 at the Wayback Machine. 2005 edition, PDF. Archived 8 July 2021 at the Wayback Machine
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).. Out of print.
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
Further reading
[edit | edit source]- Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
External links
[edit | edit source]This February 2024's use of external links may not follow Wikipedia's policies or guidelines. (February 2024) |
Lua error in Module:Sister_project_links at line 396: attempt to index field 'wikibase' (a nil value).
- Official website, ETH Zürich
- Biography at ETH Zürich
- Niklaus Wirth at DBLP Bibliography ServerLua error in Module:EditAtWikidata at line 29: attempt to index field 'wikibase' (a nil value).
- Niklaus E. Wirth at ACM
- Turing Award Lecture, 1984
- Pascal and its Successors paper by Niklaus Wirth – also includes short biography.
- A Few Words with Niklaus Wirth
- The School of Niklaus Wirth: The Art of Simplicity, by László Böszörményi, Jürg Gutknecht, Gustav Pomberger (editors). dpunkt.verlag; Morgan Kaufmann Publishers, 2000. Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value)., Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value)..
- The book Compiler Construction
- The book Algorithms and Data Structures
- The book Project Oberon – The Design of an Operating System and Compiler. The book about the Oberon language and Operating System is now available as a PDF file. The PDF file has an additional appendix Ten Years After: From Objects to Components.
- Project Oberon 2013 Online 2nd Edition of the preceding book adapted for the reimplementation on FPGA hardware.
Lua error in Module:Authority_control at line 153: attempt to index field 'wikibase' (a nil value).
- 1934 births
- 2024 deaths
- ETH Zurich alumni
- Academic staff of ETH Zurich
- Swiss electronics engineers
- 1994 fellows of the Association for Computing Machinery
- Formal methods people
- Pascal (programming language)
- Programming language designers
- Programming language researchers
- Recipients of the Pour le Mérite (civil class)
- Swiss computer scientists
- Turing Award laureates
- Université Laval alumni
- People from Winterthur
- Computer science educators
- Scientists at PARC (company)
- UC Berkeley College of Engineering alumni
- Members of Academia Europaea
- Fellows of the American Academy of Arts and Sciences