Prolog Language

Transcription

Prolog Language#prolog

Table des matièresÀ propos1Chapitre 1: Premiers pas avec le langage Prolog2Remarques2Les implémentations2Examples2Installation ou configuration2annexe / 33Contraintes CLP (FD)3Programmation de base de données4Bonjour le monde6Bonjour, World dans l'interpréteur interactif6Bonjour, Monde d'un fichier6Chapitre 2: Arbres de dérivationExamplesArbre de preuveChapitre 3: Clauses définies de la clause (DCG)Examples8881010Rien du tout: // // 0 10Analyse avec les DCG10Objectifs supplémentaires10Arguments supplémentaires11Chapitre 4: Directives de codageExamples1212Appellation12Échancrure12Ordre des arguments12Chapitre 5: Gestion des erreurs et exceptionsExamples1414Erreurs d'instanciation14Points généraux sur la gestion des erreurs14

Nettoyage après exceptions14Erreurs de type et de domaine14Chapitre 6: Les opérateursExamples1616Opérateurs prédéfinis16Déclaration de l'opérateur17Commande à terme17Égalité des termes18Chapitre 7: Liste de différences19Introduction19Examples19Utilisation de base19Evaluer une expression arithmétique20Chapitre 8: MonotonicitéExamples2222Raisonnement sur les prédicats monotones22Exemples de prédicats monotones22Prédicats non monotones22Alternatives monotones pour les constructions non monotones23Combiner la monotonie à l'efficacité23Chapitre 9: PerformanceExamples2525Machine abstraite25Indexage25Optimisation des appels de queue25Chapitre 10: Prédicats Extra-LogiquesExamples2626Prédicats avec effets secondaires26Prédicats méta-logiques26Prédicats de toutes les solutions26! / 0 et les prédicats associés26Chapitre 11: Programmation d'ordre supérieur28

Examples28appel / N prédicats28mapliste / [2,3]28Meta-call28foldl / 428Appeler une liste d'objectifs29Chapitre 12: Programmation logique par contraintesExamples3030CLP (FD)30CLP (Q)30CLP (H)30Chapitre 13: Pureté logique32Examples32dif / 232Contraintes CLP (FD)32Unification32Chapitre 14: Raisonnement sur les �der aux listes35Chapitre 15: Structures de contrôleExamples3737Disjonction (OU logique), implicite vs explicite37Conjonction (ET logique)37Couper (supprimer les points de choix)37Chapitre 16: Structures de données39Examples39Des listes39Paires40Listes d'association40termes40

Termes avec champs nommés utilisant la bibliothèque (enregistrement)Chapitre 17: Utiliser Prolog moderneExamples404242introduction42CLP (FD) pour l'arithmétique des nombres entiers42Forall au lieu de boucles pilotées par les pannes43Prédicats de fonction44Déclarations de flux / mode45Crédits47

À proposYou can share this PDF with anyone you feel could benefit from it, downloaded the latest versionfrom: prolog-languageIt is an unofficial and free Prolog Language ebook created for educational purposes. All thecontent is extracted from Stack Overflow Documentation, which is written by many hardworkingindividuals at Stack Overflow. It is neither affiliated with Stack Overflow nor official PrologLanguage.The content is released under Creative Commons BY-SA, and the list of contributors to eachchapter are provided in the credits section at the end of this book. Images may be copyright oftheir respective owners unless otherwise specified. All trademarks and registered trademarks arethe property of their respective company owners.Use the content presented in this book at your own risk; it is not guaranteed to be correct noraccurate, please send your feedback and corrections to e1

Chapitre 1: Premiers pas avec le langagePrologRemarquesLes implémentations1. SWI-Prolog (gratuit) swi-prolog Implémenté dans c2. SICStus (commercial) sicstus-prolog3. YAP (gratuit) yap4. GNU Prolog (gratuit) gnu-prolog5. XSB (gratuit) xsb6. B (commercial) b-prolog7. SI (commercial)8. Ciao (libre)9. Minerva (commercial)10. ECLiPSe-CLP (gratuit) eclipse-clp11. Jekejeke Prolog (commercial)12. Prolog IV13. Rendement Prolog (gratuit) Implémenté dans c # , javascript et phyton14. Visual Prolog (commerciale) visuo-PrologExamplesInstallation ou configurationSWI-PrologWindows et Mac: Téléchargez SWI-Prolog sur le site officiel Installez simplement en suivant les instructions du programme d'installation.Linux (PPA): Ajoutez le PPA ppa:swi-prolog/stable aux sources logicielles de votre système (lesdéveloppeurs peuvent choisir ppa:swi-prolog/devel ): Ouvrez un terminal (Ctrl Alt T) et tapez: sudoadd-apt-repository ppa:swi-prolog/stable Ensuite, mettez à jour les informations sur le paquet: sudohttps://riptutorial.com/fr/homeapt-get update2

Maintenant, installez SWI-Prolog via le gestionnaire de paquets: sudoapt-get install swi-prolog Vous pouvez maintenant démarrer SWI-Prolog via la ligne de commande avec la commandeswiplannexe / 3append([], Bs, Bs).append([A As], Bs, [A Cs]) :append(As, Bs, Cs).est l'une des relations Prolog les plus connues. Elle définit une relation entre troisarguments et est vraie si le troisième argument est une liste indiquant la concaténation des listesspécifiées dans les premier et deuxième arguments.append/3Notamment, et comme c'est généralement le cas pour un bon code Prolog, append/3 peut êtreutilisé dans plusieurs directions : Il peut être utilisé pour: ajouter deux listes totalement ou partiellement instanciées:?- A [1,Output:A [1, 2,B [4, 5,Y [1, 2,2, 3], B [4, 5, 6], append(A, B, Y)3],6],3, 4, 5, 6]. vérifier si la relation est vraie pour trois listes complètement instanciées:?- A [1, 2, 3], B [4, 5], C [1, 2, 3, 4, 5, 6], append(A, B, C)Output:false générer tous les moyens possibles pour ajouter deux listes à une liste donnée:?- append(A, B, [1, 2, 3, 4]).Output:A [],B [1, 2, 3, 4] ;A [1],B [2, 3, 4] ;A [1, 2],B [3, 4] ;A [1, 2, 3],B [4] ;A [1, 2, 3, 4],B [] ;false.Contraintes CLP (FD)Les contraintes CLP (FD) sont fournies par toutes les implémentations sérieuses de Prolog. Ilshttps://riptutorial.com/fr/home3

nous permettent de raisonner sur des entiers de manière pure.?- X # 1 2.X 3.?- 5 # Y 2.Y 3.Programmation de base de donnéesProlog classe tout en: Atomes - Toute séquence de caractères qui ne commence pas par un alphabet majuscule.Par exemple - a , b , d' okay Nombres - Il n'y a pas de syntaxe spéciale pour les nombres, aucune déclaration n'estrequise. Par exemple 1 , 22 , 35.8 Variables - Chaîne commençant par un caractère majuscule ou un trait de soulignement (). Par exemple X , Y , Abc , AA Termes complexes - Ils sont fabriqués à partir d'un foncteur et d'une séquence d'arguments . Le nom d'un terme complexe est toujours un atome, alors que les argumentspeuvent être des atomes ou des variables. Par exemple, father(john,doe) , relative(a) ,mother(X,Y) .Une base de données logique contient un ensemble de faits et de règles .Un terme complexe avec uniquement des atomes comme arguments est appelé un fait, tandisqu'un terme complexe avec des variables comme arguments est appelé une règle.Exemple de faits dans Prolog:father child(fred, susan).mother child(hillary, joe).Exemple de règle dans Prolog:child of(X,Y):father child(Y,X);mother child(Y,X).Notez que le ; ici est comme l'opérateur or dans d'autres langues.Prolog est un langage déclaratif et vous pouvez lire cette base de données comme suit:fred est le père de susanHillary est la mère de Joe.Pour tout X et Y , X est un enfant de Y si Y est un père de X ou Y est une mère de Xhttps://riptutorial.com/fr/home4

En fait, un ensemble fini de faits et / ou de règles constitue un programme logique.L'utilisation d'un tel programme est démontrée par des requêtes . Les requêtes vous permettentde récupérer des informations à partir d'un programme logique.Pour charger la base de données dans l'interpréteur (en supposant que vous avez enregistré labase de données dans le répertoire dans lequel vous exécutez l'interpréteur), il vous suffitd'entrer:?- [nameofdatabase].remplacer le nameofdatabase la nameofdatabase de nameofdatabase par le nom de fichier réel (notezque nous excluons ici l'extension .pl du nom de fichier).Exemple de requêtes dans l'interpréteur pour le programme ci-dessus et les résultats:?- child of(susan,fred).true?- child of(joe,hillary).true?- child of(fred,susan).false?- child of(susan,hillary).false?- child of(susan,X).X fred?- child of(X,Y).X susan,Y fred ;X joe,Y hillary.Les questions ci-dessus et leurs réponses peuvent être lues comme suit:est susan un enfant de fred? - vraiJoe est-il un enfant de Hillary? - vraifred est un enfant de susan? - fauxest susan un enfant de hillary? - fauxqui est un enfant de Susan? - fredVoici comment nous programmons la logique dans Prolog. Un programme logique est plus formel:un ensemble d'axiomes ou de règles définissant des relations (aka prédicats) entre objets. Uneautre manière d’interpréter la base de données ci-dessus de manière plus formelle est la suivante:https://riptutorial.com/fr/home5

La relation father child tient entre fred et susanLa relation mother child tient entre hillary et joePour tout X et Y la relation child of est child of entre X et Y si la relation father childentre Y et X , ou la relation mother child entre Y et XBonjour le mondeBonjour, World dans l'interpréteur interactifPour imprimer "Bonjour, Monde!" dans l'interpréteur Prolog (nous utilisons ici swipl , le shell pourSWI Prolog): swipl .banner. ?- write('Hello, World!'), nl.est l'invite du système: cela indique que le système est prêt pour que l'utilisateur entre uneséquence d' objectifs (c.-à-d. une requête ) devant être terminée par un . (arrêt complet).?-Ici, la requête write('HelloWorld!'), nla deux objectifs: write('Hello World!') : 'Hello World!' doit être affiché et ( , ) une nouvelle ligne ( nl ) doit suivre.(le /1 indique que le prédicat prend un argument) et nl/0 sont des prédicats intégrés (ladéfinition est fournie au préalable par le système Prolog). Les prédicats intégrés fournissent desfonctionnalités qui ne peuvent pas être obtenues par une définition de Prolog pure ou pourempêcher le programmeur de les définir.write/1Le résultat:Bonjour le monde!Ouise termine par yes ce qui signifie que la requête a réussi. Dans certains systèmes, true estimprimé au lieu de yes .Bonjour, Monde d'un fichierOuvrez un nouveau fichier appelé hello world.pl et insérez le texte suivant::- initialization hello world, halt.hello world :write('Hello, World!'), nl.https://riptutorial.com/fr/home6

La directive d' initialization spécifie que l'objectif hello world,fichier est chargé. halt quitte le programme.haltdoit être appelé lorsque leCe fichier peut alors être exécuté par votre exécutable Prolog. Les drapeaux exacts dépendent dusystème Prolog. Si vous utilisez SWI Prolog: swipl -q -l hello world.plCela produira une sortie Hello, World! . L' -q supprime la bannière qui s'affiche généralementlorsque vous appelez run swipl . Le -l spécifie un fichier à charger.Lire Premiers pas avec le langage Prolog en orial.com/fr/home7

Chapitre 2: Arbres de dérivationExamplesArbre de preuveL'arbre de preuve (également arbre de recherche ou arborescence de dérivation) est unearborescence qui montre l'exécution d'un programme Prolog. Cet arbre permet de visualiser leprocessus de retour en arrière chronologique présent dans Prolog. La racine de l'arbre représentela requête initiale et les branches sont créées lorsque des points de choix apparaissent. Chaquenœud de l'arbre représente donc un objectif. Les branches ne deviennent des leafs que lorsquetrue / false a été prouvé pour le (les) jeu (s) d'objectifs requis (s) et que la recherche dans Prologest effectuée de gauche à droite .Prenons l'exemple suivant:% Factsfather child(paul,chris).father child(paul,ellen).mother child(ellen,angie).mother child(ellen,peter).% Paul is the father of Chris and Ellen% Ellen is the mother of Angie and Peter% Rulesgrandfather grandchild(X,Y) :father child(X,Z),father child(Z,Y).grandfather grandchild(X,Y) :father child(X,Z),mother child(Z,Y).Lorsque nous interrogeons maintenant:?- grandfather grandchild(paul,peter).l'arbre de vérification suivant visualise le processus de recherche en profondeur:?- grandfather grandchild(paul,peter)./\/\?- father child(paul,Z1),father child(Z1,peter).?father child(paul,Z2),mother child(Z2,peter)./\/\{Z1 chris}{Z1 ellen}{Z2 chris}{Z2 ellen}/\/\?- father child(chris,peter). ?- father child(ellen,peter). ?- mother child(chris,peter). ?mother 8

/ failfail\failfail(*)success(*) échoue pour mother child(ellen,angie) où 'angie' ne correspond pas à 'peter'Lire Arbres de dérivation en ligne: s-de-derivationhttps://riptutorial.com/fr/home9

Chapitre 3: Clauses définies de la clause(DCG)ExamplesRien du tout: // // 0 L'un des non-terminaux DCG les plus élémentaires est .quoi"://0, qui peut être lu comme "n'importe. -- [] [ ], . .Il peut être utilisé pour décrire une liste Ls contenant l'élément E via:phrase(( ., [E], . ), Ls)Analyse avec les DCGLes DCG peuvent être utilisés pour l'analyse. Mieux encore, le même DCG peut souvent êtreutilisé pour analyser et générer des listes décrites. Par exemple:sentence -- article, subject, verb, object.article -- [the].subject -- [woman] [man].verb -- [likes] [enjoys].object -- [apples] [oranges].Exemple de requêtes:?LsLsLsphrase(sentence, Ls). [the, woman, likes, apples] ; [the, woman, likes, oranges] ; [the, woman, enjoys, apples] .?- phrase(sentence, [the,man,likes,apples]).true .Objectifs supplémentairesDes objectifs supplémentaires permettent d'ajouter du traitement aux clauses DCG, par exemple,les conditions que les éléments de la liste doivent satisfaire.Les objectifs supplémentaires sont observés entre accolades à la fin d'une clause DCG.https://riptutorial.com/fr/home10

% DCG clause requiring an integerint -- [X], {integer(X)}.Usage:?- phrase(int, [3]).true.?- phrase(int, [a]).false.Arguments supplémentairesLes arguments supplémentaires ajoutent des résultats aux prédicats d'une clause DCG, endécorant l'arbre de dérivation. Par exemple, il est possible de créer une grammaire algébrique quicalcule la valeur à la fin.Étant donné une grammaire qui prend en charge l'ajout d'opération:% Extra arguments are passed between parenthesis after the name of the DCG clauses.exp(C) -- int(A), [ ], exp(B), {plus(A, B, C)}.exp(X) -- int(X).int(X) -- [X], {integer(X)}.Le résultat de cette grammaire peut être validé et interrogé:?- phrase(exp(X), [1, ,2, ,3]).X 6 ;Lire Clauses définies de la clause (DCG) en orial.com/fr/home11

Chapitre 4: Directives de codageExamplesAppellationLors de la programmation dans Prolog, nous devons choisir deux types de noms: noms de prédicats noms de variables .Un bon nom de prédicat indique clairement ce que signifie chaque argument. Par convention, lestraits de soulignement sont utilisés dans les noms pour séparer la description des différentsarguments. Cela est dû au fait que underscores keep even longer names readable , tandis quemixingTheCasesDoesNotDoThisToTheSameExtent .Voici des exemples de bons noms de prédicats: parent child/2person likes/2route to/2Notez que les noms descriptifs sont utilisés. Les impératifs sont évités. L'utilisation de nomsdescriptifs est recommandée car les prédicats Prolog peuvent généralement être utilisés dansplusieurs directions, et le nom doit également s'appliquer à tout ou aucun des arguments n'estinstancié.La capitalisation mixte est plus courante lors de la sélection des noms de variables . Par exemple:BestSolutions , MinElement , GreatestDivisor . Une convention courante pour nommer des variablesqui indiquent des états successifs est d'utiliser S0 , S1 , S2 , ., S , où S représente l'état final.ÉchancrureIl y a peu de constructions de langage dans Prolog, et plusieurs façons de les indenter sontcommunes.Quel que soit le style choisi, un principe à respecter est de ne jamais placer (;)/2 à la fin d'uneligne. En effet ; et , ressemblent beaucoup, et , se produit souvent à la fin d'une ligne. Parconséquent, les clauses qui utilisent une disjonction doivent par exemple être écrites comme suit:(;)Goal1Goal2Ordre des argumentsIdéalement, les prédicats Prolog peuvent être utilisés dans toutes les directions. Pour dehttps://riptutorial.com/fr/home12

nombreux prédicats purs, cela est également le cas. Cependant, certains prédicats nefonctionnent que dans des modes particuliers, ce qui signifie des schémas d'instanciation de leursarguments.Par convention, les arguments les plus courants pour ces prédicats sont: les arguments d' entrée sont placés en premier. Ces arguments doivent être instanciésavant l'appel du prédicat. les paires d'arguments qui appartiennent ensemble sont placées de manière adjacente,telles que p(., State0, State, .) les arguments de sortie prévus sont placés en dernier. Ces prédicats sont instanciés par leprédicat.Lire Directives de codage en ligne: tives-de-codagehttps://riptutorial.com/fr/home13

Chapitre 5: Gestion des erreurs et exceptionsExamplesErreurs d'instanciationUne erreur d' instanciation est lancée si un argument n'est pas suffisamment instancié .De manière critique, une erreur d’instanciation ne peut pas être remplacée par une défaillancesilencieuse : en cas d’ absence de solution , cela signifie qu’il n’ya pas de solution , alorsqu’une erreur d’instanciation signifie qu’une instance de l’argument peut participer à une solution.Cela contraste avec, par exemple , une erreur de domaine , qui peut être remplacée par unedéfaillance silencieuse sans modifier le sens déclaratif d'un programme.Points généraux sur la gestion des erreursProlog propose des exceptions , qui font partie de la norme ISO Prolog.Une exception peut être lancée avec throw/1 et prise avec catch/3 .La norme ISO définit de nombreux cas dans lesquels des erreurs doivent ou peuvent être émises.Les exceptions standardisées sont toutes des error(E, ) formulaire error(E, ) , où E indiquel'erreur. Les exemples sont instantiation error , domain error et type error , qui voient.setup call cleanup/3est un prédicat important en relation avec les exceptions.Nettoyage après exceptionsLe prédicat setup call cleanup/3 , dont l'inclusion dans la norme ISO Prolog est en cours et fournipar un nombre croissant d'implémentations, nous permet de nous assurer que les ressources sontcorrectement libérées après la levée d'une exception.Une invocation typique est:setup call cleanup(open(File, Mode, Stream), process file(File), close(Stream))Notez qu'une exception ou une interruption peut même se produire immédiatement après l'appelde open/3 dans ce cas. Pour cette raison, la phase d' Setup est effectuée de manière atomique .Dans les systèmes Prolog qui ne fournissent que call cleanup/2 , cela est beaucoup plus difficile àexprimer.Erreurs de type et de domaineUne erreur de type se produit si un argument n'est pas du type attendu. Des exemples de typessont:https://riptutorial.com/fr/home14

integeratomlist.Si le prédicat est du type attendu, mais en dehors du domaine attendu, une erreur de domaineest générée.Par exemple, une erreur de domaine est admissible si un nombre entier compris entre 0 et 15 estattendu, mais l'argument est le nombre entier 20.Déclarativement, une erreur de type ou de domaine équivaut à une défaillance silencieuse , caraucune instanciation ne peut aboutir à un prédicat dont l'argument est du type ou du domaineincorrect.Lire Gestion des erreurs et exceptions en ligne: /fr/home15

Chapitre 6: Les opérateursExamplesOpérateurs prédéfinisOpérateurs prédéfinis selon ISO / IEC 13211-1 et 13211-2:PrioritéTypeLes opérateurs)Utilisation1200xfx:- -- 1200fx:- ?-1100xfy;1050xfy- 1000xfy','900fy\ 700xfx \\ Unification du terme700xfx \\ @ @ @ @ Comparaison de terme700xfx .700xfxis : \ Évaluation arithmétique et comparaison600xfy:Qualification de module500yfx - /\ \/400yfx* / div mod // rem 200xfx**Pouvoir flottant200xfy Quantification variable, puissance entière200fy -\Identité arithmétique, négation; complément binaireDirective, requêteDe nombreux systèmes fournissent d'autres opérateurs en tant qu'extension spécifique à la miseen œuvre:PrioritéTypeLes opérateurs)Utilisation1150fxdynamic multifile discontiguous initializationDirectives standardhttps://riptutorial.com/fr/home16

PrioritéTypeLes opérateurs)1150fxmode block volatile public meta predicate900fyspy nospyUtilisationDéclaration de l'opérateurDans Prolog, les opérateurs personnalisés peuvent être définis avec op/3 :op( Precedence, Type, :Operator) Déclare l'opérateur comme étant un opérateur d'un type avec une priorité. L'opérateur peutégalement être une liste de noms, auquel cas tous les éléments de la liste sont déclaréscomme étant des opérateurs identiques. La priorité est un entier compris entre 0 et 1200, où 0 supprime la déclaration. Le type est l'un de: xf , yf , xfx , xfy , yfx , fy ou fx où f indique la position du foncteur et x ety indiquent les positions des arguments. y désigne un terme avec une priorité inférieure ouégale à la priorité du foncteur, alors que x désigne une priorité strictement inférieure. Préfixe: fx , fyInfix: xfx (non associatif), xfy (associatif droit), yfx (associatif gauche)Postfix: xf , yfExemple d'utilisation::- op(900, xf, is true).X 0 is true :X 0.Exemple de requête:?- dif(X, a) is true.dif(X, a).Commande à termeDeux termes peuvent être comparés via la commande standard:variables @ numéros @ atomes @ chaînes @ structures @ listesRemarques: Les structures se comparent alphabétiquement par foncteur d'abord, puis par arité et enfinpar comparaison de chaque argument. Les listes se comparent d'abord par longueur, puis par élément.https://riptutorial.com/fr/home17

