LISP

LISP

Lisp

Lisp-glossy-120.jpg

Apparu en 1958
Auteur John McCarthy
Paradigmes fonctionnel, impératif
Typage fort, dynamique
Dialectes Common LispEmacs Lisp, Scheme
Système d'exploitation Multiplate-forme

Lisp est la plus ancienne famille de langages impératifs et fonctionnels. Développé initialement en tant que modèle pratique pour représenter des programmes (par contraste avec la notion théorique de Machine de Turing), il est devenu dans les années 1970 et 80 le langage de choix pour la recherche en intelligence artificielle. Les langages Lisp sont aujourd'hui utilisés dans de nombreux domaines, de la programmation Web à la finance, et dans les cursus de formation en Informatique.

Le terme Lisp a été forgé à partir de l'anglais « list processing ». Tous les dialectes de Lisp partagent les mêmes opérateurs de manipulation de listes chaînées simples. Lisp se distingue en outre par une syntaxe simple en notation préfixée, son typage dynamique des données, le support pour la programmation fonctionnelle, sa gestion automatique de la mémoire et la faculté de manipuler le code source en tant que structure de données.

Les langages Lisp sont reconnaissables immédiatement à leur apparence. Le code source des programmes est écrit en utilisant la même syntaxe que celle des listes - la syntaxe parenthésée des s-expressions. Chaque sous-expression d'un programme (ou structure de données) est délimitée par des parenthèses. Cela simplifie grandement l'analyse syntaxique des programmes Lisp et rend simple la métaprogrammation -- la création de programmes qui créent d'autres programmes.

Si l'on excepte le langage machine et le langage d'assemblage (ou plus communément « assembleur »), Lisp est le deuxième langage le plus ancien (juste après Fortran) parmi les langages qui se sont largement diffusés. Lisp a beaucoup évolué depuis le début des années 1960 et a ainsi donné naissance à de nombreux dialectes.

Sommaire

Histoire

Le langage Lisp fut inventé par John McCarthy en 1958 alors qu'il était au Massachusetts Institute of Technology (MIT). Il publia un article intitulé « Recursive Functions of Symbolic Expressions and Their Computation by Machine, Part I » (soit « Fonctions Récursives d'expressions symboliques et leur évaluation par une Machine, partie I ») dans la revue CACM en 1960 ; la partie II ne fut jamais publiée.

Le premier interpréteur fonctionnait sur un ordinateur IBM 704 et deux instructions de cette machine devinrent les deux opérations primitives de Lisp pour décomposer les listes :

  • car (Contents of Address register) : le premier élément de la liste
  • cdr (Contents of Decrement register) : le reste de la liste

Dans son article, John McCarthy introduit deux syntaxes : les S-expressions (expressions symboliques, parfois appelées « sexp ») et les M-expressions (méta-expressions permettant l´homoiconicité pour exprimer les fonctions manipulant des S-expressions). Les M-expressions n'ont jamais été très appréciées et la plupart des Lisps de nos jours utilisent des S-expressions pour les programmes comme pour les données. C'est la syntaxe des S-expressions qui fait que certains reprochent à Lisp d'être « plein de parenthèses », mais c'est aussi une des sources de la puissance et de la souplesse du langage.

Probablement en raison de son expressivité et de sa flexibilité, Lisp eut beaucoup de succès dans la communauté de l'intelligence artificielle. Dans les années 1970, on créa des ordinateurs spécialisés dans l'exécution de programmes Lisp : les machines Lisp.

Durant les années 1980 et 1990, on fit de grands efforts pour unifier les nombreux dialectes de Lisp qui étaient apparus. Le résultat fut appelé Common Lisp et en 1994, l'ANSI publia « ANSI X3.226-1994 Information Technology Programming Language Common Lisp », standardisant ainsi le langage. À ce moment, Lisp était bien moins florissant qu'à sa grande époque.

Bien qu'éclipsé par des langages proches de la machine (C, C++) et soutenus par des campagnes marketing agressives, Lisp reste un langage très utilisé, en particulier en tant que langage embarqué dans des applications, où il sert de langage d'extension. Le cas le plus connu d'utilisation embarquée de Lisp est l'éditeur de textes Emacs. On notera par ailleurs que Lisp vient en quatrième position en termes de lignes de codes utilisées pour implémenter les 8 600 paquets sources disponibles dans le système d'exploitation Debian publié en juin 2005. Les huit premiers langages se distribuent ainsi : C (57%), C++ (16.8%), Shell (9%), LISP (3%), Perl (2.8%), Python (1.8%), Java (1.6%), FORTRAN (1.2%)[1].

Syntaxe

