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 :

[SWI-Prolog][Débutant] Programmation par contrainte


Sujet :

Prolog

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Octobre 2008
    Messages
    82
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 82
    Par défaut [SWI-Prolog][Débutant] Programmation par contrainte
    Bonjour,

    Afin de résoudre un problème, j'ai fait des recherches sur la programmation par contrainte. Je suis tombé sur Developpez.com et le cours de prolog.

    Pourriez vous svp me donner un coup de main afin de résoudre mon pb?

    Voici de quoi il s'agit.

    J'ai 4 variables à déterminer.
    Elles appartiennent à l'ensemble des nombres entiers compris entre 1 et 20.
    Elles sont toutes différentes.

    En plus de ça, j'ai une dizaine de contraintes du type:

    1 ou 2 d'entre elles appartiennent à l'ensemble A
    Minimum 1 d'entre elles appartient à l'ensemble B
    ...

    Les ensembles A, B,.. sont des sous ensembles De [1,2,...20]

    Le but est de trouver toutes les combinaisons répondant aux contraintes...

    Ce genre de problème peut il est résolu avec swi-prolog?

    Merci de votre aide,

    Alexandre

  2. #2
    Alp
    Alp est déconnecté
    Expert confirmé

    Avatar de Alp
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    8 575
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juin 2005
    Messages : 8 575
    Par défaut
    Oui c'est tout à fait possible.

    Il faut fixer des contraintes du type :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    between_1_and_20(X) :- X =< 20, X >= 1.
    Ensuite, il faut réfléchir un peu pour les contraintes
    1 ou 2 d'entre elles appartiennent à l'ensemble A
    Minimum 1 d'entre elles appartient à l'ensemble B
    ...
    Tu peux tout à fait y arriver en travaillant avec le cours de Prolog à côté

  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
    Par défaut
    Peux-tu donner un peu plus de détails et ce que tu as écrit.
    La bibliothèque clpfd me semble être faite pour ça, mais il faut des détails ...
    "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/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Par défaut
    attention tu seras peut-être obligé d'utiliser une bib pour les domaines finis suivant la complexité du problème... ce qui peut fortement ralentir la résolution
    Evitez les MP pour les questions techniques... il y a des forums
    Contributions sur DVP : Mes Tutos | Mon Blog

  5. #5
    Membre confirmé
    Inscrit en
    Octobre 2008
    Messages
    82
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 82
    Par défaut
    Merci de vos réponses!

    j'ai commencé à lire les cours... Mais ce n'est pas simple.
    Demain j'installe swi-prolog et je vais essayé de faire le début du programme en utilisant les exemples du site.

    Voici un exemple concret du problème:

    J'ai 4 variables à déterminer.
    Elles appartiennent à l'ensemble des nombres entiers compris entre 1 et 20.
    Elles sont toutes différentes.

    - 2,3 ou 4 de ces variables appartiennent à [1,2,3,4,5,6,7,8,12,15,17,18,20]
    - 2,3,ou 4 de ces variables appartiennent à [1,2,3,4,5,6,8,12,15,17,18,20]
    - 1,2,3 ou 4 de ces variables appartiennent à [1,2,3,4,6,8,12,15,17,18]
    - 0,1 ou 2 de ces variables appartiennent à [1,2,3,4,6,8,15,17,18]
    - ...

    Quels Combinaisons répondent à ces critères?

    NB: Les contraintes changent pour chaque études, mais reste de la même forme...

    Tout le début ne semble pas poser problème. Mais comment définir ce type de contraintes?

    Alex

  6. #6
    Membre confirmé
    Inscrit en
    Octobre 2008
    Messages
    82
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 82
    Par défaut
    Swi-prolog installé et j'ai testé quelques exemples présents dans les cours. Tout fonctionne.

    J'ai lu plusieurs des cours, mais des choses restent incomprises...

    Je vais essayé de comprendre...

    Alex

Discussions similaires

  1. programmation par contrainte
    Par ratrout dans le forum Langage
    Réponses: 5
    Dernier message: 09/12/2016, 21h51
  2. [SWI-Prolog][Débutant] UNE+UNE = DEUX
    Par loupiloup314 dans le forum Prolog
    Réponses: 5
    Dernier message: 24/05/2011, 17h17
  3. Programmation par contrainte en Java
    Par domas_24 dans le forum API standards et tierces
    Réponses: 3
    Dernier message: 12/06/2008, 14h27
  4. Programmation par contrainte
    Par croc14 dans le forum API standards et tierces
    Réponses: 4
    Dernier message: 19/03/2007, 11h12

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