Opérateur de commandeRéussit siX @ YX est inférieur à Y dans l'ordre standardX @ YX est supérieur à Y dans l'ordre standardX @ YX est inférieur ou égal à Y dans l'ordre standardX @ YX est supérieur ou égal à Y dans l'ordre standardExemple de requêtes:?- alpha @ beta.true.?- alpha(1) @ beta.false.?- alpha(X) @ alpha(1).true.?- alpha(X) @ alpha(Y).true.?- alpha(X) @ alpha(Y).false.?- compound(z) @ compound(inner(a)).true.Égalité des termesOpérateurd'égalitéRéussit siX YX peut être unifié avec YX\ YX ne peut pas être unifié avec YX YX et Y sont identiques (c’est-à-dire qu’ils s’unifient sans aucune liaisonde variable)X \ YX et Y ne sont pas identiquesX : YX et Y sont arithmétiquement égauxX \ YX et Y ne sont pas arithmétiquement égauxLire Les opérateurs en ligne: perateurshttps://riptutorial.com/fr/home18

Chapitre 7: Liste de différencesIntroductionLes listes de différences de Prolog désignent le concept pour connaître la structure d'une listejusqu'à un point . Le reste de la liste peut être laissé libre jusqu'à l'évaluation complète d'unprédicat. Une liste dont la fin est inconnue est appelée liste ouverte , terminée par un trou . Cettetechnique est particulièrement utile pour valider des syntaxes complexes ou des grammaires.Le bien connu Grammars Clause définie (DCG) utilise des listes de différences pour fonctionnersous le capot.ExamplesUtilisation de baseConsidérons le prédicat sumDif/2 , vérifié si la structure d'une liste correspond à plusieurscontraintes. Le premier terme représente la liste à analyser et le second terme une autre listecontenant la partie de la première liste inconnue de nos contraintes.Pour la démonstration, sumDif/2 reconnaît une expression arithmétique pour résumer n entiers.sumDif([X, OpenList], Hole) :integer(X),sumDif(OpenList, Hole).Nous savons que le premier élément de la liste à valider est un entier, ici illustré par X , suivi dusymbole de l'addition ( ). Le reste de la liste qui doit encore être traité ultérieurement ( OpenList )est laissé non validé à ce niveau. Hole représente la partie de la liste que nous n'avons pas besoinde valider.Donnons une autre définition du prédicat sumDif/2 pour compléter la validation de l'expressionarithmétique:sumDif([X Hole], Hole) :integer(X).Nous attendons un entier appelé X directement au début de la liste ouverte. Il est intéressant denoter que le reste de la liste Hole reste inconnu et que les listes de différences servent à l’objectif:la structure de la liste est connue jusqu’à un certain point.Enfin, la pièce manquante vient quand une liste est évaluée:?- sumDif([1, ,2, ,3], []).truehttps://riptutorial.com/fr/home19

