-
Notifications
You must be signed in to change notification settings - Fork 44
/
Copy pathtranscript.py
136 lines (114 loc) · 4.02 KB
/
transcript.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
from utils import Scalar
from curve import G1Point
from merlin.merlin_transcript import MerlinTranscript
from py_ecc.secp256k1.secp256k1 import bytes_to_int
from dataclasses import dataclass
@dataclass
class Message1:
# [a(x)]₁ (commitment to left wire polynomial)
a_1: G1Point
# [b(x)]₁ (commitment to right wire polynomial)
b_1: G1Point
# [c(x)]₁ (commitment to output wire polynomial)
c_1: G1Point
@dataclass
class Message2:
# [z(x)]₁ (commitment to permutation polynomial)
z_1: G1Point
@dataclass
class Message3:
# [quot(x)]₁ (commitment to the quotient polynomial t(X))
W_t: G1Point
@dataclass
class Message4:
# Evaluation of a(X) at evaluation challenge ζ
a_eval: Scalar
# Evaluation of b(X) at evaluation challenge ζ
b_eval: Scalar
# Evaluation of c(X) at evaluation challenge ζ
c_eval: Scalar
# Evaluation of QL(X) at evaluation challenge ζ
ql_eval: Scalar
# Evaluation of QR(X) at evaluation challenge ζ
qr_eval: Scalar
# Evaluation of QM(X) at evaluation challenge ζ
qm_eval: Scalar
# Evaluation of QO(X) at evaluation challenge ζ
qo_eval: Scalar
# Evaluation of QC(X) at evaluation challenge ζ
qc_eval: Scalar
# Evaluation of the first permutation polynomial S_σ1(X) at evaluation challenge ζ
s1_eval: Scalar
# Evaluation of the second permutation polynomial S_σ2(X) at evaluation challenge ζ
s2_eval: Scalar
# Evaluation of the second permutation polynomial S_σ3(X) at evaluation challenge ζ
s3_eval: Scalar
# Evaluation of the permutation polynomial z(X) at the evaluation challenge ζ
z_eval: Scalar
# Evaluation of the shifted permutation polynomial z(X) at the shifted evaluation challenge ζω
zw_eval: Scalar
# Evaluation of Quotient Polynomial Quot(X) at evaluation challenge ζ
t_eval: Scalar
@dataclass
class Message5:
# (commitment to the opening proof polynomial)
W_a: G1Point
W_a_quot: G1Point
W_b: G1Point
W_b_quot: G1Point
W_c: G1Point
W_c_quot: G1Point
W_ql: G1Point
W_ql_quot: G1Point
W_qr: G1Point
W_qr_quot: G1Point
W_qm: G1Point
W_qm_quot: G1Point
W_qo: G1Point
W_qo_quot: G1Point
W_qc: G1Point
W_qc_quot: G1Point
W_s1: G1Point
W_s1_quot: G1Point
W_s2: G1Point
W_s2_quot: G1Point
W_s3: G1Point
W_s3_quot: G1Point
W_z: G1Point
W_z_quot: G1Point
W_zw: G1Point
W_zw_quot: G1Point
W_t: G1Point
W_t_quot: G1Point
# https://merlin.cool/
class Transcript(MerlinTranscript):
def append(self, label: bytes, item: bytes) -> None:
self.append_message(label, item)
def append_scalar(self, label: bytes, item: Scalar):
self.append_message(label, item.n.to_bytes(32, "big"))
def append_point(self, label: bytes, item: G1Point):
self.append_message(label, item[0].n.to_bytes(32, "big"))
self.append_message(label, item[1].n.to_bytes(32, "big"))
def get_and_append_challenge(self, label: bytes) -> Scalar:
while True:
challenge_bytes = self.challenge_bytes(label, 255)
f = Scalar(bytes_to_int(challenge_bytes))
if f != Scalar.zero(): # Enforce challenge != 0
self.append(label, challenge_bytes)
return f
def round_1(self, message: Message1) -> tuple[Scalar, Scalar]:
self.append_point(b"a_1", message.a_1)
self.append_point(b"b_1", message.b_1)
self.append_point(b"c_1", message.c_1)
# The first two Fiat-Shamir challenges
beta = self.get_and_append_challenge(b"beta")
gamma = self.get_and_append_challenge(b"gamma")
return beta, gamma
def round_2(self, message: Message2) -> tuple[Scalar, Scalar]:
self.append_point(b"z_1", message.z_1)
alpha = self.get_and_append_challenge(b"alpha")
return alpha
def round_3(self, message: Message3) -> Scalar:
self.append_point(b"W_t", message.W_t)
zeta = self.get_and_append_challenge(b"zeta")
return zeta