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 :

Plus court chemin entre deux états


Sujet :

Prolog

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 7
    Points : 7
    Points
    7
    Par défaut Plus court chemin entre deux états
    Bonjour je voudrais calculer la plus petite distance entre deux listes.
    Je m'explique; j'ai un état initial et un état final et des opérateurs pour passer d'un état à l'autre.Mais je voudrais juste récupérer le plus court chemin en calculant la distance entre l'état final et l'état courant.
    Je sais que je dois implémenter l'algorithme A*, mais je n'arrive pas vraiment à le faire .
    Merci .

  2. #2
    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
    Montre déjà ce que tu as écrit ...
    Et donnes plus de précisions sur ton problème.
    "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

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 7
    Points : 7
    Points
    7
    Par défaut
    Mon pb se rapproche plus ou moins du problème des cruches .Il tourne normalement mais il utilise soit le parcours en largeur ou le parcours en profondeur.Ce que je voudrais c'est de l'améliorer afin qu'il n'explore pas tous les chemins en utilisant une heuristiqie qui permet que de prendre celui qui est le minimum.
    J'ai fait des recherches et j'ai trouvé des info sur l 'algorithme A*.
    Et j'ai trouvé l'implémentation suivante:
    Heuristique:
    minimiser
    F(E) = L + MP
    avec
    E= état courant
    L= longueur du chemin de l’état initial à E
    MP= le nombre de carrés mal placés par rapport à la configuration finale.
    Pour calculer la longeur je vais utiliser le predicat longueur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    longueur:-([], [],0).
    longueur:-([T|Q],[T1|Q1],D):-longueur(Q,Q1,D).
    longueur:-([T|Q],[T1|Q1],M):-longueur(Q,Q1,D),M is D+1.
    je calcule le minimum comme suit:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    min([X],X).
    min([X|L],X) :- min(L,Y), X<Y.
    min([X|L],Y) :- min(L,Y), X>=Y.
    mon problème est de trouver comment implémenter MP le nombre de carrés mal placés par rapport à la configuration finale.

  4. #4
    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
    Je ne comprends pas bien l'intérêt de ces deux clauses :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    longueur:-([T|Q],[T1|Q1],D):-longueur(Q,Q1,D).
    longueur:-([T|Q],[T1|Q1],M):-longueur(Q,Q1,D),M is D+1.
    L'entête est exactement la même au nom près de variable près.
    peut-être est-ce ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    longueur:-([T|Q],[T|Q1],D):- <= ici c'est le même premier élément de liste 
      longueur(Q,Q1,D).
    longueur:-([T|Q],[T1|Q1],M):- <= ici ce n'est pas le même
      longueur(Q,Q1,D),M is D+1.
    Si tu utilises SWI-Prolog, tu as un prédicat min_list
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    min_list(+List, -Min)
        True  if Min is the smallest number in List.
    "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

  5. #5
    Futur Membre du Club
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 7
    Points : 7
    Points
    7
    Par défaut
    je pense que c'est juste une erreur de syntaxe je voulais écrire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    longueur([T|Q],[T1|Q1],D):-longueur(Q,Q1,D).
    longueur([T|Q],[T1|Q1],M):-longueur(Q,Q1,D),M is D+1.
    je vais essayer d'utiliser minlist comme vous avez dit.

  6. #6
    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
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    longueur([T|Q],[T1|Q1],D):-longueur(Q,Q1,D).
    longueur([T|Q],[T1|Q1],M):-longueur(Q,Q1,D),M is D+1.
    Je continue à ne pas comprendre ces deux clauses qui ont exactement la même en-tête, on peut intervertir D et M dans la deuxième clause sans rien changer à sa sémantique.
    Que sont-elle censées faire ?
    "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

  7. #7
    Futur Membre du Club
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 7
    Points : 7
    Points
    7
    Par défaut
    finalement le predicat longueur ne m'a servi à rien du tout

  8. #8
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2014
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Novembre 2014
    Messages : 2
    Points : 3
    Points
    3
    Par défaut
    titi_lion, si vous avez trouvé une solution, merci de me la passer parce que en faite je travail sur un prb pareil. merci d'avance

  9. #9
    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
    Citation Envoyé par AdelBenHassine Voir le message
    titi_lion, si vous avez trouvé une solution, merci de me la passer parce que en faite je travail sur un prb pareil. merci d'avance
    Inutile de déterrer une discussion d'il y a 6 ans !
    Postez-votre code est vos questions plutôt que demander une solution toute faite !
    "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. Le plus court chemin entre deux points les plus éloignés
    Par takesrit dans le forum Traitement d'images
    Réponses: 3
    Dernier message: 30/05/2011, 18h39
  2. Le plus court chemin entre tous les chemins.
    Par NoIdea dans le forum Intelligence artificielle
    Réponses: 4
    Dernier message: 14/04/2011, 09h42
  3. Calcul de plus court chemin dans un graphe
    Par Elmilouse dans le forum Prolog
    Réponses: 6
    Dernier message: 21/03/2010, 20h26
  4. Calcul du plu court chemin entre 2 sommets d'un graphe valué
    Par atlasm dans le forum Algorithmes et structures de données
    Réponses: 25
    Dernier message: 07/08/2005, 17h06
  5. Réponses: 2
    Dernier message: 21/03/2004, 18h57

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