Let ω∈F be a n=2k primitive root of unity forming the
domain D=(ω0,ω1,…,ωn−1) with t(X)=Xn−1 the
vanishing polynomial over this domain. Let ng,na,ne be positive integers with na,ne<n and ng≥4.
We present an interactive argument Halo=(Setup,P,V) for
the relation
R={((g(X,C0,…,Cna−1,a0(X),…,ana−1(X,C0,…,Cna−1,a0(X),…,ana−2(X)))); (a0(X),a1(X,C0,a0(X)),…,ana−1(X,C0,…,Cna−1,a0(X),…,ana−2(X)))): g(ωi,⋯)=0,,,,∀i∈[0,2k)}
where a0,a1,…,ana−1 are (multivariate) polynomials with degree n−1 in X and g has degree ng(n−1) at most in any indeterminates X,C0,C1,….
Setup(λ) returns pp=(G,F,G∈Gn,U,W∈G).
For all i∈[0,na):
- Let pi be the exhaustive set of integers j (modulo n) such that ai(ωjX,⋯) appears as a term in g(X,⋯).
- Let q be a list of distinct sets of integers containing pi and the set q0=0.
- Let σ(i)=qj when qj=pi.
Let nq≤na denote the size of q, and let ne denote the size of every pi without loss of generality.
In the following protocol, we take it for granted that each polynomial ai(X,⋯) is defined such that ne+1 blinding factors are freshly sampled by the prover and are each present as an evaluation of ai(X,⋯) over the domain D. In all of the following, the verifier’s challenges cannot be zero or an element in D, and some additional limitations are placed on specific challenges as well.
Step | Spec | Impl. | Protocol | Notes |
1 | NA | ? | P and V proceed in the following na rounds of interaction, where in round j (starting at 0) | |
| | | * P sets aj′(X)=aj(X,c0,c1,…,cj−1,a0(X,⋯),…,aj−1(X,⋯,cj−1)) | |
| | | * P sends a hiding commitment Aj=⟨a′,G⟩+[⋅]W where a′ are the coefficients of the univariate polynomial aj′(X) and ⋅ is some random, independently sampled blinding factor elided for exposition. (This elision notation is used throughout this protocol description to simplify exposition.) | We denote the blinding ⋅ used in round j as aj∗ |
| | | * V responds with a challenge cj. | |
2 | NA | ? | P sets g′(X)=g(X,c0,c1,…,cna−1,⋯). | |
3 | NA | link | P sends a commitment R=⟨r,G⟩+[⋅]W where r∈Fn are the coefficients of a randomly sampled univariate polynomial r(X) of degree n−1. | We denote the blinding ⋅ used as r∗ |
4 | step_4 | link | P computes univariate polynomial h(X)=t(X)g′(X) of degree ng(n−1)−n. | |
5 | step_5 | link | P computes at most n−1 degree polynomials h0(X),h1(X),…,hng−2(X) such that h(X)=i=0∑ng−2Xnihi(X). | |
6 | step_6 | link | P sends commitments Hi=⟨hi,G⟩+[⋅]W for all i where hi denotes the vector of coefficients for hi(X). | We denote the blinding ⋅ used in round j as hj∗ |
7 | step_7 | link(?) | V responds with challenge x and computes H′=i=0∑ng−2[xni]Hi. | |
8 | step_8 | link | P sets h′(X)=i=0∑ng−2xnihi(X). | P sets h′∗=i=0∑ng−2xnihi∗. |
9 | step_9 | link | P sends r=r(x) and for all i∈[0,na) sends ai such that (ai)j=ai′(ω(pi)jx) for all j∈[0,ne−1]. | |
10 | step_10 | link(?) | For all i∈[0,na) P and V set si(X) to be the lowest degree univariate polynomial defined such that si(ω(pi)jx)=(ai)j for all j∈[0,ne−1). | |
11 | step_11 | link | V responds with challenges x1,x2 and initializes Q0,Q1,…,Qnq−1=O. | |
| | | * Starting at i=0 and ending at na−1 V sets Qσ(i):=[x1]Qσ(i)+Ai. | |
| | | * V finally sets Q0:=[x12]Q0+[x1]H′+R. | |
12 | step_12 | link | P initializes q0(X),q1(X),…,qnq−1(X)=0. | P initializes q0∗,q1∗,…,qnq−1∗=0. |
| | | * Starting at i=0 and ending at na−1 P sets qσ(i):=x1qσ(i)+a′(X). | Starting at i=0 and ending at na−1 P sets qσ(i)∗:=x1qσ(i)∗+ai∗. |
| | | * P finally sets q0(X):=x12q0(X)+x1h′(X)+r(X). | P finally sets q0∗:=x12q0∗+x1h′∗+r∗ |
13 | step_13 | ? | P and V initialize r0(X),r1(X),…,rnq−1(X)=0. | |
| | | * Starting at i=0 and ending at na−1 P and V set rσ(i)(X):=x1rσ(i)(X)+si(X). | |
| | | * Finally P and V set r0:=x12r0+x1h+r and where h is computed by V as t(x)g′(x) using the values r,a provided by P. | |
14 | step_14 | link | P sends Q′=⟨q′,G⟩+[⋅]W where q′ defines the coefficients of the polynomial q′(X)=i=0∑nq−1x2nq−1−i⎝⎜⎛j=0∏ne−1(X−ω(qi)jx)qi(X)−ri(X)⎠⎟⎞ | The blinding ⋅ used here is denoted as q′∗. |
15 | step_15 | link | V responds with challenge x3. | |
16 | step_16 | link | P sends u∈Fnq such that ui=qi(x3) for all i∈[0,nq). | |
17 | step_17 | link | V responds with challenge x4. | |
18 | step_18 | link | V sets P=[x4nq]Q’+i=0∑nq−1[x4nq−1−i]Qi and v=x4nq⋅i=0∑nq−1(x2nq−1−i(∏ j=0ne−1(x3−ω(qi)jx)ui−ri(x3)))+∑ i=0nq−1x4nq−1−iui | |
19 | step_19 | link | P sets p(X)=x4nq⋅q’(X)+i=0∑nq−1x4nq−1−i⋅qi(X). | P sets p∗=x4nq⋅q’∗+i=0∑nq−1x4nq−1−i⋅qi∗. |
20 | step_20 | link | P samples a random polynomial s(X) of degree n−1 with a root at x3 and sends a commitment S=⟨s,G⟩+[⋅]W where s defines the coefficients of s(X). | The blinding ⋅ used here is denoted as s∗. |
21 | step_21 | link | V responds with challenges ξ,z. | |
22 | step_22 | link | V sets P′=P−[v]G0+[ξ]S. | |
23 | step_23 | link | P sets p′(X)=p(X)−p(x3)+ξs(X) (where p(x3) should correspond with the verifier’s computed value v). | P sets p′∗=s∗⋅ξ+p∗ |
24 | step_24 | link | Initialize p′ as the coefficients of p′(X) and G′=G and b=(x30,x31,…,x3n−1). P and V will interact in the following k rounds, where in the jth round starting in round j=0 and ending in round j=k−1 : | |
| | | * P sends Lj=⟨p′hi,G′lo⟩+[z⟨p′hi,blo⟩]U+[⋅]W and Rj=⟨p′lo,G′hi⟩+[z⟨p′lo,bhi⟩]U+[⋅]W. | The blinding ⋅ used for Lj is denoted Lj∗ and the blinding used for Rj is denoted Rj∗ |
| | | * V responds with challenge uj chosen such that 1+uk−1−jx32j is nonzero. | |
| | | * P and V set G′:=G′lo+ujG′hi and b:=blo+ujbhi. | |
| | | * P sets p′:=p′lo+uj−1p′hi. | |
25 | step_25 | link | P sends c=p′0 and synthetic blinding factor f computed from the elided blinding factors. | P sets f=p′∗+∑j=0k−1Lj∗⋅uj−1+rj∗⋅uj |
26 | step_26 | link | V accepts only if ∑j=0k−1[uj−1]Lj+P′+∑j=0k−1[uj]Rj=[c]G′0+[cb0z]U+[f]W. | |