workaround: add a new config `MAX_EXTENDED_MATRIX_SIZE` to avoid `class Container(List[c, a*b])`
This commit is contained in:
parent
0e4fc984ef
commit
e46c4c39fb
|
@ -157,6 +157,7 @@ WHISK_PROPOSER_SELECTION_GAP: 2
|
||||||
|
|
||||||
# EIP7594
|
# EIP7594
|
||||||
NUMBER_OF_COLUMNS: 128
|
NUMBER_OF_COLUMNS: 128
|
||||||
|
MAX_EXTENDED_MATRIX_SIZE: 768
|
||||||
DATA_COLUMN_SIDECAR_SUBNET_COUNT: 32
|
DATA_COLUMN_SIDECAR_SUBNET_COUNT: 32
|
||||||
MAX_REQUEST_DATA_COLUMN_SIDECARS: 16384
|
MAX_REQUEST_DATA_COLUMN_SIDECARS: 16384
|
||||||
|
|
||||||
|
|
|
@ -155,6 +155,7 @@ WHISK_PROPOSER_SELECTION_GAP: 1
|
||||||
|
|
||||||
# EIP7594
|
# EIP7594
|
||||||
NUMBER_OF_COLUMNS: 128
|
NUMBER_OF_COLUMNS: 128
|
||||||
|
MAX_EXTENDED_MATRIX_SIZE: 768
|
||||||
DATA_COLUMN_SIDECAR_SUBNET_COUNT: 32
|
DATA_COLUMN_SIDECAR_SUBNET_COUNT: 32
|
||||||
MAX_REQUEST_DATA_COLUMN_SIDECARS: 16384
|
MAX_REQUEST_DATA_COLUMN_SIDECARS: 16384
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,7 @@ from eth2spec.deneb import {preset_name} as deneb
|
||||||
'FIELD_ELEMENTS_PER_CELL': spec_object.preset_vars['FIELD_ELEMENTS_PER_CELL'].value,
|
'FIELD_ELEMENTS_PER_CELL': spec_object.preset_vars['FIELD_ELEMENTS_PER_CELL'].value,
|
||||||
'FIELD_ELEMENTS_PER_EXT_BLOB': spec_object.preset_vars['FIELD_ELEMENTS_PER_EXT_BLOB'].value,
|
'FIELD_ELEMENTS_PER_EXT_BLOB': spec_object.preset_vars['FIELD_ELEMENTS_PER_EXT_BLOB'].value,
|
||||||
'NUMBER_OF_COLUMNS': spec_object.config_vars['NUMBER_OF_COLUMNS'].value,
|
'NUMBER_OF_COLUMNS': spec_object.config_vars['NUMBER_OF_COLUMNS'].value,
|
||||||
|
'MAX_EXTENDED_MATRIX_SIZE': spec_object.config_vars['MAX_EXTENDED_MATRIX_SIZE'].value,
|
||||||
}
|
}
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
|
|
|
@ -46,7 +46,7 @@ We define the following Python custom types for type hinting and readability:
|
||||||
| Name | SSZ equivalent | Description |
|
| Name | SSZ equivalent | Description |
|
||||||
| - | - | - |
|
| - | - | - |
|
||||||
| `DataColumn` | `List[Cell, MAX_BLOB_COMMITMENTS_PER_BLOCK]` | The data of each column in EIP-7594 |
|
| `DataColumn` | `List[Cell, MAX_BLOB_COMMITMENTS_PER_BLOCK]` | The data of each column in EIP-7594 |
|
||||||
| `ExtendedMatrix` | `List[Cell, MAX_BLOBS_PER_BLOCK * NUMBER_OF_COLUMNS]` | The full data of one-dimensional erasure coding extended blobs (in row major format) |
|
| `ExtendedMatrix` | `List[Cell, MAX_EXTENDED_MATRIX_SIZE]` | The full data of one-dimensional erasure coding extended blobs (in row major format). |
|
||||||
|
|
||||||
## Configuration
|
## Configuration
|
||||||
|
|
||||||
|
@ -55,6 +55,7 @@ We define the following Python custom types for type hinting and readability:
|
||||||
| Name | Value | Description |
|
| Name | Value | Description |
|
||||||
| - | - | - |
|
| - | - | - |
|
||||||
| `NUMBER_OF_COLUMNS` | `uint64(FIELD_ELEMENTS_PER_EXT_BLOB // FIELD_ELEMENTS_PER_CELL)` (= 128) | Number of columns in the extended data matrix. |
|
| `NUMBER_OF_COLUMNS` | `uint64(FIELD_ELEMENTS_PER_EXT_BLOB // FIELD_ELEMENTS_PER_CELL)` (= 128) | Number of columns in the extended data matrix. |
|
||||||
|
| `MAX_EXTENDED_MATRIX_SIZE` | `uint64(MAX_BLOBS_PER_BLOCK * NUMBER_OF_COLUMNS)` (= 768) | The data size of `ExtendedMatrix`. |
|
||||||
|
|
||||||
### Networking
|
### Networking
|
||||||
|
|
||||||
|
|
|
@ -18,6 +18,7 @@ def test_invariants(spec):
|
||||||
assert spec.config.MAX_REQUEST_DATA_COLUMN_SIDECARS == (
|
assert spec.config.MAX_REQUEST_DATA_COLUMN_SIDECARS == (
|
||||||
spec.config.MAX_REQUEST_BLOCKS_DENEB * spec.config.NUMBER_OF_COLUMNS
|
spec.config.MAX_REQUEST_BLOCKS_DENEB * spec.config.NUMBER_OF_COLUMNS
|
||||||
)
|
)
|
||||||
|
assert spec.config.MAX_EXTENDED_MATRIX_SIZE == spec.MAX_BLOBS_PER_BLOCK * spec.config.NUMBER_OF_COLUMNS
|
||||||
|
|
||||||
|
|
||||||
@with_eip7594_and_later
|
@with_eip7594_and_later
|
||||||
|
|
Loading…
Reference in New Issue