ebook img

Lisp PDF

435 Pages·1980·13.032 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Lisp

PATRICK HENRY WIINSTON BERTHOLD KLAUS PAUL HORN INSTITUTE LIBRARY 0 (0S -5 LISP Patrick Henry Winston Massachusetts Institute of Technology Berthold Klaus Paul Horn Massachusetts Institute of Technology A ADDISON-WESLEY PUBLISHING COMPANY Reading, Massachusetts Menlo Park, California London Amsterdam Don Mills, Ontario Sydney Reproduced by Addison-Wesley from camera-ready copy supplied by the authors. Copyright © 1981 by Addison-Wesley Publishing Company, Inc. Philippines copyright 1981 by Addison-Wesley Publishing Company, Inc. All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted, in any form or by any means, electronic, mechanical, photocopying, recording, or otherwise, without the prior written permission of the publisher. Printed in the United States of America. Published simultaneously in Canada. Library of Congress Catalog Card No. 80-65599. ISBN 0-201-08329-9 CDEFGHIJ-AL-8987654321 PREFACE This book has two parts. The purpose of Part One is to introduce the basics of LISP programming. The first nine chapters of Part One, together with selected material from the remaining three, are appropriate for an introductory subject on LISP. People studying Part One will understand the basic ideas of symbol manipulation and know how to use LISP in contexts that are interesting, albeit simple. Writing programs to do search, for example, will be straightforward. The purpose of Part Two is to demonstrate how LISP is used in practice. We have selected examples with a view toward illustrating ideas that are well-known in Artificial Intelligence and related fields. In dealing with these examples, we discuss rules of good programming practice, basic debugging tools, data-driven programming, and building embedded interpreters and compilers. The chapters of Part Two, together with selected material from the last three chapters of Part One, are appropriate for an intermediate-to-advanced subject on how to exploit LISP. People studying Part Two will be ready to work on the big systems that are now common in parts of Artificial Intelligence such as problem solving, pattern matching, expert systems, natural language understanding, and frame systems. MACLISP is the dialect of LISP used in this book. People who have access to INTERLISP but not MACLISP should note that an appendix describes the differences that are relevant to doing the exercises with the help of a computer. Other appendices supply an index of LISP functions, give a sample of terminal interaction using LISP, and provide supplementary notes for some of the more esoteric ideas. Some of the material in this book is drawn from an earlier book, Artificial Intelligence. Occasionally a paragraph or example has been transferred verbatim because we could not think of a better way of doing something. For the most part, however, the borrowed material has been extensively revised, augmented, and generally improved: .ii Preface iv Chapter 11 of Artificial Intelligence, Basic LISP Programming, has been distributed over the first eight chapters of this book. Chapter 12, The Blocks World, is now part of Chapters 13 and 16. Chapters 14 and 15 build on the blocks world material in new ways. Chapter 13, The Games World, which introduced an alpha-beta program, has been replaced by Chapter 11 on search. Chapter 14, Symbolic Pattern Matching, has become Chapter 17, with the addition of a simple resolution theorem prover for propositional calculus. The material on solving algebra word problems has been omitted and the DOCTOR program appears only in an exercise. Chapter 15, Implementing Embedded Languages, is hardly recognizable. The ATN compiler is now in Chapter 20, but it is preceded by an ATN interpreter in Chapter 19 and followed by a data-base interface in Chapter 21. The low-level, cognitive-model, production-system interpreter has been replaced by a more general, higher-level, MYCIN-like deduction system, described in Chapter 18. The LISP interpreter, improved to deal with issues of variable scoping and closure, is now in Chapter 23. Chapter 16, Data Bases and Demons, has been replaced by Chapter 22 on frames. Certainly this book supersedes Part Two of Artificial Intelligence, and someday we will want to revise, augment, improve, and separate out Part One of that book too. At this writing, however, it regrettably looks like that will take a while. P.H.W. B.K.P.H. Acknowledgements ACKNOWLEDGEMENTS The cover design and the drawings are by Karen Prendergast. Mike Brady, Boris Katz, James Meehan, Robin Stanton, and Guy Steele read various drafts of this book with great care. In addition, the authors were helped considerably by Harold Abelson, Richard Brown, Will Clinger, Ken Forbus, Bernard Greenberg, Kent Pitman, Karen Prendergast, Charles Rich, Carol Roberts, Richard Stallman, and Clement Wang. We wish we had sufficient time to incorporate more of their suggestions. Most of the research work described in the examples in the second part of this book was sponsored by the Defense Advanced Research Projects Agency. vii Contents CONTENTS PART I UNDERSTANDING SYMBOL MANIPULATION 1 Symbol Manipulation is Like Working with Words and Sentences - Symbol Manipulation is Needed to Make Computers Intelligent - LISP is the Right Symbol-Manipulation Language to Learn - The First Part of the Book Introduces LISP - The Second Part of the Book Demonstrates LISP's Power - There are some Myths about LISP. 2 BASIC LISP FUNCTIONS 13 LISP Means Symbol Manipulation - LISP Programs and Data Are Constructed out of S-expressions - LISP Handles Both Fixed and Floating Numbers - CAR and CDR Take Lists Apart - Evaluation is often Purposely Inhibited by Quoting - Composing CARs and CDRs Makes Programming Easier - Atoms Have Values - APPEND, LIST, and CONS Construct Lists - LENGTH, REVERSE, SUBST, and LAST Round out a Basic Repertoire - The Interpreter Evaluates S-expressions - EVAL Causes Extra Evaluation. Contents viii 3 DEFINITIONS, PREDICATES, CONDITIONALS, AND SCOPING 33 DEFUN Enables a User to Make New Functions - A Predicate Is a Function Whose Value Is T or NIL - AND, OR, and NOT are used to do Logic - Predicates Help COND Select a Value among Alternatives - COND Enables DEFUN to do More - Variables May Be Free or Bound - LISP is Neither Call-by-reference nor Call-by-value - Free-variable Values are Determined Dynamically, not Lexically - Function Names can be Used as Arguments. 4 RECURSION AND ITERATION 51 Programming Requires Control Structure Selection - Recursion Allows Programs to Use Themselves - Dealing with Lists often Calls for Iteration using MAPCAR - PROG Creates Variables and Supports Explicit Iteration - PROG-based Iteration should be done with Care - Problems and their Representation Determine Proper Control Structure. 5 PROPERTIES, A-LISTS, ARRAYS, 71 AND ACCESS FUNCTIONS Properties and Property Values Generalize the Notion of Atom and Value - PUTPROP and GET are the Masters of Property Lists - ASSOC Retrieves Pairs from Association Lists - STORE and ARRAY are used with Arrays - Access Functions Simplify Data Interactions. 6 USING LAMBDA DEFINITIONS 79 LAMBDA Defines Anonymous Functions - LAMBDA is Often Used to Interface Functions to Argument Lists - MAPCAN Facilitates Filtering - Style is a Personal Matter. 7 PRINTING, READING, AND ATOM MANIPULATION 87 PRINT and READ Facilitate Communication - Special Conventions Make Weird Atom Names Possible - Atoms can be Broken Apart, Put Together, and Created - Exotic Input/Output Functions Lie Beyond PRINT and READ - Formatted Printing is Easily Arranged. 8 DEFINING FEXPRS AND MACROS 97 FEXPRs are Functions that do not Evaluate their Arguments - MACROs Translate and then Execute. ix Contents 9 LIST STORAGE, RECLAMATION, AND SURGERY 103 Networks of Memory Cells Represent Lists - Atoms have Pointers that Determine their Value - Single Quote Marks are a Shorthand Form for the Function QUOTE - CONS Builds New List Structure by Depositing Pointers in Free Cells - Garbage Collection Reclaims Memory Cells for the Free Storage List - APPEND Builds New List Structure by Copying - NCONC, RPLACA, RPLACD, and DELETE Dangerously Replace Memory-cell Contents - EQUAL is Not the Same as EQ. 10 EXAMPLES INVOLVING BINARY IMAGES 121 Binary Images are Easy to Process - An Object can be Found Using Binary Image Analysis - Features found in Binary Images can be used for Classificaton - Components of a Binary Images can be Labeled in Two Passes. 11 EXAMPLES INVOLVING SEARCH 137 Breadth-first and Depth-first Search are Basic Strategies - A Node Queue Facilitates Depth-first Search and Breadth-first Search - Best-first Search and Hill-climbing Require Sorting. 12 EXAMPLES FROM MATHEMATICS 155 It is Easy to Translate Infix Notation to Prefix - It is Useful to Represent Sparse Matrices as S-expressions - Roots of Numbers can be Found Using Tail Recursion - Roots of Algebraic Equations can be Found Using Nested Functions. PART II 13 THE BLOCKS WORLD 179 The Blocks-World Svstem Creates a Plan - The Blocks-World System Requires some Number-crunching Functions - The Blocks-World System's Functions are Relatively Transparent - The Number-crunching Functions can be Faked - Simulation Is Straightforward. Contents x 14 RULES FOR GOOD PROGRAMMING AND DEBUGGING 189 The Block-World System Illustrates some Rules of Good Programming Practice - It is Often Useful to Stop Procedure Execution using BREAK - TRACE Causes Functions to Print their Arguments and their Values - LISP Systems Offer many Debugging Features. 15 ANSWERING QUESTIONS ABOUT GOALS 197 The Blocks-World System Can Introspect to a Degree - Remembering Function Calls Creates a Useful History - It can be Convenient to Make a new Function-defining Function. 16 GETTING FUNCTIONS FROM DATA 211 Functions and Object Types Form a Table - Arguments may Supply their Own Procedures - FUNCALL Enables Function Names or Descriptions to be Computed - Data-driven Programming is becoming Popular. 17 SYMBOLIC PATTERN MATCHING 219 AND SIMPLE THEOREM PROVING Basic Pattern Matching is Easy to Implement in LISP - Matching Involves Comparison of Similar S-Expressions - Simultaneous Binding Adds Expressive Power to Matching Operations - Restrictions Limit What a Pattern Variable Can Match - Resolution is one way to Prove Theorems in Propositional Calculus - Resolution Proves Theorems by Showing they Cannot be False - Many Matching Problems Remain. 18 EXPERT PROBLEM SOLVING USING IF-THEN RULES 239 Identification World Illustrates how If-then Systems Work - Facts and Rules can be Represented Easily - Forward Chaining Means Working from Facts to Conclusions. 19 INTERPRETING AUGMENTED TRANSITION NETWORKS 251 Augmented Transition Networks Capture English Syntax - Satisfying an Augmented Transition Network Constitutes a Kind of Match - Making LISP from Augmented Transition Networks is Easy - An ATN Interpreter Follows a Retained Description - Registers Add Power to ATN Descriptions - ATN Specifications may be Involved.

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.