ZKP and MPC 3
Lec02 Zero-Knowledge Proof under Composition
2.3 Sequential Composition
: should be viewed as a black box , input , output response
If guess wrong at
, we can rewind to the time when it receives , using the same input , randomness , first messages
Def [ Zero-Knowledge Proof with Auxiliary Input ] :
is an interactive zero-knowledge proof with auxiliary input for if is an efficient algorithm ( poly-time )Completeness :
Soundness with error
:Zero-Knowledge :
in P.P.T. , expected poly-time algorithm , ,
is indeed redundant since is not computationally boundedAlternating Form of Zero-Knowledge :
Lemma [ Composition Lemma ] :
: zero-knowledge proof with auxiliary input for , is a polynomial of : An IP runs timesClaim :
are still zero-knowledge .Proof of Composition Lemma
Only Proof for perfect zero-knowledge
Using Alternating Form of Zero-Knowledge
Construction
inputs , .For
:Construct
: , output state of asNote : for
, are contained in , so we do not need to input them.By zero-knowledge ,
that can simulate the output of . runs to obtain .
invokes with to obtain final output.
Proof of
: Real Execution :- Run
and until the last phase . - Record the state of
as . - Invoke
to obtain . - Invoke
with to obtain final output .
Proof of
:Fix state
. For , its distribution is the same as- Run
to obtain - Run
with to obtain final output
By zk , given
, .Therefore ,
.- Run
: Change to after the first phases : using , : usingTherefore ,
: The execution of .
Lec03 Commitment Scheme , zk-proof for general NP
3.0 Important
In the next lecture , we re-defined commitment in a more simple way .
3.1 Commitment
Intuition :
Binding : make some choice , then won't change it . (change will be rejected)
Hiding : like "safe" , until open it , not knowing the choice . (uniform distribution)
Def [ Commitment ] : Three P.P.T. algorithms
( public parameter )
Satisfying properties :
- Hiding :
, the following distributions are identical/statistically indistinguishable/computationally indistinguishable
Binding :
, ,Perfect Binding :
Computationally Binding : in P.P.T.
Open Commitment ( implement
)One general way : let
Verify checks whether
There exists faster Verify for some specific problems.
Note : hiding and binding are incompatible
hiding :
can from differentbinding :
cannot from different
3.2 Perfect Binding & Computationally Hiding Commitment
DDH assumption
, , , The following distributions are computationally indistinguishableConstruction
Suppose that
Perfect Binding
For
, unique , s.t. .Therefore ,
, which is uniquely determinedComputationally Hiding [Prove by Hybrid Proof]
We want to prove that
: : : \ :
3.3 Computationally Binding & Perfect Hiding Commitment
Discrete Log Assumption
, . in P.P.T. ,Construction
Suppose that
, and we need to "forget" .Perfect Hiding
, which is the same distribution as , since is random .Computationally Binding
Suppose that we have P.P.T.
that , s.t. Therefore : Therefore : which contradicts with Discrete Log assumptionHow to generate
Generate by Sender ? NO
knows
, then . Sender can choose proper to reconstruct .Generate by Receiver ? YES
knows
not affect hiding
perfect binding + computationally hiding : Sender runs Gen
computationally binding + perfect hiding : Receiver runs Gen
3.4 General NP Problem
NP , NPC
Def [ NP ] :
if poly-time algorithm , is called the proof .Def [ NP-Complete ] :
if , poly-time algorithm , s.t. , and .i.e. all NP problems can be poly-reducible to NP-Complete Problem
Graph Hamiltonicity
Def [ Hamiltonian ] : A graph
is Hamiltonian , if there exists a cycle visiting each node exactly once.Construct zk-proof for Graph Hamiltonicity
Like GI :
Step 1 : send
, whereStep 2 : give a cycle of
to prove its HamiltonianTraditional ways : we cannot realize both
Protocol with commitment
Commitment of a graph
: ,Prover Verifier ,Commit :--- --><-- ---If --- -->Checks If ---cycle for , in cycle--->Checks cycle and edges existence