SlideShare ist ein Scribd-Unternehmen logo
1 von 26
Algorithme A*
Par: Sari Meriem
1
UNIVERSITE MOHAMED CHERIF MESAADIA
SOUK-AHRAS
Exposé sur:
Plan
2
 Introduction.
 Algorithme A star.
 Objectif.
 Applications.
 Description.
 Algorithme.
 Exemple.
 Implémentation du TP.
 Conclusion.
Sari Meriem Algorithme A* 1ére Année Master GL
Introduction
3
 Le « PATHFINDING » est un domaine de l'informatique qui étudie
les différentes façons de trouver un chemin entre un point A et un
point B.
 L'un des algorithmes de pathfinding les plus connus est A* (
prononcez A étoile, ou A star en anglais).
Sari Meriem Algorithme A* 1ére Année Master GL
Introduction
4
C’est quoi le A *?
Sari Meriem Algorithme A* 1ére Année Master GL
A star
5
 A été proposé pour la première fois par Peter E. Hart, Nils Nilsson
et Bertram Raphael en 1968.
 Est une extension de l'algorithme de Dijkstra de 1959.
 Est un algorithme itératif.
 Permet la recherche d’un chemin à partir d’un état Initial (source)
vers un état final (destination).
 Il ne donne pas toujours la solution optimale mais il donne très
rapidement une bonne solution.
Sari Meriem Algorithme A* 1ére Année Master GL
Objectif
6
 Déterminer, pour un agent donné, un chemin de coût minimum
depuis un sommet source vers un sommet destination au sein d’un
graphe.
 Un agent est un objet informatique utilisé pour représenter une
entité mobile dotée d’un comportement (humain, animal, véhicule,
…)
Sari Meriem Algorithme A* 1ére Année Master GL
Objectif
7
 Le coût d’un arc dépend de l’application de l’algorithme.
 Exemple:
 Distance kilométrique:
Recherche de chemins de longueur minimale.
 Temps:
Recherche de chemins en temps minimum.
 Consommation de carburant:
Rechercher de chemins « économes ».
Sari Meriem Algorithme A* 1ére Année Master GL
Applications
8
 Jeux vidéo:
 Animation des personnages non joueurs.
 Déplacement réaliste d’un personnage contrôlé par le joueur
vers un objectif désigné par le joueur.
 Simulation – vie artificielle:
 Etude du comportement d’une foule, du trafic automobile, …
 Effets spéciaux (scènes de bataille, …)
Sari Meriem Algorithme A* 1ére Année Master GL
Description
9
 Vocabulaires nécessaire à savoir:
 Le graphe: ensemble des nœuds et des arcs.
 Un nœud: c'est une unité du graphe, l'algorithme va parcourir le
graphe en passant des nœuds.
 La liste ouverte: C'est une liste qui contient les nœuds à analyser.
 La liste fermée: C'est une liste qui contient les nœuds déjà
analysés.
Sari Meriem Algorithme A* 1ére Année Master GL
Description
10
 Pour chaque nœuds on a les propriétés suivante:
 Parent (P): il s'agit du prédécesseur du nœud courant.
 G: il s'agit de la distance parcourue depuis le point de départ pour
arriver au nœud courant (Coût depuis la source).
 H: il s'agit de la distance à vol d'oiseau entre le nœud courant et le
nœud d'arrivée (Coût vers la destination).
 Poids(F): Coût depuis la source (G) + Coût vers la destination (H) .
Sari Meriem Algorithme A* 1ére Année Master GL
Algorithme
11
Initialisation
Sommet source (S)
Sommet destination (D)
Liste ouverte à explorer (E) : sommet source S
Liste fermée déjà visités (V) : vide
Tant que (la liste E est non vide) et (D n’est pas dans E) Faire
+ Récupérer le sommet X de coût F minimum.
+ Ajouter X à la liste V
+ Ajouter les successeurs de X (non déjà visités) à la liste E en
évaluant leur coût F et en identifiant leur prédécesseur.
+ Si (un successeur est déjà présent dans E) et
(nouveau coût est inférieur à l’ancien) Alors
Changer son coût F
Changer son prédécesseur
FinSi
FinFaire
Sari Meriem Algorithme A* 1ére Année Master GL
Algorithme
12
 L’algorithme s’ arrêtera dans deux cas:
I. Si la liste des nœuds à visiter (ouverte) est vide et le nœud
destinations n’appartient pas à la liste des nœuds déjà visité
(fermée)  dans ce cas il n’y a pas de chemin entre la source et
la destination.
II. Si le nœud destination appartient à la liste des nœuds déjà
visité (fermée)  dans ce cas l’algorithme a trouvé un chemin
entre la source et la destination.
Sari Meriem Algorithme A* 1ére Année Master GL
Exemple
13
S
D
S
D
Sommet source
Sommet destination
Obstacle
Sari Meriem Algorithme A* 1ére Année Master GL
Exemple
14
S
D
10 + 30
10 + 50
10 + 50
Sommet déjà visité
Sommet à explorer
G + H
Coût depuis
la source
Coût vers
la destination
Référence au
prédécesseur
Sari Meriem Algorithme A* 1ére Année Master GL
Exemple
15
S
D
10 + 30
10 + 50
10 + 50
20 + 40
20 + 40 Sommet déjà visité
Sommet à explorer
G + H
Coût depuis
la source
Coût vers
la destination
Référence au
prédécesseur
Sari Meriem Algorithme A* 1ére Année Master GL
Exemple
16
S
D
10 + 30
10 + 50
10 + 50
20 + 40
20 + 40
20 + 60
Sommet déjà visité
Sommet à explorer
G + H
Coût depuis
la source
Coût vers
la destination
Référence au
prédécesseur
Sari Meriem Algorithme A* 1ére Année Master GL
Exemple
17
S
D
10 + 30
10 + 50
10 + 50
20 + 40
20 + 40
20 + 60
20 + 60
Sommet déjà visité
Sommet à explorer
G + H
Coût depuis
la source
Coût vers
la destination
Référence au
prédécesseur
Sari Meriem Algorithme A* 1ére Année Master GL
Exemple
18
S
D
10 + 30
10 + 50
20 + 40
20 + 40
20 + 60
30 + 50 Sommet déjà visité
Sommet à explorer
G + H
Coût depuis
la source
Coût vers
la destination
Référence au
prédécesseur
Sari Meriem Algorithme A* 1ére Année Master GL
Exemple
19
S
D
10 + 30
10 + 50
10 + 50
20 + 40
20 + 40
20 + 60
20 + 60
30 + 50 30 + 30 Sommet déjà visité
Sommet à explorer
G + H
Coût depuis
la source
Coût vers
la destination
Référence au
prédécesseur
Sari Meriem Algorithme A* 1ére Année Master GL
Exemple
20
S
D
10 + 30
10 + 50
10 + 50
20 + 40
20 + 40
20 + 60
20 + 60
30 + 50 30 + 30 40 + 20 Sommet déjà visité
Sommet à explorer
G + H
Coût depuis
la source
Coût vers
la destination
Référence au
prédécesseur
Sari Meriem Algorithme A* 1ére Année Master GL
Exemple
21
S
D
10 + 30
10 + 50
20 + 40
20 + 60
30 + 30 40 + 20 50 + 10
50 + 10
Sommet déjà visité
Sommet à explorer
G + H
Coût depuis
la source
Coût vers
la destination
Référence au
prédécesseur
Sari Meriem Algorithme A* 1ére Année Master GL
Exemple
22
S
10 + 30
10 + 50
20 + 40
20 + 40
20 + 60
30 + 50 30 + 30 40 + 20 50 + 10
50 + 10
60 + 20
60 + 0
Sommet déjà visité
Sommet à explorer
G + H
Coût depuis
la source
Coût vers
la destination
Référence au
prédécesseur
Sari Meriem Algorithme A* 1ére Année Master GL
Exemple
23
S
D
Sari Meriem Algorithme A* 1ére Année Master GL
Implémentation du TP
24
 L'implémentation proposée se base sur 4 classes :
 Astar: une classe fournissant l'algorithme de calcul.
 Node: une classe représentant un noeud du parcours .
 NodeFactory: une classe abstraite permettant de créer les
noeuds, dans laquelle il faut implémenter les méthodes de calcul
de G et H.
 SuccessorComputer: une classe abstraite fournissant les
successeurs d'un point particulier.
 MainTest: une classe fournissant un cas de test concret sur une
chaine de caractères ou " " représente un chemin exploitable et
" | " représente un chemin interdit.
Sari Meriem Algorithme A* 1ére Année Master GL
Implémentation du TP
25Sari Meriem Algorithme A* 1ére Année Master GL
Conclusion
26
 L’algorithme A* ne donne pas toujours la meilleure solution mais il
en donne une bonne solution.
 On pourrait comparer ses performances avec celles de
l'algorithme de Dijkstra.
 Dijkstra donne la meilleure solution, mais A* est plus rapide.
Sari Meriem Algorithme A* 1ére Année Master GL

Weitere ähnliche Inhalte

Was ist angesagt?

Optimisation par colonie de fourmis par zellagui amine
Optimisation par colonie de fourmis par zellagui amineOptimisation par colonie de fourmis par zellagui amine
Optimisation par colonie de fourmis par zellagui amineZellagui Amine
 
Chapitre 3 la recherche tabou
Chapitre 3 la recherche tabouChapitre 3 la recherche tabou
Chapitre 3 la recherche tabouAchraf Manaa
 
Machine Learning et Intelligence Artificielle
Machine Learning et Intelligence ArtificielleMachine Learning et Intelligence Artificielle
Machine Learning et Intelligence ArtificielleSoft Computing
 