C'est lorsque le prédicat est utilisé que la fin de la liste est mentionnée, ici [] , indique que la listene contient pas d'éléments supplémentaires.Evaluer une expression arithmétiqueDéfinissons une grammaire permettant d'effectuer des additions, des multiplications avecl'utilisation de parenthèses. Pour ajouter plus de valeur à cet exemple, nous allons calculer lerésultat de l'expression arithmétique. Résumé de la grammaire:expression foisexpression fois expression ' 'times elementtimes element '*' timeselement "entier"element '(' expression ')'Tous les prédicats ont une arité de 3, car ils doivent ouvrir la liste, le trou et la valeur del'expression arithmétique.expression(Value, OpenList, FinalHole) :times(Value, OpenList, FinalHole).expression(SumValue, OpenList, FinalHole) :times(Value1, OpenList, [' ' Hole1]),expression(Value2, Hole1, FinalHole),plus(Value1, Value2, SumValue).times(Value, OpenList, FinalHole) :element(Value, OpenList, FinalHole).times(TimesValue, OpenList, FinalHole) :element(Value1, OpenList, ['*' Hole1]),times(Value2, Hole1, FinalHole),TimesValue is Value1 * Value2.element(Value, [Value FinalHole], FinalHole) :integer(Value).element(Value, ['(' OpenList], FinalHole) :expression(Value, OpenList, [')' FinalHole]).Pour bien expliquer le principe des trous et comment la valeur est calculée, prenons la deuxièmeexpression clause:expression(SumValue, OpenList, FinalHole) :times(Value1, OpenList, [' ' Hole1]),expression(Value2, Hole1, FinalHole),plus(Value1, Value2, SumValue).La liste ouverte est désignée par le prédicat OpenList . Le premier élément à valider est ce quiprécède le symbole d'addition ( ) . Lorsque le premier élément est validé, il est directement suividu symbole d'addition et de la suite de la liste, appelée Hole1 . Nous savons que Hole1 esthttps://riptutorial.com/fr/home20