Les listes sont délimitées par des parenthèses et leurs éléments sont séparés par des espaces : (1 2 "foo"). Un programme Lisp est un arbre de syntaxe composé avec des listes. Cette utilisation des parenthèses donne lieu à des moqueries sur le nom de LISP : « Lots of Irritating and Silly Parentheses », ou «Lots of Insipid and Stupid Parentheses » (que l'on pourrait traduire respectivement par : « Langage inutilement et stupidement parenthésé » et «Des tas de parenthèses stupides et insipides »).

Lisp est un langage orienté expression : il ne fait pas de distinction entre « expressions » et « statements » (instructions) comme le font de nombreux langages (par exemple Pascal) ; tout est expression et retourne une valeur ou un ensemble de valeurs.

La plupart des expressions Lisp sont des applications de fonction. Ce que d'autres langages écrivent

f(a,b,c)

Lisp l'écrit

(f a b c)

Ainsi une somme ne se note pas

1+2+3+4

ni

somme(1,2,3,4)

mais

(+ 1 2 3 4)

On utilise la même notation préfixée (dite, en arithmétique, notation polonaise[2]) pour les « formes spéciales » et les « macros » : le premier élément dans la liste, dans ces cas, détermine comment les éléments suivants seront traités. Une expression peut être une application de fonction, une forme spéciale ou une application de macro suivant la nature du premier élément.

Syntaxe en notation EBNF

Le langage LISP dispose d'une syntaxe très simple et élégante, utilisant un minimum de concepts. Cette économie de concepts mène Gregory Chaitin à qualifier cette syntaxe de « joyau de splendeur mathématique et de beauté intellectuelle austère »[3].

Le cœur et l'essentiel du langage LISP est défini par seulement trois règles EBNF :

expression -> atom | list
atom -> number | name | string | operator
list -> '(' expression* ')'

Ces règles peuvent se traduire de la manière suivante en français : un programme LISP est une liste d'expressions, chacune d'entre elles pouvant être une liste (récursion) ou un atome.

Exemples

Les programmes suivants ne sont pas typiques des vrais programmes Lisp. Ils sont typiques de la présentation que l'on fait de Lisp dans les cours d'informatique.

La factorielle est un grand classique :

(defun factorial (n)
  « Calcule la factorielle de l'entier n. »
  (if (<= n 1)
    1
    (* n (factorial (- n 1)))))

On peut aussi écrire plus efficacement (voir récursion terminale) :

(defun factorial (n &optional (acc 1))
  « Compute the factorial of the integer n. »
  (if (<= n 1)
    acc
    (factorial (- n 1) (* acc n))))

Un autre exemple typique est cette fonction qui renverse une liste (Lisp a une fonction intégrée reverse à cet effet) :

(defun reverse (l &optional (acc '()))
  « renverse la liste l »
  (if (null l)
    acc
    (reverse (cdr l) (cons (car l) acc))))

Lisp et les Objets

Divers systèmes à objets ont été construits à partir de Lisp, notamment :

  • Flavors, conçu au MIT
  • Le Common Lisp Object System (CLOS), un descendant de Flavors

CLOS offre de l'héritage multiple, la sélection multiple et un puissant système de combinaison de méthodes. Common Lisp (dont CLOS fait partie) fut le premier langage orienté-objet standardisé.

Citation

Grégory Chaitin sur Lisp :

«Malheureusement, alors que les langages de programmation gagnent en sophistication, ils sont de plus en plus le reflet de la complexité de la société humaine et du monde immense des applications logicielles. Ainsi, ils deviennent d'énormes boîtes à outils, comme des garages et des greniers chargés de plus de trente ans d'histoire ! A contrario, LISP est un langage de programmation d'une grande beauté mathématique ; il ressemble plus à un scalpel de chirurgien ou à un diamant affûté qu'à un garage à deux places encombrés de bricolages, où il ne reste plus de place pour une voiture.

LISP a un petit nombre de concepts élémentaires puissants, et tout le reste est construit au-dessus de ça, ce qui correspond à la façon de travailler des mathématiciens ; c'est à ça que ressemblent les théories mathématiques. Ces théories, les bonnes théories, consistent à définir quelques nouveaux concepts clefs, et à partir de là le feu d'artifice commence : elles révèlent de nouvelles allées, elles ouvrent la porte à des mondes radicalement nouveaux. LISP est comme ça aussi ; il est plus proche des maths que la plupart des langages de programmation. Du moins si vous éliminez les parties utiles qui ont été ajoutées, les ajouts qui ont fait de LISP un outil pratique. Ce qui reste si vous faites cela, c'est le LISP original, le cœur conceptuel de LISP, un cœur qui est un joyau de beauté mathématique et de beauté intellectuelle austère.»

Aujourd'hui, certains diraient que Scheme est le dérivé de Lisp atteignant à la beauté décrite par Chaitin ; et il est certain que Common Lisp, le descendant en ligne droite des grandes cuvées des dialectes passés de LISP (Maclisp, Interlisp, Zetalisp) penche plus du côté de la boîte à outils géante, bien qu'ayant conservé intact son cœur conceptuel.

G. Chaitin a utilisé ce Lisp idéalisé pour ses recherches : Elegant LISP Programs.

Généalogie et Variantes

  • LISP (la version originale de John McCarthy lorsqu'il était au MIT)
  • MACLisp (lié au projet MACSYMA du MIT - et sans lien avec l'Apple Macintosh), descendant direct de LISP
  • ZetaLisp, successeur de MACLisp, il fonctionna sur des machines LISP
  • InterLisp, né BBN Lisp, qui servit à développer les premières interfaces utilisateurs graphiques,
  • VLISP développé à l'Université de Paris VIII - Vincennes
  • LeLisp (ou Le-Lisp), version française du célèbre langage, développée à l'INRIA, et commercialisé ensuite par Ilog
  • EuLisp, un « Lisp Européen »
  • ELISP (Emacs Lisp), version simplifiée utilisée pour programmer l'éditeur de texte Emacs
  • Common Lisp, descendant du Lisp le plus connu.
  • AutoLISP, un LISP utilisé dans AutoCAD pour la programmation.
  • Scheme, un LISP épuré
  • Nyquist, un LISP utilisé pour travailler avec des sons.
  • xLispStat, un LISP utilisé pour les analyses statistiques de données.
  • XLisp, un sous-ensemble du langage Lisp développé par David Michael Betz
  • QLisp, une extension de Xlisp4.3 avec une centaine de routines d'analyse d'images
  • RPL (Reverse Polish lisp), un dérivé utilisé sur les calculatrices HP
  • Arc, dérivé très épuré, créé par Paul Graham

Notes et références de l'article

  1. UPGRADE (European Journal for the Informatics Professional), juin 2005
  2. Formellement, il s'agit de notation préfixée, mais l'usage particulier des parenthèses dans le langage Lisp induit qu'il s'agit réellement de notation polonaise, le rôle même de l'interpréteur étant de réduire les expressions parenthésées en expressions linéaires interprétable de gauche à droite, les opérateurs en premier
  3. Gregory Chaitin Hasard et complexité en mathématiques Flammarion 2009

Voir aussi

Articles connexes

  • Lambda calcul : langage mathématique dont Lisp, comme d'autres langages informatiques fonctionnels, est inspiré.
  • Common Lisp : Descendant direct du Lisp de McCarthy ; le terme Lisp est aujourd'hui autant employé pour se rapporter au Lisp originel qu'au Common Lisp.
  • Scheme : Autre descendant du Lisp, plus axé sur la programmation fonctionnelle que sur la programmation de macros.

Liens et documents externes

  • Portail de la programmation informatique Portail de la programmation informatique
Ce document provient de « Lisp ».

Wikimedia Foundation. 2010.

Contenu soumis à la licence CC-BY-SA. Source : Article LISP de Wikipédia en français (auteurs)

Игры ⚽ Нужна курсовая?

Regardez d'autres dictionnaires:

  • Lisp — Información general Paradigma multiparadigma: orientado a objetos, funcional, declarativo Apareció en 1958 Diseñado por John McCarthy …   Wikipedia Español

  • LISP — Paradigmen: multiparadigmatisch: funktional, prozedural; manche Dialekte außerdem modular, objektorientiert, reflexiv Erscheinungsjahr: 1958 Designer: John McCarthy …   Deutsch Wikipedia

  • Lisp — Paradigmen: multiparadigmatisch: funktional, prozedural; manche Dialekte außerdem modular, objektorientiert, reflexiv Erscheinungsjahr: 1958 Designer …   Deutsch Wikipedia

  • LISP — /lisp/, n. Computers. a high level programming language that processes data in the form of lists: widely used in artificial intelligence applications. [lis(t) p(rocessing)] * * * Powerful computer programming language designed for manipulating… …   Universalium

  • LISP — 〈EDV; Abk. für engl.〉 List Processing Language, eine höhere Programmiersprache, verbreitet zur Be u. Verarbeitung von Listen u. im Bereich der künstlichen Intelligenz * * * LISP   [Kurzwort aus englisch list processing language], Informatik: von… …   Universal-Lexikon

  • lisp — [ lisp ] n. m. • v. 1960; mot angl., acronyme de List Processing « traitement de listes » ♦ Inform. Langage évolué orienté vers le traitement d expressions symboliques. Le lisp est utilisé en intelligence artificielle. ● LISP nom masculin… …   Encyclopédie Universelle

  • Lisp — Lisp, v. t. 1. To pronounce with a lisp. [1913 Webster] 2. To utter with imperfect articulation; to express with words pronounced imperfectly or indistinctly, as a child speaks; hence, to express by the use of simple, childlike language. [1913… …   The Collaborative International Dictionary of English

  • lisp´er — lisp «lihsp», verb, noun. –v.i. 1. to use the sound of th in thin and then instead of the sound of s in bus and is when speaking: »A person who lisps might say, “Thing a thong of thixpenth” for “Sing a song of sixpence.” …   Useful english dictionary

  • Lisp — Lisp, n. The habit or act of lisping. See {Lisp}, v. i., 1. [1913 Webster] I overheard her answer, with a very pretty lisp, O! Strephon, you are a dangerous creature. Tatler. [1913 Webster] …   The Collaborative International Dictionary of English

  • lisp — [lısp] n [singular] [: Old English; Origin: wlyspian] a fault in the way someone speaks which makes them pronounce s sounds as th ▪ She speaks with a slight lisp. >lisp v [I and T] …   Dictionary of contemporary English

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”