Robert W. Floyd

From Wikipedia, the free encyclopedia

Robert W. Floyd
Born(1936-06-08)June 8, 1936
DiedSeptember 25, 2001(2001-09-25) (aged 65)
Stanford, California, United States
CitizenshipUnited States
EducationUniversity of Chicago (B.A., 1953, 1958)
Known forFloyd–Warshall algorithm
Floyd–Steinberg dithering
Floyd's cycle-finding algorithm
Floyd's triangle
ALGOL
Spouse(s)Jana M. Mason; Christiane Floyd (née Riedl)
Children4
AwardsTuring Award (1978)
Computer Pioneer Award (1991)
Scientific career
FieldsComputer science
InstitutionsIllinois Institute of Technology
Carnegie Mellon University
Stanford University
Doctoral students

Robert W Floyd[1] (June 8, 1936 – September 25, 2001) was a computer scientist. His contributions include the design of the Floyd–Warshall algorithm (independently of Stephen Warshall), which efficiently finds all shortest paths in a graph and his work on parsing; Floyd's cycle-finding algorithm for detecting cycles in a sequence was attributed to him as well. In one isolated paper he introduced the important concept of error diffusion for rendering images, also called Floyd–Steinberg dithering (though he distinguished dithering from diffusion). He pioneered in the field of program verification using logical assertions with the 1967 paper Assigning Meanings to Programs. This was a contribution to what later became Hoare logic. Floyd received the Turing Award in 1978.

Life[edit]

Born in New York City, Floyd finished high school at age 14. At the University of Chicago, he received a Bachelor of Arts (B.A.) in liberal arts in 1953 (when still only 17) and a second bachelor's degree in physics in 1958. Floyd was a college roommate of Carl Sagan.[2]

Floyd became a staff member of the Armour Research Foundation (now IIT Research Institute) at Illinois Institute of Technology in the 1950s. Becoming a computer operator in the early 1960s, he began publishing many papers, including on compilers (particularly parsing). He was a pioneer of operator-precedence grammars, and is credited with initiating the field of programming language semantics in Floyd (1967). He was appointed an associate professor at Carnegie Mellon University by the time he was 27 and became a full professor at Stanford University six years later. He obtained this position without a Doctor of Philosophy (Ph.D.) degree.

He was a member of the International Federation for Information Processing (IFIP) IFIP Working Group 2.1 on Algorithmic Languages and Calculi,[3] which specified, maintains, and supports the programming languages ALGOL 60 and ALGOL 68.[4]

He was elected a Fellow of the American Academy of Arts and Sciences in 1974.[5]

He received the Turing Award in 1978 "for having a clear influence on methodologies for the creation of efficient and reliable software, and for helping to found the following important subfields of computer science: the theory of parsing, the semantics of programming languages, automatic program verification, automatic program synthesis, and analysis of algorithms".[6]

Floyd worked closely with Donald Knuth, in particular as the major reviewer for Knuth's seminal book The Art of Computer Programming, and is the person most cited in that work. He was co-author, with Richard Beigel, of the textbook The Language of Machines: an Introduction to Computability and Formal Languages.[7] Floyd supervised seven Ph.D. graduates.[8]

Floyd married and divorced twice, first with Jana M. Mason and then computer scientist Christiane Floyd, and he had four children. In his last years he suffered from Pick's disease, a neurodegenerative disease, and thus retired early in 1994.[6]

His hobbies included hiking, and he was an avid backgammon player:

We once were stuck at the Chicago O'Hare airport for hours, waiting for our flight to leave, owing to a snow storm. As we sat at our gate, Bob asked me, in a casual manner, "do you know how to play backgammon?" I answered I knew the rules, but why did he want to know? Bob said since we had several hours to wait perhaps we should play a few games, for small stakes of course. He then reached into his briefcase and removed a backgammon set.

My Dad taught me many things. One was to be wary of anyone who suggests a game of pool for money, and then opens a black case and starts to screw together a pool stick. I figured that this advice generalized to anyone who traveled with their own backgammon set. I told Bob that I was not going to play for money, no way. He pushed a bit, but finally said fine. He proceeded instead to give me a free lesson in the art and science of playing backgammon.

I was right to pass on playing him for money—at any stakes. The lesson was fun. I found out later that for years he had been working on learning the game. He took playing backgammon very seriously, studied the game and its mathematics, and was a near professional. I think it was more than a hobby. Like his research, Bob took what he did seriously, and it is completely consistent that he would be terrific at backgammon.

Selected publications[edit]

  • Floyd, Robert W. (1967). "Assigning Meanings to Programs" (PDF). In Schwartz, J.T. (ed.). Mathematical Aspects of Computer Science. Proceedings of Symposium on Applied Mathematics. Vol. 19. American Mathematical Society. pp. 19–32. ISBN 0821867288.
  • Floyd, Robert W.; Knuth, Donald Ervin (1970). The Bose-Nelson sorting problem. Stanford, California: Computer Science Department, Stanford University.
  • Floyd, Robert W.; Smith, Alan J. (1972). A linear time two tape merge. Stanford, California: Computer Science Department, Stanford University. OCLC 71469179.
  • Floyd, R. W. (1979). "The paradigms of programming". Communications of the ACM. 22 (8): 455. doi:10.1145/359138.359140.
  • Floyd, Robert W.; Ullman, Jeffrey D. (1980). "The Compilation of Regular Expressions into Integrated Circuits". NASA Sti/Recon Technical Report N. 81. Fairfax County, Virginia: Ft. Belvoir: Defense Technical Information Center: 12334. Bibcode:1980STIN...8112334F.
  • Floyd, Robert W.; Beigel, Richard (1994). The Language of Machines: an introduction to computability and formal languages. New York: W H Freeman & Company. ISBN 978-0-7167-8266-7.

Notes[edit]

  1. ^ Floyd had his middle name "Willoughby" legally changed to "W" but deemed abbreviating it as "W." valid (Knuth 2003) (DOD form DD 48-1, personal papers, Stanford University Archive catalog SC 625 box 4)
  2. ^ Stanford University Archives, Catalog SC 625, box 7
  3. ^ Jeuring, Johan; Meertens, Lambert; Guttmann, Walter (August 17, 2016). "Profile of IFIP Working Group 2.1". Foswiki. Archived from the original on March 8, 2021. Retrieved September 6, 2020.
  4. ^ Swierstra, Doaitse; Gibbons, Jeremy; Meertens, Lambert (March 2, 2011). "ScopeEtc: IFIP21: Foswiki". Foswiki. Archived from the original on September 2, 2018. Retrieved September 6, 2020.
  5. ^ "List of Members by Classes September 1, 1997". Records of the Academy (American Academy of Arts and Sciences) (1996/1997): 56–128. 1996. JSTOR 3786119.
  6. ^ a b "Robert W. Floyd". A.M. Turing Award Laureate. June 8, 1936. Retrieved February 14, 2024.
  7. ^ Floyd, Robert W.; Beigel, Richard (1994). The Language of Machines: an Introduction to Computability and Formal Languages. New York City: W. H. Freeman and Company. ISBN 978-0-7167-8266-7.
  8. ^ "Tree of Robert Floyd's students for the Computer History Exhibits". Stanford Computer History. Stanford University.
  9. ^ Lipton, Richard J. (August 28, 2010). "Lower Bounds and Progressive Algorithms". Wordpress.

Further reading[edit]

External links[edit]