SlideShare a Scribd company logo
Declarations in Lisp
DeclarationsDeclarations allow the user to specify extra information about the program to Lisp system.Declarations are truly optional but special declarations do effect the interpretation of the variable bindings and references and so must be specified wherever necessary.Declarations are one of the good ways to add documentation to the program.
overviewDeclaration syntaxDeclaration specifiersType declaration for forms
Declaration syntaxdeclare construct is used to embed declarations within the executable code.A declare form is known as the declaration.A declaration may occur only at the beginning of the bodies of the certain special forms.declare  {decl-spec}*
Declarations may occur in the lambda expressions and in the forms listed below:
Variable bindings appear only to the bindings made by the form at the head of whose body they appear.(defun foo (x)  (declare (type float x))..(let  (( x’a)) …)….) The type declaration applies only to the outer binding of the x and not to the binding made in the let.The scope of the declaration always includes the body forms, as well as any “stepper” or “result” forms, of the special forms or lambda-expressions.If the declaration applies to a name binding, then the scope of declaration also includes the scope of the name binding.
locally  {declaration}* {form}*This macro is used to make local pervasive declarations where desired.This construct does not bind any variables.Special declaration may be used with lacally to pervasively affect references to, rather than bindings of, variables.The function proclaim takes a decl-spec as its argument and puts it into effect globally.
proclaim decl-specThe proclaim takes decl-spec as the argument and puts it into effect globally.Ex: (proclaim ‘(type float tolerance)) specifies that the dynamic value of the tolerance should always be a floating-point number.A proclaim takes special decl-spec as applying to all bindings as well as to all references of the mentioned variables.This macro is syntactically like declare and semantically like proclaim.It is an executable form and may be used anywhere proclaim may be called.declaim {decl-spec}*
Declaration specifiersList of valid declaration  specifiers for use in declare.(special var1 var2….) specifies that all of the variables named are to be considered special.(type var1, var2,…) affects only variable bindings and specifies that the variables mentioned will take on values only of the specified type.
(ftype type function-name-1, function-name-2,…) specifies that the named functions will be of the function type type.Ex: (declare (ftype(function (integer list) t) nth)                   (ftype (function (number) float) sin cos))To extend ftype declaration specifiers to accept any function-name, one may write(declaim (ftype (function (list) t) (setf cadr)))
(inline function1, function2,…)specifies that it is desirable for the compiler to open code calls to the specified functions.The compiler is free to ignore this declaration.(notinline function1, function2,…)specifies that it is undesirable for the compiler to compile the specified functions inline.This declaration  is pervasive and the compiler is not free to ignore this declaration.(ignore var1,var2,….) affects only variable bindings and specifies that the bindings of the specified variables are never used.(optimize (quality1 value1) (quality2 vale2)…) advises compiler that each quality must be given attention according to the specified corresponding value.
(declaration name1, name2,…) advises the compiler that each namej is a valid but non-standard declaration name.The is kind of declaration may be used only as a proclamation.Ex: (proclaim ‘(declaration author                              target-language                              target-machine))   (proclaim ‘(target-language ada))   (proclaim ‘(target-machine IBM-650))(defun strangep(x)  (declare (author “Harry Tweeker”)) (member  x’(strange weird odd peculiar)))
Type declarations for formsThe special form is defined to declare the type of value held by a bound variable.(the type form)the type of value means the type of value of is declared to be of type type.the value-type formthe form is evaluated and whatever it produces is returned by the form, it is an error if what is returned by the form does not confirm to the data-type specified by value-type.
Examples:(the string (copy-seq x)) the result will be a string.(the integer (+ x 3)) the result of + will be an integer.(+ (the integer x) 3)the value of x will be an integer.
Visit more self help tutorialsPick a tutorial of your choice and browse through it at your own pace.The tutorials section is free, self-guiding and will not involve any additional support.Visit us at www.dataminingtools.net

More Related Content

What's hot (17)

PPTX
CONDITIONAL STATEMENT IN C LANGUAGE
Ideal Eyes Business College
 
PDF
Loops and conditional statements
Saad Sheikh
 
PPTX
Storage Classes and Functions
Jake Bond
 
PPTX
Storage class in c
kash95
 
PPTX
Storage classes in C
Self employed
 
PPTX
Introduction to Basic C programming 02
Wingston
 
