mirror of
https://github.com/logos-co/nomos-specs.git
synced 2025-01-11 08:05:44 +00:00
cf899d2384
* Implement generator polynomial and rs encoding * Implement encode/decode+test using fft. Non-working * Use lagrange for interpolation * Remove fft, use evaluations instead * Move and rename kzg and rs test modules * Update docs * Added columns property to chunks matrix Added test for columns * Added chunkify and test * Added compute row commitments Added row commitments size test * Fix poly from evaluations method * Implement encode rows and test * Update encode row test * Implement compute row proofs (not working on extended data) * Use same polynomials for commitment and proof creation after extend * Fix polynomial from/to evaluations * Use chunks for verification * Refactor interpolate * Implement chunks matrix transposed method * Added compute column kzg commitments * Use square size data for encoder tests * Add column type to columns method * Added compute columns aggregated commitment Added aggregated commitment test Fixed and expanded encode test * Use sha3 for hashing
67 lines
2.7 KiB
Python
67 lines
2.7 KiB
Python
from itertools import chain, batched
|
|
from random import randrange
|
|
from unittest import TestCase
|
|
|
|
from eth2spec.deneb.mainnet import BLS_MODULUS, bytes_to_bls_field, BLSFieldElement
|
|
|
|
from da.kzg_rs import kzg
|
|
from da.kzg_rs.common import BYTES_PER_FIELD_ELEMENT, GLOBAL_PARAMETERS, ROOTS_OF_UNITY, GLOBAL_PARAMETERS_G2
|
|
from da.kzg_rs.trusted_setup import verify_setup
|
|
|
|
|
|
class TestKZG(TestCase):
|
|
|
|
@staticmethod
|
|
def rand_bytes(n_chunks=1024):
|
|
return bytes(
|
|
chain.from_iterable(
|
|
int.to_bytes(randrange(BLS_MODULUS), length=BYTES_PER_FIELD_ELEMENT)
|
|
for _ in range(n_chunks)
|
|
)
|
|
)
|
|
|
|
def test_kzg_setup(self):
|
|
self.assertTrue(verify_setup((GLOBAL_PARAMETERS, GLOBAL_PARAMETERS_G2)))
|
|
|
|
def test_poly_forms(self):
|
|
n_chunks = 16
|
|
rand_bytes = self.rand_bytes(n_chunks)
|
|
eval_form = [int(bytes_to_bls_field(b)) for b in batched(rand_bytes, int(BYTES_PER_FIELD_ELEMENT))]
|
|
poly = kzg.bytes_to_polynomial(rand_bytes)
|
|
self.assertEqual(poly.evaluation_form(), eval_form)
|
|
for i, chunk in enumerate(eval_form):
|
|
self.assertEqual(poly.eval(ROOTS_OF_UNITY[i]), chunk)
|
|
for i in range(n_chunks):
|
|
self.assertEqual(poly.evaluation_form()[i], poly.eval(int(ROOTS_OF_UNITY[i])))
|
|
|
|
def test_commitment(self):
|
|
rand_bytes = self.rand_bytes(32)
|
|
_, commit = kzg.bytes_to_commitment(rand_bytes, GLOBAL_PARAMETERS)
|
|
self.assertEqual(len(commit), 48)
|
|
|
|
def test_proof(self):
|
|
rand_bytes = self.rand_bytes(2)
|
|
poly = kzg.bytes_to_polynomial(rand_bytes)
|
|
proof = kzg.generate_element_proof(0, poly, GLOBAL_PARAMETERS, ROOTS_OF_UNITY)
|
|
self.assertEqual(len(proof), 48)
|
|
|
|
def test_verify(self):
|
|
n_chunks = 32
|
|
rand_bytes = self.rand_bytes(n_chunks)
|
|
_, commit = kzg.bytes_to_commitment(rand_bytes, GLOBAL_PARAMETERS)
|
|
poly = kzg.bytes_to_polynomial(rand_bytes)
|
|
for i, chunk in enumerate(batched(rand_bytes, BYTES_PER_FIELD_ELEMENT)):
|
|
chunk = bytes(chunk)
|
|
proof = kzg.generate_element_proof(i, poly, GLOBAL_PARAMETERS, ROOTS_OF_UNITY)
|
|
self.assertEqual(len(proof), 48)
|
|
self.assertEqual(poly.eval(int(ROOTS_OF_UNITY[i])), bytes_to_bls_field(chunk))
|
|
self.assertTrue(kzg.verify_element_proof(
|
|
bytes_to_bls_field(chunk), commit, proof, i, ROOTS_OF_UNITY
|
|
)
|
|
)
|
|
proof = kzg.generate_element_proof(0, poly, GLOBAL_PARAMETERS, ROOTS_OF_UNITY)
|
|
for n in range(1, n_chunks):
|
|
self.assertFalse(kzg.verify_element_proof(
|
|
BLSFieldElement(0), commit, proof, n, ROOTS_OF_UNITY
|
|
)
|
|
) |