-
Notifications
You must be signed in to change notification settings - Fork 1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Last minute cleanups #1244
Last minute cleanups #1244
Conversation
| `MIN_EPOCHS_TO_INACTIVITY_PENALTY` | `2**2` (= 4) | epochs | 25.6 minutes | | ||
|
||
* `MAX_EPOCHS_PER_CROSSLINK` should be a small constant times `SHARD_COUNT // SLOTS_PER_EPOCH`. | ||
| `MIN_ATTESTATION_INCLUSION_DELAY` | `Slot(2**0)` (= 1) | 6 seconds | |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
None of these should be typed as Slot
or Epoch
. "5 slots" is not actually a Slot
. It's a count of something.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is the thing that is being counted here not a Slot
though?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Slot
was called SlotNumber
, as the ID to identify a certain slot; Epoch
and Shard
are as well.
| `EPOCHS_PER_HISTORICAL_VECTOR` | `2**16` (= 65,536) | epochs | ~0.8 years | | ||
| `EPOCHS_PER_SLASHINGS_VECTOR` | `2**13` (= 8,192) | epochs | ~36 days | | ||
| `HISTORICAL_ROOTS_LIMIT` | `2**24` (= 16,777,216) | historical roots | ~26,131 years | | ||
| `EPOCHS_PER_HISTORICAL_VECTOR` | `Epoch(2**16)` (= 65,536) | ~0.8 years | |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ditto
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think I disagree:
- The name
EPOCHS_PER_...
is consistent with theEpoch
type. EPOCHS_PER_HISTORICAL_VECTOR
naturally occurs inEpoch
summations such asepoch + EPOCHS_PER_HISTORICAL_VECTOR - MIN_SEED_LOOKAHEAD
.EPOCHS_PER_HISTORICAL_VECTOR
naturally occurs inEpoch
modular reductions such asepoch % EPOCHS_PER_HISTORICAL_VECTOR
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think in instances where there is a PER
in the name, dimensional analysis dictates that they are not Epochs
, but `Epochs * HistoricalVectors**(-1).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
SLOTS_PER_EPOCH
is defined as "the number of slots in an epoch". That's of type Slot
, not Slot/Epoch
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Disagree. The use of SLOTS_PER_EPOCH
in slot_to_epoch
and in epoch_start_slot
stand counter to your argument.
If SLOTS_PER_EPOCH
is a Slot
then epoch_start_slot
's return type is Epoch*Slot
and epoch_start_slot
is dimensionless.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Historical vector here doesn't represent a type, but a non-typed scalar. So you could say we are multiplying by something that doesn't change the type, only the length. Imho I think the debate is silly, and naming is consistent and clear.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hum, OK. Would you agree that Epochs * HistoricalVectors**(-1)
is the same as Epochs
because HistoricalVectors
is dimensionless? 😂
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't care too much either way. Need to go to sleep soon as I can't think straight anymore 💤
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
😂Fine. :) I am not entirely convinced, but I sort of agree enough on the dimensionlessness HistoricalVectors
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Agreed the need for sleep is real.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Asides for the type of SLOTS_PER_EPOCH
, this looks good to me.
b6bb725
to
ab2001e
Compare
Opened #1251 to get merged before the freeze. 😄 |
closing in favor of #1251. Sorry! we can debate this very aesthetic item tomorrow. |
#1244 without "5 slots is a `Slot`"
BLS_WITHDRAWAL_PREFIX_BYTE
(should beBLS_WITHDRAWAL_PREFIX
)fork_version: bytes=b'\x00' * 4
(should befork_version: Version=Version()
)n
in bothint_to_bytes
andinteger_squareroot
)uint64
overint
in a few placesBLS_WITHDRAWAL_PREFIX
aBytes1
JUSTIFICATION_BITS_LENGTH
in the constants (as opposed to configurations)assert index_count <= 2**40
(there for cryptographic security)