Download presentation
Presentation is loading. Please wait.
1
LISP LISt Processing
2
History & Overview One of the oldest high level programming languages.
First developed in 1958 by John McCarthy. Later adopted as the primary research language of Artificial Intelligence (AI). The syntax of LISP is one of the least restrictive of any high-level programming languages.
3
History & Overview Was originally developed as an interpreted language, however, a number of current versions of LISP make use of an incremental compiler. Among LISP's strongest features is that programs may be treated as data. In LISP, entire programs can be used as input to other programs or sub-procedures directly.
4
Grammar List :: = ( [X1 X2 … Xn]) X :: = List | Atom
Atom :: = Number | Name Number :: = | | | -2 | 1 | 0 | 1 | 2 | | 1024 | . . . Name :: = a sequence of alphanumeric characters containing at least one letter and no separators Separator :: = . | space | ( | ) | [ | ] | ‘ | tab | carriage return all are characters with a particular role.
5
Features/Parts of LISP Definitions
Atom : A series of numbers or symbols that can’t be broken in to smaller components. Ex. Cat, Scott9, 684, 7Hearts, This-Is-A-Very-Long-Atom List : A sequence of atoms or other lists enclosed by parentheses LIST LENGTH () (John gives Mary a book) ((subject) (verb) (object)) ((+ X Y) (+ A B)) (1 2 3 A B C C B A 3 2 1) (()())
6
Features/Parts of LISP Syntax
The basic syntax for LISP is : (expression) Everything is expressed as a list or as part of a list, enclosed in parentheses Not case-sensitive Supports recursion
7
Features/Parts of LISP Syntax
The comment character is a semi-colon ‘;’ which can appear anywhere. This results in the remainder of the line being skipped. There are 2 main components of a list, the head of the list and the rest of the list The head of the list or the first list item is referred to as CAR. The rest of the list is referred to as CDR (Note: CAR & CDR were register names from the IBM mainframe that LISP was first written for.)
8
Features/Parts of LISP Syntax
Many times the CAR is a function with its arguments being CDR. The basic mathematical operations are a good example. (+ 4 2) (- 4 2) (* 4 2) (/ 4 2) Note the syntax for all functions is simply a list of symbols and numbers. All list operations return a value. This value is the last value in the list. For a procedure, the last value is the return or result value.
9
List Manipulation Some of the LISP primitives (built-in commands or functions) for manipulating lists are: LIST - Returns a list of its arguments > (list ) ( ) SETQ - Takes at least 2 arguments, the 1st being a variable name and the 2nd being any LISP expression. LISP evaluates the expression passed as the 2nd argument and assigns the value returned as the new value of the variable passed as the 1st argument. > (setq mylist (list )) > (setq yourlist (list )) ( ) ( )
10
List Manipulation CAR - Returns the first element of a list > (car mylist) 1 CDR - Returns a list of all elements except the first > (cdr mylist) (2 3 4) Nth - Returns a specific list element > (nth 3 mylist) > (nth 2 yourlist) 4 12
11
List Manipulation CONS - Short for concatenates Will insert a new element at the front of a list > (cons (car mylist) (cdr mylist)) ( ) > (cons (car mylist) (cdr yourlist)) ( ) > (cons mylist yourlist) (( ) )
12
List Manipulation APPEND - Adds new list elements to the end of a list > (append mylist yourlist) ( )
13
Functions DEFUN - This command is used to define functions which LISP refers to as a value-returning procedures > ( defun MyValueReturningProcedureName (optional_input_variables) ValueReturningProcedure_body )
14
Input/Output PRINT & PRINC - These will output an expression to the output device followed by a space. PRINT adds a line-feed. READ - This will read an expression from the input device.
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.