l'élément suivant à valider et peut être une autre expression , donc Hole1 est alors le terme donné àl' expression prédicat.La valeur est toujours représentée dans le premier terme. Dans cette clause, elle est définie par lasomme de Value1 (tout avant le symbole de l’addition) et Value2 (tout après le symbole del’addition).Enfin, une expression peut être évaluée.?- expression(V, [1, ,3,*,'(',5, ,5,')'], []).V 31Lire Liste de différences en ligne: -de-differenceshttps://riptutorial.com/fr/home21

Chapitre 8: MonotonicitéExamplesRaisonnement sur les prédicats monotonesLes prédicats monotones peuvent être débogués en appliquant un raisonnement déclaratif .En pur Prolog, une erreur de programmation peut entraîner l'un ou l'autre des phénomènessuivants:1. le prédicat réussit incorrectement dans un cas où il devrait échouer2. le prédicat échoue incorrectement dans un cas où il devrait réussir3. le prédicat boucle inopinément là où il ne devrait produire qu'un ensemble fini de réponses.À titre d'exemple, considérons comment nous pouvons déboguer la casse (2) par unraisonnement déclaratif: nous pouvons systématiquement supprimer les objectifs des clauses duprédicat et voir si la requête échoue toujours . En code monotone, la suppression des objectifspeut tout au plus rendre le programme résultant plus général . Par conséquent, nous pouvonsidentifier les erreurs en voyant lequel des objectifs conduit à l'échec inattendu.Exemples de prédicats monotonesVoici des exemples de prédicats monotones : unification avec ( )/2 ou unify with occurs check/2 dif/2 , exprimant le déséquilibre des termes Les contraintes CLP (FD) aiment (# )/2 et (# )/2 , en utilisant un mode d’exécutionmonotone.Les prédicats Prolog qui utilisent uniquement des objectifs monotones sont eux-mêmesmonotones.Les prédicats monotoniques permettent un raisonnement déclaratif:1. L'ajout d'une contrainte (c.-à-d. Un objectif) à une requête peut tout au plus réduire , jamaisétendre, l'ensemble des solutions.2. La suppression d'un objectif de tels prédicats peut au maximum prolonger , jamais réduire,l'ensemble des solutions.Prédicats non monotonesVoici des exemples de prédicats qui ne sont pas monotones: des prédicats méta-logiques tels que var/1 , integer/1 etc. les prédicats de comparaison de termes comme (@ )/2 et (@ )/2 les prédicats qui utilisent !/0 , (\ )/1 et d'autres constructions qui rompent la monotoniehttps://riptutorial.com/fr/home22

prédicats tout-solutions comme findall/3 et setof/3 .Si ces prédicats sont utilisés, l’ ajout d’ objectifs peut conduire à plus de solutions, ce qui va àl’encontre de l’importante propriété déclarative connue de la logique selon laquelle l’ajout decontraintes peut tout au plus réduire , jamais étendre, l’ensemble des solutions.Par conséquent, d'autres propriétés sur lesquelles nous nous appuyons pour le débogagedéclaratif et d'autres raisonnements sont également rompues. Par exemple, les prédicats nonmonotones brisent la notion fondamentale de commutativité de la conjonction connue de lalogique du premier ordre. L'exemple suivant illustre ceci:?- var(X), X a.X a.?- X a, var(X).false.Toutes les solutions-prédicats comme findall/3 brisera

Maintenant, installez SWI-Prolog via le gestionnaire de paquets: sudo apt-get install swi-prolog Vous pouvez maintenant démarrer SWI-Prolog via la ligne de commande avec la commande swipl annexe / 3 append([], Bs, Bs). append([A As], Bs, [A Cs]) :- append(As, Bs, Cs). append/3 est l'une des relations Prolog les plus connues. Elle .