Algorithme de Markov
En informatique théorique, un algorithme de Markov est un système de réécriture de chaîne qui utilise des règles de grammaire pour agir sur une chaîne de symboles. Il a été démontré que les algorithmes de Markov étaient Turing-complets, ce qui signifie qu'ils constituent un modèle de calcul suffisamment général. Les algorithmes de Markov ont été nommées d'après le mathématicien Andreï Markov.
Refal est un langage de programmation basé sur les algorithmes de Markov.
Algorithme
modifierLes règles sont une suite de couples de chaînes, habituellement présentées sous la forme schéma → remplacement. Certaines règles peuvent en outre être qualifiées de terminales.
Étant donné une chaîne d'entrée :
- Vérifier les règles dans l'ordre, du haut vers le bas, jusqu'à en trouver une dont le schéma peut être trouvé dans la chaîne d'entrée (ainsi, si plusieurs schémas conviennent, seule la première règle rencontrée sera prise en compte).
- Si une telle règle n'est pas trouvée, l'algorithme s'arrête.
- Sinon, l'occurrence la plus à gauche du schéma dans la chaîne d'entrée est remplacée par la chaîne de remplacement donnée par la règle.
- Si la règle est terminale, l'algorithme s'arrête.
- Recommencer à la première étape.
Exemple
modifierLes règles suivantes réécrivent un nombre binaire en version unaire ; par exemple, 101 sera réécrit comme une chaîne de 5 barres consécutives.
Règles
modifier- "|0" → "0||"
- "1" → "0|"
- "0" → ""
Chaîne d'entrée
modifier"101"
Exécution
modifierL'application de l'algorithme donne successivement les chaînes :
- "0|01"
- "00||1"
- "00||0|"
- "00|0|||"
- "000|||||"
- "00|||||"
- "0|||||"
- "|||||"
Références
modifier- Caracciolo di Forino, A. String processing languages and generalized Markov algorithms. In Symbol manipulation languages and techniques, D. G. Bobrow (Ed.), North-Holland Publ. Co., Amsterdam, The Netherlands, 1968, pp. 191–206.
- Andreï Markov 1960. The Theory of Algorithms. American Mathematical Society Translations, series 2, 15, 1-14.
Liens externes
modifier- « Online Markov algorithm interpreter »(Archive.org • Wikiwix • Archive.is • Google • Que faire ?)
- Markov algorithm interpreter
- Markov algorithm interpreter
- Joran Bigalet, « Algorithmes de Markov » (consulté le )
- Vincent Laviron, « Algorithmes de Markov » (consulté le )
- (en) Cet article est partiellement ou en totalité issu de l’article de Wikipédia en anglais intitulé « Markov algorithm » (voir la liste des auteurs).