PPT
Lecture 13 - Storage Classes
Md. Imran Hossain Showrov
 
PDF
Ooabapnoteswithprogram good 78
Yogesh Mehra
 
PDF
Pl sql programme
Dhilip Prakash
 
PPTX
C++ decision making
Zohaib Ahmed
 
PPTX
Storage classes in C
Nitesh Bichwani
 
PPTX
Storage Class in C Progrmming
Kamal Acharya
 
PDF
Lecture04(control structure part i)
Dhaka University of Engineering & Technology(DUET)
 
PPTX
First c program
NageswaraRao Gogisetti
 
PDF
C programing Tutorial
Mahira Banu
 
PPTX
11 lec 11 storage class
kapil078
 
PPTX
C if else
Ritwik Das
 
CONDITIONAL STATEMENT IN C LANGUAGE
Ideal Eyes Business College
 
Loops and conditional statements
Saad Sheikh
 
Storage Classes and Functions
Jake Bond
 
Storage class in c
kash95
 
Storage classes in C
Self employed
 
Introduction to Basic C programming 02
Wingston
 
Lecture 13 - Storage Classes
Md. Imran Hossain Showrov
 
Ooabapnoteswithprogram good 78
Yogesh Mehra
 
Pl sql programme
Dhilip Prakash
 
C++ decision making
Zohaib Ahmed
 
Storage classes in C
Nitesh Bichwani
 
Storage Class in C Progrmming
Kamal Acharya
 
Lecture04(control structure part i)
Dhaka University of Engineering & Technology(DUET)
 
First c program
NageswaraRao Gogisetti
 
C programing Tutorial
Mahira Banu
 
11 lec 11 storage class
kapil078
 
C if else
Ritwik Das
 

Viewers also liked (20)

PDF
Norihicodanch
Filip Yang
 
PPT
Excel Datamining Addin Intermediate
DataminingTools Inc
 
PDF
Apresentação Red Advisers
mezkita
 
PPT
Festivals Refuerzo
guest9536ef5
 
PPTX
Art, Culture, and Technology
TVWS, LLC
 
PPT
2008 IEDM presentation
slrommel
 
PPT
Research Presentation
guest136b28e
 
PPTX
Quick Look At Classification
DataminingTools Inc
 
XLSX
Test
spencer shanks
 
PPTX
Retrieving Data From A Database
DataminingTools Inc
 
PPTX
Oracle: Joins
DataminingTools Inc
 
PPTX
Mysql:Operators
DataminingTools Inc
 
PPTX
Pentaho: Reporting Solution Development
DataminingTools Inc
 
PPTX
Txomin Hartz Txikia
irantzugoitia86
 
PPT
Eugene SRTS Program
Eugene SRTS
 
PPTX
Data Mining The Sky
DataminingTools Inc
 
PPT
HistoriografíA Latina LatíN Ii
lara
 
PPTX
Data Applied: Similarity
DataminingTools Inc
 
PPTX
Data Applied:Outliers
DataminingTools Inc
 
PPTX
Matlab: Discrete Linear Systems
DataminingTools Inc
 
Norihicodanch
Filip Yang
 
Excel Datamining Addin Intermediate
DataminingTools Inc
 
Apresentação Red Advisers
mezkita
 
Festivals Refuerzo
guest9536ef5
 
Art, Culture, and Technology
TVWS, LLC
 
2008 IEDM presentation
slrommel
 
Research Presentation
guest136b28e
 
Quick Look At Classification
DataminingTools Inc
 
Retrieving Data From A Database
DataminingTools Inc
 
Oracle: Joins
DataminingTools Inc
 
Mysql:Operators
DataminingTools Inc
 
Pentaho: Reporting Solution Development
DataminingTools Inc
 
Txomin Hartz Txikia
irantzugoitia86
 
Eugene SRTS Program
Eugene SRTS
 
Data Mining The Sky
DataminingTools Inc
 
HistoriografíA Latina LatíN Ii
lara
 
Data Applied: Similarity
DataminingTools Inc
 
Data Applied:Outliers
DataminingTools Inc
 
Matlab: Discrete Linear Systems
DataminingTools Inc
 
Ad

Similar to LISP: Declarations In Lisp (20)

PPTX
LISP: Scope and extent in lisp
DataminingTools Inc
 
PPTX
LISP: Scope and extent in lisp
LISP Content
 
