IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Prolog Discussion :

Donner une interprétation arithmétique du prédicat


Sujet :

Prolog

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    204
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 204
    Points : 79
    Points
    79
    Par défaut Donner une interprétation arithmétique du prédicat
    Bonjour,
    je suis débutant et j'aimerais pouvoir trouver une interprétation arithmetique du prédicat suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    truc(zero).
    truc(suc(suc(suc(X)))):-truc(X).
    Je vous remercie d'avance pour votre aide.

  2. #2
    Rédacteur
    Avatar de pcaboche
    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    2 785
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Singapour

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 785
    Points : 9 716
    Points
    9 716
    Par défaut
    C'est récursif: on définit T comme un truc si:
    • soit T = zero
    • soit T est de la forme suc(suc(suc(X))) avec X défini comme étant un truc



    Quand tu exécutes le programme, ça donne ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    1 ?- truc(X).
     
    X = zero ;
     
    X = suc(suc(suc(zero))) ;
     
    X = suc(suc(suc(suc(suc(suc(zero)))))) ;
     
    X = suc(suc(suc(suc(suc(suc(suc(suc(suc(zero))))))))) ;
     
    X = suc(suc(suc(suc(suc(suc(suc(suc(suc(suc(...)))))))))) ;
     
    ...
    et il y a une infinité de solutions.
    "On en a vu poser les armes avant de se tirer une balle dans le pied..."
    -- pydévelop

    Derniers articles:

    (SQL Server) Introduction à la gestion des droits
    (UML) Souplesse et modularité grâce aux Design Patterns
    (UML) Le Pattern Etat
    Autres articles...

  3. #3
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut
    Pourrait-on dire que l'interprétation arithmétique est l'obtention des multiples de 3, en donnant une interprétation de suc comme successeur suc(n) renvoie n+1 (mais là on n'est plus dans Prolog) .
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  4. #4
    Rédacteur
    Avatar de pcaboche
    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    2 785
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Singapour

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 785
    Points : 9 716
    Points
    9 716
    Par défaut
    Citation Envoyé par Trap D
    Pourrait-on dire que l'interprétation arithmétique est l'obtention des multiples de 3, en donnant une interprétation de suc comme successeur suc(n) renvoie n+1 (mais là on n'est plus dans Prolog) .
    Pas vraiment.

    On a bien le prédicat succ(?Int1, ?Int2) mais pas d'opération arithmétique suc/1. Donc en fait il s'agit plus d'un tuple suc défini par l'utilisateur.
    "On en a vu poser les armes avant de se tirer une balle dans le pied..."
    -- pydévelop

    Derniers articles:

    (SQL Server) Introduction à la gestion des droits
    (UML) Souplesse et modularité grâce aux Design Patterns
    (UML) Le Pattern Etat
    Autres articles...

  5. #5
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut
    opeo >> tu pourrais nous dire dans quel cadre tu as trouvé cet exo, quel est le sujet du chapitre d'où il est tiré ?
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

Discussions similaires

  1. donner une valeur par defaut à un champ file
    Par Davboc dans le forum Balisage (X)HTML et validation W3C
    Réponses: 3
    Dernier message: 24/02/2006, 11h26
  2. Réponses: 1
    Dernier message: 20/01/2006, 19h07
  3. Donner une adresse à Fwrite
    Par Mike888 dans le forum C
    Réponses: 8
    Dernier message: 13/01/2006, 09h26
  4. transformation d'une expréssion arithmétique
    Par extradamus dans le forum C
    Réponses: 2
    Dernier message: 02/12/2005, 16h23
  5. Réponses: 2
    Dernier message: 07/07/2005, 18h11

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo