
- LISP Tutorial
- LISP - Home
- LISP - Overview
- LISP - Environment
- LISP - REPL
- LISP - Program Structure
- LISP - Basic Syntax
- LISP - Data Types
- Lisp Macros
- LISP - Macros
- LISP - Backquote and Comma
- LISP - Code Generation Using Macro
- LISP - Variable Capture and Hygienic macro
- LISP - Scope and Binding
- LISP - Macro Writing Style
- LISP - Macro Characters
- LISP - Read-Time Macros
- LISP - Compiler Macros
- LISP - Uses of Macros
- Lisp Functions
- LISP - Functions
- LISP - Functions vs Macros
- LISP - Calling Function using funcall
- LISP - Calling Function using apply
- LISP - Closures
- LISP - Functions as Arguments
- LISP - Functions as Return Values
- LISP - Recursion
- LISP - Built-in Functions
- Lisp Predicates
- LISP - Predicates
- LISP - Generic Data Type Predicates
- LISP - Specific Data Type Predicates
- LISP - Equality Predicates
- LISP - Numeric Predicates
- LISP - Comparison Predicates
- LISP - Logical Predicates
- LISP - List Predicates
- LISP - Custom Predicates
- LISP - Chaining Predicates
- Lisp Arrays
- LISP - Arrays
- LISP - Adjustable Arrays
- LISP - Fill Pointers in Arrays
- LISP - Specialized Arrays
- LISP - Arrays Properties
- LISP - Iterating over Arrays
- LISP - Multidimensional Arrays
- LISP - Row-Major Order
- Lisp Strings
- LISP - Strings
- LISP - String Concatenation
- LISP - String Comparison
- LISP - String Case Conversion
- LISP - String Trimmimg
- LISP - String Searching
- LISP - Getting Substring
- LISP - String Replacement
- LISP - Sorting Strings
- LISP - Merging Strings
- LISP - Accessing Characters of String
- LISP - String length
- LISP - Escape Sequences
- Lisp Sequences
- LISP - Sequences
- LISP - Accessing Element of Sequence
- LISP - Sequence length
- LISP - Getting Subsequence
- LISP - Search Element in Sequence
- LISP - Sequence Concatenation
- LISP - Reversing a Sequence
- LISP - Mapping Sequence Element
- LISP - position of Element
- LISP - Remove an Element
- LISP - Sort Sequence
- LISP - Merge Sequences
- LISP - every function
- LISP - some function
- LISP - notany function
- LISP - notevery function
- Lisp Lists
- LISP - Lists
- LISP - Accessing Elements of Lists
- LISP - Modifications to Lists
- LISP - Using mapcar on List
- LISP - Using mapc on List
- LISP - Using reduce on List
- LISP - Removing elements from List
- LISP - Reversing a List
- LISP - Sorting a List
- LISP - Searching a List
- LISP - List vs Vectors
- LISP - Matrix Multiplication
- Lisp Vectors
- LISP - Vectors
- LISP - Creating Vectors
- LISP - Accessing Elements of Vectors
- LISP - Modifications to Vectors
- LISP - Adjustable Vectors
- LISP - Specialized Vectors
- LISP - Vector Functions
- Lisp Set
- LISP - Set
- LISP - Adding elements to the Set
- LISP - Getting SubSet from a Set
- LISP - Set Difference
- LISP - Set Exclusive OR
- LISP - Set Intersection
- LISP - Set Union
- LISP - Representing Set with HashTable
- LISP - List as Set vs HashTable as Set
- Lisp Tree
- LISP - Tree
- LISP - Recursive Traversal
- LISP - Inorder Traversal
- LISP - Preorder Traversal
- LISP - Postorder Traversal
- LISP - Depth First Traversal
- LISP - Modifying Tree
- LISP - Search Tree
- LISP - Binary Tree
- Lisp Hash Table
- LISP - Hash Table
- Adding Values to Hash Table
- Removing Values from Hash Table
- Updating Values of Hash Table
- Iterating Hash Table Entries
- Searching key in HashTable
- Checking Size of HashTable
- Using Custom Equality Check
- Lisp - Input − Output
- LISP - Input − Output
- LISP - Streams
- LISP - Reading Data from Streams
- LISP - Writing Data to Streams
- LISP - File I/O
- LISP - String I/O
- LISP - Formatting with Format
- LISP - Interactive I/O
- LISP - Error Handling
- LISP - Binary I/O
- Lisp - Structures
- LISP - Structures
- LISP - Accessors and Mutators
- LISP - Structure Options
- LISP - Structure Types
- LISP - Applications and Best Practices
- Lisp - CLOS
- LISP - CLOS
- Lisp - Objects
- LISP - Class
- LISP - Slots and Accessors
- LISP - Generic Functions
- LISP - Class Precedence
- LISP - Metaobject Protocol
- LISP - Multimethods
- LISP - Multiple Inheritance
- LISP - Method Combinations
- LISP - Method Combinations
- LISP - :before Method Combination
- LISP - :primary Method Combination
- LISP - :after Method Combination
- LISP - :around Method Combination
- LISP - + Method Combination
- LISP - and Method Combination
- LISP - append Method Combination
- LISP Useful Resources
- Lisp - Quick Guide
- Lisp - Useful Resources
- Lisp - Discussion
Lisp - Predicates
Predicates are functions that test their arguments for some specific conditions and returns nil if the condition is false, or some non-nil value is the condition is true.
The following table shows some of the most commonly used predicates −
Sr.No. | Predicate & Description |
---|---|
1 |
atom It takes one argument and returns t if the argument is an atom or nil if otherwise. |
2 |
equal It takes two arguments and returns t if they are structurally equal or nil otherwise. |
3 |
eq It takes two arguments and returns t if they are same identical objects, sharing the same memory location or nil otherwise. |
4 |
eql It takes two arguments and returns t if the arguments are eq, or if they are numbers of the same type with the same value, or if they are character objects that represent the same character, or nil otherwise. |
5 |
evenp It takes one numeric argument and returns t if the argument is even number or nil if otherwise. |
6 |
oddp It takes one numeric argument and returns t if the argument is odd number or nil if otherwise. |
7 |
zerop It takes one numeric argument and returns t if the argument is zero or nil if otherwise. |
8 |
null It takes one argument and returns t if the argument evaluates to nil, otherwise it returns nil. |
9 |
listp It takes one argument and returns t if the argument evaluates to a list otherwise it returns nil. |
10 |
greaterp It takes one or more argument and returns t if either there is a single argument or the arguments are successively larger from left to right, or nil if otherwise. |
11 |
lessp It takes one or more argument and returns t if either there is a single argument or the arguments are successively smaller from left to right, or nil if otherwise. |
12 |
numberp It takes one argument and returns t if the argument is a number or nil if otherwise. |
13 |
symbolp It takes one argument and returns t if the argument is a symbol otherwise it returns nil. |
14 |
integerp It takes one argument and returns t if the argument is an integer otherwise it returns nil. |
15 |
rationalp It takes one argument and returns t if the argument is rational number, either a ratio or a number, otherwise it returns nil. |
16 |
floatp It takes one argument and returns t if the argument is a floating point number otherwise it returns nil. |
17 |
realp It takes one argument and returns t if the argument is a real number otherwise it returns nil. |
18 |
complexp It takes one argument and returns t if the argument is a complex number otherwise it returns nil. |
19 |
characterp It takes one argument and returns t if the argument is a character otherwise it returns nil. |
20 |
stringp It takes one argument and returns t if the argument is a string object otherwise it returns nil. |
21 |
arrayp It takes one argument and returns t if the argument is an array object otherwise it returns nil. |
22 |
packagep It takes one argument and returns t if the argument is a package otherwise it returns nil. |
Example
Create a new source code file named main.lisp and type the following code in it.
main.lisp
; check and print if abcd is an atom? (write (atom 'abcd)) ; terminate printing (terpri) ; check and print if a is equals to b (write (equal 'a 'b)) ; terminate printing (terpri) ; check and print if 10 is an even number (write (evenp 10)) ; terminate printing (terpri) ; check and print if 7 is an even number (write (evenp 7 )) ; terminate printing (terpri) ; check and print if 7 is an odd number (write (oddp 7 )) ; terminate printing (terpri) ; check and print if provided number is 0 (write (zerop 0.0000000001)) ; terminate printing (terpri) ; check and print if 3 and 3.0 are same (write (eq 3 3.0 )) ; terminate printing (terpri) ;check and print if 3 and 3.0 are same (write (equal 3 3.0 )) ; terminate printing (terpri) ; check and print if nil is nil (write (null nil ))
Output
When you execute the code, it returns the following result −
T NIL T NIL T NIL NIL NIL T
Example
Update the source code file named main.lisp and type the following code in it.
main.lisp
; define a function factorial (defun factorial (num) ; if num is zero, return 1 (cond ((zerop num) 1) ; call factorial recursively with one less number (t ( * num (factorial (- num 1)))) ) ) ; set n as 6 (setq n 6) ; print the factorial of the number (format t "~% Factorial ~d is: ~d" n (factorial n))
Output
When you execute the code, it returns the following result −
Factorial 6 is: 720