Andrew S. Tanenbaum

Appearance move to sidebar hide

Andy Tanenbaum
Tanenbaum in 2012
BornAndrew Stuart Tanenbaum
(1944-03-16) March 16, 1944
New York City, New York, U.S.
NationalityAmerican
Alma materMassachusetts Institute of Technology
University of California, Berkeley
Known forMINIX
Microkernels
Electoral-vote.com
Scientific career
FieldsDistributed computing
Operating systems
ThesisA Study of the Five Minute Oscillations, Supergranulation, and Related Phenomena in the Solar Atmosphere (1971)
Doctoral advisorJohn M. Wilcox
Doctoral studentsHenri Bal
Frans Kaashoek
Werner Vogels
Websitecs.vu.nl/~ast
pearsonhighered.com/tanenbaum

Andrew Stuart Tanenbaum (born March 16, 1944), sometimes referred to by the handle ast, is an American computer scientist and professor emeritus of computer science at the Vrije Universiteit Amsterdam in the Netherlands.

He is the author of MINIX, a free Unix-like operating system for teaching purposes, and has written multiple computer science textbooks regarded as standard texts in the field. He regards his teaching job as his most important work. Since 2004 he has operated Electoral-vote.com, a website dedicated to analysis of polling data in federal elections in the United States.

Biography

Tanenbaum was born in New York City and grew up in suburban White Plains, New York, where he attended the White Plains High School. His paternal grandfather was born in Khorostkiv in the Austro-Hungarian empire.

He received his Bachelor of Science degree in physics from MIT in 1965 and his PhD degree in astrophysics from the University of California, Berkeley in 1971.

He moved to the Netherlands to live with his wife, who is Dutch, but he retains his United States citizenship. He taught courses on Computer Organization and Operating Systems and supervised the work of PhD candidates at the VU University Amsterdam. On July 9, 2014, he announced his retirement.

Teaching

Books

Tanenbaum's textbooks on computer science include:

His book, Operating Systems: Design and Implementation and MINIX were Linus Torvalds' inspiration for the Linux kernel. In his autobiography Just for Fun, Torvalds describes it as "the book that launched me to new heights".

His books have been translated into many languages including Arabic, Basque, Bulgarian, Chinese, Dutch, French, German, Greek, Hebrew, Hungarian, Italian, Japanese, Korean, Macedonian, Mexican Spanish, Persian, Polish, Portuguese, Romanian, Russian, Serbian, and Spanish. They have appeared in over 175 editions and are used at universities around the world.

Doctoral students

Tanenbaum has had a number of PhD students who themselves have gone on to become widely known computer science researchers. These include:

Dean of the Advanced School for Computing and Imaging

In the early 1990s, the Dutch government began setting up a number of thematically oriented research schools that spanned multiple universities. These schools were intended to bring professors and PhD students from different Dutch (and later, foreign) universities together to help them cooperate and enhance their research.

Tanenbaum was one of the cofounders and first Dean of the Advanced School for Computing and Imaging (ASCI). This school initially consisted of nearly 200 faculty members and PhD students from the Vrije Universiteit, University of Amsterdam, Delft University of Technology, and Leiden University. They were especially working on problems in advanced computer systems such as parallel computing and image analysis and processing.

Tanenbaum remained dean for 12 years, until 2005, when he was awarded an Academy Professorship by the Royal Netherlands Academy of Arts and Sciences, at which time he became a full-time research professor. ASCI has since grown to include researchers from nearly a dozen universities in The Netherlands, Belgium, and France. ASCI offers PhD level courses, has an annual conference, and runs various workshops every year.

Projects

Amsterdam Compiler Kit

The Amsterdam Compiler Kit is a toolkit for producing portable compilers. It was started sometime before 1981 and Andrew Tanenbaum was the architect from the start until version 5.5.

MINIX

