En logique mathématique, l'interprétation de Brouwer-Heyting-Kolmogorov, ou interprétation BHK, de la logique intuitionniste a été proposée par L. E. J. Brouwer, Arend Heyting et indépendamment par Andreï Kolmogorov. Elle est aussi parfois appelée « interprétation par réalisabilité », pour son lien avec la théorie de la réalisabilité de Stephen Kleene.
L'interprétation définit exactement ce qui est attendu d'une preuve d'une formule logique. Elle est spécifiée par induction sur la structure d'une formule donnée:
L'interprétation d'une formule élémentaire est supposée donnée par le contexte. Par exemple dans le contexte de l'arithmétique, une preuve de la formule s=t est le calcul réduisant les deux termes à un nombre identique.
Kolmogorov a suivi la même idée, mais en formulant son interprétation en termes de problème et de solutions. Affirmer la vérité d'une formule est affirmer connaître une solution du problème posé par cette formule. Par exemple est dans cette formulation le problème de réduire la résolution de P à la résolution de Q; le résoudre nécessite de trouver une méthode (ou un algorithme) permettant de trouver une solution au problème Q à partir d'une solution du problème P. C'est une démarche analogue à la réduction de la théorie de la complexité des algorithmes.
La fonction identité est une preuve de la formule , quel que soit P.
Le principe de non-contradiction s'étend en :
Une preuve de est donc une fonction f qui transforme une paire <a,b> – où a est une preuve de P, et b est une fonction qui transforme une preuve de P en une preuve de – en une preuve de . La fonction remplit ce contrat, et constitue donc une preuve de la loi de non contradiction quelle que soit la formule P.
Ce n'est pas le cas pour le principe du tiers exclu formulée , qui ne peut pas se prouver dans le cas général. Selon l'interprétation, une preuve de est une paire <a, b> où a est 0 et b est une preuve de P, ou où a est 1 et b est une preuve de . Par conséquent si ni P ni ne sont prouvables, alors ne le sera pas non plus.
Il n'est pas possible pour un système formel « suffisamment puissant », d'avoir un opérateur de négation tel qu'il y ait une preuve de à chaque fois qu'il n'existe pas de preuve de ; voir le théorème d'incomplétude de Gödel. L'interprétation BHK en tient compte et définit par entraîne l'absurdité, notée . Une preuve de est ainsi une fonction qui transforme une preuve de en une preuve de l'absurdité.
Supposons une absurdité arithmétique comme 0 = 1, et procédons par récurrence : 0 = 0 par l'axiome d'égalité. Si 0 était égal à un nombre naturel n, alors 1 serait égal à n+1, (par l'axiome de Peano, : Sm = Sn si et seulement si m = n), mais comme 0=1, 0 serait aussi égal à n + 1. Par récurrence, 0 est égal à tous les nombres, et par conséquent n'importe quelle paire de nombre deviennent égaux.
Par conséquent il existe une manière de passer d'une preuve de 0=1 à une preuve de n'importe quelle égalité arithmétique simple, et donc une preuve de n'importe quelle proposition arithmétique complexe. De plus, il n'a pas été nécessaire de prendre en compte l'axiome de Peano statuant que 0 n'est le successeur d'aucun nombre naturel. On peut donc choisir 0=1 comme formule dans l'arithmétique de Heyting - l'axiome de Peano s'exprimant alors 0 = Sn → 0 = S0. Cette utilisation de la formule 0 = 1 est compatible avec le principe d'explosion.
L'interprétation BHK dépend de la définition que l'on choisit pour la fonction qui transforme une preuve en une autre preuve, ou un élément d'un domaine en une preuve. Il en découle plusieurs variantes du constructivisme qui divergent sur ce point.
La théorie de la réalisabilité de Kleene identifie ces fonctions comme les fonctions calculables. Elle permet de donner une interprétation à l'arithmétique de Heyting, dans laquelle le domaine de quantification est l'ensemble des entiers naturels et les propositions élémentaires sont de la forme . Une preuve de est simplement l'algorithme trivial qui vérifie si x et y s'évaluent au même nombre, dans le cas contraire il n'y a pas de preuve. Les autres preuves sont construites par induction sur ces algorithmes triviaux pour construire des algorithmes plus complexes.
Si on choisit le lambda calcul comme définition pour les fonctions, alors l'interprétation BHK décrit la correspondance de Curry-Howard entre la déduction naturelle et les fonctions.