PPTX
LISP:Control Structures In Lisp
DataminingTools Inc
 
PPTX
LISP: Control Structures In Lisp
LISP Content
 
PDF
Advanced features of Lisp functions Advanced features of Lisp functions
CvDs3
 
PPTX
LISP: Type specifiers in lisp
DataminingTools Inc
 
PPTX
LISP: Type specifiers in lisp
LISP Content
 
PPTX
LISP:Program structure in lisp
DataminingTools Inc
 
PPTX
LISP: Program structure in lisp
LISP Content
 
PPT
INTRODUCTION TO LISP
Nilt1234
 
PPTX
LISP: Macros in lisp
DataminingTools Inc
 
PPTX
LISP: Macros in lisp
LISP Content
 
PPTX
1614745770521_vivek macros.pptx
VivekSaini87
 
PPT
CODING-DAY-2-INTRODUCTION TO C PROGRAMMING.ppt
adamjackson818417
 
PDF
Pc module1
SANTOSH RATH
 
PDF
C programming session7
Keroles karam khalil
 
PDF
C programming session7
Keroles karam khalil
 
PPTX
Chapter-3 الشابتر الثالث هياكل بيانات جامعة خالد .pptx
HakimAlHuribi
 
PDF
Subprogram
baran19901990
 
LISP: Scope and extent in lisp
DataminingTools Inc
 
LISP: Scope and extent in lisp
LISP Content
 
LISP:Control Structures In Lisp
DataminingTools Inc
 
LISP: Control Structures In Lisp
LISP Content
 
Advanced features of Lisp functions Advanced features of Lisp functions
CvDs3
 
LISP: Type specifiers in lisp
DataminingTools Inc
 
LISP: Type specifiers in lisp
LISP Content
 
LISP:Program structure in lisp
DataminingTools Inc
 
LISP: Program structure in lisp
LISP Content
 
INTRODUCTION TO LISP
Nilt1234
 
LISP: Macros in lisp
DataminingTools Inc
 
LISP: Macros in lisp
LISP Content
 
1614745770521_vivek macros.pptx
VivekSaini87
 
CODING-DAY-2-INTRODUCTION TO C PROGRAMMING.ppt
adamjackson818417
 
Pc module1
SANTOSH RATH
 
C programming session7
Keroles karam khalil
 
C programming session7
Keroles karam khalil
 
Chapter-3 الشابتر الثالث هياكل بيانات جامعة خالد .pptx
HakimAlHuribi
 
Subprogram
baran19901990
 
Ad

More from DataminingTools Inc (20)

PPTX
Terminology Machine Learning
DataminingTools Inc
 
PPTX
Techniques Machine Learning
DataminingTools Inc
 
PPTX
Machine learning Introduction
DataminingTools Inc
 
PPTX
Areas of machine leanring
DataminingTools Inc
 
PPTX
AI: Planning and AI
DataminingTools Inc
 
PPTX
AI: Logic in AI 2
DataminingTools Inc
 
PPTX
AI: Logic in AI
DataminingTools Inc
 
PPTX
AI: Learning in AI 2
DataminingTools Inc
 
PPTX
AI: Learning in AI
DataminingTools Inc
 
PPTX
AI: Introduction to artificial intelligence
DataminingTools Inc
 
PPTX
AI: Belief Networks
DataminingTools Inc
 
PPTX
AI: AI & Searching
DataminingTools Inc
 
PPTX
AI: AI & Problem Solving
DataminingTools Inc
 
PPTX
Data Mining: Text and web mining
DataminingTools Inc
 
PPTX
Data Mining: Outlier analysis
DataminingTools Inc
 
PPTX
Data Mining: Mining stream time series and sequence data
DataminingTools Inc
 
PPTX
Data Mining: Mining ,associations, and correlations
DataminingTools Inc
 
PPTX
Data Mining: Graph mining and social network analysis
DataminingTools Inc
 
PPTX
Data warehouse and olap technology
DataminingTools Inc
 
PPTX
Data Mining: Data processing
DataminingTools Inc
 
Terminology Machine Learning
DataminingTools Inc
 
Techniques Machine Learning
DataminingTools Inc
 
Machine learning Introduction
DataminingTools Inc
 
Areas of machine leanring
DataminingTools Inc
 
AI: Planning and AI
DataminingTools Inc
 
AI: Logic in AI 2
DataminingTools Inc
 
