Nous sommes intéressés par les approximations additives de # 3SAT. c'est-à-dire, étant donné un 3CNF sur variables, comptez le nombre d'affectations satisfaisantes (appelez ceci ) jusqu'à l'erreur additive .n a kϕnak
Voici quelques résultats de base pour cela:
Cas 1: k=2n−1−poly(n)
Ici, il existe un algorithme de temps poly déterministe: Soit . Maintenant, évaluez sur entrées arbitraires (par exemple, les premières entrées lexicographiquement ). Supposons que de ces entrées satisfasse . On connaît alors car il y a au moins assignations satisfaisantes et car il y a au moins assignations insatisfaisantes. La longueur de cet intervalle est de . Donc, si nous sortons le point milieu cela se trouve dansϕ m m ℓ ϕ a ≥ ℓ ℓ a ≤ 2 n - ( m - ℓ ) m - ℓ 2 n - ( m - ℓ ) - ℓ = 2 k 2 n - 1 - m / 2 + ℓ km=2n−2k=poly(n)ϕmmℓϕa≥ℓℓa≤2n−(m−ℓ)m−ℓ2n−(m−ℓ)−ℓ=2k2n−1−m/2+ℓk de la bonne réponse, au besoin.
Cas 2: k=2n/poly(n)
Ici, nous avons un algorithme poly-temps aléatoire: Évaluer en points aléatoires . Soit et . Nous produisons . Pour que cela ait une erreur au plus nous avons besoin de ce qui équivaut àPar une borne Chernoff , asm X 1 , ⋯ , X m ∈ { 0 , 1 } n α = 1ϕmX1,⋯,Xm∈{0,1}nε=k/2n2n⋅αkk≥| 2nα-a| =2n| α-a/2n| ,| α-a/2n| ≤ε. P[| α-a/α=1m∑mi=1ϕ(Xi)ε=k/2n2n⋅αk
k≥|2nα−a|=2n|α−a/2n|,
|α−a/2n|≤ε.P[|α−a/2n|>ε]≤2−Ω(mε2),
E[ϕ(Xi)]=E[α]=a/2n. Cela implique que, si nous choisissons (et assurons que est une puissance de ), alors avec une probabilité d'au moins , l'erreur est au plus .
m=O(1/ε2)=poly(n)m20.99k
Cas 3: pourk=2cn+o(n)c<1
Dans ce cas, le problème est # P-difficile: nous ferons une réduction de # 3SAT. Prenez un 3CNF sur variables. Choisissez tel que - cela nécessite . Soit sauf que est maintenant sur variables, plutôt que . Si a affectations satisfaisantes, alors a affectations satisfaisantes, car les variables "libres" peuvent prendre n'importe quelle valeur dans une affectation satisfaisante. Supposons maintenant que nous ayons tel queψmn≥mk<2n−m−1n=O(m/(1−c))ϕ=ψϕnmψbϕb⋅2n−mn−ma^|a^−a|≤k - c'est-à-dire est une approximation du nombre d'assignations satisfaisantes de avec l'erreur additive . Alors
Puisque est un entier, cela signifie que nous pouvons déterminer la valeur exacte de partir de . La détermination algorithmique de la valeur exacte de implique la résolution du problème # P-complet # 3SAT. Cela signifie qu'il est # P-difficile de calculer .a^ϕkbb a b a
|b−a^/2n−m|=∣∣∣a−a^2n−m∣∣∣≤k2n−m<1/2.
bba^ba^