Chp4 - Diagramme de Séquence
Chp4 - Diagramme de SéquenceChp4 - Diagramme de Séquence
Chp4 - Diagramme de SéquenceLilia Sfaxi
 
chap2 algorithme de recherche.pdf
chap2 algorithme de recherche.pdfchap2 algorithme de recherche.pdf
chap2 algorithme de recherche.pdfdonixwm
 
L’intelligence artificielle
L’intelligence artificielleL’intelligence artificielle
L’intelligence artificielleiapassmed
 
Chapitre 4 heuristiques et méta heuristiques
Chapitre 4 heuristiques et méta heuristiquesChapitre 4 heuristiques et méta heuristiques
Chapitre 4 heuristiques et méta heuristiquesSana Aroussi
 
Chp3 - Diagramme de Classes
Chp3 - Diagramme de ClassesChp3 - Diagramme de Classes
Chp3 - Diagramme de ClassesLilia Sfaxi
 
Chapitre iv algorithmes de tri
Chapitre iv algorithmes de triChapitre iv algorithmes de tri
Chapitre iv algorithmes de triSana Aroussi
 
Apprentissage par renforcement
Apprentissage par renforcement Apprentissage par renforcement
Apprentissage par renforcement seml147
 
l'Intelligence Artificielle Jean-Antoine Moreau
l'Intelligence Artificielle Jean-Antoine Moreaul'Intelligence Artificielle Jean-Antoine Moreau
l'Intelligence Artificielle Jean-Antoine MoreauJean-Antoine Moreau
 
Rapport stage pfe
Rapport stage  pfe Rapport stage  pfe
Rapport stage pfe rimeh moussi
 
Data mining - Introduction générale
Data mining - Introduction généraleData mining - Introduction générale
Data mining - Introduction généraleMohamed Heny SELMI
 
Soutenance de Mon PFE - Interaction Homme Machine par geste avec Python - Jai...
Soutenance de Mon PFE - Interaction Homme Machine par geste avec Python - Jai...Soutenance de Mon PFE - Interaction Homme Machine par geste avec Python - Jai...
Soutenance de Mon PFE - Interaction Homme Machine par geste avec Python - Jai...Mohammed JAITI
 
TP2-UML-Correction
TP2-UML-CorrectionTP2-UML-Correction
TP2-UML-CorrectionLilia Sfaxi
 
Techniques du data mining
Techniques du data miningTechniques du data mining
Techniques du data miningDonia Hammami
 
Automatique systémes linéaires et non linéaires 2
Automatique   systémes linéaires et non linéaires 2Automatique   systémes linéaires et non linéaires 2
Automatique systémes linéaires et non linéaires 2badr zaimi
 
Exercice arbre de décision
Exercice arbre de décision Exercice arbre de décision
Exercice arbre de décision Yassine Badri
 

Was ist angesagt? (20)

Optimisation par colonie de fourmis par zellagui amine
Optimisation par colonie de fourmis par zellagui amineOptimisation par colonie de fourmis par zellagui amine
Optimisation par colonie de fourmis par zellagui amine
 
Chapitre 3 la recherche tabou
Chapitre 3 la recherche tabouChapitre 3 la recherche tabou
Chapitre 3 la recherche tabou
 
Machine Learning et Intelligence Artificielle
Machine Learning et Intelligence ArtificielleMachine Learning et Intelligence Artificielle
Machine Learning et Intelligence Artificielle
 
Chp4 - Diagramme de Séquence
Chp4 - Diagramme de SéquenceChp4 - Diagramme de Séquence
Chp4 - Diagramme de Séquence
 
chap2 algorithme de recherche.pdf
chap2 algorithme de recherche.pdfchap2 algorithme de recherche.pdf
chap2 algorithme de recherche.pdf
 
L’intelligence artificielle
L’intelligence artificielleL’intelligence artificielle
L’intelligence artificielle
 
Chapitre 4 heuristiques et méta heuristiques
Chapitre 4 heuristiques et méta heuristiquesChapitre 4 heuristiques et méta heuristiques
Chapitre 4 heuristiques et méta heuristiques
 
Chp3 - Diagramme de Classes
Chp3 - Diagramme de ClassesChp3 - Diagramme de Classes
Chp3 - Diagramme de Classes
 
gestion de projet
gestion de projetgestion de projet
gestion de projet
 
Chapitre iv algorithmes de tri
Chapitre iv algorithmes de triChapitre iv algorithmes de tri
Chapitre iv algorithmes de tri
 
Apprentissage par renforcement
Apprentissage par renforcement Apprentissage par renforcement
Apprentissage par renforcement
 
l'Intelligence Artificielle Jean-Antoine Moreau
l'Intelligence Artificielle Jean-Antoine Moreaul'Intelligence Artificielle Jean-Antoine Moreau
l'Intelligence Artificielle Jean-Antoine Moreau
 
Rapport stage pfe
Rapport stage  pfe Rapport stage  pfe
Rapport stage pfe
 
