Reading CS Classics Revisiting Required Reading
Total Page:16
File Type:pdf, Size:1020Kb
viewpoints VDOI:10.1145/2133806.2133818 Selma Tekir Viewpoint Reading CS Classics Revisiting required reading. E OFTEN FOCUS so much and 1970s in Britain. The program- of our attention on our ming languages community of those particular research ar- Knowledge of the years was also well described in the eas that we do not fully theories of computer reading. Hoare wrote a more efficient utilize the potential sort algorithm than the one invented science helps 9 Wcoming from the core theoretical com- by D.L. Shell. When he had the op- puter science. We lack the fundamen- in understanding portunity to hear about the recursive tal theoretical knowledge of the field. procedures in an ALGOL 60 course, Moreover, the computer science clas- the limitations Hoare realized this mechanism is sics are unknown to many computer of the field. the right way of expressing his new scientists. Knowledge of the theories sort algorithm, which is the original of computer science helps in under- QuickSort. The moral of this example standing the limitations of the field. is that one should communicate with This directly influences your ongoing people to seek better solutions to the research by providing you with new problems at hand and extend the ex- perspectives and insights. In addition, isting solutions. His remark on sim- the stories of the pioneers of the field ˲ “Gödel’s Undecidability Theo- plification is of high importance as inspire young professionals, provide a rem,” S.F. Andrilli well. A simple, reliable core is criti- common history to unite the commu- ˲ “Computing Machinery and Intel- cal for a programming language, an nity, and facilitate the recognition of ligence,” A.M. Turing operating system, and even for any computer science as an independent ˲ “Reflections on Trusting Trust,” K. software product. With this realiza- science and profession. Thompson tion, Hoare provides a foundation for With these ideas in mind, I orga- ˲ “The Humble Programmer,” E.W. the formal proofs of programs by an nized CS classics meetings in my com- Dijkstra algebraic assertions-based approach, puter engineering department during ˲ “An Interview with Edsger W. Dijks- which is named as “An Axiomatic Ba- the last summer term. Our group se- tra,” P. Frana sis for Computer Programming.”7 lected a subset of classics to initialize ˲ “Computer Programming as an Gödel’s undecidability theorem1 the project. The selected classics and Art,” D. Knuth states that any mathematical system their respective ordering reflected our ˲ “The ‘Art’ of Being Donald Knuth,” containing all the theorems of arith- personal interests; in the end, they be- E. Feigenbaum metic is an incomplete system. This come part of a coherent whole. ˲ “Donald Knuth: A Life’s Work In- opens the way for Turing to introduce It can be a good practice for CS pro- terrupted,” E. Feigenbaum the famous halting problem: There is fessionals to compile their own list of We found these intellectual gath- no general algorithm that can always classics that highlights some key scien- erings quite useful and subsequently correctly predict whether a randomly tific concepts of the field. Such an at- decided to make the CS classics group selected computer program will run tempt improves the understanding of reading a regular activity of our aca- or not.11 Before knowing about Gödel the field and serves as a valuable source demic environment. Here, I give an and his undecidability theorem, Tur- of reference, as this Viewpoint attests. overview of the classics we discussed ing stands out as the most prominent Our group discussed these CS classics: and encourage further reading. figure in computer science. After you ˲ “The Emperor’s Old Clothes,” hear about Gödel’s work, you realize C.A.R. Hoare Classics Overview Turing is standing on the shoulders of ˲ “An Axiomatic Basis for Computer In reading Hoare,6,7 you learn about giants. The proof of the undecidability Programming,” C.A.R. Hoare the computing industry of the 1960s theorem has important implications 32 COMMUNICATIONS OF THE ACM | APRIL 2012 | VOL. 55 | NO. 4 V viewpoints viewpoints for computer science by introducing period and the products that were herent in computer science. Abstrac- the Gödel numbering scheme, which launched, independent but consis- tion is extending the viewpoint in a introduces unique numbering to each tent views are required. In this sense, way that the specificities of the prob- symbol, formula, or proof in the sys- Dijkstra and Hoare’s identical views lem can be reflected in a better way tem. This system is the basis of the on ALGOL 60 help us appreciate this rather than being vague. The tools computer numbering systems that programming language. Additionally, we work with can then have vital im- provide unique representation to every the realization of the recursion mech- portance in abstracting. Dijkstra’s programming construct: due to this anism by both is spectacular—a good comment on computing tools is re- property, code can be treated as data. example of the axiom “great minds markable in this sense:2 he states that The idea of this unique numbering think alike.” computing tools have direct influence system can be better explained by the Dijkstra’s dialogue with his profes- on the thinking habits of their users. challenge of writing a source program sor cannot be overlooked. Most signifi- If you constrain yourself with one that, when compiled and executed, cant is his realization of the high intel- specific tool, your thinking becomes will produce as output an exact copy lectual challenge of programming and constrained in the boundaries of this of its source. It is a Turing machine the professor’s encouragement that tool. You continue to stay at the same SELF that is printing itself. The SELF made him one of the greatest minds of level of thinking as the creator of this machine is constructed such that it computer programming.5 tool in accordance with the famous contains two concatenated machines One lesson comes from the huge quote by Einstein: “The significant and one of them is the Gödel number abstraction capability/potential in- problems we face cannot be solved at equivalent of the other. Such a self- the same level of thinking we were at reproducing program is introduced when we created them.” by Ken Thompson in “Reflections on Reading CS classics Donald Knuth is extraordinary with Trusting Trust”10 as the most primitive his perspective on computer program- version of today’s trojans. When you widens your ming.3,4 His definition of programming see the scientific layers on top of each perspective by identifies the right balance between other like the one presented, you begin conceptual clarity and implementation to appreciate the real beauty of science introducing stable, efficiency. He says: “Programming is and the scientific developments. timeless ideas. the art of telling another human being By reading Dijkstra independent what one wants the computer to do.” EET DUGGAL G from his contemporary Hoare you In understanding the importance H BY H BY P have information about the comput- of this definition, one should realize it ing environment of that era. To make is beyond the traditional definition of PHOTOGRA a correct assessment of that time the task of telling a computer what to APRIL 2012 | VOL. 55 | NO. 4 | COMMUNICATIONS OF THE ACM 33 viewpoints do. Knuth’s viewpoint is more encom- bining the assessments of Dijkstra References passing and is helpful in understand- and Knuth, what we (plan to) do is not 1. Andrilli, S.F. Gödel’s Undecidability Theorem. Applications of Discrete Mathematics. J.G. Michaels ing the diversity and convergence of independent of how we (plan to) do it. and K.H. Rosen, Eds. McGraw-Hill, 1991. programming languages. Moreover, The process is a good indicator of the 2. Dijkstra, E.W. The humble programmer. Commun. ACM 51, 10 (Oct. 1972), 859–866; DOI: it points out an important trade-off resultant product most of the time. 10.1145/355604.361591. between conceptual clarity and imple- 3. Feigenbaum, E. Donald Knuth: A life’s work interrupted. Shustek, L., Ed. Commun. ACM 51, 8 (Aug. mentation efficiency. When the task is Conclusion 2008), 31–35; DOI: 10.1145/1378704.1378715. to define a job to a computer, low-level Reading CS classics widens your per- 4. Feigenbaum, E. The ‘art’ of being Donald Knuth. Shustek, L., Ed. Commun. ACM 51, 7 (July 2008), instructions are better in terms of ex- spective by introducing stable, time- 35–39; DOI: 10.1145/1364782.1364794. ecution efficiency. However, people less ideas. You escape the popular 5. Frana, P. An interview with Edsger W. Dijkstra. T.J. Misa, Ed. Commun. ACM 53, 8 (Aug. 2010), 41–47; have difficulty in understanding such themes of your times and evaluate the DOI: 10.1145/1787234.1787249. 6. Hoare, C.A.R. The emperor’s old clothes. written code. When you try to describe field from a more literal position. You Commun. ACM 24, 2 (Feb. 1981), 75–83; DOI: a task to a human being, you can skip learn about the qualities that make a 10.1145/358549.358561. 7. Hoare, C.A.R. An axiomatic basis for computer some steps because humans are good person a great scientist. You realize programming. Commun. ACM 12, 10 (Oct. 1969), at filling in the blanks; machines have those people are delighted to think 576–580; DOI: 10.1145/363235.363259. 8. Knuth, D.E. Computer programming as an art. difficulty doing this. The best is to over problems. By learning the histo- Commun. ACM 17, 12 (Dec. 1974), 667–673; DOI: compromise: to discuss the task at a ry of computers and studying the lives 10.1145/361604.361612.