In 1987, Tanenbaum wrote a clone of UNIX, called MINIX (MINi-unIX), for the IBM PC. It was targeted at students and others who wanted to learn how an operating system worked. Consequently, he wrote a book that listed the source code in an appendix and described it in detail in the text. The source code itself was available on a set of floppy disks. Within three months, a Usenet newsgroup, comp.os.minix, had sprung up with over 40,000 subscribers discussing and improving the system. One of these subscribers was a Finnish student named Linus Torvalds, who began adding new features to MINIX and tailoring it to his own needs. On October 5, 1991, Torvalds announced his own (POSIX-like) kernel, called Linux, which originally used the MINIX file system but is not based on MINIX code.

Although MINIX and Linux have diverged, MINIX continues to be developed, now as a production system as well as an educational one. The focus is on building a highly modular, reliable, and secure operating system. The system is based on a microkernel, with only 5000 lines of code running in kernel mode. The rest of the operating system runs as a number of independent processes in user mode, including processes for the file system, process manager, and each device driver. The system continuously monitors each of these processes, and when a failure is detected is often capable of automatically replacing the failed process without a reboot, without disturbing running programs, and without the user even noticing. MINIX 3, as the current version is called, is available under the BSD license for free.

In 2017, Google discovered that the Intel Management Engine runs MINIX in ring -3. After Tanenbaum read about this, he published an open letter to Intel, detailing conversations with Intel software engineers that occurred several years ago, where they wanted his assistance in modifying MINIX to work on "some secret project". He believes that Intel chose MINIX for this purpose because it is licensed under the BSD-3-Clause license, which allowed Intel to modify the MINIX source code without freely distributing their modified version. In his letter, Tanenbaum claims that MINIX is the most widespread operating system, and this is interpreted by the community as Tanenbaum believing that he has won the Tanenbaum–Torvalds debate. It is hard to know if MINIX or Linux is more popular, as Intel does not publish chipset sales figures, and there is no direct way to find the number of systems running Linux or MINIX. However, Linux has seen much more widespread use in the server space, is widely used in embedded systems, and also runs on all Android phones, which account for at least 3 billion active devices, meaning that it is likely that Linux is the most widespread operating system, although there is no concrete data to back up this claim.

Research projects

Tanenbaum has also been involved in numerous other research projects in the areas of operating systems, distributed systems, and ubiquitous computing, often as supervisor of PhD students or a postdoctoral researcher. These projects include:

Electoral-vote.com

In 2004, Tanenbaum created Electoral-vote.com, a web site analyzing opinion polls for the 2004 U.S. Presidential Election, using them to project the outcome in the Electoral College. He stated that he created the site as an American who "knows first hand what the world thinks of America and it is not a pretty picture at the moment. I want people to think of America as the land of freedom and democracy, not the land of arrogance and blind revenge. I want to be proud of America again." The site provided a color-coded map, updated each day with projections for each state's electoral votes. Through most of the campaign period Tanenbaum kept his identity secret, referring to himself as "the Votemaster" and acknowledging only that he personally preferred John Kerry. Mentioning that he supported the Democrats, he revealed his identity on November 1, 2004, the day before the election, and also stating his reasons and qualifications for running the website.

Through the site he also covered the 2006 midterm elections, correctly predicting the winner of all 33 Senate races that year.

For the 2008 elections, he got every state right except for Indiana, which he said McCain would win by 2% (Obama won by 1%) and Missouri, which he said was too close to call (McCain won by 0.1%). He correctly predicted all the winners in the Senate except for Minnesota, where he predicted a 1% win by Norm Coleman over Al Franken. After 7 months of legal battling and recounts, Franken won by 312 votes (0.01%).

In 2010, he correctly projected 35 out of 37 Senate races in the Midterm elections on the website. The exceptions were Colorado and Nevada.

Electoral-vote.com incorrectly predicted Hillary Clinton would win the 2016 United States presidential election. The website incorrectly predicted Clinton would win Wisconsin, Michigan, Pennsylvania, North Carolina, and Florida. Electoral-vote.com did not predict a winner for Nevada, which Clinton would win. The website predicted the winners of the remaining 44 states and the District of Columbia correctly.

Tanenbaum–Torvalds debate

The Tanenbaum–Torvalds debate was a famous debate between Tanenbaum and Linus Torvalds regarding kernel design on Usenet in 1992.