Data mining - Introduction générale
Data mining - Introduction généraleData mining - Introduction générale
Data mining - Introduction générale
 
Knn
KnnKnn
Knn
 
Soutenance de Mon PFE - Interaction Homme Machine par geste avec Python - Jai...
Soutenance de Mon PFE - Interaction Homme Machine par geste avec Python - Jai...Soutenance de Mon PFE - Interaction Homme Machine par geste avec Python - Jai...
Soutenance de Mon PFE - Interaction Homme Machine par geste avec Python - Jai...
 
TP2-UML-Correction
TP2-UML-CorrectionTP2-UML-Correction
TP2-UML-Correction
 
Techniques du data mining
Techniques du data miningTechniques du data mining
Techniques du data mining
 
Automatique systémes linéaires et non linéaires 2
Automatique   systémes linéaires et non linéaires 2Automatique   systémes linéaires et non linéaires 2
Automatique systémes linéaires et non linéaires 2
 
Exercice arbre de décision
Exercice arbre de décision Exercice arbre de décision
Exercice arbre de décision
 

Mehr von meriem sari

What is an aspect in aspect oriented requirements engineering
What is an aspect in aspect oriented requirements engineeringWhat is an aspect in aspect oriented requirements engineering
What is an aspect in aspect oriented requirements engineeringmeriem sari
 
Structural features for face recognition
Structural features for face recognitionStructural features for face recognition
Structural features for face recognitionmeriem sari
 
Qt user interface
Qt user interfaceQt user interface
Qt user interfacemeriem sari
 
Programmation orienté aspect
Programmation orienté aspectProgrammation orienté aspect
Programmation orienté aspectmeriem sari
 
Meta-modelisation avec eclipse
Meta-modelisation avec eclipseMeta-modelisation avec eclipse
Meta-modelisation avec eclipsemeriem sari
 
Diagrammes de classes uml
Diagrammes de classes umlDiagrammes de classes uml
Diagrammes de classes umlmeriem sari
 
Design patterns french
Design patterns frenchDesign patterns french
Design patterns frenchmeriem sari
 
Design patterns english
Design patterns englishDesign patterns english
Design patterns englishmeriem sari
 

Mehr von meriem sari (13)

Contraintes uml
Contraintes umlContraintes uml
Contraintes uml
 
Cvs
CvsCvs
Cvs
 
Ws asp.net
Ws asp.netWs asp.net
Ws asp.net
 
What is an aspect in aspect oriented requirements engineering
What is an aspect in aspect oriented requirements engineeringWhat is an aspect in aspect oriented requirements engineering
What is an aspect in aspect oriented requirements engineering
 
Structural features for face recognition
Structural features for face recognitionStructural features for face recognition
Structural features for face recognition
 
Rest ws
Rest wsRest ws
Rest ws
 
Qt user interface
Qt user interfaceQt user interface
Qt user interface
 
Programmation orienté aspect
Programmation orienté aspectProgrammation orienté aspect
Programmation orienté aspect
 
Meta-modelisation avec eclipse
Meta-modelisation avec eclipseMeta-modelisation avec eclipse
Meta-modelisation avec eclipse
 
Diagrammes de classes uml
Diagrammes de classes umlDiagrammes de classes uml
Diagrammes de classes uml
 
Design patterns french
Design patterns frenchDesign patterns french
Design patterns french
 
Design patterns english
Design patterns englishDesign patterns english
Design patterns english
 
Cvl
CvlCvl
Cvl
 

Kürzlich hochgeladen

Cadre réglementaire et développement de l'agrivoltaïsme en France
Cadre réglementaire et développement de l'agrivoltaïsme en FranceCadre réglementaire et développement de l'agrivoltaïsme en France
Cadre réglementaire et développement de l'agrivoltaïsme en Franceidelewebmestre
 
BOW 24 - De la réflexion de groupe à l'immersion dans des bâtiments porcins
BOW 24 - De la réflexion de groupe à l'immersion dans des bâtiments porcinsBOW 24 - De la réflexion de groupe à l'immersion dans des bâtiments porcins
BOW 24 - De la réflexion de groupe à l'immersion dans des bâtiments porcinsidelewebmestre
 
Bow 2024 - Plein air à l'intérieur des bâtiments d'élevage de ruminants
Bow 2024 - Plein air à l'intérieur des bâtiments d'élevage de ruminantsBow 2024 - Plein air à l'intérieur des bâtiments d'élevage de ruminants
Bow 2024 - Plein air à l'intérieur des bâtiments d'élevage de ruminantsidelewebmestre
 
BOW 2024 - Le bâtiment multicritère porcin
BOW 2024 - Le bâtiment multicritère porcinBOW 2024 - Le bâtiment multicritère porcin
BOW 2024 - Le bâtiment multicritère porcinidelewebmestre
 