AI: Logic in AI
DataminingTools Inc
 
AI: Learning in AI 2
DataminingTools Inc
 
AI: Learning in AI
DataminingTools Inc
 
AI: Introduction to artificial intelligence
DataminingTools Inc
 
AI: Belief Networks
DataminingTools Inc
 
AI: AI & Searching
DataminingTools Inc
 
AI: AI & Problem Solving
DataminingTools Inc
 
Data Mining: Text and web mining
DataminingTools Inc
 
Data Mining: Outlier analysis
DataminingTools Inc
 
Data Mining: Mining stream time series and sequence data
DataminingTools Inc
 
Data Mining: Mining ,associations, and correlations
DataminingTools Inc
 
Data Mining: Graph mining and social network analysis
DataminingTools Inc
 
Data warehouse and olap technology
DataminingTools Inc
 
Data Mining: Data processing
DataminingTools Inc
 

Recently uploaded (20)

PDF
Transcript: New from BookNet Canada for 2025: BNC BiblioShare - Tech Forum 2025
BookNet Canada
 
PDF
Bitcoin for Millennials podcast with Bram, Power Laws of Bitcoin
Stephen Perrenod
 
PDF
Newgen Beyond Frankenstein_Build vs Buy_Digital_version.pdf
darshakparmar
 
DOCX
Python coding for beginners !! Start now!#
Rajni Bhardwaj Grover
 
PDF
Building Real-Time Digital Twins with IBM Maximo & ArcGIS Indoors
Safe Software
 
PDF
Staying Human in a Machine- Accelerated World
Catalin Jora
 
PDF
How do you fast track Agentic automation use cases discovery?
DianaGray10
 
PPTX
Webinar: Introduction to LF Energy EVerest
DanBrown980551
 
PDF
Mastering Financial Management in Direct Selling
Epixel MLM Software
 
PDF
Smart Trailers 2025 Update with History and Overview
Paul Menig
 
PDF
CIFDAQ Market Insights for July 7th 2025
CIFDAQ
 
PDF
Go Concurrency Real-World Patterns, Pitfalls, and Playground Battles.pdf
Emily Achieng
 
PDF
Agentic AI lifecycle for Enterprise Hyper-Automation
Debmalya Biswas
 
PPTX
The Project Compass - GDG on Campus MSIT
dscmsitkol
 
PDF
What’s my job again? Slides from Mark Simos talk at 2025 Tampa BSides
Mark Simos
 
PDF
Achieving Consistent and Reliable AI Code Generation - Medusa AI
medusaaico
 
PDF
Book industry state of the nation 2025 - Tech Forum 2025
BookNet Canada
 
PDF
"Beyond English: Navigating the Challenges of Building a Ukrainian-language R...
Fwdays
 
PDF
The Rise of AI and IoT in Mobile App Tech.pdf
IMG Global Infotech
 
PDF
Automating Feature Enrichment and Station Creation in Natural Gas Utility Net...
Safe Software
 
Transcript: New from BookNet Canada for 2025: BNC BiblioShare - Tech Forum 2025
BookNet Canada
 
Bitcoin for Millennials podcast with Bram, Power Laws of Bitcoin
Stephen Perrenod
 
Newgen Beyond Frankenstein_Build vs Buy_Digital_version.pdf
darshakparmar
 
Python coding for beginners !! Start now!#
Rajni Bhardwaj Grover
 
Building Real-Time Digital Twins with IBM Maximo & ArcGIS Indoors
Safe Software
 
Staying Human in a Machine- Accelerated World
Catalin Jora
 
How do you fast track Agentic automation use cases discovery?
DianaGray10
 
Webinar: Introduction to LF Energy EVerest
DanBrown980551
 
Mastering Financial Management in Direct Selling
Epixel MLM Software
 
Smart Trailers 2025 Update with History and Overview
Paul Menig
 
CIFDAQ Market Insights for July 7th 2025
CIFDAQ
 
Go Concurrency Real-World Patterns, Pitfalls, and Playground Battles.pdf
Emily Achieng
 
Agentic AI lifecycle for Enterprise Hyper-Automation
Debmalya Biswas
 
The Project Compass - GDG on Campus MSIT
dscmsitkol
 
What’s my job again? Slides from Mark Simos talk at 2025 Tampa BSides
Mark Simos
 
