Stephen Curtis Johnson (born 1944) is a computer scientist who worked at Bell Labs and AT&T for nearly 20 years. He is best known for Yacc, Lint, spell, and the Portable C Compiler, which contributed to the spread of Unix and C.[1] He has also contributed to fields as diverse as computer music, psychometrics and VLSI design.[2]

Stephen C. Johnson
Born
Stephen Curtis Johnson

1944 (age 79–80)
Alma mater
OccupationComputer scientist
Known forYacc, Lint, Portable C Compiler
Scientific career
FieldsComputer science
InstitutionsBell Labs
ThesisCategorical decompositions (1968)
Doctoral advisorsSamuel Eilenberg

Life and education

edit

Johnson's passion for computing started at age five, when his grandfather took him along to his work at the Bureau of Standards. The computer he saw ("the size of a small house") made a strong impression on him, and he decided he "wanted to work with computers, and never looked back after".[2]

There were no computer science classes in college, so he studied mathematics, in which he eventually earned a PhD.

Career

edit

Bell Labs and AT&T

edit

Johnson joined Bell Labs and AT&T in the 1960s and worked on Unix tools for nearly 20 years, alongside computer scientists like Jeffrey Ullman, Dennis Ritchie and Alfred Aho. He was best known for writing Yacc, Lint, and the Portable C Compiler.

In the mid-1970s, Johnson and Bell colleague Dennis Ritchie co-authored the first AT&T Unix port. They also "demonstrated that Unix was portable", which Ritchie considers the spark that led to Unix becoming widespread.[3] In the mid-1980s, he served as the head of the UNIX Languages Department (UNIX System V).[2]

Johnson developed Yacc in the early '70s because he wanted to insert an exclusive or operator into Ritchie's B language compiler.[4] Bell Labs colleague Alfred Aho suggested he look at Donald Knuth's work on LR parsing, which served as the basis for Yacc.[2] In a 2008 interview, Johnson reflected that "the contribution Yacc made to the spread of Unix and C is what I'm proudest of".[1] Lint was developed in 1978 while Johnson was debugging the Yacc grammar he was writing for C and struggling with portability issues stemming from porting Unix to a 32-bit machine.[2][5]

Silicon Valley

edit

In 1986, Johnson moved to Silicon Valley, where he joined several startups, where he worked mostly on compilers, but also 2D and 3D graphics, massively parallel computing and embedded systems. The startups included Dana Computer, Inc.,[6] Melismatic Software, and Transmeta, which made low-power, Intel-compatible microprocessors.[2]

Johnson served on the USENIX board for ten years, including four years as president in the early 1990s. He now serves as the USENIX representative to the Computing Research Association.[citation needed]

Later career

edit

In 2002, he moved to Boston to work at MathWorks,[7] where he helped maintain the front end of the MATLAB programming language, for which he also built a lint product called M-Lint. He had met MathWorks founder Cleve Moler while working at a Silicon Valley startup and developed a "long-distance consulting relationship" with him in the 1990s.[2]

As of 2018 Johnson currently lived in Morgan Hill, California busy working on energy-efficient computers for machine learning at Wave Computing.[8]

References

edit
  1. ^ a b Hamilton, Naomi (10 July 2008). "Yacc, Unix, and Advice from Bell Labs Alumni Stephen Johnson". Computerworld. Retrieved 19 January 2018.
  2. ^ a b c d e f g Morris, Richard (1 October 2009). "Stephen Curtis Johnson: Geek of the Week". Red Gate Software. Retrieved 19 January 2018.
  3. ^ Ritchie, Dennis (September 1994). "How Did We Get Here, Where Are We Going?". AUUG Conference Proceedings. Australia: AUUG, Inc. p. 4. ISBN 978-0-646-20108-5.
  4. ^ Ritchie, Dennis M. (April 1993). The Development of the C Language (PDF). Association for Computing Machinery.
  5. ^ Johnson, Stephen C. (25 October 1978). "Lint, a C Program Checker". Comp. Sci. Tech. Rep: 78–1273. CiteSeerX 10.1.1.56.1841.
  6. ^ Watt, Peggy (15 June 1987). "Jobs Pushes for New Unix Standard: Usenix Attendees Defend Operating System". InfoWorld. Retrieved 19 January 2018.
  7. ^ "USENIX '04 Training Track Instructors". USENIX. Retrieved 19 January 2018.
  8. ^ Johnson, Steve. "What's it All About". Yaccman.com. Retrieved 19 January 2018.