Accompagnement de l'agrivoltaïsme dans le département de la Nièvre
Accompagnement de l'agrivoltaïsme dans le département de la NièvreAccompagnement de l'agrivoltaïsme dans le département de la Nièvre
Accompagnement de l'agrivoltaïsme dans le département de la Nièvreidelewebmestre
 
Agrivoltaïsme et filière ovine en Dordogne
Agrivoltaïsme et filière ovine en DordogneAgrivoltaïsme et filière ovine en Dordogne
Agrivoltaïsme et filière ovine en Dordogneidelewebmestre
 
BOW 2024 - Dedans/Dehors quand voir ne suffit pas
BOW 2024 - Dedans/Dehors quand voir ne suffit pasBOW 2024 - Dedans/Dehors quand voir ne suffit pas
BOW 2024 - Dedans/Dehors quand voir ne suffit pasidelewebmestre
 
Cours polymère presentation powerpoint 46 pages
Cours polymère presentation powerpoint 46 pagesCours polymère presentation powerpoint 46 pages
Cours polymère presentation powerpoint 46 pagesPierreFournier32
 
BOW 2024 -3-9 - Matelas de logettes à eau refroidie VL
BOW 2024 -3-9 - Matelas de logettes à eau refroidie VLBOW 2024 -3-9 - Matelas de logettes à eau refroidie VL
BOW 2024 -3-9 - Matelas de logettes à eau refroidie VLidelewebmestre
 
BOW 2024 - 3-5 - Des solutions numériques pour se préparer aux pics de chaleur
BOW 2024 - 3-5 - Des solutions numériques pour se préparer aux pics de chaleurBOW 2024 - 3-5 - Des solutions numériques pour se préparer aux pics de chaleur
BOW 2024 - 3-5 - Des solutions numériques pour se préparer aux pics de chaleuridelewebmestre
 
BOW 2024 - Jardins d'hiver en poulets de chair
BOW 2024 - Jardins d'hiver en poulets de chairBOW 2024 - Jardins d'hiver en poulets de chair
BOW 2024 - Jardins d'hiver en poulets de chairidelewebmestre
 
BOW 2024 - L'écurie ouverte : un concept inspirant pour la filière équine
BOW 2024 - L'écurie ouverte : un concept inspirant pour la filière équineBOW 2024 - L'écurie ouverte : un concept inspirant pour la filière équine
BOW 2024 - L'écurie ouverte : un concept inspirant pour la filière équineidelewebmestre
 
BOW 2024 - Nouveaux modes de logement pour des veaux de boucherie avec accès ...
BOW 2024 - Nouveaux modes de logement pour des veaux de boucherie avec accès ...BOW 2024 - Nouveaux modes de logement pour des veaux de boucherie avec accès ...
BOW 2024 - Nouveaux modes de logement pour des veaux de boucherie avec accès ...idelewebmestre
 
BOW 2024 - 3-2 - Stress thermique impact vaches laitières
BOW 2024 - 3-2 - Stress thermique impact vaches laitièresBOW 2024 - 3-2 - Stress thermique impact vaches laitières
BOW 2024 - 3-2 - Stress thermique impact vaches laitièresidelewebmestre
 
BOW 2024-3-10 - Batcool Petits ruminants
BOW 2024-3-10 - Batcool Petits ruminantsBOW 2024-3-10 - Batcool Petits ruminants
BOW 2024-3-10 - Batcool Petits ruminantsidelewebmestre
 
Accompagnement de l'agrivoltaisme - Focus sur l'étude système en Merthe et Mo...
Accompagnement de l'agrivoltaisme - Focus sur l'étude système en Merthe et Mo...Accompagnement de l'agrivoltaisme - Focus sur l'étude système en Merthe et Mo...
Accompagnement de l'agrivoltaisme - Focus sur l'étude système en Merthe et Mo...idelewebmestre
 
BOW 2024 - L'enrichissement du milieu des chèvres laitières
BOW 2024 - L'enrichissement du milieu des chèvres laitièresBOW 2024 - L'enrichissement du milieu des chèvres laitières
BOW 2024 - L'enrichissement du milieu des chèvres laitièresidelewebmestre
 
BOW 2024 - 3-6 - Adaptation climat chaud Porcs
BOW 2024 - 3-6 - Adaptation climat chaud PorcsBOW 2024 - 3-6 - Adaptation climat chaud Porcs
BOW 2024 - 3-6 - Adaptation climat chaud Porcsidelewebmestre
 
BOW 2024 - 3 1 - Les infrastructures équestres et le changement climatique
BOW 2024 - 3 1 - Les infrastructures équestres et le changement climatiqueBOW 2024 - 3 1 - Les infrastructures équestres et le changement climatique
BOW 2024 - 3 1 - Les infrastructures équestres et le changement climatiqueidelewebmestre
 

Kürzlich hochgeladen (20)