Achieving Consistent and Reliable AI Code Generation - Medusa AI
medusaaico
 
Book industry state of the nation 2025 - Tech Forum 2025
BookNet Canada
 
"Beyond English: Navigating the Challenges of Building a Ukrainian-language R...
Fwdays
 
The Rise of AI and IoT in Mobile App Tech.pdf
IMG Global Infotech
 
Automating Feature Enrichment and Station Creation in Natural Gas Utility Net...
Safe Software
 

LISP: Declarations In Lisp

  • 2. DeclarationsDeclarations allow the user to specify extra information about the program to Lisp system.Declarations are truly optional but special declarations do effect the interpretation of the variable bindings and references and so must be specified wherever necessary.Declarations are one of the good ways to add documentation to the program.
  • 4. Declaration syntaxdeclare construct is used to embed declarations within the executable code.A declare form is known as the declaration.A declaration may occur only at the beginning of the bodies of the certain special forms.declare {decl-spec}*
  • 5. Declarations may occur in the lambda expressions and in the forms listed below:
  • 6. Variable bindings appear only to the bindings made by the form at the head of whose body they appear.(defun foo (x) (declare (type float x))..(let (( x’a)) …)….) The type declaration applies only to the outer binding of the x and not to the binding made in the let.The scope of the declaration always includes the body forms, as well as any “stepper” or “result” forms, of the special forms or lambda-expressions.If the declaration applies to a name binding, then the scope of declaration also includes the scope of the name binding.
  • 7. locally {declaration}* {form}*This macro is used to make local pervasive declarations where desired.This construct does not bind any variables.Special declaration may be used with lacally to pervasively affect references to, rather than bindings of, variables.The function proclaim takes a decl-spec as its argument and puts it into effect globally.
  • 8. proclaim decl-specThe proclaim takes decl-spec as the argument and puts it into effect globally.Ex: (proclaim ‘(type float tolerance)) specifies that the dynamic value of the tolerance should always be a floating-point number.A proclaim takes special decl-spec as applying to all bindings as well as to all references of the mentioned variables.This macro is syntactically like declare and semantically like proclaim.It is an executable form and may be used anywhere proclaim may be called.declaim {decl-spec}*
  • 9. Declaration specifiersList of valid declaration specifiers for use in declare.(special var1 var2….) specifies that all of the variables named are to be considered special.(type var1, var2,…) affects only variable bindings and specifies that the variables mentioned will take on values only of the specified type.
  • 10. (ftype type function-name-1, function-name-2,…) specifies that the named functions will be of the function type type.Ex: (declare (ftype(function (integer list) t) nth) (ftype (function (number) float) sin cos))To extend ftype declaration specifiers to accept any function-name, one may write(declaim (ftype (function (list) t) (setf cadr)))
  • 11. (inline function1, function2,…)specifies that it is desirable for the compiler to open code calls to the specified functions.The compiler is free to ignore this declaration.(notinline function1, function2,…)specifies that it is undesirable for the compiler to compile the specified functions inline.This declaration is pervasive and the compiler is not free to ignore this declaration.(ignore var1,var2,….) affects only variable bindings and specifies that the bindings of the specified variables are never used.(optimize (quality1 value1) (quality2 vale2)…) advises compiler that each quality must be given attention according to the specified corresponding value.
  • 12. (declaration name1, name2,…) advises the compiler that each namej is a valid but non-standard declaration name.The is kind of declaration may be used only as a proclamation.Ex: (proclaim ‘(declaration author target-language target-machine))  (proclaim ‘(target-language ada)) (proclaim ‘(target-machine IBM-650))(defun strangep(x) (declare (author “Harry Tweeker”)) (member x’(strange weird odd peculiar)))
  • 13. Type declarations for formsThe special form is defined to declare the type of value held by a bound variable.(the type form)the type of value means the type of value of is declared to be of type type.the value-type formthe form is evaluated and whatever it produces is returned by the form, it is an error if what is returned by the form does not confirm to the data-type specified by value-type.
  • 14. Examples:(the string (copy-seq x)) the result will be a string.(the integer (+ x 3)) the result of + will be an integer.(+ (the integer x) 3)the value of x will be an integer.
  • 15. Visit more self help tutorialsPick a tutorial of your choice and browse through it at your own pace.The tutorials section is free, self-guiding and will not involve any additional support.Visit us at www.dataminingtools.net