Content deleted Content added
m Bot: link syntax and minor changes |
Altered journal. Add: authors 1-1. Removed parameters. Some additions/deletions were parameter name changes. | Use this tool. Report bugs. | #UCB_Gadget |
||
(94 intermediate revisions by 40 users not shown) | |||
Line 1:
{{Short description|Computer science textbook}}
{{Redirect|SICP}}
{{Infobox book
| italic title = force
| name = Structure and Interpretation of Computer Programs (SICP)
| image = SICP cover.jpg
| caption = Cover of the second edition
| author = [[Harold Abelson]], [[Gerald Jay Sussman]], Julie Sussman
| cover_artist =
| country =
| series =
| subject = [[Computer science]]
| genre = [[Textbook]]
| publisher = [[MIT Press]]
| pub_date =
| media_type =
| pages = 657
| isbn = 0-262-51087-1
| isbn_note = (2nd ed.)
| oclc =
| dewey =
| congress = QA76.6 .A255 1996
| website = {{URL|mitpress.mit.edu/sicp}}
}}
'''''Structure and Interpretation of Computer Programs''''' ('''''SICP''''') is a [[computer science]] textbook by [[Massachusetts Institute of Technology]]
MIT Press published a [[JavaScript]] version of the book in 2022.<ref>{{Cite book |publisher=MIT Press |year=2022 |url=https://mitpress.mit.edu/books/structure-and-interpretation-computer-programs-1 |title=Structure and Interpretation of Computer Programs: JavaScript Edition |isbn=9780262543231}}</ref>
The book describes computer science concepts using [[Scheme (programming language)|Scheme]], a dialect of [[Lisp (programming language)|Lisp]]. It also uses a [[virtual machine|virtual]] [[register machine]] and [[Assembly language#Assember|assembler]] to implement Lisp [[Interpreter (computing)|interpreter]]s and [[compiler]]s.▼
==
▲The book describes computer science concepts using [[Scheme (programming language)|Scheme]], a dialect of [[Lisp (programming language)|Lisp]]. It also uses a [[virtual machine|virtual]] [[register machine]] and [[Assembly language#
Several fictional characters appear in the book:▼
Topics in the books are:
=== Chapter 1: Building [[Abstraction (computer science)|Abstractions]] with [[Function (computer programming)|Procedures]] ===
# The Elements of Programming
# Procedures and the [[Process (computing)|Processes]] They Generate
# Formulating Abstractions with Higher-Order Procedures
=== Chapter 2: Building Abstractions with [[Data]] ===
# Introduction to Data Abstraction
# Hierarchical Data and the [[Closure (mathematics)|Closure Property]]
# Symbolic Data
# Multiple Representations for Abstract Data
# Systems with Generic Operations
=== Chapter 3: Modularity, [[Object (computer science)|Objects]], and [[State (computer science)|State]] ===
# [[Assignment (computer science)|Assignment]] and [[Local variable|Local State]]
# The Environment Model of Evaluation
# Modeling with Mutable Data
# [[Concurrency (computer science)|Concurrency]]: Time Is of the Essence
# Streams
=== Chapter 4: [[Metalinguistics|Metalinguistic]] Abstraction ===
# The [[Meta-circular evaluator|Metacircular Evaluator]]
# Variations on a Scheme – [[Lazy evaluation|Lazy Evaluation]]
# Variations on a Scheme – [[Nondeterministic algorithm|Nondeterministic Computing]]
# [[Logic programming|Logic Programming]]
=== Chapter 5: Computing with [[Register machine|Register Machines]] ===
# Designing [[Register machine|Register Machines]]
# A Register-Machine Simulator
# [[Register allocation|Storage Allocation]] and [[Garbage collection (computer science)|Garbage Collection]]
# The Explicit-Control Evaluator
# Compilation
== Characters ==
▲Several humorously-named fictional characters appear in the book:
* Alyssa P. Hacker, a Lisp [[hacker]]
* Ben Bitdiddle
* [[Side effect (computer science)|Cy D. Fect]], a "reformed C programmer"
* [[Evaluator|Eva Lu Ator
* Lem E. Tweakit
* Louis Reasoner, a "loose reasoner"
== License ==
The book is licensed under a [[Creative Commons]] Attribution
==
The book was used as the textbook for MIT's former introductory programming course, 6.001
▲The book is licensed under a [[Creative Commons]] Attribution ShareAlike 4.0 License.<ref>{{Cite web |url=http://mitpress.mit.edu/sicp/ |title=SICP |publisher=MIT Press}}.</ref>
==
''[[Byte (magazine)|Byte]]'' recommended SICP in 1986 "for professional programmers who are really interested in their profession". The magazine said that the book was not easy to read, but that it would expose experienced programmers to both old and new topics.<ref name="kilov198611">{{cite
▲The book was used as the textbook for MIT's former introductory programming course, 6.001.<ref>{{cite web |url=http://ocw.mit.edu/OcwWeb/Electrical-Engineering-and-Computer-Science/6-001Spring-2005/CourseHome/ |title=Electrical Engineering and Computer Science; 6.001 Structure and Interpretation of Computer Programs |date=Spring 2005 |website=OpenCourseWare |publisher=MIT |access-date=2011-06-28}}</ref> That course was replaced by 6.0001,<ref>{{Citation |title=Catalog |url=http://student.mit.edu/catalog/search.cgi?search=6.0001 |contribution=6.0001 |publisher=MIT}}.</ref> which uses [[Python (programming language)|Python]].<ref>{{Citation |first=Donald |last=Guy |quote=I talked to Professor Sussman on the phone... He said that he'd actually been trying to have 6.001 replaced for the last ten years (and I read somewhere that Professor Abelson was behind the move too). Understanding the principles is not essential for an introduction to the subject matter anymore. He sees 6.001 as obsolete. |url=https://web.archive.org/web/20180821202714/http://mitadmissions.org/blogs/entry/the_end_of_an_era_1 |title=MIT Admissions |type=blog comment |contribution=The End of an Era |access-date=2008-08-05}}.</ref> Other schools also made use of the book as a course textbook.<ref>{{cite web |first=Edward C. |last=Martin |url=http://www.schemers.com/schools.html |title=Schools |publisher=Schemers |date=2009-07-20 |access-date=2011-06-28}}</ref> It is used as the textbook for MIT's Large Scale Symbolic Systems class, 6.945.<ref>{{cite web |url=http://eduapps.mit.edu/textbook/books.html?Term=2016SP&Subject=6.945 |title=Large Scale Symbolic Systems class, 6.945 |website=MIT Touchstone |access-date=2019-06-16<!--Page does not display-->}}</ref>
A review of SICP as an undergraduate textbook by [[Philip Wadler]] noted the weaknesses of the Scheme language as an introductory language for a computer science course.<ref>{{Cite journal |last=Wadler |first=P |date=1987-03-01 |title=A critique of Abelson and Sussman or why calculating is better than scheming |url=https://dl.acm.org/doi/10.1145/24697.24706 |journal= ACM SIGPLAN Notices|volume=22 |issue=3 |pages=83–94 |doi=10.1145/24697.24706 |issn=0362-1340}}</ref> Wadler criticized in particular the lack of [[pattern matching]], obscuring [[equational reasoning]] and making the teaching of proofs harder; the lack of [[Algebraic data type|algebraic data types]] in Scheme and the over-reliance on [[cons]] pairs for both code and data representation, which can confuse beginning students; and the choice of [[Strict evaluation|strict]] instead of [[lazy evaluation]] as the standard evaluation strategy.
▲''[[Byte (magazine)|Byte]]'' recommended SICP "for professional programmers who are really interested in their profession". The magazine said that the book was not easy to read, but that it would expose experienced programmers to both old and new topics.<ref name="kilov198611">{{cite news |last=Kilov |first=Haim |date=November 1986 |title=Structure and Interpretation of Computer Programs |work=Byte |page=70}}</ref>
== Influence ==
SICP has been influential in computer science education, and several later books have been inspired by its style.
* ''[[Structure and Interpretation of Classical Mechanics]] (SICM)'', another book that uses Scheme as an instructional element, by Gerald Jay Sussman
* ''[[Software Design for Flexibility]]'', by Chris Hanson and Gerald Jay Sussman
* ''[[How to Design Programs]] (HtDP)'', which intends to be a more accessible book for introductory Computer Science, and to address perceived * ''[[Essentials of Programming Languages]] (EoPL)'', a book for Programming Languages courses
== See also ==
* ''[[Compilers: Principles, Techniques, and Tools]]''{{snd}} also known as ''The Dragon Book''
{{Main|Structure and Interpretation of Computer Programs, JavaScript Adaptation}}▼
== References ==
{{Reflist}}
== External links ==
* {{Official website|mitpress.mit.edu/sicp}}
* [
* [https://
▲
{{Lisp programming language}}
{{Authority control}}
[[Category:
[[Category:1996 non-fiction books]]
[[Category:Computer science books]]
|