RP (complexité)

En informatique théorique, plus précisément en théorie de la complexité, la classe RP (Randomized Polynomial time) est la classe de complexité des problèmes de décision pour lesquels il existe une machine de Turing probabiliste, en temps polynomial, qui refuse toutes les instances négatives et accepte les instances positives avec une probabilité supérieure à 1/2.

Inclusions de classes de complexité probabilistes.

Définition

Une première définition

La classe RP est l'ensemble des problèmes, ou de façon équivalente des langages, pour lesquels il existe une machine de Turing probabiliste en temps polynomial qui satisfait les conditions d'acceptation suivantes :

  • Si le mot n'est pas dans le langage, la machine le rejette.
  • Si le mot est dans le langage, la machine l'accepte avec une probabilité supérieure à 1/2.

On dit que la machine « ne se trompe que d'un côté »[réf. nécessaire].

Définition formelle

Pour un polynôme en la taille de l'entrée , on définit , l'ensemble des langages pour lesquels il existe une machine de Turing probabiliste , en temps , telle que pour tout mot  :

  • .
  • .

Alors on peut définir RP comme : .

Le rôle de la constante

La constante 1/2 est en fait arbitraire, on peut choisir n'importe quel nombre (constant) entre 0 et 1 (exclus)[1].

L'idée est qu'en faisant le calcul indépendamment un nombre polynomial de fois , on peut faire chuter la probabilité d'erreur à dans le cas (tout en gardant une réponse sûre dans le cas ).

La classe co-RP

La classe co-RP est l'ensemble des langages, pour lesquels il existe une machine de Turing probabiliste en temps polynomial qui satisfait les conditions d'acceptation suivantes :

  • Si le mot est dans le langage, la machine l'accepte.
  • Si le mot n'est pas dans le langage, la machine le rejette avec une probabilité supérieure à 1/2.

(Même remarque sur la constante)

Relations avec les autres classes

Avec les classes "classiques"

On a la relation suivante avec les classes P et NP :

Remarquons que cette classe n'est plus intéressante si P=NP.

Valiant et Vazirani ont démontré[2] que où USAT est le problème SAT, où on promet que la formule booléenne en entrée admet au plus qu'une solution. L'oracle à USAT fonctionne comme suit : il répond positivement sur des formules qui ont exactement une unique solution, il répond négativement sur des formules sans solution, et il répond de manière arbitraire sur les autres formules.

Avec les autres classes probabilistes

Les inclusions suivantes mettent en jeu les classes ZPP et BPP.

Cela vient directement des définitions : ZPP est l'intersection de RP et co-RP et BPP a des conditions d'acceptation moins contraignantes (erreur « des deux côtés »).

Problèmes dans RP et co-RP

Les problèmes de RP sont des problèmes pour lesquels il existe un algorithme probabiliste qui satisfait les conditions décrites plus haut.

Par exemple le problème de savoir si un entier est premier est dans co-RP grâce au test de primalité de Miller-Rabin. En fait, ce problème est même dans P, grâce au test de primalité AKS.

Un problème de co-RP qui n'est pas connu comme étant dans P est le problème polynomial identity testing, qui consiste, étant donné un polynôme multivarié sous une forme quelconque, à décider s'il est identiquement nul ou non. Grâce au lemme de Schwartz-Zippel, on peut reconnaître les polynômes nuls avec une bonne probabilité en les évaluant en un petit nombre de points.

Histoire

Cette classe a été introduite par J. Gill[3] dans l'article Computational complexity of probabilistic Turing machines (Gill 1977).

Bibliographie

  • (en) Sanjeev Arora et Boaz Barak, Computational Complexity : A Modern Approach, Cambridge University Press, (ISBN 0-521-42426-7), chap. 7
  • (en) John Gill, « Computational complexity of probabilistic Turing machines », SIAM Journal on Computing, vol. 6, no 4, , p. 675-695

Lien externe

(en) La classe RP sur le Complexity Zoo

Notes et références

  1. (en) Sanjeev Arora et Boaz Barak, Computational Complexity : A Modern Approach, Cambridge University Press, (ISBN 0-521-42426-7), chap. 7
  2. L. G. Valiant et V. V. Vazirani, « NP is as easy as detecting unique solutions », Theoretical Computer Science, vol. 47, , p. 85–93 (ISSN 0304-3975, DOI 10.1016/0304-3975(86)90135-0, lire en ligne, consulté le )
  3. Complexity Zoo
  • Portail de l'informatique théorique
Cet article est issu de Wikipedia. Le texte est sous licence Creative Commons - Attribution - Partage dans les Mêmes. Des conditions supplémentaires peuvent s'appliquer aux fichiers multimédias.