Implement `compute_extended_matrix`

This commit is contained in:
Hsiao-Wei Wang 2024-02-02 02:24:07 +08:00
parent c47d5f3578
commit 91dbbb365c
No known key found for this signature in database
GPG Key ID: AE3D6B174F971DE4
2 changed files with 39 additions and 8 deletions

View File

@ -17,7 +17,7 @@
- [`DataColumnSidecar`](#datacolumnsidecar) - [`DataColumnSidecar`](#datacolumnsidecar)
- [Helper functions](#helper-functions) - [Helper functions](#helper-functions)
- [`get_custody_columns`](#get_custody_columns) - [`get_custody_columns`](#get_custody_columns)
- [`compute_extended_data`](#compute_extended_data) - [`compute_extended_matrix`](#compute_extended_matrix)
- [`recover_matrix`](#recover_matrix) - [`recover_matrix`](#recover_matrix)
- [`get_data_column_sidecars`](#get_data_column_sidecars) - [`get_data_column_sidecars`](#get_data_column_sidecars)
- [Custody](#custody) - [Custody](#custody)
@ -112,13 +112,20 @@ def get_custody_columns(node_id: NodeID, custody_subnet_count: uint64) -> Sequen
] ]
``` ```
#### `compute_extended_data` #### `compute_extended_matrix`
```python ```python
def compute_extended_data(data: Sequence[BLSFieldElement]) -> Sequence[BLSFieldElement]: def compute_extended_matrix(blobs: Sequence[Blob]) -> ExtendedMatrix:
# TODO """
# pylint: disable=unused-argument Return the full ``ExtendedMatrix``.
...
This helper demonstrates the relationship between blobs and ``ExtendedMatrix``.
The data structure for storing cells is implementation-dependent.
"""
extended_matrix = []
for blob in blobs:
extended_matrix.extend(compute_cells(blob))
return ExtendedMatrix(extended_matrix)
``` ```
#### `recover_matrix` #### `recover_matrix`
@ -128,7 +135,7 @@ def recover_matrix(cells_dict: Dict[Tuple[BlobIndex, CellID], Cell], blob_count:
""" """
Return the recovered ``ExtendedMatrix``. Return the recovered ``ExtendedMatrix``.
This helper demonstrate how to apply ``recover_polynomial``. This helper demonstrates how to apply ``recover_polynomial``.
The data structure for storing cells is implementation-dependent. The data structure for storing cells is implementation-dependent.
""" """
extended_matrix = [] extended_matrix = []
@ -208,7 +215,7 @@ A node runs a background peer discovery process, maintaining at least `TARGET_NU
## Extended data ## Extended data
In this construction, we extend the blobs using a one-dimensional erasure coding extension. The matrix comprises maximum `MAX_BLOBS_PER_BLOCK` rows and fixed `NUMBER_OF_COLUMNS` columns, with each row containing a `Blob` and its corresponding extension. In this construction, we extend the blobs using a one-dimensional erasure coding extension. The matrix comprises maximum `MAX_BLOBS_PER_BLOCK` rows and fixed `NUMBER_OF_COLUMNS` columns, with each row containing a `Blob` and its corresponding extension. `compute_extended_matrix` demonstrates the relationship between blobs and custom type `ExtendedMatrix`.
## Column gossip ## Column gossip

View File

@ -9,6 +9,30 @@ from eth2spec.test.helpers.sharding import (
) )
@with_eip7594_and_later
@spec_test
@single_phase
def test_compute_extended_matrix(spec):
rng = random.Random(5566)
blob_count = 2
input_blobs = [get_sample_blob(spec, rng=rng) for _ in range(blob_count)]
extended_matrix = spec.compute_extended_matrix(input_blobs)
assert len(extended_matrix) == spec.CELLS_PER_BLOB * blob_count
rows = [extended_matrix[i:(i + spec.CELLS_PER_BLOB)] for i in range(0, len(extended_matrix), spec.CELLS_PER_BLOB)]
assert len(rows) == blob_count
assert len(rows[0]) == spec.CELLS_PER_BLOB
for blob_index, row in enumerate(rows):
extended_blob = []
for cell in row:
extended_blob.extend(cell)
blob_part = extended_blob[0:len(extended_blob) // 2]
blob = b''.join([spec.bls_field_to_bytes(x) for x in blob_part])
assert blob == input_blobs[blob_index]
@with_eip7594_and_later @with_eip7594_and_later
@spec_test @spec_test
@single_phase @single_phase