Cadre réglementaire et développement de l'agrivoltaïsme en France
Cadre réglementaire et développement de l'agrivoltaïsme en FranceCadre réglementaire et développement de l'agrivoltaïsme en France
Cadre réglementaire et développement de l'agrivoltaïsme en France
 
BOW 24 - De la réflexion de groupe à l'immersion dans des bâtiments porcins
BOW 24 - De la réflexion de groupe à l'immersion dans des bâtiments porcinsBOW 24 - De la réflexion de groupe à l'immersion dans des bâtiments porcins
BOW 24 - De la réflexion de groupe à l'immersion dans des bâtiments porcins
 
Bow 2024 - Plein air à l'intérieur des bâtiments d'élevage de ruminants
Bow 2024 - Plein air à l'intérieur des bâtiments d'élevage de ruminantsBow 2024 - Plein air à l'intérieur des bâtiments d'élevage de ruminants
Bow 2024 - Plein air à l'intérieur des bâtiments d'élevage de ruminants
 
BOW 2024 - Le bâtiment multicritère porcin
BOW 2024 - Le bâtiment multicritère porcinBOW 2024 - Le bâtiment multicritère porcin
BOW 2024 - Le bâtiment multicritère porcin
 
Accompagnement de l'agrivoltaïsme dans le département de la Nièvre
Accompagnement de l'agrivoltaïsme dans le département de la NièvreAccompagnement de l'agrivoltaïsme dans le département de la Nièvre
Accompagnement de l'agrivoltaïsme dans le département de la Nièvre
 
Agrivoltaïsme et filière ovine en Dordogne
Agrivoltaïsme et filière ovine en DordogneAgrivoltaïsme et filière ovine en Dordogne
Agrivoltaïsme et filière ovine en Dordogne
 
BOW 2024 - Dedans/Dehors quand voir ne suffit pas
BOW 2024 - Dedans/Dehors quand voir ne suffit pasBOW 2024 - Dedans/Dehors quand voir ne suffit pas
BOW 2024 - Dedans/Dehors quand voir ne suffit pas
 
Cours polymère presentation powerpoint 46 pages
Cours polymère presentation powerpoint 46 pagesCours polymère presentation powerpoint 46 pages
Cours polymère presentation powerpoint 46 pages
 
BOW 2024 -3-9 - Matelas de logettes à eau refroidie VL
BOW 2024 -3-9 - Matelas de logettes à eau refroidie VLBOW 2024 -3-9 - Matelas de logettes à eau refroidie VL
BOW 2024 -3-9 - Matelas de logettes à eau refroidie VL
 
BOW 2024 - 3-5 - Des solutions numériques pour se préparer aux pics de chaleur
BOW 2024 - 3-5 - Des solutions numériques pour se préparer aux pics de chaleurBOW 2024 - 3-5 - Des solutions numériques pour se préparer aux pics de chaleur
BOW 2024 - 3-5 - Des solutions numériques pour se préparer aux pics de chaleur
 
BOW 2024 - Jardins d'hiver en poulets de chair
BOW 2024 - Jardins d'hiver en poulets de chairBOW 2024 - Jardins d'hiver en poulets de chair
BOW 2024 - Jardins d'hiver en poulets de chair
 
BOW 2024 - L'écurie ouverte : un concept inspirant pour la filière équine
BOW 2024 - L'écurie ouverte : un concept inspirant pour la filière équineBOW 2024 - L'écurie ouverte : un concept inspirant pour la filière équine
BOW 2024 - L'écurie ouverte : un concept inspirant pour la filière équine
 
Webinaire lésions podales_04.04.2024.pptx
Webinaire lésions podales_04.04.2024.pptxWebinaire lésions podales_04.04.2024.pptx
Webinaire lésions podales_04.04.2024.pptx
 
BOW 2024 - Nouveaux modes de logement pour des veaux de boucherie avec accès ...
BOW 2024 - Nouveaux modes de logement pour des veaux de boucherie avec accès ...BOW 2024 - Nouveaux modes de logement pour des veaux de boucherie avec accès ...
BOW 2024 - Nouveaux modes de logement pour des veaux de boucherie avec accès ...
 
BOW 2024 - 3-2 - Stress thermique impact vaches laitières
BOW 2024 - 3-2 - Stress thermique impact vaches laitièresBOW 2024 - 3-2 - Stress thermique impact vaches laitières
BOW 2024 - 3-2 - Stress thermique impact vaches laitières
 
BOW 2024-3-10 - Batcool Petits ruminants
BOW 2024-3-10 - Batcool Petits ruminantsBOW 2024-3-10 - Batcool Petits ruminants
BOW 2024-3-10 - Batcool Petits ruminants
 
Accompagnement de l'agrivoltaisme - Focus sur l'étude système en Merthe et Mo...
Accompagnement de l'agrivoltaisme - Focus sur l'étude système en Merthe et Mo...Accompagnement de l'agrivoltaisme - Focus sur l'étude système en Merthe et Mo...
Accompagnement de l'agrivoltaisme - Focus sur l'étude système en Merthe et Mo...
 