Awards

Honorary doctorates

Tanenbaum in Târgu Mureș Tanenbaum is 4th from left

Keynote talks

Tanenbaum has been keynote speaker at numerous conferences, most recently

References

  1. ^ Bal, H. E.; Steiner, J. G.; Tanenbaum, A. S. (1989). "Programming languages for distributed computing systems". ACM Computing Surveys. 21 (3): 261. doi:10.1145/72551.72552. hdl:1871/2587. S2CID 8028479. Archived from the original on April 17, 2024. Retrieved December 8, 2019.
  2. ^ a b Steen, Maarten van; Tanenbaum, Andrew S. (2007). Distributed systems: principles and paradigms. Upper Saddle River, NJ: Pearson Prentice Hall. ISBN 978-0-13-239227-3.
  3. ^ a b Tanenbaum, Andrew S. (2008). Modern operating systems. Upper Saddle River, NJ: Pearson Prentice Hall. ISBN 978-0-13-600663-3.
  4. ^ a b Tanenbaum, Andrew S. (1995). Distributed operating systems. Englewood Cliffs, N.J: Prentice Hall. ISBN 978-0-13-219908-7.
  5. ^ a b Vogels, Werner (2003). Scalable Cluster Technologies for Mission Critical Enterprise Computing (PhD thesis). Vrije Universiteit. hdl:1871/10357.
  6. ^ A. S. Tanenbaum (January 29, 1992). "LINUX is obsolete". Newsgroupcomp.os.minix. Usenet: [email protected]. Archived from the original on January 22, 2011. Retrieved November 27, 2006.
  7. ^ Works by Andrew S. Tanenbaum at Open Library
  8. ^ Andrew S. Tanenbaum at DBLP Bibliography Server
  9. ^ 2004 article Archived May 24, 2004, at the Wayback Machine about Linux, the Usenet debate, and the Alexis de Tocqueville Institution
  10. ^ a b c "Andrew S. Tanenbaum's FAQ". Archived from the original on December 6, 2008. Retrieved April 25, 2023.
  11. ^ "Retirement of Prof. Andy Tanenbaum". Archived from the original on March 29, 2023. Retrieved March 29, 2023.
  12. ^ Tanenbaum, Andrew S. (2006). Structured computer organization. Upper Saddle River, NJ: Pearson Prentice Hall. ISBN 978-0-13-148521-1.
  13. ^ David Wetherall; Tanenbaum, Andrew S.; Nickolas Feamster (2019). Computer networks. Upper Saddle River, NJ: Pearson Prentice Hall. ISBN 978-0-13-540800-1.
  14. ^ Albert S Woodhull; Tanenbaum, Andrew S. (2006). Operating systems: design and implementation. Upper Saddle River, NJ: Pearson Prentice Hall. ISBN 978-0-13-142938-3.
  15. ^ Andrew S. Tanenbaum - Publications Archived May 9, 2007, at the Wayback Machine
  16. ^ Andrew S. Tanenbaum - Publications, Colloquia section Archived May 9, 2007, at the Wayback Machine
  17. ^ "Amazon.com: Operating Systems Design and Implementation (3rd Edition) (Prentice Hall Software Series): Andrew S Tanenbaum, Albert S Woodhull: Books". Archived from the original on May 28, 2020. Retrieved August 29, 2017.
  18. ^ Some notes on the "Who wrote Linux" Kerfuffle Archived August 18, 2010, at the Wayback Machine
  19. ^ "USENIX April 06" (PDF). Archived (PDF) from the original on August 7, 2007. Retrieved July 17, 2007.
  20. ^ "Andrew S. Tanenbaum, Professor at the Vrije Universiteit". Archived from the original on January 11, 2010. Retrieved October 29, 2009.
  21. ^ Minnich, Ronald. "Replace your exploit-ridden firmware with a Linux kernel" (PDF). schd.ws. Archived from the original (PDF) on January 31, 2018. Retrieved October 8, 2023.
  22. ^ Tanenbaum, Andrew. "An Open Letter to Intel". Vrije Universiteit Department of Computer Science. Archived from the original on August 27, 2023. Retrieved October 8, 2023.
  23. ^ dahitokiri (April 3, 2019). "Andrew Tanenbaum's famous 1992 comp.os.minix newsgroup posting in which he criticizes Linux's monolithic kernel as well as Linus Torvald's first response in a very long thread". r/programming. Archived from the original on June 11, 2023. Retrieved October 8, 2023.
  24. ^ Schoon, Ben (May 11, 2022). "Numbers from Google I/O: 3x growth for Wear OS, 3 billion active Android devices, more". 9to5 Google. Archived from the original on May 12, 2023. Retrieved October 8, 2023.
  25. ^ Tanenbaum, A. S.; Van Renesse, R.; Van Staveren, H.; Sharp, G. J.; Mullender, S. J. (1990). "Experiences with the Amoeba distributed operating system" (PDF). Communications of the ACM. 33 (12): 46. doi:10.1145/96267.96281. hdl:1871/2583. S2CID 1147771. Archived (PDF) from the original on August 26, 2021. Retrieved July 21, 2022.
  26. ^ Van Steen, M.; Homburg, P.; Tanenbaum, A. S. (1999). "Globe: A wide area distributed system" (PDF). IEEE Concurrency. 7: 70. doi:10.1109/4434.749137. hdl:1871/12837. S2CID 9181192. Archived (PDF) from the original on September 23, 2021. Retrieved December 8, 2019.
  27. ^ Noordende, Guido van ’t; Brazier, Frances M. T.; Tanenbaum, Andrew S. (2002). Mansion: A Structured Middleware Environment for Agents (PDF) (Report). Division of Mathematics and Computer Science, Vrije Universiteit Amsterdam. Archived from the original on August 26, 2021. Retrieved July 21, 2022.
  28. ^ Bal, H. E.; Kaashoek, M. F.; Tanenbaum, A. S. (1992). "Orca: A language for parallel programming of distributed systems" (PDF). IEEE Transactions on Software Engineering. 18 (3): 190. doi:10.1109/32.126768. hdl:1871/2576. S2CID 1513191. Archived (PDF) from the original on May 9, 2019. Retrieved July 21, 2022.
  29. ^ Van Doorn, L.; Homburg, P.; Tanenbaum, A. S. (1995). "Paramecium: An extensible object-based kernel". Proceedings 5th Workshop on Hot Topics in Operating Systems (HotOS-V). p. 86. doi:10.1109/HOTOS.1995.513460. hdl:1871/2565. ISBN 978-0-8186-7081-7. S2CID 10004092. Archived from the original on April 17, 2024. Retrieved November 2, 2020.
  30. ^ Mitrokotsa, A.; Rieback, M. R.; Tanenbaum, A. S. (2009). "Classifying RFID attacks and defenses". Information Systems Frontiers. 12 (5): 491. doi:10.1007/s10796-009-9210-z. S2CID 11923232. Archived from the original on April 17, 2024. Retrieved December 8, 2019.
  31. ^ a b "The Votemaster FAQ". Archived from the original on November 2, 2004. Retrieved February 26, 2017.
  32. ^ "ElectoralVote". Archived from the original on November 1, 2020. Retrieved February 10, 2019.
  33. ^ "LINUX is obsolete". Archived from the original on March 28, 2023. Retrieved March 29, 2023.
  34. ^ "IEEE Fellows 1998 | IEEE Communications Society". Archived from the original on September 27, 2023. Retrieved September 17, 2023.
  35. ^ "Andrew Tanenbaum". Royal Netherlands Academy of Arts and Sciences. Archived from the original on July 21, 2015. Retrieved July 17, 2015.
  36. ^ "USENIX Flame Award". Archived from the original on October 6, 2012. Retrieved October 24, 2008.
  37. ^ "IEEE James H. Mulligan, Jr. Education Medal Recipients" (PDF). IEEE. Archived from the original (PDF) on November 24, 2010. Retrieved November 24, 2010.

External links

Wikiquote has quotations related to Andrew S. Tanenbaum. Wikimedia Commons has media related to Andrew S. Tanenbaum.