🎉 从330转为WashU帮助手册啦!

CSE442
模块
Cse442t L5

Lecture 5

Proving that there are one-way functions relies on assumptions.

Factoring Assumption: a,ε(n)\forall a, \exist \varepsilon (n), let p,qprime,p,q<2np,q\in prime,p,q<2^n

P[pΠn;qΠn;N=pq:a(N){p,q}]<ε(n)P[p\gets \Pi_n;q\gets \Pi_n;N=p\cdot q:a(N)\in \{p,q\}]<\varepsilon(n)

Evidence: To this point, best known procedure to always factor has run time O(2nlog(n))O(2^{\sqrt{n}\sqrt{log(n)}})

Distribution of prime numbers:

  • We have infinitely many prime
  • Prime Number Theorem π(n)nln(n)\pi(n)\approx\frac{n}{\ln(n)}, that means, 1lnn\frac{1}{\ln n} of all integers are prime.

We want to (guaranteed to) find prime:

π(n)>2n2n\pi(n)>\frac{2^n}{2n}

e.g.

P[x{0,1}n:xprime]2n2n2n=12nP[x\gets \{0,1\}^n:x\in prime]\geq {\frac{2^n}{2n}\over 2^n}=\frac{1}{2n}

Theorem:

fmult:{0,1}2n{0,1}2n,fmult(x1,x2)=x1x2f_{mult}:\{0,1\}^{2n}\to \{0,1\}^{2n},f_{mult}(x_1,x_2)=x_1\cdot x_2

Idea: There are enough pairs of primes to make this difficult.

Reminder: Weak on-way if easy to compute and p(n)\exist p(n), P[a inverts=success]<11p(n)P[a\ inverts=success]<1-\frac{1}{p(n)} P[failure]>1p(n)P[failure]>\frac{1}{p(n)} high enough

Prove one-way function (under assumptions)

To prove ff is on-way (under assumption)

  1. Show p.p.t\exists p.p.t solves f(x),xf(x),\forall x.
  2. Proof by contradiction.
    • For weak: Provide p(n)p(n) that we know works.
      • Assume a\exists a such that P[a inverts]>11p(n)P[a\ inverts]>1-\frac{1}{p(n)}
    • For strong: Provide p(n)p(n) that we know works.
      • Assume a\exists a such that P[a inverts]>1p(n)P[a\ inverts]>\frac{1}{p(n)}

Construct p.p.t B which uses aa to solve a problem, which contradicts assumption or known fact.

Back to Theorem:

We will show that p(n)=8n2p(n)=8n^2 works.

We claim a\forall a,

P[(x1,x2){0,1}2n;y=fmult(x1,x2):f(a(y))=y]<118n2P[(x_1,x_2)\gets \{0,1\}^{2n};y=f_{mult}(x_1,x_2):f(a(y))=y]<1-\frac{1}{8n^2}

For the sake of contradiction, suppose

a such thatP[success]>118n2\exists a \textup{ such that} P[success]>1-\frac{1}{8n^2}

We will use this aa to design p.p.t BB which can factor 2 random primes with non-negligible prob.

def A(y):
    # the adversary algorithm
    # expecting N to be product of random integer, don't need to be prime
 
def is_prime(x):
    # test if x is a prime
 
def gen(n):
    # generate number up to n bits
 
def B(y):
    # N is the input cipher
    x1,x2=gen(n),gen(n)
    p=x1*x2
    if is_prime(x1) and is_prime(x2):
        return A(p)
    return A(y)

How often does B succeed/fail?

B fails to factor N=pq˙N=p\dot q, if:

  • xx and yy are not both prime
    • Pe=1P(xprime)P(yprime)1(12n)2=114n2P_e=1-P(x\in prime)P(y\in prime)\leq 1-(\frac{1}{2n})^2=1-\frac{1}{4n^2}
  • if aa fails to factor
    • Pf<18n2P_f<\frac{1}{8n^2}

So

P[B fails]P[EF]P[E]+P[F](114n2+18n2)=118n2P[B\ fails]\leq P[E\cup F]\leq P[E]+P[F]\leq (1-\frac{1}{4n^2}+\frac{1}{8n^2})=1-\frac{1}{8n^2}

So

P[B succeed]18n2 (non negligible)P[B\ succeed]\geq \frac{1}{8n^2}\ (non\ negligible)

This contradicting factoring assumption. Therefore, our assumption that aa exists was wrong.

Therefore a\forall a, P[(x1,x2){0,1}2n;y=fmult(x1,x2):f(a(y))=y]<118n2P[(x_1,x_2)\gets \{0,1\}^{2n};y=f_{mult}(x_1,x_2):f(a(y))=y]<1-\frac{1}{8n^2} is wrong.