BOW 2024 - L'enrichissement du milieu des chèvres laitières
BOW 2024 - L'enrichissement du milieu des chèvres laitièresBOW 2024 - L'enrichissement du milieu des chèvres laitières
BOW 2024 - L'enrichissement du milieu des chèvres laitières
 
BOW 2024 - 3-6 - Adaptation climat chaud Porcs
BOW 2024 - 3-6 - Adaptation climat chaud PorcsBOW 2024 - 3-6 - Adaptation climat chaud Porcs
BOW 2024 - 3-6 - Adaptation climat chaud Porcs
 
BOW 2024 - 3 1 - Les infrastructures équestres et le changement climatique
BOW 2024 - 3 1 - Les infrastructures équestres et le changement climatiqueBOW 2024 - 3 1 - Les infrastructures équestres et le changement climatique
BOW 2024 - 3 1 - Les infrastructures équestres et le changement climatique
 

A star

  • 1. Algorithme A* Par: Sari Meriem 1 UNIVERSITE MOHAMED CHERIF MESAADIA SOUK-AHRAS Exposé sur:
  • 2. Plan 2  Introduction.  Algorithme A star.  Objectif.  Applications.  Description.  Algorithme.  Exemple.  Implémentation du TP.  Conclusion. Sari Meriem Algorithme A* 1ére Année Master GL
  • 3. Introduction 3  Le « PATHFINDING » est un domaine de l'informatique qui étudie les différentes façons de trouver un chemin entre un point A et un point B.  L'un des algorithmes de pathfinding les plus connus est A* ( prononcez A étoile, ou A star en anglais). Sari Meriem Algorithme A* 1ére Année Master GL
  • 4. Introduction 4 C’est quoi le A *? Sari Meriem Algorithme A* 1ére Année Master GL
  • 5. A star 5  A été proposé pour la première fois par Peter E. Hart, Nils Nilsson et Bertram Raphael en 1968.  Est une extension de l'algorithme de Dijkstra de 1959.  Est un algorithme itératif.  Permet la recherche d’un chemin à partir d’un état Initial (source) vers un état final (destination).  Il ne donne pas toujours la solution optimale mais il donne très rapidement une bonne solution. Sari Meriem Algorithme A* 1ére Année Master GL
  • 6. Objectif 6  Déterminer, pour un agent donné, un chemin de coût minimum depuis un sommet source vers un sommet destination au sein d’un graphe.  Un agent est un objet informatique utilisé pour représenter une entité mobile dotée d’un comportement (humain, animal, véhicule, …) Sari Meriem Algorithme A* 1ére Année Master GL
  • 7. Objectif 7  Le coût d’un arc dépend de l’application de l’algorithme.  Exemple:  Distance kilométrique: Recherche de chemins de longueur minimale.  Temps: Recherche de chemins en temps minimum.  Consommation de carburant: Rechercher de chemins « économes ». Sari Meriem Algorithme A* 1ére Année Master GL
  • 8. Applications 8  Jeux vidéo:  Animation des personnages non joueurs.  Déplacement réaliste d’un personnage contrôlé par le joueur vers un objectif désigné par le joueur.  Simulation – vie artificielle:  Etude du comportement d’une foule, du trafic automobile, …  Effets spéciaux (scènes de bataille, …) Sari Meriem Algorithme A* 1ére Année Master GL
  • 9. Description 9  Vocabulaires nécessaire à savoir:  Le graphe: ensemble des nœuds et des arcs.  Un nœud: c'est une unité du graphe, l'algorithme va parcourir le graphe en passant des nœuds.  La liste ouverte: C'est une liste qui contient les nœuds à analyser.  La liste fermée: C'est une liste qui contient les nœuds déjà analysés. Sari Meriem Algorithme A* 1ére Année Master GL
  • 10. Description 10  Pour chaque nœuds on a les propriétés suivante:  Parent (P): il s'agit du prédécesseur du nœud courant.  G: il s'agit de la distance parcourue depuis le point de départ pour arriver au nœud courant (Coût depuis la source).  H: il s'agit de la distance à vol d'oiseau entre le nœud courant et le nœud d'arrivée (Coût vers la destination).  Poids(F): Coût depuis la source (G) + Coût vers la destination (H) . Sari Meriem Algorithme A* 1ére Année Master GL
  • 11. Algorithme 11 Initialisation Sommet source (S) Sommet destination (D) Liste ouverte à explorer (E) : sommet source S Liste fermée déjà visités (V) : vide Tant que (la liste E est non vide) et (D n’est pas dans E) Faire + Récupérer le sommet X de coût F minimum. + Ajouter X à la liste V + Ajouter les successeurs de X (non déjà visités) à la liste E en évaluant leur coût F et en identifiant leur prédécesseur. + Si (un successeur est déjà présent dans E) et (nouveau coût est inférieur à l’ancien) Alors Changer son coût F Changer son prédécesseur FinSi FinFaire Sari Meriem Algorithme A* 1ére Année Master GL
  • 12. Algorithme 12  L’algorithme s’ arrêtera dans deux cas: I. Si la liste des nœuds à visiter (ouverte) est vide et le nœud destinations n’appartient pas à la liste des nœuds déjà visité (fermée)  dans ce cas il n’y a pas de chemin entre la source et la destination. II. Si le nœud destination appartient à la liste des nœuds déjà visité (fermée)  dans ce cas l’algorithme a trouvé un chemin entre la source et la destination. Sari Meriem Algorithme A* 1ére Année Master GL
  • 13. Exemple 13 S D S D Sommet source Sommet destination Obstacle Sari Meriem Algorithme A* 1ére Année Master GL
  • 14. Exemple 14 S D 10 + 30 10 + 50 10 + 50 Sommet déjà visité Sommet à explorer G + H Coût depuis la source Coût vers la destination Référence au prédécesseur Sari Meriem Algorithme A* 1ére Année Master GL
  • 15. Exemple 15 S D 10 + 30 10 + 50 10 + 50 20 + 40 20 + 40 Sommet déjà visité Sommet à explorer G + H Coût depuis la source Coût vers la destination Référence au prédécesseur Sari Meriem Algorithme A* 1ére Année Master GL
  • 16. Exemple 16 S D 10 + 30 10 + 50 10 + 50 20 + 40 20 + 40 20 + 60 Sommet déjà visité Sommet à explorer G + H Coût depuis la source Coût vers la destination Référence au prédécesseur Sari Meriem Algorithme A* 1ére Année Master GL
  • 17. Exemple 17 S D 10 + 30 10 + 50 10 + 50 20 + 40 20 + 40 20 + 60 20 + 60 Sommet déjà visité Sommet à explorer G + H Coût depuis la source Coût vers la destination Référence au prédécesseur Sari Meriem Algorithme A* 1ére Année Master GL
  • 18. Exemple 18 S D 10 + 30 10 + 50 20 + 40 20 + 40 20 + 60 30 + 50 Sommet déjà visité Sommet à explorer G + H Coût depuis la source Coût vers la destination Référence au prédécesseur Sari Meriem Algorithme A* 1ére Année Master GL
  • 19. Exemple 19 S D 10 + 30 10 + 50 10 + 50 20 + 40 20 + 40 20 + 60 20 + 60 30 + 50 30 + 30 Sommet déjà visité Sommet à explorer G + H Coût depuis la source Coût vers la destination Référence au prédécesseur Sari Meriem Algorithme A* 1ére Année Master GL
  • 20. Exemple 20 S D 10 + 30 10 + 50 10 + 50 20 + 40 20 + 40 20 + 60 20 + 60 30 + 50 30 + 30 40 + 20 Sommet déjà visité Sommet à explorer G + H Coût depuis la source Coût vers la destination Référence au prédécesseur Sari Meriem Algorithme A* 1ére Année Master GL
  • 21. Exemple 21 S D 10 + 30 10 + 50 20 + 40 20 + 60 30 + 30 40 + 20 50 + 10 50 + 10 Sommet déjà visité Sommet à explorer G + H Coût depuis la source Coût vers la destination Référence au prédécesseur Sari Meriem Algorithme A* 1ére Année Master GL
  • 22. Exemple 22 S 10 + 30 10 + 50 20 + 40 20 + 40 20 + 60 30 + 50 30 + 30 40 + 20 50 + 10 50 + 10 60 + 20 60 + 0 Sommet déjà visité Sommet à explorer G + H Coût depuis la source Coût vers la destination Référence au prédécesseur Sari Meriem Algorithme A* 1ére Année Master GL
  • 23. Exemple 23 S D Sari Meriem Algorithme A* 1ére Année Master GL
  • 24. Implémentation du TP 24  L'implémentation proposée se base sur 4 classes :  Astar: une classe fournissant l'algorithme de calcul.  Node: une classe représentant un noeud du parcours .  NodeFactory: une classe abstraite permettant de créer les noeuds, dans laquelle il faut implémenter les méthodes de calcul de G et H.  SuccessorComputer: une classe abstraite fournissant les successeurs d'un point particulier.  MainTest: une classe fournissant un cas de test concret sur une chaine de caractères ou " " représente un chemin exploitable et " | " représente un chemin interdit. Sari Meriem Algorithme A* 1ére Année Master GL
  • 25. Implémentation du TP 25Sari Meriem Algorithme A* 1ére Année Master GL
  • 26. Conclusion 26  L’algorithme A* ne donne pas toujours la meilleure solution mais il en donne une bonne solution.  On pourrait comparer ses performances avec celles de l'algorithme de Dijkstra.  Dijkstra donne la meilleure solution, mais A* est plus rapide. Sari Meriem Algorithme A* 1ére Année Master GL